﻿/* ============================================
   VARIÁVEIS (CORES E TOKENS)
   ============================================ */
:root {
    /* Cores Primárias */
    --cor-primaria: #007c30;
    --cor-primaria-hover: #fec810;
    --cor-primaria-active: #fec503;
    --cor-primaria-dark: #133328;
    --cor-primaria-rgb: 0, 124, 48;
    /* Cores Secundárias */
    --cor-secundaria: #f07545;
    --cor-secundaria-hover: #ff7d5c;
    --cor-secundaria-dark: #6c757d;
    /* Cores de Destaque */
    --cor-destaque: #ff8c3f;
    --cor-destaque-hover: #fec810;
    --cor-amarelo: #e6b301;
    --cor-dourado: #d7b355;
    --cor-roxo: #341848;
    --cor-roxo-escuro: #2c2b64;
    --cor-teal: #15474a;
    --cor-teal-dark: #1e685b;
    --cor-verde-escuro: #56216a;
    /* Cores de Estado */
    --cor-sucesso: #28a745;
    --cor-sucesso-hover: #218838;
    --cor-sucesso-active: #1e7e34;
    --cor-info: #17a2b8;
    --cor-info-hover: #138496;
    --cor-info-active: #117a8b;
    --cor-perigo: #dc3545;
    --cor-perigo-hover: #c82333;
    --cor-perigo-active: #bd2130;
    --cor-aviso: #ffc107;
    /* Cores de Texto */
    --cor-texto: #212529;
    --cor-texto-secundario: #6c757d;
    --cor-texto-claro: #495057;
    --cor-texto-branco: #fff;
    --cor-texto-titulos: #15474a;
    /* Cores de Fundo */
    --cor-fundo: #fff;
    --cor-fundo-claro: #f3f3f3;
    --cor-fundo-escuro: #343a40;
    --cor-fundo-cabecalho: #1d1e1d;
    --cor-fundo-navegacao: #133328;
    /* Cores de Borda */
    --cor-borda: #dee2e6;
    --cor-borda-input: #ced4da;
    --cor-borda-clara: #e9ecef;
    /* Cores de Tabela */
    --cor-tabela-titulo: #9f4f4e;
    --cor-tabela-primary-bg: #fff2c7;
    --cor-tabela-primary-border: #fee796;
    /* Cores de Feedback */
    --cor-valid: #28a745;
    --cor-invalid: #dc3545;
    --cor-focus-shadow: rgba(254, 209, 54, 0.25);
    --cor-focus-border: #ffeeb5;
    /* Tipografia */
    --fonte-principal: "Roboto Slab", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --fonte-titulos: "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --fonte-mono: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --fonte-serif: "Droid Serif", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    /* Tamanhos de Fonte */
    --fonte-base: 1rem;
    --fonte-sm: 0.875rem;
    --fonte-lg: 1.25rem;
    --fonte-xl: 1.5rem;
    /* Espaçamentos */
    --espacamento-1: 0.25rem;
    --espacamento-2: 0.5rem;
    --espacamento-3: 1rem;
    --espacamento-4: 1.5rem;
    --espacamento-5: 3rem;
    /* Border Radius */
    --raio-sm: 0.2rem;
    --raio-base: 0.25rem;
    --raio-lg: 0.3rem;
    --raio-pill: 50rem;
    --raio-circulo: 20px;
    /* Sombras */
    --sombra-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --sombra-base: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --sombra-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
    /* Z-index */
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-offcanvas-backdrop: 1040;
    --z-offcanvas: 1045;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-tooltip: 1070;
    /* Bootstrap compat */
    --bs-blue: #0d6efd;
    --bs-green: #198754;
    --bs-yellow: #ffc107;
    --bs-red: #dc3545;
    --bs-cyan: #0dcaf0;
    --bs-white: #fff;
    --bs-gray: #6c757d;
    --bs-dark: #212529;
    --bs-primary-rgb: 0, 110, 163;
    --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --bs-body-color: #212529;
    --bs-body-bg: #fff;
    --bs-border-radius: 0.375rem;
}


/* ============================================
   FONTES
   ============================================ */
@font-face {
    font-family: 'roboto-black-webfont';
    src: url('/Content/font/Roboto/roboto-black-webfont.ttf') format('truetype'), url('/Content/font/Roboto/roboto-black-webfont.woff') format('woff'), url('/Content/font/Roboto/roboto-black-webfont.woff2') format('woff2');
}

@font-face {
    font-family: 'roboto-regular-webfont';
    src: url('/Content/font/Roboto/roboto-regular-webfont.woff') format('woff'), url('/Content/font/Roboto/roboto-regular-webfont.woff2') format('woff2');
}


/* ============================================
   RESET E BASE
   ============================================ */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

body {
    margin: 0;
    font-family: var(--fonte-principal);
    font-size: var(--fonte-base);
    font-weight: 400;
    line-height: 1.5;
    color: var(--cor-texto);
    text-align: left;
    background-color: var(--cor-fundo);
    overflow-x: hidden;
}

article, aside, figcaption, figure, footer, header, hgroup, main, nav, section {
    display: block;
}

main {
    min-height: 85vh;
    margin-top: 4.4rem !important;
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
    margin-top: var(--espacamento-3);
    margin-bottom: var(--espacamento-3);
    border: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

[data-indice="-1"]:focus:not(:focus-visible) {
    outline: 0 !important;
}


/* ============================================
   TIPOGRAFIA
   ============================================ */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    margin-top: 0;
    margin-bottom: 0.5rem;
    font-family: var(--fonte-titulos);
    font-weight: 700;
    line-height: 1.2;
    color: var(--cor-texto-titulos);
}

h1, .h1 {
    font-size: 2.5rem;
}

h2, .h2 {
    font-size: 2rem;
}

h3, .h3 {
    font-size: 1.75rem;
}

h4, .h4 {
    font-size: var(--fonte-xl);
}

h5, .h5 {
    font-size: var(--fonte-lg);
}

h6, .h6 {
    font-size: var(--fonte-base);
}

p {
    margin-top: 0;
    margin-bottom: var(--espacamento-3);
    text-align: justify;
    line-height: 1.75;
}

.lead {
    font-size: 1.2rem !important;
    font-weight: 300;
}

.display-1 {
    font-size: 6rem;
    font-weight: 300;
    line-height: 1.2;
}

.display-2 {
    font-size: 5.5rem;
    font-weight: 300;
    line-height: 1.2;
}

.display-3 {
    font-size: 4.5rem;
    font-weight: 300;
    line-height: 1.2;
}

.display-4 {
    font-size: 3.5rem;
    font-weight: 300;
    line-height: 1.2;
}

small, .small {
    font-size: 80%;
    font-weight: 400;
}

mark, .mark {
    padding: 0.2em;
    background-color: #fcf8e3;
}

b, strong {
    font-weight: bolder;
}

sub, sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

abbr[title],
abbr[data-original-title] {
    text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
    text-decoration-skip-ink: none;
}

address {
    margin-bottom: var(--espacamento-3);
    font-style: normal;
    line-height: inherit;
}

blockquote {
    margin: 0 0 var(--espacamento-3);
}

.blockquote {
    margin-bottom: var(--espacamento-3);
    font-size: var(--fonte-lg);
}

.blockquote-footer {
    display: block;
    font-size: 80%;
    color: var(--cor-texto-secundario);
}

    .blockquote-footer::before {
        content: "— ";
    }

dt {
    font-weight: 700;
}

dd {
    margin-bottom: 0.5rem;
    margin-left: 0;
}

ol, ul, dl {
    margin-top: 0;
    margin-bottom: var(--espacamento-3);
}

    ol ol, ul ul, ol ul, ul ol {
        margin-bottom: 0;
    }

.initialism {
    font-size: 90%;
    text-transform: uppercase;
}


/* ============================================
   LINKS
   ============================================ */
a {
    color: var(--cor-texto-titulos);
    text-decoration: none;
    background-color: transparent;
    overflow-wrap: break-word;
}

    a:hover {
        color: var(--cor-amarelo);
        text-decoration: underline;
    }

    a:not([href]):not([class]) {
        color: inherit;
        text-decoration: none;
    }

        a:not([href]):not([class]):hover {
            color: inherit;
            text-decoration: none;
        }


/* ============================================
   CÓDIGO
   ============================================ */
pre, code, kbd, samp {
    font-family: var(--fonte-mono);
    font-size: 1em;
}

pre {
    display: block;
    margin-top: 0;
    margin-bottom: var(--espacamento-3);
    overflow: auto;
    -ms-overflow-style: scrollbar;
    font-size: 87.5%;
    color: var(--cor-texto);
}

    pre code {
        font-size: inherit;
        color: inherit;
        word-break: normal;
    }

.pre-scrollable {
    max-height: 340px;
    overflow-y: scroll;
}

code {
    font-size: 87.5%;
    color: #e83e8c;
    word-wrap: break-word;
}

a > code {
    color: inherit;
}


/* ============================================
   IMAGENS E MÍDIA
   ============================================ */
img {
    vertical-align: middle;
    border-style: none;
}

svg {
    overflow: hidden;
    vertical-align: middle;
}

figure {
    margin: 0 0 var(--espacamento-3);
}

.img-fluid {
    max-width: 100%;
    height: auto;
}

.img-thumbnail {
    padding: var(--espacamento-1);
    background-color: var(--cor-fundo);
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-base);
    max-width: 100%;
    height: auto;
}

.figure {
    display: inline-block;
}

.figure-img {
    margin-bottom: 0.5rem;
    line-height: 1;
}

.figure-caption {
    font-size: 90%;
    color: var(--cor-texto-secundario);
}

.imagem-cabecalho {
    width: 100%;
}

@media (max-width: 300px) {
    .logo-evento {
        width: 60%;
    }
}

.logo-apoio {
    width: 60%;
    transition: all ease .5s;
}

    .logo-apoio:hover {
        transform: scale3d(1.1, 1.1, 1.1);
    }

.embed-responsive {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    overflow: hidden;
}

    .embed-responsive::before {
        display: block;
        content: "";
    }

    .embed-responsive .embed-responsive-item,
    .embed-responsive iframe,
    .embed-responsive embed,
    .embed-responsive object,
    .embed-responsive video {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: 0;
    }

.embed-responsive-21by9::before {
    padding-top: 42.8571428571%;
}

.embed-responsive-16by9::before {
    padding-top: 56.25%;
}

.embed-responsive-4by3::before {
    padding-top: 75%;
}

.embed-responsive-1by1::before {
    padding-top: 100%;
}


/* ============================================
   TABELAS
   ============================================ */
table {
    border-collapse: collapse;
}

caption {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    color: var(--cor-destaque);
    text-align: left;
    caption-side: top;
    font-weight: bold;
}

th {
    text-align: inherit;
    text-align: -webkit-match-parent;
}

.table {
    width: 100%;
    margin-bottom: var(--espacamento-3);
    color: var(--cor-texto);
}

    .table th,
    .table td {
        padding: 0.75rem;
        vertical-align: top;
        border-top: 1px solid var(--cor-borda);
    }

        .table td.tituloTable {
            background-color: var(--cor-tabela-titulo);
            color: #f8f9fa;
        }

    .table thead th {
        vertical-align: bottom;
        border-bottom: 2px solid var(--cor-borda);
    }

    .table tbody + tbody {
        border-top: 2px solid var(--cor-borda);
    }

.table-sm th, .table-sm td {
    padding: 0.3rem;
}

.table-bordered {
    border: 1px solid var(--cor-borda);
}

    .table-bordered th, .table-bordered td {
        border: 1px solid var(--cor-borda);
    }

    .table-bordered thead th, .table-bordered thead td {
        border-bottom-width: 2px;
    }

.table-borderless th,
.table-borderless td,
.table-borderless thead th,
.table-borderless tbody + tbody {
    border: 0;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(0, 0, 0, 0.05);
}

.table-hover tbody tr:hover {
    color: var(--cor-texto);
    background-color: rgba(0, 0, 0, 0.075);
}

.table-primary, .table-primary > th, .table-primary > td {
    background-color: var(--cor-tabela-primary-bg);
}

    .table-primary th, .table-primary td, .table-primary thead th, .table-primary tbody + tbody {
        border-color: var(--cor-tabela-primary-border);
    }

.table-hover .table-primary:hover {
    background-color: #ffecae;
}

    .table-hover .table-primary:hover > td, .table-hover .table-primary:hover > th {
        background-color: #ffecae;
    }

.table-secondary, .table-secondary > th, .table-secondary > td {
    background-color: #d6d8db;
}

    .table-secondary th, .table-secondary td, .table-secondary thead th, .table-secondary tbody + tbody {
        border-color: #b3b7bb;
    }

.table-hover .table-secondary:hover {
    background-color: #c8cbcf;
}

    .table-hover .table-secondary:hover > td, .table-hover .table-secondary:hover > th {
        background-color: #c8cbcf;
    }

.table-success, .table-success > th, .table-success > td {
    background-color: #c3e6cb;
}

    .table-success th, .table-success td, .table-success thead th, .table-success tbody + tbody {
        border-color: #8fd19e;
    }

.table-hover .table-success:hover {
    background-color: #b1dfbb;
}

    .table-hover .table-success:hover > td, .table-hover .table-success:hover > th {
        background-color: #b1dfbb;
    }

.table-info, .table-info > th, .table-info > td {
    background-color: #bee5eb;
}

    .table-info th, .table-info td, .table-info thead th, .table-info tbody + tbody {
        border-color: #86cfda;
    }

.table-hover .table-info:hover {
    background-color: #abdde5;
}

    .table-hover .table-info:hover > td, .table-hover .table-info:hover > th {
        background-color: #abdde5;
    }

.table-warning, .table-warning > th, .table-warning > td {
    background-color: var(--cor-tabela-primary-bg);
}

    .table-warning th, .table-warning td, .table-warning thead th, .table-warning tbody + tbody {
        border-color: var(--cor-tabela-primary-border);
    }

.table-hover .table-warning:hover {
    background-color: #ffecae;
}

    .table-hover .table-warning:hover > td, .table-hover .table-warning:hover > th {
        background-color: #ffecae;
    }

.table-danger, .table-danger > th, .table-danger > td {
    background-color: #f5c6cb;
}

    .table-danger th, .table-danger td, .table-danger thead th, .table-danger tbody + tbody {
        border-color: #ed969e;
    }

.table-hover .table-danger:hover {
    background-color: #f1b0b7;
}

    .table-hover .table-danger:hover > td, .table-hover .table-danger:hover > th {
        background-color: #f1b0b7;
    }

.table-claro, .table-claro > th, .table-claro > td {
    background-color: #fdfdfe;
}

    .table-claro th, .table-claro td, .table-claro thead th, .table-claro tbody + tbody {
        border-color: #fbfcfc;
    }

.table-hover .table-claro:hover {
    background-color: #ececf6;
}

    .table-hover .table-claro:hover > td, .table-hover .table-claro:hover > th {
        background-color: #ececf6;
    }

.table-escuro, .table-escuro > th, .table-escuro > td {
    background-color: #c6c8ca;
}

    .table-escuro th, .table-escuro td, .table-escuro thead th, .table-escuro tbody + tbody {
        border-color: #95999c;
    }

.table-hover .table-escuro:hover {
    background-color: #b9bbbe;
}

    .table-hover .table-escuro:hover > td, .table-hover .table-escuro:hover > th {
        background-color: #b9bbbe;
    }

.table-active, .table-active > th, .table-active > td {
    background-color: rgba(0, 0, 0, 0.075);
}

.table-hover .table-active:hover {
    background-color: rgba(0, 0, 0, 0.075);
}

    .table-hover .table-active:hover > td, .table-hover .table-active:hover > th {
        background-color: rgba(0, 0, 0, 0.075);
    }

.table .thead-escuro th {
    color: var(--cor-texto-branco);
    background-color: var(--cor-fundo-escuro);
    border-color: #454d55;
}

.table .thead-claro th {
    color: var(--cor-texto-claro);
    background-color: var(--cor-borda-clara);
    border-color: var(--cor-borda);
}

.table-escuro {
    color: var(--cor-texto-branco);
    background-color: var(--cor-fundo-escuro);
}

    .table-escuro th, .table-escuro td, .table-escuro thead th {
        border-color: #454d55;
    }

    .table-escuro.table-bordered {
        border: 0;
    }

    .table-escuro.table-striped tbody tr:nth-of-type(odd) {
        background-color: rgba(255, 255, 255, 0.05);
    }

    .table-escuro.table-hover tbody tr:hover {
        color: var(--cor-texto-branco);
        background-color: rgba(255, 255, 255, 0.075);
    }

@media (max-width: 575.98px) {
    .table-responsive-sm {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-sm > .table-bordered {
            border: 0;
        }
}

@media (max-width: 767.98px) {
    .table-responsive-md {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-md > .table-bordered {
            border: 0;
        }
}

@media (max-width: 991.98px) {
    .table-responsive-lg {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-lg > .table-bordered {
            border: 0;
        }
}

@media (max-width: 1199.98px) {
    .table-responsive-xl {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-xl > .table-bordered {
            border: 0;
        }
}

.table-responsive {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

    .table-responsive > .table-bordered {
        border: 0;
    }


/* ============================================
   FORMULÁRIOS
   ============================================ */
label {
    display: inline-block;
    margin-bottom: 0.5rem;
}

input, button, select, optgroup, textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

button, input {
    overflow: visible;
}

button, select {
    text-transform: none;
}

[role=button] {
    cursor: pointer;
}

select {
    word-wrap: normal;
}

button, [type=button], [type=reset], [type=submit] {
    -webkit-appearance: button;
}

    button:not(:disabled), [type=button]:not(:disabled), [type=reset]:not(:disabled), [type=submit]:not(:disabled) {
        cursor: pointer;
    }

    button::-moz-focus-inner, [type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner {
        padding: 0;
        border-style: none;
    }

    button:focus {
        outline: 1px dotted;
        outline: 5px auto -webkit-focus-ring-color;
    }

button {
    border-radius: 0;
}

input[type=radio], input[type=checkbox] {
    box-sizing: border-box;
    padding: 0;
}

input[type=date].form-control, input[type=time].form-control, input[type=datetime-local].form-control, input[type=month].form-control {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
    height: auto;
}

[type=search] {
    outline-offset: -2px;
    -webkit-appearance: none;
}

    [type=search]::-webkit-search-decoration {
        -webkit-appearance: none;
    }

::-webkit-file-upload-button {
    font: inherit;
    -webkit-appearance: button;
}

textarea {
    overflow: auto;
    resize: vertical;
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: 0.5rem;
    font-size: var(--fonte-xl);
    line-height: inherit;
    color: inherit;
    white-space: normal;
}

progress {
    vertical-align: baseline;
}

output {
    display: inline-block;
}

summary {
    display: list-item;
    cursor: pointer;
}

template {
    display: none;
}

[hidden] {
    display: none !important;
}

.form-control {
    display: block;
    width: 100%;
    height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 0.75rem;
    font-size: var(--fonte-base);
    font-weight: 400;
    line-height: 1.5;
    color: var(--cor-texto-claro);
    background-color: var(--cor-fundo);
    background-clip: padding-box;
    border: 1px solid var(--cor-borda-input);
    border-radius: var(--raio-base);
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .form-control {
        transition: none;
    }
}

.form-control::-ms-expand {
    background-color: transparent;
    border: 0;
}

.form-control:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 var(--cor-texto-claro);
}

.form-control:focus {
    color: var(--cor-texto-claro);
    background-color: var(--cor-fundo);
    border-color: var(--cor-focus-border);
    outline: 0;
    box-shadow: 0 0 0 0.2rem var(--cor-focus-shadow);
}

.form-control::placeholder {
    color: var(--cor-texto-secundario);
    opacity: 1;
}

.form-control:disabled, .form-control[readonly] {
    background-color: var(--cor-borda-clara);
    opacity: 1;
}

select.form-control:focus::-ms-value {
    color: var(--cor-texto-claro);
    background-color: var(--cor-fundo);
}

.form-control-file, .form-control-range {
    display: block;
    width: 100%;
}

.col-form-label {
    padding-top: calc(0.375rem + 1px);
    padding-bottom: calc(0.375rem + 1px);
    margin-bottom: 0;
    font-size: inherit;
    line-height: 1.5;
}

.col-form-label-lg {
    padding-top: calc(0.5rem + 1px);
    padding-bottom: calc(0.5rem + 1px);
    font-size: var(--fonte-lg);
    line-height: 1.5;
}

.col-form-label-sm {
    padding-top: calc(0.25rem + 1px);
    padding-bottom: calc(0.25rem + 1px);
    font-size: var(--fonte-sm);
    line-height: 1.5;
}

.form-control-plaintext {
    display: block;
    width: 100%;
    padding: 0.375rem 0;
    margin-bottom: 0;
    font-size: var(--fonte-base);
    line-height: 1.5;
    color: var(--cor-texto);
    background-color: transparent;
    border: solid transparent;
    border-width: 1px 0;
}

    .form-control-plaintext.form-control-sm, .form-control-plaintext.form-control-lg {
        padding-right: 0;
        padding-left: 0;
    }

.form-control-sm {
    height: calc(1.5em + 0.5rem + 2px);
    padding: 0.25rem 0.5rem;
    font-size: var(--fonte-sm);
    line-height: 1.5;
    border-radius: var(--raio-sm);
}

.form-control-lg {
    height: calc(1.5em + 1rem + 2px);
    padding: 0.5rem 1rem;
    font-size: var(--fonte-lg);
    line-height: 1.5;
    border-radius: var(--raio-lg);
}

select.form-control[size], select.form-control[multiple] {
    height: auto;
}

textarea.form-control {
    height: auto;
}

.form-group {
    margin-bottom: var(--espacamento-3);
}

.form-text {
    display: block;
    margin-top: var(--espacamento-1);
}

.form-row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -5px;
    margin-left: -5px;
}

    .form-row > .col, .form-row > [class*=col-] {
        padding-right: 5px;
        padding-left: 5px;
    }

.form-check {
    position: relative;
    display: block;
    padding-left: 1.25rem;
}

.form-check-input {
    position: absolute;
    margin-top: 0.3rem;
    margin-left: -1.25rem;
}

    .form-check-input[disabled] ~ .form-check-label, .form-check-input:disabled ~ .form-check-label {
        color: var(--cor-texto-secundario);
    }

.form-check-label {
    margin-bottom: 0;
}

.form-check-inline {
    display: inline-flex;
    align-items: center;
    padding-left: 0;
    margin-right: 0.75rem;
}

    .form-check-inline .form-check-input {
        position: static;
        margin-top: 0;
        margin-right: 0.3125rem;
        margin-left: 0;
    }

/* Validação */
.valid-feedback {
    display: none;
    width: 100%;
    margin-top: var(--espacamento-1);
    font-size: 80%;
    color: var(--cor-valid);
}

.valid-tooltip {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: 0.25rem 0.5rem;
    margin-top: 0.1rem;
    font-size: var(--fonte-sm);
    line-height: 1.5;
    color: var(--cor-texto-branco);
    background-color: rgba(40, 167, 69, 0.9);
    border-radius: var(--raio-base);
}

.was-validated :valid ~ .valid-feedback,
.was-validated :valid ~ .valid-tooltip,
.is-valid ~ .valid-feedback,
.is-valid ~ .valid-tooltip {
    display: block;
}

.was-validated .form-control:valid, .form-control.is-valid {
    border-color: var(--cor-valid);
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .was-validated .form-control:valid:focus, .form-control.is-valid:focus {
        border-color: var(--cor-valid);
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
    }

.was-validated textarea.form-control:valid, textarea.form-control.is-valid {
    padding-right: calc(1.5em + 0.75rem);
    background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}

.was-validated .custom-select:valid, .custom-select.is-valid {
    border-color: var(--cor-valid);
    padding-right: calc(0.75em + 2.3125rem);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px, url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") var(--cor-fundo) no-repeat center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .was-validated .custom-select:valid:focus, .custom-select.is-valid:focus {
        border-color: var(--cor-valid);
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
    }

.was-validated .form-check-input:valid ~ .form-check-label, .form-check-input.is-valid ~ .form-check-label {
    color: var(--cor-valid);
}

.was-validated .form-check-input:valid ~ .valid-feedback, .was-validated .form-check-input:valid ~ .valid-tooltip, .form-check-input.is-valid ~ .valid-feedback, .form-check-input.is-valid ~ .valid-tooltip {
    display: block;
}

.was-validated .custom-control-input:valid ~ .custom-control-label, .custom-control-input.is-valid ~ .custom-control-label {
    color: var(--cor-valid);
}

    .was-validated .custom-control-input:valid ~ .custom-control-label::before, .custom-control-input.is-valid ~ .custom-control-label::before {
        border-color: var(--cor-valid);
    }

.was-validated .custom-control-input:valid:checked ~ .custom-control-label::before, .custom-control-input.is-valid:checked ~ .custom-control-label::before {
    border-color: #34ce57;
    background-color: #34ce57;
}

.was-validated .custom-control-input:valid:focus ~ .custom-control-label::before, .custom-control-input.is-valid:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.was-validated .custom-control-input:valid:focus:not(:checked) ~ .custom-control-label::before, .custom-control-input.is-valid:focus:not(:checked) ~ .custom-control-label::before {
    border-color: var(--cor-valid);
}

.was-validated .custom-file-input:valid ~ .custom-file-label, .custom-file-input.is-valid ~ .custom-file-label {
    border-color: var(--cor-valid);
}

.was-validated .custom-file-input:valid:focus ~ .custom-file-label, .custom-file-input.is-valid:focus ~ .custom-file-label {
    border-color: var(--cor-valid);
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: var(--espacamento-1);
    font-size: 80%;
    color: var(--cor-invalid);
}

.invalid-tooltip {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: 0.25rem 0.5rem;
    margin-top: 0.1rem;
    font-size: var(--fonte-sm);
    line-height: 1.5;
    color: var(--cor-texto-branco);
    background-color: rgba(220, 53, 69, 0.9);
    border-radius: var(--raio-base);
}

.was-validated :invalid ~ .invalid-feedback,
.was-validated :invalid ~ .invalid-tooltip,
.is-invalid ~ .invalid-feedback,
.is-invalid ~ .invalid-tooltip {
    display: block;
}

.was-validated .form-control:invalid, .form-control.is-invalid {
    border-color: var(--cor-invalid);
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .was-validated .form-control:invalid:focus, .form-control.is-invalid:focus {
        border-color: var(--cor-invalid);
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
    }

.was-validated textarea.form-control:invalid, textarea.form-control.is-invalid {
    padding-right: calc(1.5em + 0.75rem);
    background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}

.was-validated .custom-select:invalid, .custom-select.is-invalid {
    border-color: var(--cor-invalid);
    padding-right: calc(0.75em + 2.3125rem);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px, url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e") var(--cor-fundo) no-repeat center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .was-validated .custom-select:invalid:focus, .custom-select.is-invalid:focus {
        border-color: var(--cor-invalid);
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
    }

.was-validated .form-check-input:invalid ~ .form-check-label, .form-check-input.is-invalid ~ .form-check-label {
    color: var(--cor-invalid);
}

.was-validated .form-check-input:invalid ~ .invalid-feedback, .was-validated .form-check-input:invalid ~ .invalid-tooltip, .form-check-input.is-invalid ~ .invalid-feedback, .form-check-input.is-invalid ~ .invalid-tooltip {
    display: block;
}

.was-validated .custom-control-input:invalid ~ .custom-control-label, .custom-control-input.is-invalid ~ .custom-control-label {
    color: var(--cor-invalid);
}

    .was-validated .custom-control-input:invalid ~ .custom-control-label::before, .custom-control-input.is-invalid ~ .custom-control-label::before {
        border-color: var(--cor-invalid);
    }

.was-validated .custom-control-input:invalid:checked ~ .custom-control-label::before, .custom-control-input.is-invalid:checked ~ .custom-control-label::before {
    border-color: #e4606d;
    background-color: #e4606d;
}

.was-validated .custom-control-input:invalid:focus ~ .custom-control-label::before, .custom-control-input.is-invalid:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.was-validated .custom-control-input:invalid:focus:not(:checked) ~ .custom-control-label::before, .custom-control-input.is-invalid:focus:not(:checked) ~ .custom-control-label::before {
    border-color: var(--cor-invalid);
}

.was-validated .custom-file-input:invalid ~ .custom-file-label, .custom-file-input.is-invalid ~ .custom-file-label {
    border-color: var(--cor-invalid);
}

.was-validated .custom-file-input:invalid:focus ~ .custom-file-label, .custom-file-input.is-invalid:focus ~ .custom-file-label {
    border-color: var(--cor-invalid);
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

/* Form Inline */
.form-inline {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
}

    .form-inline .form-check {
        width: 100%;
    }

@media (min-width: 576px) {
    .form-inline label {
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 0;
    }

    .form-inline .form-group {
        display: flex;
        flex: 0 0 auto;
        flex-flow: row wrap;
        align-items: center;
        margin-bottom: 0;
    }

    .form-inline .form-control {
        display: inline-block;
        width: auto;
        vertical-align: middle;
    }

    .form-inline .form-control-plaintext {
        display: inline-block;
    }

    .form-inline .input-group, .form-inline .custom-select {
        width: auto;
    }

    .form-inline .form-check {
        display: flex;
        align-items: center;
        justify-content: center;
        width: auto;
        padding-left: 0;
    }

    .form-inline .form-check-input {
        position: relative;
        flex-shrink: 0;
        margin-top: 0;
        margin-right: 0.25rem;
        margin-left: 0;
    }

    .form-inline .custom-control {
        align-items: center;
        justify-content: center;
    }

    .form-inline .custom-control-label {
        margin-bottom: 0;
    }
}

/* Form Floating */
.form-floating {
    position: relative;
}

    .form-floating > .form-control, .form-floating > .form-select {
        height: calc(3.5rem + 2px);
        padding: 1rem 0.75rem;
    }

    .form-floating > label {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        padding: 1rem 0.75rem;
        pointer-events: none;
        border: 1px solid transparent;
        transform-origin: 0 0;
        transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out;
        color: var(--cor-texto-secundario);
    }

    .form-floating > .form-control:focus ~ label,
    .form-floating > .form-control:not(:placeholder-shown) ~ label,
    .form-floating > .form-select ~ label {
        opacity: 0.65;
        transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
    }

/* Inputs customizados */
input[type="email"], input[type="password"], input[type="text"], textarea, input[type="submit"], input[type="button"] {
    padding: 12px 8px;
    box-sizing: border-box;
    border: 1px solid var(--cor-borda-input);
    border-radius: var(--raio-base);
    background-color: var(--cor-fundo);
    margin-bottom: 10px;
    font-size: 13px;
}

button:not(:disabled), [type=button]:not(:disabled), [type=reset]:not(:disabled), [type=submit]:not(:disabled) {
    color: var(--cor-texto-branco);
    font-weight: bold;
    cursor: pointer;
    border: 1px solid transparent;
    padding: 0.55rem 0.75rem;
    font-size: var(--fonte-base);
    line-height: 1.5;
    border-radius: var(--raio-base);
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    background-color: var(--cor-destaque);
    border-color: var(--cor-destaque) !important;
}


/* ============================================
   GRID SYSTEM
   ============================================ */
.conteudo,
.conteudo-fluid,
.conteudo-xl,
.conteudo-lg,
.conteudo-md,
.conteudo-sm {
    width: 100%;
    padding-right: 0.75rem;
    padding-left: 0.75rem;
    margin-right: auto;
    margin-left: auto;
}

.conteudo-full {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 576px) {
    .conteudo-sm, .conteudo {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .conteudo-md, .conteudo-sm, .conteudo {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .conteudo-lg, .conteudo-md, .conteudo-sm, .conteudo {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .conteudo-xl, .conteudo-lg, .conteudo-md, .conteudo-sm, .conteudo {
        max-width: 1140px;
    }
}

@media (min-width: 1400px) {
    .conteudo-xxl, .conteudo-xl, .conteudo-lg, .conteudo-md, .conteudo-sm, .conteudo {
        max-width: 1320px;
    }
}

.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -0.75rem;
    margin-left: -0.75rem;
    justify-content: center;
}

.col-xl, .col-xl-auto, .col-xl-12, .col-xl-11, .col-xl-10, .col-xl-9, .col-xl-8, .col-xl-7, .col-xl-6, .col-xl-5, .col-xl-4, .col-xl-3, .col-xl-2, .col-xl-1,
.col-lg, .col-lg-auto, .col-lg-12, .col-lg-11, .col-lg-10, .col-lg-9, .col-lg-8, .col-lg-7, .col-lg-6, .col-lg-5, .col-lg-4, .col-lg-3, .col-lg-3-2, .col-lg-2, .col-lg-1,
.col-md, .col-md-auto, .col-md-12, .col-md-11, .col-md-10, .col-md-9, .col-md-8, .col-md-7, .col-md-6, .col-md-5, .col-md-4, .col-md-3, .col-md-2, .col-md-1,
.col-sm, .col-sm-auto, .col-sm-12, .col-sm-11, .col-sm-10, .col-sm-9, .col-sm-8, .col-sm-7, .col-sm-6, .col-sm-5, .col-sm-4, .col-sm-3, .col-sm-2, .col-sm-1,
.col, .col-auto, .col-12, .col-11, .col-10, .col-9, .col-8, .col-7, .col-6, .col-5, .col-4, .col-3, .col-2, .col-1 {
    position: relative;
    width: 100%;
    padding-right: 0.75rem;
    padding-left: 0.75rem;
}

.col {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
}

.col-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
}

.col-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
}

.col-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
}

.col-3 {
    flex: 0 0 25%;
    max-width: 25%;
}

.col-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
}

.col-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
}

.col-6 {
    flex: 0 0 50%;
    max-width: 50%;
}

.col-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
}

.col-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
}

.col-9 {
    flex: 0 0 75%;
    max-width: 75%;
}

.col-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
}

.col-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
}

