@charset "UTF-8";
/**
 * Eco Igrejas Portugal
 * @author Carlos Coutinho, Atlantic Direction, Lda.
 * @version 1
 */
:root { /** Official EcoIgrejas Pantone **/
    --ei-colour-darkgreen: #005e1d;
    --ei-colour-darkgreen-rgb: 0, 94, 29;
    --ei-colour-lightgreen: #cdcd00;
    --ei-colour-cyan: #009999;
    --ei-colour-purple: #660099;
    --ei-colour-yellow: #ffbc0d;
    --ei-colour-orange: #f26a21;
    --ei-colour-red: #db0007;
    --ei-colour-brown: #643511;

    --ei-colour-arocha: #0097ce;

    --ei-colour-yellowbutton: #ffdb83;
    --bs-btn-bg: var(--ei-colour-yellowbutton);
    --bs-btn-hover-bg: var(--ei-colour-yellowbutton);

    --ei-colour-pearl: #f6f6f5;
    --ei-colour-fadeyellow: #ffefca;
    --ei-colour-fadegreen: #d5f1de;
    --ei-colour-table-border: #dee2e6;
    --ei-colour-table-striped: #f2f2f2;
    --ei-colour-table-hover: #e9ecef;
    --ei-colour-success: #198754;
    --ei-colour-error: #dc3545;
    --ei-colour-file-info: #495057;
    --ei-colour-file-progress: #0a3622;

    /** TO DELETE? **/
    --ei-colour-ambiental: var(--ei-colour-cyan);
    --ei-colour-social: var(--ei-colour-yellow);
    --ei-colour-espiritual: var(--ei-colour-purple);
    --ei-colour-loggedin-userarea-border: #107d2f;
}

.ei-text-green {
    color: var(--ei-colour-darkgreen) !important;
}
.ei-bg-green {
    background-color: var(--ei-colour-darkgreen) !important;
}
.ei-border-green {
    --bs-border-opacity: 1;
    border-color: rgba(var(--ei-colour-darkgreen-rgb), var(--bs-border-opacity)) !important;
}
.ei-bg-pearl {
    background-color: var(--ei-colour-pearl);
}
.ei-bg-backoffice {
    background-color: var(--ei-colour-fadeyellow);
}
.ei-fw-extrabold {
    font-weight: 800;
}
.ei-shadow {
    box-shadow: 0px 4px 24px #00000014, 0px 0.5px 2px #00000029;
}

.flex-basis-10 { flex-basis: 10%; }
.flex-basis-20 { flex-basis: 20%; }
.flex-basis-30 { flex-basis: 30%; }
.flex-basis-40 { flex-basis: 40%; }
.flex-basis-50 { flex-basis: 50%; }
.flex-basis-60 { flex-basis: 60%; }
.flex-basis-70 { flex-basis: 70%; }
.flex-basis-80 { flex-basis: 80%; }
.flex-basis-90 { flex-basis: 90%; }


input[type="radio"] {
    accent-color: var(--ei-colour-darkgreen) !important;
}
input[type="checkbox"] {
    accent-color: var(--ei-colour-darkgreen) !important;
}
input[type="range"] {
    accent-color: var(--ei-colour-darkgreen) !important;
}
.form-check-input:checked[type=checkbox] {
    background-color: var(--ei-colour-darkgreen) !important;
}

/** Label to be used in all form fields **/
.ei-label {
    padding-bottom: 0.25rem;
    font-size: var(--font-size-s);
    font-weight: 600;
}
.ei-label-comentario {
    padding-bottom: 0.25rem;
    font-size: var(--font-size-s);
    font-weight: 600;
    color: var(--ei-colour-orange);
}
.ei-comentario {
    background-color: var(--ei-colour-fadeyellow);
    border-color: var(--ei-colour-orange);
    color: var(--ei-colour-orange);
}
.ei-text-comentario {
    color: var(--ei-colour-orange);
}
.ei-button {
    align-items: center;
    align-self: stretch;
    background-color: var(--ei-colour-yellowbutton);
    border-radius: 5px;
    display: flex;
    gap: 10px;
    height: 40px;
    justify-content: center;
    padding: 10px 20px;
    position: relative;
    width: 100%;
    font-weight: 600;
    border: none;
}

