/* Largura máxima do conteúdo admin (ex.: auditoria — aplicar classe no template) */
.ec-admin-container {
    max-width: 1320px;
}

/* Contentor a largura útil total (ficha participante, grupo bulk, etc.): `container-fluid pmr-page-wide`. */
.pmr-page-wide.container-fluid {
    max-width: none !important;
}

/* Cartões compactos (participante / grupo bulk); evita repetir em cada template. */
.pmr-card-tight .card-header {
    padding: 0.85rem 1.1rem;
}
.pmr-card-tight .card-body {
    padding: 1rem 1.1rem;
}

/* Acções em tabela: botão / link só com ícone (texto em .sr-only + title). */
.connect-container .btn.ec-btn-icon-only,
.connect-container a.btn.ec-btn-icon-only {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.28rem 0.45rem;
    min-width: 2.05rem;
    line-height: 1;
}
.connect-container .btn.btn-sm.ec-btn-icon-only,
.connect-container a.btn.btn-sm.ec-btn-icon-only {
    padding: 0.22rem 0.4rem;
    min-width: 1.95rem;
}
.connect-container .btn.ec-btn-icon-only .material-icons-outlined,
.connect-container a.btn.ec-btn-icon-only .material-icons-outlined {
    font-size: 18px;
    line-height: 1;
}

/* Texto extra só para pesquisa (DataTables / Ctrl+F); não ocupa espaço visual. */
.ec-dt-search-bundle {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/*
 * Raiz: connect.css define html, body { height: 100% } e html { overflow-x: hidden }.
 * Com isso, em alguns motores surgem dois scrollbars verticais (viewport + body).
 * Deixar o body com altura automática e overflow visível concentra o scroll no html.
 */
body {
    height: auto;
    min-height: 100vh;
    overflow: visible;
}

/*
 * Barra lateral: o tema usa float nos ícones; com marca em duas palavras
 * ("Event Manager") o texto colidia com os botões. Grid alinha tudo.
 */
.page-sidebar .logo-box {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 0.5rem;
    row-gap: 0.15rem;
    padding: 12px 16px;
}

.page-sidebar .logo-box a.logo-text {
    grid-column: 1;
    grid-row: 1;
    float: none !important;
    margin: 0 !important;
    font-size: 1.05rem;
    line-height: 1.25;
    font-weight: 700;
    text-transform: none;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: break-word;
    hyphens: auto;
}

.page-sidebar .logo-box a#sidebar-close,
.page-sidebar .logo-box a#sidebar-state {
    float: none !important;
    margin: 0 !important;
    line-height: 1;
    align-self: start;
    padding-top: 2px;
}

/* Desktop: só o toggle compacto (o tema esconde #sidebar-close) */
@media (min-width: 1200px) {
    .page-sidebar .logo-box a#sidebar-close {
        display: none;
    }

    .page-sidebar .logo-box a#sidebar-state {
        grid-column: 2;
        grid-row: 1;
    }
}

/* Ecrã estreito: só fechar sidebar (o tema esconde #sidebar-state) */
@media (max-width: 1199.98px) {
    .page-sidebar .logo-box a#sidebar-state {
        display: none;
    }

    .page-sidebar .logo-box a#sidebar-close {
        grid-column: 2;
        grid-row: 1;
    }
}

/* Sidebar compacta (desktop): só ícone — alinhado ao connect.min */
@media (min-width: 1200px) {
    .compact-sidebar .page-sidebar .logo-box {
        display: block;
        text-align: center;
        padding: 15px 12px;
    }

    .compact-sidebar .page-sidebar .logo-box a.logo-text {
        display: none;
    }

    .compact-sidebar .page-sidebar .logo-box a#sidebar-state {
        display: block;
        float: none !important;
        margin: 0 auto !important;
        padding-top: 0;
    }

    .compact-sidebar .page-sidebar .logo-box a#sidebar-close {
        display: none !important;
    }
}

.ec-audit-table thead th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-weight: 600;
    color: #6c757d;
    white-space: nowrap;
}

body.dark-theme .ec-audit-table thead th {
    color: #9aa7bc;
}

/* ----- Select2: alinhar ao tema Event Manager (sobrepor connect.min + plugin) ----- */
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #4faa53 !important;
    color: #fff !important;
}

/* Por cima de .dark-theme .select2-results__option--highlighted (dark_theme.css) */
body.dark-theme .select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #4faa53 !important;
    color: #fff !important;
}

body:not(.dark-theme) .select2-container--default .select2-results__option[aria-selected="true"] {
    background-color: #e9f5ea !important;
    color: #1e2329 !important;
}

body.dark-theme .select2-container--default .select2-results__option[aria-selected="true"] {
    background-color: #2a3340 !important;
    color: #e8eef7 !important;
}

/* Caixa single/multiple: cantos em cápsula (2rem, como .connect-container .btn); cores alinhadas a .form-control */
body:not(.dark-theme) .select2-container--default .select2-selection--single,
body:not(.dark-theme) .select2-container--default .select2-selection--multiple {
    border: 1px solid #ced4da !important;
    border-radius: 2rem !important;
    min-height: calc(1.5em + 0.75rem + 2px) !important;
    padding: 0 !important;
    box-shadow: none !important;
    background-color: #fff !important;
}

body.dark-theme .select2-container--default .select2-selection--single,
body.dark-theme .select2-container--default .select2-selection--multiple {
    border: 1px solid #404652 !important;
    border-radius: 2rem !important;
    min-height: calc(1.5em + 0.75rem + 2px) !important;
    padding: 0 !important;
    box-shadow: none !important;
    background-color: #1f2128 !important;
}

body:not(.dark-theme) .select2-container--default.select2-container--focus .select2-selection--single,
body:not(.dark-theme) .select2-container--default.select2-container--focus .select2-selection--multiple,
body:not(.dark-theme) .select2-container--default.select2-container--open .select2-selection--single,
body:not(.dark-theme) .select2-container--default.select2-container--open .select2-selection--multiple {
    border-color: rgba(79, 170, 83, 0.6) !important;
    box-shadow: 0 0 0 0.2rem rgba(79, 170, 83, 0.25) !important;
}

body.dark-theme .select2-container--default.select2-container--focus .select2-selection--single,
body.dark-theme .select2-container--default.select2-container--focus .select2-selection--multiple,
body.dark-theme .select2-container--default.select2-container--open .select2-selection--single,
body.dark-theme .select2-container--default.select2-container--open .select2-selection--multiple {
    border-color: rgba(95, 208, 165, 0.6) !important;
    box-shadow: 0 0 0 0.2rem rgba(95, 208, 165, 0.25) !important;
    background-color: #282a33 !important;
}

/* Single: flex para centrar texto e seta verticalmente (evita rendered “desalinhado”) */
.select2-container--default .select2-selection--single {
    display: flex !important;
    align-items: center !important;
}

body:not(.dark-theme) .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 0.75rem !important;
    padding-right: 2rem !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    line-height: 1.5 !important;
    font-weight: 400 !important;
    color: #1e2329 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
}

body.dark-theme .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 0.75rem !important;
    padding-right: 2rem !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    line-height: 1.5 !important;
    font-weight: 400 !important;
    color: #e8eef4 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 1.25rem !important;
    right: 0.5rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin-top: 0 !important;
}

/* Múltiplo: layout flex; padding alinhado a .form-control */
.select2-container--default .select2-selection--multiple .select2-selection__rendered {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0.25rem !important;
    padding: 0.25rem 0.5rem !important;
    margin: 0 !important;
}

.select2-container--default .select2-selection--multiple .select2-search--inline {
    flex: 1 0 5rem;
    min-width: 3rem;
}

.select2-container--default .select2-selection--multiple .select2-search--inline .select2-search__field {
    margin-top: 0 !important;
    padding: 0.15rem 0 !important;
    font-weight: 400 !important;
}

body.dark-theme .select2-container--default .select2-selection--multiple .select2-search--inline .select2-search__field {
    color: #dbe4f2 !important;
}

body:not(.dark-theme) .select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: #e9ecef !important;
    border: 1px solid #ced4da !important;
    color: #495057 !important;
    border-radius: 9999px !important;
    padding: 0.1rem 0.35rem 0.1rem 0.3rem !important;
    margin: 0 !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    height: auto !important;
    max-width: 100%;
}

body:not(.dark-theme) .select2-container--default .select2-selection__choice__remove {
    color: #6c757d !important;
    margin-right: 0.2rem !important;
    font-weight: 600 !important;
}

body:not(.dark-theme) .select2-container--default .select2-selection__choice__remove:hover {
    color: #c0392b !important;
}

body.dark-theme .select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: #2c3038 !important;
    border: 1px solid #404652 !important;
    color: #dde4ee !important;
    border-radius: 9999px !important;
    padding: 0.1rem 0.35rem 0.1rem 0.3rem !important;
    margin: 0 !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    height: auto !important;
    max-width: 100%;
}

body.dark-theme .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: #9aa7bc !important;
    margin-right: 0.2rem !important;
}

body.dark-theme .select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
    color: #ff8a80 !important;
}

/* Dropdown e pesquisa (modo claro): alinhar a inputs */
body:not(.dark-theme) .select2-dropdown {
    border: 1px solid #ced4da !important;
    border-radius: 1rem !important;
    padding: 0.25rem 0 !important;
    box-shadow: 0 0.125rem 0.25rem rgba(31, 45, 61, 0.08) !important;
}

body:not(.dark-theme) .select2-search--dropdown {
    padding: 0.35rem 0.5rem !important;
}

body:not(.dark-theme) .select2-search--dropdown .select2-search__field {
    border: 1px solid #ced4da !important;
    border-radius: 2rem !important;
    padding: 0.375rem 0.75rem !important;
    font-weight: 400 !important;
    background-color: #fff !important;
    color: #1e2329 !important;
}

body.dark-theme .select2-search--dropdown .select2-search__field {
    border-radius: 2rem !important;
    border: 1px solid #404652 !important;
    background-color: #1f2128 !important;
    color: #e8eef4 !important;
}

body.dark-theme .select2-search--dropdown .select2-search__field:focus {
    border-color: rgba(95, 208, 165, 0.6) !important;
    box-shadow: 0 0 0 0.2rem rgba(95, 208, 165, 0.25) !important;
    outline: none !important;
}

/* Aviso de cookies / RGPD (preferência em localStorage) */
.ec-cookie-banner {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2000;
    background: rgba(28, 28, 39, 0.97);
    color: #e8ecf2;
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.22);
}
.ec-cookie-banner-inner {
    max-width: 1200px;
    margin: 0 auto;
}
.ec-cookie-banner a:not(.btn) {
    color: #9dd3ff;
}
.ec-cookie-banner .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.45);
    color: #fff;
}
.page-footer .footer-legal-links a,
.portal-cred-footer .footer-legal-links a,
.op-kiosk-footer .footer-legal-links a {
    white-space: nowrap;
}

/* Matriz dias de acesso: scroll vertical + coluna participante fixa ao scroll horizontal */
.access-days-table-wrap {
    overflow-x: auto;
    overflow-y: auto;
    max-height: min(70vh, 640px);
    -webkit-overflow-scrolling: touch;
}
.access-days-src-badges {
    line-height: 1.35;
}
.access-days-matrix .access-days-src-badge {
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.12em 0.35em;
    vertical-align: middle;
}

.access-days-matrix {
    border-collapse: separate;
    border-spacing: 0;
}
.access-days-matrix thead tr th:not(.access-days-col--sticky) {
    position: sticky;
    top: 0;
    z-index: 3;
    background: #e9ecef;
    box-shadow: 0 1px 0 0 rgba(0, 0, 0, 0.06);
}
.access-days-matrix th.access-days-col--sticky,
.access-days-matrix td.access-days-col--sticky {
    position: sticky;
    left: 0;
    z-index: 2;
    background: #fff;
    box-shadow: 4px 0 10px -6px rgba(0, 0, 0, 0.22);
    max-width: 12rem;
    min-width: 8rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.access-days-matrix thead th.access-days-col--sticky {
    top: 0;
    z-index: 5;
    background: #e9ecef;
    box-shadow:
        4px 0 10px -6px rgba(0, 0, 0, 0.22),
        0 1px 0 0 rgba(0, 0, 0, 0.06);
}
.access-days-matrix .access-days-cell-btn {
    min-width: 2.5rem;
    padding: 0.15rem 0.3rem;
    font-size: 0.72rem;
    line-height: 1.25;
}
.access-days-matrix.table-hover tbody tr:hover td.access-days-col--sticky {
    background: #f1f3f5;
}
body.dark-theme .access-days-matrix.table-hover tbody tr:hover td.access-days-col--sticky {
    background: #323842;
}
body.dark-theme .access-days-matrix th.access-days-col--sticky,
body.dark-theme .access-days-matrix td.access-days-col--sticky {
    background: #272b33;
    box-shadow: 4px 0 12px -4px rgba(0, 0, 0, 0.65);
}
body.dark-theme .access-days-matrix thead th.access-days-col--sticky {
    background: #272b33;
    border-color: #3c4554 !important;
}
body.dark-theme .access-days-matrix thead tr th:not(.access-days-col--sticky) {
    background: #272b33;
    box-shadow: 0 1px 0 0 rgba(0, 0, 0, 0.35);
}

/*
 * Cabeçalho “hero” dos cartões (lista de eventos, fichas, matrizes, etc.).
 * Usar: class="card-header ec-card-header-hero border-0 py-3" (e variantes --compact / --split).
 */
.connect-container .ec-card-header-hero {
    background: linear-gradient(
        180deg,
        rgba(95, 208, 165, 0.1) 0%,
        rgba(95, 208, 165, 0.02) 100%
    );
    border: 0 !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
    position: relative;
    /* Connect: .card .card-header força uppercase e 12px; nos heros usamos título + subtítulo em caixa normal */
    text-transform: none;
    font-size: inherit;
    font-weight: normal;
    font-family: inherit;
    letter-spacing: normal;
    color: inherit;
}

.connect-container .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap)) {
    padding-left: 4rem !important;
}

.connect-container .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap))::before {
    content: "event_available";
    font-family: "Material Icons Outlined";
    font-weight: normal;
    font-style: normal;
    font-size: 20px;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    background: rgba(79, 170, 83, 0.16);
    color: #2f7f37;
}
body.dark-theme .connect-container .ec-card-header-hero {
    background: linear-gradient(180deg, rgba(95, 208, 165, 0.14) 0%, rgba(95, 208, 165, 0.04) 100%);
    border-bottom-color: #404652 !important;
}
body.dark-theme .connect-container .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap))::before {
    background: rgba(95, 208, 165, 0.2);
    color: #7edb98;
}