.col-12 {
    flex: 0 0 100%;
    max-width: 100%;
}

.row-cols-1 > * {
    flex: 0 0 100%;
    max-width: 100%;
}

.row-cols-2 > * {
    flex: 0 0 50%;
    max-width: 50%;
}

.row-cols-3 > * {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
}

.row-cols-4 > * {
    flex: 0 0 25%;
    max-width: 25%;
}

.row-cols-5 > * {
    flex: 0 0 20%;
    max-width: 20%;
}

.row-cols-6 > * {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
}

/* Order */
.order-first {
    order: -1;
}

.order-last {
    order: 13;
}

.order-0 {
    order: 0;
}

.order-1 {
    order: 1;
}

.order-2 {
    order: 2;
}

.order-3 {
    order: 3;
}

.order-4 {
    order: 4;
}

.order-5 {
    order: 5;
}

.order-6 {
    order: 6;
}

.order-7 {
    order: 7;
}

.order-8 {
    order: 8;
}

.order-9 {
    order: 9;
}

.order-10 {
    order: 10;
}

.order-11 {
    order: 11;
}

.order-12 {
    order: 12;
}

/* Offset */
.offset-1 {
    margin-left: 8.3333333333%;
}

.offset-2 {
    margin-left: 16.6666666667%;
}

.offset-3 {
    margin-left: 25%;
}

.offset-4 {
    margin-left: 33.3333333333%;
}

.offset-5 {
    margin-left: 41.6666666667%;
}

.offset-6 {
    margin-left: 50%;
}

.offset-7 {
    margin-left: 58.3333333333%;
}

.offset-8 {
    margin-left: 66.6666666667%;
}

.offset-9 {
    margin-left: 75%;
}

.offset-10 {
    margin-left: 83.3333333333%;
}

.offset-11 {
    margin-left: 91.6666666667%;
}

/* SM Breakpoint */
@media (min-width: 576px) {
    .col-sm {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%;
    }

    .col-sm-auto {
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-sm-1 {
        flex: 0 0 8.3333333333%;
        max-width: 8.3333333333%;
    }

    .col-sm-2 {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .col-sm-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-sm-4 {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .col-sm-5 {
        flex: 0 0 41.6666666667%;
        max-width: 41.6666666667%;
    }

    .col-sm-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-sm-7 {
        flex: 0 0 58.3333333333%;
        max-width: 58.3333333333%;
    }

    .col-sm-8 {
        flex: 0 0 66.6666666667%;
        max-width: 66.6666666667%;
    }

    .col-sm-9 {
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-sm-10 {
        flex: 0 0 83.3333333333%;
        max-width: 83.3333333333%;
    }

    .col-sm-11 {
        flex: 0 0 91.6666666667%;
        max-width: 91.6666666667%;
    }

    .col-sm-12 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-sm-1 > * {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-sm-2 > * {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-sm-3 > * {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .row-cols-sm-4 > * {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-sm-5 > * {
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-sm-6 > * {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .order-sm-first {
        order: -1;
    }

    .order-sm-last {
        order: 13;
    }

    .order-sm-0 {
        order: 0;
    }

    .order-sm-1 {
        order: 1;
    }

    .order-sm-2 {
        order: 2;
    }

    .order-sm-3 {
        order: 3;
    }

    .order-sm-4 {
        order: 4;
    }

    .order-sm-5 {
        order: 5;
    }

    .order-sm-6 {
        order: 6;
    }

    .order-sm-7 {
        order: 7;
    }

    .order-sm-8 {
        order: 8;
    }

    .order-sm-9 {
        order: 9;
    }

    .order-sm-10 {
        order: 10;
    }

    .order-sm-11 {
        order: 11;
    }

    .order-sm-12 {
        order: 12;
    }

    .offset-sm-0 {
        margin-left: 0;
    }

    .offset-sm-1 {
        margin-left: 8.3333333333%;
    }

    .offset-sm-2 {
        margin-left: 16.6666666667%;
    }

    .offset-sm-3 {
        margin-left: 25%;
    }

    .offset-sm-4 {
        margin-left: 33.3333333333%;
    }

    .offset-sm-5 {
        margin-left: 41.6666666667%;
    }

    .offset-sm-6 {
        margin-left: 50%;
    }

    .offset-sm-7 {
        margin-left: 58.3333333333%;
    }

    .offset-sm-8 {
        margin-left: 66.6666666667%;
    }

    .offset-sm-9 {
        margin-left: 75%;
    }

    .offset-sm-10 {
        margin-left: 83.3333333333%;
    }

    .offset-sm-11 {
        margin-left: 91.6666666667%;
    }
}

/* MD Breakpoint */
@media (min-width: 768px) {
    .col-md {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%;
    }

    .col-md-auto {
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-md-1 {
        flex: 0 0 8.3333333333%;
        max-width: 8.3333333333%;
    }

    .col-md-2 {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .col-md-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-md-4 {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .col-md-5 {
        flex: 0 0 41.6666666667%;
        max-width: 41.6666666667%;
    }

    .col-md-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-md-7 {
        flex: 0 0 58.3333333333%;
        max-width: 58.3333333333%;
    }

    .col-md-8 {
        flex: 0 0 66.6666666667%;
        max-width: 66.6666666667%;
    }

    .col-md-9 {
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-md-10 {
        flex: 0 0 83.3333333333%;
        max-width: 83.3333333333%;
    }

    .col-md-11 {
        flex: 0 0 91.6666666667%;
        max-width: 91.6666666667%;
    }

    .col-md-12 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-md-1 > * {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-md-2 > * {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-md-3 > * {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .row-cols-md-4 > * {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-md-5 > * {
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-md-6 > * {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .order-md-first {
        order: -1;
    }

    .order-md-last {
        order: 13;
    }

    .order-md-0 {
        order: 0;
    }

    .order-md-1 {
        order: 1;
    }

    .order-md-2 {
        order: 2;
    }

    .order-md-3 {
        order: 3;
    }

    .order-md-4 {
        order: 4;
    }

    .order-md-5 {
        order: 5;
    }

    .order-md-6 {
        order: 6;
    }

    .order-md-7 {
        order: 7;
    }

    .order-md-8 {
        order: 8;
    }

    .order-md-9 {
        order: 9;
    }

    .order-md-10 {
        order: 10;
    }

    .order-md-11 {
        order: 11;
    }

    .order-md-12 {
        order: 12;
    }

    .offset-md-0 {
        margin-left: 0;
    }

    .offset-md-1 {
        margin-left: 8.3333333333%;
    }

    .offset-md-2 {
        margin-left: 16.6666666667%;
    }

    .offset-md-3 {
        margin-left: 25%;
    }

    .offset-md-4 {
        margin-left: 33.3333333333%;
    }

    .offset-md-5 {
        margin-left: 41.6666666667%;
    }

    .offset-md-6 {
        margin-left: 50%;
    }

    .offset-md-7 {
        margin-left: 58.3333333333%;
    }

    .offset-md-8 {
        margin-left: 66.6666666667%;
    }

    .offset-md-9 {
        margin-left: 75%;
    }

    .offset-md-10 {
        margin-left: 83.3333333333%;
    }

    .offset-md-11 {
        margin-left: 91.6666666667%;
    }
}

/* LG Breakpoint */
@media (min-width: 992px) {
    .col-lg {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%;
    }

    .col-lg-auto {
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-lg-1 {
        flex: 0 0 8.3333333333%;
        max-width: 8.3333333333%;
    }

    .col-lg-2 {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .col-lg-3-2 {
        flex: 0 0 20%;
        max-width: 20%;
    }

    .col-lg-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-lg-4 {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .col-lg-5 {
        flex: 0 0 41.6666666667%;
        max-width: 41.6666666667%;
    }

    .col-lg-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-lg-7 {
        flex: 0 0 58.3333333333%;
        max-width: 58.3333333333%;
    }

    .col-lg-8 {
        flex: 0 0 66.6666666667%;
        max-width: 66.6666666667%;
    }

    .col-lg-9 {
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-lg-10 {
        flex: 0 0 83.3333333333%;
        max-width: 83.3333333333%;
    }

    .col-lg-11 {
        flex: 0 0 91.6666666667%;
        max-width: 91.6666666667%;
    }

    .col-lg-12 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-lg-1 > * {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-lg-2 > * {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-lg-3 > * {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .row-cols-lg-4 > * {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-lg-5 > * {
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-lg-6 > * {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .order-lg-first {
        order: -1;
    }

    .order-lg-last {
        order: 13;
    }

    .order-lg-0 {
        order: 0;
    }

    .order-lg-1 {
        order: 1;
    }

    .order-lg-2 {
        order: 2;
    }

    .order-lg-3 {
        order: 3;
    }

    .order-lg-4 {
        order: 4;
    }

    .order-lg-5 {
        order: 5;
    }

    .order-lg-6 {
        order: 6;
    }

    .order-lg-7 {
        order: 7;
    }

    .order-lg-8 {
        order: 8;
    }

    .order-lg-9 {
        order: 9;
    }

    .order-lg-10 {
        order: 10;
    }

    .order-lg-11 {
        order: 11;
    }

    .order-lg-12 {
        order: 12;
    }

    .offset-lg-0 {
        margin-left: 0;
    }

    .offset-lg-1 {
        margin-left: 8.3333333333%;
    }

    .offset-lg-2 {
        margin-left: 16.6666666667%;
    }

    .offset-lg-3 {
        margin-left: 25%;
    }

    .offset-lg-4 {
        margin-left: 33.3333333333%;
    }

    .offset-lg-5 {
        margin-left: 41.6666666667%;
    }

    .offset-lg-6 {
        margin-left: 50%;
    }

    .offset-lg-7 {
        margin-left: 58.3333333333%;
    }

    .offset-lg-8 {
        margin-left: 66.6666666667%;
    }

    .offset-lg-9 {
        margin-left: 75%;
    }

    .offset-lg-10 {
        margin-left: 83.3333333333%;
    }

    .offset-lg-11 {
        margin-left: 91.6666666667%;
    }
}

/* XL Breakpoint */
@media (min-width: 1200px) {
    .col-xl {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%;
    }

    .col-xl-auto {
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-xl-1 {
        flex: 0 0 8.3333333333%;
        max-width: 8.3333333333%;
    }

    .col-xl-2 {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .col-xl-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-xl-4 {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .col-xl-5 {
        flex: 0 0 41.6666666667%;
        max-width: 41.6666666667%;
    }

    .col-xl-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-xl-7 {
        flex: 0 0 58.3333333333%;
        max-width: 58.3333333333%;
    }

    .col-xl-8 {
        flex: 0 0 66.6666666667%;
        max-width: 66.6666666667%;
    }

    .col-xl-9 {
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-xl-10 {
        flex: 0 0 83.3333333333%;
        max-width: 83.3333333333%;
    }

    .col-xl-11 {
        flex: 0 0 91.6666666667%;
        max-width: 91.6666666667%;
    }

    .col-xl-12 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-xl-1 > * {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-xl-2 > * {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-xl-3 > * {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .row-cols-xl-4 > * {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-xl-5 > * {
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-xl-6 > * {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .order-xl-first {
        order: -1;
    }

    .order-xl-last {
        order: 13;
    }

    .order-xl-0 {
        order: 0;
    }

    .order-xl-1 {
        order: 1;
    }

    .order-xl-2 {
        order: 2;
    }

    .order-xl-3 {
        order: 3;
    }

    .order-xl-4 {
        order: 4;
    }

    .order-xl-5 {
        order: 5;
    }

    .order-xl-6 {
        order: 6;
    }

    .order-xl-7 {
        order: 7;
    }

    .order-xl-8 {
        order: 8;
    }

    .order-xl-9 {
        order: 9;
    }

    .order-xl-10 {
        order: 10;
    }

    .order-xl-11 {
        order: 11;
    }

    .order-xl-12 {
        order: 12;
    }

    .offset-xl-0 {
        margin-left: 0;
    }

    .offset-xl-1 {
        margin-left: 8.3333333333%;
    }

    .offset-xl-2 {
        margin-left: 16.6666666667%;
    }

    .offset-xl-3 {
        margin-left: 25%;
    }

    .offset-xl-4 {
        margin-left: 33.3333333333%;
    }

    .offset-xl-5 {
        margin-left: 41.6666666667%;
    }

    .offset-xl-6 {
        margin-left: 50%;
    }

    .offset-xl-7 {
        margin-left: 58.3333333333%;
    }

    .offset-xl-8 {
        margin-left: 66.6666666667%;
    }

    .offset-xl-9 {
        margin-left: 75%;
    }

    .offset-xl-10 {
        margin-left: 83.3333333333%;
    }

    .offset-xl-11 {
        margin-left: 91.6666666667%;
    }
}

/* XXL Breakpoint */
@media (min-width: 1400px) {
    .col-xxl {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%;
    }

    .col-xxl-auto {
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-xxl-1 {
        flex: 0 0 8.3333333333%;
        max-width: 8.3333333333%;
    }

    .col-xxl-2 {
        flex: 0 0 16.6666666667%;
        max-width: 16.6666666667%;
    }

    .col-xxl-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-xxl-4 {
        flex: 0 0 33.3333333333%;
        max-width: 33.3333333333%;
    }

    .col-xxl-5 {
        flex: 0 0 41.6666666667%;
        max-width: 41.6666666667%;
    }

    .col-xxl-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-xxl-7 {
        flex: 0 0 58.3333333333%;
        max-width: 58.3333333333%;
    }

    .col-xxl-8 {
        flex: 0 0 66.6666666667%;
        max-width: 66.6666666667%;
    }

    .col-xxl-9 {
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-xxl-10 {
        flex: 0 0 83.3333333333%;
        max-width: 83.3333333333%;
    }

    .col-xxl-11 {
        flex: 0 0 91.6666666667%;
        max-width: 91.6666666667%;
    }

    .col-xxl-12 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .offset-xxl-0 {
        margin-left: 0;
    }

    .offset-xxl-1 {
        margin-left: 8.3333333333%;
    }

    .offset-xxl-2 {
        margin-left: 16.6666666667%;
    }

    .offset-xxl-3 {
        margin-left: 25%;
    }

    .offset-xxl-4 {
        margin-left: 33.3333333333%;
    }

    .offset-xxl-5 {
        margin-left: 41.6666666667%;
    }

    .offset-xxl-6 {
        margin-left: 50%;
    }

    .offset-xxl-7 {
        margin-left: 58.3333333333%;
    }

    .offset-xxl-8 {
        margin-left: 66.6666666667%;
    }

    .offset-xxl-9 {
        margin-left: 75%;
    }

    .offset-xxl-10 {
        margin-left: 83.3333333333%;
    }

    .offset-xxl-11 {
        margin-left: 91.6666666667%;
    }

    .d-xxl-none {
        display: none !important;
    }

    .d-xxl-inline {
        display: inline !important;
    }

    .d-xxl-inline-block {
        display: inline-block !important;
    }

    .d-xxl-block {
        display: block !important;
    }

    .d-xxl-flex {
        display: flex !important;
    }

    .d-xxl-inline-flex {
        display: inline-flex !important;
    }
}

/* Gutter */
.g-0, .gx-0 {
    --bs-gutter-x: 0;
}

.g-0, .gy-0 {
    --bs-gutter-y: 0;
}

.g-1, .gx-1 {
    --bs-gutter-x: 0.25rem;
}

.g-1, .gy-1 {
    --bs-gutter-y: 0.25rem;
}

.g-2, .gx-2 {
    --bs-gutter-x: 0.5rem;
}

.g-2, .gy-2 {
    --bs-gutter-y: 0.5rem;
}

.g-3, .gx-3 {
    --bs-gutter-x: 1rem;
}

.g-3, .gy-3 {
    --bs-gutter-y: 1rem;
}

.g-4, .gx-4 {
    --bs-gutter-x: 1.5rem;
}

.g-4, .gy-4 {
    --bs-gutter-y: 1.5rem;
}

.g-5, .gx-5 {
    --bs-gutter-x: 3rem;
}

.g-5, .gy-5 {
    --bs-gutter-y: 3rem;
}

.row[class*="g-"] {
    margin-right: calc(var(--bs-gutter-x, 0.75rem) * -0.5);
    margin-left: calc(var(--bs-gutter-x, 0.75rem) * -0.5);
    row-gap: var(--bs-gutter-y, 0);
}

    .row[class*="g-"] > * {
        padding-right: calc(var(--bs-gutter-x, 0.75rem) * 0.5);
        padding-left: calc(var(--bs-gutter-x, 0.75rem) * 0.5);
    }


/* ============================================
   BOTÕES
   ============================================ */
.btn {
    display: inline-block;
    font-weight: 400;
    color: var(--cor-texto);
    text-align: center;
    vertical-align: middle;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: 0.375rem 0.75rem;
    font-size: var(--fonte-base);
    line-height: 1.5;
    border-radius: var(--raio-base);
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .btn {
        transition: none;
    }
}

.btn:hover {
    color: var(--cor-texto);
    text-decoration: none;
}

.btn:focus, .btn.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem var(--cor-focus-shadow);
}

.btn.disabled, .btn:disabled {
    opacity: 0.65;
}

.btn:not(:disabled):not(.disabled) {
    cursor: pointer;
}

a.btn.disabled, fieldset:disabled a.btn {
    pointer-events: none;
}

/* Btn Primary */
.btn-primary {
    color: var(--cor-texto-branco);
    background-color: var(--cor-destaque);
    border-color: var(--cor-destaque);
    border-radius: 10px;
    transition: all ease .2s;
}

    .btn-primary:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria-hover);
        border-color: var(--cor-primaria-active);
        transform: scale3d(1.05, 1.05, 1.05);
    }

    .btn-primary:focus, .btn-primary.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
        box-shadow: 0 0 0 0.2rem rgba(254, 216, 84, 0.5);
    }

    .btn-primary.disabled, .btn-primary:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

    .btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active, .show > .btn-primary.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria-dark);
        border-color: var(--cor-primaria-dark);
    }

        .btn-primary:not(:disabled):not(.disabled):active:focus, .btn-primary:not(:disabled):not(.disabled).active:focus, .show > .btn-primary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(254, 216, 84, 0.5);
        }

/* Btn Secondary */
.btn-secondary {
    color: var(--cor-texto-branco);
    background-color: var(--cor-secundaria);
    border-color: var(--cor-secundaria);
    border-radius: 10px;
}

    .btn-secondary:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-secundaria-hover);
        border-color: var(--cor-secundaria-hover);
    }

    .btn-secondary:focus, .btn-secondary.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria-dark);
        border-color: var(--cor-primaria-dark);
        box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5);
    }

    .btn-secondary.disabled, .btn-secondary:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-secundaria-dark);
        border-color: var(--cor-secundaria-dark);
    }

    .btn-secondary:not(:disabled):not(.disabled):active, .btn-secondary:not(:disabled):not(.disabled).active, .show > .btn-secondary.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: #545b62;
        border-color: #4e555b;
    }

        .btn-secondary:not(:disabled):not(.disabled):active:focus, .btn-secondary:not(:disabled):not(.disabled).active:focus, .show > .btn-secondary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5);
        }

/* Btn Video */
.btn-video {
    color: var(--cor-texto-branco);
    background-color: var(--cor-dourado);
    border-color: var(--cor-dourado) !important;
}

    .btn-video:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-teal-dark);
        border-color: var(--cor-teal-dark) !important;
    }

    .btn-video:focus, .btn-video.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-teal-dark);
        border-color: var(--cor-teal-dark) !important;
    }

    .btn-video.disabled, .btn-video:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-roxo);
        border-color: var(--cor-roxo);
    }

    .btn-video:not(:disabled):not(.disabled):active, .btn-video:not(:disabled):not(.disabled).active, .show > .btn-video.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-roxo);
        border-color: var(--cor-roxo);
    }

        .btn-video:not(:disabled):not(.disabled):active:focus, .btn-video:not(:disabled):not(.disabled).active:focus, .show > .btn-video.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem var(--cor-roxo);
        }

/* Btn Success */
.btn-success {
    color: var(--cor-texto-branco);
    background-color: var(--cor-sucesso);
    border-color: var(--cor-sucesso);
}

    .btn-success:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-sucesso-hover);
        border-color: var(--cor-sucesso-active);
    }

    .btn-success:focus, .btn-success.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-sucesso-hover);
        border-color: var(--cor-sucesso-active);
        box-shadow: 0 0 0 0.2rem rgba(72, 180, 97, 0.5);
    }

    .btn-success.disabled, .btn-success:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-sucesso);
        border-color: var(--cor-sucesso);
    }

    .btn-success:not(:disabled):not(.disabled):active, .btn-success:not(:disabled):not(.disabled).active, .show > .btn-success.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-sucesso-active);
        border-color: #1c7430;
    }

        .btn-success:not(:disabled):not(.disabled):active:focus, .btn-success:not(:disabled):not(.disabled).active:focus, .show > .btn-success.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(72, 180, 97, 0.5);
        }

/* Btn Info */
.btn-info {
    color: var(--cor-texto-branco);
    background-color: var(--cor-info);
    border-color: var(--cor-info);
}

    .btn-info:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-info-hover);
        border-color: var(--cor-info-active);
    }

    .btn-info:focus, .btn-info.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-info-hover);
        border-color: var(--cor-info-active);
        box-shadow: 0 0 0 0.2rem rgba(58, 176, 195, 0.5);
    }

    .btn-info.disabled, .btn-info:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-info);
        border-color: var(--cor-info);
    }

    .btn-info:not(:disabled):not(.disabled):active, .btn-info:not(:disabled):not(.disabled).active, .show > .btn-info.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-info-active);
        border-color: #10707f;
    }

        .btn-info:not(:disabled):not(.disabled):active:focus, .btn-info:not(:disabled):not(.disabled).active:focus, .show > .btn-info.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(58, 176, 195, 0.5);
        }