/** @@STT Scrollbar **/
[dark-scroll]::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
[dark-scroll]::-webkit-scrollbar-track-piece {
    background-color: #2b2b2b;
    border: 1px solid #1d1d1d;
}
[dark-scroll]::-webkit-scrollbar-thumb {
    height: 10px;
    background-color: #4d4d4d;
}
[dark-scroll]::-webkit-scrollbar-thumb:hover {
    background-color: #5a5a5a;
}
/** @@END Scrollbar **/

/** @@STT Card **/
.ei-card {
    border-radius: var(--bs-border-radius-xl);
    padding: 0.5rem 1rem;
    margin-bottom: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
/** Option: Add border to card **/
.ei-card.ei-card-border {
    border: var(--bs-border-width) solid var(--bs-border-color-translucent);
}
/** Option: Add shadow to card **/
.ei-card.ei-card-shadow {
    box-shadow: 0px 4px 24px #00000014, 0px 0.5px 2px #00000029;
}
/** Option: Background header/footer **/
.ei-card.ei-card-header, .ei-card.ei-card-footer {
    background-color: var(--ei-colour-pearl);
}
/** Option: Background white **/
.ei-card.ei-card-body {
    background-color: white;
}
/** @@END Card **/

/** @@STT EcoIgrejas Responsive behaviours **/
/*****************************************************************************/
/**                    DEFINITIONS FOR SMALL SCREENS                        **/
/**                        SMALL SCREENS < lg                               **/
/*****************************************************************************/
@media (max-width: 991.98px) {
    /** Small screens: ND **/
    /** Large screens: Show the EcoIgrejas Background image **/
    .ei-lg-bg-image {
    }
    /** Small screens: This container fits all screen width WITHOUT padding-X **/
    /** Large screens: This container has padding-X, max-width and centred content **/
    .ei-container {
        padding-right: 0;
        padding-left: 0;
    }
    /** Small screens: ND
    /** Large screens: The section (Questão, Secção) cards have rounded edges **/
    .ei-questao {
    }
    /** @@STT Responsive DIV table **/
    .ei-table {
    }
    /** Small screens: Table Row is a full card **/
    /** Large screens: Table Row is a table row **/
    .ei-table-row {
        border-radius: var(--bs-border-radius-xl);
        padding: 1rem 1rem;
        margin-bottom: 1rem;
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
    }
    /** Option: Add border to the table row card **/
    .ei-table.ei-card-border .ei-table-row {
        border: var(--bs-border-width) solid var(--bs-border-color-translucent);
    }
    /** Option: Add shadow to the table row card **/
    .ei-table.ei-card-shadow .ei-table-row {
        box-shadow: 0px 4px 24px #00000014, 0px 0.5px 2px #00000029;
    }
    /** Option: Table row card with coloured background (like card-header/footer) **/
    .ei-table.ei-card-header .ei-table-row, .ei-table.ei-card-footer .ei-table-row {
        background-color: var(--ei-colour-pearl);
    }
    /** Option: Table row card with white background (like card-body) **/
    .ei-table.ei-card-body .ei-table-row {
        background-color: white;
    }
    /** Small screens: Do not show a table header row (table) **/
    /** Large screens: Can show table header row (table) **/
    .ei-table-header {
        display: none;
    }
    /** Small screens: Stack all table row cells (fields) vertically **/
    /** Large screens: Default table cell (column) **/
    .ei-table-cell {
        flex: 1 0 100%;
    }
    /** Small screens: Can show cell labels per field (card) **/
    /** Large screens: Do not show labels per field (card) **/
    .ei-table-card-label {
        display: block;
        color: var(--ei-colour-darkgreen);
        font-weight: bold;
    }
    /** Small screens: Can show in semibold the labels of the main text of table-lg cards **/
    /** Large screens: ND **/
    .ei-card-mainlabel-fw-semibold {
        font-weight: 600;
    }
    /** @@END Responsive DIV table **/
}
/*****************************************************************************/
/**                    DEFINITIONS FOR LARGE SCREENS                        **/
/**                        LARGE SCREENS >= lg                              **/
/*****************************************************************************/
@media (min-width: 992px) {
    /** Small screens: ND **/
    /** Large screens: Show the EcoIgrejas Background image **/
    .ei-lg-bg-image {
        background: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3)),
        url('/images/ei-tab-inicio.jpg') center/cover no-repeat;
    }
    /** Small screens: This container fits all screen width WITHOUT padding-X **/
    /** Large screens: This container has padding-X, max-width and centred content **/
    .ei-container {
        max-width: 1024px;
        margin-right: auto;
        margin-left: auto;
        --bs-gutter-x: 1.5rem;
        padding-right: calc(var(--bs-gutter-x) * 0.5);
        padding-left: calc(var(--bs-gutter-x) * 0.5);
    }
    /** Small screens: ND
    /** Large screens: The section (Questão, Secção) cards have rounded edges **/
    .ei-questao {
        border-radius: var(--bs-border-radius-xl);
    }
    /** @@STT Responsive DIV table **/
    .ei-table {
        --bs-table-border-color: var(--bs-border-color);
        --bs-table-striped-bg: rgba(0, 0, 0, 0.05);
    }
    /** Small screens: Table Row is a full card **/
    /** Large screens: Table Row is a table row **/
    .ei-table-row {
        align-items: center;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;        /** allow responsiveness **/
        border-bottom: 1px solid var(--bs-table-border-color);
        padding: 0.5rem 1rem;
    }
    /** Option: Table striped effect (like table-striped) **/
    .ei-table.ei-table-striped .ei-table-row:nth-of-type(even):not(.ei-table-header) {
        background-color: var(--bs-table-striped-bg);
    }
    /** Option: Table row hover effect (like table-hover) **/
    .ei-table.ei-table-hover .ei-table-row:hover:not(.ei-table-header) {
        background-color: var(--ei-colour-table-hover);
    }
    /** Option: Remove border from last row **/
    .ei-table.ei-table-lastrow-noborder .ei-table-row:last-child {
        border-bottom: none;
    }
    /** Small screens: Do not show a table header row (table) **/
    /** Large screens: Can show table header row (table) **/
    .ei-table-header {
        background-color: var(--ei-colour-darkgreen)!important;
        text-align: center;
        color: white;
        font-weight: bold;
    }
    /** Small screens: Stack all table row cells (fields) vertically **/
    /** Large screens: Default table cell (column) **/
    .ei-table-cell {
        flex: 1 0;                  /** Grow 1 (grow when screen grows), do not shrink, no min-size **/
        padding: 0 1rem;            /** Padding-X 1rem **/
        display: flex;              /** All columns are flex **/
    }
    .ei-table-cell.col-progresso {  /** Special behaviour for column Progresso **/
        flex: 0.2 0 13rem;          /** Grow 0.2 (lesser rate), do not shrink, min-size 13rem **/
        justify-content: center;    /** The content is always centered with the title even if the column grows **/
    }
    .ei-table-cell.col-realizada {  /** Special behaviour for column Realizada (NA/NC/OF/JF) **/
        flex: 0.2 0 10rem;          /** Grow 0.2 (lesser rate), do not shrink, min-size 10rem **/
        justify-content: center;    /** The content is always centered with the title even if the column grows **/
    }
    .ei-table-cell.col-data {       /** Special behaviour for column Data (DF/P) **/
        flex: 0.1 0 10rem;          /** Grow 0.1 (lesser rate), do not shrink, min-size 10rem **/
        justify-content: center;    /** The content is always centered with the title even if the column grows **/
    }
    .ei-table-cell.col-estado {     /** Special behaviour for column Estado and Validação **/
        flex: 0.1 0 10rem;          /** Grow 0.1 (lesser rate), do not shrink, min-size 10rem **/
        justify-content: center;    /** The content is always centered with the title even if the column grows **/
    }
    .ei-table-cell.col-anexo {      /** Special behaviour for column Anexo (File) **/
        flex: 0.2 0 13rem;          /** Grow 0.2 (lesser rate), do not shrink, min-size 13rem **/
        justify-content: center;    /** The content is always centered with the title even if the column grows **/
    }
    .ei-table-cell.col-percentagem { /** Special behaviour for column Percentagem (Inquerito 1, Secção 5) **/
        flex: 1 0;                  /** Grow 1 (same rate), do not shrink **/
        justify-content: center;    /** The content is always centered with the title even if the column grows **/
    }
    .ei-table-cell.col-pontos {     /** Special behaviour for column Pontos **/
        flex: 0 0 6rem;             /** Do not grow, do not shrink, min-size 5rem **/
        justify-content: center;    /** The content is always centered with the title**/
    }
    /** Small screens: Can show cell labels per field (card) **/
    /** Large screens: Do not show labels per field (card) **/
    .ei-table-card-label {
        display: none !important;
    }
    /** Small screens: Show in semibold the labels of the main text of table-lg cards **/
    /** Large screens: ND **/
    .ei-card-mainlabel-fw-semibold {
    }
    /** @@END Responsive DIV table **/
}
@media (min-width: 1200px) {
    .ei-container {
        max-width: 1280px;
    }
}
.ei-container {
    max-width: 1536px;
}
/** @@END EcoIgrejas Responsive behaviours **/

