/**
 * Identidade "clarity": layout em pilares verticais, document-like, minimalista e compacto.
 */

/* Inter local (Exemplopadrão_formulario-flat.html) — não depende de CDN externa */
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('/assets/fonts/inter/inter-400.woff2') format('woff2');
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('/assets/fonts/inter/inter-500.woff2') format('woff2');
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('/assets/fonts/inter/inter-600.woff2') format('woff2');
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('/assets/fonts/inter/inter-700.woff2') format('woff2');
}

/* =========================================
   1. RESET / ISOLAMENTO DO LAYOUT LEGADO
========================================= */
html.visual-identity-clarity {
    --bs-font-sans-serif: var(--font-sans, Inter, -apple-system, BlinkMacSystemFont, sans-serif);
    --bs-body-font-family: var(--bs-font-sans-serif);
    --bs-body-font-size: var(--fs-base, 13px);
    --bs-body-font-weight: 400;
    --bs-body-line-height: 1.45;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

html.visual-identity-clarity body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    font-size: var(--fs-base, 13px) !important;
    font-weight: 400 !important;
    line-height: 1.45 !important;
    letter-spacing: 0 !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    background: var(--visual-bg-page) !important;
    color: var(--visual-text-heading) !important;
    overflow: hidden;
}

html.visual-identity-clarity .clarity-layout-root {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    line-height: 1.45;
    letter-spacing: 0;
    -webkit-font-smoothing: antialiased;
}