/* Btn Warning */
.btn-warning {
    color: var(--cor-texto-branco);
    background-color: var(--cor-primaria);
    border-color: var(--cor-primaria);
}

    .btn-warning:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria-hover);
        border-color: var(--cor-primaria-active);
    }

    .btn-warning:focus, .btn-warning.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria-hover);
        border-color: var(--cor-primaria-active);
        box-shadow: 0 0 0 0.2rem rgba(254, 216, 84, 0.5);
    }

    .btn-warning.disabled, .btn-warning:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

    .btn-warning:not(:disabled):not(.disabled):active, .btn-warning:not(:disabled):not(.disabled).active, .show > .btn-warning.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria-active);
        border-color: #f3bd01;
    }

        .btn-warning:not(:disabled):not(.disabled):active:focus, .btn-warning:not(:disabled):not(.disabled).active:focus, .show > .btn-warning.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(254, 216, 84, 0.5);
        }

/* Btn Danger */
.btn-danger {
    color: var(--cor-texto-branco);
    background-color: var(--cor-perigo);
    border-color: var(--cor-perigo);
}

    .btn-danger:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-perigo-hover);
        border-color: var(--cor-perigo-active);
    }

    .btn-danger:focus, .btn-danger.focus {
        color: var(--cor-texto-branco);
        background-color: var(--cor-perigo-hover);
        border-color: var(--cor-perigo-active);
        box-shadow: 0 0 0 0.2rem rgba(225, 83, 97, 0.5);
    }

    .btn-danger.disabled, .btn-danger:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-perigo);
        border-color: var(--cor-perigo);
    }

    .btn-danger:not(:disabled):not(.disabled):active, .btn-danger:not(:disabled):not(.disabled).active, .show > .btn-danger.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-perigo-active);
        border-color: #b21f2d;
    }

        .btn-danger:not(:disabled):not(.disabled):active:focus, .btn-danger:not(:disabled):not(.disabled).active:focus, .show > .btn-danger.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(225, 83, 97, 0.5);
        }

/* Btn Claro */
.btn-claro {
    color: var(--cor-texto);
    background-color: #f8f9fa;
    border-color: #f8f9fa;
}

    .btn-claro:hover {
        color: var(--cor-texto);
        background-color: #e2e6ea;
        border-color: #dae0e5;
    }

    .btn-claro:focus, .btn-claro.focus {
        color: var(--cor-texto);
        background-color: #e2e6ea;
        border-color: #dae0e5;
        box-shadow: 0 0 0 0.2rem rgba(216, 217, 219, 0.5);
    }

    .btn-claro.disabled, .btn-claro:disabled {
        color: var(--cor-texto);
        background-color: #f8f9fa;
        border-color: #f8f9fa;
    }

    .btn-claro:not(:disabled):not(.disabled):active, .btn-claro:not(:disabled):not(.disabled).active, .show > .btn-claro.dropdown-toggle {
        color: var(--cor-texto);
        background-color: #dae0e5;
        border-color: #d3d9df;
    }

        .btn-claro:not(:disabled):not(.disabled):active:focus, .btn-claro:not(:disabled):not(.disabled).active:focus, .show > .btn-claro.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(216, 217, 219, 0.5);
        }

/* Btn Escuro */
.btn-escuro {
    color: var(--cor-texto-branco);
    background-color: var(--cor-fundo-escuro);
    border-color: var(--cor-fundo-escuro);
}

    .btn-escuro:hover {
        color: var(--cor-texto-branco);
        background-color: #23272b;
        border-color: #1d2124;
    }

    .btn-escuro:focus, .btn-escuro.focus {
        color: var(--cor-texto-branco);
        background-color: #23272b;
        border-color: #1d2124;
        box-shadow: 0 0 0 0.2rem rgba(82, 88, 93, 0.5);
    }

    .btn-escuro.disabled, .btn-escuro:disabled {
        color: var(--cor-texto-branco);
        background-color: var(--cor-fundo-escuro);
        border-color: var(--cor-fundo-escuro);
    }

    .btn-escuro:not(:disabled):not(.disabled):active, .btn-escuro:not(:disabled):not(.disabled).active, .show > .btn-escuro.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: #1d2124;
        border-color: #171a1d;
    }

        .btn-escuro:not(:disabled):not(.disabled):active:focus, .btn-escuro:not(:disabled):not(.disabled).active:focus, .show > .btn-escuro.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(82, 88, 93, 0.5);
        }

/* Btn Outline Primary */
.btn-outline-primary {
    color: var(--cor-primaria);
    border-color: var(--cor-primaria);
}

    .btn-outline-primary:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

    .btn-outline-primary:focus, .btn-outline-primary.focus {
        box-shadow: 0 0 0 0.2rem rgba(254, 209, 54, 0.5);
    }

    .btn-outline-primary.disabled, .btn-outline-primary:disabled {
        color: var(--cor-primaria);
        background-color: transparent;
    }

    .btn-outline-primary:not(:disabled):not(.disabled):active, .btn-outline-primary:not(:disabled):not(.disabled).active, .show > .btn-outline-primary.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

        .btn-outline-primary:not(:disabled):not(.disabled):active:focus, .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-primary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(254, 209, 54, 0.5);
        }

/* Btn Outline Secondary */
.btn-outline-secondary {
    color: var(--cor-secundaria-dark);
    border-color: var(--cor-secundaria-dark);
}

    .btn-outline-secondary:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-secundaria-dark);
        border-color: var(--cor-secundaria-dark);
    }

    .btn-outline-secondary:focus, .btn-outline-secondary.focus {
        box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
    }

    .btn-outline-secondary.disabled, .btn-outline-secondary:disabled {
        color: var(--cor-secundaria-dark);
        background-color: transparent;
    }

    .btn-outline-secondary:not(:disabled):not(.disabled):active, .btn-outline-secondary:not(:disabled):not(.disabled).active, .show > .btn-outline-secondary.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-secundaria-dark);
        border-color: var(--cor-secundaria-dark);
    }

        .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-secondary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
        }

/* Btn Outline Success */
.btn-outline-success {
    color: var(--cor-sucesso);
    border-color: var(--cor-sucesso);
}

    .btn-outline-success:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-sucesso);
        border-color: var(--cor-sucesso);
    }

    .btn-outline-success:focus, .btn-outline-success.focus {
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
    }

    .btn-outline-success.disabled, .btn-outline-success:disabled {
        color: var(--cor-sucesso);
        background-color: transparent;
    }

    .btn-outline-success:not(:disabled):not(.disabled):active, .btn-outline-success:not(:disabled):not(.disabled).active, .show > .btn-outline-success.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-sucesso);
        border-color: var(--cor-sucesso);
    }

        .btn-outline-success:not(:disabled):not(.disabled):active:focus, .btn-outline-success:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-success.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
        }

/* Btn Outline Info */
.btn-outline-info {
    color: var(--cor-info);
    border-color: var(--cor-info);
}

    .btn-outline-info:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-info);
        border-color: var(--cor-info);
    }

    .btn-outline-info:focus, .btn-outline-info.focus {
        box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
    }

    .btn-outline-info.disabled, .btn-outline-info:disabled {
        color: var(--cor-info);
        background-color: transparent;
    }

    .btn-outline-info:not(:disabled):not(.disabled):active, .btn-outline-info:not(:disabled):not(.disabled).active, .show > .btn-outline-info.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-info);
        border-color: var(--cor-info);
    }

        .btn-outline-info:not(:disabled):not(.disabled):active:focus, .btn-outline-info:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-info.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
        }

/* Btn Outline Warning */
.btn-outline-warning {
    color: var(--cor-primaria);
    border-color: var(--cor-primaria);
}

    .btn-outline-warning:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

    .btn-outline-warning:focus, .btn-outline-warning.focus {
        box-shadow: 0 0 0 0.2rem rgba(254, 209, 54, 0.5);
    }

    .btn-outline-warning.disabled, .btn-outline-warning:disabled {
        color: var(--cor-primaria);
        background-color: transparent;
    }

    .btn-outline-warning:not(:disabled):not(.disabled):active, .btn-outline-warning:not(:disabled):not(.disabled).active, .show > .btn-outline-warning.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

        .btn-outline-warning:not(:disabled):not(.disabled):active:focus, .btn-outline-warning:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-warning.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(254, 209, 54, 0.5);
        }

/* Btn Outline Danger */
.btn-outline-danger {
    color: var(--cor-perigo);
    border-color: var(--cor-perigo);
}

    .btn-outline-danger:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-perigo);
        border-color: var(--cor-perigo);
    }

    .btn-outline-danger:focus, .btn-outline-danger.focus {
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
    }

    .btn-outline-danger.disabled, .btn-outline-danger:disabled {
        color: var(--cor-perigo);
        background-color: transparent;
    }

    .btn-outline-danger:not(:disabled):not(.disabled):active, .btn-outline-danger:not(:disabled):not(.disabled).active, .show > .btn-outline-danger.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-perigo);
        border-color: var(--cor-perigo);
    }

        .btn-outline-danger:not(:disabled):not(.disabled):active:focus, .btn-outline-danger:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-danger.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
        }

/* Btn Outline Claro */
.btn-outline-claro {
    color: #f8f9fa;
    border-color: #f8f9fa;
}

    .btn-outline-claro:hover {
        color: var(--cor-texto);
        background-color: #f8f9fa;
        border-color: #f8f9fa;
    }

    .btn-outline-claro:focus, .btn-outline-claro.focus {
        box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
    }

    .btn-outline-claro.disabled, .btn-outline-claro:disabled {
        color: #f8f9fa;
        background-color: transparent;
    }

    .btn-outline-claro:not(:disabled):not(.disabled):active, .btn-outline-claro:not(:disabled):not(.disabled).active, .show > .btn-outline-claro.dropdown-toggle {
        color: var(--cor-texto);
        background-color: #f8f9fa;
        border-color: #f8f9fa;
    }

        .btn-outline-claro:not(:disabled):not(.disabled):active:focus, .btn-outline-claro:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-claro.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
        }

/* Btn Outline Escuro */
.btn-outline-escuro {
    color: var(--cor-fundo-escuro);
    border-color: var(--cor-fundo-escuro);
}

    .btn-outline-escuro:hover {
        color: var(--cor-texto-branco);
        background-color: var(--cor-fundo-escuro);
        border-color: var(--cor-fundo-escuro);
    }

    .btn-outline-escuro:focus, .btn-outline-escuro.focus {
        box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
    }

    .btn-outline-escuro.disabled, .btn-outline-escuro:disabled {
        color: var(--cor-fundo-escuro);
        background-color: transparent;
    }

    .btn-outline-escuro:not(:disabled):not(.disabled):active, .btn-outline-escuro:not(:disabled):not(.disabled).active, .show > .btn-outline-escuro.dropdown-toggle {
        color: var(--cor-texto-branco);
        background-color: var(--cor-fundo-escuro);
        border-color: var(--cor-fundo-escuro);
    }

        .btn-outline-escuro:not(:disabled):not(.disabled):active:focus, .btn-outline-escuro:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-escuro.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
        }

/* Btn Link */
.btn-link {
    font-weight: 400;
    color: var(--cor-primaria);
    text-decoration: none;
}

    .btn-link:hover {
        color: var(--cor-amarelo);
        text-decoration: underline;
    }

    .btn-link:focus, .btn-link.focus {
        text-decoration: underline;
    }

    .btn-link:disabled, .btn-link.disabled {
        color: var(--cor-texto-secundario);
        pointer-events: none;
    }

/* Btn Sizes */
.btn-lg, .btn-group-lg > .btn {
    padding: 0.5rem 1rem;
    font-size: var(--fonte-lg);
    line-height: 1.5;
    border-radius: var(--raio-lg);
}

.btn-sm, .btn-group-sm > .btn {
    padding: 0.25rem 0.5rem;
    font-size: var(--fonte-sm);
    line-height: 1.5;
    border-radius: var(--raio-sm);
}

.btn-block {
    display: block;
    width: 100%;
}

    .btn-block + .btn-block {
        margin-top: 0.5rem;
    }

input[type=submit].btn-block, input[type=reset].btn-block, input[type=button].btn-block {
    width: 100%;
}

.btn-xl {
    padding: 1.25rem 2.5rem;
    font-family: var(--fonte-titulos);
    font-size: 1.125rem;
    font-weight: 700;
}

.btn-xxl {
    padding: 1.25rem 2.5rem;
    font-family: var(--fonte-titulos);
    font-size: var(--fonte-xl);
    font-weight: 700;
}

.btn-social {
    height: 2.5rem;
    width: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border-radius: 8px;
}

/* Btn Close */
.btn-close {
    box-sizing: content-box;
    width: 1em;
    height: 1em;
    padding: 0.25em;
    color: #000;
    background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
    border: 0;
    border-radius: var(--raio-base);
    opacity: 0.5;
    cursor: pointer;
}

    .btn-close:hover {
        opacity: 0.75;
    }

    .btn-close:focus {
        outline: 0;
        box-shadow: 0 0 0 0.25rem rgba(0,110,163,0.25);
        opacity: 1;
    }

    .btn-close.disabled, .btn-close:disabled {
        opacity: 0.25;
        pointer-events: none;
    }

.btn-close-white {
    filter: invert(1) grayscale(100%) brightness(200%);
}


/* ============================================
   BUTTON GROUPS
   ============================================ */
.btn-group, .btn-group-vertical {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
}

    .btn-group > .btn, .btn-group-vertical > .btn {
        position: relative;
        flex: 1 1 auto;
    }

        .btn-group > .btn:hover, .btn-group-vertical > .btn:hover {
            z-index: 1;
        }

        .btn-group > .btn:focus, .btn-group > .btn:active, .btn-group > .btn.active, .btn-group-vertical > .btn:focus, .btn-group-vertical > .btn:active, .btn-group-vertical > .btn.active {
            z-index: 1;
        }

.btn-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

    .btn-toolbar .input-group {
        width: auto;
    }

.btn-group > .btn:not(:first-child), .btn-group > .btn-group:not(:first-child) {
    margin-left: -1px;
}