/** @@STT footer inquéritos **/
.ei-footer-inquerito {
    width: 100%;
    background-color: white;
    left: 0;
    bottom: 0;
    position: fixed;
    box-shadow: 0 4px 24px #00000014, 0 0.5px 2px #00000029;
    overflow: hidden;
    padding: 1.5rem 0;
    z-index: 2147483647;    /* Importante para ficar por cima dos outros conteúdos */
    display: flex;
    flex-direction: column;
    align-items: center;
}
/** @@END footer inquéritos **/

/** @@STT ATD Navbar **/
.ei-navbar {
    padding: .75rem 0;
    background-color: transparent;
    box-shadow: 0 .5rem 1rem #00000026, inset 0 -1px #ffffff26;
    --bs-navbar-padding-x: 0rem;
    --bs-navbar-padding-y: 0.5rem;
}
.ei-navbar:after {
    position: absolute;
    inset: 0;
    z-index: -1;
    display: block;
    content: "";
    background-color: var(--ei-colour-darkgreen);
}
.tab-entrar {
    background-color: white;
    border-radius: var(--bs-border-radius-sm);
    color: var(--ei-colour-darkgreen);
    font-weight: 600;
}
.ei-navbar-nav {
    --bs-nav-link-font-size: 1.1rem;
    --bs-nav-link-font-weight: 300;
}
/** @@END ATD Navbar **/

