/* ===== Main Theme - Bootstrap Dark Theme Standardization ===== */

/* VariÃ¡veis CSS do Sistema */
:root {
  --bg: #051f20;              /* Background principal */
  --bg-2: #0a2b2d;            /* Background secundÃ¡rio (cards) */
  --text: #e8f4f3;            /* Texto principal */
  --muted: #9fb8b6;           /* Texto secundÃ¡rio/muted */
  --stroke: rgba(255, 255, 255, 0.055);  /* Separadores / bordas (flat, quase fundo) */
  --accent: #1f9ea3;          /* Turquesa de destaque */
  /* Bootstrap 5: primary = tema (botões, .text-primary, links, rgba com --bs-primary-rgb) */
  --bs-primary: var(--accent);
  --bs-primary-rgb: 31, 158, 163;
  --bs-link-color: var(--accent);
  --bs-link-hover-color: #26b4ba;
  /* Fontes gerais do sistema (carregadas nos layouts) */
  --font-sans: 'Saira', sans-serif;
  --font-display: 'Sansation', sans-serif;
  --font-serif: 'GFS Neohellenic', serif;
  /* Fundo por detrás do rótulo flutuante (Bootstrap .form-floating), alinhado ao fundo do contentor */
  --form-floating-label-bg: var(--bg-2, #0a2b2d);
  /* Preenchimento WebKit autofill em campos floating (nunca branco semi-transparente — vira “tijolo” branco) */
  --form-floating-autofill-inset: #0a2b2d;
  /* Fundo sólido do input/select .form-floating (equiv. ~6% / ~8% branco sobre --bg-2) */
  --form-floating-field-bg: #19383a;
  --form-floating-field-bg-focus: #1e3c3e;
  --form-floating-label-radius: 7px;
  /* 0 = colado ao alinhamento esquerdo do .form-floating (padding do Bootstrap no input) */
  --form-floating-label-margin-left: 0;
  /* Borda em repouso: flat (quase cor do fundo do input) */
  --input-border-rest: rgba(255, 255, 255, 0.06);
  /* Borda do campo: próxima do fundo (flat) */
  --form-floating-input-border: #1a3032;
  /* Flat UI: bordas quase da cor do fundo + pouca sombra (Bootstrap “customizado”) */
  --flat-border: rgba(255, 255, 255, 0.04);
  --flat-border-muted: rgba(255, 255, 255, 0.055);
  --flat-border-hair: rgba(255, 255, 255, 0.06);
  --flat-shadow-raised: 0 1px 2px rgba(0, 0, 0, 0.2);
  --flat-shadow-none: none;
  --flat-focus-ring: 0 0 0 0.2rem rgba(31, 158, 163, 0.12);
}

/* Background e fonte geral do body */
body {
    font-family: var(--font-sans);
    background-color: var(--bg, #051f20) !important;
    color: var(--text, #e5e7eb) !important;
}

/* Utilitários Bootstrap .border — borda “invisível” no tema escuro */
.border,
.border-top,
.border-end,
.border-bottom,
.border-start {
    border-color: var(--flat-border-muted) !important;
}

/* Grupos de botões: separadores discretos */
.btn-group > .btn:not(:first-child) {
    margin-left: 0 !important;
    border-left-color: var(--flat-border-muted) !important;
}

.btn-group-vertical > .btn:not(:first-child) {
    margin-left: 0 !important;
    border-top-color: var(--flat-border-muted) !important;
}

/* Input group: flat */
.input-group-text {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    border-left-color: var(--flat-border-muted) !important;
}

hr,
hr.divider {
    border-color: var(--flat-border-muted) !important;
    opacity: 1 !important;
}

/* ===== TÍTULO DE PÁGINA (igual ao da /capa: mesmo tamanho/fonte) ===== */
.page-header {
    margin-bottom: 1.5rem; /* mesmo que mb-4 da capa */
}
.page-title {
    margin-bottom: 0; /* mesmo que mb-0 do h2 da capa */
    /* desktop: sem font-size para ficar igual ao h2 .capas-title da capa */
}
@media (max-width: 768px) {
    .page-title {
        font-size: 1.25rem !important; /* igual .capas-title no mobile */
    }

    /* Padrão comum de headers dos CRUDs */
    .crud-page-title {
        font-size: 1.25rem !important;
    }

    .crud-btn-group .btn,
    .crud-btn-single {
        padding: 0.25rem 0.5rem;
        font-size: 0.875rem;
    }
}

/* ===== 1. CARDS (flat) ===== */
.card {
    background: var(--bg-2, #0a2b2d) !important;
    border: 1px solid var(--flat-border) !important;
    border-radius: 14px !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: var(--flat-shadow-raised) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.card-body {
    color: var(--text, #e5e7eb) !important;
}

.card-header {
    background: transparent !important;
    border-bottom-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.card-footer {
    background: transparent !important;
    border-top-color: var(--flat-border-muted) !important;
}

/* Bordas horizontais dentro de cards */
.card .border-bottom,
.card-body .border-bottom {
    border-color: var(--flat-border-muted) !important;
    border-width: 1px !important;
}

.card .text-muted {
    color: var(--muted, #9aa4b2) !important;
}

.card:hover {
    transform: none;
    border-color: var(--flat-border-hair) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.22) !important;
}

/* ===== 2. BOTÕES (flat: sem sombra, borda = fundo) ===== */
.btn:not(.btn-link) {
    box-shadow: none !important;
    border-width: 1px !important;
}

.btn:focus-visible:not(.btn-link) {
    box-shadow: var(--flat-focus-ring) !important;
}

.btn-link:focus-visible {
    box-shadow: none !important;
    outline: 2px solid rgba(31, 158, 163, 0.35) !important;
    outline-offset: 2px !important;
}

/* Botão Primário (--bs-primary em :root alinha com /admin e utilitários Bootstrap) */
.btn-primary {
    background: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
    color: #fff !important;
    font-weight: 700 !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    filter: brightness(.96) !important;
    color: #fff !important;
    background: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}

/* Ícones dentro de botão primary: mesma cor do texto do botão */
.btn-primary .bi,
.btn-primary [class^="bi-"] {
    color: inherit !important;
}

/* Outline primary + utilitário texto (Bootstrap usa azul por defeito) */
.btn-outline-primary {
    color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
    background: transparent !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    color: #fff !important;
    background-color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}

.text-primary {
    color: var(--bs-primary) !important;
}

.link-primary {
    color: var(--bs-primary) !important;
}

.link-primary:hover,
.link-primary:focus {
    color: var(--bs-link-hover-color) !important;
}

/* Botão Secundário */
.btn-secondary {
    background: rgba(255,255,255,.05) !important;
    border: 1px solid var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary.active {
    background: rgba(31,158,163,.08) !important;
    border-color: rgba(31,158,163,.28) !important;
    color: var(--accent, #1f9ea3) !important;
}

/* Botão Outline Secondary */
.btn-outline-secondary {
    border-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
    background: transparent !important;
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background-color: rgba(255,255,255,.06) !important;
    border-color: rgba(31,158,163,.28) !important;
    color: var(--accent, #1f9ea3) !important;
}

/* BotÃ£o Danger */
.btn-danger {
    background: #dc3545 !important;
    border-color: #dc3545 !important;
    color: #fff !important;
}

.btn-danger:hover,
.btn-danger:focus {
    background: #bb2d3b !important;
    border-color: #bb2d3b !important;
    color: #fff !important;
}

/* BotÃ£o Success */
.btn-success {
    background: #198754 !important;
    border-color: #198754 !important;
    color: #fff !important;
}

.btn-success:hover,
.btn-success:focus {
    background: #157347 !important;
    border-color: #157347 !important;
    color: #fff !important;
}

/* BotÃ£o Info */
.btn-info {
    background: #0dcaf0 !important;
    border-color: #0dcaf0 !important;
    color: #000 !important;
}

.btn-info:hover,
.btn-info:focus {
    background: #0aa2c0 !important;
    border-color: #0aa2c0 !important;
    color: #000 !important;
}

/* BotÃ£o Warning */
.btn-warning {
    background: #1f9ea3 !important;
    border-color: #1f9ea3 !important;
    color: #fff !important;
}

.btn-warning:hover,
.btn-warning:focus {
    background: #157f82 !important;
    border-color: #157f82 !important;
    color: #fff !important;
}

/* BotÃ£o Link */
.btn-link {
    color: var(--accent, #1f9ea3) !important;
    text-decoration: none !important;
}

.btn-link:hover,
.btn-link:focus {
    color: var(--accent, #1f9ea3) !important;
    filter: brightness(1.1);
    text-decoration: underline !important;
}

/* ===== 3. MODAIS ===== */
.modal-content {
    background: #103235 !important;
    --form-floating-label-bg: #103235;
    --form-floating-autofill-inset: #103235;
    /* Mesma lógica sólida que :root, mas sobre fundo #103235 */
    --form-floating-field-bg: #1e3e41;
    --form-floating-field-bg-focus: #234245;
    --form-floating-input-border: #2a4042;
    border: 1px solid var(--flat-border) !important;
    border-radius: 14px !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: var(--flat-shadow-raised) !important;
    animation: slideUp 0.3s ease-out;
}

.modal-header {
    border-bottom: 1px solid var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.modal-header .modal-title {
    color: var(--text, #e5e7eb) !important;
}

.modal-header .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

.modal-body {
    color: var(--text, #e5e7eb) !important;
}

.modal-footer {
    border-top: 1px solid var(--flat-border-muted) !important;
}

.modal-backdrop {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

/* Animação de entrada quando o modal fica visível (padrão usado nos CRUDs) */
.modal.show {
    animation: fadeIn 0.2s ease-in;
}

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

/* AnimaÃ§Ã£o de entrada */
@keyframes slideUp {
    from {
        transform: translateY(50px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* ===== 4. INPUTS E FORMULÃRIOS ===== */

/* Inputs de Texto */
.form-control,
.form-select,
textarea {
    background-color: rgba(255,255,255,.04) !important;
    border-color: var(--input-border-rest, rgba(255, 255, 255, 0.11)) !important;
    color: var(--text, #e5e7eb) !important;
    color-scheme: dark !important;
}

.form-control:focus,
.form-select:focus,
textarea:focus {
    background-color: rgba(255,255,255,.06) !important;
    border-color: var(--accent, #1f9ea3) !important;
    box-shadow: var(--flat-focus-ring) !important;
    color: var(--text, #e5e7eb) !important;
}

.form-control::placeholder {
    color: var(--muted, #9aa4b2) !important;
    opacity: 0.7;
}

/* Labels */
.form-label {
    color: var(--text, #e5e7eb) !important;
}

/* Texto de Ajuda */
.form-text {
    color: var(--muted, #9aa4b2) !important;
}

/* Mensagens de ValidaÃ§Ã£o */
.invalid-feedback {
    color: #ff6b6b !important;
}

.valid-feedback {
    color: #51cf66 !important;
}

.form-control.is-invalid,
.form-select.is-invalid {
    border-color: #dc3545 !important;
}

.form-control.is-valid,
.form-select.is-valid {
    border-color: #198754 !important;
}

/* ===== 4b. FLOATING LABELS (Bootstrap .form-floating) ===== */
/* Campos: fundo explícito no tema (evita mancha clara vs. modal/cards) */
.form-floating > .form-control,
.form-floating > .form-select {
    background-color: var(--form-floating-field-bg) !important;
    border-color: var(--form-floating-input-border, #2d494b) !important;
    color: var(--text, #e8f4f3) !important;
}

.form-floating > .form-control:focus,
.form-floating > .form-select:focus {
    background-color: var(--form-floating-field-bg-focus) !important;
    border-color: var(--accent, #1f9ea3) !important;
    color: var(--text, #e8f4f3) !important;
    box-shadow: var(--flat-focus-ring) !important;
}

/*
 * Com o rótulo na borda (sem “notch” branco), o texto pode ir simétrico na vertical.
 * Antes: padding-top grande + bottom pequeno → texto colado ao fundo do input.
 */
.form-floating > .form-control:focus,
.form-floating > .form-control:not(:placeholder-shown),
.form-floating > .form-control:-webkit-autofill {
    padding-top: calc(1.1rem + 1px) !important;
    padding-bottom: calc(1.1rem + 1px) !important;
    line-height: 1.35 !important;
}

.form-floating > .form-select {
    padding-top: calc(1.1rem + 1px) !important;
    padding-bottom: calc(1.1rem + 1px) !important;
    line-height: 1.35 !important;
}

/*
 * Label do .form-floating: Bootstrap define `border: 1px solid transparent` — em tema escuro
 * isso aparece como linha fina. Zerar todas as faces + outline (especificidade com body).
 */
body .form-floating > label {
    margin-left: var(--form-floating-label-margin-left, 0) !important;
    color: rgba(232, 244, 243, 0.72) !important;
    border: 0 !important;
    border-width: 0 !important;
    border-style: none !important;
    border-color: transparent !important;
    outline: 0 !important;
    outline-width: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
}

/*
 * Bootstrap 5.3+ (CDN): o label ganha ::after com background = $input-bg compilado (#fff).
 * Em tema escuro vira a faixa branca por baixo do texto do rótulo. Desativar o “notch” artificial.
 * Ref.: twbs/bootstrap _floating-labels.scss (~ label::after { background-color: $input-bg })
 */
body .form-floating > label::after {
    display: none !important;
}

/*
 * Rótulo ativo: mesma cor de fundo que o campo (--form-floating-field-bg).
 */
body .form-floating > .form-control:focus ~ label,
body .form-floating > .form-control:not(:placeholder-shown) ~ label,
body .form-floating > .form-select ~ label {
    left: 0 !important;
    transform-origin: left center !important;
    transform: scale(0.8) translateY(-0.68rem) translateX(0) !important;
    color: var(--muted, #9fb8b6) !important;
    background-color: var(--form-floating-field-bg) !important;
    background: var(--form-floating-field-bg) !important;
    /* Mesmo inset horizontal que o .form-control / .form-select (Bootstrap ~0.75rem) */
    padding: 1px 0.75rem !important;
    border-radius: var(--form-floating-label-radius, 7px) !important;
    height: auto !important;
    max-width: calc(100% - 1.25rem - var(--form-floating-label-margin-left, 0px)) !important;
    border: 0 !important;
    border-width: 0 !important;
    border-style: none !important;
    outline: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
}

/* Campo com foco → fundo do rótulo igual ao input em foco */
body .form-floating > .form-control:focus ~ label,
body .form-floating > .form-select:focus ~ label {
    background-color: var(--form-floating-field-bg-focus) !important;
    background: var(--form-floating-field-bg-focus) !important;
}

/* Autofill: interior do input é sólido (--form-floating-autofill-inset) */
body .form-floating > .form-control:-webkit-autofill ~ label {
    left: 0 !important;
    transform-origin: left center !important;
    transform: scale(0.8) translateY(-0.68rem) translateX(0) !important;
    color: var(--muted, #9fb8b6) !important;
    background-color: var(--form-floating-autofill-inset) !important;
    background: var(--form-floating-autofill-inset) !important;
    max-width: calc(100% - 1.25rem - var(--form-floating-label-margin-left, 0px)) !important;
    padding: 1px 0.75rem !important;
    border-radius: var(--form-floating-label-radius, 7px) !important;
    border: 0 !important;
    border-width: 0 !important;
    border-style: none !important;
    outline: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    backface-visibility: hidden;
}

/* Autofill WebKit: fundo opaco do tema (o truque rgba(255,255,255,.06) aparece como barra branca) */
.form-floating > .form-control:-webkit-autofill,
.form-floating > .form-control:-webkit-autofill:hover,
.form-floating > .form-control:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--text, #e8f4f3) !important;
    box-shadow: inset 0 0 0 1000px var(--form-floating-autofill-inset, #0a2b2d) !important;
    transition: background-color 99999s ease-out 0s;
}

/* Autofill + foco: manter anel de foco por cima do inset */
.form-floating > .form-control:-webkit-autofill:focus {
    box-shadow:
        inset 0 0 0 1000px var(--form-floating-autofill-inset, #0a2b2d),
        var(--flat-focus-ring) !important;
}

/* Foco: sem outline extra que pareça moldura à volta do rótulo */
.form-floating > .form-control:focus,
.form-floating > .form-select:focus {
    outline: none !important;
}

/* ===== Floating label para input customizado de Tags (fora do padrão Bootstrap) ===== */
.banner-models-tags-floating {
    position: relative;
}

.banner-models-tags-floating-label {
    position: absolute;
    left: 0;
    top: 0;
    transform-origin: left center;
    transform: scale(1) translateY(0) translateX(0);
    transition: transform 0.15s ease, top 0.15s ease, color 0.15s ease, background-color 0.15s ease;
    pointer-events: none;
    z-index: 2;

    color: rgba(232, 244, 243, 0.72) !important;
    background-color: transparent !important;
    background: transparent !important;
    border-radius: var(--form-floating-label-radius, 7px) !important;
    padding: 0 0.75rem;
}

.banner-models-tags-floating:focus-within .banner-models-tags-floating-label,
.banner-models-tags-floating[data-has-value="true"] .banner-models-tags-floating-label {
    /* Mesmo comportamento visual do `.form-floating` (sem depender da altura real do container). */
    top: 0;
    left: 0 !important;
    transform: scale(0.8) translateY(-0.68rem) translateX(0);
    color: var(--muted, #9fb8b6) !important;
    background-color: var(--form-floating-field-bg) !important;
    background: var(--form-floating-field-bg) !important;
    padding: 1px 0.75rem;
}

/* Reservar espaço vertical quando o label flutua, para o texto/chips não fiquem em cima. */
.banner-models-tags-floating:focus-within,
.banner-models-tags-floating[data-has-value="true"] {
    /* Apenas o respiro do label (equivalente ao .form-floating) */
    padding-top: 1.25rem !important;
    align-items: flex-start !important;
}

/* Voltar para o “estado normal” (label centralizado) */
.banner-models-tags-floating:not(:focus-within)[data-has-value="false"] {
    padding-top: 0.35rem !important;
}

/* Deixar o input interno com área vertical mais parecida com .form-control */
.banner-models-tags-floating .looks-tags-text-input {
    /* Deixar o input seguir a altura do layout original dos chips */
    min-height: unset;
    padding: 0 !important;
}

/* Hint discreto do campo de Tags (mantém Bootstrap, mas reduz contraste) — mesmo estilo em textos estáticos (ex.: Custos de IA) */
.banner-models-tags-floating + small.text-muted,
.tags-input-floating + small.text-muted,
small.text-muted.form-field-hint-muted {
    display: block;
    font-size: 0.74rem !important;
    line-height: 1.2;
    margin-top: 0.2rem;
    color: rgba(232, 244, 243, 0.35) !important;
    opacity: 0.75;
}

/* ===== 4c. CAMPO DE FICHEIRO (upload) — alinhado ao aspeto .form-floating / inputs de texto ===== */
.theme-file-upload {
    position: relative;
}

.theme-file-upload__field {
    position: relative;
    border: 1px solid var(--form-floating-input-border, #1a3032);
    background-color: var(--form-floating-field-bg, #19383a);
    border-radius: 0.375rem;
    min-height: 4.25rem;
    /* Horizontal igual ao `.form-floating` (0.75rem) para alinhar chip e conteúdo com Nome / Gênero */
    padding: 0.45rem 0.75rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

/* Com foto: respiro por baixo do chip do rótulo + conteúdo alinhado à esquerda */
.theme-file-upload__field--has-file {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.theme-file-upload__field--has-file .theme-file-upload__inner {
    padding-top: 0.65rem;
    justify-content: flex-start;
    align-items: center;
    min-height: 3rem;
}

.theme-file-upload__field:focus-within {
    border-color: var(--accent, #1f9ea3) !important;
    box-shadow: var(--flat-focus-ring) !important;
    background-color: var(--form-floating-field-bg-focus, #1e3c3e) !important;
}

.theme-file-upload__inner {
    position: relative;
    flex: 1 1 auto;
    min-height: 2.85rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

/* Por baixo do conteúdo: cliques passam pelo conteúdo (pointer-events: none) até ao input,
   exceto no botão X (pointer-events: auto) — assim o X não abre o seletor de ficheiros. */
.theme-file-upload__native {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    z-index: 1;
    font-size: 0;
}

.theme-file-upload__content {
    position: relative;
    z-index: 2;
    width: 100%;
    pointer-events: none;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 2.85rem;
}

.theme-file-upload__hint {
    color: rgba(232, 244, 243, 0.55);
    font-size: 0.9375rem;
}

/* Com pré-visualização: linha — thumb à esquerda, X à direita; tudo encostado à esquerda do campo */
.theme-file-upload__content--has-file {
    align-items: flex-start;
    justify-content: center;
    min-height: auto;
    text-align: left;
    width: 100%;
}

/* Chip na borda: mesmo modelo que Bootstrap — left:0 + padding horizontal = texto alinhado ao conteúdo */
.theme-file-upload__file-label--floating {
    position: absolute;
    left: 0 !important;
    top: 0;
    transform-origin: left center !important;
    transform: scale(0.8) translateY(-0.68rem) translateX(0) !important;
    margin: 0 !important;
    margin-left: var(--form-floating-label-margin-left, 0) !important;
    color: var(--muted, #9fb8b6) !important;
    background-color: var(--form-floating-field-bg) !important;
    background: var(--form-floating-field-bg) !important;
    padding: 1px 0.75rem !important;
    border-radius: var(--form-floating-label-radius, 7px) !important;
    height: auto !important;
    max-width: calc(100% - 1.25rem - var(--form-floating-label-margin-left, 0px)) !important;
    border: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    z-index: 5;
    pointer-events: none;
    line-height: 1.25;
    font-size: 1rem;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    backface-visibility: hidden;
}

.theme-file-upload__field:focus-within .theme-file-upload__file-label--floating {
    background-color: var(--form-floating-field-bg-focus) !important;
    background: var(--form-floating-field-bg-focus) !important;
}

.theme-file-upload__preview-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 100%;
    gap: 0.5rem;
    pointer-events: none;
}

.theme-file-upload__preview-wrap {
    pointer-events: none;
    flex: 0 0 auto;
    width: 3.5rem;
    height: 3.5rem;
    background: rgba(0, 0, 0, 0.22);
    display: flex;
    align-items: center;
    justify-content: center;
}

.theme-file-upload__preview-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.theme-file-upload__remove {
    flex-shrink: 0;
    pointer-events: auto;
    position: relative;
    width: 2.125rem;
    height: 2.125rem;
    padding: 0;
    margin: 0;
    border: none;
    border-radius: 50%;
    background: #dc3545;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    cursor: pointer;
    transition: background 0.15s ease, transform 0.12s ease;
}

.theme-file-upload__remove:hover {
    background: #bb2d3b;
    color: #fff;
}

.theme-file-upload__remove:active {
    transform: scale(0.94);
}

.theme-file-upload__remove:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.45);
}

/* Overlay + barra ao ler ficheiro antes do crop (acima de modais Bootstrap) */
.theme-file-read-overlay {
    position: fixed;
    inset: 0;
    z-index: 200000;
    background: rgba(5, 31, 32, 0.88);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.theme-file-read-overlay.d-none {
    display: none !important;
}

.theme-file-read-overlay__inner {
    width: 100%;
    max-width: min(90vw, 28rem);
}

.theme-file-read-progress.progress {
    height: 2rem;
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: 0.5rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.theme-file-read-progress .progress-bar {
    background-color: var(--accent, #1f9ea3) !important;
}

.theme-file-read-caption {
    color: rgba(232, 244, 243, 0.88);
    font-size: 0.95rem;
}

/* ===== 5. SELECTS ===== */
.form-select {
    background-color: rgba(255,255,255,.04) !important;
    border-color: var(--input-border-rest, rgba(255, 255, 255, 0.11)) !important;
    color: var(--text, #e5e7eb) !important;
    color-scheme: dark !important;
}

.form-select:focus {
    background-color: rgba(255,255,255,.06) !important;
    border-color: var(--accent, #1f9ea3) !important;
    box-shadow: var(--flat-focus-ring) !important;
    color: var(--text, #e5e7eb) !important;
}

/* OpÃ§Ãµes do select */
.form-select option {
    background-color: #103235 !important;
    background: #103235 !important;
    color: var(--text, #e5e7eb) !important;
    padding: 0.5rem !important;
}

.form-select option:checked,
.form-select option:selected {
    background-color: rgba(31,158,163,.15) !important;
    background: rgba(31,158,163,.15) !important;
    color: var(--accent, #1f9ea3) !important;
}

.form-select option:hover {
    background-color: rgba(31,158,163,.1) !important;
    background: rgba(31,158,163,.1) !important;
    color: var(--accent, #1f9ea3) !important;
}

/* Seta customizada do select */
.form-select:not([multiple]):not([size]) {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235a80e1' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 0.75rem center !important;
    background-size: 12px !important;
    padding-right: 2.5rem !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
}

/* ForÃ§ar tema escuro */
.modal-body select.form-select,
.form-select {
    color-scheme: dark !important;
}

/* ===== 6. CHECKBOXES E RADIOS ===== */
.form-check-input {
    background-color: rgba(255,255,255,.04) !important;
    border-color: var(--flat-border-hair) !important;
}

.form-check-input:checked {
    background-color: var(--accent, #1f9ea3) !important;
    border-color: var(--accent, #1f9ea3) !important;
}

.form-check-input:focus {
    border-color: var(--accent, #1f9ea3) !important;
    box-shadow: var(--flat-focus-ring) !important;
}

.form-check-label {
    color: var(--text, #e5e7eb) !important;
}

/* ===== 7. PAGINAÃ‡ÃƒO ===== */
.pagination-links-only p {
    display: none;
}

.pagination .page-link {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    background-color: rgba(255,255,255,.05) !important;
    border-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: none !important;
}

.pagination .page-link:hover {
    background-color: rgba(31,158,163,.08) !important;
    border-color: rgba(31,158,163,.28) !important;
    color: var(--accent, #1f9ea3) !important;
}

.pagination .page-item.active .page-link {
    background-color: var(--accent, #1f9ea3) !important;
    border-color: var(--accent, #1f9ea3) !important;
    color: #fff !important;
}

.pagination .page-item.disabled .page-link {
    background-color: rgba(255,255,255,.03) !important;
    border-color: var(--flat-border) !important;
    color: var(--muted, #9aa4b2) !important;
    opacity: 0.5;
}

@media (max-width: 768px) {
    .pagination {
        display: flex;
        justify-content: space-between;
        width: 100%;
    }
    .pagination .page-item:not(:first-child):not(:last-child) {
        display: none;
    }
}

/* ===== 8. BADGES (flat) ===== */
.badge {
    color: #fff !important;
    border: 1px solid transparent !important;
    box-shadow: none !important;
    font-weight: 600 !important;
}

.badge.bg-primary {
    background-color: var(--bs-primary) !important;
    color: #fff !important;
}

.badge.bg-secondary {
    background-color: rgba(255,255,255,.1) !important;
    border-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.badge.bg-info {
    background-color: #0dcaf0 !important;
    color: #000 !important;
}

.badge.bg-success {
    background-color: #198754 !important;
    color: #fff !important;
}

.badge.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.badge.bg-warning {
    background-color: #1f9ea3 !important;
    color: #fff !important;
}

/* ===== 9. LOADING OVERLAY ===== */
.loading-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(12, 18, 32, 0.95) !important;
    backdrop-filter: blur(8px);
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 9999 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.loading-overlay[style]:not([style*="display: none"]) {
    display: flex !important;
}

.loading-overlay .spinner-border {
    color: var(--accent, #1f9ea3) !important;
    width: 3rem !important;
    height: 3rem !important;
    border-width: 0.3em !important;
}

.spinner-border {
    color: var(--accent, #1f9ea3) !important;
}

/* ===== 10. TOAST NOTIFICATIONS ===== */
.toast {
    background-color: var(--bg-2, #103235) !important;
    border: 1px solid var(--flat-border) !important;
    border-radius: 12px !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: var(--flat-shadow-raised) !important;
}

.toast-header {
    background-color: rgba(255,255,255,.04) !important;
    border-bottom: 1px solid var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
    border-radius: 12px 12px 0 0 !important;
}

.toast-header .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

.toast-header strong {
    color: var(--text, #e5e7eb) !important;
}

.toast-header small {
    color: var(--muted, #9aa4b2) !important;
}

.toast-body {
    background-color: var(--bg-2, #103235) !important;
    color: var(--text, #e5e7eb) !important;
}

/* ===== 11. TEXTOS E TIPOGRAFIA ===== */

/* TÃ­tulos */
h1, h2, h3, h4, h5, h6 {
    color: var(--text, #e5e7eb) !important;
}

/* ParÃ¡grafos */
p {
    color: var(--text, #e5e7eb) !important;
}

/* Texto muted */
.text-muted {
    color: var(--muted, #9aa4b2) !important;
}

/* Links */
a {
    color: var(--accent, #1f9ea3) !important;
}

a:hover {
    color: var(--accent, #1f9ea3) !important;
    filter: brightness(1.1);
}

/* ===== 12. TABELAS ===== */
.table {
    color: var(--text, #e5e7eb) !important;
}

.table-dark {
    background-color: var(--bg-2, #0a2b2d) !important;
    color: var(--text, #e5e7eb) !important;
}

.table-striped > tbody > tr:nth-of-type(odd) > td,
.table-striped > tbody > tr:nth-of-type(odd) > th {
    background-color: rgba(255,255,255,.02) !important;
}

.table-hover > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > th {
    background-color: rgba(31,158,163,.05) !important;
    color: var(--text, #e5e7eb) !important;
}

.table thead th {
    border-bottom-color: var(--stroke, rgba(255,255,255,.06)) !important;
    color: var(--text, #e5e7eb) !important;
}

.table td,
.table th {
    border-top-color: var(--stroke, rgba(255,255,255,.06)) !important;
}

/* ===== 13. ALERTAS (flat) ===== */
.alert {
    border-radius: 10px !important;
    border: 1px solid var(--flat-border) !important;
    box-shadow: none !important;
}

.alert-primary {
    background-color: rgba(31,158,163,.1) !important;
    border-color: rgba(31,158,163,.18) !important;
    color: var(--accent, #1f9ea3) !important;
}

.alert-secondary {
    background-color: rgba(255,255,255,.04) !important;
    border-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.alert-danger {
    background-color: rgba(220,53,69,.1) !important;
    border-color: rgba(220,53,69,.2) !important;
    color: #ff6b6b !important;
}

.alert-success {
    background-color: rgba(25,135,84,.1) !important;
    border-color: rgba(25,135,84,.2) !important;
    color: #51cf66 !important;
}

.alert-warning {
    background-color: rgba(31,158,163,.1) !important;
    border-color: rgba(31,158,163,.18) !important;
    color: #1f9ea3 !important;
}

.alert-info {
    background-color: rgba(13,202,240,.1) !important;
    border-color: rgba(13,202,240,.2) !important;
    color: #0dcaf0 !important;
}

/* ===== 14. DROPDOWNS (flat) ===== */
.dropdown-menu {
    background-color: #103235 !important;
    border: 1px solid var(--flat-border) !important;
    border-radius: 10px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.35) !important;
}

.dropdown-item {
    color: var(--text, #e5e7eb) !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: rgba(31,158,163,.1) !important;
    color: var(--accent, #1f9ea3) !important;
}

.dropdown-item.active {
    background-color: rgba(31,158,163,.15) !important;
    color: var(--accent, #1f9ea3) !important;
}

.dropdown-divider {
    border-top-color: var(--flat-border-muted) !important;
}

/* ===== 15. OFF-CANVAS (flat) ===== */
.offcanvas {
    background-color: var(--bg-2, #0a2b2d) !important;
    border-color: var(--flat-border) !important;
    color: var(--text, #e5e7eb) !important;
}
.offcanvas-header {
    border-bottom-color: var(--flat-border-muted) !important;
}

.offcanvas-header .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

.offcanvas-body {
    color: var(--text, #e5e7eb) !important;
}

/* ===== 16. POPOVERS E TOOLTIPS (flat) ===== */
.popover {
    background-color: #103235 !important;
    border-color: var(--flat-border) !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: var(--flat-shadow-raised) !important;
}

.popover-header {
    background-color: rgba(255,255,255,.04) !important;
    border-bottom-color: var(--flat-border-muted) !important;
    color: var(--text, #e5e7eb) !important;
}

.popover-body {
    color: var(--text, #e5e7eb) !important;
}

.tooltip .tooltip-inner {
    background-color: #103235 !important;
    color: var(--text, #e5e7eb) !important;
}

.tooltip .tooltip-arrow::before {
    border-top-color: #103235 !important;
}

/* ===== 17. ACCORDION (flat) ===== */
.accordion {
    --bs-accordion-border-color: var(--flat-border);
    --bs-accordion-btn-focus-border-color: rgba(31, 158, 163, 0.35);
    --bs-accordion-active-bg: rgba(31, 158, 163, 0.06);
    --bs-accordion-btn-focus-box-shadow: var(--flat-focus-ring);
}

.accordion-item {
    background-color: var(--bg-2, #0a2b2d) !important;
    border-color: var(--flat-border) !important;
}

.accordion-button {
    background-color: var(--bg-2, #0a2b2d) !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: none !important;
}

.accordion-button:not(.collapsed) {
    background-color: rgba(31,158,163,.06) !important;
    color: var(--accent, #1f9ea3) !important;
}

.accordion-button:focus {
    box-shadow: var(--flat-focus-ring) !important;
    border-color: var(--accent, #1f9ea3) !important;
}

.accordion-body {
    background-color: var(--bg-2, #0a2b2d) !important;
    color: var(--text, #e5e7eb) !important;
}

/* ===== 18. LIST GROUPS (flat) ===== */
.list-group-item {
    background-color: var(--bg-2, #0a2b2d) !important;
    border-color: var(--flat-border) !important;
    color: var(--text, #e5e7eb) !important;
}

.list-group-item.active {
    background-color: var(--accent, #1f9ea3) !important;
    border-color: var(--accent, #1f9ea3) !important;
    color: #fff !important;
}

.list-group-item:hover {
    background-color: rgba(31,158,163,.05) !important;
}

/* ===== 19. PROGRESS BARS (flat) ===== */
.progress {
    background-color: rgba(255,255,255,.05) !important;
    border: 1px solid var(--flat-border) !important;
    box-shadow: none !important;
}

.progress-bar {
    background-color: var(--accent, #1f9ea3) !important;
    color: #fff !important;
}

.progress-bar.bg-success {
    background-color: #198754 !important;
    color: #fff !important;
}

.progress-bar.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.progress-bar.bg-info {
    background-color: #0dcaf0 !important;
    color: #000 !important;
}

.progress-bar.bg-warning {
    background-color: #1f9ea3 !important;
    color: #fff !important;
}

/* ===== 20. BREADCRUMBS ===== */
.breadcrumb {
    background-color: transparent !important;
}

.breadcrumb-item a {
    color: var(--accent, #1f9ea3) !important;
}

.breadcrumb-item.active {
    color: var(--muted, #9aa4b2) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--muted, #9aa4b2) !important;
}

/* ===== 21. NAVS E TABS (flat) ===== */
.nav-tabs .nav-link {
    color: var(--text, #e5e7eb) !important;
    border-color: var(--flat-border) !important;
}

.nav-tabs .nav-link:hover {
    border-color: rgba(31,158,163,.22) !important;
    color: var(--accent, #1f9ea3) !important;
}

.nav-tabs .nav-link.active {
    background-color: rgba(31,158,163,.06) !important;
    border-color: rgba(31,158,163,.35) !important;
    color: var(--accent, #1f9ea3) !important;
}

.nav-pills .nav-link {
    color: var(--text, #e5e7eb) !important;
}

.nav-pills .nav-link.active {
    background-color: var(--accent, #1f9ea3) !important;
    color: #fff !important;
}

/* ===== 22. SIDEBAR E MENU LATERAL (flat) ===== */
#sidebar {
    background-color: var(--bg-2, #0a2b2d) !important;
    border-right: 1px solid var(--flat-border) !important;
    color: var(--text, #e5e7eb) !important;
}

#sidebar strong {
    color: var(--text, #e5e7eb) !important;
}

#sidebar .nav-link {
    color: var(--text, #e5e7eb) !important;
    border-radius: 8px !important;
}

#sidebar .nav-link:hover {
    background-color: rgba(31,158,163,.08) !important;
    color: var(--accent, #1f9ea3) !important;
}

#sidebar .nav-link.active {
    background-color: rgba(31,158,163,.15) !important;
    color: var(--accent, #1f9ea3) !important;
}

#sidebar .nav-link i {
    color: inherit !important;
}

#sidebar .btn {
    color: var(--text, #e5e7eb) !important;
}

/* ===== 23. TOPBAR/NAVBAR SUPERIOR (flat — nav-menu.css pode sobrepor sombra) ===== */
#topbar,
.navbar-top,
header.sticky-top.bg-body {
    background-color: var(--bg-2, #0a2b2d) !important;
    border-bottom: 1px solid var(--flat-border) !important;
    color: var(--text, #e5e7eb) !important;
    box-shadow: var(--flat-shadow-raised) !important;
}

#topbar .navbar-brand,
.navbar-top .navbar-brand {
    color: var(--text, #e5e7eb) !important;
}

#topbar .nav-link,
.navbar-top .nav-link {
    color: var(--text, #e5e7eb) !important;
}

#topbar .nav-link:hover,
.navbar-top .nav-link:hover {
    color: var(--accent, #1f9ea3) !important;
}

#topbar .dropdown-menu,
.navbar-top .dropdown-menu {
    background-color: #103235 !important;
    border-color: var(--flat-border) !important;
}

#topbar .dropdown-item,
.navbar-top .dropdown-item {
    color: var(--text, #e5e7eb) !important;
}

#topbar .dropdown-item:hover,
.navbar-top .dropdown-item:hover {
    background-color: rgba(31,158,163,.1) !important;
    color: var(--accent, #1f9ea3) !important;
}

/* Override bg-body do Bootstrap para usar tema escuro */
.bg-body {
    background-color: var(--bg-2, #0a2b2d) !important;
    color: var(--text, #e5e7eb) !important;
}

/* Garantir que elementos dentro do sidebar e topbar tenham cores corretas */
#sidebar *,
header.sticky-top.bg-body * {
    color: inherit;
}

#sidebar .badge {
    color: #fff !important;
}

/* ===== 24. CLOUDFLARE TURNSTILE ===== */
/* Turnstile tem largura fixa de aproximadamente 300px */
.cf-turnstile {
    width: 300px !important;
}

/* ===== 25. ÃCONES DE PRODUTOS/PRODUÃ‡Ã•ES (Grid) ===== */
/* Fundo escuro para Ã­cones quando nÃ£o hÃ¡ imagem (promoÃ§Ãµes, anÃºncios, etc) */
.card-img-top.bg-light,
.bg-light.rounded {
    background-color: var(--bg, #051f20) !important;
    background: var(--bg, #051f20) !important;
    border-radius: 14px 14px 0 0 !important;
}

/* Para cards horizontais, border-radius completo */
.bg-light.rounded {
    border-radius: 14px !important;
}

/* Garantir que Ã­cones dentro desses containers tenham cor adequada */
.card-img-top.bg-light .bi,
.bg-light.rounded .bi {
    color: var(--accent, #1f9ea3) !important;
}

/* Garantir que imagens também tenham o mesmo border-radius */
.card-img-top img {
    border-radius: 14px 14px 0 0 !important;
}