.btn-group > .btn:not(:last-child):not(.dropdown-toggle), .btn-group > .btn-group:not(:last-child) > .btn {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.btn-group > .btn:not(:first-child), .btn-group > .btn-group:not(:first-child) > .btn {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.dropdown-toggle-split {
    padding-right: 0.5625rem;
    padding-left: 0.5625rem;
}

    .dropdown-toggle-split::after, .dropup .dropdown-toggle-split::after, .dropright .dropdown-toggle-split::after {
        margin-left: 0;
    }

.dropleft .dropdown-toggle-split::before {
    margin-right: 0;
}

.btn-sm + .dropdown-toggle-split, .btn-group-sm > .btn + .dropdown-toggle-split {
    padding-right: 0.375rem;
    padding-left: 0.375rem;
}

.btn-lg + .dropdown-toggle-split, .btn-group-lg > .btn + .dropdown-toggle-split {
    padding-right: 0.75rem;
    padding-left: 0.75rem;
}

.btn-group-vertical {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

    .btn-group-vertical > .btn, .btn-group-vertical > .btn-group {
        width: 100%;
    }

        .btn-group-vertical > .btn:not(:first-child), .btn-group-vertical > .btn-group:not(:first-child) {
            margin-top: -1px;
        }

        .btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle), .btn-group-vertical > .btn-group:not(:last-child) > .btn {
            border-bottom-right-radius: 0;
            border-bottom-left-radius: 0;
        }

        .btn-group-vertical > .btn:not(:first-child), .btn-group-vertical > .btn-group:not(:first-child) > .btn {
            border-top-left-radius: 0;
            border-top-right-radius: 0;
        }

.btn-group-toggle > .btn, .btn-group-toggle > .btn-group > .btn {
    margin-bottom: 0;
}

    .btn-group-toggle > .btn input[type=radio], .btn-group-toggle > .btn input[type=checkbox], .btn-group-toggle > .btn-group > .btn input[type=radio], .btn-group-toggle > .btn-group > .btn input[type=checkbox] {
        position: absolute;
        clip: rect(0, 0, 0, 0);
        pointer-events: none;
    }


/* ============================================
   INPUT GROUPS
   ============================================ */
.input-group {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 100%;
}

    .input-group > .form-control, .input-group > .form-control-plaintext, .input-group > .custom-select, .input-group > .custom-file {
        position: relative;
        flex: 1 1 auto;
        width: 1%;
        min-width: 0;
        margin-bottom: 0;
    }

        .input-group > .form-control + .form-control, .input-group > .form-control + .custom-select, .input-group > .form-control + .custom-file,
        .input-group > .form-control-plaintext + .form-control, .input-group > .form-control-plaintext + .custom-select, .input-group > .form-control-plaintext + .custom-file,
        .input-group > .custom-select + .form-control, .input-group > .custom-select + .custom-select, .input-group > .custom-select + .custom-file,
        .input-group > .custom-file + .form-control, .input-group > .custom-file + .custom-select, .input-group > .custom-file + .custom-file {
            margin-left: -1px;
        }

        .input-group > .form-control:focus, .input-group > .custom-select:focus, .input-group > .custom-file .custom-file-input:focus ~ .custom-file-label {
            z-index: 3;
        }

        .input-group > .custom-file .custom-file-input:focus {
            z-index: 4;
        }

        .input-group > .form-control:not(:last-child), .input-group > .custom-select:not(:last-child) {
            border-top-right-radius: 0;
            border-bottom-right-radius: 0;
        }

        .input-group > .form-control:not(:first-child), .input-group > .custom-select:not(:first-child) {
            border-top-left-radius: 0;
            border-bottom-left-radius: 0;
        }

    .input-group > .custom-file {
        display: flex;
        align-items: center;
    }

        .input-group > .custom-file:not(:last-child) .custom-file-label, .input-group > .custom-file:not(:last-child) .custom-file-label::after {
            border-top-right-radius: 0;
            border-bottom-right-radius: 0;
        }

        .input-group > .custom-file:not(:first-child) .custom-file-label {
            border-top-left-radius: 0;
            border-bottom-left-radius: 0;
        }

.input-group-prepend, .input-group-append {
    display: flex;
}

    .input-group-prepend .btn, .input-group-append .btn {
        position: relative;
        z-index: 2;
    }

        .input-group-prepend .btn:focus, .input-group-append .btn:focus {
            z-index: 3;
        }

        .input-group-prepend .btn + .btn, .input-group-prepend .btn + .input-group-text, .input-group-prepend .input-group-text + .input-group-text, .input-group-prepend .input-group-text + .btn,
        .input-group-append .btn + .btn, .input-group-append .btn + .input-group-text, .input-group-append .input-group-text + .input-group-text, .input-group-append .input-group-text + .btn {
            margin-left: -1px;
        }

.input-group-prepend {
    margin-right: -1px;
}

.input-group-append {
    margin-left: -1px;
}

.input-group-text {
    display: flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    margin-bottom: 0;
    font-size: var(--fonte-base);
    font-weight: 400;
    line-height: 1.5;
    color: var(--cor-texto-claro);
    text-align: center;
    white-space: nowrap;
    background-color: var(--cor-borda-clara);
    border: 1px solid var(--cor-borda-input);
    border-radius: var(--raio-base);
}

    .input-group-text input[type=radio], .input-group-text input[type=checkbox] {
        margin-top: 0;
    }

.input-group-lg > .form-control:not(textarea), .input-group-lg > .custom-select {
    height: calc(1.5em + 1rem + 2px);
}

.input-group-lg > .form-control, .input-group-lg > .custom-select, .input-group-lg > .input-group-prepend > .input-group-text, .input-group-lg > .input-group-append > .input-group-text, .input-group-lg > .input-group-prepend > .btn, .input-group-lg > .input-group-append > .btn {
    padding: 0.5rem 1rem;
    font-size: var(--fonte-lg);
    line-height: 1.5;
    border-radius: var(--raio-lg);
}

.input-group-sm > .form-control:not(textarea), .input-group-sm > .custom-select {
    height: calc(1.5em + 0.5rem + 2px);
}

.input-group-sm > .form-control, .input-group-sm > .custom-select, .input-group-sm > .input-group-prepend > .input-group-text, .input-group-sm > .input-group-append > .input-group-text, .input-group-sm > .input-group-prepend > .btn, .input-group-sm > .input-group-append > .btn {
    padding: 0.25rem 0.5rem;
    font-size: var(--fonte-sm);
    line-height: 1.5;
    border-radius: var(--raio-sm);
}

.input-group-lg > .custom-select, .input-group-sm > .custom-select {
    padding-right: 1.75rem;
}

.input-group > .input-group-prepend > .btn, .input-group > .input-group-prepend > .input-group-text,
.input-group > .input-group-append:not(:last-child) > .btn, .input-group > .input-group-append:not(:last-child) > .input-group-text,
.input-group > .input-group-append:last-child > .btn:not(:last-child):not(.dropdown-toggle), .input-group > .input-group-append:last-child > .input-group-text:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group > .input-group-append > .btn, .input-group > .input-group-append > .input-group-text,
.input-group > .input-group-prepend:not(:first-child) > .btn, .input-group > .input-group-prepend:not(:first-child) > .input-group-text,
.input-group > .input-group-prepend:first-child > .btn:not(:first-child), .input-group > .input-group-prepend:first-child > .input-group-text:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}


/* ============================================
   NAVEGAÇÃO (Nav, Tabs, Pills)
   ============================================ */
.nav {
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.nav-link {
    display: block;
    padding: 0.5rem 1rem;
}

    .nav-link:hover, .nav-link:focus {
        text-decoration: none;
    }

    .nav-link.disabled {
        color: var(--cor-texto-secundario);
        pointer-events: none;
        cursor: default;
    }

.nav-tabs {
    border-bottom: 1px solid var(--cor-borda);
}

    .nav-tabs .nav-item {
        margin-bottom: -1px;
    }

    .nav-tabs .nav-link {
        border: 1px solid transparent;
        border-top-left-radius: var(--raio-base);
        border-top-right-radius: var(--raio-base);
    }

        .nav-tabs .nav-link:hover, .nav-tabs .nav-link:focus {
            border-color: var(--cor-borda-clara) var(--cor-borda-clara) var(--cor-borda);
        }

        .nav-tabs .nav-link.disabled {
            color: var(--cor-texto-secundario);
            background-color: transparent;
            border-color: transparent;
        }

        .nav-tabs .nav-link.active, .nav-tabs .nav-item.show .nav-link {
            color: var(--cor-texto-claro);
            background-color: var(--cor-fundo);
            border-color: var(--cor-borda) var(--cor-borda) var(--cor-fundo);
        }

    .nav-tabs .dropdown-menu {
        margin-top: -1px;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
    }

.nav-pills .nav-link {
    border-radius: var(--raio-base);
}

    .nav-pills .nav-link.active, .nav-pills .show > .nav-link {
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
    }

.nav-fill > .nav-link, .nav-fill .nav-item {
    flex: 1 1 auto;
    text-align: center;
}

.nav-justified > .nav-link, .nav-justified .nav-item {
    flex-basis: 0;
    flex-grow: 1;
    text-align: center;
}

.tab-content > .tab-pane {
    display: none;
}

.tab-content > .active {
    display: block;
}


/* ============================================
   BARRA DE NAVEGAÇÃO (Navbar)
   ============================================ */
.barra-navegacao {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}

    .barra-navegacao .conteudo, .barra-navegacao .conteudo-fluid, .barra-navegacao .conteudo-sm, .barra-navegacao .conteudo-md, .barra-navegacao .conteudo-lg, .barra-navegacao .conteudo-xl {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
    }

.barra-navegacao-brand {
    display: inline-block;
    padding-top: 0.3125rem;
    padding-bottom: 0.3125rem;
    margin-right: var(--espacamento-3);
    font-size: var(--fonte-lg);
    line-height: inherit;
    white-space: nowrap;
}

    .barra-navegacao-brand:hover, .barra-navegacao-brand:focus {
        text-decoration: none;
    }

.barra-navegacao-nav {
    display: flex;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

    .barra-navegacao-nav .nav-link {
        padding-right: 0;
        padding-left: 0;
    }

    .barra-navegacao-nav .dropdown-menu {
        position: static;
        float: none;
    }

.barra-navegacao-text {
    display: inline-block;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.barra-navegacao-collapse {
    flex-basis: 100%;
    flex-grow: 1;
    align-items: center;
    max-height: 100vh;
    overflow-y: hidden;
}

@media (max-height: 456px) {
    .barra-navegacao-collapse {
        overflow-y: scroll !important;
    }
}

.barra-navegacao-toggler {
    padding: 0.25rem 0.75rem;
    font-size: var(--fonte-lg);
    line-height: 1;
    background-color: transparent;
    border: 1px solid transparent;
    border-radius: var(--raio-base);
}

    .barra-navegacao-toggler:hover, .barra-navegacao-toggler:focus {
        text-decoration: none;
    }

.barra-navegacao-toggler-icon {
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    content: "";
    background: no-repeat center center;
    background-size: 100% 100%;
}

/* Navbar Expand SM */
@media (max-width: 575.98px) {
    .barra-navegacao-expand-sm > .conteudo, .barra-navegacao-expand-sm > .conteudo-fluid, .barra-navegacao-expand-sm > .conteudo-sm, .barra-navegacao-expand-sm > .conteudo-md, .barra-navegacao-expand-sm > .conteudo-lg, .barra-navegacao-expand-sm > .conteudo-xl {
        padding-right: 0;
        padding-left: 0;
    }

    .barra-navegacao-toggler-right span {
        display: none;
    }
}

@media (min-width: 576px) {
    .barra-navegacao-expand-sm {
        flex-flow: row nowrap;
        justify-content: flex-start;
    }

        .barra-navegacao-expand-sm .barra-navegacao-nav {
            flex-direction: row;
        }

            .barra-navegacao-expand-sm .barra-navegacao-nav .dropdown-menu {
                position: absolute;
            }

            .barra-navegacao-expand-sm .barra-navegacao-nav .nav-link {
                padding-right: 0.5rem;
                padding-left: 0.5rem;
            }

        .barra-navegacao-expand-sm > .conteudo, .barra-navegacao-expand-sm > .conteudo-fluid, .barra-navegacao-expand-sm > .conteudo-sm, .barra-navegacao-expand-sm > .conteudo-md, .barra-navegacao-expand-sm > .conteudo-lg, .barra-navegacao-expand-sm > .conteudo-xl {
            flex-wrap: nowrap;
        }

        .barra-navegacao-expand-sm .barra-navegacao-collapse {
            display: flex !important;
            flex-basis: auto;
        }

        .barra-navegacao-expand-sm .barra-navegacao-toggler {
            display: none;
        }
}

/* Navbar Expand MD */
@media (max-width: 767.98px) {
    .barra-navegacao-expand-md > .conteudo, .barra-navegacao-expand-md > .conteudo-fluid, .barra-navegacao-expand-md > .conteudo-sm, .barra-navegacao-expand-md > .conteudo-md, .barra-navegacao-expand-md > .conteudo-lg, .barra-navegacao-expand-md > .conteudo-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 768px) {
    .barra-navegacao-expand-md {
        flex-flow: row nowrap;
        justify-content: flex-start;
    }

        .barra-navegacao-expand-md .barra-navegacao-nav {
            flex-direction: row;
        }

            .barra-navegacao-expand-md .barra-navegacao-nav .dropdown-menu {
                position: absolute;
            }

            .barra-navegacao-expand-md .barra-navegacao-nav .nav-link {
                padding-right: 0.5rem;
                padding-left: 0.5rem;
            }

        .barra-navegacao-expand-md > .conteudo, .barra-navegacao-expand-md > .conteudo-fluid, .barra-navegacao-expand-md > .conteudo-sm, .barra-navegacao-expand-md > .conteudo-md, .barra-navegacao-expand-md > .conteudo-lg, .barra-navegacao-expand-md > .conteudo-xl {
            flex-wrap: nowrap;
        }

        .barra-navegacao-expand-md .barra-navegacao-collapse {
            display: flex !important;
            flex-basis: auto;
        }

        .barra-navegacao-expand-md .barra-navegacao-toggler {
            display: none;
        }
}

/* Navbar Expand LG */
@media (max-width: 991.98px) {
    .barra-navegacao-expand-lg > .conteudo, .barra-navegacao-expand-lg > .conteudo-fluid, .barra-navegacao-expand-lg > .conteudo-sm, .barra-navegacao-expand-lg > .conteudo-md, .barra-navegacao-expand-lg > .conteudo-lg, .barra-navegacao-expand-lg > .conteudo-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

/* Navbar Expand (always) */
.barra-navegacao-expand {
    flex-flow: row nowrap;
    justify-content: flex-start;
}

    .barra-navegacao-expand > .conteudo, .barra-navegacao-expand > .conteudo-fluid, .barra-navegacao-expand > .conteudo-sm, .barra-navegacao-expand > .conteudo-md, .barra-navegacao-expand > .conteudo-lg, .barra-navegacao-expand > .conteudo-xl {
        padding-right: 0;
        padding-left: 0;
        flex-wrap: nowrap;
    }

    .barra-navegacao-expand .barra-navegacao-nav {
        flex-direction: row;
    }

        .barra-navegacao-expand .barra-navegacao-nav .dropdown-menu {
            position: absolute;
        }

        .barra-navegacao-expand .barra-navegacao-nav .nav-link {
            padding-right: 0.5rem;
            padding-left: 0.5rem;
        }

    .barra-navegacao-expand .barra-navegacao-collapse {
        display: flex !important;
        flex-basis: auto;
    }

    .barra-navegacao-expand .barra-navegacao-toggler {
        display: none;
    }

/* Navbar Claro */
.barra-navegacao-claro .barra-navegacao-brand {
    color: rgba(0, 0, 0, 0.9);
}

    .barra-navegacao-claro .barra-navegacao-brand:hover, .barra-navegacao-claro .barra-navegacao-brand:focus {
        color: rgba(0, 0, 0, 0.9);
    }

.barra-navegacao-claro .barra-navegacao-nav .nav-link {
    color: rgba(0, 0, 0, 0.5);
}

    .barra-navegacao-claro .barra-navegacao-nav .nav-link:hover, .barra-navegacao-claro .barra-navegacao-nav .nav-link:focus {
        color: rgba(0, 0, 0, 0.7);
    }

    .barra-navegacao-claro .barra-navegacao-nav .nav-link.disabled {
        color: rgba(0, 0, 0, 0.3);
    }

    .barra-navegacao-claro .barra-navegacao-nav .show > .nav-link, .barra-navegacao-claro .barra-navegacao-nav .active > .nav-link, .barra-navegacao-claro .barra-navegacao-nav .nav-link.show, .barra-navegacao-claro .barra-navegacao-nav .nav-link.active {
        color: rgba(0, 0, 0, 0.9);
    }

.barra-navegacao-claro .barra-navegacao-toggler {
    color: rgba(0, 0, 0, 0.5);
    border-color: rgba(0, 0, 0, 0.1);
}

.barra-navegacao-claro .barra-navegacao-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.barra-navegacao-claro .barra-navegacao-text {
    color: rgba(0, 0, 0, 0.5);
}

    .barra-navegacao-claro .barra-navegacao-text a {
        color: rgba(0, 0, 0, 0.9);
    }

        .barra-navegacao-claro .barra-navegacao-text a:hover, .barra-navegacao-claro .barra-navegacao-text a:focus {
            color: rgba(0, 0, 0, 0.9);
        }

/* Navegação Principal */
#navegacao-principal {
    padding: var(--espacamento-3);
    background-color: var(--cor-fundo-navegacao);
}

    #navegacao-principal .barra-navegacao-toggler {
        padding: 0.75rem;
        font-family: var(--fonte-titulos);
        font-size: 0.75rem;
        color: var(--cor-texto-branco);
        text-transform: uppercase;
        background-color: var(--cor-secundaria);
        border: 0;
    }

    #navegacao-principal .barra-navegacao-brand {
        color: var(--cor-texto-branco);
        font-family: var(--fonte-titulos);
        font-weight: 700;
        letter-spacing: 0.0625em;
        text-transform: uppercase;
    }

        #navegacao-principal .barra-navegacao-brand img {
            height: 1.5rem;
        }

    #navegacao-principal .barra-navegacao-nav .nav-item .nav-link {
        font-family: var(--fonte-titulos);
        font-size: 0.95rem;
        color: var(--cor-texto-branco);
        letter-spacing: 0.0625em;
    }

        #navegacao-principal .barra-navegacao-nav .nav-item .nav-link.active,
        #navegacao-principal .barra-navegacao-nav .nav-item .nav-link:hover {
            color: var(--cor-texto-branco);
        }

@media (min-width: 992px) {
    #navegacao-principal {
        padding-top: var(--espacamento-4);
        padding-bottom: var(--espacamento-4);
        border: none;
        transition: padding-top 0.3s ease-in-out, padding-bottom 0.3s ease-in-out;
    }

        #navegacao-principal .barra-navegacao-brand {
            font-size: 1.5em;
            transition: font-size 0.3s ease-in-out;
        }

            #navegacao-principal .barra-navegacao-brand img {
                height: 2rem;
                transition: height 0.3s ease-in-out;
            }

        #navegacao-principal.barra-navegacao-shrink {
            padding-top: var(--espacamento-3);
            padding-bottom: var(--espacamento-3);
        }

            #navegacao-principal.barra-navegacao-shrink .barra-navegacao-brand {
                font-size: 1.25em;
            }

                #navegacao-principal.barra-navegacao-shrink .barra-navegacao-brand svg,
                #navegacao-principal.barra-navegacao-shrink .barra-navegacao-brand img {
                    height: 1.5rem;
                }
}


/* ============================================
   DROPDOWN
   ============================================ */
.dropup, .dropright, .dropdown, .dropleft {
    position: relative;
}

.dropdown-toggle {
    white-space: nowrap;
}

    .dropdown-toggle::after {
        display: inline-block;
        margin-left: 0.255em;
        vertical-align: 0.255em;
        content: "";
        border-top: 0.3em solid;
        border-right: 0.3em solid transparent;
        border-bottom: 0;
        border-left: 0.3em solid transparent;
    }

    .dropdown-toggle:empty::after {
        margin-left: 0;
    }

.dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: var(--z-dropdown);
    display: none;
    float: left;
    min-width: 10rem;
    padding: 0.5rem 0;
    margin: 0.125rem 0 0;
    font-size: var(--fonte-base);
    color: var(--cor-texto);
    text-align: left;
    list-style: none;
    background-color: var(--cor-fundo);
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: var(--raio-base);
}

.dropdown-menu-left {
    right: auto;
    left: 0;
}

.dropdown-menu-right {
    right: 0;
    left: auto;
}

@media (min-width: 576px) {
    .dropdown-menu-sm-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-sm-right {
        right: 0;
        left: auto;
    }
}

@media (min-width: 768px) {
    .dropdown-menu-md-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-md-right {
        right: 0;
        left: auto;
    }
}

@media (min-width: 992px) {
    .dropdown-menu-lg-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-lg-right {
        right: 0;
        left: auto;
    }
}

@media (min-width: 1200px) {
    .dropdown-menu-xl-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-xl-right {
        right: 0;
        left: auto;
    }
}

.dropup .dropdown-menu {
    top: auto;
    bottom: 100%;
    margin-top: 0;
    margin-bottom: 0.125rem;
}

.dropup .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0;
    border-right: 0.3em solid transparent;
    border-bottom: 0.3em solid;
    border-left: 0.3em solid transparent;
}

.dropup .dropdown-toggle:empty::after {
    margin-left: 0;
}

.dropright .dropdown-menu {
    top: 0;
    right: auto;
    left: 100%;
    margin-top: 0;
    margin-left: 0.125rem;
}

.dropright .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0.3em solid transparent;
    border-right: 0;
    border-bottom: 0.3em solid transparent;
    border-left: 0.3em solid;
}

.dropright .dropdown-toggle:empty::after {
    margin-left: 0;
}

.dropright .dropdown-toggle::after {
    vertical-align: 0;
}

.dropleft .dropdown-menu {
    top: 0;
    right: 100%;
    left: auto;
    margin-top: 0;
    margin-right: 0.125rem;
}

.dropleft .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    display: none;
}

.dropleft .dropdown-toggle::before {
    display: inline-block;
    margin-right: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0.3em solid transparent;
    border-right: 0.3em solid;
    border-bottom: 0.3em solid transparent;
}

.dropleft .dropdown-toggle:empty::after {
    margin-left: 0;
}

.dropleft .dropdown-toggle::before {
    vertical-align: 0;
}

.dropdown-menu[x-placement^=top], .dropdown-menu[x-placement^=right], .dropdown-menu[x-placement^=bottom], .dropdown-menu[x-placement^=left] {
    right: auto;
    bottom: auto;
}

.dropdown-divider {
    height: 0;
    margin: 0.5rem 0;
    overflow: hidden;
    border-top: 1px solid var(--cor-borda-clara);
}

.dropdown-item {
    display: block;
    width: 100%;
    padding: 0.25rem 1.5rem;
    clear: both;
    font-weight: 400;
    color: var(--cor-texto);
    text-align: inherit;
    white-space: nowrap;
    background-color: transparent;
    border: 0;
}

    .dropdown-item:hover, .dropdown-item:focus {
        color: #16181b;
        text-decoration: none;
        background-color: #f8f9fa;
    }

    .dropdown-item.active, .dropdown-item:active {
        color: var(--cor-texto-branco);
        text-decoration: none;
        background-color: var(--cor-primaria);
    }

    .dropdown-item.disabled, .dropdown-item:disabled {
        color: var(--cor-texto-secundario);
        pointer-events: none;
        background-color: transparent;
    }

.dropdown-menu.show {
    display: block;
}

.dropdown-header {
    display: block;
    padding: 0.5rem 1.5rem;
    margin-bottom: 0;
    font-size: var(--fonte-sm);
    color: var(--cor-texto-secundario);
    white-space: nowrap;
}

.dropdown-item-text {
    display: block;
    padding: 0.25rem 1.5rem;
    color: var(--cor-texto);
}


/* ============================================
   ALERTAS
   ============================================ */
.alert {
    position: relative;
    padding: 0.75rem 1.25rem;
    margin-bottom: var(--espacamento-3);
    border: 1px solid transparent;
    border-radius: var(--raio-base);
}

.alert-heading {
    color: inherit;
}

.alert-link {
    font-weight: 700;
}

.alert-dismissible {
    padding-right: 4rem;
}

    .alert-dismissible .close {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 2;
        padding: 0.75rem 1.25rem;
        color: inherit;
    }

.alert-primary {
    color: #846d1c;
    background-color: #fff6d7;
    border-color: var(--cor-tabela-primary-bg);
}

    .alert-primary hr {
        border-top-color: #ffecae;
    }

    .alert-primary .alert-link {
        color: #5a4a13;
    }

.alert-secondary {
    color: #383d41;
    background-color: #e2e3e5;
    border-color: #d6d8db;
}

    .alert-secondary hr {
        border-top-color: #c8cbcf;
    }

    .alert-secondary .alert-link {
        color: #202326;
    }

.alert-success {
    color: #155724;
    background-color: #d4edda;
    border-color: #c3e6cb;
}

    .alert-success hr {
        border-top-color: #b1dfbb;
    }

    .alert-success .alert-link {
        color: #0b2e13;
    }

.alert-info {
    color: #0c5460;
    background-color: #d1ecf1;
    border-color: #bee5eb;
}

    .alert-info hr {
        border-top-color: #abdde5;
    }

    .alert-info .alert-link {
        color: #062c33;
    }

.alert-warning {
    color: #846d1c;
    background-color: #fff6d7;
    border-color: var(--cor-tabela-primary-bg);
}

    .alert-warning hr {
        border-top-color: #ffecae;
    }

    .alert-warning .alert-link {
        color: #5a4a13;
    }

.alert-danger {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
}

    .alert-danger hr {
        border-top-color: #f1b0b7;
    }

    .alert-danger .alert-link {
        color: #491217;
    }

.alert-claro {
    color: #818182;
    background-color: #fefefe;
    border-color: #fdfdfe;
}

    .alert-claro hr {
        border-top-color: #ececf6;
    }

    .alert-claro .alert-link {
        color: #686868;
    }

.alert-escuro {
    color: #1b1e21;
    background-color: #d6d8d9;
    border-color: #c6c8ca;
}

    .alert-escuro hr {
        border-top-color: #b9bbbe;
    }

    .alert-escuro .alert-link {
        color: #040505;
    }


/* ============================================
   PROGRESS BAR
   ============================================ */
@keyframes progress-bar-stripes {
    from {
        background-position: 1rem 0;
    }

    to {
        background-position: 0 0;
    }
}

.progress {
    display: flex;
    height: 1rem;
    overflow: hidden;
    line-height: 0;
    font-size: 0.75rem;
    background-color: var(--cor-borda-clara);
    border-radius: var(--raio-base);
}

.progress-bar {
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    color: var(--cor-texto-branco);
    text-align: center;
    white-space: nowrap;
    background-color: var(--cor-primaria);
    transition: width 0.6s ease;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar {
        transition: none;
    }
}

.progress-bar-striped {
    background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
    background-size: 1rem 1rem;
}

.progress-bar-animated {
    animation: progress-bar-stripes 1s linear infinite;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar-animated {
        animation: none;
    }
}


/* ============================================
   SPINNERS
   ============================================ */
@keyframes spinner-border {
    to {
        transform: rotate(360deg);
    }
}

@keyframes spinner-grow {
    0% {
        transform: scale(0);
    }

    50% {
        opacity: 1;
        transform: none;
    }
}

.spinner-border {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    vertical-align: text-bottom;
    border: 0.25em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: spinner-border 0.75s linear infinite;
}

.spinner-border-sm {
    width: 1rem;
    height: 1rem;
    border-width: 0.2em;
}

.spinner-grow {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    vertical-align: text-bottom;
    background-color: currentColor;
    border-radius: 50%;
    opacity: 0;
    animation: spinner-grow 0.75s linear infinite;
}

.spinner-grow-sm {
    width: 1rem;
    height: 1rem;
}


/* ============================================
   MODAL
   ============================================ */
.modal-open {
    overflow: hidden;
}

    .modal-open .modal {
        overflow-x: hidden;
        overflow-y: auto;
    }

.modal {
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--z-modal);
    display: none;
    width: 100%;
    height: 100%;
    overflow: hidden;
    outline: 0;
}

.modal-dialog {
    position: relative;
    width: auto;
    margin: 0.5rem;
    pointer-events: none;
}

.modal.fade .modal-dialog {
    transition: transform 0.3s ease-out;
    transform: translate(0, -50px);
}

@media (prefers-reduced-motion: reduce) {
    .modal.fade .modal-dialog {
        transition: none;
    }
}

.modal.show .modal-dialog {
    transform: none;
}

.modal.modal-static .modal-dialog {
    transform: scale(1.02);
}

.modal-dialog-scrollable {
    display: flex;
    max-height: calc(100% - 1rem);
}

    .modal-dialog-scrollable .modal-content {
        max-height: calc(100vh - 1rem);
        overflow: hidden;
    }

    .modal-dialog-scrollable .modal-header, .modal-dialog-scrollable .modal-footer {
        flex-shrink: 0;
    }

    .modal-dialog-scrollable .modal-body {
        overflow-y: auto;
    }

.modal-dialog-centered {
    display: flex;
    align-items: center;
    min-height: calc(100% - 1rem);
}

    .modal-dialog-centered::before {
        display: block;
        height: calc(100vh - 1rem);
        height: min-content;
        content: "";
    }

    .modal-dialog-centered.modal-dialog-scrollable {
        flex-direction: column;
        justify-content: center;
        height: 100%;
    }

        .modal-dialog-centered.modal-dialog-scrollable .modal-content {
            max-height: none;
        }

        .modal-dialog-centered.modal-dialog-scrollable::before {
            content: none;
        }

.modal-content {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    pointer-events: auto;
    background-color: var(--cor-fundo);
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: var(--raio-lg);
    outline: 0;
}

.modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--z-modal-backdrop);
    width: 100vw;
    height: 100vh;
    background-color: #000;
}

    .modal-backdrop.fade {
        opacity: 0;
    }

    .modal-backdrop.show {
        opacity: 0.5;
    }

.modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: var(--espacamento-3);
    border-bottom: 1px solid var(--cor-borda);
    border-top-left-radius: calc(var(--raio-lg) - 1px);
    border-top-right-radius: calc(var(--raio-lg) - 1px);
}

    .modal-header .close {
        padding: var(--espacamento-3);
        margin: -1rem -1rem -1rem auto;
    }

.modal-title {
    margin-bottom: 0;
    line-height: 1.5;
}

.modal-body {
    position: relative;
    flex: 1 1 auto;
    padding: var(--espacamento-3);
}

.modal-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    padding: 0.75rem;
    border-top: 1px solid var(--cor-borda);
    border-bottom-right-radius: calc(var(--raio-lg) - 1px);
    border-bottom-left-radius: calc(var(--raio-lg) - 1px);
}

    .modal-footer > * {
        margin: var(--espacamento-1);
    }

.modal-scrollbar-measure {
    position: absolute;
    top: -9999px;
    width: 50px;
    height: 50px;
    overflow: scroll;
}

@media (min-width: 576px) {
    .modal-dialog {
        max-width: 500px;
        margin: 1.75rem auto;
    }

    .modal-dialog-scrollable {
        max-height: calc(100% - 3.5rem);
    }

        .modal-dialog-scrollable .modal-content {
            max-height: calc(100vh - 3.5rem);
        }

    .modal-dialog-centered {
        min-height: calc(100% - 3.5rem);
    }

        .modal-dialog-centered::before {
            height: calc(100vh - 3.5rem);
            height: min-content;
        }

    .modal-sm {
        max-width: 300px;
    }
}

@media (min-width: 992px) {
    .modal-lg, .modal-xl {
        max-width: 800px;
    }
}

@media (min-width: 1200px) {
    .modal-xl {
        max-width: 1140px;
    }
}


/* ============================================
   TOOLTIP
   ============================================ */
.tooltip {
    position: absolute;
    z-index: var(--z-tooltip);
    display: block;
    margin: 0;
    font-family: var(--fonte-principal);
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    word-spacing: normal;
    white-space: normal;
    line-break: auto;
    font-size: var(--fonte-sm);
    word-wrap: break-word;
    opacity: 0;
}

    .tooltip.show {
        opacity: 0.9;
    }

    .tooltip .arrow {
        position: absolute;
        display: block;
        width: 0.8rem;
        height: 0.4rem;
    }

        .tooltip .arrow::before {
            position: absolute;
            content: "";
            border-color: transparent;
            border-style: solid;
        }

.bs-tooltip-top, .bs-tooltip-auto[x-placement^=top] {
    padding: 0.4rem 0;
}

    .bs-tooltip-top .arrow, .bs-tooltip-auto[x-placement^=top] .arrow {
        bottom: 0;
    }

        .bs-tooltip-top .arrow::before, .bs-tooltip-auto[x-placement^=top] .arrow::before {
            top: 0;
            border-width: 0.4rem 0.4rem 0;
            border-top-color: #000;
        }

.bs-tooltip-right, .bs-tooltip-auto[x-placement^=right] {
    padding: 0 0.4rem;
}

    .bs-tooltip-right .arrow, .bs-tooltip-auto[x-placement^=right] .arrow {
        left: 0;
        width: 0.4rem;
        height: 0.8rem;
    }

        .bs-tooltip-right .arrow::before, .bs-tooltip-auto[x-placement^=right] .arrow::before {
            right: 0;
            border-width: 0.4rem 0.4rem 0.4rem 0;
            border-right-color: #000;
        }

.bs-tooltip-bottom, .bs-tooltip-auto[x-placement^=bottom] {
    padding: 0.4rem 0;
}

    .bs-tooltip-bottom .arrow, .bs-tooltip-auto[x-placement^=bottom] .arrow {
        top: 0;
    }

        .bs-tooltip-bottom .arrow::before, .bs-tooltip-auto[x-placement^=bottom] .arrow::before {
            bottom: 0;
            border-width: 0 0.4rem 0.4rem;
            border-bottom-color: #000;
        }

.bs-tooltip-left, .bs-tooltip-auto[x-placement^=left] {
    padding: 0 0.4rem;
}

    .bs-tooltip-left .arrow, .bs-tooltip-auto[x-placement^=left] .arrow {
        right: 0;
        width: 0.4rem;
        height: 0.8rem;
    }

        .bs-tooltip-left .arrow::before, .bs-tooltip-auto[x-placement^=left] .arrow::before {
            left: 0;
            border-width: 0.4rem 0 0.4rem 0.4rem;
            border-left-color: #000;
        }

.tooltip-inner {
    max-width: 200px;
    padding: 0.25rem 0.5rem;
    color: var(--cor-texto-branco);
    text-align: center;
    background-color: #000;
    border-radius: var(--raio-base);
}


/* ============================================
   TOAST
   ============================================ */
.toast {
    flex-basis: 350px;
    max-width: 350px;
    font-size: var(--fonte-sm);
    background-color: rgba(255, 255, 255, 0.85);
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.1);
    opacity: 0;
    border-radius: var(--raio-base);
}

    .toast:not(:last-child) {
        margin-bottom: 0.75rem;
    }

    .toast.showing {
        opacity: 1;
    }

    .toast.show {
        display: block;
        opacity: 1;
    }

    .toast.hide {
        display: none;
    }