/** @@STT ATD File Control **/
.ei-file-control {
    position: relative;
    max-width: 17rem;
}
.ei-file-control .a-file-name {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-secondary-rgb), var(--bs-text-opacity));
    font-size: 0.6875rem;
}
.ei-file-control .a-file-error {
    --bs-text-opacity: 1;
    color: red;
    font-size: 0.6875rem;
}
.ei-file-control .a-file-status {
    display: none;
    position: relative;
    border: 1px solid #dee2e6;
    border-radius: .375rem;
    background-color: #f8f9fa;
    padding: .4rem .6rem;
    overflow: hidden;
    font-size: .9rem;
}
.ei-file-control .a-progress-bg {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0;
    background-color: rgba(25, 135, 84, 0.2);
    transition: width .3s ease, background-color .3s ease;
    z-index: 1;
}
.ei-file-control .a-progress-bg.uploading {
    background-image: linear-gradient(45deg, rgba(25,135,84,0.4) 25%, rgba(25,135,84,0.2) 25%, rgba(25,135,84,0.2) 50%, rgba(25,135,84,0.4) 50%, rgba(25,135,84,0.4) 75%, rgba(25,135,84,0.2) 75%, rgba(25,135,84,0.2));
    background-size: 40px 40px; animation: a-moveStripes 1s linear infinite;
}
.ei-file-control .a-file-status-content {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 2;
}
.ei-file-control .a-file-info {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color:var(--ei-colour-file-info);
}
.ei-file-control .a-file-progress {
    width: 3rem;
    text-align: right;
    font-weight: 600;
    margin-left: 10px;
    color: var(--ei-colour-file-progress);
}
.ei-file-control .a-unlock-file {
    margin-left: 10px;
}
.ei-file-control .a-status-icon {
    font-size: 1.1rem;
    margin-left: 6px;
    display: none;
}
.ei-file-control .a-status-icon.success {
    color: var(--ei-colour-success);
}
.ei-file-control .a-status-icon.error {
    color: var(--ei-colour-error);
}
@keyframes a-moveStripes {
    0% { background-position: 0 0; }
    100% { background-position: 40px 0; }
}
/** @@END ATD File Control **/