/* Tipografia flat — tokens do Exemplopadrão_formulario-flat.html */
html.visual-identity-clarity .clarity-layout-root button,
html.visual-identity-clarity .clarity-layout-root input,
html.visual-identity-clarity .clarity-layout-root optgroup,
html.visual-identity-clarity .clarity-layout-root select,
html.visual-identity-clarity .clarity-layout-root textarea,
html.visual-identity-clarity .clarity-layout-root .form-control,
html.visual-identity-clarity .clarity-layout-root .form-select,
html.visual-identity-clarity .clarity-layout-root .btn,
html.visual-identity-clarity .select2-container--default .select2-selection--single .select2-selection__rendered,
html.visual-identity-clarity .select2-search__field,
html.visual-identity-clarity .select2-results__option {
    font-family: inherit;
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-page-body .form-control,
html.visual-identity-clarity .clarity-page-body .form-select,
html.visual-identity-clarity .clarity-form-elegant .form-control,
html.visual-identity-clarity .clarity-form-elegant .form-select {
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    letter-spacing: 0;
}

html.visual-identity-clarity .wrapper {
    display: none !important;
}

html.visual-identity-clarity body > .page-wrapper:not(.clarity-page-wrapper) {
    display: none !important;
}

html.visual-identity-clarity .clarity-layout-root {
    display: flex;
    height: 100vh;
    width: 100%;
    overflow: hidden;
    background: var(--visual-bg-page);
}

/* =========================================
   2. PILAR 1 — ICON RAIL
========================================= */
html.visual-identity-clarity .clarity-icon-rail {
    flex: 0 0 var(--clarity-rail-width, 56px);
    width: var(--clarity-rail-width, 56px);
    height: 100vh;
    background: var(--clarity-rail-bg, #1B2537);
    display: flex;
    flex-direction: column;
    z-index: 1100;
    transition: width 0.25s ease, flex-basis 0.25s ease;
    overflow: hidden;
}

html.visual-identity-clarity body.clarity-rail-expanded {
    --clarity-rail-width: var(--clarity-rail-width-expanded, 200px);
}

html.visual-identity-clarity .clarity-icon-rail__nav {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-between;
    padding: 8px 0;
}

html.visual-identity-clarity .clarity-icon-rail__top,
html.visual-identity-clarity .clarity-icon-rail__bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: 100%;
    padding-left: 8px;
    padding-right: 8px;
    box-sizing: border-box;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__top,
html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__bottom {
    align-items: stretch;
}

html.visual-identity-clarity .clarity-icon-rail__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-bottom: 8px;
    border-radius: 8px;
    overflow: hidden;
    flex-shrink: 0;
    text-decoration: none;
    gap: 0;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__logo {
    width: 100%;
    justify-content: flex-start;
    gap: 10px;
    padding: 0 4px;
    height: auto;
    min-height: 40px;
}

html.visual-identity-clarity .clarity-icon-rail__brand {
    display: none;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__brand {
    display: block;
}

html.visual-identity-clarity .clarity-icon-rail__logo-img {
    max-width: 28px;
    max-height: 28px;
    object-fit: contain;
    filter: brightness(0) invert(1);
}

html.visual-identity-clarity .clarity-icon-rail__divider {
    width: 28px;
    height: 1px;
    margin: 4px auto 8px;
    background: rgba(255, 255, 255, 0.14);
    align-self: center;
    flex-shrink: 0;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__divider {
    width: 100%;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__btn--rail-toggle {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

html.visual-identity-clarity .clarity-icon-rail__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: rgba(255, 255, 255, 0.72);
    font-size: 18px;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.15s, color 0.15s, width 0.25s ease;
    flex-shrink: 0;
    padding: 0;
    gap: 0;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__btn {
    width: 100%;
    justify-content: flex-start;
    gap: 10px;
    padding: 0 10px;
    font-size: 16px;
}

html.visual-identity-clarity .clarity-icon-rail__btn > i {
    flex-shrink: 0;
    width: 20px;
    text-align: center;
}

html.visual-identity-clarity .clarity-icon-rail__label {
    display: none;
    font-size: 0.8125rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
    min-width: 0;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__label {
    display: block;
}

html.visual-identity-clarity .clarity-icon-rail__btn:hover,
html.visual-identity-clarity .clarity-icon-rail__btn.is-active {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

html.visual-identity-clarity .clarity-icon-rail__btn.is-active {
    box-shadow: inset 3px 0 0 var(--visual-action-blue, #2F6FED);
    border-radius: 8px 8px 8px 4px;
}

html.visual-identity-clarity .clarity-icon-rail__avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__avatar {
    width: 100%;
    border-radius: 8px;
    justify-content: flex-start;
    gap: 10px;
    padding: 0 10px;
    height: 40px;
}

html.visual-identity-clarity .clarity-icon-rail__user-label {
    font-size: 0.8125rem;
    font-weight: 500;
}

html.visual-identity-clarity .clarity-icon-rail__user {
    width: 100%;
    display: flex;
    justify-content: center;
}

html.visual-identity-clarity body.clarity-rail-expanded .clarity-icon-rail__user {
    justify-content: stretch;
}

html.visual-identity-clarity .clarity-icon-rail__avatar-initials {
    line-height: 1;
}

html.visual-identity-clarity .clarity-icon-rail__user-menu {
    min-width: 200px;
    z-index: 1200;
    border: 1px solid var(--visual-border, #E5E7EB);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
    padding: 0.35rem 0;
}

html.visual-identity-clarity .clarity-icon-rail__user-menu .dropdown-header {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--visual-text-heading, #1F2937);
    white-space: normal;
    word-break: break-word;
}

html.visual-identity-clarity .clarity-icon-rail__user-menu .dropdown-item {
    font-size: 0.8125rem;
    padding: 0.45rem 1rem;
}

html.visual-identity-clarity .clarity-icon-rail.clarity-icon-rail--user-menu-open {
    overflow: visible;
}

/* =========================================
   3. PILAR 2 — SIDEBAR
========================================= */
html.visual-identity-clarity .clarity-sidebar-wrapper {
    flex: 0 0 var(--clarity-sidebar-width, 240px);
    width: var(--clarity-sidebar-width, 240px);
    height: 100vh;
    background: var(--clarity-sidebar-bg, #FFFFFF);
    border-right: 1px solid var(--visual-border);
    display: flex;
    flex-direction: column;
    transition: width 0.25s ease, margin 0.25s ease;
    z-index: 1050;
}

html.visual-identity-clarity body.clarity-sidebar-collapsed .clarity-sidebar-wrapper {
    flex: 0 0 0;
    width: 0;
    overflow: hidden;
    border-right: none;
}

html.visual-identity-clarity .clarity-sidebar-header {
    flex-shrink: 0;
    padding: 0;
    border-bottom: 1px solid var(--visual-border);
    background: var(--clarity-sidebar-bg, #FFFFFF);
}

html.visual-identity-clarity .clarity-sidebar-toolbar {
    padding: 10px 12px;
    border-bottom: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-sidebar-toolbar__btn,
html.visual-identity-clarity .clarity-page-header__sidebar-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    margin: 0;
    padding: 6px 10px;
    border: none;
    border-radius: var(--visual-radius-sm, 4px);
    background: transparent;
    color: var(--visual-text-muted);
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0;
    cursor: pointer;
    transition: background 0.12s ease, color 0.12s ease;
}

html.visual-identity-clarity .clarity-page-header__sidebar-toggle {
    width: auto;
    flex-shrink: 0;
    margin-right: 4px;
}

html.visual-identity-clarity body.clarity-sidebar-collapsed .clarity-page-header__sidebar-toggle {
    display: none !important;
}

html.visual-identity-clarity .clarity-sidebar-toolbar__btn:hover,
html.visual-identity-clarity .clarity-sidebar-toolbar__btn:focus-visible,
html.visual-identity-clarity .clarity-page-header__sidebar-toggle:hover,
html.visual-identity-clarity .clarity-page-header__sidebar-toggle:focus-visible {
    background: var(--clarity-gray-100, #F4F4F6);
    border-color: transparent;
    color: var(--visual-text-heading);
    outline: none;
}

html.visual-identity-clarity .clarity-sidebar-toolbar__btn .bx,
html.visual-identity-clarity .clarity-page-header__sidebar-toggle .bx {
    font-size: 1rem;
    line-height: 1;
}

html.visual-identity-clarity .clarity-sidebar-empresa {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 2px;
    align-items: center;
    padding: 12px 14px;
}

html.visual-identity-clarity .clarity-sidebar-empresa__pin {
    display: none;
}

html.visual-identity-clarity .clarity-sidebar-empresa__label {
    font-size: var(--fs-xs, 11px);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--clarity-gray-400, #A8A8B2);
    line-height: var(--clarity-label-line-height, 1.2);
}

html.visual-identity-clarity .clarity-sidebar-empresa__name,
html.visual-identity-clarity .clarity-sidebar-empresa__form button {
    font-size: var(--fs-md, 14px);
    font-weight: 600;
    letter-spacing: -0.005em;
    color: var(--visual-text-heading);
    background: none;
    border: none;
    padding: 0;
    text-align: left;
    cursor: pointer;
    line-height: var(--clarity-label-line-height, 1.2);
}

html.visual-identity-clarity .clarity-sidebar-nav {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 8px 0 16px;
}

html.visual-identity-clarity .clarity-sidebar-module__title {
    font-size: var(--fs-xs, 11px);
    font-weight: 600;
    color: var(--clarity-gray-400, #A8A8B2);
    padding: 12px 16px 8px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

html.visual-identity-clarity .clarity-sidebar-section {
    margin: 0;
}

html.visual-identity-clarity .clarity-sidebar-section__toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    margin: 0;
    padding: 7px 16px;
    border: none;
    background: transparent;
    cursor: pointer;
    text-align: left;
    border-radius: 0;
    font-family: inherit;
    transition: background 0.12s ease;
}

html.visual-identity-clarity .clarity-sidebar-section__toggle:hover,
html.visual-identity-clarity .clarity-sidebar-section__toggle:focus-visible {
    background: var(--clarity-gray-100, #F4F4F6);
    outline: none;
}

html.visual-identity-clarity .clarity-sidebar-section.is-open > .clarity-sidebar-section__toggle {
    background: transparent;
}

html.visual-identity-clarity .clarity-sidebar-section__label {
    display: block;
    flex: 1;
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    letter-spacing: 0;
    color: var(--visual-text-heading);
    padding: 0;
    line-height: 1.45;
    text-transform: none;
}

html.visual-identity-clarity .clarity-sidebar-section.is-open > .clarity-sidebar-section__toggle .clarity-sidebar-section__label {
    font-weight: 500;
    color: var(--visual-action-blue, #2F6FED);
}

html.visual-identity-clarity .clarity-sidebar-section__chevron {
    flex-shrink: 0;
    font-size: 1rem;
    color: var(--visual-text-muted);
    transition: transform 0.2s ease;
}

html.visual-identity-clarity .clarity-sidebar-section.is-open .clarity-sidebar-section__chevron {
    transform: rotate(180deg);
    color: var(--visual-action-blue, #2F6FED);
}

html.visual-identity-clarity .clarity-sidebar-section__panel {
    display: none;
    overflow: hidden;
}

html.visual-identity-clarity .clarity-sidebar-section.is-open .clarity-sidebar-section__panel {
    display: block;
}

html.visual-identity-clarity .clarity-sidebar-section__list,
html.visual-identity-clarity .clarity-sidebar-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

html.visual-identity-clarity .clarity-sidebar-section__icon {
    font-size: 1rem;
    opacity: 0.72;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-sidebar-section__list a,
html.visual-identity-clarity .clarity-sidebar-links > li > a {
    display: flex;
    align-items: center;
    gap: 8px;
}

html.visual-identity-clarity .clarity-sidebar-link__icon {
    font-size: 1rem;
    opacity: 0.72;
    flex-shrink: 0;
    width: 1rem;
    text-align: center;
}

html.visual-identity-clarity .clarity-sidebar-section__list li.is-active .clarity-sidebar-link__icon,
html.visual-identity-clarity .clarity-sidebar-links > li.is-active .clarity-sidebar-link__icon,
html.visual-identity-clarity .clarity-sidebar-section.is-open > .clarity-sidebar-section__toggle .clarity-sidebar-section__icon {
    opacity: 1;
}

html.visual-identity-clarity .clarity-sidebar-section__list a {
    padding: 6px 16px 6px 22px;
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    letter-spacing: 0;
    color: var(--visual-text-heading);
    text-decoration: none;
    border-radius: 0;
    line-height: 1.45;
}

html.visual-identity-clarity .clarity-sidebar-links > li > a {
    padding: 7px 16px;
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    letter-spacing: 0;
    color: var(--visual-text-heading);
    text-decoration: none;
    border-radius: 0;
    line-height: 1.45;
}

html.visual-identity-clarity .clarity-sidebar-section__list a:hover,
html.visual-identity-clarity .clarity-sidebar-links > li > a:hover {
    background: var(--clarity-gray-100, #F4F4F6);
}

html.visual-identity-clarity .clarity-sidebar-section__list li.is-active > a,
html.visual-identity-clarity .clarity-sidebar-links > li.is-active > a {
    background: var(--clarity-active-bg, #E8EEF8);
    color: var(--visual-action-blue, #2F6FED);
    font-weight: 500;
    position: relative;
}

html.visual-identity-clarity .clarity-sidebar-section__list li.is-active > a::before,
html.visual-identity-clarity .clarity-sidebar-links > li.is-active > a::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--visual-action-blue, #2F6FED);
}

/* =========================================
   4. PILAR 3 — MAIN CONTENT
========================================= */
html.visual-identity-clarity .clarity-main-content {
    flex: 1;
    min-width: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--visual-bg-page, #fff);
    overflow: hidden;
}

html.visual-identity-clarity .clarity-page-header {
    flex-shrink: 0;
    border-bottom: 1px solid var(--visual-border);
    background: #fff;
    padding: 8px 20px;
}

html.visual-identity-clarity .clarity-page-header__inner {
    display: flex;
    align-items: center;
    gap: 12px 16px;
    min-height: 40px;
}

html.visual-identity-clarity .clarity-page-header__context {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1 1 auto;
    min-width: 0;
}

html.visual-identity-clarity .clarity-page-header__brand-row {
    display: flex;
    align-items: center;
    gap: 10px 12px;
    min-width: 0;
    flex: 1 1 auto;
}

html.visual-identity-clarity .clarity-page-header__empresa {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    flex-shrink: 1;
}

html.visual-identity-clarity .clarity-page-header__badges {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-page-header__title {
    font-size: var(--fs-md, 14px);
    font-weight: 600;
    margin: 0;
    color: var(--visual-text-heading);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.25;
    letter-spacing: -0.01em;
}

html.visual-identity-clarity .clarity-page-header__meta {
    font-size: var(--fs-sm, 12px);
    font-weight: 400;
    color: var(--visual-text-muted);
    letter-spacing: 0;
    white-space: nowrap;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-page-header__search {
    flex: 0 1 300px;
    max-width: 340px;
    margin-left: auto;
}

html.visual-identity-clarity .clarity-page-header__actions {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
    margin-left: 4px;
}

html.visual-identity-clarity .clarity-page-header__icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: none;
    border-radius: var(--visual-radius-sm, 6px);
    background: transparent;
    color: var(--visual-text-muted);
    font-size: 18px;
    cursor: pointer;
    padding: 0;
}

html.visual-identity-clarity .clarity-page-header__icon-btn .alert-count {
    top: 4px;
    right: 4px;
    left: auto;
    width: 16px;
    height: 16px;
    font-size: 10px;
    font-weight: 600;
    line-height: 1;
    background: var(--visual-danger, #E0517A);
}

html.visual-identity-clarity .clarity-page-header__icon-btn .alert-count:empty {
    display: none;
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown {
    min-width: 300px;
    max-width: 360px;
    padding: 0;
    margin-top: 6px !important;
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 6px);
    box-shadow: 0 8px 24px rgba(31, 41, 55, 0.08);
    overflow: hidden;
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown .msg-header {
    padding: 10px 14px;
    border-bottom: 1px solid var(--visual-border);
    background: var(--clarity-gray-50, #FAFAFB);
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown .msg-header-title {
    font-size: var(--fs-md, 14px);
    font-weight: 600;
    color: var(--visual-text-heading);
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown__list,
html.visual-identity-clarity .clarity-page-header .header-notifications-list,
html.visual-identity-clarity .clarity-page-header .header-favoritos-list {
    height: auto !important;
    max-height: 300px;
    min-height: 0;
    overflow-y: auto;
    position: relative;
}

html.visual-identity-clarity .clarity-page-header .header-notifications-list .dropdown-item.alert-item,
html.visual-identity-clarity .clarity-page-header .header-favoritos-list .dropdown-item {
    padding: 10px 14px;
    border-bottom: 1px solid var(--visual-border);
    white-space: normal;
    font-size: var(--fs-sm, 12px);
}

html.visual-identity-clarity .clarity-page-header .header-notifications-list .dropdown-item.alert-item:last-child,
html.visual-identity-clarity .clarity-page-header .header-favoritos-list .dropdown-item:last-child {
    border-bottom: none;
}

html.visual-identity-clarity .clarity-page-header .header-notifications-list .msg-name {
    font-size: var(--fs-sm, 12px);
    font-weight: 600;
    color: var(--visual-text-heading);
    margin-bottom: 2px;
}

html.visual-identity-clarity .clarity-page-header .header-notifications-list .msg-info,
html.visual-identity-clarity .clarity-page-header .header-notifications-list small {
    font-size: var(--fs-xs, 11px);
    color: var(--visual-text-muted);
}

html.visual-identity-clarity .clarity-page-header .header-notifications-list .notify {
    width: 36px;
    height: 36px;
    line-height: 36px;
    font-size: 18px;
    border-radius: var(--visual-radius-sm, 4px);
    margin-right: 0;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown__footer {
    padding: 10px 12px;
    border-top: 1px solid var(--visual-border);
    background: #fff;
}

html.visual-identity-clarity .clarity-page-header .clarity-notifications-footer {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

html.visual-identity-clarity .clarity-page-header .clarity-notifications-footer .btn {
    height: 32px;
    padding: 0 10px;
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    white-space: nowrap;
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown__footer .btn-primary {
    height: 34px;
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    background-color: var(--visual-action-blue) !important;
    border-color: var(--visual-action-blue) !important;
    color: #fff !important;
}

html.visual-identity-clarity .clarity-page-header .clarity-header-dropdown__footer .btn-primary:hover {
    background-color: var(--visual-action-blue-alt) !important;
    border-color: var(--visual-action-blue-alt) !important;
}

html.visual-identity-clarity .clarity-page-header__icon-btn:hover {
    background: var(--clarity-table-hover-bg, #F9FAFB);
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .clarity-page-header__search-box {
    position: relative;
}

html.visual-identity-clarity .clarity-page-header__search-box i {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--visual-text-muted);
    font-size: 16px;
    pointer-events: none;
}

html.visual-identity-clarity .clarity-page-header__search-box .search-control {
    padding-left: 32px;
    height: var(--clarity-element-sm, 34px);
    font-size: var(--fs-sm, 12px);
    font-weight: 400;
    letter-spacing: 0;
    border-radius: var(--visual-radius-sm, 4px);
    border: 1px solid var(--visual-border);
    background: var(--clarity-gray-50, #FAFAFB);
    font-family: inherit;
}

html.visual-identity-clarity .clarity-page-header__mobile-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    padding: 0;
    border: none;
    border-radius: var(--visual-radius-sm, 4px);
    background: transparent;
    color: var(--visual-text-heading);
    font-size: 22px;
}

html.visual-identity-clarity .clarity-page-body {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    background: var(--visual-bg-page);
}

html.visual-identity-clarity .clarity-page-wrapper {
    margin: 0 !important;
    padding: 20px 24px 28px !important;
    width: 100% !important;
    max-width: 100% !important;
    background: transparent;
}

/* =========================================
   5. SCROLLBARS (Strict UI)
========================================= */
html.visual-identity-clarity .clarity-scrollbar,
html.visual-identity-clarity .clarity-main-content,
html.visual-identity-clarity .clarity-page-body,
html.visual-identity-clarity .clarity-sidebar-nav {
    scrollbar-width: thin;
    scrollbar-color: var(--clarity-scrollbar-thumb, #E5E7EB) transparent;
}

html.visual-identity-clarity .clarity-page-body::-webkit-scrollbar,
html.visual-identity-clarity .clarity-sidebar-nav::-webkit-scrollbar {
    width: var(--clarity-scrollbar-width, 6px);
}

html.visual-identity-clarity .clarity-page-body::-webkit-scrollbar-track,
html.visual-identity-clarity .clarity-sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}

html.visual-identity-clarity .clarity-page-body::-webkit-scrollbar-thumb,
html.visual-identity-clarity .clarity-sidebar-nav::-webkit-scrollbar-thumb {
    background: var(--clarity-scrollbar-thumb, #E5E7EB);
    border-radius: 999px;
}

/* =========================================
   6. COMPONENTES — GHOST, BOTÕES, INPUTS
========================================= */
html.visual-identity-clarity .badge-clarity-ghost {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.2;
    color: var(--visual-text-muted);
    background: transparent;
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-sm, 6px);
}

html.visual-identity-clarity .badge-clarity-ghost--warning {
    color: var(--clarity-ghost-warning-text, #D97706);
    border-color: var(--clarity-ghost-warning-border, #F59E0B);
}

html.visual-identity-clarity .btn-clarity-ghost {
    background: transparent;
    border: 1px solid var(--clarity-border-strong, var(--visual-border));
    color: var(--visual-text-heading);
    height: var(--clarity-element-sm, 34px);
    padding: 7px 16px;
    font-size: var(--fs-base, 13px);
    font-weight: 500;
    font-family: inherit;
    letter-spacing: 0;
    border-radius: var(--visual-radius-sm, 4px);
    transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}

html.visual-identity-clarity .btn-clarity-ghost:hover {
    background: var(--clarity-gray-100, #F4F4F6);
    border-color: var(--clarity-border-strong, var(--visual-border));
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .btn-clarity-text {
    background: transparent;
    border: 1px solid transparent;
    color: var(--visual-text-muted);
    height: var(--clarity-element-sm, 34px);
    padding: 7px 16px;
    font-size: var(--fs-base, 13px);
    font-weight: 500;
    font-family: inherit;
    letter-spacing: 0;
    border-radius: var(--visual-radius-sm, 4px);
    transition: background 0.12s ease, color 0.12s ease;
}

html.visual-identity-clarity .btn-clarity-text:hover {
    background: var(--clarity-gray-100, #F4F4F6);
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .clarity-page-body .form-control,
html.visual-identity-clarity .clarity-page-body .form-select,
html.visual-identity-clarity .clarity-page-body .btn {
    min-height: var(--clarity-element-sm, 34px);
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    letter-spacing: 0;
    border-radius: var(--visual-radius-sm, 4px);
    transition: border-color 0.12s ease, box-shadow 0.12s ease, background 0.12s ease;
}

html.visual-identity-clarity .clarity-page-body .form-control,
html.visual-identity-clarity .clarity-page-body .form-select {
    border-color: var(--clarity-border-strong, var(--visual-border));
    color: var(--visual-text-heading);
    background-color: var(--visual-bg-card, #fff);
    padding: 8px 12px;
}

html.visual-identity-clarity .clarity-page-body .form-control:hover,
html.visual-identity-clarity .clarity-page-body .form-select:hover {
    border-color: var(--clarity-gray-400, #A8A8B2);
}

html.visual-identity-clarity .clarity-page-body .form-control:focus,
html.visual-identity-clarity .clarity-page-body .form-select:focus {
    border-color: var(--visual-action-blue);
    box-shadow: 0 0 0 3px rgba(47, 111, 237, 0.12);
    outline: none;
}

html.visual-identity-clarity .clarity-page-body .form-select {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7A85' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 30px;
}

html.visual-identity-clarity .clarity-page-body .btn-primary,
html.visual-identity-clarity .btn-clarity-primary {
    background-color: var(--visual-action-blue) !important;
    border-color: var(--visual-action-blue) !important;
    color: #fff !important;
    font-weight: 500;
}

html.visual-identity-clarity .clarity-page-body .btn-primary:hover,
html.visual-identity-clarity .btn-clarity-primary:hover {
    background-color: var(--visual-action-blue-alt) !important;
    border-color: var(--visual-action-blue-alt) !important;
    filter: none;
}

html.visual-identity-clarity .clarity-page-body .btn-success,
html.visual-identity-clarity .clarity-content-header__actions .btn-success {
    background-color: var(--visual-action-blue) !important;
    border-color: var(--visual-action-blue) !important;
    color: #fff !important;
    font-weight: 500;
}

html.visual-identity-clarity .clarity-page-body .btn-success:hover,
html.visual-identity-clarity .clarity-content-header__actions .btn-success:hover {
    background-color: var(--visual-action-blue-alt) !important;
    border-color: var(--visual-action-blue-alt) !important;
}

html.visual-identity-clarity .clarity-page-body .text-primary {
    color: var(--visual-action-blue) !important;
}

html.visual-identity-clarity .clarity-page-body .border-primary {
    border-color: var(--visual-border) !important;
}

html.visual-identity-clarity .clarity-page-body .btn-sm {
    min-height: var(--clarity-element-xs, 28px);
    padding: 4px 12px;
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-page-body .form-label,
html.visual-identity-clarity .clarity-page-body .col-form-label,
html.visual-identity-clarity .clarity-form-elegant .form-group > label:not(.form-check-label),
html.visual-identity-clarity .clarity-form-elegant label.required,
html.visual-identity-clarity .clarity-form-field > label:not(.form-check-label) {
    font-family: inherit;
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    line-height: var(--clarity-label-line-height, 1.45);
    color: var(--visual-text-heading);
    margin-bottom: 6px;
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-field-required {
    color: var(--clarity-required, #D14C6F);
}

html.visual-identity-clarity .clarity-page-body .card {
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 8px);
    box-shadow: none;
    background: #fff;
}

/* =========================================
   7. TABELAS LIMPAS
========================================= */
html.visual-identity-clarity .clarity-page-body .table {
    border-collapse: collapse;
    --bs-table-bg: #fff;
    --bs-table-striped-bg: #fff;
    --bs-table-hover-bg: var(--clarity-table-hover-bg, #FAFAFB);
}

html.visual-identity-clarity .clarity-page-body .table-striped > tbody > tr:nth-of-type(odd) > * {
    --bs-table-accent-bg: #fff;
    background-color: #fff !important;
}

html.visual-identity-clarity .clarity-page-body .table > :not(caption) > * > * {
    border-left: none !important;
    border-right: none !important;
    border-bottom: 1px solid var(--visual-border);
    padding: 8px 12px;
    font-size: 0.8125rem;
    vertical-align: middle;
}

html.visual-identity-clarity .clarity-page-body .table thead th {
    background: var(--visual-table-head-bg, #F3F4F6);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--visual-text-muted);
    border-bottom: 1px solid var(--visual-border);
    box-shadow: none;
}

html.visual-identity-clarity .clarity-page-body .table-hover > tbody > tr:hover > * {
    background-color: var(--clarity-table-hover-bg, #FAFAFB) !important;
}

/* =========================================
   7B. CONTEÚDO PRINCIPAL (page-content)
========================================= */
html.visual-identity-clarity .clarity-page-wrapper > .row,
html.visual-identity-clarity .clarity-page-wrapper > .page-content {
    margin-left: 0 !important;
    margin-right: 0 !important;
    --bs-gutter-x: 0;
    max-width: 100%;
}

html.visual-identity-clarity .clarity-page-body .page-content {
    padding: 0 !important;
    background: transparent;
}

html.visual-identity-clarity .clarity-page-wrapper > .row > .page-content:only-child,
html.visual-identity-clarity .clarity-page-wrapper > .page-content:only-child,
html.visual-identity-clarity .clarity-page-panel {
    background: var(--visual-bg-card, #fff);
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 6px);
    box-shadow: var(--visual-shadow-panel, none);
}

html.visual-identity-clarity .clarity-page-content {
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

html.visual-identity-clarity .clarity-page-content .clarity-page-panel__inner {
    padding: 0;
}

html.visual-identity-clarity h1,
html.visual-identity-clarity h2,
html.visual-identity-clarity h3,
html.visual-identity-clarity h4,
html.visual-identity-clarity h5,
html.visual-identity-clarity h6 {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    font-weight: 600;
    letter-spacing: -0.015em;
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .clarity-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    margin: 0 0 12px;
    font-size: var(--fs-sm, 12px);
    font-weight: 400;
    line-height: 1.4;
    color: var(--visual-text-muted);
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-breadcrumb__sep {
    font-size: 14px;
    color: var(--clarity-gray-400, #A8A8B2);
}

html.visual-identity-clarity .clarity-breadcrumb__current {
    color: var(--visual-text-heading);
    font-weight: 500;
}

html.visual-identity-clarity .clarity-page-panel__inner {
    padding: 1.25rem 1.5rem 1.5rem;
}

html.visual-identity-clarity .clarity-page-panel__body > *:last-child {
    margin-bottom: 0;
}

html.visual-identity-clarity .clarity-page-panel__section {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-page-panel__section:first-child,
html.visual-identity-clarity .clarity-content-header + .clarity-page-panel__section {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

/* Sub-cabeçalho da página */
html.visual-identity-clarity .clarity-content-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px 16px;
    margin-bottom: 20px;
}

html.visual-identity-clarity .clarity-content-header__main {
    flex: 1;
    min-width: 0;
}

html.visual-identity-clarity .clarity-content-header__title {
    margin: 0;
    font-family: inherit;
    font-size: var(--fs-xl, 20px);
    font-weight: 600;
    line-height: 1.3;
    color: var(--visual-text-heading);
    letter-spacing: -0.015em;
}

html.visual-identity-clarity .clarity-content-header__description {
    margin: 4px 0 0;
    font-size: var(--fs-md, 14px);
    font-weight: 400;
    line-height: 1.45;
    color: var(--visual-text-muted);
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-content-header__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-shrink: 0;
}

/* Toolbar de seção (filtros + ações) */
html.visual-identity-clarity .clarity-content-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 1rem;
}

html.visual-identity-clarity .clarity-content-toolbar__start,
html.visual-identity-clarity .clarity-content-toolbar__end {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

html.visual-identity-clarity .clarity-content-toolbar__title {
    margin: 0;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--visual-text-heading);
}

/* Barra de filtros */
html.visual-identity-clarity .clarity-filter-bar {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 12px;
    align-items: end;
    margin-bottom: 1rem;
    padding: 1rem;
    background: var(--clarity-filter-bg, #FAFAFB);
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 8px);
}

html.visual-identity-clarity .clarity-filter-bar__fields {
    display: contents;
}

html.visual-identity-clarity .clarity-filter-bar__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 8px;
    grid-column: 1 / -1;
    justify-content: flex-end;
}

@media (min-width: 768px) {
    html.visual-identity-clarity .clarity-filter-bar:has(.clarity-filter-bar__fields > :only-child) {
        grid-template-columns: 1fr auto;
    }

    html.visual-identity-clarity .clarity-filter-bar:has(.clarity-filter-bar__fields > :only-child) .clarity-filter-bar__actions {
        grid-column: auto;
    }
}

html.visual-identity-clarity .clarity-filter-bar .form-label {
    margin-bottom: 4px;
}

html.visual-identity-clarity .clarity-filter-accordion .accordion-button {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--visual-text-heading);
    background: var(--clarity-filter-bg, #FAFAFB);
    box-shadow: none;
}

html.visual-identity-clarity .clarity-filter-accordion .accordion-button:not(.collapsed) {
    color: var(--visual-action-blue);
    background: rgba(47, 111, 237, 0.06);
}

/* Upload / file input */
html.visual-identity-clarity .clarity-upload-zone {
    padding: 1rem;
    border: 1px dashed var(--visual-border);
    border-radius: var(--visual-radius-md, 8px);
    background: var(--clarity-filter-bg, #FAFAFB);
}

html.visual-identity-clarity .clarity-page-body .form-control[type="file"] {
    padding: 0.5rem;
    background: #fff;
}

html.visual-identity-clarity .clarity-page-body .form-control[type="file"]::file-selector-button {
    margin-right: 12px;
    padding: 6px 12px;
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-sm, 6px);
    background: #fff;
    color: var(--visual-text-heading);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
}

/* Botões — hierarquia no conteúdo */
html.visual-identity-clarity .clarity-page-body .page-content .btn-success:not(.badge):not(span),
html.visual-identity-clarity .clarity-page-body .clarity-content-header__actions .btn-success,
html.visual-identity-clarity .clarity-page-body .clarity-content-toolbar .btn-success {
    background-color: var(--visual-action-blue) !important;
    border-color: var(--visual-action-blue) !important;
    color: #fff !important;
}

html.visual-identity-clarity .clarity-page-body .page-content .btn-success:not(.badge):not(span):hover,
html.visual-identity-clarity .clarity-page-body .clarity-content-header__actions .btn-success:hover,
html.visual-identity-clarity .clarity-page-body .clarity-content-toolbar .btn-success:hover {
    background-color: var(--visual-action-blue-alt, #2563EB) !important;
    border-color: var(--visual-action-blue-alt, #2563EB) !important;
    filter: none;
}

html.visual-identity-clarity .clarity-page-body .clarity-content-toolbar .btn-warning,
html.visual-identity-clarity .clarity-page-body .page-content .btn-warning:not(.badge) {
    background-color: #F59E0B !important;
    border-color: #D97706 !important;
    color: #fff !important;
}

html.visual-identity-clarity .btn-clarity-primary {
    background-color: var(--visual-action-blue) !important;
    border-color: var(--visual-action-blue) !important;
    color: #fff !important;
}

html.visual-identity-clarity .btn-clarity-secondary {
    background: transparent !important;
    border: 1px solid var(--clarity-border-strong, var(--visual-border)) !important;
    color: var(--visual-text-heading) !important;
    font-weight: 500;
}

html.visual-identity-clarity .btn-clarity-secondary:hover {
    background: var(--clarity-gray-100, #F4F4F6) !important;
}

/* Alertas */
html.visual-identity-clarity .clarity-page-body .alert {
    border-radius: var(--visual-radius-md, 8px);
    border-width: 1px;
    font-size: 0.8125rem;
    padding: 10px 14px;
}

html.visual-identity-clarity .clarity-alert {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 14px;
    border-radius: var(--visual-radius-md, 8px);
    border: 1px solid var(--visual-border);
    font-size: 0.8125rem;
    line-height: 1.45;
}

html.visual-identity-clarity .clarity-alert__icon {
    flex-shrink: 0;
    font-size: 1.125rem;
    line-height: 1.2;
    margin-top: 1px;
}

html.visual-identity-clarity .clarity-alert__content {
    flex: 1;
    min-width: 0;
}

html.visual-identity-clarity .clarity-alert__title {
    display: block;
    margin-bottom: 2px;
    font-weight: 600;
}

html.visual-identity-clarity .clarity-alert__message ul {
    margin-bottom: 0;
}

html.visual-identity-clarity .clarity-alert__close {
    flex-shrink: 0;
    margin-top: 2px;
}

html.visual-identity-clarity .clarity-alert--success {
    background-color: #ECFDF5;
    border-color: #A7F3D0;
    color: #065F46;
}

html.visual-identity-clarity .clarity-alert--success .clarity-alert__icon {
    color: var(--visual-success, #10B981);
}

html.visual-identity-clarity .clarity-alert--danger {
    background-color: #FEF2F2;
    border-color: #FECACA;
    color: #991B1B;
}

html.visual-identity-clarity .clarity-alert--danger .clarity-alert__icon {
    color: var(--visual-danger, #EF4444);
}

html.visual-identity-clarity .clarity-alert--warning {
    background-color: #FFFBEB;
    border-color: #FDE68A;
    color: #92400E;
}

html.visual-identity-clarity .clarity-alert--warning .clarity-alert__icon {
    color: var(--visual-warning, #F59E0B);
}

html.visual-identity-clarity .clarity-alert--info {
    background-color: #EFF6FF;
    border-color: #BFDBFE;
    color: #1E40AF;
}

html.visual-identity-clarity .clarity-alert--info .clarity-alert__icon {
    color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-page-body .alert-warning {
    background-color: #FFFBEB;
    border-color: #FDE68A;
    color: #92400E;
}

html.visual-identity-clarity .clarity-page-body .alert-success {
    background-color: #ECFDF5;
    border-color: #A7F3D0;
    color: #065F46;
}

html.visual-identity-clarity .clarity-page-body .alert-danger {
    background-color: #FEF2F2;
    border-color: #FECACA;
    color: #991B1B;
}

html.visual-identity-clarity .clarity-page-body .alert-info {
    background-color: #EFF6FF;
    border-color: #BFDBFE;
    color: #1E40AF;
}

/* Tabela moderna (design system) */
html.visual-identity-clarity .clarity-page-body .table-modern th,
html.visual-identity-clarity .clarity-page-body .table-modern td {
    border-left: none !important;
    border-right: none !important;
}

html.visual-identity-clarity .clarity-page-body .table-modern thead {
    background: var(--visual-table-head-bg, #F8FAFB);
    border-bottom: 1.5px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-page-body .table-modern tbody tr {
    border-bottom: 1px solid #f0f2f5;
}

html.visual-identity-clarity .clarity-page-body .text-truncate-cell {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

html.visual-identity-clarity .clarity-page-body .sticky-col {
    position: sticky;
    background: #fff !important;
    z-index: 5;
}

html.visual-identity-clarity .clarity-page-body .sticky-col-01 { left: 0; width: 40px; min-width: 40px; max-width: 40px; }
html.visual-identity-clarity .clarity-page-body .sticky-col-02 { left: 40px; width: 40px; min-width: 40px; max-width: 40px; }
html.visual-identity-clarity .clarity-page-body .sticky-col-03 {
    left: 80px;
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    box-shadow: 5px 0 8px -4px rgba(70, 70, 70, 0.1);
    z-index: 6;
}

html.visual-identity-clarity .clarity-page-body tr:hover .sticky-col {
    background: #fff !important;
}

html.visual-identity-clarity .clarity-page-body .th-sort-link {
    color: inherit;
    text-decoration: none;
    font-weight: 600;
}

html.visual-identity-clarity .clarity-page-body .th-sort-link:hover {
    color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-page-body .bulk-actions-panel {
    position: fixed;
    top: 90px;
    left: 50%;
    transform: translateX(-50%);
    width: min(960px, calc(100% - 40px));
    z-index: 1055;
    border-radius: 0.85rem;
    background: #fff;
    border: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-page-body .table-container {
    min-height: 200px;
}

html.visual-identity-clarity .clarity-session-alert {
    margin-bottom: 1rem;
}

html.visual-identity-clarity .clarity-session-alert + .clarity-session-alert {
    margin-top: -0.5rem;
}

html.visual-identity-clarity .clarity-table-pagination__per-page .form-label {
    font-size: 0.8125rem;
}

html.visual-identity-clarity .clarity-page-body .text-truncate-cell:hover {
    white-space: normal !important;
    word-wrap: break-word;
    overflow: visible;
    background-color: var(--clarity-gray-100, #F4F4F6);
    position: relative;
    z-index: 10;
}

html.visual-identity-clarity .clarity-page-body .text-truncate-sm { max-width: 120px; }
html.visual-identity-clarity .clarity-page-body .text-truncate-md { max-width: 200px; }
html.visual-identity-clarity .clarity-page-body .text-truncate-lg { max-width: 300px; }
html.visual-identity-clarity .clarity-page-body .text-truncate-xl { max-width: 400px; }

html.visual-identity-clarity .clarity-page-body .table-modern tfoot.clarity-table-tfoot-totals td {
    background: var(--clarity-gray-100, #F4F4F6);
    border-top: 1.5px solid var(--visual-border) !important;
    font-weight: 600;
    font-size: 0.8125rem;
}

html.visual-identity-clarity .clarity-page-body .clarity-table-link {
    color: var(--visual-action-blue);
    font-weight: 600;
    text-decoration: none;
    transition: color 0.2s ease;
}

html.visual-identity-clarity .clarity-page-body .clarity-table-link:hover {
    color: var(--visual-action-blue-alt, #2563EB);
    text-decoration: underline;
}

html.visual-identity-clarity .clarity-page-body .clarity-table-link .bx {
    font-size: 0.7rem;
    opacity: 0.55;
    transition: opacity 0.2s ease;
}

html.visual-identity-clarity .clarity-page-body .clarity-table-link:hover .bx {
    opacity: 1;
}

/* Filtros empilhados (relatórios com múltiplas linhas de campos) */
html.visual-identity-clarity .clarity-filter-bar--stacked {
    display: block;
}

html.visual-identity-clarity .clarity-filter-bar--stacked .clarity-filter-bar__fields {
    display: block;
}

html.visual-identity-clarity .clarity-filter-bar--stacked .clarity-filter-bar__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 12px;
    grid-column: unset;
}

html.visual-identity-clarity .clarity-date-range {
    display: flex;
    gap: 8px;
}

html.visual-identity-clarity .clarity-date-range .form-control {
    min-width: 0;
    flex: 1 1 0;
}

html.visual-identity-clarity .clarity-filter-bar--stacked .select2-container--bootstrap4 .select2-selection--single {
    height: var(--clarity-element-sm, 34px);
    min-height: var(--clarity-element-sm, 34px);
    padding: 0.25rem 0.5rem;
    font-size: 0.8125rem;
}

html.visual-identity-clarity .clarity-filter-bar--stacked .select2-container--bootstrap4 .select2-selection--single .select2-selection__rendered {
    line-height: 1.45;
    padding-left: 0;
    padding-right: 1.5rem;
}

html.visual-identity-clarity .clarity-filter-bar--stacked .select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow {
    top: 50%;
    transform: translateY(-50%);
    height: auto;
}

html.visual-identity-clarity .clarity-filter-bar--stacked .select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow b {
    top: 50%;
    left: 50%;
    margin: 0;
    transform: translate(-50%, -50%);
}

/* Cards legados dentro do painel — sem borda dupla */
html.visual-identity-clarity .clarity-page-body .table-modern th a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s;
}

html.visual-identity-clarity .clarity-page-body .table-modern th a:hover {
    color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-page-body .first-mobile-col {
    padding-left: 24px !important;
}

@media (max-width: 700px) {
    html.visual-identity-clarity .clarity-page-body .sticky-col-01,
    html.visual-identity-clarity .clarity-page-body .sticky-col-02,
    html.visual-identity-clarity .clarity-page-body .sticky-col-03 {
        width: 32px;
        min-width: 32px;
        max-width: 32px;
    }

    html.visual-identity-clarity .clarity-page-body .first-mobile-col {
        padding-left: 10px !important;
    }
}

html.visual-identity-clarity .clarity-page-body .bulk-actions-panel .btn-light {
    transition: background-color 0.2s ease, color 0.2s ease;
}

html.visual-identity-clarity .clarity-page-body .bulk-actions-panel .btn-light:hover {
    background-color: #f8f9fa;
}

html.visual-identity-clarity .clarity-table-empty {
    padding: 2.5rem 1rem;
    text-align: center;
    color: var(--visual-text-muted);
}

html.visual-identity-clarity .clarity-table-empty__icon {
    font-size: 2.5rem;
    opacity: 0.35;
    margin-bottom: 0.75rem;
    display: block;
}

html.visual-identity-clarity .clarity-table-empty__message {
    margin: 0 0 1rem;
    font-size: 0.875rem;
}

/* Cards legados dentro do painel — sem borda dupla */
html.visual-identity-clarity .clarity-page-panel .card {
    border: none;
    box-shadow: none;
    background: transparent;
}

html.visual-identity-clarity .clarity-page-panel .card > .card-body {
    padding: 0;
}

html.visual-identity-clarity .clarity-page-panel .card .card {
    border: 1px solid var(--visual-border);
    background: #fff;
}

html.visual-identity-clarity .clarity-page-panel .card .card > .card-body {
    padding: 1rem;
}

/* Seções de formulário (create/edit) — layout elegante */
html.visual-identity-clarity .clarity-form-elegant {
    --clarity-form-panel-bg: var(--visual-bg-card, #fff);
    --clarity-form-panel-radius: var(--visual-radius-md, 6px);
}

html.visual-identity-clarity .clarity-form-panel {
    background: var(--clarity-form-panel-bg);
    border: 1px solid var(--visual-border);
    border-radius: var(--clarity-form-panel-radius);
    margin-bottom: 16px;
    overflow: hidden;
}

html.visual-identity-clarity .clarity-form-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 0;
    padding: 16px 20px;
    border-bottom: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-form-panel__body,
html.visual-identity-clarity .clarity-form-panel > :not(.clarity-form-panel__head):not(.clarity-form-panel__hint) {
    padding: 20px;
}

html.visual-identity-clarity .clarity-form-panel__head + *:not(.clarity-form-panel__hint) {
    padding: 20px;
}

html.visual-identity-clarity .clarity-form-panel:last-of-type {
    margin-bottom: 0;
}

html.visual-identity-clarity .clarity-form-panel--highlight {
    background: linear-gradient(135deg, #fffbeb 0%, #fff 48%);
    border-color: #fde68a;
}

html.visual-identity-clarity .clarity-form-section {
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-form-section:last-of-type {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

html.visual-identity-clarity .clarity-form-section--accent-warning {
    padding: 1rem;
    margin-bottom: 1.25rem;
    border: 1px solid var(--visual-border);
    border-left: 3px solid var(--color-warning, #f59e0b);
    border-radius: var(--visual-radius-md, 8px);
    background: #fff;
}

html.visual-identity-clarity .clarity-form-panel__head-main {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

html.visual-identity-clarity .clarity-form-section__head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 1rem;
}

html.visual-identity-clarity .clarity-form-section__icon,
html.visual-identity-clarity .clarity-form-panel__icon {
    width: 32px;
    height: 32px;
    border-radius: var(--visual-radius-sm, 4px);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
}

html.visual-identity-clarity .clarity-form-section__icon--primary,
html.visual-identity-clarity .clarity-form-panel__icon--primary {
    background: rgba(47, 111, 237, 0.1);
    color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-form-section__icon--info,
html.visual-identity-clarity .clarity-form-panel__icon--info {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

html.visual-identity-clarity .clarity-form-section__icon--warning,
html.visual-identity-clarity .clarity-form-panel__icon--warning {
    background: rgba(245, 158, 11, 0.12);
    color: #f59e0b;
}

html.visual-identity-clarity .clarity-form-section__icon--muted,
html.visual-identity-clarity .clarity-form-panel__icon--muted {
    background: var(--clarity-gray-100, #F4F4F6);
    color: var(--visual-text-muted);
}

html.visual-identity-clarity .clarity-form-section__title,
html.visual-identity-clarity .clarity-form-panel__title {
    margin: 0;
    font-size: var(--fs-md, 14px);
    font-weight: 600;
    letter-spacing: -0.005em;
    color: var(--visual-text-heading);
    line-height: 1.3;
}

html.visual-identity-clarity .clarity-form-panel__subtitle {
    margin: 2px 0 0;
    font-size: var(--fs-sm, 12px);
    font-weight: 400;
    line-height: 1.45;
    color: var(--visual-text-muted);
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-form-section__hint,
html.visual-identity-clarity .clarity-form-panel__hint {
    margin: 0 20px 20px;
    padding: 0.65rem 0.85rem;
    font-size: 0.75rem;
    line-height: 1.45;
    color: var(--visual-text-muted);
    background: rgba(47, 111, 237, 0.04);
    border-radius: 8px;
    border: 1px solid rgba(47, 111, 237, 0.08);
}

html.visual-identity-clarity .clarity-form-panel__hint i {
    color: var(--visual-action-blue);
    margin-right: 4px;
}

/* Cards de escolha (tipo de conta) */
html.visual-identity-clarity .clarity-choice-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

html.visual-identity-clarity .clarity-choice-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 108px;
    padding: 1rem 0.75rem;
    margin: 0;
    text-align: center;
    background: #fff;
    border: 1.5px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 6px);
    cursor: pointer;
    transition: border-color 0.12s ease, background-color 0.12s ease;
}

html.visual-identity-clarity .clarity-choice-card:hover {
    border-color: #c7d2fe;
    box-shadow: 0 4px 14px rgba(47, 111, 237, 0.08);
    transform: translateY(-1px);
}

html.visual-identity-clarity .clarity-choice-card:has(.form-check-input:checked) {
    border-color: var(--visual-action-blue);
    background: linear-gradient(180deg, rgba(47, 111, 237, 0.07) 0%, #fff 70%);
    box-shadow: 0 0 0 1px rgba(47, 111, 237, 0.12);
}

html.visual-identity-clarity .clarity-choice-card .form-check-input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

html.visual-identity-clarity .clarity-choice-card__badge {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 20px;
    height: 20px;
    border-radius: 999px;
    border: 1.5px solid var(--visual-border);
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: transparent;
    transition: all 0.2s ease;
}

html.visual-identity-clarity .clarity-choice-card:has(.form-check-input:checked) .clarity-choice-card__badge {
    background: var(--visual-action-blue);
    border-color: var(--visual-action-blue);
    color: #fff;
}

html.visual-identity-clarity .clarity-choice-card__icon {
    width: 44px;
    height: 44px;
    border-radius: var(--visual-radius-md, 6px);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
}

html.visual-identity-clarity .clarity-choice-card--blue .clarity-choice-card__icon {
    background: rgba(59, 130, 246, 0.12);
    color: #3b82f6;
}

html.visual-identity-clarity .clarity-choice-card--green .clarity-choice-card__icon {
    background: rgba(16, 185, 129, 0.12);
    color: #10b981;
}

html.visual-identity-clarity .clarity-choice-card--amber .clarity-choice-card__icon {
    background: rgba(245, 158, 11, 0.12);
    color: #f59e0b;
}

html.visual-identity-clarity .clarity-choice-card--rose .clarity-choice-card__icon {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

html.visual-identity-clarity .clarity-choice-card__label {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--visual-text-muted);
    line-height: 1.25;
}

html.visual-identity-clarity .clarity-choice-card:has(.form-check-input:checked) .clarity-choice-card__label {
    color: var(--visual-text-heading);
    font-weight: 600;
}

/* Campos dentro de painéis */
html.visual-identity-clarity .clarity-form-elegant .form-control,
html.visual-identity-clarity .clarity-form-elegant .form-select,
html.visual-identity-clarity .clarity-form-elegant .select2-container--default .select2-selection--single {
    background-color: var(--visual-bg-card, #fff);
    border-color: var(--clarity-border-strong, var(--visual-border));
    box-shadow: none;
    min-height: var(--clarity-element-sm, 34px);
}

html.visual-identity-clarity .clarity-form-elegant .form-control:focus,
html.visual-identity-clarity .clarity-form-elegant .form-select:focus {
    border-color: var(--visual-action-blue);
    box-shadow: 0 0 0 3px rgba(47, 111, 237, 0.12);
}

html.visual-identity-clarity .clarity-form-elegant .select2-container--default .select2-selection--single {
    min-height: var(--clarity-element-sm, 32px);
    border-color: #e5e7eb;
    border-radius: var(--visual-radius-sm, 6px);
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
}

html.visual-identity-clarity .clarity-form-elegant .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: calc(var(--clarity-element-sm, 34px) - 2px);
    font-size: var(--fs-base, 13px);
    font-weight: 400;
    color: var(--visual-text-heading);
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-form-elegant .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: calc(var(--clarity-element-sm, 32px) - 2px);
}

/* Select2 — respeitar largura da coluna (evita sobreposição com menu expandido) */
html.visual-identity-clarity .clarity-page-body .select2-container,
html.visual-identity-clarity .clarity-filter-bar .select2-container {
    width: 100% !important;
    max-width: 100%;
    box-sizing: border-box;
}

html.visual-identity-clarity .clarity-page-body .row > [class*="col-"],
html.visual-identity-clarity .clarity-filter-bar .row > [class*="col-"],
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel .row > [class*="col-"] {
    min-width: 0;
}

html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row {
    --bs-gutter-x: 16px;
    --bs-gutter-y: 16px;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > [class*="col-"],
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > [class*="col-"] {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    grid-column: span 1;
}

html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-8,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-7,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-8,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-7 {
    grid-column: span 3;
}

html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-6,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-6 {
    grid-column: span 2;
}

html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-12,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-12,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-12,
html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-12 {
    grid-column: span 4;
}

@media (max-width: 1100px) {
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-8,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-7,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-md-12,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > .row > .col-12,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-8,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-7,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-md-12,
    html.visual-identity-clarity .clarity-form-elegant .clarity-form-panel > form > .row > .col-12 {
        grid-column: span 2;
    }
}

html.visual-identity-clarity .clarity-form-field-hint {
    display: block;
    margin-top: 4px;
    font-size: 0.6875rem;
    line-height: 1.35;
    color: var(--visual-text-muted);
}

html.visual-identity-clarity .clarity-field-label-info {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 4px;
    padding: 0;
    border: none;
    background: none;
    color: var(--visual-text-muted);
    font-size: 14px;
    line-height: 1;
    vertical-align: middle;
    cursor: help;
    transition: color 0.15s ease;
}

html.visual-identity-clarity .clarity-field-label-info:hover,
html.visual-identity-clarity .clarity-field-label-info:focus {
    color: var(--visual-action-blue);
    outline: none;
}

html.visual-identity-clarity .form-label .clarity-field-label-info {
    vertical-align: -2px;
}

html.visual-identity-clarity .clarity-tipo-conta-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
    gap: 10px;
}

html.visual-identity-clarity .clarity-tipo-conta-item {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 44px;
    padding: 8px 12px;
    background: #fff;
    border-radius: var(--visual-radius-sm, 6px);
    border: 1px solid var(--visual-border);
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease;
    font-size: 0.8125rem;
    color: var(--visual-text-muted);
    margin: 0;
}

html.visual-identity-clarity .clarity-tipo-conta-item:hover {
    background: #f9fafb;
    border-color: #d1d5db;
}

html.visual-identity-clarity .clarity-tipo-conta-item:has(.form-check-input:checked) {
    background: rgba(47, 111, 237, 0.06);
    border-color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-tipo-conta-item:has(.form-check-input:checked) span {
    font-weight: 600;
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .clarity-tipo-conta-item .form-check-input {
    cursor: pointer;
    width: 1em;
    height: 1em;
    margin: 0;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-tipo-conta-item .form-check-input:checked {
    background-color: var(--visual-action-blue);
    border-color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-tipo-conta-item i {
    font-size: 1.125rem;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-hint-box {
    padding: 0.75rem 1rem;
    border-radius: var(--visual-radius-sm, 6px);
    font-size: 0.8125rem;
}

html.visual-identity-clarity .clarity-hint-box--warning {
    background: #fffbeb;
    border-left: 3px solid var(--color-warning, #f59e0b);
    color: #78350f;
}

html.visual-identity-clarity .clarity-hint-box--warning strong {
    color: #92400e;
}

html.visual-identity-clarity .clarity-form-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 16px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
}

html.visual-identity-clarity .clarity-form-footer--fixed {
    position: fixed;
    bottom: 0;
    left: calc(var(--clarity-rail-width, 56px) + var(--clarity-sidebar-width, 240px));
    right: 0;
    height: var(--clarity-footer-h, 60px);
    margin-top: 0;
    padding: 0 24px;
    background: var(--visual-bg-card, #fff);
    border-top: 1px solid var(--visual-border);
    z-index: 10;
}

html.visual-identity-clarity body.clarity-sidebar-collapsed .clarity-form-footer--fixed {
    left: var(--clarity-rail-width, 56px);
}

html.visual-identity-clarity .clarity-page-body:has(.clarity-form-footer--fixed) {
    padding-bottom: calc(var(--clarity-footer-h, 60px) + 24px);
}

html.visual-identity-clarity .clarity-form-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--visual-border);
}

@media (max-width: 991.98px) {
    html.visual-identity-clarity .clarity-choice-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    html.visual-identity-clarity .clarity-choice-grid {
        grid-template-columns: 1fr;
    }

    html.visual-identity-clarity .clarity-form-panel {
        padding: 1rem;
    }
}

html.visual-identity-clarity .clarity-page-panel__inner:has(.clarity-form-elegant) {
    padding: 1.5rem 1.75rem 1.75rem;
}

html.visual-identity-clarity .clarity-content-header:has(+ .clarity-session-alert),
html.visual-identity-clarity .clarity-content-header {
    margin-bottom: 1.25rem;
}

@media screen and (max-width: 1024px) {
    html.visual-identity-clarity .clarity-page-wrapper > .row > .page-content:only-child,
    html.visual-identity-clarity .clarity-page-wrapper > .page-content:only-child,
    html.visual-identity-clarity .clarity-page-panel {
        border-left: none;
        border-right: none;
        border-radius: 0;
    }

    html.visual-identity-clarity .clarity-page-panel__inner {
        padding: 1rem;
    }
}

/* =========================================
   8. FILTER LIST (4ª coluna)
========================================= */
html.visual-identity-clarity .clarity-filter-list {
    display: flex;
    min-height: 0;
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 8px);
    overflow: hidden;
    background: #fff;
}

html.visual-identity-clarity .clarity-filter-list__sidebar {
    flex: 0 0 var(--clarity-inner-filter-width, 220px);
    background: var(--clarity-filter-bg, #FAFAFB);
    border-right: 1px solid var(--visual-border);
    padding: 12px 0;
    overflow-y: auto;
}

html.visual-identity-clarity .clarity-filter-list__content {
    flex: 1;
    min-width: 0;
    background: #fff;
    padding: 0;
}

/* =========================================
   9. TABS
========================================= */
html.visual-identity-clarity .clarity-page-body .nav-tabs {
    border-bottom: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-page-body .nav-tabs .nav-link {
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--visual-text-muted);
    font-size: 0.8125rem;
    padding: 8px 12px;
    margin-bottom: -1px;
}

html.visual-identity-clarity .clarity-page-body .nav-tabs .nav-link.active {
    color: var(--visual-text-heading);
    border-bottom-color: var(--visual-action-blue);
    background: transparent;
}

/* =========================================
   10. MODAIS E OVERLAYS
========================================= */
/* Acima do sidebar (1050), icon rail (1100) e flyout (1200) */
html.visual-identity-clarity .modal-backdrop {
    --bs-backdrop-zindex: 1290;
    z-index: 1290 !important;
    background-color: var(--clarity-backdrop, rgba(31, 41, 55, 0.12)) !important;
}

html.visual-identity-clarity .modal {
    --bs-modal-zindex: 1300;
    z-index: 1300 !important;
}

html.visual-identity-clarity .modal-dialog {
    max-width: min(var(--bs-modal-width, 500px), calc(100vw - 2rem));
    margin-left: auto;
    margin-right: auto;
}

html.visual-identity-clarity .modal-dialog.modal-lg {
    --bs-modal-width: 800px;
    max-width: min(800px, calc(100vw - 2rem));
}

html.visual-identity-clarity .modal-dialog.modal-xl {
    --bs-modal-width: 1140px;
    max-width: min(1140px, calc(100vw - 2rem));
}

html.visual-identity-clarity .modal-dialog-scrollable .modal-body {
    max-height: min(70vh, calc(100vh - 12rem));
}

html.visual-identity-clarity .modal-backdrop.show {
    opacity: 1 !important;
}

html.visual-identity-clarity .modal-content {
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 8px);
    box-shadow: 0 4px 24px rgba(31, 41, 55, 0.08);
}

html.visual-identity-clarity .modal-header,
html.visual-identity-clarity .modal-footer {
    border-color: var(--visual-border);
    padding: 12px 16px;
}

html.visual-identity-clarity .swal2-container.swal2-backdrop-show {
    background: var(--clarity-backdrop, rgba(31, 41, 55, 0.12)) !important;
}

html.visual-identity-clarity .swal2-popup {
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 8px) !important;
    box-shadow: 0 4px 24px rgba(31, 41, 55, 0.08) !important;
    font-family: var(--font-stack) !important;
}

html.visual-identity-clarity body.loading .modal-loading {
    background: rgba(250, 250, 251, 0.92) url("/loading.gif") 50% 50% no-repeat;
    position: fixed;
    inset: 0;
    z-index: 2000;
}

html.visual-identity-clarity .modal-loading {
    border: none;
    border-radius: 0;
}

/* =========================================
   11. FLYOUT (sidebar recolhida)
========================================= */
html.visual-identity-clarity .clarity-menu-flyout-host {
    position: fixed;
    inset: 0;
    z-index: 1200;
    pointer-events: none;
}

html.visual-identity-clarity .clarity-menu-flyout-host:not([hidden]) {
    pointer-events: auto;
}

html.visual-identity-clarity .clarity-menu-flyout-backdrop {
    position: absolute;
    inset: 0;
    background: var(--clarity-backdrop);
}

html.visual-identity-clarity .clarity-menu-flyout-panel {
    position: absolute;
    top: 0;
    left: var(--clarity-rail-width, 56px);
    width: var(--clarity-sidebar-width, 240px);
    height: 100vh;
    background: var(--clarity-sidebar-bg);
    border-right: 1px solid var(--visual-border);
    display: flex;
    flex-direction: column;
    box-shadow: 4px 0 16px rgba(31, 41, 55, 0.06);
}

html.visual-identity-clarity .clarity-menu-flyout-panel__head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-menu-flyout-title {
    flex: 1;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--visual-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

html.visual-identity-clarity .clarity-menu-flyout-expand,
html.visual-identity-clarity .clarity-menu-flyout-close {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border: 1px solid var(--visual-border);
    background: #fff;
    border-radius: 6px;
    min-height: 28px;
    padding: 0 8px;
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--visual-text-heading);
    cursor: pointer;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-menu-flyout-close {
    width: 28px;
    padding: 0;
    justify-content: center;
}

html.visual-identity-clarity .clarity-menu-flyout-expand:hover,
html.visual-identity-clarity .clarity-menu-flyout-close:hover,
html.visual-identity-clarity .clarity-menu-flyout-expand:focus-visible,
html.visual-identity-clarity .clarity-menu-flyout-close:focus-visible {
    background: var(--clarity-active-bg, #E8EEF8);
    border-color: rgba(47, 111, 237, 0.25);
    color: var(--visual-action-blue, #2F6FED);
    outline: none;
}

html.visual-identity-clarity .clarity-menu-flyout-back {
    display: none;
}

html.visual-identity-clarity .clarity-menu-flyout-body {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}

/* =========================================
   12. LOGIN
========================================= */
html.visual-identity-clarity body.clarity-login-page {
    overflow: auto;
    background: var(--visual-bg-page) !important;
    color: var(--visual-text-heading, #26262C);
}

html.visual-identity-clarity .clarity-auth {
    min-height: 100vh;
    display: flex;
}

html.visual-identity-clarity .clarity-auth-aside {
    flex: 0 0 42%;
    max-width: 520px;
    background: linear-gradient(160deg, var(--visual-login-hero-from, #1B2537), var(--visual-login-hero-to, #2F6FED));
    color: #fff !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 48px;
}

html.visual-identity-clarity .clarity-auth-aside__brand {
    display: block;
    margin-bottom: 36px;
    background: transparent;
}

html.visual-identity-clarity .clarity-auth-aside__logo {
    display: block;
    width: auto;
    height: auto;
    max-width: min(360px, 78vw);
    max-height: min(200px, 26vh);
    object-fit: contain;
}

html.visual-identity-clarity .clarity-auth-form {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 24px;
    background: #fff;
}

html.visual-identity-clarity .clarity-auth-form__card {
    width: 100%;
    max-width: 400px;
}

html.visual-identity-clarity .clarity-auth-form .form-control {
    min-height: var(--clarity-element-sm, 32px);
    font-size: 0.875rem;
}

html.visual-identity-clarity .clarity-btn-login {
    min-height: var(--clarity-element-sm, 32px);
    background: var(--visual-login-cta, #2F6FED);
    border-color: var(--visual-login-cta, #2F6FED);
    font-weight: 500;
}

html.visual-identity-clarity .clarity-btn-login:hover,
html.visual-identity-clarity .clarity-btn-login:focus {
    background: var(--visual-login-cta, #2F6FED);
    border-color: var(--visual-login-cta, #2F6FED);
    filter: brightness(0.94);
}

html.visual-identity-clarity .clarity-auth-aside__text {
    font-size: 0.9375rem;
    line-height: 1.55;
    color: #fff !important;
    opacity: 0.92;
    margin: 0;
    max-width: 340px;
}

html.visual-identity-clarity .clarity-auth-aside__copy {
    color: #fff !important;
    opacity: 0.65;
    font-size: 0.75rem;
    margin-top: 48px;
}

html.visual-identity-clarity .clarity-auth-form__intro h2 {
    color: var(--visual-text-heading, #1B2537);
}

html.visual-identity-clarity .clarity-auth-form .form-label {
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    color: var(--visual-text-heading, #1B2537);
    margin-bottom: 6px;
}

html.visual-identity-clarity .clarity-auth-form .form-control {
    border-color: var(--visual-border, #E2E8F0);
    background: #fff;
}

html.visual-identity-clarity .clarity-auth-form .form-control:focus {
    border-color: var(--visual-action-blue, #2F6FED);
    box-shadow: 0 0 0 0.15rem rgba(47, 111, 237, 0.15);
}

html.visual-identity-clarity .clarity-auth-forgot {
    color: var(--visual-action-blue, #2F6FED);
    text-decoration: none;
    font-weight: 500;
}

html.visual-identity-clarity .clarity-auth-forgot:hover {
    text-decoration: underline;
}

@media (max-width: 991.98px) {
    html.visual-identity-clarity .clarity-auth {
        flex-direction: column;
    }

    html.visual-identity-clarity .clarity-auth-aside {
        flex: none;
        max-width: none;
        width: 100%;
        padding: 32px 24px;
        min-height: auto;
    }

    html.visual-identity-clarity .clarity-auth-aside__brand {
        margin-bottom: 28px;
    }

    html.visual-identity-clarity .clarity-auth-aside__logo {
        max-width: min(280px, 72vw);
        max-height: min(150px, 20vh);
    }

    html.visual-identity-clarity .clarity-auth-aside__copy {
        margin-top: 24px;
    }

    html.visual-identity-clarity .clarity-auth-form {
        padding: 24px 16px 32px;
    }
}

/* Escolher empresa (auth) */
html.visual-identity-clarity .clarity-auth--pick-company .clarity-auth-form {
    align-items: flex-start;
    padding-top: 48px;
    padding-bottom: 48px;
}

html.visual-identity-clarity .clarity-auth-form__card--wide {
    max-width: 720px;
}

html.visual-identity-clarity .clarity-company-grid {
    display: grid;
    gap: 12px;
    width: 100%;
}

html.visual-identity-clarity .clarity-company-grid--single {
    grid-template-columns: minmax(0, 1fr);
}

html.visual-identity-clarity .clarity-company-grid--multi {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

html.visual-identity-clarity .clarity-company-form {
    margin: 0;
    min-width: 0;
}

html.visual-identity-clarity .clarity-company-card {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    width: 100%;
    min-height: 100%;
    padding: 16px;
    margin: 0;
    text-align: left;
    appearance: none;
    background: var(--visual-bg-card, #fff);
    border: 1.5px solid var(--visual-border, #E2E8F0);
    border-radius: var(--visual-radius-md, 6px);
    cursor: pointer;
    transition: border-color 0.12s ease, box-shadow 0.12s ease, transform 0.12s ease;
}

html.visual-identity-clarity .clarity-company-card:hover,
html.visual-identity-clarity .clarity-company-card:focus-visible {
    border-color: var(--visual-action-blue, #2F6FED);
    box-shadow: 0 4px 14px rgba(47, 111, 237, 0.1);
    transform: translateY(-1px);
    outline: none;
}

html.visual-identity-clarity .clarity-company-card__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--visual-radius-md, 6px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: var(--visual-action-blue, #2F6FED);
    background: rgba(47, 111, 237, 0.1);
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-company-card__body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

html.visual-identity-clarity .clarity-company-card__name {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--visual-text-heading, #1B2537);
    line-height: 1.3;
    word-break: break-word;
}

html.visual-identity-clarity .clarity-company-card__cnpj {
    font-size: 0.8125rem;
    color: var(--visual-text-muted, #64748B);
}

html.visual-identity-clarity .clarity-company-card__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: auto;
    min-height: var(--clarity-element-sm, 32px);
    padding: 0 12px;
    border-radius: var(--visual-radius-md, 6px);
    font-size: 0.875rem;
    font-weight: 500;
    color: #fff;
    background: var(--visual-login-cta, #2F6FED);
}

html.visual-identity-clarity .clarity-auth-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--visual-action-blue, #2F6FED);
    text-decoration: none;
}

html.visual-identity-clarity .clarity-auth-back:hover {
    text-decoration: underline;
}

html.visual-identity-clarity body.clarity-login-page.clarity-pick-company-page {
    overflow: auto;
}

@media (max-width: 767.98px) {
    html.visual-identity-clarity .clarity-company-grid--multi {
        grid-template-columns: minmax(0, 1fr);
    }

    html.visual-identity-clarity .clarity-auth--pick-company .clarity-auth-form {
        padding-top: 24px;
    }

    html.visual-identity-clarity .clarity-auth-form__card--wide {
        max-width: none;
    }
}

/* =========================================
   12B. FORMULÁRIO FLAT — GRID E CAMPOS ESPECIAIS
========================================= */
html.visual-identity-clarity .clarity-form-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

html.visual-identity-clarity .clarity-form-grid-legacy {
    --bs-gutter-x: 16px;
    --bs-gutter-y: 16px;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

html.visual-identity-clarity .clarity-form-grid-legacy > [class*="col-"] {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    grid-column: span 1;
}

html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-8,
html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-7 {
    grid-column: span 3;
}

html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-6 {
    grid-column: span 2;
}

html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-4,
html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-3,
html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-2 {
    grid-column: span 1;
}

html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-12,
html.visual-identity-clarity .clarity-form-grid-legacy > #campo-local,
html.visual-identity-clarity .clarity-form-grid-legacy > .col-12 {
    grid-column: span 4;
}

@media (max-width: 1100px) {
    html.visual-identity-clarity .clarity-form-grid-legacy {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-8,
    html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-7,
    html.visual-identity-clarity .clarity-form-grid-legacy > .col-md-12,
    html.visual-identity-clarity .clarity-form-grid-legacy > #campo-local,
    html.visual-identity-clarity .clarity-form-grid-legacy > .col-12 {
        grid-column: span 2;
    }
}

html.visual-identity-clarity .clarity-form-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

html.visual-identity-clarity .clarity-form-field .form-group {
    margin-bottom: 0;
}

html.visual-identity-clarity .clarity-form-field > .form-label,
html.visual-identity-clarity .clarity-form-field .form-group > .form-label,
html.visual-identity-clarity .clarity-form-field .form-group > label.form-label {
    margin-bottom: 0;
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    color: var(--visual-text-heading);
    letter-spacing: 0;
}

html.visual-identity-clarity .clarity-form-field--span-2 { grid-column: span 2; }
html.visual-identity-clarity .clarity-form-field--span-3 { grid-column: span 3; }
html.visual-identity-clarity .clarity-form-field--span-4 { grid-column: span 4; }

@media (max-width: 1100px) {
    html.visual-identity-clarity .clarity-form-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    html.visual-identity-clarity .clarity-form-field--span-3,
    html.visual-identity-clarity .clarity-form-field--span-4 {
        grid-column: span 2;
    }
}

html.visual-identity-clarity .clarity-input-currency {
    position: relative;
}

html.visual-identity-clarity .clarity-input-currency__prefix {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--visual-text-muted);
    font-size: 13px;
    pointer-events: none;
}

html.visual-identity-clarity .clarity-input-currency .form-control {
    padding-left: 32px;
}

html.visual-identity-clarity .clarity-input-date {
    position: relative;
}

html.visual-identity-clarity .clarity-input-date__icon {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--clarity-gray-400, #A8A8B2);
    pointer-events: none;
    font-size: 14px;
    line-height: 1;
}

html.visual-identity-clarity .clarity-input-date .form-control {
    padding-right: 32px;
}

html.visual-identity-clarity .clarity-input-group {
    display: flex;
    align-items: stretch;
}

html.visual-identity-clarity .clarity-input-group .form-control,
html.visual-identity-clarity .clarity-input-group .form-select {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    flex: 1;
    min-width: 0;
}

html.visual-identity-clarity .clarity-input-group > .select2-container {
    flex: 1;
    min-width: 0;
}

html.visual-identity-clarity .clarity-input-group > .select2-container .select2-selection--single {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    min-height: var(--clarity-element-sm, 34px);
    height: var(--clarity-element-sm, 34px);
}

html.visual-identity-clarity .clarity-input-group__addon {
    display: grid;
    place-items: center;
    padding: 0 10px;
    border: 1px solid var(--clarity-border-strong, var(--visual-border));
    border-left: none;
    border-radius: 0 var(--visual-radius-sm, 4px) var(--visual-radius-sm, 4px) 0;
    background: var(--clarity-gray-50, #FAFAFB);
    color: var(--visual-text-muted);
    font-size: 13px;
    cursor: pointer;
    transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}

html.visual-identity-clarity .clarity-input-group__addon:hover {
    background: var(--clarity-active-bg, #E8EEF8);
    color: var(--visual-action-blue);
    border-color: var(--visual-action-blue);
}

/* Seção colapsável */
html.visual-identity-clarity .clarity-collapsible {
    background: var(--visual-bg-card, #fff);
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 6px);
    margin-bottom: 16px;
    overflow: hidden;
}

html.visual-identity-clarity .clarity-collapsible__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    padding: 16px 20px;
    border: none;
    background: transparent;
    text-align: left;
    cursor: pointer;
    color: inherit;
}

html.visual-identity-clarity .clarity-collapsible__title-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

html.visual-identity-clarity .clarity-collapsible__icon-box {
    width: 32px;
    height: 32px;
    border-radius: var(--visual-radius-sm, 4px);
    background: var(--clarity-gray-100, #F4F4F6);
    color: var(--visual-text-muted);
    display: grid;
    place-items: center;
    flex-shrink: 0;
    font-size: 1rem;
}

html.visual-identity-clarity .clarity-collapsible__title {
    font-size: var(--fs-md, 14px);
    font-weight: 600;
    letter-spacing: -0.005em;
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .clarity-collapsible__subtitle {
    font-size: var(--fs-sm, 12px);
    font-weight: 400;
    color: var(--visual-text-muted);
    letter-spacing: 0;
    margin-top: 2px;
    line-height: 1.45;
}

html.visual-identity-clarity .clarity-collapsible__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

html.visual-identity-clarity .clarity-collapsible__chevron {
    color: var(--visual-text-muted);
    transition: transform 0.15s ease;
    font-size: 1rem;
}

html.visual-identity-clarity .clarity-collapsible.is-open .clarity-collapsible__chevron {
    transform: rotate(180deg);
}

html.visual-identity-clarity .clarity-collapsible__body {
    display: none;
    padding: 0 20px 20px;
    border-top: 1px solid var(--visual-border);
}

html.visual-identity-clarity .clarity-collapsible.is-open .clarity-collapsible__body {
    display: block;
    padding-top: 20px;
}

html.visual-identity-clarity .clarity-value-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 4px 12px;
    background: var(--clarity-gray-100, #F4F4F6);
    border-radius: var(--visual-radius-sm, 4px);
    font-size: 12px;
    color: var(--visual-text-muted);
    white-space: nowrap;
}

html.visual-identity-clarity .clarity-value-pill strong {
    color: var(--visual-text-heading);
    font-weight: 600;
}

/* Colapsável com Bootstrap collapse (compat. JS existente) */
html.visual-identity-clarity .clarity-collapsible--bootstrap .clarity-collapsible__header[aria-expanded="true"] .clarity-collapsible__chevron,
html.visual-identity-clarity .clarity-collapsible--bootstrap .clarity-collapsible__header[aria-expanded="true"] .cc-chevron {
    transform: rotate(180deg);
}

html.visual-identity-clarity .clarity-collapsible--bootstrap .clarity-collapsible__collapse-body {
    padding: 20px;
    border-top: 1px solid var(--visual-border);
}

/* Barra de seção com toggle (transferência, cartão) */
html.visual-identity-clarity .clarity-section-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 20px;
    margin-bottom: 16px;
    background: var(--visual-bg-card, #fff);
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 6px);
}

html.visual-identity-clarity .clarity-section-bar__main {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

html.visual-identity-clarity .clarity-section-bar__title {
    display: block;
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--visual-text-heading);
    line-height: 1.3;
    cursor: pointer;
}

html.visual-identity-clarity .clarity-section-bar__subtitle {
    margin: 2px 0 0;
    font-size: 12px;
    color: var(--visual-text-muted);
    line-height: 1.45;
}

html.visual-identity-clarity .clarity-section-bar__switch .form-check-input {
    width: 40px;
    height: 22px;
    margin: 0;
    cursor: pointer;
    border: 1px solid var(--clarity-gray-300, #D8D8DE);
    background-color: var(--clarity-gray-200, #EAEAEE);
}

html.visual-identity-clarity .clarity-section-bar__switch .form-check-input:checked {
    background-color: var(--visual-action-blue);
    border-color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-section-bar__switch .form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(47, 111, 237, 0.15);
}

html.visual-identity-clarity .clarity-form-elegant .clarity-form-footer--fixed {
    margin-top: 0;
}

/* Harmonização de markup legado (ex.: lancamento/_forms) */
html.visual-identity-clarity .clarity-form-elegant .card.border-primary {
    border-color: var(--visual-border) !important;
    border-radius: var(--visual-radius-md, 6px);
    box-shadow: none;
    background: var(--visual-bg-card, #fff);
    margin-bottom: 16px;
}

html.visual-identity-clarity .clarity-form-elegant .card.border-primary > .card-header {
    background: transparent;
    border-bottom: 1px solid var(--visual-border);
    padding: 16px 20px;
}

html.visual-identity-clarity .clarity-form-elegant .card.border-primary .text-primary,
html.visual-identity-clarity .clarity-form-elegant .card.border-primary .fw-semibold.text-primary {
    color: var(--visual-text-heading) !important;
}

html.visual-identity-clarity .clarity-form-elegant .card.border-primary .badge.bg-light {
    background: var(--clarity-gray-100, #F4F4F6) !important;
    color: var(--visual-text-muted) !important;
    border: none !important;
    font-weight: 400;
    font-size: 12px;
    padding: 4px 12px;
    border-radius: var(--visual-radius-sm, 4px);
}

html.visual-identity-clarity .clarity-form-elegant .input-group > .form-control,
html.visual-identity-clarity .clarity-form-elegant .input-group > .form-select,
html.visual-identity-clarity .clarity-form-elegant .input-group > .select2-container .select2-selection--single {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

html.visual-identity-clarity .clarity-form-elegant .input-group .btn,
html.visual-identity-clarity .clarity-form-elegant .input-group > a.btn {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    background: var(--clarity-gray-50, #FAFAFB);
    border: 1px solid var(--clarity-border-strong, var(--visual-border));
    border-left: none;
    color: var(--visual-text-muted);
    min-height: var(--clarity-element-sm, 34px);
    padding: 0 10px;
}

html.visual-identity-clarity .clarity-form-elegant .input-group .btn:hover,
html.visual-identity-clarity .clarity-form-elegant .input-group > a.btn:hover {
    background: var(--clarity-active-bg, #E8EEF8);
    color: var(--visual-action-blue);
    border-color: var(--visual-action-blue);
}

html.visual-identity-clarity .clarity-form-elegant .form-label.required::after,
html.visual-identity-clarity .clarity-form-elegant label.required::after {
    content: ' *';
    color: var(--clarity-required, #D14C6F);
}

html.visual-identity-clarity .clarity-form-elegant hr {
    border-color: var(--visual-border);
    opacity: 1;
}

/* Validação Bootstrap: evitar ícones verdes repetidos em form-select
   (shorthand background + background-image do Bootstrap sem background-repeat) */
html.visual-identity-clarity .clarity-page-body .form-control.is-valid,
html.visual-identity-clarity .clarity-page-body .was-validated .form-control:valid,
html.visual-identity-clarity .clarity-form-elegant .form-control.is-valid,
html.visual-identity-clarity .clarity-form-elegant .was-validated .form-control:valid {
    border-color: var(--clarity-border-strong, var(--visual-border));
    background-color: var(--visual-bg-card, #fff);
    background-image: none;
    box-shadow: none;
}

html.visual-identity-clarity .clarity-page-body .form-select.is-valid,
html.visual-identity-clarity .clarity-page-body .was-validated .form-select:valid,
html.visual-identity-clarity .clarity-form-elegant .form-select.is-valid,
html.visual-identity-clarity .clarity-form-elegant .was-validated .form-select:valid {
    border-color: var(--clarity-border-strong, var(--visual-border));
    background-color: var(--visual-bg-card, #fff);
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7A85' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
    background-repeat: no-repeat !important;
    background-position: right 10px center;
    background-size: 12px 12px;
    box-shadow: none;
    padding-right: 30px;
}

html.visual-identity-clarity .clarity-page-body .form-control.is-invalid,
html.visual-identity-clarity .clarity-page-body .was-validated .form-control:invalid,
html.visual-identity-clarity .clarity-page-body .form-select.is-invalid,
html.visual-identity-clarity .clarity-page-body .was-validated .form-select:invalid,
html.visual-identity-clarity .clarity-form-elegant .form-control.is-invalid,
html.visual-identity-clarity .clarity-form-elegant .was-validated .form-control:invalid,
html.visual-identity-clarity .clarity-form-elegant .form-select.is-invalid,
html.visual-identity-clarity .clarity-form-elegant .was-validated .form-select:invalid {
    background-image: none;
    box-shadow: none;
}

html.visual-identity-clarity .clarity-form-elegant .form-select.is-invalid,
html.visual-identity-clarity .clarity-form-elegant .was-validated .form-select:invalid,
html.visual-identity-clarity .clarity-page-body .form-select.is-invalid,
html.visual-identity-clarity .clarity-page-body .was-validated .form-select:invalid {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7A85' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
    background-repeat: no-repeat !important;
    background-position: right 10px center;
    background-size: 12px 12px;
    padding-right: 30px;
}

/* =========================================
   13. RESPONSIVO
========================================= */
@media (max-width: 1024px) {
    html.visual-identity-clarity .clarity-sidebar-wrapper {
        position: fixed;
        left: var(--clarity-rail-width, 56px);
        top: 0;
        box-shadow: 4px 0 24px rgba(31, 41, 55, 0.1);
        transform: translateX(-110%);
        transition: transform 0.25s ease;
    }

    html.visual-identity-clarity body.clarity-mobile-sidebar-open .clarity-sidebar-wrapper {
        transform: translateX(0);
    }
}

/* =========================================
   14. DARK THEME
========================================= */
html.visual-identity-clarity.dark-theme .clarity-main-content,
html.visual-identity-clarity.dark-theme .clarity-page-header {
    background: #171717;
}

html.visual-identity-clarity.dark-theme .clarity-sidebar-wrapper {
    background: #1a1a1a;
}

/* =========================================
   15. DASHBOARD — ALERTAS DO DIA
========================================= */
html.visual-identity-clarity .alerts-section {
    background: var(--visual-bg-card, #fff);
    border: 1px solid var(--visual-border);
    border-radius: var(--visual-radius-md, 6px);
    padding: 16px 18px;
    margin-bottom: 20px;
    box-shadow: none;
}

html.visual-identity-clarity .alerts-section .section-title {
    font-size: var(--fs-xs, 11px);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--visual-text-muted);
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

html.visual-identity-clarity .alerts-section .section-title i {
    font-size: 14px;
    color: var(--visual-text-muted);
}

html.visual-identity-clarity .alerts-section .section-title small {
    font-size: var(--fs-xs, 11px);
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--clarity-gray-400, #A8A8B2);
}

html.visual-identity-clarity .alert-item {
    border: 1px solid var(--visual-border);
    border-left-width: 3px;
    border-radius: var(--visual-radius-sm, 4px);
    box-shadow: none;
    font-family: inherit;
}

html.visual-identity-clarity .alert-item:hover {
    box-shadow: none;
    background: var(--clarity-gray-50, #FAFAFB);
}

html.visual-identity-clarity .alert-item .alert-label {
    font-size: var(--fs-sm, 12px);
    font-weight: 500;
    color: var(--visual-text-muted);
}

html.visual-identity-clarity .alert-item .alert-value {
    font-size: var(--fs-md, 14px);
    font-weight: 600;
    letter-spacing: -0.01em;
}

html.visual-identity-clarity .alert-item.success {
    border-left-color: var(--visual-success, #10B981);
}

html.visual-identity-clarity .alert-item.success .alert-value {
    color: var(--visual-success, #10B981);
}

html.visual-identity-clarity .alert-item.danger {
    border-left-color: var(--visual-danger, #E0517A);
}

html.visual-identity-clarity .alert-item.danger .alert-value {
    color: var(--visual-danger, #E0517A);
}

html.visual-identity-clarity .alert-item.warning {
    border-left-color: var(--visual-warning, #F59E0B);
}

html.visual-identity-clarity .alert-item.warning .alert-value {
    color: var(--visual-warning, #F59E0B);
}

html.visual-identity-clarity .alert-item.critical {
    border-left-color: #DC2626;
}

html.visual-identity-clarity .alert-item.critical .alert-value {
    color: #DC2626;
}

/* =========================================
   15B. SUPER — PERMISSÕES E FORMULÁRIOS
========================================= */
html.visual-identity-clarity .clarity-super-permission-tree input[type='checkbox']:hover {
    cursor: pointer;
}

html.visual-identity-clarity .clarity-super-permission-tree__module {
    margin-top: 8px;
}

html.visual-identity-clarity .clarity-super-permission-tree__module:first-child {
    margin-top: 0;
}

html.visual-identity-clarity .clarity-super-permission-tree__module-title {
    margin-left: 5px;
    font-size: 16px;
}

html.visual-identity-clarity .clarity-super-permission-tree__subs {
    margin-top: 10px;
}

html.visual-identity-clarity .clarity-super-permission-tree__group-title {
    margin-left: 20px;
    font-size: 14px;
}

html.visual-identity-clarity .clarity-super-permission-tree__group-subs {
    margin-left: 30px;
    margin-top: 5px;
}

html.visual-identity-clarity .clarity-super-permission-tree__label {
    display: block;
    margin-bottom: 8px;
    font-size: var(--fs-sm, 12px);
    font-weight: 600;
    color: var(--visual-text-heading);
}

html.visual-identity-clarity .clarity-super-permission-tabs .tab-content {
    border: 1px solid var(--visual-border, #EAEAEE);
    border-top: 0;
    border-radius: 0 0 var(--visual-radius-md, 6px) var(--visual-radius-md, 6px);
    padding: 16px;
    background: var(--visual-bg-card, #fff);
}

html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-4,
html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-5 {
    grid-column: span 2;
}

html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-3,
html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-2,
html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-1 {
    grid-column: span 1;
}

html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .clarity-super-form-divider {
    grid-column: span 4;
    margin: 4px 0;
    border: 0;
    border-top: 1px solid var(--visual-border, #EAEAEE);
    opacity: 1;
}

html.visual-identity-clarity .clarity-super-form-grid .clarity-super-btn-field {
    display: flex;
    align-items: flex-end;
}

@media (max-width: 1100px) {
    html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-4,
    html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .col-md-5,
    html.visual-identity-clarity .clarity-super-form-grid.clarity-form-grid-legacy > .clarity-super-form-divider {
        grid-column: span 2;
    }
}

html.visual-identity-clarity .clarity-pre-scroll {
    max-height: 400px;
    overflow-y: auto;
    white-space: pre-wrap;
    word-break: break-word;
}

html.visual-identity-clarity .clarity-pre-scroll--md {
    max-height: 400px;
}

html.visual-identity-clarity .clarity-pre-scroll--sm {
    max-height: 300px;
}

html.visual-identity-clarity .ia-exec-badge {
    max-width: 100%;
}

/* =========================================
   16. PRINT
========================================= */
@media print {
    html.visual-identity-clarity .clarity-icon-rail,
    html.visual-identity-clarity .clarity-sidebar-wrapper,
    html.visual-identity-clarity .clarity-page-header {
        display: none !important;
    }

    html.visual-identity-clarity .clarity-layout-root {
        display: block;
        height: auto;
    }

    html.visual-identity-clarity .clarity-main-content {
        height: auto;
        overflow: visible;
    }

    html.visual-identity-clarity .clarity-page-body {
        overflow: visible;
    }
}

/* Ignorar color-sidebar do switcher */
html.visual-identity-clarity.color-sidebar .sidebar-wrapper {
    background: var(--clarity-sidebar-bg) !important;
}