.toast-header {
    display: flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    color: var(--cor-texto-secundario);
    background-color: rgba(255, 255, 255, 0.85);
    background-clip: padding-box;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    border-top-left-radius: calc(var(--raio-base) - 1px);
    border-top-right-radius: calc(var(--raio-base) - 1px);
}

.toast-body {
    padding: 0.75rem;
}


/* ============================================
   ACCORDION
   ============================================ */
.accordion-item {
    background-color: var(--cor-fundo);
    border: 1px solid rgba(0,0,0,.125);
}

    .accordion-item:first-of-type {
        border-top-left-radius: var(--raio-base);
        border-top-right-radius: var(--raio-base);
    }

    .accordion-item:last-of-type {
        border-bottom-left-radius: var(--raio-base);
        border-bottom-right-radius: var(--raio-base);
    }

    .accordion-item + .accordion-item {
        border-top: 0;
    }

.accordion-header {
    margin-bottom: 0;
}

.accordion-button {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--espacamento-3);
    font-size: var(--fonte-base);
    color: var(--cor-texto);
    text-align: left;
    background-color: var(--cor-fundo);
    border: 0;
    border-radius: 0;
    overflow-anchor: none;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    cursor: pointer;
}

    .accordion-button:not(.collapsed) {
        color: #006ea3;
        background-color: #e8f4fb;
        box-shadow: inset 0 -1px 0 rgba(0,0,0,.125);
    }

    .accordion-button::after {
        flex-shrink: 0;
        width: 1.25rem;
        height: 1.25rem;
        margin-left: auto;
        content: "";
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 01.708 0L8 10.293l5.646-5.647a.5.5 0 01.708.708l-6 6a.5.5 0 01-.708 0l-6-6a.5.5 0 010-.708z'/%3e%3c/svg%3e");
        background-repeat: no-repeat;
        background-size: 1.25rem;
        transition: transform 0.2s ease-in-out;
    }

    .accordion-button:not(.collapsed)::after {
        transform: rotate(-180deg);
    }

.accordion-collapse {
    overflow: hidden;
    transition: height 0.35s ease;
}

.accordion-body {
    padding: var(--espacamento-3);
}


/* ============================================
   OFFCANVAS
   ============================================ */
.offcanvas {
    position: fixed;
    bottom: 0;
    z-index: var(--z-offcanvas);
    display: flex;
    flex-direction: column;
    max-width: 100%;
    visibility: hidden;
    background-color: var(--cor-fundo);
    background-clip: padding-box;
    outline: 0;
    transition: transform 0.3s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .offcanvas {
        transition: none;
    }
}

.offcanvas-start {
    top: 0;
    left: 0;
    width: 400px;
    border-right: 1px solid rgba(0,0,0,.2);
    transform: translateX(-100%);
}

.offcanvas-end {
    top: 0;
    right: 0;
    width: 400px;
    border-left: 1px solid rgba(0,0,0,.2);
    transform: translateX(100%);
}

.offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: 30vh;
    max-height: 100%;
    border-bottom: 1px solid rgba(0,0,0,.2);
    transform: translateY(-100%);
}

.offcanvas-bottom {
    right: 0;
    left: 0;
    height: 30vh;
    max-height: 100%;
    border-top: 1px solid rgba(0,0,0,.2);
    transform: translateY(100%);
}

.offcanvas.show {
    transform: none;
    visibility: visible;
}

.offcanvas-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--espacamento-3);
}

    .offcanvas-header .btn-close {
        padding: 0.5rem;
        margin: -0.5rem -0.5rem -0.5rem auto;
    }

.offcanvas-title {
    margin-bottom: 0;
    line-height: 1.5;
}

.offcanvas-body {
    flex-grow: 1;
    padding: var(--espacamento-3);
    overflow-y: auto;
}

.offcanvas-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--z-offcanvas-backdrop);
    width: 100vw;
    height: 100vh;
    background-color: #000;
}

    .offcanvas-backdrop.fade {
        opacity: 0;
    }

    .offcanvas-backdrop.show {
        opacity: 0.5;
    }


/* ============================================
   MEDIA, LIST GROUP, CLOSE
   ============================================ */
.media {
    display: flex;
    align-items: flex-start;
}

.media-body {
    flex: 1;
}

.list-unstyled {
    padding-left: 0;
    list-style: none;
}

.list-inline {
    padding-left: 0;
    list-style: none;
}

.list-inline-item {
    display: inline-block;
}

    .list-inline-item:not(:last-child) {
        margin-right: 0.5rem;
    }

.list-group {
    display: flex;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    border-radius: var(--raio-base);
}

.list-group-item-action {
    width: 100%;
    color: var(--cor-texto-claro);
    text-align: inherit;
}

    .list-group-item-action:hover, .list-group-item-action:focus {
        z-index: 1;
        color: var(--cor-texto-claro);
        text-decoration: none;
        background-color: #f8f9fa;
    }

    .list-group-item-action:active {
        color: var(--cor-texto);
        background-color: var(--cor-borda-clara);
    }

.list-group-item {
    position: relative;
    display: block;
    padding: 0.75rem 1.25rem;
    background-color: var(--cor-fundo);
    border: 1px solid rgba(0, 0, 0, 0.125);
}

    .list-group-item:first-child {
        border-top-left-radius: inherit;
        border-top-right-radius: inherit;
    }

    .list-group-item:last-child {
        border-bottom-right-radius: inherit;
        border-bottom-left-radius: inherit;
    }

    .list-group-item.disabled, .list-group-item:disabled {
        color: var(--cor-texto-secundario);
        pointer-events: none;
        background-color: var(--cor-fundo);
    }

    .list-group-item.active {
        z-index: 2;
        color: var(--cor-texto-branco);
        background-color: var(--cor-primaria);
        border-color: var(--cor-primaria);
    }

    .list-group-item + .list-group-item {
        border-top-width: 0;
    }

        .list-group-item + .list-group-item.active {
            margin-top: -1px;
            border-top-width: 1px;
        }

.list-group-horizontal {
    flex-direction: row;
}

    .list-group-horizontal > .list-group-item:first-child {
        border-bottom-left-radius: var(--raio-base);
        border-top-right-radius: 0;
    }

    .list-group-horizontal > .list-group-item:last-child {
        border-top-right-radius: var(--raio-base);
        border-bottom-left-radius: 0;
    }

    .list-group-horizontal > .list-group-item.active {
        margin-top: 0;
    }

    .list-group-horizontal > .list-group-item + .list-group-item {
        border-top-width: 1px;
        border-left-width: 0;
    }

        .list-group-horizontal > .list-group-item + .list-group-item.active {
            margin-left: -1px;
            border-left-width: 1px;
        }

@media (min-width: 576px) {
    .list-group-horizontal-sm {
        flex-direction: row;
    }

        .list-group-horizontal-sm > .list-group-item:first-child {
            border-bottom-left-radius: var(--raio-base);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-sm > .list-group-item:last-child {
            border-top-right-radius: var(--raio-base);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-sm > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-sm > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-sm > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

@media (min-width: 768px) {
    .list-group-horizontal-md {
        flex-direction: row;
    }

        .list-group-horizontal-md > .list-group-item:first-child {
            border-bottom-left-radius: var(--raio-base);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-md > .list-group-item:last-child {
            border-top-right-radius: var(--raio-base);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-md > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-md > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-md > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

@media (min-width: 992px) {
    .list-group-horizontal-lg {
        flex-direction: row;
    }

        .list-group-horizontal-lg > .list-group-item:first-child {
            border-bottom-left-radius: var(--raio-base);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-lg > .list-group-item:last-child {
            border-top-right-radius: var(--raio-base);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-lg > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-lg > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-lg > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

@media (min-width: 1200px) {
    .list-group-horizontal-xl {
        flex-direction: row;
    }

        .list-group-horizontal-xl > .list-group-item:first-child {
            border-bottom-left-radius: var(--raio-base);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-xl > .list-group-item:last-child {
            border-top-right-radius: var(--raio-base);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-xl > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-xl > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-xl > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

.list-group-flush {
    border-radius: 0;
}

    .list-group-flush > .list-group-item {
        border-width: 0 0 1px;
    }

        .list-group-flush > .list-group-item:last-child {
            border-bottom-width: 0;
        }

.list-group-item-primary {
    color: #846d1c;
    background-color: var(--cor-tabela-primary-bg);
}

    .list-group-item-primary.list-group-item-action:hover, .list-group-item-primary.list-group-item-action:focus {
        color: #846d1c;
        background-color: #ffecae;
    }

    .list-group-item-primary.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #846d1c;
        border-color: #846d1c;
    }

.list-group-item-secondary {
    color: #383d41;
    background-color: #d6d8db;
}

    .list-group-item-secondary.list-group-item-action:hover, .list-group-item-secondary.list-group-item-action:focus {
        color: #383d41;
        background-color: #c8cbcf;
    }

    .list-group-item-secondary.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #383d41;
        border-color: #383d41;
    }

.list-group-item-success {
    color: #155724;
    background-color: #c3e6cb;
}

    .list-group-item-success.list-group-item-action:hover, .list-group-item-success.list-group-item-action:focus {
        color: #155724;
        background-color: #b1dfbb;
    }

    .list-group-item-success.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #155724;
        border-color: #155724;
    }

.list-group-item-info {
    color: #0c5460;
    background-color: #bee5eb;
}

    .list-group-item-info.list-group-item-action:hover, .list-group-item-info.list-group-item-action:focus {
        color: #0c5460;
        background-color: #abdde5;
    }

    .list-group-item-info.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #0c5460;
        border-color: #0c5460;
    }

.list-group-item-warning {
    color: #846d1c;
    background-color: var(--cor-tabela-primary-bg);
}

    .list-group-item-warning.list-group-item-action:hover, .list-group-item-warning.list-group-item-action:focus {
        color: #846d1c;
        background-color: #ffecae;
    }

    .list-group-item-warning.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #846d1c;
        border-color: #846d1c;
    }

.list-group-item-danger {
    color: #721c24;
    background-color: #f5c6cb;
}

    .list-group-item-danger.list-group-item-action:hover, .list-group-item-danger.list-group-item-action:focus {
        color: #721c24;
        background-color: #f1b0b7;
    }

    .list-group-item-danger.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #721c24;
        border-color: #721c24;
    }

.list-group-item-claro {
    color: #818182;
    background-color: #fdfdfe;
}

    .list-group-item-claro.list-group-item-action:hover, .list-group-item-claro.list-group-item-action:focus {
        color: #818182;
        background-color: #ececf6;
    }

    .list-group-item-claro.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #818182;
        border-color: #818182;
    }

.list-group-item-escuro {
    color: #1b1e21;
    background-color: #c6c8ca;
}

    .list-group-item-escuro.list-group-item-action:hover, .list-group-item-escuro.list-group-item-action:focus {
        color: #1b1e21;
        background-color: #b9bbbe;
    }

    .list-group-item-escuro.list-group-item-action.active {
        color: var(--cor-texto-branco);
        background-color: #1b1e21;
        border-color: #1b1e21;
    }

.close {
    float: right;
    font-size: var(--fonte-xl);
    font-weight: 700;
    line-height: 1;
    color: #000;
    text-shadow: 0 1px 0 var(--cor-texto-branco);
    opacity: 0.5;
}

    .close:hover {
        color: #000;
        text-decoration: none;
    }

    .close:not(:disabled):not(.disabled):hover, .close:not(:disabled):not(.disabled):focus {
        opacity: 0.75;
    }

button.close {
    padding: 0;
    background-color: transparent;
    border: 0;
}

a.close.disabled {
    pointer-events: none;
}


/* ============================================
   PLACEHOLDER
   ============================================ */
.placeholder {
    display: inline-block;
    min-height: 1em;
    vertical-align: middle;
    cursor: wait;
    background-color: currentColor;
    opacity: 0.5;
    border-radius: var(--raio-base);
}

    .placeholder.btn::before {
        display: inline-block;
        content: "";
    }

.placeholder-xs {
    min-height: .6em;
}

.placeholder-sm {
    min-height: .8em;
}

.placeholder-lg {
    min-height: 1.2em;
}

.placeholder-glow .placeholder {
    animation: placeholder-glow 2s ease-in-out infinite;
}

@keyframes placeholder-glow {
    50% {
        opacity: 0.2;
    }
}

.placeholder-wave {
    mask-image: linear-gradient(130deg, #000 55%, rgba(0,0,0,0.8) 75%, #000 95%);
    mask-size: 200% 100%;
    animation: placeholder-wave 2s linear infinite;
}

@keyframes placeholder-wave {
    100% {
        mask-position: -200% 0%;
    }
}


/* ============================================
   FADE, COLLAPSE, TRANSITIONS
   ============================================ */
.fade {
    transition: opacity 0.15s linear;
}

@media (prefers-reduced-motion: reduce) {
    .fade {
        transition: none;
    }
}

.fade:not(.show) {
    opacity: 0;
}

.collapse:not(.show) {
    display: none;
}

.collapsing {
    position: relative;
    height: 0;
    overflow: hidden;
    transition: height 0.35s ease;
}

@media (prefers-reduced-motion: reduce) {
    .collapsing {
        transition: none;
    }
}


/* ============================================
   CABEÇALHO (Header)
   ============================================ */
header.cabecalho {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    text-align: center;
    color: var(--cor-texto-branco);
    background-color: var(--cor-fundo-cabecalho);
}

@media (max-width: 768px) {
    header.cabecalho .conteudo {
        padding: 0;
    }
}

header.cabecalho img {
    max-width: 100%;
    margin-top: var(--espacamento-5) !important;
    margin-bottom: var(--espacamento-5) !important;
    margin: auto 0;
}

@keyframes visibilidadeCabecalhoImagem {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes cabecalhoImagem {
    0% {
        transform: perspective(150px) rotate3d(0, 0, 0, -2deg);
    }

    25% {
        transform: perspective(150px) rotate3d(0, -2, 0, -2deg);
    }

    75% {
        transform: perspective(150px) rotate3d(0, 2, 0, -2deg);
    }

    100% {
        transform: perspective(150px) rotate3d(0, 0, 0, -2deg);
    }
}

header.cabecalho .cabecalho-subheading {
    font-size: var(--fonte-xl);
    line-height: 1.5rem;
    margin-bottom: 25px;
    font-family: var(--fonte-titulos);
}

header.cabecalho .cabecalho-heading {
    font-size: 3.25rem;
    font-weight: 700;
    line-height: 3.25rem;
    margin-bottom: 2rem;
    font-family: var(--fonte-titulos);
}

@media (min-width: 768px) {
    header.cabecalho {
        padding-top: 12.5rem;
        padding-bottom: 12.5rem;
    }

        header.cabecalho .cabecalho-subheading {
            font-size: 2.25rem;
            line-height: 2.25rem;
            margin-bottom: 2rem;
        }

        header.cabecalho .cabecalho-heading {
            font-size: 4.5rem;
            font-weight: 700;
            line-height: 4.5rem;
            margin-bottom: 4rem;
        }
}


/* ============================================
   SEÇÕES DE PÁGINA
   ============================================ */
.pagina-section {
    padding: var(--espacamento-5) 0;
}

.mapa-section {
    padding: 0;
}

.pagina-section h2.section-titulo {
    font-size: 2.5rem;
    margin-top: 0;
    margin-bottom: var(--espacamento-3);
}

.pagina-section h3.section-subtitulo {
    font-size: var(--fonte-base);
    font-weight: 400;
    font-family: var(--fonte-titulos);
    margin-bottom: 4rem;
    line-height: 1.6em;
}

@media (min-width: 768px) {
    section {
        padding: 9rem 0;
    }
}

::selection {
    background: rgba(0, 0, 0, 0.1);
    text-shadow: none;
    color: var(--cor-texto);
}

::-moz-selection {
    background: var(--cor-primaria);
    text-shadow: none;
}

img::selection {
    background: transparent;
}

img::-moz-selection {
    background: transparent;
}


/* ============================================
   EVENTOS
   ============================================ */
.evento .evento-item {
    max-width: 25rem;
    margin-left: auto;
    margin-right: auto;
    border-radius: var(--raio-circulo);
    height: 100%;
}

    .evento .evento-item .evento-caption-nohover {
        padding: var(--espacamento-4);
        text-align: center;
        background-color: var(--cor-fundo);
        min-height: 10rem;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        border-radius: var(--raio-circulo);
        text-decoration: none;
        transition: all ease .2s;
        flex-direction: column;
        height: 100%;
    }

    .evento .evento-item .evento-caption {
        padding: var(--espacamento-4);
        text-align: center;
        background-color: var(--cor-fundo);
        cursor: pointer;
        min-height: 10rem;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: var(--raio-circulo);
        text-decoration: none;
        transition: all ease .2s;
        flex-direction: column;
        height: 100%;
    }

        .evento .evento-item .evento-caption img {
            width: 80%;
        }

        .evento .evento-item .evento-caption:hover {
            background-color: var(--cor-secundaria);
            color: var(--cor-texto-branco);
            transform: scale3d(1.05, 1.05, 1.05);
        }

        .evento .evento-item .evento-caption .evento-caption-heading {
            font-size: var(--fonte-xl);
            font-family: var(--fonte-titulos);
            font-weight: 700;
            margin-bottom: 0;
        }

        .evento .evento-item .evento-caption .evento-caption-subheading {
            font-family: var(--fonte-titulos);
        }

/* Evento Modal */
.evento-modal .modal-dialog {
    margin: var(--espacamento-3);
    max-width: 100vw;
}

.evento-modal .modal-content {
    padding-top: 6rem;
    padding-bottom: 6rem;
    text-align: center;
}

    .evento-modal .modal-content h2 {
        font-size: 3rem;
        line-height: 3rem;
    }

    .evento-modal .modal-content p.item-intro {
        font-style: italic;
        margin-bottom: 2rem;
        font-family: var(--fonte-serif);
    }

    .evento-modal .modal-content p {
        margin-bottom: 2rem;
    }

    .evento-modal .modal-content ul.list-inline {
        margin-bottom: 2rem;
    }

    .evento-modal .modal-content img {
        margin-bottom: 2rem;
    }

.evento-modal .close-modal {
    position: absolute;
    top: 1.5rem;
    right: 1.5rem;
    width: 3rem;
    height: 3rem;
    cursor: pointer;
    background-color: transparent;
}

    .evento-modal .close-modal:hover {
        opacity: 0.3;
    }


/* ============================================
   LINHA DO TEMPO (Timeline)
   ============================================ */
.linhadotempo {
    position: relative;
    padding: 0;
    list-style: none;
}

    .linhadotempo:before {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 40px;
        width: 2px;
        margin-left: -1.5px;
        content: "";
        background-color: var(--cor-borda-clara);
    }

    .linhadotempo > li {
        position: relative;
        min-height: 50px;
        margin-bottom: 50px;
    }

        .linhadotempo > li:after, .linhadotempo > li:before {
            display: table;
            content: " ";
        }

        .linhadotempo > li:after {
            clear: both;
        }

        .linhadotempo > li .linhadotempo-panel {
            position: relative;
            float: right;
            width: 100%;
            padding: 0 20px 0 100px;
            text-align: left;
        }

            .linhadotempo > li .linhadotempo-panel:before {
                right: auto;
                left: -15px;
                border-right-width: 15px;
                border-left-width: 0;
            }

            .linhadotempo > li .linhadotempo-panel:after {
                right: auto;
                left: -14px;
                border-right-width: 14px;
                border-left-width: 0;
            }

        .linhadotempo > li .linhadotempo-image {
            position: absolute;
            z-index: 100;
            left: 0;
            width: 80px;
            height: 80px;
            margin-left: 0;
            text-align: center;
            color: var(--cor-texto-branco);
            border: 7px solid var(--cor-borda-clara);
            border-radius: var(--raio-circulo);
            background-color: var(--cor-roxo);
            box-shadow: 0 10px 15px -3px rgb(0 0 0 / 10%), 0 4px 6px -2px rgb(0 0 0 / 5%);
        }

            .linhadotempo > li .linhadotempo-image h4 {
                font-size: 10px;
                line-height: 14px;
                margin-top: 12px;
            }

        .linhadotempo > li.linhadotempo-inverted > .linhadotempo-panel {
            float: right;
            padding: 0 20px 0 100px;
            text-align: left;
        }

            .linhadotempo > li.linhadotempo-inverted > .linhadotempo-panel:before {
                right: auto;
                left: -15px;
                border-right-width: 15px;
                border-left-width: 0;
            }

            .linhadotempo > li.linhadotempo-inverted > .linhadotempo-panel:after {
                right: auto;
                left: -14px;
                border-right-width: 14px;
                border-left-width: 0;
            }

        .linhadotempo > li:last-child {
            margin-bottom: 0;
        }

    .linhadotempo .linhadotempo-heading h4 {
        margin-top: 0;
        color: inherit;
    }

        .linhadotempo .linhadotempo-heading h4.subheading {
            text-transform: none;
        }

    .linhadotempo .linhadotempo-body > ul, .linhadotempo .linhadotempo-body > p {
        margin-bottom: 0;
    }

@media (min-width: 768px) {
    .linhadotempo:before {
        left: 50%;
    }

    .linhadotempo > li {
        min-height: 100px;
        margin-bottom: 100px;
    }

        .linhadotempo > li .linhadotempo-panel {
            float: left;
            width: 41%;
            padding: 0 20px 20px 30px;
            text-align: right;
        }

        .linhadotempo > li .linhadotempo-image {
            left: 50%;
            width: 100px;
            height: 100px;
            margin-left: -50px;
        }

            .linhadotempo > li .linhadotempo-image h4 {
                font-size: 13px;
                line-height: 18px;
                margin-top: 16px;
            }

        .linhadotempo > li.linhadotempo-inverted > .linhadotempo-panel {
            float: right;
            padding: 0 30px 20px 20px;
            text-align: left;
        }
}

@media (min-width: 992px) {
    .linhadotempo > li {
        min-height: 150px;
    }

        .linhadotempo > li .linhadotempo-panel {
            padding: 0 20px 20px;
        }

        .linhadotempo > li .linhadotempo-image {
            width: 150px;
            height: 150px;
            margin-left: -75px;
        }

            .linhadotempo > li .linhadotempo-image h4 {
                font-size: 18px;
                line-height: 26px;
                margin-top: 30px;
            }

        .linhadotempo > li.linhadotempo-inverted > .linhadotempo-panel {
            padding: 0 20px 20px;
        }
}

@media (min-width: 1200px) {
    .linhadotempo > li {
        min-height: 170px;
    }

        .linhadotempo > li .linhadotempo-panel {
            padding: 0 20px 20px 100px;
        }

        .linhadotempo > li .linhadotempo-image {
            width: 170px;
            height: 170px;
            margin-left: -85px;
        }

            .linhadotempo > li .linhadotempo-image h4 {
                margin-top: 40px;
            }

        .linhadotempo > li.linhadotempo-inverted > .linhadotempo-panel {
            padding: 0 100px 20px 20px;
        }
}


/* ============================================
   PALESTRANTES
   ============================================ */
.palestrante-item {
    margin-bottom: var(--espacamento-5);
    text-align: center;
    transition: all 1s;
    cursor: pointer;
}

    .palestrante-item img {
        width: 8rem;
        height: 8rem;
        border: 0.5rem solid rgba(0, 0, 0, 0.1);
        transition: all;
    }

    .palestrante-item h4 {
        margin-top: var(--espacamento-3);
        margin-bottom: var(--espacamento-3);
        transition: all;
    }

    .palestrante-item .icon {
        border: 0 !important;
        width: 20px;
        height: 20px;
        transition: all;
    }

    .palestrante-item .icon-redesocial {
        border-radius: 50px;
        background-color: var(--cor-roxo-escuro);
        color: var(--cor-texto-branco);
    }

    .palestrante-item .icon-instagram-2 {
        font-size: 0.8rem;
    }

    .palestrante-item .palestrante-info {
        display: block;
        opacity: 0;
        transition: all 1s;
        height: 0;
        font-size: 0.9rem;
    }

    .palestrante-item:hover .palestrante-info {
        opacity: 1;
        height: 350px;
        transition: all 1s;
    }

    .palestrante-item:hover img {
        border: 0.5rem solid var(--cor-verde-escuro);
        transition: all;
    }

    .palestrante-item:hover {
        animation: pulse;
        animation-duration: 2s;
    }


/* ============================================
   CONTATO
   ============================================ */
section#contato {
    color: var(--cor-texto-branco);
    background-color: var(--cor-fundo-navegacao);
    background-repeat: no-repeat;
    background-attachment: scroll;
    background-position: center center;
    background-size: cover;
}

    section#contato .section-titulo {
        color: var(--cor-texto-branco);
    }

    section#contato form#formulario-contato .form-group {
        margin-bottom: var(--espacamento-4);
    }

        section#contato form#formulario-contato .form-group input, section#contato form#formulario-contato .form-group textarea {
            padding: 1.25rem;
        }

            section#contato form#formulario-contato .form-group input.form-control {
                height: auto;
            }

    section#contato form#formulario-contato .form-group-textarea {
        height: 100%;
    }

        section#contato form#formulario-contato .form-group-textarea textarea {
            height: 100%;
            min-height: 10rem;
        }

    section#contato form#formulario-contato p.help-block {
        margin: 0;
    }

    section#contato form#formulario-contato .form-control:focus {
        border-color: var(--cor-primaria);
        box-shadow: none;
    }

    section#contato form#formulario-contato ::-webkit-input-placeholder {
        font-family: var(--fonte-titulos);
        font-weight: 700;
        color: var(--cor-borda-input);
    }

    section#contato form#formulario-contato :-moz-placeholder {
        font-family: var(--fonte-titulos);
        font-weight: 700;
        color: var(--cor-borda-input);
    }

    section#contato form#formulario-contato ::-moz-placeholder {
        font-family: var(--fonte-titulos);
        font-weight: 700;
        color: var(--cor-borda-input);
    }

    section#contato form#formulario-contato :-ms-input-placeholder {
        font-family: var(--fonte-titulos);
        font-weight: 700;
        color: var(--cor-borda-input);
    }


/* ============================================
   FOOTER
   ============================================ */
.footer {
    text-align: center;
    font-size: 0.9rem;
    font-family: var(--fonte-titulos);
    background-color: var(--cor-fundo-navegacao);
    bottom: 0;
    width: 100%;
}


/* ============================================
   BOTÕES FLUTUANTES (Scroll, Back)
   ============================================ */