/* Cabeçalhos de cartão = mesma família que .ec-participant-sections (índigo) / .ec-group-sections (laranja) */
.connect-container .page-body:has(.ec-participant-sections) .ec-card-header-hero {
    background: linear-gradient(180deg, rgba(92, 107, 192, 0.12) 0%, rgba(121, 134, 203, 0.05) 100%) !important;
    border-bottom-color: rgba(92, 107, 192, 0.2) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap))::before {
    background: rgba(92, 107, 192, 0.2) !important;
    color: #283593 !important;
}
.connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .h5,
.connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero h5 {
    color: #283593 !important;
}
.connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .text-muted {
    color: #5c6b8a !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-card-header-hero {
    background: linear-gradient(180deg, rgba(121, 134, 203, 0.18) 0%, rgba(92, 107, 192, 0.06) 100%) !important;
    border-bottom-color: rgba(129, 140, 220, 0.28) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap))::before {
    background: rgba(121, 134, 203, 0.26) !important;
    color: #c5ccff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .h5,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero h5 {
    color: #e8ecff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .text-muted {
    color: #aeb8de !important;
}
.connect-container .page-body:has(.ec-participant-sections) .ec-card-header-hero__icon-wrap,
.connect-container .page-body:has(.ec-participant-sections) .ec-access-days-matrix-card__icon-wrap {
    background: rgba(92, 107, 192, 0.22) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-card-header-hero__icon-wrap,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-access-days-matrix-card__icon-wrap {
    background: rgba(121, 134, 203, 0.26) !important;
}

.connect-container .page-body:has(.ec-group-sections) .ec-card-header-hero {
    background: linear-gradient(180deg, rgba(253, 126, 20, 0.14) 0%, rgba(245, 124, 0, 0.05) 100%) !important;
    border-bottom-color: rgba(234, 88, 12, 0.22) !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap))::before {
    background: rgba(234, 88, 12, 0.26) !important;
    color: #c2410c !important;
}
.connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .h5,
.connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero h5 {
    color: #9a3412 !important;
}
.connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .text-muted {
    color: #b45309 !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-card-header-hero {
    background: linear-gradient(180deg, rgba(251, 146, 60, 0.22) 0%, rgba(251, 146, 60, 0.07) 100%) !important;
    border-bottom-color: rgba(251, 146, 60, 0.32) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-card-header-hero:not(:has(.ec-card-header-hero__icon-wrap))::before {
    background: rgba(251, 146, 60, 0.32) !important;
    color: #ffedd5 !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .h5,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero h5 {
    color: #fff7ed !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .text-muted {
    color: #fdba74 !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-card-header-hero__icon-wrap,
.connect-container .page-body:has(.ec-group-sections) .ec-access-days-matrix-card__icon-wrap {
    background: rgba(200, 96, 61, 0.22) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-card-header-hero__icon-wrap,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-access-days-matrix-card__icon-wrap {
    background: rgba(232, 130, 88, 0.28) !important;
}

/* Secções de evento: unificar look de tabelas (light/dark) */
.connect-container .page-body:has(.ec-event-sections) .table thead th,
.connect-container .page-body:has(.ec-event-sections) .ec-datatable thead th,
.connect-container .page-body:has(.ec-event-sections) .thead-light th {
    background: #f4faf7 !important;
    color: #2f6f53 !important;
    border-bottom-color: rgba(79, 170, 83, 0.22) !important;
}
.connect-container .page-body:has(.ec-event-sections) .table-hover tbody tr:hover td,
.connect-container .page-body:has(.ec-event-sections) .ec-datatable tbody tr:hover td {
    background: rgba(79, 170, 83, 0.06) !important;
}
.connect-container .page-body:has(.ec-event-sections) .table td,
.connect-container .page-body:has(.ec-event-sections) .table th {
    border-top-color: rgba(47, 111, 83, 0.1);
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .table thead th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .ec-datatable thead th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .thead-light th {
    background: #25332c !important;
    color: #a7e5c9 !important;
    border-bottom-color: rgba(95, 208, 165, 0.3) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .table-hover tbody tr:hover td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .ec-datatable tbody tr:hover td {
    background: rgba(95, 208, 165, 0.12) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .table td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections) .table th {
    border-top-color: rgba(95, 208, 165, 0.18);
}

/* Participante: a faixa tem .ec-event-sections + .ec-participant-sections; as regras de evento acima
   pintam tabelas de verde — repor tom índigo (coerente com .ec-card-header-hero do participante). */
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table thead th,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable thead th,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable thead th,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable thead td,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .thead-light th {
    background: #eef0fb !important;
    color: #303f7b !important;
    border-bottom-color: rgba(92, 107, 192, 0.26) !important;
}
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table-hover tbody tr:hover td,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable tbody tr:hover td,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable.table-hover tbody tr:hover > td {
    background: rgba(92, 107, 192, 0.07) !important;
}
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table td,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table th,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable td,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable th,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable td,
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable th {
    border-top-color: rgba(92, 107, 192, 0.12);
}
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table-wrap {
    border-color: rgba(92, 107, 192, 0.18);
    background: #fbfcff;
}
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table thead th {
    background: #eef0fb !important;
    color: #303f7b !important;
    box-shadow: 0 1px 0 rgba(92, 107, 192, 0.1);
}
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table td.font-weight-medium {
    color: #303f7b;
}
.connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .table-striped tbody tr:nth-of-type(odd) {
    background: rgba(92, 107, 192, 0.035);
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table thead th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable thead th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable thead th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable thead td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .thead-light th {
    background: #252a3a !important;
    color: #c5ccff !important;
    border-bottom-color: rgba(129, 140, 220, 0.32) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table-hover tbody tr:hover td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable tbody tr:hover td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable.table-hover tbody tr:hover > td {
    background: rgba(121, 134, 203, 0.14) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .table th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-datatable th,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable td,
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) table.dataTable th {
    border-top-color: rgba(129, 140, 220, 0.2);
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table-wrap {
    border-color: rgba(129, 140, 220, 0.28);
    background: #1c1f2a;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table thead th {
    background: #252a3a !important;
    color: #c5ccff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table td.font-weight-medium {
    color: #e8ecff;
}
body.dark-theme .connect-container .page-body:has(.ec-event-sections):has(.ec-participant-sections) .ec-pzones-page .table-striped tbody tr:nth-of-type(odd) {
    background: rgba(0, 0, 0, 0.06);
}

/* Grupo: o mesmo page-body contém .ec-event-sections (faixa de navegação) e .ec-group-sections;
   as regras "evento" acima pintam tabelas de verde — repor tom laranja da secção de grupo. */
.connect-container .page-body:has(.ec-group-sections) .table thead th,
.connect-container .page-body:has(.ec-group-sections) .ec-datatable thead th,
.connect-container .page-body:has(.ec-group-sections) table.dataTable thead th,
.connect-container .page-body:has(.ec-group-sections) table.dataTable thead td,
.connect-container .page-body:has(.ec-group-sections) .thead-light th {
    background: #fff7ed !important;
    color: #9a3412 !important;
    border-bottom-color: rgba(234, 88, 12, 0.28) !important;
}
.connect-container .page-body:has(.ec-group-sections) .table-hover tbody tr:hover td,
.connect-container .page-body:has(.ec-group-sections) .ec-datatable tbody tr:hover td,
.connect-container .page-body:has(.ec-group-sections) table.dataTable.table-hover tbody tr:hover > td {
    background: rgba(253, 126, 20, 0.08) !important;
}
.connect-container .page-body:has(.ec-group-sections) .table td,
.connect-container .page-body:has(.ec-group-sections) .table th,
.connect-container .page-body:has(.ec-group-sections) .ec-datatable td,
.connect-container .page-body:has(.ec-group-sections) .ec-datatable th,
.connect-container .page-body:has(.ec-group-sections) table.dataTable td,
.connect-container .page-body:has(.ec-group-sections) table.dataTable th {
    border-top-color: rgba(234, 88, 12, 0.12);
}
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table td.font-weight-medium,
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table td.font-weight-medium a,
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table a.ec-gmp-name-link {
    color: #9a3412 !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member td {
    background: rgba(253, 126, 20, 0.09) !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member td.font-weight-medium,
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member td.font-weight-medium a,
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member a.ec-gmp-name-link {
    color: #7c2d12 !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-table-wrap {
    border-color: rgba(234, 88, 12, 0.22);
    background: #fffdfb;
}
.connect-container .page-body:has(.ec-group-sections) .ec-gmp-page .ec-gmp-table thead th {
    background: #fff7ed !important;
    color: #9a3412 !important;
    box-shadow: 0 1px 0 rgba(234, 88, 12, 0.12);
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .table thead th,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-datatable thead th,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) table.dataTable thead th,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) table.dataTable thead td,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .thead-light th {
    background: #2a231c !important;
    color: #ffedd5 !important;
    border-bottom-color: rgba(251, 146, 60, 0.35) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .table-hover tbody tr:hover td,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-datatable tbody tr:hover td,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) table.dataTable.table-hover tbody tr:hover > td {
    background: rgba(251, 146, 60, 0.12) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .table td,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .table th,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-datatable td,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-datatable th,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) table.dataTable td,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) table.dataTable th {
    border-top-color: rgba(251, 146, 60, 0.2);
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table td.font-weight-medium,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table td.font-weight-medium a,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table a.ec-gmp-name-link {
    color: #ffedd5 !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member td {
    background: rgba(251, 146, 60, 0.14) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member td.font-weight-medium,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member td.font-weight-medium a,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table tbody tr.is-member a.ec-gmp-name-link {
    color: #fff7ed !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-table-wrap {
    border-color: rgba(251, 146, 60, 0.32);
    background: #1f1c18;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-gmp-page .ec-gmp-table thead th {
    background: #2a231c !important;
    color: #ffedd5 !important;
    box-shadow: 0 1px 0 rgba(251, 146, 60, 0.2);
}

/* ec-pzones / ec-pprog: <style> inline ainda usava verde; alinhar ao contexto participante vs grupo */
.connect-container .page-body:has(.ec-participant-sections) .ec-pzones-page .ec-pzones-main-card > .card-header {
    background: linear-gradient(180deg, rgba(92, 107, 192, 0.12) 0%, rgba(121, 134, 203, 0.05) 100%) !important;
    border-bottom-color: rgba(92, 107, 192, 0.2) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-pzones-page .ec-pzones-main-card > .card-header {
    background: linear-gradient(180deg, rgba(121, 134, 203, 0.18) 0%, rgba(92, 107, 192, 0.06) 100%) !important;
    border-bottom-color: rgba(129, 140, 220, 0.28) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-pzones-page .ec-pzones-main-card > .card-header h5 {
    color: #e8ecff !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-pzones-page .ec-pzones-main-card > .card-header {
    background: linear-gradient(180deg, rgba(253, 126, 20, 0.14) 0%, rgba(245, 124, 0, 0.05) 100%) !important;
    border-bottom-color: rgba(234, 88, 12, 0.22) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-pzones-page .ec-pzones-main-card > .card-header {
    background: linear-gradient(180deg, rgba(251, 146, 60, 0.22) 0%, rgba(251, 146, 60, 0.07) 100%) !important;
    border-bottom-color: rgba(251, 146, 60, 0.32) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-pzones-page .ec-pzones-main-card > .card-header h5 {
    color: #fff7ed !important;
}
.connect-container .page-body:has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table tbody tr:hover {
    background: rgba(92, 107, 192, 0.06);
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-pzones-page .ec-pzones-table tbody tr:hover {
    background: rgba(92, 107, 192, 0.1) !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-pzones-page .ec-pzones-table tbody tr:hover {
    background: rgba(253, 126, 20, 0.07);
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-pzones-page .ec-pzones-table tbody tr:hover {
    background: rgba(251, 146, 60, 0.12) !important;
}

.connect-container .page-body:has(.ec-participant-sections) .ec-pprog-page .ec-pprog-main-card > .card-header {
    background: linear-gradient(180deg, rgba(92, 107, 192, 0.12) 0%, rgba(121, 134, 203, 0.05) 100%) !important;
    border-bottom-color: rgba(92, 107, 192, 0.2) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-pprog-page .ec-pprog-main-card > .card-header {
    background: linear-gradient(180deg, rgba(121, 134, 203, 0.18) 0%, rgba(92, 107, 192, 0.06) 100%) !important;
    border-bottom-color: rgba(129, 140, 220, 0.28) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-pprog-page .ec-pprog-main-card > .card-header h5 {
    color: #e8ecff !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-pprog-page .ec-pprog-main-card > .card-header {
    background: linear-gradient(180deg, rgba(253, 126, 20, 0.14) 0%, rgba(245, 124, 0, 0.05) 100%) !important;
    border-bottom-color: rgba(234, 88, 12, 0.22) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-pprog-page .ec-pprog-main-card > .card-header {
    background: linear-gradient(180deg, rgba(251, 146, 60, 0.22) 0%, rgba(251, 146, 60, 0.07) 100%) !important;
    border-bottom-color: rgba(251, 146, 60, 0.32) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-pprog-page .ec-pprog-main-card > .card-header h5 {
    color: #fff7ed !important;
}
.connect-container .page-body:has(.ec-participant-sections) .ec-pprog-page .ec-pprog-table tbody tr:hover {
    background: rgba(92, 107, 192, 0.06);
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .ec-pprog-page .ec-pprog-table tbody tr:hover {
    background: rgba(92, 107, 192, 0.1) !important;
}
.connect-container .page-body:has(.ec-group-sections) .ec-pprog-page .ec-pprog-table tbody tr:hover {
    background: rgba(253, 126, 20, 0.07);
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .ec-pprog-page .ec-pprog-table tbody tr:hover {
    background: rgba(251, 146, 60, 0.12) !important;
}

#participant-stay-assignment .ec-stay-needs-scroll .ec-stay-sticky-thead th {
    color: #283593 !important;
    background: rgba(92, 107, 192, 0.1) !important;
    box-shadow: 0 1px 0 rgba(92, 107, 192, 0.22) !important;
}
body.dark-theme #participant-stay-assignment .ec-stay-needs-scroll .ec-stay-sticky-thead th {
    color: #e8ecff !important;
    background: rgba(36, 38, 52, 0.88) !important;
    box-shadow: 0 1px 0 rgba(129, 140, 220, 0.28) !important;
}

#group-stay-assignment .ec-stay-needs-table thead .ec-stay-group-th-group {
    color: #c2410c !important;
    background: rgba(253, 126, 20, 0.1) !important;
}
#group-stay-assignment .ec-stay-needs-table thead tr.ec-stay-group-subhead th {
    color: #9a3412 !important;
    background: rgba(253, 126, 20, 0.06) !important;
}
body.dark-theme #group-stay-assignment .ec-stay-needs-table thead .ec-stay-group-th-group {
    color: #fdba74 !important;
    background: rgba(251, 146, 60, 0.14) !important;
}
body.dark-theme #group-stay-assignment .ec-stay-needs-table thead tr.ec-stay-group-subhead th {
    color: #fed7aa !important;
    background: rgba(251, 146, 60, 0.1) !important;
}

.connect-container .ec-card-header-hero.ec-card-header-hero--split.border-top {
    border-top: 1px solid rgba(0, 0, 0, 0.07) !important;
}
body.dark-theme .connect-container .ec-card-header-hero.ec-card-header-hero--split.border-top {
    border-top-color: rgba(255, 255, 255, 0.1) !important;
}

/* Ações nos headers hero: padrão consistente e texto em maiúsculas */
.connect-container .card-header.ec-card-header-hero .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-weight: 600;
    white-space: nowrap;
}

/* Paleta padrão dos botões de ações em headers hero (como no template de Programas) */
.connect-container .card-header.ec-card-header-hero .btn[class*="btn-outline-"] {
    color: #6c757d;
    border-color: #6c757d;
    background: transparent;
}

.connect-container .card-header.ec-card-header-hero .btn[class*="btn-outline-"]:hover,
.connect-container .card-header.ec-card-header-hero .btn[class*="btn-outline-"]:focus {
    color: #fff;
    border-color: #6c757d;
    background: #6c757d;
}

.connect-container .card-header.ec-card-header-hero .btn.btn-primary {
    background: #4faa53 !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}

.connect-container .card-header.ec-card-header-hero .btn.btn-primary:hover,
.connect-container .card-header.ec-card-header-hero .btn.btn-primary:focus {
    background: #3d8f42 !important;
    border-color: #3d8f42 !important;
    color: #fff !important;
}

body.dark-theme .connect-container .card-header.ec-card-header-hero .btn[class*="btn-outline-"] {
    color: #cfd5e0;
    border-color: #5c6575;
    background: transparent;
}

body.dark-theme .connect-container .card-header.ec-card-header-hero .btn[class*="btn-outline-"]:hover,
body.dark-theme .connect-container .card-header.ec-card-header-hero .btn[class*="btn-outline-"]:focus {
    color: #0f1720;
    border-color: #cfd5e0;
    background: #cfd5e0;
}

body.dark-theme .connect-container .card-header.ec-card-header-hero .btn.btn-primary {
    background: #2d8a5e !important;
    border-color: #2d8a5e !important;
    color: #fff !important;
}

body.dark-theme .connect-container .card-header.ec-card-header-hero .btn.btn-primary:hover,
body.dark-theme .connect-container .card-header.ec-card-header-hero .btn.btn-primary:focus {
    background: #3aa672 !important;
    border-color: #3aa672 !important;
    color: #fff !important;
}

/*
 * Backoffice geral (lista de eventos vazia, CTAs em .page-body, etc.): primário = verde da marca,
 * não o azul por defeito do Bootstrap. Páginas participante/grupo redefinem com :has(...) mais abaixo.
 */
.connect-container .page-body .btn.btn-primary,
.connect-container .page-body a.btn.btn-primary {
    background: #4faa53 !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}

.connect-container .page-body .btn.btn-primary:hover,
.connect-container .page-body .btn.btn-primary:focus,
.connect-container .page-body a.btn.btn-primary:hover,
.connect-container .page-body a.btn.btn-primary:focus {
    background: #3d8f42 !important;
    border-color: #3d8f42 !important;
    color: #fff !important;
}

.connect-container .page-body .btn-outline-primary,
.connect-container .page-body a.btn-outline-primary {
    color: #4faa53 !important;
    border-color: #4faa53 !important;
    background: transparent !important;
}

.connect-container .page-body .btn-outline-primary:hover,
.connect-container .page-body .btn-outline-primary:focus,
.connect-container .page-body a.btn-outline-primary:hover,
.connect-container .page-body a.btn-outline-primary:focus {
    color: #fff !important;
    border-color: #4faa53 !important;
    background: #4faa53 !important;
}

body.dark-theme .connect-container .page-body .btn.btn-primary,
body.dark-theme .connect-container .page-body a.btn.btn-primary {
    background: #2d8a5e !important;
    border-color: #2d8a5e !important;
    color: #fff !important;
}

body.dark-theme .connect-container .page-body .btn.btn-primary:hover,
body.dark-theme .connect-container .page-body .btn.btn-primary:focus,
body.dark-theme .connect-container .page-body a.btn.btn-primary:hover,
body.dark-theme .connect-container .page-body a.btn.btn-primary:focus {
    background: #3aa672 !important;
    border-color: #3aa672 !important;
    color: #fff !important;
}

body.dark-theme .connect-container .page-body .btn-outline-primary,
body.dark-theme .connect-container .page-body a.btn-outline-primary {
    color: #5fd0a5 !important;
    border-color: #5fd0a5 !important;
    background: transparent !important;
}

body.dark-theme .connect-container .page-body .btn-outline-primary:hover,
body.dark-theme .connect-container .page-body .btn-outline-primary:focus,
body.dark-theme .connect-container .page-body a.btn-outline-primary:hover,
body.dark-theme .connect-container .page-body a.btn-outline-primary:focus {
    color: #0f1720 !important;
    border-color: #5fd0a5 !important;
    background: #5fd0a5 !important;
}

/*
 * Secção participante / grupo: botões «cor principal» (primary, outline-primary, success em CTAs)
 * deixam de usar o verde-teal global do Connect — índigo vs laranja, alinhado às barras de secção.
 */
.connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn.btn-primary {
    color: #fff !important;
    background: linear-gradient(90deg, #3949ab 0%, #5c6bc0 48%, #7986cb 100%) !important;
    border-color: transparent !important;
    box-shadow: none;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-primary:before,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn-primary:before {
    background: linear-gradient(90deg, #303f9f 0%, #4a57b8 48%, #6574c4 100%) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary:focus,
.connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary.active,
.connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary:active,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn.btn-primary:focus,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn.btn-primary.active,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn.btn-primary:active {
    box-shadow: 0 0 0 0.2rem rgba(92, 107, 192, 0.35) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-primary:not(:disabled):not(.disabled):active:focus,
.connect-container .page-body:has(.ec-participant-sections) .btn-primary:not(:disabled):not(.disabled).active:focus,
.connect-container .page-body:has(.ec-participant-sections) .show > .btn-primary.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(92, 107, 192, 0.45) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-outline-primary {
    color: #3949ab !important;
    border-color: #5c6bc0 !important;
    background: transparent !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-outline-primary:hover,
.connect-container .page-body:has(.ec-participant-sections) .btn-outline-primary:focus {
    color: #fff !important;
    background: #5c6bc0 !important;
    border-color: #5c6bc0 !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-success,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn-success {
    color: #fff !important;
    background: linear-gradient(90deg, #3949ab 0%, #5c6bc0 48%, #6f7dd2 100%) !important;
    border-color: transparent !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-success:before,
.connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn-success:before {
    background: linear-gradient(90deg, #303f9f 0%, #4a57b8 48%, #5c6bc0 100%) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .btn-success:hover,
.connect-container .page-body:has(.ec-participant-sections) .btn-success:focus {
    color: #fff !important;
    background: linear-gradient(90deg, #303f9f 0%, #4a57b8 52%, #5c6bc0 100%) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .btn.btn-primary {
    background: linear-gradient(90deg, #3949ab 0%, #5c6bc0 48%, #7986cb 100%) !important;
    border-color: transparent !important;
}
.connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .btn.btn-primary:hover,
.connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .btn.btn-primary:focus {
    background: linear-gradient(90deg, #303f9f 0%, #4a57b8 52%, #6574c4 100%) !important;
    border-color: transparent !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn.btn-primary {
    background: linear-gradient(90deg, #5c6bc0 0%, #6a77c9 48%, #7e8ce0 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-primary:before,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn-primary:before {
    background: linear-gradient(90deg, #4a57b8 0%, #5c6bc0 48%, #6d7bc8 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary:focus,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary.active,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn.btn-primary:active,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn.btn-primary:focus {
    box-shadow: 0 0 0 0.2rem rgba(159, 168, 218, 0.45) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-outline-primary {
    color: #c5ccff !important;
    border-color: #9fa8da !important;
    background: transparent !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-outline-primary:hover,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-outline-primary:focus {
    color: #0f1720 !important;
    background: #c5ccff !important;
    border-color: #c5ccff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-success,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn-success {
    background: linear-gradient(90deg, #5c6bc0 0%, #6a77c9 52%, #7e8ce0 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-success:before,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .btn-group > .btn-success:before {
    background: linear-gradient(90deg, #4a57b8 0%, #5c6bc0 52%, #6d7bc8 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .btn.btn-primary {
    background: linear-gradient(90deg, #5c6bc0 0%, #6a77c9 52%, #7e8ce0 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .btn.btn-primary:hover,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .card-header.ec-card-header-hero .btn.btn-primary:focus {
    background: linear-gradient(90deg, #4a57b8 0%, #5c6bc0 52%, #6d7bc8 100%) !important;
}

.connect-container .page-body:has(.ec-group-sections) .btn.btn-primary,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn.btn-primary {
    color: #fff !important;
    background: linear-gradient(90deg, #ea580c 0%, #f97316 48%, #fb923c 100%) !important;
    border-color: transparent !important;
    box-shadow: none;
}
.connect-container .page-body:has(.ec-group-sections) .btn-primary:before,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn-primary:before {
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 48%, #f97316 100%) !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn.btn-primary:focus,
.connect-container .page-body:has(.ec-group-sections) .btn.btn-primary.active,
.connect-container .page-body:has(.ec-group-sections) .btn.btn-primary:active,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn.btn-primary:focus,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn.btn-primary.active,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn.btn-primary:active {
    box-shadow: 0 0 0 0.2rem rgba(249, 115, 22, 0.38) !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-primary:not(:disabled):not(.disabled):active:focus,
.connect-container .page-body:has(.ec-group-sections) .btn-primary:not(:disabled):not(.disabled).active:focus,
.connect-container .page-body:has(.ec-group-sections) .show > .btn-primary.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(234, 88, 12, 0.5) !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-outline-primary {
    color: #c2410c !important;
    border-color: #ea580c !important;
    background: transparent !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-outline-primary:hover,
.connect-container .page-body:has(.ec-group-sections) .btn-outline-primary:focus {
    color: #fff !important;
    background: #ea580c !important;
    border-color: #ea580c !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-success,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn-success {
    color: #fff !important;
    background: linear-gradient(90deg, #ea580c 0%, #f97316 48%, #fb923c 100%) !important;
    border-color: transparent !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-success:before,
.connect-container .page-body:has(.ec-group-sections) .btn-group > .btn-success:before {
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 48%, #f97316 100%) !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-success:hover,
.connect-container .page-body:has(.ec-group-sections) .btn-success:focus {
    color: #fff !important;
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 52%, #f97316 100%) !important;
}
.connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .btn.btn-primary {
    background: linear-gradient(90deg, #ea580c 0%, #f97316 48%, #fb923c 100%) !important;
    border-color: transparent !important;
}
.connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .btn.btn-primary:hover,
.connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .btn.btn-primary:focus {
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 52%, #f97316 100%) !important;
    border-color: transparent !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn.btn-primary,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-group > .btn.btn-primary {
    background: linear-gradient(90deg, #ea580c 0%, #f97316 48%, #fdba74 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-primary:before,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-group > .btn-primary:before {
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 48%, #f97316 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn.btn-primary:focus,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn.btn-primary.active,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn.btn-primary:active,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-group > .btn.btn-primary:focus {
    box-shadow: 0 0 0 0.2rem rgba(251, 146, 60, 0.45) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-outline-primary {
    color: #fdba74 !important;
    border-color: #fb923c !important;
    background: transparent !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-outline-primary:hover,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-outline-primary:focus {
    color: #1a0f0f !important;
    background: #fdba74 !important;
    border-color: #fdba74 !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-success,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-group > .btn-success {
    background: linear-gradient(90deg, #ea580c 0%, #f97316 52%, #fb923c 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-success:before,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .btn-group > .btn-success:before {
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 52%, #f97316 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .btn.btn-primary {
    background: linear-gradient(90deg, #ea580c 0%, #f97316 52%, #fb923c 100%) !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .btn.btn-primary:hover,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .card-header.ec-card-header-hero .btn.btn-primary:focus {
    background: linear-gradient(90deg, #c2410c 0%, #ea580c 52%, #f97316 100%) !important;
}

.connect-container .page-body:has(.ec-participant-sections) .btn-success:focus,
.connect-container .page-body:has(.ec-participant-sections) .btn-success:active,
.connect-container .page-body:has(.ec-participant-sections) .btn-success.active {
    box-shadow: 0 0 0 0.2rem rgba(92, 107, 192, 0.35) !important;
}
.connect-container .page-body:has(.ec-group-sections) .btn-success:focus,
.connect-container .page-body:has(.ec-group-sections) .btn-success:active,
.connect-container .page-body:has(.ec-group-sections) .btn-success.active {
    box-shadow: 0 0 0 0.2rem rgba(249, 115, 22, 0.38) !important;
}
.connect-container .page-body:has(.ec-participant-sections) .badge-primary,
.connect-container .page-body:has(.ec-participant-sections) .badge.badge-primary {
    background-color: #5c6bc0 !important;
    color: #fff !important;
}
.connect-container .page-body:has(.ec-group-sections) .badge-primary,
.connect-container .page-body:has(.ec-group-sections) .badge.badge-primary {
    background-color: #ea580c !important;
    color: #fff !important;
}
/* Secção grupo: estado "activo" / sucesso em badges alinha ao laranja (evita verde Bootstrap). */
.connect-container .page-body:has(.ec-group-sections) .badge-success,
.connect-container .page-body:has(.ec-group-sections) .badge.badge-success {
    background-color: #ea580c !important;
    border-color: rgba(234, 88, 12, 0.35) !important;
    color: #fff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .badge-success,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .badge.badge-success {
    background-color: #ea580c !important;
    border-color: rgba(253, 186, 116, 0.35) !important;
    color: #fff !important;
}
.connect-container .page-body:has(.ec-participant-sections) a.text-primary,
.connect-container .page-body:has(.ec-participant-sections) .text-primary {
    color: #3949ab !important;
}
.connect-container .page-body:has(.ec-participant-sections) a.text-primary:hover,
.connect-container .page-body:has(.ec-participant-sections) a.text-primary:focus {
    color: #1a237e !important;
}
.connect-container .page-body:has(.ec-group-sections) a.text-primary,
.connect-container .page-body:has(.ec-group-sections) .text-primary {
    color: #c2410c !important;
}
.connect-container .page-body:has(.ec-group-sections) a.text-primary:hover,
.connect-container .page-body:has(.ec-group-sections) a.text-primary:focus {
    color: #9a3412 !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) a.text-primary,
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) .text-primary {
    color: #9fa8da !important;
}
body.dark-theme .connect-container .page-body:has(.ec-participant-sections) a.text-primary:hover {
    color: #e8ecff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) a.text-primary,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) .text-primary {
    color: #fdba74 !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) a.text-primary:hover {
    color: #ffedd5 !important;
}

/* Material icons usam ligaduras em minúsculas; manter sem transformação */
.connect-container .card-header.ec-card-header-hero .btn .material-icons,
.connect-container .card-header.ec-card-header-hero .btn .material-icons-outlined {
    text-transform: none;
    letter-spacing: normal;
}

.connect-container .ec-card-header-hero--compact {
    /* Mantém gradiente do .ec-card-header-hero; só ajusta densidade visual */
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
}
.ec-access-days-page .ec-access-days-bulk-card .card-header {
    font-size: 0.95rem;
    font-weight: 600;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    background: rgba(248, 249, 250, 0.95);
}
body.dark-theme .connect-container .ec-access-days-page .ec-access-days-bulk-card .card-header {
    background: rgba(39, 43, 51, 0.85);
    border-bottom-color: rgba(255, 255, 255, 0.08);
}
.ec-access-days-page .ec-access-days-bulk-card .card-body {
    padding: 1rem 1rem 1.1rem;
}
.ec-access-days-page .ec-access-days-matrix-card > .card-header.ec-card-header-hero,
.ec-access-days-page .ec-access-days-bulk-column > .card-header.ec-card-header-hero {
    min-height: 5rem;
    display: flex;
    align-items: center;
}
.ec-access-days-page .ec-access-days-search-panel {
    border-radius: 0.5rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(248, 249, 250, 0.65);
    padding: 1rem 1.1rem;
}
body.dark-theme .connect-container .ec-access-days-page .ec-access-days-search-panel {
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(39, 43, 51, 0.45);
}
.ec-access-days-page .ec-access-days-legend {
    border-radius: 0.45rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    background: rgba(255, 255, 255, 0.75);
    padding: 0.55rem 0.75rem;
}
body.dark-theme .connect-container .ec-access-days-page .ec-access-days-legend {
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(30, 33, 40, 0.55);
}
.ec-access-days-page .access-days-table-wrap {
    overflow-x: auto !important;
    overflow-y: visible !important;
    max-height: none !important;
    border-radius: 0.5rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: #fff;
}
body.dark-theme .connect-container .ec-access-days-page .access-days-table-wrap {
    border-color: rgba(255, 255, 255, 0.1);
    background: #1e2128;
}
.ec-access-days-page .access-days-matrix thead th {
    position: sticky;
    top: 0;
    z-index: 6;
}
.ec-access-days-page .dataTables_wrapper {
    margin-top: 0.75rem;
}
.ec-access-days-page .dataTables_wrapper .row:last-child {
    margin-top: 0.5rem;
    align-items: center;
}

/* Matriz dias de acesso: página ativa DataTables — verde da marca (evita azul Bootstrap) */
.connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link,
.connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active > a.page-link {
    background-color: #4faa53 !important;
    background-image: none !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}
.connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:hover,
.connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:focus {
    background-color: #3d9441 !important;
    border-color: #3d9441 !important;
    color: #fff !important;
}
body.dark-theme .connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link,
body.dark-theme .connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active > a.page-link {
    background: linear-gradient(90deg, #2d7a32 0%, #4faa53 48%, #45a649 100%) !important;
    border-color: #5fd0a5 !important;
    color: #fff !important;
}
body.dark-theme .connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:hover,
body.dark-theme .connect-container .ec-access-days-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:focus {
    background: #3d9441 !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}

/* Secção grupo (membros, etc.): paginação laranja */
.connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > .page-link,
.connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > a,
.connect-container .ec-gmp-page ul.pagination li.page-item.active > .page-link,
.connect-container .ec-gmp-page ul.pagination li.page-item.active > a {
    background-color: #ea580c !important;
    border-color: #c2410c !important;
    color: #fff !important;
}
.connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > .page-link:hover,
.connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > .page-link:focus,
.connect-container .ec-gmp-page ul.pagination li.page-item.active > .page-link:hover,
.connect-container .ec-gmp-page ul.pagination li.page-item.active > .page-link:focus {
    background-color: #c2410c !important;
    border-color: #9a3412 !important;
    color: #fff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > .page-link,
body.dark-theme .connect-container .ec-gmp-page ul.pagination li.page-item.active > .page-link {
    background-color: #ea580c !important;
    border-color: #fb923c !important;
    color: #fff !important;
}
body.dark-theme .connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > .page-link:hover,
body.dark-theme .connect-container .page-body:has(.ec-group-sections) ul.pagination li.page-item.active > .page-link:focus,
body.dark-theme .connect-container .ec-gmp-page ul.pagination li.page-item.active > .page-link:hover,
body.dark-theme .connect-container .ec-gmp-page ul.pagination li.page-item.active > .page-link:focus {
    background-color: #c2410c !important;
    border-color: #ea580c !important;
    color: #fff !important;
}

/* Lista de participantes: DataTables + BS4 usam .page-item.active .page-link; garantir verde da marca (admin3) por cima do azul Bootstrap */
.connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link,
.connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active > a.page-link {
    background-color: #4faa53 !important;
    background-image: none !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}
.connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:hover,
.connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:focus {
    background-color: #3d9441 !important;
    border-color: #3d9441 !important;
    color: #fff !important;
}
body.dark-theme .connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link,
body.dark-theme .connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active > a.page-link {
    background: linear-gradient(90deg, #2d7a32 0%, #4faa53 48%, #45a649 100%) !important;
    border-color: #5fd0a5 !important;
    color: #fff !important;
}
body.dark-theme .connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:hover,
body.dark-theme .connect-container .ec-ep-list-page .dataTables_wrapper ul.pagination li.page-item.active a.page-link:focus {
    background: #3d9441 !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}

/* Lista de participantes: tipografia do badge do atalho «por validar» */
.ec-ep-list-page .ec-ep-pending-review-link .badge {
    font-size: 0.7rem;
    font-weight: 600;
}

@media (min-width: 992px) {
    .ec-access-days-page .ec-access-days-bulk-column {
        position: sticky;
        top: 0.75rem;
        align-self: flex-start;
    }
}
.ec-card-header-hero__icon-wrap,
.ec-access-days-matrix-card__icon-wrap {
    width: 2.5rem;
    height: 2.5rem;
    flex-shrink: 0;
    background: rgba(95, 208, 165, 0.18);
}
.connect-container .ec-card-header-hero__icon-wrap .material-icons,
.connect-container .ec-card-header-hero__icon-wrap .material-icons-outlined,
.connect-container .ec-access-days-matrix-card__icon-wrap .material-icons,
.connect-container .ec-access-days-matrix-card__icon-wrap .material-icons-outlined {
    font-size: 20px !important;
}
body.dark-theme .connect-container .ec-card-header-hero__icon-wrap,
body.dark-theme .connect-container .ec-access-days-matrix-card__icon-wrap {
    background: rgba(95, 208, 165, 0.14);
}
/*
 * Select2 alinhado a .form-control-sm (altura / tipografia como inputs pequenos).
 * O Select2 insere o .select2-container imediatamente a seguir ao <select>.
 */
.connect-container select.form-control-sm + .select2-container .select2-selection--single,
.connect-container select.form-control-sm + .select2-container .select2-selection--multiple {
    min-height: calc(1.5em + 0.5rem + 2px) !important;
    border-radius: 2rem !important;
    border: 1px solid #ced4da !important;
    background-color: #fff !important;
}

body.dark-theme .connect-container select.form-control-sm + .select2-container .select2-selection--single,
body.dark-theme .connect-container select.form-control-sm + .select2-container .select2-selection--multiple {
    border-color: #404652 !important;
    background-color: #1f2128 !important;
}

.connect-container select.form-control-sm + .select2-container .select2-selection--single .select2-selection__rendered {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    padding-left: 0.5rem !important;
    padding-right: 2rem !important;
}

.connect-container select.form-control-sm + .select2-container .select2-selection--multiple .select2-selection__rendered {
    font-size: 0.875rem !important;
    padding: 0.2rem 0.35rem !important;
}

.connect-container select.form-control-sm + .select2-container .select2-selection--multiple .select2-selection__choice {
    font-size: 0.8125rem !important;
}

body.dark-theme .connect-container select.form-control-sm + .select2-container .select2-selection--single .select2-selection__rendered {
    color: #e8ecf4 !important;
}

.connect-container select.form-control:not(.form-control-sm) + .select2-container .select2-selection--single,
.connect-container select.form-control:not(.form-control-sm) + .select2-container .select2-selection--multiple {
    min-height: calc(1.5em + 0.75rem + 2px) !important;
    border-radius: 2rem !important;
    border: 1px solid #ced4da !important;
    background-color: #fff !important;
}

body.dark-theme .connect-container select.form-control:not(.form-control-sm) + .select2-container .select2-selection--single,
body.dark-theme .connect-container select.form-control:not(.form-control-sm) + .select2-container .select2-selection--multiple {
    border-color: #404652 !important;
    background-color: #1f2128 !important;
}

/*
 * Botões: cantos consistentes (cápsula / “pill”).
 * O tema (connect.css) usa border-radius: 7px; o Bootstrap em .btn-group
 * deixa botões interiores retos — unificamos tudo para o mesmo aspeto redondo.
 */
.connect-container .btn:not(.btn-link):not(.close):not(.dropdown-item) {
    border-radius: 2rem !important;
}

.connect-container .btn-group > .btn:first-child:not(:only-child) {
    border-top-left-radius: 2rem !important;
    border-bottom-left-radius: 2rem !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.connect-container .btn-group > .btn:last-child:not(:only-child) {
    border-top-right-radius: 2rem !important;
    border-bottom-right-radius: 2rem !important;
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.connect-container .btn-group > .btn:not(:first-child):not(:last-child) {
    border-radius: 0 !important;
}

/* Pseudo-elementos dos botões do tema seguem o raio do botão */
.connect-container .btn-primary:before,
.connect-container .btn-outline-primary:before {
    border-radius: inherit !important;
}

/* Barra de ações no resumo do evento (sem caixa de fundo) */
.connect-container .ec-event-overview-actions {
    gap: 0.5rem;
}

.connect-container .ec-event-overview-actions .ec-event-overview-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-left: 0.85rem;
    padding-right: 0.9rem;
    min-height: 2rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.connect-container .ec-event-overview-actions .ec-event-overview-action-icon {
    font-size: 15px;
    margin-right: 0.35rem;
    vertical-align: -2px;
    opacity: 0.9;
}

body.dark-theme .connect-container .ec-event-overview-actions .ec-event-overview-action {
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.32);
}

/* Resumo do evento: cartão superior + grelha KPI (cores tipo app) */
.ec-event-overview-summary {
    border-radius: 14px;
    overflow: hidden;
}

.ec-event-overview-summary__body {
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(95, 208, 165, 0.1) 0%, #ffffff 52%);
    box-shadow: inset 0 3px 0 0 #3cb892;
}

.ec-event-overview-summary--draft .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(108, 117, 125, 0.12) 0%, #ffffff 52%);
    box-shadow: inset 0 3px 0 0 #868e96;
}

.ec-event-overview-summary--closed .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(255, 193, 7, 0.12) 0%, #fffef8 52%);
    box-shadow: inset 0 3px 0 0 #e0a800;
}

.ec-event-overview-summary--archived .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(108, 117, 125, 0.08) 0%, #f8f9fa 52%);
    box-shadow: inset 0 3px 0 0 #adb5bd;
}

/* Metadados do evento (slug, datas, …): lista compacta, sem «caixa» pesada */
.ec-event-overview-meta {
    margin-top: 0.9rem;
    padding: 0;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, 0.06);
    background: rgba(255, 255, 255, 0.5);
}

.ec-event-overview-meta__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem 1rem;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.ec-event-overview-meta__row:last-child {
    border-bottom: 0;
}

.ec-event-overview-meta__label {
    flex: 0 1 auto;
    max-width: 48%;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #7a8a82;
    line-height: 1.3;
}

.ec-event-overview-meta__value {
    flex: 1 1 auto;
    min-width: 0;
    font-size: 0.875rem;
    font-weight: 500;
    color: #24332c;
    text-align: right;
    word-break: break-word;
}

@media (max-width: 575.98px) {
    .ec-event-overview-meta__value {
        text-align: left;
        width: 100%;
    }

    .ec-event-overview-meta__label {
        max-width: 100%;
    }
}

.ec-event-overview-meta__slug {
    display: inline-block;
    max-width: 100%;
    padding: 0.12rem 0.45rem;
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.78rem;
    font-weight: 500;
    color: #2d4a40;
    background: rgba(95, 208, 165, 0.12);
    border: 1px solid rgba(95, 208, 165, 0.22);
    border-radius: 6px;
}

.ec-event-overview-meta__pill {
    display: inline-block;
    padding: 0.12rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 999px;
    line-height: 1.2;
}

.ec-event-overview-meta__pill--yes {
    color: #1e5a45;
    background: rgba(95, 208, 165, 0.22);
    border: 1px solid rgba(60, 184, 146, 0.35);
}

.ec-event-overview-meta__pill--no {
    color: #5c636a;
    background: rgba(108, 117, 125, 0.12);
    border: 1px solid rgba(108, 117, 125, 0.22);
}

.ec-event-overview-kpi-card {
    border-radius: 14px;
}

.ec-event-overview-kpi-card .event-overview-kpi-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.65rem;
    padding: 0.75rem;
    background: #eef1f3;
}

@media (min-width: 576px) {
    .ec-event-overview-kpi-card .event-overview-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 768px) {
    .ec-event-overview-kpi-card .event-overview-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .ec-event-overview-kpi-card .event-overview-kpi-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.event-overview-kpi-item[data-kpi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    min-height: 4.5rem;
    padding: 0.875rem 1rem;
    color: inherit;
    text-decoration: none;
    border-radius: 12px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.07);
    box-shadow: 0 1px 2px rgba(62, 85, 120, 0.06);
    transition: box-shadow 0.16s ease, transform 0.12s ease, border-color 0.15s ease;
}

.event-overview-kpi-item[data-kpi]:hover {
    color: inherit;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 0.3rem 0.85rem rgba(62, 85, 120, 0.1);
    border-color: rgba(0, 0, 0, 0.1);
}

.event-overview-kpi-main {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    min-width: 0;
    flex: 1;
}

.event-overview-kpi-icon {
    color: #868e96;
    line-height: 1;
}

.event-overview-kpi-item:not([data-kpi]) .event-overview-kpi-icon {
    color: #868e96;
}

.event-overview-kpi-icon .material-icons-outlined {
    font-size: 22px;
    vertical-align: middle;
}

.event-overview-kpi-text {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.event-overview-kpi-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #495057;
    letter-spacing: 0.01em;
    line-height: 1.25;
}

.event-overview-kpi-sub {
    font-size: 0.75rem;
    color: #868e96;
    line-height: 1.2;
}

.event-overview-kpi-value {
    font-size: 1.375rem;
    font-weight: 700;
    color: #212529;
    line-height: 1.1;
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
}

body.dark-theme .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(95, 208, 165, 0.12) 0%, rgba(40, 44, 52, 0.98) 48%);
    box-shadow: inset 0 3px 0 0 #5fd0a5;
}

body.dark-theme .ec-event-overview-summary--draft .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(120, 130, 145, 0.14) 0%, rgba(38, 40, 46, 0.98) 48%);
    box-shadow: inset 0 3px 0 0 #9aa3b2;
}

body.dark-theme .ec-event-overview-summary--closed .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(224, 168, 0, 0.12) 0%, rgba(42, 40, 32, 0.98) 48%);
    box-shadow: inset 0 3px 0 0 #f0c040;
}

body.dark-theme .ec-event-overview-summary--archived .ec-event-overview-summary__body {
    background: linear-gradient(180deg, rgba(100, 108, 120, 0.12) 0%, rgba(36, 38, 44, 0.98) 48%);
    box-shadow: inset 0 3px 0 0 #8a96a8;
}

body.dark-theme .ec-event-overview-meta {
    background: rgba(28, 31, 38, 0.75);
    border-color: rgba(255, 255, 255, 0.08);
}

body.dark-theme .ec-event-overview-meta__row {
    border-bottom-color: rgba(255, 255, 255, 0.07);
}

body.dark-theme .ec-event-overview-meta__label {
    color: #9aa8a2;
}

body.dark-theme .ec-event-overview-meta__value {
    color: #e8f0ec;
}

body.dark-theme .ec-event-overview-meta__slug {
    color: #c5e8dc;
    background: rgba(95, 208, 165, 0.12);
    border-color: rgba(95, 208, 165, 0.28);
}

body.dark-theme .ec-event-overview-meta__pill--yes {
    color: #b8f0dc;
    background: rgba(95, 208, 165, 0.18);
    border-color: rgba(95, 208, 165, 0.35);
}

body.dark-theme .ec-event-overview-meta__pill--no {
    color: #c5cad3;
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.1);
}

body.dark-theme .ec-event-overview-kpi-card .event-overview-kpi-grid {
    background: #1e2229;
}

body.dark-theme .event-overview-kpi-item[data-kpi] {
    background: rgba(40, 44, 52, 0.96);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
    color: #dbe4f2;
}

body.dark-theme .event-overview-kpi-item[data-kpi]:hover {
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 0.35rem 0.9rem rgba(0, 0, 0, 0.45);
}

body.dark-theme .event-overview-kpi-icon {
    color: #9aa7bc;
}

body.dark-theme .event-overview-kpi-label {
    color: #e8eef9;
}

body.dark-theme .event-overview-kpi-sub {
    color: #9aa7bc;
}

body.dark-theme .event-overview-kpi-value {
    color: #f3f7ff;
}

/* --- Cabeçalho global (barra superior: tema, idioma, perfil) --- */
/* Nota: escopar modo claro para não sobrepor dark_theme.css (custom.css carrega por último). */
.connect-container .ec-app-header .ec-app-navbar {
    padding: 0.65rem 2rem;
    min-height: 3.25rem;
}

@media (min-width: 1200px) {
    .connect-container .ec-app-header .ec-app-navbar {
        padding-top: 0.85rem;
        padding-bottom: 0.85rem;
    }
}

.connect-container .ec-app-header .navbar-nav > .nav-item > .nav-link {
    border-radius: 0.5rem;
}

body:not(.dark-theme) .connect-container .page-container > .ec-app-header {
    background: #fff;
    border-bottom: 1px solid #e8eaef;
    box-shadow: 0 1px 0 rgba(31, 45, 61, 0.04);
}

body:not(.dark-theme) .connect-container .ec-app-header .nav-item .btn-outline-light {
    border-color: #dee2e6;
    color: #5a6268;
    background: #fff;
}

body:not(.dark-theme) .connect-container .ec-app-header .nav-item .btn-outline-light:hover {
    border-color: #4faa53;
    color: #3d8f42;
    background: rgba(79, 170, 83, 0.08);
}

body:not(.dark-theme) .connect-container .ec-app-header .nav-item .btn-outline-light.active {
    border-color: #4faa53;
    background: #4faa53;
    color: #fff;
}

body.dark-theme .connect-container .page-container > .ec-app-header {
    background: #272b33;
    border-bottom: 1px solid #3a3f4a;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.25);
}

body.dark-theme .connect-container .ec-app-header .nav-item .btn-outline-light {
    border-color: #4a505c;
    color: #c8d0de;
    background: #323742;
}

body.dark-theme .connect-container .ec-app-header .nav-item .btn-outline-light:hover {
    border-color: #5fd0a5;
    color: #5fd0a5;
    background: rgba(95, 208, 165, 0.12);
}

body.dark-theme .connect-container .ec-app-header .nav-item .btn-outline-light.active {
    border-color: #5fd0a5;
    background: #5fd0a5;
    color: #1f2128;
}

body:not(.dark-theme) .connect-container .ec-app-header .ec-app-lang-select {
    border-color: #dee2e6;
    color: #212529;
    background: #fff;
}

body:not(.dark-theme) .connect-container .ec-app-header .ec-app-lang-select:focus {
    border-color: #4faa53;
    box-shadow: 0 0 0 0.15rem rgba(79, 170, 83, 0.2);
}

body.dark-theme .connect-container .ec-app-header .ec-app-lang-select {
    border-color: #4a505c;
    color: #e8ecf0;
    background: #323742;
}

body.dark-theme .connect-container .ec-app-header .ec-app-lang-select:focus {
    border-color: #5fd0a5;
    box-shadow: 0 0 0 0.15rem rgba(95, 208, 165, 0.2);
}

/* Breadcrumbs: antes partilhavam .page-header com a barra superior (estilos de posição fixa em ecrã estreito) */
.ec-page-heading {
    padding: 0 0 0.25rem;
}

.ec-page-heading .ec-breadcrumb {
    background: transparent;
    /* O espaço até ao conteúdo / barras de secções fica em .ec-page-heading-content (ritmo único). */
    padding: 0.35rem 0 0.25rem;
    font-size: 0.8125rem;
    font-weight: 600;
}

/* Ritmo único abaixo dos breadcrumbs (admin, participante, hub de refeições, etc.):
   evita somar mt-lg-3 nos templates com o padding antigo do breadcrumb. */
.ec-page-heading-content {
    padding-top: 0.875rem;
}

.ec-page-heading-content > .page-body {
    margin-top: 0 !important;
}

/* Resumo do evento / lista de eventos: primeira faixa sem classe .page-body */
.ec-page-heading-content > .px-xl-4.mt-0.mt-lg-3 {
    margin-top: 0 !important;
}

/* Duas barras de secções seguidas (casos raros no mesmo bloco) */
.ec-page-heading-content .ec-event-sections + .ec-event-sections {
    margin-top: 0.75rem;
}

/* Linha opcional acima da barra de secções do participante (ex. links rápidos). */
.ec-participant-subpage-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    min-height: 1.375rem;
    margin-bottom: 0.375rem;
}
.ec-participant-subpage-toolbar:empty {
    display: none;
    min-height: 0;
    margin-bottom: 0;
}

/* Faixa reservada acima da barra de secções do grupo (ritmo com participante). */
.ec-group-subpage-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    min-height: 1.375rem;
    margin-bottom: 0.375rem;
}
.ec-group-subpage-toolbar:empty {
    display: none;
    min-height: 0;
    margin-bottom: 0;
}

body:not(.dark-theme) .ec-page-heading .breadcrumb-item + .breadcrumb-item::before {
    color: #adb5bd;
}

body:not(.dark-theme) .ec-page-heading .breadcrumb-item a {
    color: #4faa53;
}

body:not(.dark-theme) .ec-page-heading .breadcrumb-item a:hover {
    color: #3d8f42;
    text-decoration: none;
}

body:not(.dark-theme) .ec-page-heading .breadcrumb-item.active {
    color: #6c757d;
    opacity: 0.9;
}

body.dark-theme .ec-page-heading .breadcrumb-item + .breadcrumb-item::before {
    color: #8e98ab;
}

body.dark-theme .ec-page-heading .breadcrumb-item a {
    color: #5fd0a5;
}

body.dark-theme .ec-page-heading .breadcrumb-item a:hover {
    color: #8ee4c4;
    text-decoration: none;
}

body.dark-theme .ec-page-heading .breadcrumb-item.active {
    color: #c8d0de;
    opacity: 0.9;
}

/* --- Placeholders vs valores (modo claro): valor escuro e em destaque; hint mais claro e sem bold --- */
body:not(.dark-theme) .form-control:not(.form-control-plaintext) {
    color: #1e2329;
}

body:not(.dark-theme) .form-control:not(.form-control-plaintext)::placeholder,
body:not(.dark-theme) .form-control:not(.form-control-plaintext)::-webkit-input-placeholder {
    color: #6c757d;
    opacity: 1;
    font-weight: 400;
}

body:not(.dark-theme) .form-control:not(.form-control-plaintext)::-moz-placeholder {
    color: #6c757d;
    opacity: 1;
    font-weight: 400;
}

body:not(.dark-theme) .form-control:not(.form-control-plaintext):-ms-input-placeholder {
    color: #6c757d;
    font-weight: 400;
}

body:not(.dark-theme) .custom-select {
    color: #1e2329;
}

/* Campos extra (participantes): select com look alinhado aos controlos compactos do header */
.connect-container .ec-extra-fields-page select.form-control,
.connect-container .ec-extra-fields-page select.form-control.form-control-sm {
    border-radius: 1rem;
    min-height: 34px;
    height: 34px;
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
    padding-left: 0.75rem;
    padding-right: 2rem;
    line-height: 1.2;
    background-position: right 0.7rem center;
    background-size: 10px 10px;
}

.connect-container .ec-extra-fields-page select.form-control:focus,
.connect-container .ec-extra-fields-page select.form-control.form-control-sm:focus {
    border-color: #5fd0a5;
    box-shadow: 0 0 0 0.12rem rgba(95, 208, 165, 0.18);
}

/* Select2 (modo claro): placeholder da pesquisa vs texto escrito */
body:not(.dark-theme) .select2-container--default .select2-search--dropdown .select2-search__field::placeholder,
body:not(.dark-theme) .select2-container--default .select2-search--dropdown .select2-search__field::-webkit-input-placeholder {
    color: #6c757d;
    opacity: 1;
    font-weight: 400;
}

body:not(.dark-theme) .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #6c757d !important;
    font-weight: 400;
}

/* Painel: identidade do evento + voltar + pills de secções */
.ec-event-sections {
    border: 1px solid rgba(95, 208, 165, 0.28);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(248, 252, 250, 1) 100%);
    box-shadow: 0 2px 10px rgba(62, 85, 120, 0.07);
    /* visible: menus dropdown da barra de secções ficam por cima do conteúdo abaixo */
    overflow: visible;
    position: relative;
    /* Toda a faixa (incl. menu que sai para baixo) fica acima do cartão/conteúdo seguinte */
    z-index: 40;
}

/* Hub global /admin/events: garantir stacking acima de overlays da shell */
.ec-events-hub-section {
    position: relative;
    z-index: 2;
}

/* Lista de eventos (/admin/events): cartões tipo app + cor por estado temporal */
.ec-events-list-filters .ec-events-filter-btn.active {
    color: #fff;
    border-color: transparent;
    box-shadow: 0 2px 6px rgba(62, 85, 120, 0.18);
}

.ec-events-list-filters .ec-events-filter-btn[data-filter="all"].active {
    background: #4a5d56;
}

.ec-events-list-filters .ec-events-filter-btn[data-filter="upcoming"].active {
    background: #3a6fd8;
}

.ec-events-list-filters .ec-events-filter-btn[data-filter="ongoing"].active {
    background: #2f9d78;
}

.ec-events-list-filters .ec-events-filter-btn[data-filter="past"].active {
    background: #6b7788;
}

body.dark-theme .ec-events-list-filters .ec-events-filter-btn.active {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.ec-events-list-card {
    border-radius: 12px;
    transition: box-shadow 0.18s ease, transform 0.14s ease;
    overflow: hidden;
}

.ec-events-list-card--upcoming {
    background: linear-gradient(180deg, rgba(66, 124, 245, 0.12) 0%, #ffffff 46%);
    box-shadow: inset 0 3px 0 0 #427cf5, 0 1px 3px rgba(62, 85, 120, 0.06);
}

.ec-events-list-card--ongoing {
    background: linear-gradient(180deg, rgba(95, 208, 165, 0.2) 0%, #ffffff 46%);
    box-shadow: inset 0 3px 0 0 #3cb892, 0 1px 3px rgba(62, 85, 120, 0.06);
}

.ec-events-list-card--past {
    background: linear-gradient(180deg, rgba(108, 118, 132, 0.14) 0%, #f8f9fb 48%);
    box-shadow: inset 0 3px 0 0 #8a96a8, 0 1px 3px rgba(62, 85, 120, 0.05);
}

.ec-events-list-card:hover {
    box-shadow: 0 0.4rem 1.15rem rgba(62, 85, 120, 0.14) !important;
    transform: translateY(-2px);
}

.ec-events-list-card--upcoming:hover {
    box-shadow: 0 0.45rem 1.2rem rgba(66, 124, 245, 0.22) !important;
}

.ec-events-list-card--ongoing:hover {
    box-shadow: 0 0.45rem 1.2rem rgba(60, 184, 146, 0.22) !important;
}

.ec-events-list-card--past:hover {
    box-shadow: 0 0.45rem 1.2rem rgba(108, 118, 132, 0.2) !important;
}

.ec-events-list-card .ec-events-list-card__meta-icon {
    font-size: 1rem;
    margin-right: 0.25rem;
    flex-shrink: 0;
    opacity: 0.85;
    vertical-align: -3px;
}

.ec-events-list-card__footer {
    border-color: rgba(0, 0, 0, 0.06) !important;
}

.ec-events-list-card__stats {
    gap: 0.65rem 1rem;
}

.ec-events-list-card__stat {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    font-weight: 600;
    color: #4a5d56;
}

.ec-events-list-card__stat .material-icons-outlined {
    font-size: 1rem;
    opacity: 0.75;
}

body.dark-theme .ec-events-list-card {
    background: rgba(40, 44, 52, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
}

body.dark-theme .ec-events-list-card--upcoming {
    background: linear-gradient(180deg, rgba(66, 124, 245, 0.2) 0%, rgba(40, 44, 52, 0.98) 52%);
    box-shadow: inset 0 3px 0 0 #6a9cff, 0 1px 4px rgba(0, 0, 0, 0.25);
}

body.dark-theme .ec-events-list-card--ongoing {
    background: linear-gradient(180deg, rgba(95, 208, 165, 0.18) 0%, rgba(40, 44, 52, 0.98) 52%);
    box-shadow: inset 0 3px 0 0 #5fd0a5, 0 1px 4px rgba(0, 0, 0, 0.25);
}

body.dark-theme .ec-events-list-card--past {
    background: linear-gradient(180deg, rgba(120, 130, 148, 0.16) 0%, rgba(36, 38, 44, 0.98) 52%);
    box-shadow: inset 0 3px 0 0 #9aa3b2, 0 1px 4px rgba(0, 0, 0, 0.22);
}

body.dark-theme .ec-events-list-card .card-body {
    color: #e4e8ee;
}

body.dark-theme .ec-events-list-card h6 {
    color: #f2f4f8;
}

body.dark-theme .ec-events-list-card:hover {
    box-shadow: 0 0.45rem 1.25rem rgba(0, 0, 0, 0.45) !important;
}

body.dark-theme .ec-events-list-card--upcoming:hover {
    box-shadow: 0 0.5rem 1.35rem rgba(66, 124, 245, 0.28) !important;
}

body.dark-theme .ec-events-list-card--ongoing:hover {
    box-shadow: 0 0.5rem 1.35rem rgba(95, 208, 165, 0.25) !important;
}

body.dark-theme .ec-events-list-card--past:hover {
    box-shadow: 0 0.5rem 1.35rem rgba(0, 0, 0, 0.5) !important;
}

body.dark-theme .ec-events-list-card__stat {
    color: #c5cdd6;
}

body.dark-theme .ec-events-list-card__footer {
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.ec-event-sections__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
    padding: 0.85rem 1rem 0.75rem;
    border-bottom: 1px solid rgba(95, 208, 165, 0.2);
    background: rgba(255, 255, 255, 0.65);
}

.ec-event-sections__identity {
    min-width: 0;
    flex: 1 1 auto;
}

.ec-event-sections__current {
    margin-left: 1rem;
    font-size: 1.15rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.035em;
    opacity: 1;
    white-space: nowrap;
    line-height: 1.2;
    align-self: flex-start;
    text-align: right;
    color: #0f3d31;
    background: rgba(95, 208, 165, 0.16);
    border: 1px solid rgba(95, 208, 165, 0.42);
    border-radius: 999px;
    padding: 0.28rem 0.72rem 0.24rem;
}

.ec-group-sections .ec-event-sections__current {
    color: #9a3412;
    background: rgba(249, 115, 22, 0.16);
    border-color: rgba(249, 115, 22, 0.45);
}

.ec-participant-sections .ec-event-sections__current {
    color: #283593;
    background: rgba(92, 107, 192, 0.16);
    border-color: rgba(92, 107, 192, 0.42);
}

.ec-event-sections__title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.65rem;
    margin-bottom: 0.25rem;
}

.ec-event-sections__badge {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(90deg, rgba(85, 195, 183, 1) 0%, rgba(95, 208, 165, 1) 100%);
    padding: 0.2rem 0.55rem;
    border-radius: 6px;
    line-height: 1.3;
}

.ec-event-sections__event-name {
    font-size: 1.05rem;
    font-weight: 600;
    color: #1a2f28;
    line-height: 1.3;
}

.ec-event-sections__scope {
    font-size: 0.8125rem;
    color: #5a6d66;
    margin: 0;
    max-width: 48rem;
    line-height: 1.45;
}

.ec-event-sections__nav {
    /* Horizontal alinhado a .ec-event-sections__head (1rem) para a barra de pills não “saltar” face ao título */
    padding: 0.5rem 1rem 0.65rem;
}

body.dark-theme .ec-event-sections {
    border-color: rgba(95, 208, 165, 0.25);
    background: linear-gradient(180deg, rgba(38, 42, 49, 1) 0%, rgba(32, 36, 42, 1) 100%);
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}

body.dark-theme .ec-event-sections__head {
    border-bottom-color: rgba(95, 208, 165, 0.2);
    background: rgba(32, 36, 42, 0.9);
}

body.dark-theme .ec-event-sections__event-name {
    color: #e8ecf1;
}

body.dark-theme .ec-event-sections__scope {
    color: #a8b0bc;
}

body.dark-theme .ec-event-sections__current {
    opacity: 1;
    color: #dcfce7;
    background: rgba(95, 208, 165, 0.2);
    border-color: rgba(95, 208, 165, 0.45);
}

body.dark-theme .ec-group-sections .ec-event-sections__current {
    color: #fed7aa;
    background: rgba(249, 115, 22, 0.2);
    border-color: rgba(251, 146, 60, 0.5);
}

body.dark-theme .ec-participant-sections .ec-event-sections__current {
    color: #c7d2fe;
    background: rgba(92, 107, 192, 0.22);
    border-color: rgba(121, 134, 203, 0.52);
}

/* Secções do participante — paleta índigo (contrasta com o verde-teal das secções do evento) */
.ec-participant-sections.ec-event-sections {
    border-color: rgba(92, 107, 192, 0.4);
    background: linear-gradient(180deg, rgba(252, 253, 255, 1) 0%, rgba(241, 244, 255, 1) 100%);
    box-shadow: 0 2px 12px rgba(65, 80, 140, 0.09);
}

.ec-participant-sections .ec-event-sections__head {
    border-bottom-color: rgba(92, 107, 192, 0.22);
    background: rgba(255, 255, 255, 0.78);
}

.ec-participant-sections .ec-event-sections__badge {
    background: linear-gradient(90deg, #5c6bc0 0%, #7986cb 52%, #9fa8da 100%);
}

.ec-participant-sections .ec-event-sections__event-name {
    color: #283593;
}

.ec-participant-sections .ec-event-sections__scope {
    color: #5c6b8a;
}

.ec-participant-sections .ec-section-nav {
    background: linear-gradient(135deg, rgba(92, 107, 192, 0.12) 0%, rgba(121, 134, 203, 0.07) 100%);
    border-color: rgba(92, 107, 192, 0.28);
    box-shadow: 0 1px 4px rgba(65, 80, 140, 0.06);
}

.ec-participant-sections .ec-section-nav__link {
    color: #303f73 !important;
}

.ec-participant-sections .ec-section-nav__link:hover {
    color: #1a237e !important;
    border-color: rgba(92, 107, 192, 0.42);
    box-shadow: 0 3px 10px rgba(92, 107, 192, 0.16);
}

.ec-participant-sections .ec-section-nav__link.is-active {
    background: linear-gradient(90deg, #5c6bc0 0%, #7986cb 52%, #9fa8da 100%);
    box-shadow: 0 2px 8px rgba(92, 107, 192, 0.32);
}

.ec-participant-sections .ec-section-nav__link--back {
    border-color: rgba(92, 107, 192, 0.48);
}

.ec-participant-sections .ec-section-nav__sep {
    background: rgba(92, 107, 192, 0.38);
}

body.dark-theme .ec-participant-sections.ec-event-sections {
    border-color: rgba(129, 140, 220, 0.38);
    background: linear-gradient(180deg, rgba(38, 40, 52, 1) 0%, rgba(32, 34, 48, 1) 100%);
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.38);
}

body.dark-theme .ec-participant-sections .ec-event-sections__head {
    border-bottom-color: rgba(129, 140, 220, 0.28);
    background: rgba(36, 38, 52, 0.92);
}

body.dark-theme .ec-participant-sections .ec-event-sections__badge {
    background: linear-gradient(90deg, #5c6bc0 0%, #7e8ce0 50%, #9fa8da 100%);
}

body.dark-theme .ec-participant-sections .ec-event-sections__event-name {
    color: #e8ecff;
}

body.dark-theme .ec-participant-sections .ec-event-sections__scope {
    color: #aeb8de;
}

body.dark-theme .ec-participant-sections .ec-section-nav {
    background: linear-gradient(135deg, rgba(121, 134, 203, 0.14) 0%, rgba(92, 107, 192, 0.06) 100%);
    border-color: rgba(129, 140, 220, 0.28);
}

body.dark-theme .ec-participant-sections .ec-section-nav__link {
    color: #e4e8f7 !important;
    background: rgba(48, 52, 68, 0.96);
    border-color: rgba(160, 170, 220, 0.12);
}

body.dark-theme .ec-participant-sections .ec-section-nav__link:hover {
    color: #c5ccff !important;
    background: rgba(121, 134, 203, 0.18);
    border-color: rgba(159, 168, 218, 0.45);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}

body.dark-theme .ec-participant-sections .ec-section-nav__link.is-active {
    box-shadow: 0 2px 12px rgba(121, 134, 203, 0.35);
}

body.dark-theme .ec-participant-sections .ec-section-nav__link--back {
    border-color: rgba(159, 168, 218, 0.42);
}

body.dark-theme .ec-participant-sections .ec-section-nav__sep {
    background: rgba(159, 168, 218, 0.35);
}

body.dark-theme .ec-participant-sections .ec-section-nav__dropdown .dropdown-item:hover,
body.dark-theme .ec-participant-sections .ec-section-nav__dropdown .dropdown-item:focus {
    background: rgba(121, 134, 203, 0.22);
    color: #c5ccff;
}

/* Secções do grupo — terracota / âmbar (sem barra do evento; distinto do índigo do participante) */
.ec-group-sections.ec-event-sections {
    border-color: rgba(180, 95, 70, 0.42);
    background: linear-gradient(180deg, rgba(255, 253, 251, 1) 0%, rgba(255, 244, 236, 1) 100%);
    box-shadow: 0 2px 12px rgba(120, 52, 36, 0.1);
}

.ec-group-sections .ec-event-sections__head {
    border-bottom-color: rgba(200, 110, 85, 0.3);
    background: rgba(255, 255, 255, 0.88);
}

.ec-group-sections .ec-event-sections__badge {
    background: linear-gradient(90deg, #b54d32 0%, #d06a40 45%, #e89458 100%);
}

.ec-group-sections .ec-event-sections__event-name {
    color: #6d2a1c;
}

.ec-group-sections .ec-event-sections__scope {
    color: #8a5244;
}

.ec-group-sections .ec-section-nav {
    background: linear-gradient(135deg, rgba(200, 96, 61, 0.16) 0%, rgba(232, 160, 96, 0.09) 100%);
    border-color: rgba(200, 110, 85, 0.38);
    box-shadow: 0 1px 4px rgba(100, 40, 28, 0.08);
}

.ec-group-sections .ec-section-nav__link {
    color: #4a1f14 !important;
}

.ec-group-sections .ec-section-nav__link:hover {
    color: #2f120c !important;
    border-color: rgba(200, 96, 61, 0.48);
    box-shadow: 0 3px 10px rgba(200, 96, 61, 0.2);
}

.ec-group-sections .ec-section-nav__link.is-active {
    background: linear-gradient(90deg, #b54d32 0%, #d06a40 48%, #e89458 100%);
    box-shadow: 0 2px 8px rgba(180, 70, 45, 0.38);
}

.ec-group-sections .ec-section-nav__link--back {
    border-color: rgba(200, 96, 61, 0.52);
}

.ec-group-sections .ec-section-nav__sep {
    background: rgba(200, 110, 85, 0.42);
}

body.dark-theme .ec-group-sections.ec-event-sections {
    border-color: rgba(232, 150, 110, 0.34);
    background: linear-gradient(180deg, rgba(46, 30, 26, 1) 0%, rgba(34, 22, 20, 1) 100%);
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.42);
}

body.dark-theme .ec-group-sections .ec-event-sections__head {
    border-bottom-color: rgba(232, 150, 110, 0.24);
    background: rgba(44, 28, 24, 0.94);
}

body.dark-theme .ec-group-sections .ec-event-sections__badge {
    background: linear-gradient(90deg, #d06040 0%, #e08050 50%, #f0a870 100%);
}

body.dark-theme .ec-group-sections .ec-event-sections__event-name {
    color: #ffe8dc;
}

body.dark-theme .ec-group-sections .ec-event-sections__scope {
    color: #e0b8a6;
}

body.dark-theme .ec-group-sections .ec-section-nav {
    background: linear-gradient(135deg, rgba(220, 110, 72, 0.18) 0%, rgba(160, 72, 48, 0.1) 100%);
    border-color: rgba(232, 150, 110, 0.3);
}

body.dark-theme .ec-group-sections .ec-section-nav__link {
    color: #fdeee6 !important;
    background: rgba(52, 32, 28, 0.96);
    border-color: rgba(232, 170, 130, 0.14);
}

body.dark-theme .ec-group-sections .ec-section-nav__link:hover {
    color: #fff8f2 !important;
    background: rgba(200, 96, 61, 0.24);
    border-color: rgba(255, 190, 150, 0.38);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.32);
}

body.dark-theme .ec-group-sections .ec-section-nav__link.is-active {
    box-shadow: 0 2px 12px rgba(232, 130, 88, 0.38);
}

body.dark-theme .ec-group-sections .ec-section-nav__link--back {
    border-color: rgba(255, 180, 140, 0.4);
}

body.dark-theme .ec-group-sections .ec-section-nav__sep {
    background: rgba(255, 170, 130, 0.36);
}

body.dark-theme .ec-group-sections .ec-section-nav__dropdown .dropdown-item:hover,
body.dark-theme .ec-group-sections .ec-section-nav__dropdown .dropdown-item:focus {
    background: rgba(220, 110, 72, 0.28);
    color: #fff8f2;
}

/* Voltar na mesma barra que as secções (mesmo estilo de pill, ligeiro destaque) */
.ec-section-nav__link--back {
    border-style: dashed;
    border-color: rgba(95, 208, 165, 0.45);
}

.ec-section-nav__sep {
    display: inline-block;
    align-self: center;
    width: 1px;
    height: 1.15rem;
    margin: 0 0.15rem 0 0.05rem;
    background: rgba(95, 208, 165, 0.35);
    flex-shrink: 0;
}

body.dark-theme .ec-section-nav__sep {
    background: rgba(95, 208, 165, 0.28);
}

body.dark-theme .ec-section-nav__link--back {
    border-color: rgba(95, 208, 165, 0.4);
}

/* Navegação por secções do evento (pills dentro de faixa suave) */
.ec-section-nav-wrap {
    flex: 1 1 auto;
    min-width: 0;
    width: 100%;
    margin-left: 0;
    overflow: visible;
}

.ec-section-nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem 0.45rem;
    padding: 0.5rem 0.65rem;
    background: linear-gradient(135deg, rgba(95, 208, 165, 0.1) 0%, rgba(85, 195, 183, 0.06) 100%);
    border: 1px solid rgba(95, 208, 165, 0.22);
    border-radius: 14px;
    box-shadow: 0 1px 3px rgba(62, 85, 120, 0.05);
    overflow: visible;
}

.ec-section-nav__link {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    padding: 0.38rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.25;
    color: #2d4a40 !important;
    text-decoration: none !important;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

/* Mesmo peso em links e em botões (dropdowns); evita <button> mais fino que <a> */
nav.ec-section-nav a.ec-section-nav__link,
nav.ec-section-nav button.ec-section-nav__link {
    font-family: inherit;
    font-weight: 600;
}

nav.ec-section-nav .ec-section-nav__link span {
    font-weight: inherit;
}

.ec-section-nav__link:hover {
    color: #0f5c44 !important;
    background: #fff;
    border-color: rgba(95, 208, 165, 0.45);
    box-shadow: 0 3px 10px rgba(95, 208, 165, 0.15);
    transform: translateY(-1px);
    text-decoration: none !important;
}

.ec-section-nav__link.is-active {
    color: #fff !important;
    background: linear-gradient(90deg, rgba(85, 195, 183, 1) 0%, rgba(95, 208, 165, 1) 55%, rgba(102, 218, 144, 1) 100%);
    border-color: transparent;
    box-shadow: 0 2px 8px rgba(95, 208, 165, 0.35);
    font-weight: 600;
}

.ec-section-nav__link.is-active:hover {
    color: #fff !important;
    filter: brightness(1.03);
    transform: translateY(-1px);
}

/* Hub participante: botões Bootstrap com o mesmo padding/tipo que .ec-section-nav__link (Locais de Refeição) */
.ec-meal-hub-tabs.btn-group .btn {
    padding: 0.38rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.25;
}

.ec-elig-page-actions .btn.btn-sm {
    padding: 0.38rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.25;
}

.ec-section-nav-icon {
    font-size: 17px;
    line-height: 1;
    margin-right: 0;
    vertical-align: -4px;
    opacity: 0.92;
}

.ec-section-nav__link.is-active .ec-section-nav-icon {
    opacity: 1;
}

.ec-section-nav__dropdown .dropdown-toggle.ec-section-nav__link::after {
    margin-left: 0.2rem;
    vertical-align: 0.12em;
}
.ec-section-nav__dropdown {
    position: relative;
}
.ec-section-nav__dropdown .dropdown-menu {
    /* abaixo do modal Bootstrap (1050), acima do conteúdo da página */
    z-index: 1030;
    min-width: 11.5rem;
    border-radius: 10px;
    border: 1px solid rgba(0, 0, 0, 0.08);
}
.ec-section-nav__dropdown .dropdown-item {
    font-size: 0.8125rem;
    font-weight: 600;
}
body.dark-theme .ec-section-nav__dropdown .dropdown-menu {
    background: rgba(47, 52, 61, 0.98);
    border-color: rgba(255, 255, 255, 0.1);
}
body.dark-theme .ec-section-nav__dropdown .dropdown-item {
    color: #e2e6ee;
}
body.dark-theme .ec-section-nav__dropdown .dropdown-item:hover,
body.dark-theme .ec-section-nav__dropdown .dropdown-item:focus {
    background: rgba(95, 208, 165, 0.15);
    color: #5fd0a5;
}

body.dark-theme .ec-section-nav {
    background: linear-gradient(135deg, rgba(95, 208, 165, 0.08) 0%, rgba(95, 208, 165, 0.03) 100%);
    border-color: rgba(95, 208, 165, 0.2);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}

body.dark-theme .ec-section-nav__link {
    color: #e2e6ee !important;
    background: rgba(47, 52, 61, 0.95);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: none;
}

body.dark-theme .ec-section-nav__link:hover {
    color: #5fd0a5 !important;
    background: rgba(95, 208, 165, 0.12);
    border-color: rgba(95, 208, 165, 0.35);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}

body.dark-theme .ec-section-nav__link.is-active {
    color: #fff !important;
    box-shadow: 0 2px 12px rgba(95, 208, 165, 0.25);
}

body.dark-theme .ec-section-nav__link.is-active:hover {
    color: #fff !important;
}

/* Filtros matriz refeições: nota «aplica-se às tabelas abaixo» */
.ec-meal-hub-filters-scope {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.55rem 0.75rem 0.55rem 0.8rem;
    margin-bottom: 1rem;
    border-left: 3px solid rgba(95, 208, 165, 0.9);
    background: rgba(95, 208, 165, 0.08);
    border-radius: 0 0.35rem 0.35rem 0;
    color: #2d4a40;
    line-height: 1.45;
    font-size: 0.875rem;
}
.ec-meal-hub-filters-scope__icon {
    font-size: 1.2rem;
    color: #1f7a5c;
    flex-shrink: 0;
    margin-top: 0.06rem;
}
body.dark-theme .ec-meal-hub-filters-scope {
    background: rgba(95, 208, 165, 0.1);
    color: #d1e8df;
    border-left-color: rgba(95, 208, 165, 0.75);
}
body.dark-theme .ec-meal-hub-filters-scope__icon {
    color: #7ee0c3;
}
.ec-meal-hub-date-row {
    gap: 0.5rem;
}
.ec-meal-hub-date-row .form-control {
    min-width: 0;
    flex: 1 1 auto;
}

/* Título matriz por local: «Quem pode comer» + link do restaurante na mesma linha */
.ec-meal-loc-matrix-heading {
    gap: 0.35rem;
}

/* Matriz «todos os dias» — refeições por local (quem comeu) */
.ec-meal-loc-matrix th.ec-meal-loc-day,
.ec-meal-loc-matrix td.ec-meal-loc-day {
    text-align: center;
    vertical-align: middle;
    white-space: nowrap;
    font-size: 0.8rem;
    padding: 0.35rem 0.25rem;
}
.ec-meal-loc-matrix th.ec-meal-loc-day {
    font-weight: 600;
}
.ec-meal-loc-matrix .ec-meal-loc-sticky {
    position: sticky;
    left: 0;
    background: #f8f9fa;
    z-index: 2;
    box-shadow: 2px 0 4px rgba(0, 0, 0, 0.04);
}
.dark-theme .ec-meal-loc-matrix .ec-meal-loc-sticky {
    background: #2a303a;
    box-shadow: 2px 0 4px rgba(0, 0, 0, 0.2);
}
.ec-meal-loc-view-toggle {
    display: flex;
    width: 100%;
    max-width: 20rem;
}
.ec-meal-loc-view-toggle .btn {
    flex: 1 1 0;
    min-width: 0;
    font-weight: 600;
    white-space: nowrap;
}
.ec-meal-loc-view-toggle .btn.btn-primary,
.ec-meal-hub-date-row .btn.btn-primary {
    background: #4faa53;
    border-color: #4faa53;
    color: #fff;
}
.ec-meal-loc-view-toggle .btn.btn-primary:hover,
.ec-meal-loc-view-toggle .btn.btn-primary:focus,
.ec-meal-hub-date-row .btn.btn-primary:hover,
.ec-meal-hub-date-row .btn.btn-primary:focus {
    background: #3d8f42;
    border-color: #3d8f42;
    color: #fff;
}
body.dark-theme .ec-meal-loc-view-toggle .btn.btn-primary,
body.dark-theme .ec-meal-hub-date-row .btn.btn-primary {
    background: #2d8a5e;
    border-color: #2d8a5e;
    color: #fff;
}
body.dark-theme .ec-meal-loc-view-toggle .btn.btn-primary:hover,
body.dark-theme .ec-meal-loc-view-toggle .btn.btn-primary:focus,
body.dark-theme .ec-meal-hub-date-row .btn.btn-primary:hover,
body.dark-theme .ec-meal-hub-date-row .btn.btn-primary:focus {
    background: #3aa672;
    border-color: #3aa672;
    color: #fff;
}
.ec-meal-loc-view-toggle .btn.btn-outline-primary:hover {
    z-index: 1;
}

/* Intervalo de datas (filtros matriz refeições) — evitar bg-white/text-dark nos templates */
.ec-meal-loc-range-box {
    background: #fff;
    color: #212529;
    border-color: rgba(0, 0, 0, 0.12) !important;
}
.dark-theme .ec-meal-loc-range-box {
    background: rgba(255, 255, 255, 0.04) !important;
    border-color: rgba(255, 255, 255, 0.12) !important;
    color: #d1d6e0;
}

/* Faixa de filtros por separador (resumo) — contraste em dark mode */
.ec-meal-hub-filters-strip {
    background: linear-gradient(180deg, rgba(248, 252, 250, 0.92) 0%, rgba(241, 243, 245, 0.96) 100%);
}
body.dark-theme .ec-meal-hub-filters-strip {
    background: linear-gradient(180deg, rgba(42, 46, 54, 0.96) 0%, rgba(34, 38, 46, 0.99) 100%);
    border-bottom-color: rgba(255, 255, 255, 0.1) !important;
}

/* Resumo refeições — separadores «por restaurante / por participante» (pills, alinhado à barra de secções) */
.ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills {
    gap: 0.45rem;
    row-gap: 0.5rem;
    border-bottom: 1px solid rgba(95, 208, 165, 0.2);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 252, 250, 0.9) 100%);
}
body.dark-theme .ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills {
    border-bottom-color: rgba(95, 208, 165, 0.22);
    background: linear-gradient(180deg, rgba(38, 42, 49, 0.98) 0%, rgba(32, 36, 42, 1) 100%);
}
.ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill {
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.875rem;
    padding: 0.42rem 1rem;
    color: #2d4a40;
    border: 1px solid rgba(0, 0, 0, 0.06);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
body.dark-theme .ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill {
    color: #d6deec;
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(47, 52, 61, 0.92);
    box-shadow: none;
}
.ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill:hover {
    color: #0f5c44;
    border-color: rgba(95, 208, 165, 0.45);
    background: #fff;
}
body.dark-theme .ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill:hover {
    color: #5fd0a5 !important;
    border-color: rgba(95, 208, 165, 0.38);
    background: rgba(95, 208, 165, 0.12);
}
.ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill.active {
    color: #fff !important;
    background: linear-gradient(90deg, rgba(85, 195, 183, 1) 0%, rgba(95, 208, 165, 1) 55%, rgba(102, 218, 144, 1) 100%);
    border-color: transparent;
    box-shadow: 0 2px 10px rgba(95, 208, 165, 0.28);
}
body.dark-theme .ec-meal-summary-hub--tabs .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill.active {
    box-shadow: 0 2px 12px rgba(95, 208, 165, 0.32);
}
.page-body:has(#ec-meal-summary-hub) .btn.btn-primary,
.page-body:has(#ec-meal-summary-hub) .btn-group .btn.btn-primary,
.page-body:has(.ec-meal-loc-view-toggle) .btn.btn-primary {
    background: #4faa53 !important;
    border-color: #4faa53 !important;
    color: #fff !important;
}
.page-body:has(#ec-meal-summary-hub) .btn.btn-primary:hover,
.page-body:has(#ec-meal-summary-hub) .btn.btn-primary:focus,
.page-body:has(#ec-meal-summary-hub) .btn-group .btn.btn-primary:hover,
.page-body:has(#ec-meal-summary-hub) .btn-group .btn.btn-primary:focus,
.page-body:has(.ec-meal-loc-view-toggle) .btn.btn-primary:hover,
.page-body:has(.ec-meal-loc-view-toggle) .btn.btn-primary:focus {
    background: #3d8f42 !important;
    border-color: #3d8f42 !important;
    color: #fff !important;
}
.page-body:has(#ec-meal-summary-hub) .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill.active {
    background: #4faa53 !important;
    border-color: #4faa53 !important;
    box-shadow: none !important;
}
body.dark-theme .page-body:has(#ec-meal-summary-hub) .btn.btn-primary,
body.dark-theme .page-body:has(#ec-meal-summary-hub) .btn-group .btn.btn-primary,
body.dark-theme .page-body:has(.ec-meal-loc-view-toggle) .btn.btn-primary {
    background: #2d8a5e !important;
    border-color: #2d8a5e !important;
    color: #fff !important;
}
body.dark-theme .page-body:has(#ec-meal-summary-hub) .btn.btn-primary:hover,
body.dark-theme .page-body:has(#ec-meal-summary-hub) .btn.btn-primary:focus,
body.dark-theme .page-body:has(#ec-meal-summary-hub) .btn-group .btn.btn-primary:hover,
body.dark-theme .page-body:has(#ec-meal-summary-hub) .btn-group .btn.btn-primary:focus,
body.dark-theme .page-body:has(.ec-meal-loc-view-toggle) .btn.btn-primary:hover,
body.dark-theme .page-body:has(.ec-meal-loc-view-toggle) .btn.btn-primary:focus {
    background: #3aa672 !important;
    border-color: #3aa672 !important;
    color: #fff !important;
}
body.dark-theme .page-body:has(#ec-meal-summary-hub) .ec-meal-summary-hub__pills .nav-link.ec-meal-summary-hub__pill.active {
    background: #2d8a5e !important;
    border-color: #2d8a5e !important;
    box-shadow: none !important;
}
.ec-meal-summary-hub--tabs .ec-meal-summary-hub__tab-content {
    background: transparent;
}
#ec-meal-summary-hub .card-body + .card-header.ec-card-header-hero.ec-card-header-hero--split {
    margin: 1rem 1rem 0;
    border-top: 0 !important;
    border-radius: 0.5rem 0.5rem 0 0 !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    border-bottom: 0 !important;
}
#ec-meal-summary-hub .card-body + .card-header.ec-card-header-hero.ec-card-header-hero--split + .card-body {
    margin: 0 1rem 1rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-top: 0;
    border-radius: 0 0 0.5rem 0.5rem;
    background: #fff;
}
body.dark-theme #ec-meal-summary-hub .card-body + .card-header.ec-card-header-hero.ec-card-header-hero--split {
    border-color: rgba(255, 255, 255, 0.12) !important;
}
body.dark-theme #ec-meal-summary-hub .card-body + .card-header.ec-card-header-hero.ec-card-header-hero--split + .card-body {
    border-color: rgba(255, 255, 255, 0.12);
    background: #1e2128;
}

/* Refeições — vista unificada /meals: matrizes largas (hub / parciais) — scroll horizontal fiável.
   Ancestors em flex precisam de min-width:0 para o overflow-x do .table-responsive ser aplicado. */
#ec-meal-summary-hub,
#ec-meal-summary-hub .tab-content,
#ec-meal-summary-hub .tab-pane,
#ec-meal-participant-matrices-root,
#ec-meal-participant-loaded,
#ec-stay-summary-hub,
#ec-stay-summary-hub .tab-content,
#ec-stay-summary-hub .tab-pane {
    min-width: 0;
}

/* Resumo estadia (/events/…/participants/stay): títulos de secção + rodapé de contexto */
.ec-participants-stay-summary .ec-stay-summary-section-title {
    font-size: 0.72rem;
    letter-spacing: 0.055em;
    text-transform: uppercase;
    color: #5c6570;
    font-weight: 700;
    margin-bottom: 0.35rem;
}
body.dark-theme .ec-participants-stay-summary .ec-stay-summary-section-title {
    color: #9aa7bc;
}
.ec-participants-stay-summary .ec-stay-summary-footnote {
    background: rgba(248, 250, 252, 0.96);
    border-top-color: rgba(0, 0, 0, 0.07) !important;
}
body.dark-theme .ec-participants-stay-summary .ec-stay-summary-footnote {
    background: rgba(30, 34, 42, 0.72);
    border-top-color: rgba(255, 255, 255, 0.09) !important;
}
body.dark-theme .ec-participants-stay-summary .ec-stay-summary-footnote .text-muted {
    color: #adb5c2 !important;
}

/* Estadia — visão geral (/events/…/participants/stay): calendário semanal */
.ec-stay-overview-page .ec-stay-overview-calendar-card .card-body {
    min-width: 0;
}

/* Refeições — vista /events/…/meals (hero + corpo) */
.ec-meal-overview-page .ec-meal-overview-calendar-card .card-body,
.ec-meals-overview-page .ec-meal-overview-calendar-card .card-body {
    min-width: 0;
}
.ec-participants-meal-summary .ec-meal-summary-section-title {
    font-size: 0.72rem;
    letter-spacing: 0.055em;
    text-transform: uppercase;
    color: #5c6570;
    font-weight: 700;
    margin-bottom: 0.35rem;
}
body.dark-theme .ec-participants-meal-summary .ec-meal-summary-section-title {
    color: #9aa7bc;
}
.ec-stay-cal-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.25rem;
}
.ec-stay-cal-weekday-row {
    display: grid;
    grid-template-columns: repeat(7, minmax(7.5rem, 1fr));
    gap: 0.35rem;
    margin-bottom: 0.35rem;
}
.ec-stay-cal-weekday {
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #6c757d;
    text-align: center;
    padding: 0.25rem 0;
}
.ec-stay-cal-week {
    display: grid;
    grid-template-columns: repeat(7, minmax(7.5rem, 1fr));
    gap: 0.35rem;
    margin-bottom: 0.35rem;
}
.ec-stay-cal-cell {
    border: 1px solid #e2e6ea;
    border-radius: 10px;
    background: #fff;
    padding: 0.5rem 0.55rem 0.6rem;
    min-height: 6.5rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}
.ec-stay-cal-cell--empty {
    background: rgba(248, 249, 250, 0.65);
    border-style: dashed;
    border-color: #e8ecef;
    min-height: 4rem;
}
.ec-stay-cal-cell--has-stays {
    background: linear-gradient(165deg, #eef8f1 0%, #e4f3ea 52%, #dcf0e4 100%);
    border-color: rgba(45, 106, 79, 0.32);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
}
.ec-stay-cal-cell-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.35rem;
}
.ec-stay-cal-dow {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ec-stay-cal-date {
    font-size: 0.95rem;
}
.ec-stay-cal-total {
    margin-top: 0.25rem;
}
.ec-stay-cal-total-badge {
    display: block;
    width: 100%;
    max-width: 100%;
    font-size: 0.68rem;
    font-weight: 600;
    line-height: 1.3;
    white-space: normal;
    text-align: left;
    border-radius: 0.45rem;
    padding: 0.35rem 0.45rem;
    hyphens: auto;
}
body.dark-theme .ec-stay-cal-total-badge {
    background-color: #2d6a4f;
    color: #fff;
}
body.dark-theme .ec-stay-cal-needs-unmet-badge {
    background-color: #e8a317;
    color: #1a1e24 !important;
    border: 1px solid rgba(0, 0, 0, 0.12);
}

/* Refeições — calendário: muitos locais por dia (lista rolável, célula com altura contida) */
.ec-meal-overview-page .ec-stay-cal-cell,
.ec-meals-overview-page .ec-stay-cal-cell {
    min-height: 6.5rem;
    max-height: 15.5rem;
}
.ec-meal-overview-page .ec-stay-cal-loc-list,
.ec-meals-overview-page .ec-stay-cal-loc-list {
    flex: 1 1 auto;
    min-height: 0;
    max-height: 9.25rem;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-gutter: stable;
}
.ec-meal-overview-page .ec-stay-cal-needs-unmet-wrap,
.ec-meals-overview-page .ec-stay-cal-needs-unmet-wrap {
    flex-shrink: 0;
}

/* Matriz participantes — coluna «Em falta» */
.ec-meal-overview-page .ec-meal-overview-gap-th,
.ec-meals-overview-page .ec-meal-overview-gap-th {
    font-weight: 800;
    color: #92400e;
}
.ec-meal-overview-page .ec-meal-needs-gap--positive,
.ec-meals-overview-page .ec-meal-needs-gap--positive {
    font-weight: 800;
    color: #b45309;
    background: rgba(251, 191, 36, 0.22);
    border-radius: 0.35rem;
}
body.dark-theme .ec-meal-overview-page .ec-meal-overview-gap-th,
body.dark-theme .ec-meals-overview-page .ec-meal-overview-gap-th {
    color: #fbbf24;
}
body.dark-theme .ec-meal-overview-page .ec-meal-needs-gap--positive,
body.dark-theme .ec-meals-overview-page .ec-meal-needs-gap--positive {
    color: #fde68a;
    background: rgba(180, 83, 9, 0.28);
}

/* Meal overview — cartão unificado (título + KPIs) */
.ec-meal-overview-page .ec-meals-overview-kpi-card,
.ec-meals-overview-page .ec-meals-overview-kpi-card {
    border-radius: 14px;
}
.ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar,
.ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar {
    width: 100%;
}
@media (min-width: 768px) {
    .ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar,
    .ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar {
        width: auto;
    }
}
@media (max-width: 767.98px) {
    .ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar,
    .ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar {
        padding-top: 0.35rem;
        border-top: 1px solid rgba(0, 0, 0, 0.06);
    }
    body.dark-theme .ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar,
    body.dark-theme .ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-overview-kpi-toolbar {
        border-top-color: rgba(255, 255, 255, 0.08);
    }
}
.ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-3,
.ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-3 {
    grid-template-columns: 1fr;
    gap: 0.75rem;
}
.ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-4,
.ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-4 {
    grid-template-columns: 1fr;
    gap: 0.75rem;
}
.ec-stay-overview-page .ec-stay-overview-kpi-card .ec-meals-kpi-grid-4 {
    grid-template-columns: 1fr;
    gap: 0.75rem;
}
@media (min-width: 768px) {
    .ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-3,
    .ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .ec-meal-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-4,
    .ec-meals-overview-page .ec-meals-overview-kpi-card .ec-meals-kpi-grid-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .ec-stay-overview-page .ec-stay-overview-kpi-card .ec-meals-kpi-grid-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}
.ec-meal-overview-page .ec-meal-overview-kpi-tile,
.ec-meals-overview-page .ec-meal-overview-kpi-tile {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    min-height: 4.85rem;
    padding: 1rem 1.05rem;
    border-radius: 12px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.07);
    box-shadow: 0 1px 2px rgba(62, 85, 120, 0.06);
}
.ec-meal-overview-page .ec-meal-overview-kpi-tile .ec-meal-overview-kpi-value,
.ec-meals-overview-page .ec-meal-overview-kpi-tile .ec-meal-overview-kpi-value {
    font-size: 1.5rem;
    font-variant-numeric: tabular-nums;
}
.ec-meal-overview-page .ec-meal-overview-kpi-tile--needs,
.ec-meals-overview-page .ec-meal-overview-kpi-tile--needs {
    border-left: 4px solid #2563eb;
}
.ec-meal-overview-page .ec-meal-overview-kpi-tile--gap,
.ec-meals-overview-page .ec-meal-overview-kpi-tile--gap {
    border-left: 4px solid #94a3b8;
}
.ec-meal-overview-page .ec-meal-overview-kpi-tile--gap.ec-meal-overview-kpi-tile--gap-alert,
.ec-meals-overview-page .ec-meal-overview-kpi-tile--gap.ec-meal-overview-kpi-tile--gap-alert {
    border-left-color: #d97706;
    background: linear-gradient(90deg, rgba(254, 243, 199, 0.45) 0%, #fff 52%);
}
.ec-meal-overview-page .ec-meal-overview-kpi-tile--assigned,
.ec-meals-overview-page .ec-meal-overview-kpi-tile--assigned {
    border-left: 4px solid #059669;
}
body.dark-theme .ec-meal-overview-page .ec-meal-overview-kpi-tile,
body.dark-theme .ec-meals-overview-page .ec-meal-overview-kpi-tile {
    background: rgba(40, 44, 52, 0.96);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}
body.dark-theme .ec-meal-overview-page .ec-meal-overview-kpi-tile--gap.ec-meal-overview-kpi-tile--gap-alert,
body.dark-theme .ec-meals-overview-page .ec-meal-overview-kpi-tile--gap.ec-meal-overview-kpi-tile--gap-alert {
    border-left-color: #fbbf24;
    background: linear-gradient(90deg, rgba(180, 83, 9, 0.22) 0%, rgba(40, 44, 52, 0.96) 55%);
}
body.dark-theme .ec-meal-overview-page .ec-meal-overview-kpi-tile .text-warning,
body.dark-theme .ec-meals-overview-page .ec-meal-overview-kpi-tile .text-warning {
    color: #fbbf24 !important;
}
body.dark-theme .ec-meal-overview-page .ec-meal-overview-kpi-tile .text-success,
body.dark-theme .ec-meals-overview-page .ec-meal-overview-kpi-tile .text-success {
    color: #6ee7b7 !important;
}

/* Locais de refeição — lista admin (DataTables + tabela) */
.ec-meal-locs-admin-page .ec-meal-locs-main-card {
    border-radius: 0.75rem;
    overflow: hidden;
}
.ec-meal-locs-admin-page .ec-meal-locs-loc-card {
    border: 1px solid rgba(0, 0, 0, 0.07);
}
.ec-meal-locs-admin-page .ec-meal-locs-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap {
    background: #eef2f6;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap .dataTables_wrapper {
    padding: 0.75rem 1rem 0.6rem;
}
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap .dataTables_wrapper > .row:first-child {
    margin-bottom: 0.65rem;
    align-items: center;
}
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap .dataTables_wrapper .dataTables_length,
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap .dataTables_wrapper .dataTables_filter {
    margin-bottom: 0;
}
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap .dataTables_wrapper .dataTables_filter input {
    min-width: 10.5rem;
    border-radius: 0.375rem;
}
.ec-meal-locs-admin-page .ec-meal-locs-table-wrap .dataTables_wrapper table.dataTable {
    margin-top: 0 !important;
    margin-bottom: 0.4rem !important;
}
.ec-meal-locs-admin-page .ec-meal-locs-table.ec-meal-locs-table {
    border-collapse: separate;
    border-spacing: 0;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(62, 85, 120, 0.06);
}
.ec-meal-locs-admin-page .ec-meal-locs-table thead th {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #64748b;
    font-weight: 700;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    vertical-align: middle;
}
.ec-meal-locs-admin-page .ec-meal-locs-table tbody td {
    border-top: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    vertical-align: middle;
}
.ec-meal-locs-admin-page .ec-meal-locs-table tbody tr:last-child td {
    border-bottom: 0;
}
.ec-meal-locs-admin-page .ec-meal-locs-table tbody tr:hover td {
    background: rgba(248, 250, 252, 0.98);
}
.ec-meal-locs-admin-page .ec-meal-locs-desc {
    display: inline-block;
    max-width: 22rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: bottom;
}
.ec-meal-locs-admin-page .ec-meal-locs-actions {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
}
.ec-meal-locs-admin-page .ec-meal-loc-open-btn,
.ec-meal-locs-admin-page .ec-meal-loc-delete-btn {
    border-radius: 0.4rem;
    font-weight: 600;
}
.ec-meal-locs-admin-page .ec-meal-loc-delete-btn {
    color: #842029;
    border-color: #f1c2c7;
    background: #fff5f6;
}
.ec-meal-locs-admin-page .ec-meal-loc-delete-btn:hover {
    color: #7a1c27;
    border-color: #e7aab2;
    background: #ffecef;
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-locs-loc-card {
    border-color: rgba(255, 255, 255, 0.1);
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-locs-table-wrap {
    background: #1a1f26;
    border-top-color: rgba(255, 255, 255, 0.07);
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-locs-table.ec-meal-locs-table {
    background: #22262e;
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-locs-table thead th {
    background: #2c3139 !important;
    color: #94a3b8;
    border-bottom-color: rgba(255, 255, 255, 0.1);
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-locs-table tbody td {
    border-bottom-color: rgba(255, 255, 255, 0.07);
    color: #e2e8f0;
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-locs-table tbody tr:hover td {
    background: rgba(40, 45, 56, 0.95);
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-loc-delete-btn {
    color: #ffb3bc;
    border-color: #7a3b46;
    background: #3a2328;
}
body.dark-theme .ec-meal-locs-admin-page .ec-meal-loc-delete-btn:hover {
    border-color: #8b4753;
    background: #43292f;
}

.ec-stay-cal-loc-line {
    padding: 0.15rem 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.ec-stay-cal-loc-line:last-child {
    border-bottom: none;
}
.ec-meal-overview-page .ec-stay-cal-loc-line,
.ec-meals-overview-page .ec-stay-cal-loc-line {
    padding: 0.1rem 0;
}
.ec-stay-cal-loc-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
    color: #1a4d38;
    font-weight: 600;
    text-decoration: none;
}
.ec-stay-cal-loc-name:hover,
.ec-stay-cal-loc-name:focus {
    color: #0f3d2b;
    text-decoration: underline;
}
body.dark-theme .ec-stay-cal-loc-name {
    color: #bfe3cf;
}
body.dark-theme .ec-stay-cal-loc-name:hover,
body.dark-theme .ec-stay-cal-loc-name:focus {
    color: #5fd0a5;
}
body.dark-theme .ec-stay-cal-cell {
    background: #272b33;
    border-color: #404652;
}
body.dark-theme .ec-stay-cal-cell--has-stays {
    background: linear-gradient(165deg, #24362c 0%, #1c2b24 55%, #18261f 100%);
    border-color: rgba(79, 170, 83, 0.42);
    box-shadow: inset 0 0 0 1px rgba(79, 170, 83, 0.14);
}
body.dark-theme .ec-stay-cal-cell--empty {
    background: rgba(30, 34, 42, 0.5);
    border-color: #3d4450;
}
body.dark-theme .ec-stay-cal-weekday {
    color: #9aa3b8;
}
body.dark-theme .ec-stay-cal-loc-line {
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

/* Locais de estadia (/events/…/stay-locations): rodapé com atalho matriz */
.ec-stay-locations-page .ec-stay-loc-list-footer {
    background: rgba(248, 250, 252, 0.96);
    border-top-color: rgba(0, 0, 0, 0.07) !important;
}
body.dark-theme .ec-stay-locations-page .ec-stay-loc-list-footer {
    background: rgba(30, 34, 42, 0.72);
    border-top-color: rgba(255, 255, 255, 0.09) !important;
}
body.dark-theme .ec-stay-locations-page .ec-stay-loc-list-footer a.text-muted {
    color: #adb5c2 !important;
}
body.dark-theme .ec-stay-locations-page .ec-stay-loc-list-footer a.text-muted:hover {
    color: #5fd0a5 !important;
}
#ec-meal-summary-hub .table-responsive,
#ec-meal-participant-loaded .table-responsive,
#ec-stay-summary-hub .table-responsive {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
}
#ec-meal-summary-hub .table-responsive > .table,
#ec-meal-participant-loaded .table-responsive > .table,
#ec-stay-summary-hub .table-responsive > .table {
    width: max-content;
    min-width: 100%;
    margin-bottom: 0;
}

/* Matrizes do resumo: texto/link .text-dark legível no tema escuro */
body.dark-theme #ec-meal-summary-hub .text-dark,
body.dark-theme #ec-meal-participant-loaded .text-dark,
body.dark-theme #ec-stay-summary-hub .text-dark {
    color: #e6edf9 !important;
}
body.dark-theme #ec-meal-summary-hub a.text-dark:hover,
body.dark-theme #ec-meal-participant-loaded a.text-dark:hover,
body.dark-theme #ec-stay-summary-hub a.text-dark:hover {
    color: #5fd0a5 !important;
}

/* Ecrãs estreitos: quebra de linha em vez de scroll horizontal — scroll cortava os dropdowns */
@media (max-width: 576px) {
    .ec-section-nav-wrap {
        overflow-x: visible;
        overflow-y: visible;
        padding-bottom: 0.2rem;
        margin-left: -0.15rem;
        margin-right: -0.15rem;
        padding-left: 0.15rem;
        padding-right: 0.15rem;
    }
    .ec-section-nav {
        flex-wrap: wrap;
        width: 100%;
        max-width: 100%;
    }
}

/* Permissão refeição (Quem pode comer): bolas por célula */
.ec-perm-dot {
    display: inline-block;
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 50%;
    vertical-align: middle;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
}
.ec-perm-dot--ok {
    background: linear-gradient(135deg, #34c38f 0%, #28a745 100%);
}
.ec-perm-dot--warn {
    background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%);
}
.ec-perm-dot--no {
    background: #ced4da;
}
.ec-perm-dot--pblock {
    background: linear-gradient(135deg, #ff6b6b 0%, #dc3545 100%);
}
button.ec-perm-slot-toggle.ec-perm-dot--ok {
    background: linear-gradient(135deg, #34c38f 0%, #28a745 100%);
}
button.ec-perm-slot-toggle.ec-perm-dot--warn {
    background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%);
}
button.ec-perm-slot-toggle.ec-perm-dot--no {
    background: #ced4da;
}
button.ec-perm-slot-toggle.ec-perm-dot--pblock {
    background: linear-gradient(135deg, #ff6b6b 0%, #dc3545 100%);
}
.ec-perm-slot--over-cap {
    box-shadow: 0 0 0 2px #dc3545, 0 0 0 4px rgba(220, 53, 69, 0.22);
}
.dark-theme .ec-perm-slot--over-cap {
    box-shadow: 0 0 0 2px #ff6b6b, 0 0 0 4px rgba(255, 107, 107, 0.35);
}
/* Não usar background:transparent no botão — apagava o verde/cinzento das bolinhas. */
button.ec-perm-slot-toggle {
    cursor: pointer;
    padding: 0;
    border: none;
    font: inherit;
    line-height: 1;
    -webkit-appearance: none;
    appearance: none;
}
button.ec-perm-slot-toggle:focus {
    outline: 2px solid rgba(95, 208, 165, 0.55);
    outline-offset: 2px;
}
.dark-theme .ec-perm-dot--no {
    background: #5a6270;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.dark-theme .ec-perm-dot--pblock {
    background: linear-gradient(135deg, #ff8787 0%, #e55353 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.dark-theme button.ec-perm-slot-toggle.ec-perm-dot--no {
    background: #5a6270;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.dark-theme button.ec-perm-slot-toggle.ec-perm-dot--pblock {
    background: linear-gradient(135deg, #ff8787 0%, #e55353 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.ec-perm-legend .ec-perm-dot {
    margin-right: 0;
}
.ec-perm-legend-dot-wrap {
    flex-shrink: 0;
    width: 0.65rem;
    padding-top: 0.2rem;
}
.ec-perm-legend-label {
    font-weight: 600;
    font-size: 0.875rem;
}
.ec-perm-legend-label--ok {
    color: #155724;
}
.ec-perm-legend-label--warn {
    color: #856404;
}
.ec-perm-legend-label--no {
    color: #6c757d;
}
.ec-perm-legend-label--pblock {
    color: #c82333;
}
.ec-perm-legend-detail {
    font-size: 0.8125rem;
}

/* Uma bola por período de serviço (meal_location_windows) nesse dia no local */
.ec-meal-slot-dots {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 3px;
    max-width: 8.5rem;
    line-height: 1;
}
.ec-meal-loc-day .ec-meal-slot-dots {
    max-width: 5.5rem;
    margin-top: 0.25rem;
}
.ec-meal-slot-dot {
    display: inline-block;
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    flex-shrink: 0;
    background: linear-gradient(135deg, #6c8eef 0%, #4c6ef5 100%);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}
.ec-meal-slot-dots--hinted .ec-meal-slot-dot {
    cursor: help;
}
.ec-meal-slot-dots-more {
    font-size: 0.65rem;
    font-weight: 700;
    color: #495057;
    margin-left: 1px;
}
.dark-theme .ec-meal-slot-dot {
    background: linear-gradient(135deg, #90a4ff 0%, #5c7cfa 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.dark-theme .ec-meal-slot-dots-more {
    color: #c0c9d8;
}
.ec-meal-slot-legend-dots .ec-meal-slot-dots {
    max-width: none;
    justify-content: flex-start;
}
.dark-theme .ec-perm-legend-label--ok {
    color: #b9f6ca;
}
.dark-theme .ec-perm-legend-label--warn {
    color: #ffe69c;
}
.dark-theme .ec-perm-legend-label--no {
    color: #c0c9d8;
}
.dark-theme .ec-perm-legend-label--pblock {
    color: #ff8a8a;
}
.dark-theme .ec-perm-legend-detail.text-muted {
    color: #9aa7bc !important;
}
.dark-theme .ec-perm-legend.border-top {
    background: #272c35 !important;
    border-color: #3c4554 !important;
    color: #aeb6c6 !important;
}
.dark-theme .ec-perm-legend .font-weight-bold.text-dark {
    color: #e8ecf4 !important;
}

/* Permissões refeição: alternar vista restaurante / participante */
.ec-elig-perspective {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.35rem;
    flex-shrink: 0;
}
.ec-elig-perspective__label {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #6c757d;
    line-height: 1.2;
}
.ec-elig-perspective__btns .btn-sm {
    font-weight: 600;
    white-space: nowrap;
}
@media (max-width: 575.98px) {
    .ec-elig-perspective {
        align-items: stretch;
        width: 100%;
    }
    .ec-elig-perspective__btns {
        display: flex;
        width: 100%;
    }
    .ec-elig-perspective__btns > .btn,
    .ec-elig-perspective__btns > span.btn {
        flex: 1 1 0;
        text-align: center;
    }
}
.dark-theme .ec-elig-perspective__label {
    color: #9aa7bc;
}

/* Quem comeu: cores por permissão + consumo diário */
.ec-guest-dot {
    display: inline-block;
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 50%;
    vertical-align: middle;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
}
.ec-guest-dot--green {
    background: linear-gradient(135deg, #34c38f 0%, #28a745 100%);
}
.ec-guest-dot--blue {
    background: linear-gradient(135deg, #4dabf7 0%, #1c7ed6 100%);
}
.ec-guest-dot--yellow {
    background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%);
}
.ec-guest-dot--none {
    background: #ced4da;
}
.dark-theme .ec-guest-dot--none {
    background: #5a6270;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
}
.dark-theme .ec-guest-legend.border-top {
    background: #272c35 !important;
    border-color: #3c4554 !important;
}

.ec-elig-page-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
@media (min-width: 576px) {
    .ec-elig-page-actions {
        gap: 0.65rem;
    }
}

/* ----- Links no conteúdo: contraste legível (fora do breadcrumb / sidebar) ----- */
.connect-container .page-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link),
.connect-container .page-content .card-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link) {
    text-decoration-skip-ink: auto;
}

/* Modo claro: verde mais escuro sobre fundo claro (WCAG) */
body:not(.dark-theme) .connect-container .page-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link),
body:not(.dark-theme) .connect-container .page-content .card-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link),
body:not(.dark-theme) .connect-container .auth-form a:not(.btn):not(.logo-text):not(.close),
body:not(.dark-theme) .connect-container .page-content .table a:not(.btn):not(.badge) {
    color: #0f5c44;
    font-weight: 500;
}

body:not(.dark-theme) .connect-container .page-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link):hover,
body:not(.dark-theme) .connect-container .page-content .card-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link):hover,
body:not(.dark-theme) .connect-container .auth-form a:not(.btn):not(.logo-text):not(.close):hover,
body:not(.dark-theme) .connect-container .page-content .table a:not(.btn):not(.badge):hover {
    color: #0a4030;
    text-decoration: underline;
}

/* Bootstrap: links com text-muted / text-body em tabelas e listas */
body:not(.dark-theme) .connect-container .page-content .table a.text-muted,
body:not(.dark-theme) .connect-container .page-content .table a.text-body {
    color: #0f5c44 !important;
}

body:not(.dark-theme) .connect-container .page-content .table a.text-muted:hover,
body:not(.dark-theme) .connect-container .page-content .table a.text-body:hover {
    color: #0a4030 !important;
}

/* Modo escuro: azul claro legível; cobre page-body, cartões e portal */
body.dark-theme .connect-container .page-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link),
body.dark-theme .connect-container .page-content .card-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link),
body.dark-theme .connect-container .auth-form a:not(.btn):not(.logo-text):not(.close),
body.dark-theme .connect-container .page-content .table a:not(.btn):not(.badge),
body.dark-theme .connect-container.portal-cred-shell a:not(.btn):not(.logo-text):not(.nav-link):not(.page-link):not(.badge):not(.close):not(.portal-cred-brand):not(.portal-cred-switch-brand) {
    color: #9ed2ff;
    font-weight: 500;
}

body.dark-theme .connect-container .page-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link):hover,
body.dark-theme .connect-container .page-content .card-body a:not(.btn):not(.dropdown-item):not(.nav-link):not(.page-link):not(.badge):not(.logo-text):not(.list-group-item-action):not(.close):not(.alert-link):hover,
body.dark-theme .connect-container .auth-form a:not(.btn):not(.logo-text):not(.close):hover,
body.dark-theme .connect-container .page-content .table a:not(.btn):not(.badge):hover,
body.dark-theme .connect-container.portal-cred-shell a:not(.btn):not(.logo-text):not(.nav-link):not(.page-link):not(.badge):not(.close):not(.portal-cred-brand):not(.portal-cred-switch-brand):hover {
    color: #cfe9ff;
    text-decoration: underline;
}

body.dark-theme .connect-container .page-content .table a.text-muted,
body.dark-theme .connect-container .page-content .table a.text-body {
    color: #9ed2ff !important;
}

body.dark-theme .connect-container .page-content .table a.text-muted:hover,
body.dark-theme .connect-container .page-content .table a.text-body:hover {
    color: #cfe9ff !important;
}

/* Dark mode: texto cinzento legível na shell da app (placeholders mantêm regras ::placeholder em dark_theme.css) */
body.dark-theme .connect-container .page-content,
body.dark-theme .connect-container .page-body {
    color: #d1d6e0;
}

body.dark-theme .connect-container .text-muted {
    color: #aeb6c6 !important;
}

body.dark-theme .connect-container .text-secondary {
    color: #b8c0ce !important;
}

body.dark-theme .connect-container .text-dark {
    color: #e8ecf4 !important;
}

body.dark-theme .connect-container .card-body,
body.dark-theme .connect-container .card-header:not(.bg-primary):not(.bg-success):not(.bg-danger):not(.bg-warning):not(.bg-info) {
    color: #d1d6e0;
}

body.dark-theme .connect-container label:not(.btn):not(.custom-control-label) {
    color: #e0e4ee;
}

body.dark-theme .connect-container .custom-control-label {
    color: #dce0ea;
}

body.dark-theme .connect-container .form-text {
    color: #aeb6c6 !important;
}

body.dark-theme .connect-container .page-footer,
body.dark-theme .connect-container .page-footer .footer-text {
    color: #9aa3b4;
}

body.dark-theme .connect-container .thead-light th {
    color: #c8d0de !important;
}

body.dark-theme .connect-container .ec-audit-table thead th {
    color: #c8d0de !important;
}

/* ----- Cabeçalho global: menu lateral em mobile (hamburger do tema connect.js) ----- */
.ec-app-navbar-inner {
    gap: 0.25rem;
}

/* Cabeçalho: Select2 (largura do wrap; o <select> fica width:100%) */
.ec-header-select2-wrap {
    min-width: 230px;
    flex: 1 1 auto;
}

.ec-subscription-scope-select,
.ec-header-event-select,
.ec-header-participant-select {
    min-width: 0;
}

/* Superadmin: contexto de subscrição + vista de utilizador (destaque no header) */
.ec-superadmin-header-cluster {
    padding: 0.25rem 0.55rem;
    border-radius: 0.5rem;
    background: linear-gradient(
        135deg,
        rgba(109, 40, 217, 0.1),
        rgba(37, 99, 235, 0.09)
    );
    border: 1px solid rgba(109, 40, 217, 0.28);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
}

.ec-superadmin-header-inner {
    gap: 0.45rem 0.65rem;
}

.ec-superadmin-header-tool {
    min-width: 0;
}

.ec-superadmin-header-label {
    color: #5b21b6 !important;
    font-weight: 600;
    white-space: nowrap;
}

.ec-superadmin-select-wrap {
    min-width: 160px;
}

.ec-superadmin-header-cluster .select2-container--default .select2-selection--single {
    border-radius: 2rem !important;
    border-color: rgba(109, 40, 217, 0.4) !important;
    background-color: rgba(255, 255, 255, 0.92) !important;
}

.ec-superadmin-header-cluster .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #4c1d95;
}

.ec-superadmin-header-cluster .select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #6d28d9 transparent transparent transparent;
}

body.dark-theme .ec-superadmin-header-cluster {
    background: linear-gradient(
        135deg,
        rgba(167, 139, 250, 0.14),
        rgba(96, 165, 250, 0.1)
    );
    border-color: rgba(167, 139, 250, 0.42);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06) inset;
}

body.dark-theme .ec-superadmin-header-label {
    color: #ddd6fe !important;
}

body.dark-theme .ec-superadmin-header-cluster .select2-container--default .select2-selection--single {
    border-radius: 2rem !important;
    background-color: rgba(24, 22, 36, 0.92) !important;
    border-color: rgba(167, 139, 250, 0.45) !important;
}

body.dark-theme .ec-superadmin-header-cluster .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #e9d5ff;
}

body.dark-theme .ec-superadmin-header-cluster .select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #c4b5fd transparent transparent transparent;
}

.ec-nav-profile-toggle {
    max-width: 12rem;
}

@media (max-width: 1199.98px) {
    .connect-container .ec-app-header .ec-app-navbar-inner {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .ec-app-header-tools {
        min-width: 0;
        flex: 1 1 auto;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        justify-content: flex-end;
    }

    .ec-mobile-sidebar-toggle {
        min-width: 44px;
        min-height: 44px;
        justify-content: center;
        border-radius: 0.5rem;
    }

    .ec-header-select2-wrap {
        min-width: 0 !important;
        max-width: min(46vw, 220px);
    }

    .ec-app-header-tools .select2-container {
        max-width: min(46vw, 220px);
    }

    .ec-nav-profile-toggle {
        max-width: 5rem;
        padding-left: 0.35rem !important;
        padding-right: 0.35rem !important;
    }

    .ec-nav-profile-toggle .dropdown-icon {
        display: none;
    }

    .ec-nav-profile-toggle img {
        margin-right: 0 !important;
    }
}

body.dark-theme .ec-mobile-sidebar-toggle {
    color: #c8d0de;
}

body.dark-theme .ec-mobile-sidebar-toggle:hover,
body.dark-theme .ec-mobile-sidebar-toggle:focus {
    color: #5fd0a5;
    background: rgba(95, 208, 165, 0.1);
}

/* ----- Tabelas em mobile / ecrãs estreitos: scroll horizontal legível e toque ----- */
.connect-container .table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
}

.connect-container .table-responsive > .table {
    width: max-content;
    min-width: 100%;
    margin-bottom: 0;
}

@media (max-width: 767.98px) {
    .connect-container .table-responsive {
        border-radius: 0.5rem;
        border: 1px solid rgba(0, 0, 0, 0.06);
        background: #fff;
    }

    .connect-container .table-responsive > .table {
        font-size: 0.8125rem;
    }

    .connect-container .table-responsive > .table th,
    .connect-container .table-responsive > .table td {
        padding: 0.45rem 0.55rem;
        vertical-align: middle;
    }

    .connect-container .table-responsive > .table .btn {
        white-space: nowrap;
    }

    .connect-container .table-responsive > .table .btn-sm {
        padding: 0.35rem 0.55rem;
        font-size: 0.78rem;
    }

    .connect-container .card > .table-responsive {
        border: 0;
        border-radius: 0;
        border-top: 1px solid rgba(0, 0, 0, 0.06);
        background: transparent;
    }

    .connect-container .card > .table-responsive:first-child {
        border-top: 0;
    }
}

body.dark-theme .connect-container .table-responsive {
    scrollbar-color: #4a505c #272b33;
}

body.dark-theme .connect-container .table-responsive::-webkit-scrollbar {
    height: 6px;
}

body.dark-theme .connect-container .table-responsive::-webkit-scrollbar-thumb {
    background: #4a505c;
    border-radius: 4px;
}

body.dark-theme .connect-container .table-responsive::-webkit-scrollbar-track {
    background: #272b33;
}

@media (max-width: 767.98px) {
    body.dark-theme .connect-container .table-responsive {
        border-color: rgba(255, 255, 255, 0.08);
        background: #1f2128;
    }

    body.dark-theme .connect-container .card > .table-responsive {
        border-top-color: rgba(255, 255, 255, 0.08);
    }
}

/* Botões e hiperligações: cursor em forma de mão (tema connect não define .btn; UA usa seta em <button>) */
a[href],
button:not(:disabled):not(.disabled),
input[type="button"]:not(:disabled):not(.disabled),
input[type="submit"]:not(:disabled):not(.disabled),
input[type="reset"]:not(:disabled):not(.disabled),
.btn:not(:disabled):not(.disabled),
[role="button"]:not([aria-disabled="true"]):not(.disabled),
.nav-link[href],
.dropdown-item:not(:disabled):not(.disabled),
.page-link:not(.disabled),
.list-group-item-action,
a.badge[href],
label.custom-control-label,
summary {
    cursor: pointer;
}

/* Menu lateral: substituir menta do Connect por índigo + ícones com aria-hidden (evita leitura «eventEventos») */
.connect-container .accordion-menu > li > a .ec-sidebar-nav-icon {
    margin-right: 0.5rem;
    vertical-align: middle;
    font-size: 1.25rem;
    line-height: 1;
    position: relative;
    top: 1px;
}
.connect-container .accordion-menu li.open > a {
    color: #3949ab;
}
.connect-container .accordion-menu li.open > a .material-icons-outlined,
.connect-container .accordion-menu li.open > a .ec-sidebar-nav-icon {
    color: #3949ab;
}
.connect-container .accordion-menu > li > a:hover,
.connect-container .accordion-menu > li.active-page > a {
    color: #1a237e;
    background: rgba(92, 107, 192, 0.1);
}
.connect-container .accordion-menu > li > a:hover .material-icons-outlined,
.connect-container .accordion-menu > li.active-page > a .material-icons-outlined,
.connect-container .accordion-menu > li.active-page > a .ec-sidebar-nav-icon {
    color: #3949ab;
}
.connect-container .accordion-menu li.active-page > a:only-child {
    background: linear-gradient(90deg, #303f9f 0%, #5c6bc0 48%, #7986cb 100%);
    color: #fff;
}
.connect-container .accordion-menu li.active-page > a:only-child .material-icons-outlined,
.connect-container .accordion-menu li.active-page > a:only-child .ec-sidebar-nav-icon {
    color: #fff !important;
}
.connect-container .logo-box a.logo-text {
    color: #3949ab;
}
.connect-container .logo-box a.logo-text:hover {
    color: #1a237e;
}
.connect-container .logo-box a#sidebar-state:hover,
.connect-container .logo-box a#sidebar-close:hover {
    color: #3949ab;
}
.connect-container .compact-sidebar .accordion-menu ul li a:hover,
.connect-container .compact-sidebar .accordion-menu ul li a.active {
    color: #3949ab;
}

/* Terminar sessão no menu lateral (mesmo aspeto que os restantes itens) */
.accordion-menu > li.ec-sidebar-logout > form.ec-sidebar-logout-form {
    margin: 0;
    padding: 0;
}

.accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn {
    display: flex;
    align-items: center;
    width: 100%;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.6);
    text-align: left;
    padding: 12px 18px 12px 30px;
    font-size: inherit;
    font-family: inherit;
    line-height: inherit;
    cursor: pointer;
    transition: color 0.15s ease, background 0.15s ease;
}

.accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn .material-icons-outlined {
    margin-right: 15px;
    font-size: 22px;
    vertical-align: middle;
    opacity: 0.9;
}

/* Modo compacto (≥1200px): alinhar ao resto do menu — só ícone; rótulo no title do botão */
@media (min-width: 1200px) {
    .compact-sidebar .accordion-menu > li.ec-sidebar-logout > form.ec-sidebar-logout-form {
        width: 100%;
    }

    .compact-sidebar .accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn {
        justify-content: center;
        padding: 12px 8px;
    }

    .compact-sidebar .accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-label {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }

    .compact-sidebar .accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn .material-icons-outlined {
        margin-right: 0 !important;
    }
}

.accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn:hover,
.accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn:focus {
    color: rgba(255, 255, 255, 1);
    background: transparent;
    outline: none;
}

body:not(.dark-theme) .accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn {
    color: rgba(255, 255, 255, 0.6);
}

body:not(.dark-theme) .accordion-menu > li.ec-sidebar-logout .ec-sidebar-logout-btn:hover {
    color: #fff;
}

/* ----- Admin: estacionamento por participante (ficha dedicada) ----- */
.ec-parking-assign-page .ec-parking-assign-card {
    overflow: visible;
}

.ec-parking-assign-page .ec-parking-help {
    color: #6c757d;
    max-width: 42rem;
    line-height: 1.5;
}

.ec-parking-assign-page .ec-parking-field-label {
    color: #6c757d;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.ec-parking-assign-page .ec-parking-access-row {
    background: #f4f7fa;
    border-color: rgba(0, 0, 0, 0.07) !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ec-parking-assign-page .ec-parking-access-row:focus-within {
    border-color: rgba(95, 208, 165, 0.45) !important;
    box-shadow: 0 0 0 0.15rem rgba(95, 208, 165, 0.12);
}

.ec-parking-assign-page .ec-parking-plate-input {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    letter-spacing: 0.06em;
}

.ec-parking-assign-page .ec-parking-plate-qr-actions {
    gap: 0.35rem 0.5rem;
}

.ec-parking-assign-page .ec-parking-actions {
    border-color: rgba(0, 0, 0, 0.06) !important;
    gap: 0.5rem;
}

body.dark-theme .ec-parking-assign-page .ec-parking-help {
    color: #aeb6c6 !important;
}

body.dark-theme .ec-parking-assign-page .ec-parking-field-label {
    color: #c5cad8 !important;
}

body.dark-theme .ec-parking-assign-page .ec-parking-access-row {
    background: #2c323c;
    border-color: #3c4554 !important;
}

body.dark-theme .ec-parking-assign-page .ec-parking-access-row:focus-within {
    border-color: rgba(95, 208, 165, 0.5) !important;
    box-shadow: 0 0 0 0.15rem rgba(95, 208, 165, 0.14);
}

body.dark-theme .ec-parking-assign-page .ec-parking-actions {
    border-color: #3c4554 !important;
}

/* DataTables + Bootstrap 4: barra "Mostrar" / pesquisa — evitar overlap, cortes e row a sair do contentor */
div.dataTables_wrapper.dt-bootstrap4 > .row {
    margin-left: 0;
    margin-right: 0;
}

div.dataTables_wrapper.dt-bootstrap4 > .row > [class*="col-"] {
    padding-left: 10px;
    padding-right: 10px;
}

div.dataTables_wrapper div.dataTables_length,
div.dataTables_wrapper div.dataTables_filter {
    margin-bottom: 0.5rem;
}

div.dataTables_wrapper div.dataTables_length label,
div.dataTables_wrapper div.dataTables_filter label {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    white-space: normal;
    width: 100%;
    max-width: 100%;
    margin-bottom: 0;
}

div.dataTables_wrapper div.dataTables_length select {
    margin: 0 !important;
    flex: 0 0 auto;
    min-width: 4.25rem;
}

/* Largura / altura partilhadas: "Mostrar" (Select2) e "Pesquisar" ficam do mesmo tamanho */
div.dataTables_wrapper {
    --ec-dt-toolbar-control-max: min(100%, 15rem);
}

div.dataTables_wrapper div.dataTables_filter {
    text-align: left;
}

@media (min-width: 768px) {
    div.dataTables_wrapper div.dataTables_filter {
        text-align: right;
    }

    div.dataTables_wrapper div.dataTables_filter label {
        justify-content: flex-end;
        margin-left: auto;
    }
}

div.dataTables_wrapper div.dataTables_filter input.form-control {
    margin-left: 0 !important;
    flex: 0 1 auto;
    width: 100%;
    max-width: var(--ec-dt-toolbar-control-max);
    min-width: 0;
    box-sizing: border-box;
}

/* DataTables "Mostrar": Select2 alinhado ao texto do label (como toolbar) */
div.dataTables_wrapper div.dataTables_length .select2-container {
    display: inline-block;
    vertical-align: middle;
    min-width: 5.25rem;
    max-width: var(--ec-dt-toolbar-control-max);
    width: auto !important;
}

div.dataTables_wrapper div.dataTables_length .select2-container .select2-selection--single {
    min-height: calc(1.5em + 0.5rem + 2px);
    height: calc(1.5em + 0.5rem + 2px);
    padding-top: 0.125rem;
    padding-bottom: 0.125rem;
    border-radius: 2rem !important;
    border: 1px solid #ced4da !important;
    background-color: #fff !important;
}

body.dark-theme div.dataTables_wrapper div.dataTables_length .select2-container .select2-selection--single {
    border-color: #404652 !important;
    background-color: #1f2128 !important;
}

/* Menu "Mostrar N" (DataTables): o dropdown do Select2 fica no body e herda o realce
   azul (#5897fb) do select2.min.css; forçar paleta da app. */
.select2-dropdown.ec-dt-length-dropdown .select2-results__option--highlighted,
.select2-dropdown.ec-dt-length-dropdown
    .select2-results__option--highlighted.select2-results__option--selectable,
.select2-dropdown.ec-dt-length-dropdown
    .select2-results__option--highlighted[aria-selected] {
    background-color: #4faa53 !important;
    color: #fff !important;
}

body.dark-theme .select2-dropdown.ec-dt-length-dropdown .select2-results__option--highlighted,
body.dark-theme
    .select2-dropdown.ec-dt-length-dropdown
    .select2-results__option--highlighted.select2-results__option--selectable,
body.dark-theme
    .select2-dropdown.ec-dt-length-dropdown
    .select2-results__option--highlighted[aria-selected] {
    background-color: #4faa53 !important;
    color: #fff !important;
}

body:not(.dark-theme)
    div.dataTables_wrapper
    div.dataTables_length
    .select2-container.ec-dt-length-select2-container.select2-container--default.select2-container--focus
    .select2-selection--single,
body:not(.dark-theme)
    div.dataTables_wrapper
    div.dataTables_length
    .select2-container.ec-dt-length-select2-container.select2-container--default.select2-container--open
    .select2-selection--single {
    border-color: rgba(79, 170, 83, 0.6) !important;
    box-shadow: 0 0 0 0.2rem rgba(79, 170, 83, 0.25) !important;
}

body.dark-theme
    div.dataTables_wrapper
    div.dataTables_length
    .select2-container.ec-dt-length-select2-container.select2-container--default.select2-container--focus
    .select2-selection--single,
body.dark-theme
    div.dataTables_wrapper
    div.dataTables_length
    .select2-container.ec-dt-length-select2-container.select2-container--default.select2-container--open
    .select2-selection--single {
    border-color: rgba(95, 208, 165, 0.6) !important;
    box-shadow: 0 0 0 0.2rem rgba(95, 208, 165, 0.25) !important;
    background-color: #282a33 !important;
}

div.dataTables_wrapper div.dataTables_filter input.form-control.form-control-sm {
    min-height: calc(1.5em + 0.5rem + 2px);
    height: calc(1.5em + 0.5rem + 2px);
    line-height: 1.5;
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

/* --- Quiosque operador: dark mode (ec_theme_pref + prefers-color-scheme; classe no body) --- */
body.dark-theme.op-kiosk-body {
    background-color: #1f2128;
    color: #d1d6e0;
}

body.dark-theme.op-kiosk-body .op-kiosk-main {
    background-color: #1a1d24 !important;
}

body.dark-theme.op-kiosk-body:has(.op-store-shell) .op-kiosk-main {
    background: linear-gradient(160deg, #1a2420 0%, #152018 45%, #121a16 100%) !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-floating-actions .btn {
    background: rgba(39, 43, 51, 0.96) !important;
    border-color: #5c6575 !important;
    color: #d1d6e0 !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

body.dark-theme.op-kiosk-body .op-kiosk-footer {
    background: #272b33 !important;
    border-top-color: #404652 !important;
    color: #9aa3b8 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-banner {
    background: #272b33 !important;
    border-color: #404652 !important;
    color: #d1d6e0 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-banner .text-dark,
body.dark-theme.op-kiosk-body .op-kiosk-banner strong.text-dark {
    color: #e8ecf4 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-cred,
body.dark-theme.op-kiosk-body select.form-control,
body.dark-theme.op-kiosk-body .form-control[type="search"],
body.dark-theme.op-kiosk-body .form-control:not(.btn):not([type="checkbox"]):not([type="radio"]) {
    background-color: #1e2128 !important;
    border-color: #404652 !important;
    color: #e8ecf4 !important;
}

body.dark-theme.op-kiosk-body .form-control:focus {
    border-color: #5a7dca !important;
    box-shadow: 0 0 0 0.2rem rgba(90, 125, 202, 0.25) !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-result-panel .card {
    background-color: #272b33 !important;
    border-color: #404652 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-result-panel .card.bg-white {
    background-color: #272b33 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-participants-col .card {
    background-color: #272b33 !important;
    border-color: #404652 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-participants-col .list-group-item {
    background-color: #272b33;
    border-color: #404652;
    color: #d1d6e0;
}

body.dark-theme.op-kiosk-body .op-store-hero {
    background: #272b33 !important;
    border-color: rgba(79, 170, 83, 0.35) !important;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
}

body.dark-theme.op-kiosk-body .op-store-hero-title {
    color: #e8ecf4 !important;
}

body.dark-theme.op-kiosk-body .op-store-hero-sub,
body.dark-theme.op-kiosk-body .op-store-hero-sub .op-store-detail {
    color: #9aa3b8 !important;
}

body.dark-theme.op-kiosk-body .op-store-hero-sub .font-weight-bold.text-dark {
    color: #e8ecf4 !important;
}

body.dark-theme.op-kiosk-body .op-store-segmented {
    background: rgba(39, 43, 51, 0.85) !important;
    border-color: rgba(79, 170, 83, 0.28) !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}

body.dark-theme.op-kiosk-body .op-store-seg-btn {
    color: #c5cdd8 !important;
}

body.dark-theme.op-kiosk-body .op-store-seg-btn:not(.active):hover {
    background: rgba(255, 255, 255, 0.08) !important;
}

body.dark-theme.op-kiosk-body .op-store-panel {
    background: #272b33 !important;
    border-color: #404652 !important;
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.35) !important;
}

body.dark-theme.op-kiosk-body .op-store-panel-icon {
    background: linear-gradient(145deg, #2a3830 0%, #1e2a22 100%) !important;
    color: #7bdc8a !important;
}

body.dark-theme.op-kiosk-body .op-store-field-label {
    color: #9aa3b8 !important;
}

body.dark-theme.op-kiosk-body .op-store-panel .form-control-lg,
body.dark-theme.op-kiosk-body .op-store-panel .op-kiosk-cred {
    border-color: #404652 !important;
    background-color: #1e2128 !important;
    color: #e8ecf4 !important;
}

body.dark-theme.op-kiosk-body .op-store-panel .form-control-lg:focus {
    border-color: #4faa53 !important;
    box-shadow: 0 0 0 3px rgba(79, 170, 83, 0.25) !important;
}

body.dark-theme.op-kiosk-body .op-store-customer-bar {
    border-color: #404652 !important;
    background-color: #1e2128 !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3) !important;
}

body.dark-theme.op-kiosk-body .op-store-catalog {
    border-color: #404652 !important;
    box-shadow: 0 6px 22px rgba(0, 0, 0, 0.35) !important;
}

body.dark-theme.op-kiosk-body .op-store-catalog__cats {
    background: linear-gradient(180deg, #2a302c 0%, #222824 100%) !important;
    border-bottom-color: #404652 !important;
}

body.dark-theme.op-kiosk-body .op-store-catalog__grid {
    background: #1a1d24 !important;
}

body.dark-theme.op-kiosk-body .op-cons-prod-card {
    background: #272b33 !important;
    border-color: #404652 !important;
    color: #d1d6e0;
}

body.dark-theme.op-kiosk-body .op-cons-prod-card:hover,
body.dark-theme.op-kiosk-body .op-cons-prod-card:focus {
    border-color: #4faa53 !important;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.35) !important;
}

body.dark-theme.op-kiosk-body .op-cons-prod-card .op-cons-cost {
    color: #7bdc8a !important;
}

body.dark-theme.op-kiosk-body .op-cons-tabs .op-cons-tab-btn {
    background: #1e2128 !important;
    color: #c5cdd8 !important;
    border-color: #404652 !important;
    box-shadow: none;
}

body.dark-theme.op-kiosk-body .op-store-cart {
    border-color: #404652 !important;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.4) !important;
}

body.dark-theme.op-kiosk-body .op-store-cart__body {
    background: #1a1d24 !important;
    color: #d1d6e0;
}

body.dark-theme.op-kiosk-body .op-store-cart__foot {
    background: #272b33 !important;
    border-top-color: #404652 !important;
}

body.dark-theme.op-kiosk-body .op-store-cart-total {
    color: #7bdc8a !important;
}

body.dark-theme.op-kiosk-body .select2-container .select2-selection--single {
    border-color: #404652 !important;
    background-color: #1e2128 !important;
}

body.dark-theme.op-kiosk-body .select2-container .select2-selection--single .select2-selection__rendered {
    color: #e8ecf4 !important;
}

body.dark-theme.op-kiosk-body .op-kiosk-footer a {
    color: #8ab4f8;
}

body.dark-theme.op-kiosk-body .op-kiosk-footer a:hover {
    color: #a8c7ff;
}

/* Páginas legais (privacidade, termos, cookies): coluna de leitura ~52rem */
body.legal-public-page .legal-public-shell--narrow {
    max-width: 52rem;
    margin-left: auto;
    margin-right: auto;
}

/* Inscrição pública de participante: ocupar a largura do viewport em desktop */
@media (min-width: 992px) {
    body.legal-public-page .legal-public-shell--full {
        padding-left: clamp(1rem, 2.5vw, 2.5rem);
        padding-right: clamp(1rem, 2.5vw, 2.5rem);
    }
}

/* Marca global (static/images/icon/favicon.svg) + sidebar compacta só com ícone */
.logo-box a.logo-text.ec-site-brand-logo .ec-site-logo-img {
    width: 1.85rem;
    height: 1.85rem;
    object-fit: contain;
}
@media (min-width: 1200px) {
    .compact-sidebar .logo-box a.logo-text.ec-site-brand-logo {
        display: flex !important;
        justify-content: center;
        padding-left: 0.35rem;
        padding-right: 0.35rem;
    }
    .compact-sidebar .logo-box a.logo-text.ec-site-brand-logo .ec-site-logo-wordmark {
        display: none;
    }
    .compact-sidebar .logo-box a.logo-text.ec-site-brand-logo .ec-site-logo-img {
        margin-right: 0 !important;
    }
}