.ei-navbar .navbar-toggler {
    padding: 0;
    margin-right: -.5rem;
    border: 0
}

.ei-navbar .navbar-toggler:first-child {
    margin-left: -.5rem
}

.ei-navbar .navbar-toggler .bi {
    width: 1.5rem;
    height: 1.5rem
}

.ei-navbar .navbar-toggler:focus {
    box-shadow: none
}

.ei-navbar .navbar-brand {
    color: #fff;
    transition: transform .2s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .ei-navbar .navbar-brand {
        transition: none
    }
}

.ei-navbar .navbar-brand:hover {
    transform: rotate(-5deg) scale(1.1)
}

.ei-navbar .navbar-toggler, .ei-navbar .nav-link {
    border-bottom: medium solid transparent;
    padding-right: .25rem;
    padding-left: .25rem;
}

.ei-navbar .nav-link:hover {
    border-bottom: medium solid var(--ei-colour-yellow);
}

.ei-navbar .tab-entrar:hover {
    border-bottom: medium solid transparent;
    color: var(--ei-colour-darkgreen);
}

.ei-navbar .nav-link.active {
    background: #044A18;
    border-bottom: medium solid var(--ei-colour-yellow);
    font-weight: 600;
}

.ei-navbar .tab-entrar.active {
    background: white;
    border-bottom: medium solid transparent;
    color: var(--ei-colour-darkgreen);
}

.ei-navbar .navbar-nav-svg {
    display: inline-block;
    vertical-align: -.125rem
}

.ei-navbar .offcanvas-lg {
    background-color: var(--ei-colour-darkgreen);
    border-left: 0
}

@media (max-width: 992px) {
    .ei-navbar .offcanvas-lg {
        box-shadow:var(--bs-box-shadow-lg)
    }
}

.ei-navbar .dropdown-toggle:focus:not(:focus-visible) {
    outline: 0
}

.ei-navbar .dropdown-menu {
    --bs-dropdown-min-width: 12rem;
    --bs-dropdown-padding-x: .25rem;
    --bs-dropdown-padding-y: .25rem;
    --bs-dropdown-link-hover-bg: rgba(var(--ei-colour-darkgreen-rgb), .1);
    --bs-dropdown-link-active-bg: rgba(var(--ei-colour-darkgreen-rgb), 1);
    --bs-dropdown-font-size: .875rem;
    font-size: .875rem;
    border-radius: .5rem;
    box-shadow: var(--bs-box-shadow)
}

.ei-navbar .dropdown-menu li+li {
    margin-top: .125rem
}

.ei-navbar .dropdown-menu .dropdown-item {
    border-radius: .25rem
}

.ei-navbar .dropdown-menu .dropdown-item:active .bi {
    color: inherit!important
}

.ei-navbar .dropdown-menu .active {
    font-weight: 600
}

.ei-navbar .dropdown-menu .active .bi {
    display: block!important
}

.ei-navbar .dropdown-menu-end {
    --bs-dropdown-min-width: 8rem
}

.bi {
    width: 1em;
    height: 1em;
    vertical-align: -.125em;
    fill: currentcolor
}

.ei-navbar-gutter {
  --bs-gutter-x: 3rem;
}