.btn-scroll-option {
    display: flex;
    right: 1rem;
    bottom: 8rem;
    width: 3rem;
    height: 3rem;
    transition: right 400ms cubic-bezier(0.68, -0.55, 0.265, 1.55), opacity 0.3s, background-color 0.25s ease-in-out;
    border-radius: 50%;
    background-color: var(--cor-destaque);
    color: var(--cor-texto-branco);
    text-align: center;
    opacity: 0;
    z-index: var(--z-dropdown);
    box-shadow: 0.5px 0.5px 1px #000;
    padding: 0.5rem;
    align-items: center;
    justify-content: center;
    animation: bounce ease 0.2s;
}

.btn-scroll-top {
    display: flex;
    position: fixed;
    right: 1rem;
    bottom: 5rem;
    width: 3rem;
    height: 3rem;
    transition: right 400ms cubic-bezier(0.68, -0.55, 0.265, 1.55), opacity 0.3s, background-color 0.25s ease-in-out;
    border-radius: 50%;
    background-color: var(--cor-secundaria);
    color: var(--cor-texto-branco);
    text-align: center;
    opacity: 0;
    z-index: var(--z-fixed);
    box-shadow: 0.5px 0.5px 1px #000;
    padding: 0.5rem;
    align-items: center;
    justify-content: center;
}

.btn-back {
    display: flex;
    position: fixed;
    left: 1rem;
    bottom: 5rem;
    width: 3rem;
    height: 3rem;
    transition: all;
    border-radius: 50%;
    background-color: var(--cor-secundaria);
    color: var(--cor-texto-branco);
    text-align: center;
    opacity: 1;
    z-index: var(--z-fixed);
    box-shadow: 0.5px 0.5px 1px #000;
    padding: 0.5rem;
    align-items: center;
    justify-content: center;
}


/* ============================================
   CORES DE FUNDO
   ============================================ */
.fundo-primary {
    background-color: var(--cor-primaria) !important;
}

a.fundo-primary:hover, a.fundo-primary:focus, button.fundo-primary:hover, button.fundo-primary:focus {
    background-color: var(--cor-primaria-active) !important;
}

.fundo-secondary {
    background-color: var(--cor-secundaria-dark) !important;
}

a.fundo-secondary:hover, a.fundo-secondary:focus, button.fundo-secondary:hover, button.fundo-secondary:focus {
    background-color: #545b62 !important;
}

.fundo-success {
    background-color: var(--cor-sucesso) !important;
}

a.fundo-success:hover, a.fundo-success:focus, button.fundo-success:hover, button.fundo-success:focus {
    background-color: var(--cor-sucesso-active) !important;
}

.fundo-info {
    background-color: var(--cor-info) !important;
}

a.fundo-info:hover, a.fundo-info:focus, button.fundo-info:hover, button.fundo-info:focus {
    background-color: var(--cor-info-active) !important;
}

.fundo-warning {
    background-color: var(--cor-primaria) !important;
}

a.fundo-warning:hover, a.fundo-warning:focus, button.fundo-warning:hover, button.fundo-warning:focus {
    background-color: var(--cor-primaria-active) !important;
}

.fundo-danger {
    background-color: var(--cor-perigo) !important;
}

a.fundo-danger:hover, a.fundo-danger:focus, button.fundo-danger:hover, button.fundo-danger:focus {
    background-color: var(--cor-perigo-active) !important;
}

.fundo-claro {
    background-color: var(--cor-fundo-claro) !important;
}

a.fundo-claro:hover, a.fundo-claro:focus, button.fundo-claro:hover, button.fundo-claro:focus {
    background-color: #dae0e5 !important;
}

.fundo-escuro {
    background-color: var(--cor-fundo-escuro) !important;
}

a.fundo-escuro:hover, a.fundo-escuro:focus, button.fundo-escuro:hover, button.fundo-escuro:focus {
    background-color: #1d2124 !important;
}

.fundo-white {
    background-color: var(--cor-fundo) !important;
}

.fundo-transparent {
    background-color: transparent !important;
}


/* ============================================
   BORDAS
   ============================================ */
.border {
    border: 1px solid var(--cor-borda) !important;
}

.border-top {
    border-top: 1px solid var(--cor-borda) !important;
}

.border-right {
    border-right: 1px solid var(--cor-borda) !important;
}

.border-bottom {
    border-bottom: 1px solid var(--cor-borda) !important;
}

.border-left {
    border-left: 1px solid var(--cor-borda) !important;
}

.border-0 {
    border: 0 !important;
}

.border-top-0 {
    border-top: 0 !important;
}

.border-right-0 {
    border-right: 0 !important;
}

.border-bottom-0 {
    border-bottom: 0 !important;
}

.border-left-0 {
    border-left: 0 !important;
}

.border-primary {
    border-color: var(--cor-primaria) !important;
}

.border-secondary {
    border-color: var(--cor-secundaria-dark) !important;
}

.border-success {
    border-color: var(--cor-sucesso) !important;
}

.border-info {
    border-color: var(--cor-info) !important;
}

.border-warning {
    border-color: var(--cor-primaria) !important;
}

.border-danger {
    border-color: var(--cor-perigo) !important;
}

.border-claro {
    border-color: #f8f9fa !important;
}

.border-escuro {
    border-color: var(--cor-fundo-escuro) !important;
}

.border-white {
    border-color: var(--cor-fundo) !important;
}


/* ============================================
   BORDER RADIUS
   ============================================ */
.rounded-sm {
    border-radius: var(--raio-sm) !important;
}

.rounded {
    border-radius: var(--raio-base) !important;
}

.rounded-top {
    border-top-left-radius: var(--raio-base) !important;
    border-top-right-radius: var(--raio-base) !important;
}

.rounded-right {
    border-top-right-radius: var(--raio-base) !important;
    border-bottom-right-radius: var(--raio-base) !important;
}

.rounded-bottom {
    border-bottom-right-radius: var(--raio-base) !important;
    border-bottom-left-radius: var(--raio-base) !important;
}

.rounded-left {
    border-top-left-radius: var(--raio-base) !important;
    border-bottom-left-radius: var(--raio-base) !important;
}

.rounded-lg {
    border-radius: var(--raio-lg) !important;
}

.rounded-circle {
    border-radius: var(--raio-circulo) !important;
}

.rounded-pill {
    border-radius: var(--raio-pill) !important;
}

.rounded-0 {
    border-radius: 0 !important;
}


/* ============================================
   CORES DE TEXTO
   ============================================ */
.text-white {
    color: var(--cor-texto-branco) !important;
}

.text-primary {
    color: var(--cor-roxo) !important;
}

a.text-primary:hover, a.text-primary:focus {
    color: var(--cor-roxo) !important;
}

.text-secondary {
    color: var(--cor-secundaria-dark) !important;
}

a.text-secondary:hover, a.text-secondary:focus {
    color: #494f54 !important;
}

.text-success {
    color: var(--cor-sucesso) !important;
}

a.text-success:hover, a.text-success:focus {
    color: #19692c !important;
}

.text-info {
    color: var(--cor-info) !important;
}

a.text-info:hover, a.text-info:focus {
    color: #0f6674 !important;
}

.text-warning {
    color: var(--cor-primaria) !important;
}

a.text-warning:hover, a.text-warning:focus {
    color: var(--cor-amarelo) !important;
}

.text-danger {
    color: var(--cor-perigo) !important;
}

a.text-danger:hover, a.text-danger:focus {
    color: #a71d2a !important;
}

.text-claro {
    color: #f8f9fa !important;
}

a.text-claro:hover, a.text-claro:focus {
    color: #cbd3da !important;
}

.text-escuro {
    color: var(--cor-fundo-escuro) !important;
}

a.text-escuro:hover, a.text-escuro:focus {
    color: #121416 !important;
}

.text-body {
    color: var(--cor-texto) !important;
}

.text-muted {
    color: var(--cor-texto-secundario) !important;
}

.text-black-50 {
    color: rgba(0, 0, 0, 0.5) !important;
}

.text-white-50 {
    color: rgba(255, 255, 255, 0.5) !important;
}

.white {
    color: var(--cor-texto-branco);
}

.text-hide {
    font: 0/0 a;
    color: transparent;
    text-shadow: none;
    background-color: transparent;
    border: 0;
}

.text-decoration-none {
    text-decoration: none !important;
}

.text-break {
    word-break: break-word !important;
    word-wrap: break-word !important;
}

.text-reset {
    color: inherit !important;
}


/* ============================================
   UTILITÁRIOS DE TEXTO
   ============================================ */
.text-monospace {
    font-family: var(--fonte-mono) !important;
}

.text-justify {
    text-align: justify !important;
}

.text-wrap {
    white-space: normal !important;
}

.text-nowrap {
    white-space: nowrap !important;
}

.text-truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.text-left {
    text-align: left !important;
}

.text-right {
    text-align: right !important;
}

.text-center {
    text-align: center !important;
}

@media (min-width: 576px) {
    .text-sm-left {
        text-align: left !important;
    }

    .text-sm-right {
        text-align: right !important;
    }

    .text-sm-center {
        text-align: center !important;
    }
}

@media (min-width: 768px) {
    .text-md-left {
        text-align: left !important;
    }

    .text-md-right {
        text-align: right !important;
    }

    .text-md-center {
        text-align: center !important;
    }
}

@media (min-width: 992px) {
    .text-lg-left {
        text-align: left !important;
    }

    .text-lg-right {
        text-align: right !important;
    }

    .text-lg-center {
        text-align: center !important;
    }
}

@media (min-width: 1200px) {
    .text-xl-left {
        text-align: left !important;
    }

    .text-xl-right {
        text-align: right !important;
    }

    .text-xl-center {
        text-align: center !important;
    }
}

.text-lowercase {
    text-transform: lowercase !important;
}

.text-uppercase {
    text-transform: uppercase !important;
}

.text-capitalize {
    text-transform: capitalize !important;
}

/* Font Weight */
.font-weight-claro {
    font-weight: 300 !important;
}

.font-weight-claroer {
    font-weight: lighter !important;
}

.font-weight-normal {
    font-weight: 400 !important;
}

.font-weight-bold {
    font-weight: 700 !important;
}

.font-weight-bolder {
    font-weight: bolder !important;
}

.font-italic {
    font-style: italic !important;
}

.fw-lighter {
    font-weight: lighter !important;
}

.fw-light {
    font-weight: 300 !important;
}

.fw-normal {
    font-weight: 400 !important;
}

.fw-medium {
    font-weight: 500 !important;
}

.fw-semibold {
    font-weight: 600 !important;
}

.fw-bold {
    font-weight: 700 !important;
}

.fw-bolder {
    font-weight: bolder !important;
}

.fst-italic {
    font-style: italic !important;
}

.fst-normal {
    font-style: normal !important;
}

/* Line Height */
.lh-1 {
    line-height: 1 !important;
}

.lh-sm {
    line-height: 1.25 !important;
}

.lh-base {
    line-height: 1.5 !important;
}

.lh-lg {
    line-height: 2 !important;
}

/* Text Opacity */
.text-opacity-25 {
    --bs-text-opacity: 0.25;
}

.text-opacity-50 {
    --bs-text-opacity: 0.5;
}

.text-opacity-75 {
    --bs-text-opacity: 0.75;
}

.text-opacity-100 {
    --bs-text-opacity: 1;
}

/* BG Opacity */
.bg-opacity-10 {
    --bs-bg-opacity: 0.1;
}

.bg-opacity-25 {
    --bs-bg-opacity: 0.25;
}

.bg-opacity-50 {
    --bs-bg-opacity: 0.5;
}

.bg-opacity-75 {
    --bs-bg-opacity: 0.75;
}

.bg-opacity-100 {
    --bs-bg-opacity: 1;
}


/* ============================================
   UTILITÁRIOS DE DISPLAY
   ============================================ */
.d-none {
    display: none !important;
}

.d-inline {
    display: inline !important;
}

.d-inline-block {
    display: inline-block !important;
}

.d-block {
    display: block !important;
}

.d-table {
    display: table !important;
}

.d-table-row {
    display: table-row !important;
}

.d-table-cell {
    display: table-cell !important;
}

.d-flex {
    display: flex !important;
}

.d-inline-flex {
    display: inline-flex !important;
}

@media (min-width: 576px) {
    .d-sm-none {
        display: none !important;
    }

    .d-sm-inline {
        display: inline !important;
    }

    .d-sm-inline-block {
        display: inline-block !important;
    }

    .d-sm-block {
        display: block !important;
    }

    .d-sm-table {
        display: table !important;
    }

    .d-sm-table-row {
        display: table-row !important;
    }

    .d-sm-table-cell {
        display: table-cell !important;
    }

    .d-sm-flex {
        display: flex !important;
    }

    .d-sm-inline-flex {
        display: inline-flex !important;
    }
}

@media (min-width: 768px) {
    .d-md-none {
        display: none !important;
    }

    .d-md-inline {
        display: inline !important;
    }

    .d-md-inline-block {
        display: inline-block !important;
    }

    .d-md-block {
        display: block !important;
    }

    .d-md-table {
        display: table !important;
    }

    .d-md-table-row {
        display: table-row !important;
    }

    .d-md-table-cell {
        display: table-cell !important;
    }

    .d-md-flex {
        display: flex !important;
    }

    .d-md-inline-flex {
        display: inline-flex !important;
    }
}

@media (min-width: 992px) {
    .d-lg-none {
        display: none !important;
    }

    .d-lg-inline {
        display: inline !important;
    }

    .d-lg-inline-block {
        display: inline-block !important;
    }

    .d-lg-block {
        display: block !important;
    }

    .d-lg-table {
        display: table !important;
    }

    .d-lg-table-row {
        display: table-row !important;
    }

    .d-lg-table-cell {
        display: table-cell !important;
    }

    .d-lg-flex {
        display: flex !important;
    }

    .d-lg-inline-flex {
        display: inline-flex !important;
    }
}

@media (min-width: 1200px) {
    .d-xl-none {
        display: none !important;
    }

    .d-xl-inline {
        display: inline !important;
    }

    .d-xl-inline-block {
        display: inline-block !important;
    }

    .d-xl-block {
        display: block !important;
    }

    .d-xl-table {
        display: table !important;
    }

    .d-xl-table-row {
        display: table-row !important;
    }

    .d-xl-table-cell {
        display: table-cell !important;
    }

    .d-xl-flex {
        display: flex !important;
    }

    .d-xl-inline-flex {
        display: inline-flex !important;
    }
}

@media print {
    .d-print-none {
        display: none !important;
    }

    .d-print-inline {
        display: inline !important;
    }

    .d-print-inline-block {
        display: inline-block !important;
    }

    .d-print-block {
        display: block !important;
    }

    .d-print-table {
        display: table !important;
    }

    .d-print-table-row {
        display: table-row !important;
    }

    .d-print-table-cell {
        display: table-cell !important;
    }

    .d-print-flex {
        display: flex !important;
    }

    .d-print-inline-flex {
        display: inline-flex !important;
    }
}


/* ============================================
   UTILITÁRIOS DE FLEXBOX
   ============================================ */
.flex-row {
    flex-direction: row !important;
}

.flex-column {
    flex-direction: column !important;
}

.flex-row-reverse {
    flex-direction: row-reverse !important;
}

.flex-column-reverse {
    flex-direction: column-reverse !important;
}

.flex-wrap {
    flex-wrap: wrap !important;
}

.flex-nowrap {
    flex-wrap: nowrap !important;
}

.flex-wrap-reverse {
    flex-wrap: wrap-reverse !important;
}

.flex-fill {
    flex: 1 1 auto !important;
}

.flex-grow-0 {
    flex-grow: 0 !important;
}

.flex-grow-1 {
    flex-grow: 1 !important;
}

.flex-shrink-0 {
    flex-shrink: 0 !important;
}

.flex-shrink-1 {
    flex-shrink: 1 !important;
}

.justify-content-start {
    justify-content: flex-start !important;
}

.justify-content-end {
    justify-content: flex-end !important;
}

.justify-content-center {
    justify-content: center !important;
}

.justify-content-between {
    justify-content: space-between !important;
}

.justify-content-around {
    justify-content: space-around !important;
}

.align-items-start {
    align-items: flex-start !important;
}

.align-items-end {
    align-items: flex-end !important;
}

.align-items-center {
    align-items: center !important;
}

.align-items-baseline {
    align-items: baseline !important;
}

.align-items-stretch {
    align-items: stretch !important;
}

.align-content-start {
    align-content: flex-start !important;
}

.align-content-end {
    align-content: flex-end !important;
}

.align-content-center {
    align-content: center !important;
}

.align-content-between {
    align-content: space-between !important;
}

.align-content-around {
    align-content: space-around !important;
}

.align-content-stretch {
    align-content: stretch !important;
}

.align-self-auto {
    align-self: auto !important;
}

.align-self-start {
    align-self: flex-start !important;
}

.align-self-end {
    align-self: flex-end !important;
}

.align-self-center {
    align-self: center !important;
}

.align-self-baseline {
    align-self: baseline !important;
}

.align-self-stretch {
    align-self: stretch !important;
}

@media (min-width: 576px) {
    .flex-sm-row {
        flex-direction: row !important;
    }

    .flex-sm-column {
        flex-direction: column !important;
    }

    .flex-sm-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-sm-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-sm-wrap {
        flex-wrap: wrap !important;
    }

    .flex-sm-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-sm-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .flex-sm-fill {
        flex: 1 1 auto !important;
    }

    .flex-sm-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-sm-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-sm-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-sm-shrink-1 {
        flex-shrink: 1 !important;
    }

    .justify-content-sm-start {
        justify-content: flex-start !important;
    }

    .justify-content-sm-end {
        justify-content: flex-end !important;
    }

    .justify-content-sm-center {
        justify-content: center !important;
    }

    .justify-content-sm-between {
        justify-content: space-between !important;
    }

    .justify-content-sm-around {
        justify-content: space-around !important;
    }

    .align-items-sm-start {
        align-items: flex-start !important;
    }

    .align-items-sm-end {
        align-items: flex-end !important;
    }

    .align-items-sm-center {
        align-items: center !important;
    }

    .align-items-sm-baseline {
        align-items: baseline !important;
    }

    .align-items-sm-stretch {
        align-items: stretch !important;
    }

    .align-content-sm-start {
        align-content: flex-start !important;
    }

    .align-content-sm-end {
        align-content: flex-end !important;
    }

    .align-content-sm-center {
        align-content: center !important;
    }

    .align-content-sm-between {
        align-content: space-between !important;
    }

    .align-content-sm-around {
        align-content: space-around !important;
    }

    .align-content-sm-stretch {
        align-content: stretch !important;
    }

    .align-self-sm-auto {
        align-self: auto !important;
    }

    .align-self-sm-start {
        align-self: flex-start !important;
    }

    .align-self-sm-end {
        align-self: flex-end !important;
    }

    .align-self-sm-center {
        align-self: center !important;
    }

    .align-self-sm-baseline {
        align-self: baseline !important;
    }

    .align-self-sm-stretch {
        align-self: stretch !important;
    }
}

@media (min-width: 768px) {
    .flex-md-row {
        flex-direction: row !important;
    }

    .flex-md-column {
        flex-direction: column !important;
    }

    .flex-md-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-md-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-md-wrap {
        flex-wrap: wrap !important;
    }

    .flex-md-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-md-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .flex-md-fill {
        flex: 1 1 auto !important;
    }

    .flex-md-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-md-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-md-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-md-shrink-1 {
        flex-shrink: 1 !important;
    }

    .justify-content-md-start {
        justify-content: flex-start !important;
    }

    .justify-content-md-end {
        justify-content: flex-end !important;
    }

    .justify-content-md-center {
        justify-content: center !important;
    }

    .justify-content-md-between {
        justify-content: space-between !important;
    }

    .justify-content-md-around {
        justify-content: space-around !important;
    }

    .align-items-md-start {
        align-items: flex-start !important;
    }

    .align-items-md-end {
        align-items: flex-end !important;
    }

    .align-items-md-center {
        align-items: center !important;
    }

    .align-items-md-baseline {
        align-items: baseline !important;
    }

    .align-items-md-stretch {
        align-items: stretch !important;
    }

    .align-content-md-start {
        align-content: flex-start !important;
    }

    .align-content-md-end {
        align-content: flex-end !important;
    }

    .align-content-md-center {
        align-content: center !important;
    }

    .align-content-md-between {
        align-content: space-between !important;
    }

    .align-content-md-around {
        align-content: space-around !important;
    }

    .align-content-md-stretch {
        align-content: stretch !important;
    }

    .align-self-md-auto {
        align-self: auto !important;
    }

    .align-self-md-start {
        align-self: flex-start !important;
    }

    .align-self-md-end {
        align-self: flex-end !important;
    }

    .align-self-md-center {
        align-self: center !important;
    }

    .align-self-md-baseline {
        align-self: baseline !important;
    }

    .align-self-md-stretch {
        align-self: stretch !important;
    }
}

@media (min-width: 992px) {
    .flex-lg-row {
        flex-direction: row !important;
    }

    .flex-lg-column {
        flex-direction: column !important;
    }

    .flex-lg-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-lg-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-lg-wrap {
        flex-wrap: wrap !important;
    }

    .flex-lg-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-lg-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .flex-lg-fill {
        flex: 1 1 auto !important;
    }

    .flex-lg-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-lg-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-lg-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-lg-shrink-1 {
        flex-shrink: 1 !important;
    }

    .justify-content-lg-start {
        justify-content: flex-start !important;
    }

    .justify-content-lg-end {
        justify-content: flex-end !important;
    }

    .justify-content-lg-center {
        justify-content: center !important;
    }

    .justify-content-lg-between {
        justify-content: space-between !important;
    }

    .justify-content-lg-around {
        justify-content: space-around !important;
    }

    .align-items-lg-start {
        align-items: flex-start !important;
    }

    .align-items-lg-end {
        align-items: flex-end !important;
    }

    .align-items-lg-center {
        align-items: center !important;
    }

    .align-items-lg-baseline {
        align-items: baseline !important;
    }

    .align-items-lg-stretch {
        align-items: stretch !important;
    }

    .align-content-lg-start {
        align-content: flex-start !important;
    }

    .align-content-lg-end {
        align-content: flex-end !important;
    }

    .align-content-lg-center {
        align-content: center !important;
    }

    .align-content-lg-between {
        align-content: space-between !important;
    }

    .align-content-lg-around {
        align-content: space-around !important;
    }

    .align-content-lg-stretch {
        align-content: stretch !important;
    }

    .align-self-lg-auto {
        align-self: auto !important;
    }

    .align-self-lg-start {
        align-self: flex-start !important;
    }

    .align-self-lg-end {
        align-self: flex-end !important;
    }

    .align-self-lg-center {
        align-self: center !important;
    }

    .align-self-lg-baseline {
        align-self: baseline !important;
    }

    .align-self-lg-stretch {
        align-self: stretch !important;
    }
}

@media (min-width: 1200px) {
    .flex-xl-row {
        flex-direction: row !important;
    }

    .flex-xl-column {
        flex-direction: column !important;
    }

    .flex-xl-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-xl-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-xl-wrap {
        flex-wrap: wrap !important;
    }

    .flex-xl-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-xl-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .flex-xl-fill {
        flex: 1 1 auto !important;
    }

    .flex-xl-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-xl-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-xl-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-xl-shrink-1 {
        flex-shrink: 1 !important;
    }

    .justify-content-xl-start {
        justify-content: flex-start !important;
    }

    .justify-content-xl-end {
        justify-content: flex-end !important;
    }

    .justify-content-xl-center {
        justify-content: center !important;
    }

    .justify-content-xl-between {
        justify-content: space-between !important;
    }

    .justify-content-xl-around {
        justify-content: space-around !important;
    }

    .align-items-xl-start {
        align-items: flex-start !important;
    }

    .align-items-xl-end {
        align-items: flex-end !important;
    }

    .align-items-xl-center {
        align-items: center !important;
    }

    .align-items-xl-baseline {
        align-items: baseline !important;
    }

    .align-items-xl-stretch {
        align-items: stretch !important;
    }

    .align-content-xl-start {
        align-content: flex-start !important;
    }

    .align-content-xl-end {
        align-content: flex-end !important;
    }

    .align-content-xl-center {
        align-content: center !important;
    }

    .align-content-xl-between {
        align-content: space-between !important;
    }

    .align-content-xl-around {
        align-content: space-around !important;
    }

    .align-content-xl-stretch {
        align-content: stretch !important;
    }

    .align-self-xl-auto {
        align-self: auto !important;
    }

    .align-self-xl-start {
        align-self: flex-start !important;
    }

    .align-self-xl-end {
        align-self: flex-end !important;
    }

    .align-self-xl-center {
        align-self: center !important;
    }

    .align-self-xl-baseline {
        align-self: baseline !important;
    }

    .align-self-xl-stretch {
        align-self: stretch !important;
    }
}


/* ============================================
   UTILITÁRIOS DE ESPAÇAMENTO (Margin & Padding)
   ============================================ */
.m-0 {
    margin: 0 !important;
}

.mt-0, .my-0 {
    margin-top: 0 !important;
}

.mr-0, .mx-0 {
    margin-right: 0 !important;
}

.mb-0, .my-0 {
    margin-bottom: 0 !important;
}

.ml-0, .mx-0 {
    margin-left: 0 !important;
}

.m-1 {
    margin: var(--espacamento-1) !important;
}

.mt-1, .my-1 {
    margin-top: var(--espacamento-1) !important;
}

.mr-1, .mx-1 {
    margin-right: var(--espacamento-1) !important;
}

.mb-1, .my-1 {
    margin-bottom: var(--espacamento-1) !important;
}

.ml-1, .mx-1 {
    margin-left: var(--espacamento-1) !important;
}

.m-2 {
    margin: var(--espacamento-2) !important;
}

.mt-2, .my-2 {
    margin-top: var(--espacamento-2) !important;
}

.mr-2, .mx-2 {
    margin-right: var(--espacamento-2) !important;
}

.mb-2, .my-2 {
    margin-bottom: var(--espacamento-2) !important;
}

.ml-2, .mx-2 {
    margin-left: var(--espacamento-2) !important;
}

.m-3 {
    margin: var(--espacamento-3) !important;
}

.mt-3, .my-3 {
    margin-top: var(--espacamento-3) !important;
}

.mr-3, .mx-3 {
    margin-right: var(--espacamento-3) !important;
}

.mb-3, .my-3 {
    margin-bottom: var(--espacamento-3) !important;
}

.ml-3, .mx-3 {
    margin-left: var(--espacamento-3) !important;
}

.m-4 {
    margin: var(--espacamento-4) !important;
}

.mt-4, .my-4 {
    margin-top: var(--espacamento-4) !important;
}

.mr-4, .mx-4 {
    margin-right: var(--espacamento-4) !important;
}

.mb-4, .my-4 {
    margin-bottom: var(--espacamento-4) !important;
}

.ml-4, .mx-4 {
    margin-left: var(--espacamento-4) !important;
}

.m-5 {
    margin: var(--espacamento-5) !important;
}

.mt-5, .my-5 {
    margin-top: var(--espacamento-5) !important;
}

.mr-5, .mx-5 {
    margin-right: var(--espacamento-5) !important;
}

.mb-5, .my-5 {
    margin-bottom: var(--espacamento-5) !important;
}

.ml-5, .mx-5 {
    margin-left: var(--espacamento-5) !important;
}

.p-0 {
    padding: 0 !important;
}

.pt-0, .py-0 {
    padding-top: 0 !important;
}

.pr-0, .px-0 {
    padding-right: 0 !important;
}

.pb-0, .py-0 {
    padding-bottom: 0 !important;
}

.pl-0, .px-0 {
    padding-left: 0 !important;
}

.p-1 {
    padding: var(--espacamento-1) !important;
}

.pt-1, .py-1 {
    padding-top: var(--espacamento-1) !important;
}

.pr-1, .px-1 {
    padding-right: var(--espacamento-1) !important;
}

.pb-1, .py-1 {
    padding-bottom: var(--espacamento-1) !important;
}

.pl-1, .px-1 {
    padding-left: var(--espacamento-1) !important;
}

.p-2 {
    padding: var(--espacamento-2) !important;
}

.pt-2, .py-2 {
    padding-top: var(--espacamento-2) !important;
}

.pr-2, .px-2 {
    padding-right: var(--espacamento-2) !important;
}

.pb-2, .py-2 {
    padding-bottom: var(--espacamento-2) !important;
}

.pl-2, .px-2 {
    padding-left: var(--espacamento-2) !important;
}

.p-3 {
    padding: var(--espacamento-3) !important;
}

.pt-3, .py-3 {
    padding-top: var(--espacamento-3) !important;
}

.pr-3, .px-3 {
    padding-right: var(--espacamento-3) !important;
}

.pb-3, .py-3 {
    padding-bottom: var(--espacamento-3) !important;
}

.pl-3, .px-3 {
    padding-left: var(--espacamento-3) !important;
}

.p-4 {
    padding: var(--espacamento-4) !important;
}

.pt-4, .py-4 {
    padding-top: var(--espacamento-4) !important;
}

.pr-4, .px-4 {
    padding-right: var(--espacamento-4) !important;
}

.pb-4, .py-4 {
    padding-bottom: var(--espacamento-4) !important;
}

.pl-4, .px-4 {
    padding-left: var(--espacamento-4) !important;
}

.p-5 {
    padding: var(--espacamento-5) !important;
}

.pt-5, .py-5 {
    padding-top: var(--espacamento-5) !important;
}

.pr-5, .px-5 {
    padding-right: var(--espacamento-5) !important;
}

.pb-5, .py-5 {
    padding-bottom: var(--espacamento-5) !important;
}

.pl-5, .px-5 {
    padding-left: var(--espacamento-5) !important;
}

/* Negative Margins */
.m-n1 {
    margin: calc(var(--espacamento-1) * -1) !important;
}

.mt-n1, .my-n1 {
    margin-top: calc(var(--espacamento-1) * -1) !important;
}

.mr-n1, .mx-n1 {
    margin-right: calc(var(--espacamento-1) * -1) !important;
}

.mb-n1, .my-n1 {
    margin-bottom: calc(var(--espacamento-1) * -1) !important;
}

.ml-n1, .mx-n1 {
    margin-left: calc(var(--espacamento-1) * -1) !important;
}

.m-n2 {
    margin: calc(var(--espacamento-2) * -1) !important;
}

.mt-n2, .my-n2 {
    margin-top: calc(var(--espacamento-2) * -1) !important;
}

.mr-n2, .mx-n2 {
    margin-right: calc(var(--espacamento-2) * -1) !important;
}

.mb-n2, .my-n2 {
    margin-bottom: calc(var(--espacamento-2) * -1) !important;
}

.ml-n2, .mx-n2 {
    margin-left: calc(var(--espacamento-2) * -1) !important;
}

.m-n3 {
    margin: calc(var(--espacamento-3) * -1) !important;
}

.mt-n3, .my-n3 {
    margin-top: calc(var(--espacamento-3) * -1) !important;
}

.mr-n3, .mx-n3 {
    margin-right: calc(var(--espacamento-3) * -1) !important;
}

.mb-n3, .my-n3 {
    margin-bottom: calc(var(--espacamento-3) * -1) !important;
}

.ml-n3, .mx-n3 {
    margin-left: calc(var(--espacamento-3) * -1) !important;
}

.m-n4 {
    margin: calc(var(--espacamento-4) * -1) !important;
}

.mt-n4, .my-n4 {
    margin-top: calc(var(--espacamento-4) * -1) !important;
}

.mr-n4, .mx-n4 {
    margin-right: calc(var(--espacamento-4) * -1) !important;
}

.mb-n4, .my-n4 {
    margin-bottom: calc(var(--espacamento-4) * -1) !important;
}

.ml-n4, .mx-n4 {
    margin-left: calc(var(--espacamento-4) * -1) !important;
}

.m-n5 {
    margin: calc(var(--espacamento-5) * -1) !important;
}

.mt-n5, .my-n5 {
    margin-top: calc(var(--espacamento-5) * -1) !important;
}

.mr-n5, .mx-n5 {
    margin-right: calc(var(--espacamento-5) * -1) !important;
}

.mb-n5, .my-n5 {
    margin-bottom: calc(var(--espacamento-5) * -1) !important;
}

.ml-n5, .mx-n5 {
    margin-left: calc(var(--espacamento-5) * -1) !important;
}

/* Auto Margins */
.m-auto {
    margin: auto !important;
}

.mt-auto, .my-auto {
    margin-top: auto !important;
}

.mr-auto, .mx-auto {
    margin-right: auto !important;
}

.mb-auto, .my-auto {
    margin-bottom: auto !important;
}

.ml-auto, .mx-auto {
    margin-left: auto !important;
}

/* SM Responsive Spacing */
@media (min-width: 576px) {
    .m-sm-0 {
        margin: 0 !important;
    }

    .mt-sm-0, .my-sm-0 {
        margin-top: 0 !important;
    }

    .mr-sm-0, .mx-sm-0 {
        margin-right: 0 !important;
    }

    .mb-sm-0, .my-sm-0 {
        margin-bottom: 0 !important;
    }

    .ml-sm-0, .mx-sm-0 {
        margin-left: 0 !important;
    }

    .m-sm-1 {
        margin: var(--espacamento-1) !important;
    }

    .mt-sm-1, .my-sm-1 {
        margin-top: var(--espacamento-1) !important;
    }

    .mr-sm-1, .mx-sm-1 {
        margin-right: var(--espacamento-1) !important;
    }

    .mb-sm-1, .my-sm-1 {
        margin-bottom: var(--espacamento-1) !important;
    }

    .ml-sm-1, .mx-sm-1 {
        margin-left: var(--espacamento-1) !important;
    }

    .m-sm-2 {
        margin: var(--espacamento-2) !important;
    }

    .mt-sm-2, .my-sm-2 {
        margin-top: var(--espacamento-2) !important;
    }

    .mr-sm-2, .mx-sm-2 {
        margin-right: var(--espacamento-2) !important;
    }

    .mb-sm-2, .my-sm-2 {
        margin-bottom: var(--espacamento-2) !important;
    }

    .ml-sm-2, .mx-sm-2 {
        margin-left: var(--espacamento-2) !important;
    }

    .m-sm-3 {
        margin: var(--espacamento-3) !important;
    }

    .mt-sm-3, .my-sm-3 {
        margin-top: var(--espacamento-3) !important;
    }

    .mr-sm-3, .mx-sm-3 {
        margin-right: var(--espacamento-3) !important;
    }

    .mb-sm-3, .my-sm-3 {
        margin-bottom: var(--espacamento-3) !important;
    }

    .ml-sm-3, .mx-sm-3 {
        margin-left: var(--espacamento-3) !important;
    }

    .m-sm-4 {
        margin: var(--espacamento-4) !important;
    }

    .mt-sm-4, .my-sm-4 {
        margin-top: var(--espacamento-4) !important;
    }

    .mr-sm-4, .mx-sm-4 {
        margin-right: var(--espacamento-4) !important;
    }

    .mb-sm-4, .my-sm-4 {
        margin-bottom: var(--espacamento-4) !important;
    }

    .ml-sm-4, .mx-sm-4 {
        margin-left: var(--espacamento-4) !important;
    }

    .m-sm-5 {
        margin: var(--espacamento-5) !important;
    }

    .mt-sm-5, .my-sm-5 {
        margin-top: var(--espacamento-5) !important;
    }

    .mr-sm-5, .mx-sm-5 {
        margin-right: var(--espacamento-5) !important;
    }

    .mb-sm-5, .my-sm-5 {
        margin-bottom: var(--espacamento-5) !important;
    }

    .ml-sm-5, .mx-sm-5 {
        margin-left: var(--espacamento-5) !important;
    }

    .p-sm-0 {
        padding: 0 !important;
    }

    .pt-sm-0, .py-sm-0 {
        padding-top: 0 !important;
    }

    .pr-sm-0, .px-sm-0 {
        padding-right: 0 !important;
    }

    .pb-sm-0, .py-sm-0 {
        padding-bottom: 0 !important;
    }

    .pl-sm-0, .px-sm-0 {
        padding-left: 0 !important;
    }

    .p-sm-1 {
        padding: var(--espacamento-1) !important;
    }

    .pt-sm-1, .py-sm-1 {
        padding-top: var(--espacamento-1) !important;
    }

    .pr-sm-1, .px-sm-1 {
        padding-right: var(--espacamento-1) !important;
    }

    .pb-sm-1, .py-sm-1 {
        padding-bottom: var(--espacamento-1) !important;
    }

    .pl-sm-1, .px-sm-1 {
        padding-left: var(--espacamento-1) !important;
    }

    .p-sm-2 {
        padding: var(--espacamento-2) !important;
    }

    .pt-sm-2, .py-sm-2 {
        padding-top: var(--espacamento-2) !important;
    }

    .pr-sm-2, .px-sm-2 {
        padding-right: var(--espacamento-2) !important;
    }

    .pb-sm-2, .py-sm-2 {
        padding-bottom: var(--espacamento-2) !important;
    }

    .pl-sm-2, .px-sm-2 {
        padding-left: var(--espacamento-2) !important;
    }

    .p-sm-3 {
        padding: var(--espacamento-3) !important;
    }

    .pt-sm-3, .py-sm-3 {
        padding-top: var(--espacamento-3) !important;
    }

    .pr-sm-3, .px-sm-3 {
        padding-right: var(--espacamento-3) !important;
    }

    .pb-sm-3, .py-sm-3 {
        padding-bottom: var(--espacamento-3) !important;
    }

    .pl-sm-3, .px-sm-3 {
        padding-left: var(--espacamento-3) !important;
    }

    .p-sm-4 {
        padding: var(--espacamento-4) !important;
    }

    .pt-sm-4, .py-sm-4 {
        padding-top: var(--espacamento-4) !important;
    }

    .pr-sm-4, .px-sm-4 {
        padding-right: var(--espacamento-4) !important;
    }

    .pb-sm-4, .py-sm-4 {
        padding-bottom: var(--espacamento-4) !important;
    }

    .pl-sm-4, .px-sm-4 {
        padding-left: var(--espacamento-4) !important;
    }

    .p-sm-5 {
        padding: var(--espacamento-5) !important;
    }

    .pt-sm-5, .py-sm-5 {
        padding-top: var(--espacamento-5) !important;
    }

    .pr-sm-5, .px-sm-5 {
        padding-right: var(--espacamento-5) !important;
    }

    .pb-sm-5, .py-sm-5 {
        padding-bottom: var(--espacamento-5) !important;
    }

    .pl-sm-5, .px-sm-5 {
        padding-left: var(--espacamento-5) !important;
    }

    .m-sm-n1 {
        margin: calc(var(--espacamento-1) * -1) !important;
    }

    .mt-sm-n1, .my-sm-n1 {
        margin-top: calc(var(--espacamento-1) * -1) !important;
    }

    .mr-sm-n1, .mx-sm-n1 {
        margin-right: calc(var(--espacamento-1) * -1) !important;
    }

    .mb-sm-n1, .my-sm-n1 {
        margin-bottom: calc(var(--espacamento-1) * -1) !important;
    }

    .ml-sm-n1, .mx-sm-n1 {
        margin-left: calc(var(--espacamento-1) * -1) !important;
    }

    .m-sm-n2 {
        margin: calc(var(--espacamento-2) * -1) !important;
    }

    .mt-sm-n2, .my-sm-n2 {
        margin-top: calc(var(--espacamento-2) * -1) !important;
    }

    .mr-sm-n2, .mx-sm-n2 {
        margin-right: calc(var(--espacamento-2) * -1) !important;
    }

    .mb-sm-n2, .my-sm-n2 {
        margin-bottom: calc(var(--espacamento-2) * -1) !important;
    }

    .ml-sm-n2, .mx-sm-n2 {
        margin-left: calc(var(--espacamento-2) * -1) !important;
    }

    .m-sm-n3 {
        margin: calc(var(--espacamento-3) * -1) !important;
    }

    .mt-sm-n3, .my-sm-n3 {
        margin-top: calc(var(--espacamento-3) * -1) !important;
    }

    .mr-sm-n3, .mx-sm-n3 {
        margin-right: calc(var(--espacamento-3) * -1) !important;
    }

    .mb-sm-n3, .my-sm-n3 {
        margin-bottom: calc(var(--espacamento-3) * -1) !important;
    }

    .ml-sm-n3, .mx-sm-n3 {
        margin-left: calc(var(--espacamento-3) * -1) !important;
    }

    .m-sm-n4 {
        margin: calc(var(--espacamento-4) * -1) !important;
    }

    .mt-sm-n4, .my-sm-n4 {
        margin-top: calc(var(--espacamento-4) * -1) !important;
    }

    .mr-sm-n4, .mx-sm-n4 {
        margin-right: calc(var(--espacamento-4) * -1) !important;
    }

    .mb-sm-n4, .my-sm-n4 {
        margin-bottom: calc(var(--espacamento-4) * -1) !important;
    }

    .ml-sm-n4, .mx-sm-n4 {
        margin-left: calc(var(--espacamento-4) * -1) !important;
    }

    .m-sm-n5 {
        margin: calc(var(--espacamento-5) * -1) !important;
    }

    .mt-sm-n5, .my-sm-n5 {
        margin-top: calc(var(--espacamento-5) * -1) !important;
    }

    .mr-sm-n5, .mx-sm-n5 {
        margin-right: calc(var(--espacamento-5) * -1) !important;
    }

    .mb-sm-n5, .my-sm-n5 {
        margin-bottom: calc(var(--espacamento-5) * -1) !important;
    }

    .ml-sm-n5, .mx-sm-n5 {
        margin-left: calc(var(--espacamento-5) * -1) !important;
    }

    .m-sm-auto {
        margin: auto !important;
    }

    .mt-sm-auto, .my-sm-auto {
        margin-top: auto !important;
    }

    .mr-sm-auto, .mx-sm-auto {
        margin-right: auto !important;
    }

    .mb-sm-auto, .my-sm-auto {
        margin-bottom: auto !important;
    }

    .ml-sm-auto, .mx-sm-auto {
        margin-left: auto !important;
    }
}

/* MD Responsive Spacing */
@media (min-width: 768px) {
    .m-md-0 {
        margin: 0 !important;
    }

    .mt-md-0, .my-md-0 {
        margin-top: 0 !important;
    }

    .mr-md-0, .mx-md-0 {
        margin-right: 0 !important;
    }

    .mb-md-0, .my-md-0 {
        margin-bottom: 0 !important;
    }

    .ml-md-0, .mx-md-0 {
        margin-left: 0 !important;
    }

    .m-md-1 {
        margin: var(--espacamento-1) !important;
    }

    .mt-md-1, .my-md-1 {
        margin-top: var(--espacamento-1) !important;
    }

    .mr-md-1, .mx-md-1 {
        margin-right: var(--espacamento-1) !important;
    }

    .mb-md-1, .my-md-1 {
        margin-bottom: var(--espacamento-1) !important;
    }

    .ml-md-1, .mx-md-1 {
        margin-left: var(--espacamento-1) !important;
    }

    .m-md-2 {
        margin: var(--espacamento-2) !important;
    }

    .mt-md-2, .my-md-2 {
        margin-top: var(--espacamento-2) !important;
    }

    .mr-md-2, .mx-md-2 {
        margin-right: var(--espacamento-2) !important;
    }

    .mb-md-2, .my-md-2 {
        margin-bottom: var(--espacamento-2) !important;
    }

    .ml-md-2, .mx-md-2 {
        margin-left: var(--espacamento-2) !important;
    }

    .m-md-3 {
        margin: var(--espacamento-3) !important;
    }

    .mt-md-3, .my-md-3 {
        margin-top: var(--espacamento-3) !important;
    }

    .mr-md-3, .mx-md-3 {
        margin-right: var(--espacamento-3) !important;
    }

    .mb-md-3, .my-md-3 {
        margin-bottom: var(--espacamento-3) !important;
    }

    .ml-md-3, .mx-md-3 {
        margin-left: var(--espacamento-3) !important;
    }

    .m-md-4 {
        margin: var(--espacamento-4) !important;
    }

    .mt-md-4, .my-md-4 {
        margin-top: var(--espacamento-4) !important;
    }

    .mr-md-4, .mx-md-4 {
        margin-right: var(--espacamento-4) !important;
    }

    .mb-md-4, .my-md-4 {
        margin-bottom: var(--espacamento-4) !important;
    }

    .ml-md-4, .mx-md-4 {
        margin-left: var(--espacamento-4) !important;
    }

    .m-md-5 {
        margin: var(--espacamento-5) !important;
    }

    .mt-md-5, .my-md-5 {
        margin-top: var(--espacamento-5) !important;
    }

    .mr-md-5, .mx-md-5 {
        margin-right: var(--espacamento-5) !important;
    }

    .mb-md-5, .my-md-5 {
        margin-bottom: var(--espacamento-5) !important;
    }

    .ml-md-5, .mx-md-5 {
        margin-left: var(--espacamento-5) !important;
    }

    .p-md-0 {
        padding: 0 !important;
    }

    .pt-md-0, .py-md-0 {
        padding-top: 0 !important;
    }

    .pr-md-0, .px-md-0 {
        padding-right: 0 !important;
    }

    .pb-md-0, .py-md-0 {
        padding-bottom: 0 !important;
    }

    .pl-md-0, .px-md-0 {
        padding-left: 0 !important;
    }

    .p-md-1 {
        padding: var(--espacamento-1) !important;
    }

    .pt-md-1, .py-md-1 {
        padding-top: var(--espacamento-1) !important;
    }

    .pr-md-1, .px-md-1 {
        padding-right: var(--espacamento-1) !important;
    }

    .pb-md-1, .py-md-1 {
        padding-bottom: var(--espacamento-1) !important;
    }

    .pl-md-1, .px-md-1 {
        padding-left: var(--espacamento-1) !important;
    }

    .p-md-2 {
        padding: var(--espacamento-2) !important;
    }

    .pt-md-2, .py-md-2 {
        padding-top: var(--espacamento-2) !important;
    }

    .pr-md-2, .px-md-2 {
        padding-right: var(--espacamento-2) !important;
    }

    .pb-md-2, .py-md-2 {
        padding-bottom: var(--espacamento-2) !important;
    }

    .pl-md-2, .px-md-2 {
        padding-left: var(--espacamento-2) !important;
    }

    .p-md-3 {
        padding: var(--espacamento-3) !important;
    }

    .pt-md-3, .py-md-3 {
        padding-top: var(--espacamento-3) !important;
    }

    .pr-md-3, .px-md-3 {
        padding-right: var(--espacamento-3) !important;
    }

    .pb-md-3, .py-md-3 {
        padding-bottom: var(--espacamento-3) !important;
    }

    .pl-md-3, .px-md-3 {
        padding-left: var(--espacamento-3) !important;
    }

    .p-md-4 {
        padding: var(--espacamento-4) !important;
    }

    .pt-md-4, .py-md-4 {
        padding-top: var(--espacamento-4) !important;
    }

    .pr-md-4, .px-md-4 {
        padding-right: var(--espacamento-4) !important;
    }

    .pb-md-4, .py-md-4 {
        padding-bottom: var(--espacamento-4) !important;
    }

    .pl-md-4, .px-md-4 {
        padding-left: var(--espacamento-4) !important;
    }

    .p-md-5 {
        padding: var(--espacamento-5) !important;
    }

    .pt-md-5, .py-md-5 {
        padding-top: var(--espacamento-5) !important;
    }

    .pr-md-5, .px-md-5 {
        padding-right: var(--espacamento-5) !important;
    }

    .pb-md-5, .py-md-5 {
        padding-bottom: var(--espacamento-5) !important;
    }

    .pl-md-5, .px-md-5 {
        padding-left: var(--espacamento-5) !important;
    }

    .m-md-n1 {
        margin: calc(var(--espacamento-1) * -1) !important;
    }

    .mt-md-n1, .my-md-n1 {
        margin-top: calc(var(--espacamento-1) * -1) !important;
    }

    .mr-md-n1, .mx-md-n1 {
        margin-right: calc(var(--espacamento-1) * -1) !important;
    }

    .mb-md-n1, .my-md-n1 {
        margin-bottom: calc(var(--espacamento-1) * -1) !important;
    }

    .ml-md-n1, .mx-md-n1 {
        margin-left: calc(var(--espacamento-1) * -1) !important;
    }

    .m-md-n2 {
        margin: calc(var(--espacamento-2) * -1) !important;
    }

    .mt-md-n2, .my-md-n2 {
        margin-top: calc(var(--espacamento-2) * -1) !important;
    }

    .mr-md-n2, .mx-md-n2 {
        margin-right: calc(var(--espacamento-2) * -1) !important;
    }

    .mb-md-n2, .my-md-n2 {
        margin-bottom: calc(var(--espacamento-2) * -1) !important;
    }

    .ml-md-n2, .mx-md-n2 {
        margin-left: calc(var(--espacamento-2) * -1) !important;
    }

    .m-md-n3 {
        margin: calc(var(--espacamento-3) * -1) !important;
    }

    .mt-md-n3, .my-md-n3 {
        margin-top: calc(var(--espacamento-3) * -1) !important;
    }

    .mr-md-n3, .mx-md-n3 {
        margin-right: calc(var(--espacamento-3) * -1) !important;
    }

    .mb-md-n3, .my-md-n3 {
        margin-bottom: calc(var(--espacamento-3) * -1) !important;
    }

    .ml-md-n3, .mx-md-n3 {
        margin-left: calc(var(--espacamento-3) * -1) !important;
    }

    .m-md-n4 {
        margin: calc(var(--espacamento-4) * -1) !important;
    }

    .mt-md-n4, .my-md-n4 {
        margin-top: calc(var(--espacamento-4) * -1) !important;
    }

    .mr-md-n4, .mx-md-n4 {
        margin-right: calc(var(--espacamento-4) * -1) !important;
    }

    .mb-md-n4, .my-md-n4 {
        margin-bottom: calc(var(--espacamento-4) * -1) !important;
    }

    .ml-md-n4, .mx-md-n4 {
        margin-left: calc(var(--espacamento-4) * -1) !important;
    }

    .m-md-n5 {
        margin: calc(var(--espacamento-5) * -1) !important;
    }

    .mt-md-n5, .my-md-n5 {
        margin-top: calc(var(--espacamento-5) * -1) !important;
    }

    .mr-md-n5, .mx-md-n5 {
        margin-right: calc(var(--espacamento-5) * -1) !important;
    }

    .mb-md-n5, .my-md-n5 {
        margin-bottom: calc(var(--espacamento-5) * -1) !important;
    }

    .ml-md-n5, .mx-md-n5 {
        margin-left: calc(var(--espacamento-5) * -1) !important;
    }

    .m-md-auto {
        margin: auto !important;
    }

    .mt-md-auto, .my-md-auto {
        margin-top: auto !important;
    }

    .mr-md-auto, .mx-md-auto {
        margin-right: auto !important;
    }

    .mb-md-auto, .my-md-auto {
        margin-bottom: auto !important;
    }

    .ml-md-auto, .mx-md-auto {
        margin-left: auto !important;
    }
}

/* LG Responsive Spacing */
@media (min-width: 992px) {
    .m-lg-0 {
        margin: 0 !important;
    }

    .mt-lg-0, .my-lg-0 {
        margin-top: 0 !important;
    }

    .mr-lg-0, .mx-lg-0 {
        margin-right: 0 !important;
    }

    .mb-lg-0, .my-lg-0 {
        margin-bottom: 0 !important;
    }

    .ml-lg-0, .mx-lg-0 {
        margin-left: 0 !important;
    }

    .m-lg-1 {
        margin: var(--espacamento-1) !important;
    }

    .mt-lg-1, .my-lg-1 {
        margin-top: var(--espacamento-1) !important;
    }

    .mr-lg-1, .mx-lg-1 {
        margin-right: var(--espacamento-1) !important;
    }

    .mb-lg-1, .my-lg-1 {
        margin-bottom: var(--espacamento-1) !important;
    }

    .ml-lg-1, .mx-lg-1 {
        margin-left: var(--espacamento-1) !important;
    }

    .m-lg-2 {
        margin: var(--espacamento-2) !important;
    }

    .mt-lg-2, .my-lg-2 {
        margin-top: var(--espacamento-2) !important;
    }

    .mr-lg-2, .mx-lg-2 {
        margin-right: var(--espacamento-2) !important;
    }

    .mb-lg-2, .my-lg-2 {
        margin-bottom: var(--espacamento-2) !important;
    }

    .ml-lg-2, .mx-lg-2 {
        margin-left: var(--espacamento-2) !important;
    }

    .m-lg-3 {
        margin: var(--espacamento-3) !important;
    }

    .mt-lg-3, .my-lg-3 {
        margin-top: var(--espacamento-3) !important;
    }

    .mr-lg-3, .mx-lg-3 {
        margin-right: var(--espacamento-3) !important;
    }

    .mb-lg-3, .my-lg-3 {
        margin-bottom: var(--espacamento-3) !important;
    }

    .ml-lg-3, .mx-lg-3 {
        margin-left: var(--espacamento-3) !important;
    }

    .m-lg-4 {
        margin: var(--espacamento-4) !important;
    }

    .mt-lg-4, .my-lg-4 {
        margin-top: var(--espacamento-4) !important;
    }

    .mr-lg-4, .mx-lg-4 {
        margin-right: var(--espacamento-4) !important;
    }

    .mb-lg-4, .my-lg-4 {
        margin-bottom: var(--espacamento-4) !important;
    }

    .ml-lg-4, .mx-lg-4 {
        margin-left: var(--espacamento-4) !important;
    }

    .m-lg-5 {
        margin: var(--espacamento-5) !important;
    }

    .mt-lg-5, .my-lg-5 {
        margin-top: var(--espacamento-5) !important;
    }

    .mr-lg-5, .mx-lg-5 {
        margin-right: var(--espacamento-5) !important;
    }

    .mb-lg-5, .my-lg-5 {
        margin-bottom: var(--espacamento-5) !important;
    }

    .ml-lg-5, .mx-lg-5 {
        margin-left: var(--espacamento-5) !important;
    }

    .p-lg-0 {
        padding: 0 !important;
    }

    .pt-lg-0, .py-lg-0 {
        padding-top: 0 !important;
    }

    .pr-lg-0, .px-lg-0 {
        padding-right: 0 !important;
    }

    .pb-lg-0, .py-lg-0 {
        padding-bottom: 0 !important;
    }

    .pl-lg-0, .px-lg-0 {
        padding-left: 0 !important;
    }

    .p-lg-1 {
        padding: var(--espacamento-1) !important;
    }

    .pt-lg-1, .py-lg-1 {
        padding-top: var(--espacamento-1) !important;
    }

    .pr-lg-1, .px-lg-1 {
        padding-right: var(--espacamento-1) !important;
    }

    .pb-lg-1, .py-lg-1 {
        padding-bottom: var(--espacamento-1) !important;
    }

    .pl-lg-1, .px-lg-1 {
        padding-left: var(--espacamento-1) !important;
    }

    .p-lg-2 {
        padding: var(--espacamento-2) !important;
    }

    .pt-lg-2, .py-lg-2 {
        padding-top: var(--espacamento-2) !important;
    }

    .pr-lg-2, .px-lg-2 {
        padding-right: var(--espacamento-2) !important;
    }

    .pb-lg-2, .py-lg-2 {
        padding-bottom: var(--espacamento-2) !important;
    }

    .pl-lg-2, .px-lg-2 {
        padding-left: var(--espacamento-2) !important;
    }

    .p-lg-3 {
        padding: var(--espacamento-3) !important;
    }

    .pt-lg-3, .py-lg-3 {
        padding-top: var(--espacamento-3) !important;
    }

    .pr-lg-3, .px-lg-3 {
        padding-right: var(--espacamento-3) !important;
    }

    .pb-lg-3, .py-lg-3 {
        padding-bottom: var(--espacamento-3) !important;
    }

    .pl-lg-3, .px-lg-3 {
        padding-left: var(--espacamento-3) !important;
    }

    .p-lg-4 {
        padding: var(--espacamento-4) !important;
    }

    .pt-lg-4, .py-lg-4 {
        padding-top: var(--espacamento-4) !important;
    }

    .pr-lg-4, .px-lg-4 {
        padding-right: var(--espacamento-4) !important;
    }

    .pb-lg-4, .py-lg-4 {
        padding-bottom: var(--espacamento-4) !important;
    }

    .pl-lg-4, .px-lg-4 {
        padding-left: var(--espacamento-4) !important;
    }

    .p-lg-5 {
        padding: var(--espacamento-5) !important;
    }

    .pt-lg-5, .py-lg-5 {
        padding-top: var(--espacamento-5) !important;
    }

    .pr-lg-5, .px-lg-5 {
        padding-right: var(--espacamento-5) !important;
    }

    .pb-lg-5, .py-lg-5 {
        padding-bottom: var(--espacamento-5) !important;
    }

    .pl-lg-5, .px-lg-5 {
        padding-left: var(--espacamento-5) !important;
    }

    .m-lg-n1 {
        margin: calc(var(--espacamento-1) * -1) !important;
    }

    .mt-lg-n1, .my-lg-n1 {
        margin-top: calc(var(--espacamento-1) * -1) !important;
    }

    .mr-lg-n1, .mx-lg-n1 {
        margin-right: calc(var(--espacamento-1) * -1) !important;
    }

    .mb-lg-n1, .my-lg-n1 {
        margin-bottom: calc(var(--espacamento-1) * -1) !important;
    }

    .ml-lg-n1, .mx-lg-n1 {
        margin-left: calc(var(--espacamento-1) * -1) !important;
    }

    .m-lg-n2 {
        margin: calc(var(--espacamento-2) * -1) !important;
    }

    .mt-lg-n2, .my-lg-n2 {
        margin-top: calc(var(--espacamento-2) * -1) !important;
    }

    .mr-lg-n2, .mx-lg-n2 {
        margin-right: calc(var(--espacamento-2) * -1) !important;
    }

    .mb-lg-n2, .my-lg-n2 {
        margin-bottom: calc(var(--espacamento-2) * -1) !important;
    }

    .ml-lg-n2, .mx-lg-n2 {
        margin-left: calc(var(--espacamento-2) * -1) !important;
    }

    .m-lg-n3 {
        margin: calc(var(--espacamento-3) * -1) !important;
    }

    .mt-lg-n3, .my-lg-n3 {
        margin-top: calc(var(--espacamento-3) * -1) !important;
    }

    .mr-lg-n3, .mx-lg-n3 {
        margin-right: calc(var(--espacamento-3) * -1) !important;
    }

    .mb-lg-n3, .my-lg-n3 {
        margin-bottom: calc(var(--espacamento-3) * -1) !important;
    }

    .ml-lg-n3, .mx-lg-n3 {
        margin-left: calc(var(--espacamento-3) * -1) !important;
    }

    .m-lg-n4 {
        margin: calc(var(--espacamento-4) * -1) !important;
    }

    .mt-lg-n4, .my-lg-n4 {
        margin-top: calc(var(--espacamento-4) * -1) !important;
    }

    .mr-lg-n4, .mx-lg-n4 {
        margin-right: calc(var(--espacamento-4) * -1) !important;
    }

    .mb-lg-n4, .my-lg-n4 {
        margin-bottom: calc(var(--espacamento-4) * -1) !important;
    }

    .ml-lg-n4, .mx-lg-n4 {
        margin-left: calc(var(--espacamento-4) * -1) !important;
    }

    .m-lg-n5 {
        margin: calc(var(--espacamento-5) * -1) !important;
    }

    .mt-lg-n5, .my-lg-n5 {
        margin-top: calc(var(--espacamento-5) * -1) !important;
    }

    .mr-lg-n5, .mx-lg-n5 {
        margin-right: calc(var(--espacamento-5) * -1) !important;
    }

    .mb-lg-n5, .my-lg-n5 {
        margin-bottom: calc(var(--espacamento-5) * -1) !important;
    }

    .ml-lg-n5, .mx-lg-n5 {
        margin-left: calc(var(--espacamento-5) * -1) !important;
    }

    .m-lg-auto {
        margin: auto !important;
    }

    .mt-lg-auto, .my-lg-auto {
        margin-top: auto !important;
    }

    .mr-lg-auto, .mx-lg-auto {
        margin-right: auto !important;
    }

    .mb-lg-auto, .my-lg-auto {
        margin-bottom: auto !important;
    }

    .ml-lg-auto, .mx-lg-auto {
        margin-left: auto !important;
    }
}

/* XL Responsive Spacing */
@media (min-width: 1200px) {
    .m-xl-0 {
        margin: 0 !important;
    }

    .mt-xl-0, .my-xl-0 {
        margin-top: 0 !important;
    }

    .mr-xl-0, .mx-xl-0 {
        margin-right: 0 !important;
    }

    .mb-xl-0, .my-xl-0 {
        margin-bottom: 0 !important;
    }

    .ml-xl-0, .mx-xl-0 {
        margin-left: 0 !important;
    }

    .m-xl-1 {
        margin: var(--espacamento-1) !important;
    }

    .mt-xl-1, .my-xl-1 {
        margin-top: var(--espacamento-1) !important;
    }

    .mr-xl-1, .mx-xl-1 {
        margin-right: var(--espacamento-1) !important;
    }

    .mb-xl-1, .my-xl-1 {
        margin-bottom: var(--espacamento-1) !important;
    }

    .ml-xl-1, .mx-xl-1 {
        margin-left: var(--espacamento-1) !important;
    }

    .m-xl-2 {
        margin: var(--espacamento-2) !important;
    }

    .mt-xl-2, .my-xl-2 {
        margin-top: var(--espacamento-2) !important;
    }

    .mr-xl-2, .mx-xl-2 {
        margin-right: var(--espacamento-2) !important;
    }

    .mb-xl-2, .my-xl-2 {
        margin-bottom: var(--espacamento-2) !important;
    }

    .ml-xl-2, .mx-xl-2 {
        margin-left: var(--espacamento-2) !important;
    }

    .m-xl-3 {
        margin: var(--espacamento-3) !important;
    }

    .mt-xl-3, .my-xl-3 {
        margin-top: var(--espacamento-3) !important;
    }

    .mr-xl-3, .mx-xl-3 {
        margin-right: var(--espacamento-3) !important;
    }

    .mb-xl-3, .my-xl-3 {
        margin-bottom: var(--espacamento-3) !important;
    }

    .ml-xl-3, .mx-xl-3 {
        margin-left: var(--espacamento-3) !important;
    }

    .m-xl-4 {
        margin: var(--espacamento-4) !important;
    }

    .mt-xl-4, .my-xl-4 {
        margin-top: var(--espacamento-4) !important;
    }

    .mr-xl-4, .mx-xl-4 {
        margin-right: var(--espacamento-4) !important;
    }

    .mb-xl-4, .my-xl-4 {
        margin-bottom: var(--espacamento-4) !important;
    }

    .ml-xl-4, .mx-xl-4 {
        margin-left: var(--espacamento-4) !important;
    }

    .m-xl-5 {
        margin: var(--espacamento-5) !important;
    }

    .mt-xl-5, .my-xl-5 {
        margin-top: var(--espacamento-5) !important;
    }

    .mr-xl-5, .mx-xl-5 {
        margin-right: var(--espacamento-5) !important;
    }

    .mb-xl-5, .my-xl-5 {
        margin-bottom: var(--espacamento-5) !important;
    }

    .ml-xl-5, .mx-xl-5 {
        margin-left: var(--espacamento-5) !important;
    }

    .p-xl-0 {
        padding: 0 !important;
    }

    .pt-xl-0, .py-xl-0 {
        padding-top: 0 !important;
    }

    .pr-xl-0, .px-xl-0 {
        padding-right: 0 !important;
    }

    .pb-xl-0, .py-xl-0 {
        padding-bottom: 0 !important;
    }

    .pl-xl-0, .px-xl-0 {
        padding-left: 0 !important;
    }

    .p-xl-1 {
        padding: var(--espacamento-1) !important;
    }

    .pt-xl-1, .py-xl-1 {
        padding-top: var(--espacamento-1) !important;
    }

    .pr-xl-1, .px-xl-1 {
        padding-right: var(--espacamento-1) !important;
    }

    .pb-xl-1, .py-xl-1 {
        padding-bottom: var(--espacamento-1) !important;
    }

    .pl-xl-1, .px-xl-1 {
        padding-left: var(--espacamento-1) !important;
    }

    .p-xl-2 {
        padding: var(--espacamento-2) !important;
    }

    .pt-xl-2, .py-xl-2 {
        padding-top: var(--espacamento-2) !important;
    }

    .pr-xl-2, .px-xl-2 {
        padding-right: var(--espacamento-2) !important;
    }

    .pb-xl-2, .py-xl-2 {
        padding-bottom: var(--espacamento-2) !important;
    }

    .pl-xl-2, .px-xl-2 {
        padding-left: var(--espacamento-2) !important;
    }

    .p-xl-3 {
        padding: var(--espacamento-3) !important;
    }

    .pt-xl-3, .py-xl-3 {
        padding-top: var(--espacamento-3) !important;
    }

    .pr-xl-3, .px-xl-3 {
        padding-right: var(--espacamento-3) !important;
    }

    .pb-xl-3, .py-xl-3 {
        padding-bottom: var(--espacamento-3) !important;
    }

    .pl-xl-3, .px-xl-3 {
        padding-left: var(--espacamento-3) !important;
    }

    .p-xl-4 {
        padding: var(--espacamento-4) !important;
    }

    .pt-xl-4, .py-xl-4 {
        padding-top: var(--espacamento-4) !important;
    }

    .pr-xl-4, .px-xl-4 {
        padding-right: var(--espacamento-4) !important;
    }

    .pb-xl-4, .py-xl-4 {
        padding-bottom: var(--espacamento-4) !important;
    }

    .pl-xl-4, .px-xl-4 {
        padding-left: var(--espacamento-4) !important;
    }

    .p-xl-5 {
        padding: var(--espacamento-5) !important;
    }

    .pt-xl-5, .py-xl-5 {
        padding-top: var(--espacamento-5) !important;
    }

    .pr-xl-5, .px-xl-5 {
        padding-right: var(--espacamento-5) !important;
    }

    .pb-xl-5, .py-xl-5 {
        padding-bottom: var(--espacamento-5) !important;
    }

    .pl-xl-5, .px-xl-5 {
        padding-left: var(--espacamento-5) !important;
    }

    .m-xl-n1 {
        margin: calc(var(--espacamento-1) * -1) !important;
    }

    .mt-xl-n1, .my-xl-n1 {
        margin-top: calc(var(--espacamento-1) * -1) !important;
    }

    .mr-xl-n1, .mx-xl-n1 {
        margin-right: calc(var(--espacamento-1) * -1) !important;
    }

    .mb-xl-n1, .my-xl-n1 {
        margin-bottom: calc(var(--espacamento-1) * -1) !important;
    }

    .ml-xl-n1, .mx-xl-n1 {
        margin-left: calc(var(--espacamento-1) * -1) !important;
    }

    .m-xl-n2 {
        margin: calc(var(--espacamento-2) * -1) !important;
    }

    .mt-xl-n2, .my-xl-n2 {
        margin-top: calc(var(--espacamento-2) * -1) !important;
    }

    .mr-xl-n2, .mx-xl-n2 {
        margin-right: calc(var(--espacamento-2) * -1) !important;
    }

    .mb-xl-n2, .my-xl-n2 {
        margin-bottom: calc(var(--espacamento-2) * -1) !important;
    }

    .ml-xl-n2, .mx-xl-n2 {
        margin-left: calc(var(--espacamento-2) * -1) !important;
    }

    .m-xl-n3 {
        margin: calc(var(--espacamento-3) * -1) !important;
    }

    .mt-xl-n3, .my-xl-n3 {
        margin-top: calc(var(--espacamento-3) * -1) !important;
    }

    .mr-xl-n3, .mx-xl-n3 {
        margin-right: calc(var(--espacamento-3) * -1) !important;
    }

    .mb-xl-n3, .my-xl-n3 {
        margin-bottom: calc(var(--espacamento-3) * -1) !important;
    }

    .ml-xl-n3, .mx-xl-n3 {
        margin-left: calc(var(--espacamento-3) * -1) !important;
    }

    .m-xl-n4 {
        margin: calc(var(--espacamento-4) * -1) !important;
    }

    .mt-xl-n4, .my-xl-n4 {
        margin-top: calc(var(--espacamento-4) * -1) !important;
    }

    .mr-xl-n4, .mx-xl-n4 {
        margin-right: calc(var(--espacamento-4) * -1) !important;
    }

    .mb-xl-n4, .my-xl-n4 {
        margin-bottom: calc(var(--espacamento-4) * -1) !important;
    }

    .ml-xl-n4, .mx-xl-n4 {
        margin-left: calc(var(--espacamento-4) * -1) !important;
    }

    .m-xl-n5 {
        margin: calc(var(--espacamento-5) * -1) !important;
    }

    .mt-xl-n5, .my-xl-n5 {
        margin-top: calc(var(--espacamento-5) * -1) !important;
    }

    .mr-xl-n5, .mx-xl-n5 {
        margin-right: calc(var(--espacamento-5) * -1) !important;
    }

    .mb-xl-n5, .my-xl-n5 {
        margin-bottom: calc(var(--espacamento-5) * -1) !important;
    }

    .ml-xl-n5, .mx-xl-n5 {
        margin-left: calc(var(--espacamento-5) * -1) !important;
    }

    .m-xl-auto {
        margin: auto !important;
    }

    .mt-xl-auto, .my-xl-auto {
        margin-top: auto !important;
    }

    .mr-xl-auto, .mx-xl-auto {
        margin-right: auto !important;
    }

    .mb-xl-auto, .my-xl-auto {
        margin-bottom: auto !important;
    }

    .ml-xl-auto, .mx-xl-auto {
        margin-left: auto !important;
    }
}


/* ============================================
   UTILITÁRIOS DE GAP
   ============================================ */
.gap-0 {
    gap: 0 !important;
}

.gap-1 {
    gap: var(--espacamento-1) !important;
}

.gap-2 {
    gap: var(--espacamento-2) !important;
}

.gap-3 {
    gap: var(--espacamento-3) !important;
}

.gap-4 {
    gap: var(--espacamento-4) !important;
}

.gap-5 {
    gap: var(--espacamento-5) !important;
}

.row-gap-0 {
    row-gap: 0 !important;
}

.row-gap-1 {
    row-gap: var(--espacamento-1) !important;
}

.row-gap-2 {
    row-gap: var(--espacamento-2) !important;
}

.row-gap-3 {
    row-gap: var(--espacamento-3) !important;
}

.row-gap-4 {
    row-gap: var(--espacamento-4) !important;
}

.row-gap-5 {
    row-gap: var(--espacamento-5) !important;
}

.column-gap-0 {
    column-gap: 0 !important;
}

.column-gap-1 {
    column-gap: var(--espacamento-1) !important;
}

.column-gap-2 {
    column-gap: var(--espacamento-2) !important;
}

.column-gap-3 {
    column-gap: var(--espacamento-3) !important;
}

.column-gap-4 {
    column-gap: var(--espacamento-4) !important;
}

.column-gap-5 {
    column-gap: var(--espacamento-5) !important;
}


/* ============================================
   UTILITÁRIOS DIVERSOS
   ============================================ */
/* Float */
.float-left {
    float: left !important;
}

.float-right {
    float: right !important;
}

.float-none {
    float: none !important;
}

@media (min-width: 576px) {
    .float-sm-left {
        float: left !important;
    }

    .float-sm-right {
        float: right !important;
    }

    .float-sm-none {
        float: none !important;
    }
}

@media (min-width: 768px) {
    .float-md-left {
        float: left !important;
    }

    .float-md-right {
        float: right !important;
    }

    .float-md-none {
        float: none !important;
    }
}

@media (min-width: 992px) {
    .float-lg-left {
        float: left !important;
    }

    .float-lg-right {
        float: right !important;
    }

    .float-lg-none {
        float: none !important;
    }
}

@media (min-width: 1200px) {
    .float-xl-left {
        float: left !important;
    }

    .float-xl-right {
        float: right !important;
    }

    .float-xl-none {
        float: none !important;
    }
}

/* Overflow */
.overflow-auto {
    overflow: auto !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

.overflow-visible {
    overflow: visible !important;
}

.overflow-scroll {
    overflow: scroll !important;
}

.overflow-x-auto {
    overflow-x: auto !important;
}

.overflow-x-hidden {
    overflow-x: hidden !important;
}

.overflow-y-auto {
    overflow-y: auto !important;
}

.overflow-y-hidden {
    overflow-y: hidden !important;
}

/* Object Fit */
.object-fit-contain {
    object-fit: contain !important;
}

.object-fit-cover {
    object-fit: cover !important;
}

.object-fit-fill {
    object-fit: fill !important;
}

.object-fit-scale {
    object-fit: scale-down !important;
}

.object-fit-none {
    object-fit: none !important;
}

/* Position */
.position-static {
    position: static !important;
}

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

.position-fixed {
    position: fixed !important;
}

.position-sticky {
    position: sticky !important;
}

.position-sticky-top {
    position: sticky !important;
    top: 0;
}

.position-sticky-bottom {
    position: sticky !important;
    bottom: 0;
}

.fixed-top {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: var(--z-fixed);
}

.fixed-bottom {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: var(--z-fixed);
}

@supports ((position: -webkit-sticky) or (position: sticky)) {
    .sticky-top {
        position: sticky;
        top: 0;
        z-index: var(--z-sticky);
    }
}

/* User Select */
.user-select-all {
    user-select: all !important;
}

.user-select-auto {
    user-select: auto !important;
}

.user-select-none {
    user-select: none !important;
}

/* Pointer Events */
.pe-none {
    pointer-events: none !important;
}

.pe-auto {
    pointer-events: auto !important;
}

/* Cursor */
.cursor-pointer {
    cursor: pointer !important;
}

.cursor-default {
    cursor: default !important;
}

.cursor-auto {
    cursor: auto !important;
}

.cursor-wait {
    cursor: wait !important;
}

.cursor-text {
    cursor: text !important;
}

.cursor-move {
    cursor: move !important;
}

.cursor-not-allowed {
    cursor: not-allowed !important;
}

/* Vertical Align */
.align-baseline {
    vertical-align: baseline !important;
}

.align-top {
    vertical-align: top !important;
}

.align-middle {
    vertical-align: middle !important;
}

.align-bottom {
    vertical-align: bottom !important;
}

.align-text-bottom {
    vertical-align: text-bottom !important;
}

.align-text-top {
    vertical-align: text-top !important;
}

/* Sizing */
.w-25 {
    width: 25% !important;
}

.w-50 {
    width: 50% !important;
}

.w-75 {
    width: 75% !important;
}

.w-100 {
    width: 100% !important;
}

.w-auto {
    width: auto !important;
}

.h-25 {
    height: 25% !important;
}

.h-50 {
    height: 50% !important;
}

.h-75 {
    height: 75% !important;
}

.h-100 {
    height: 100% !important;
}

.h-auto {
    height: auto !important;
}

.mw-100 {
    max-width: 100% !important;
}

.mh-100 {
    max-height: 100% !important;
}

.min-vw-100 {
    min-width: 100vw !important;
}

.min-vh-100 {
    min-height: 100vh !important;
}

.vw-100 {
    width: 100vw !important;
}

.vh-100 {
    height: 100vh !important;
}

/* Shadow */
.shadow-sm {
    box-shadow: var(--sombra-sm) !important;
}

.shadow {
    box-shadow: var(--sombra-base) !important;
}

.shadow-lg {
    box-shadow: var(--sombra-lg) !important;
}

.shadow-none {
    box-shadow: none !important;
}

/* Visibility */
.visible {
    visibility: visible !important;
}

.invisible {
    visibility: hidden !important;
}

/* Clearfix */
.clearfix::after {
    display: block;
    clear: both;
    content: "";
}

/* Stretched Link */
.stretched-link::after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    pointer-events: auto;
    content: "";
    background-color: rgba(0, 0, 0, 0);
}

/* SR Only */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.sr-only-focusable:active, .sr-only-focusable:focus {
    position: static;
    width: auto;
    height: auto;
    overflow: visible;
    clip: auto;
    white-space: normal;
}

/* Visually Hidden (BS5) */
.visually-hidden, .visually-hidden-focusable:not(:focus):not(:focus-within) {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Z-index */
.z-n1 {
    z-index: -1 !important;
}

.z-0 {
    z-index: 0 !important;
}

.z-1 {
    z-index: 1 !important;
}

.z-2 {
    z-index: 2 !important;
}

.z-3 {
    z-index: 3 !important;
}

/* Focus Ring */
.focus-ring:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Stacks */
.vstack {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    align-self: stretch;
}

.hstack {
    display: flex;
    flex-direction: row;
    align-items: center;
    align-self: stretch;
}

    .vstack > *, .hstack > * {
        flex-shrink: 0;
    }

/* Vertical Rule */
.vr {
    display: inline-block;
    align-self: stretch;
    width: 1px;
    min-height: 1em;
    background-color: currentColor;
    opacity: 0.25;
}


/* ============================================
   PRINT
   ============================================ */
@media print {
    *, *::before, *::after {
        text-shadow: none !important;
        box-shadow: none !important;
    }

    a:not(.btn) {
        text-decoration: underline;
    }

    abbr[title]::after {
        content: " (" attr(title) ")";
    }

    pre {
        white-space: pre-wrap !important;
    }

    pre, blockquote {
        border: 1px solid #adb5bd;
        page-break-inside: avoid;
    }

    thead {
        display: table-header-group;
    }

    tr, img {
        page-break-inside: avoid;
    }

    p, h2, h3 {
        orphans: 3;
        widows: 3;
    }

    h2, h3 {
        page-break-after: avoid;
    }

    @page {
        size: a3;
    }

    body {
        min-width: 992px !important;
    }

    .conteudo {
        min-width: 992px !important;
    }

    .barra-navegacao {
        display: none;
    }

    .badge {
        border: 1px solid #000;
    }

    .table {
        border-collapse: collapse !important;
    }

        .table td, .table th {
            background-color: var(--cor-fundo) !important;
        }

    .table-bordered th, .table-bordered td {
        border: 1px solid var(--cor-borda) !important;
    }

    .table-escuro {
        color: inherit;
    }

        .table-escuro th, .table-escuro td, .table-escuro thead th, .table-escuro tbody + tbody {
            border-color: var(--cor-borda);
        }

    .table .thead-escuro th {
        color: inherit;
        border-color: var(--cor-borda);
    }
}
