/*------------------------------------
   ?FUENTES
------------------------------------*/


/* Fuente Baloo */

@font-face {
    font-family: 'Baloo';
    src: url('https://gestion.escueladidactica.com/system/fonts/Baloo-Regular.woff2') format('woff2'),
        url('https://gestion.escueladidactica.com/system/fonts/Baloo-Regular.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}

/* Parrafos */

@font-face {
    font-family: 'Source Sans Pro';
    src: url('https://gestion.escueladidactica.com/system/fonts/SourceSansPro-Regular.woff2') format('woff2'),
        url('https://gestion.escueladidactica.com/system/fonts/SourceSansPro-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Source Sans Pro';
    src: url('https://gestion.escueladidactica.com/system/fonts/SourceSansPro-SemiBold.woff2') format('woff2'),
        url('https://gestion.escueladidactica.com/system/fonts/SourceSansPro-SemiBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}






/*------------------------------------
   ?VARIABLES
------------------------------------*/

:root {
    font-size: 17px;
}

/* Colores marca */

body {
    --color__marca1: #1F9393;
    --color__marca2: #45BA89;
    --color__marca3: #8BBC3C;
    --color__texto: #161B1C;
    --color__textoGris: #848484;
    --color__textoVerde: #2A5859;

    --color__grisClaro: #f5f5f5;
    --color__grisMedio: #efefef;
    --color__grisOscuro: #989898;

    --fuente: "Source Sans Pro", sans-serif;
    --fuente__titulos: "Baloo", sans-serif;

    font-family: var(--fuente);
    font-size: 1rem;
}


/* Botones */


.btn {
    font-size: 14px;
    border-radius: 8px;
}

.btn.active.focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn:active:focus,
.btn:focus {
    outline: none !important;
}







/*------------------------------------
   ?LOGIN ADMIN
------------------------------------*/

body.login_admin {
    position: relative;
    background: url('https://gestion.escueladidactica.com/media/login_admin-person.png'), url('https://gestion.escueladidactica.com/media/login_customers.jpg') !important;
    /* La url de la imagen completa */
    background-repeat: no-repeat !important;
    background-size: 450px, cover !important;
    background-position: right 20px bottom, center !important;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 992px) {

    body.login_admin {
        background-size: 400px, cover !important;
    }
}

@media (max-width: 768px) {

    body.login_admin {
        padding-bottom: 300px !important;
        padding-top: 30px !important;
        background-position: center bottom !important;
        background-size: 320px, cover !important;
    }
}

body.login_admin .company-logo {
    max-width: 340px;
    padding: 0;
}

body.login_admin .authentication-form {
    border: none;
    background: transparent;
    padding: 0;
}

@media (max-width: 576px) {
    body.login_admin .ed-gestionLogin__contentForm .authentication-form {
        padding: 0;
    }
}

.gestion_login_form .form-group,
.authentication-form .form-group {
    margin-bottom: 0 !important;
}

.gestion_login_form .form-group label,
.authentication-form .form-group label {
    color: var(--color__marca1);
    font-size: 14px;
    margin-top: 10px;
}

.authentication-formBtn {
    background-color: var(--color__marca3) !important;
    width: auto !important;
    margin: auto !important;
    padding: 7px 16px !important;
    border: none !important;
    margin-bottom: 15px !important;
    text-transform: capitalize;
    font-family: var(--fuente);
    font-weight: bold !important;
    font-size: 16px !important;
}

body.login_admin .authentication-form-wrapper {
    margin-top: 0;
    max-width: 350px;
    width: 90%;
    background: #fff;
    padding: 20px;
    border-radius: 10px;
}

@media (max-width: 767px) {
    body.login_admin .authentication-form-wrapper {
        padding: 15px;
        margin: auto;
    }
}

.authentication-form .checkbox label,
.authentication-form .form-group a,
.gestion_login_form .checkbox label,
.gestion_login_form a {
    color: #5fa3a5 !important;
    font-size: 14px !important;
}

.ed-gestionLogin__contentForm h1 {
    display: none;
}

.gestion_login {
    max-width: 400px;
    width: 100%;
    border: 1px solid #e4e5e7;
    padding: 20px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 1px 15px 1px rgb(90 90 90 / 8%);
    margin-top: 0;
}

.gestion_login_titulo {
    text-align: center;
    font-family: var(--fuente__titulos);
    color: var(--color__marca1);
    margin-bottom: 10px;
}

.gestion_login_titulo h1 {
    margin-bottom: 5px;
    font-weight: bold;
}

.gestion_login_titulo span {
    font-size: 15px;
    line-height: 1;
    text-align: center;
    font-family: var(--fuente);
    color: var(--color__textoVerde);
}

.gestion_login_form .panel_s {
    box-shadow: none;
    margin-bottom: 0;
}

.gestion_login_form .panel_s .panel-body {
    border-radius: 10px;
    background: transparent;
    border: none;
    padding: 0;
}

.gestion_login_formButton {
    background-color: var(--color__marca3) !important;
    margin: auto !important;
    padding: 7px 16px !important;
    border: none !important;
    margin-bottom: 10px !important;
    text-transform: capitalize;
    font-family: var(--fuente);
    font-weight: bold !important;
    font-size: 1rem !important;
}

.company-logo img {
    max-width: 200px;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}

.customers .dataTables_wrapper {
    background: #fff;
    padding: 15px;
    border-radius: 20px;
    box-shadow: 0 1px 15px 1px rgba(90, 90, 90, .08);
}

.customers #greeting {
    color: var(--color__textoVerde);
    padding-bottom: 8px;
    border-bottom: 2px solid var(--color__marca1);

}

.customers hr {
    border: 1px dashed #ccc;
}

.customers .tickets-summary-heading {
    color: var(--color__marca1);
    font-weight: bold;
}



/*------------------------------------
   ?LOGIN CLIENTES
------------------------------------*/

body.customers_login {
    position: relative;
    background: url('https://gestion.escueladidactica.com/media/login_customers-person.png'), url('https://gestion.escueladidactica.com/media/login_customers.jpg') !important;
    /* La url de la imagen completa */
    background-repeat: no-repeat !important;
    background-size: 500px, cover !important;
    background-position: right 20px bottom, center !important;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}


@media (max-width: 992px) {

    body.customers_login {
        background-size: 400px, cover !important;
    }
}


@media (max-width: 767px) {

    body.customers_login {
        padding-bottom: 300px !important;
        padding-top: 30px !important;
        background-position: center bottom !important;
        background-size: 320px, cover !important;
    }
}

body.customers_login #wrapper {
    display: flex;
    max-width: 1000px;
}

body.customers_login #content {
    padding-bottom: 0;
}

body.customers_login .navbar-default,
body.customers_login .navbar-fixed-bottom {
    display: none;
}

.navbar-default .navbar-nav>li>a,
.navbar-default .navbar-nav>li>a:hover {
    color: inherit;
}


/* Estilos de clases adicionales */
.ed-gestionLogin__logo {
    width: 100%;
    max-width: 340px;
    height: 60px;
    background-image: url(https://gestion.escueladidactica.com/media/login_logo.png);
    background-size: 100%;
    background-position: top center;
    background-repeat: no-repeat;
}

.ed-gestionLogin__contentLogin {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    height: 100vh;
}

@media (max-width: 767px) {
    .ed-gestionLogin__contentLogin {
        align-items: initial;
        justify-content: flex-start;
        max-width: 320px;
        margin: 10px auto;
    }
}

.ed-gestionLogin__title {
    display: none;
}

.ed-gestionLogin__contentForm {
    max-width: 350px;
    width: 100%;
}

@media (max-width: 576px) {
    .ed-gestionLogin__contentForm {
        max-width: 280px;
        margin: 10px auto;
    }
}

body.customers_login .ed-gestionLogin__contentForm .panel_s {
    box-shadow: none;
}

body.customers_login .ed-gestionLogin__contentForm .panel_s .panel-body {
    background: rgba(255, 255, 255, 0);
    border: none;
    border-radius: 0;
}

@media (max-width: 576px) {
    body.customers_login .ed-gestionLogin__contentForm .panel_s .panel-body {
        padding: 0;
    }
}

.ed-gestionLogin__contentForm label {
    font-weight: 400;
    color: #5a9b9c;
    font-size: 18px;
}

.ed-gestionLogin__contentForm button {
    border-radius: 2rem;
    width: max-content;
    padding: 5px 15px;
    background-color: #99b94b !important;
    border: none;
    margin: 0 auto;
    text-transform: capitalize;
    font-size: 18px;
}

.ed-gestionLogin__contentForm button:hover {
    background-color: hsla(77, 44%, 51%, 0.9) !important;
}

.ed-gestionLogin__contentForm a {
    color: #5a9b9c;
}

.ed-gestionLogin__contentForm a:hover {
    color: #99b94b;
}

.ed-gestionLogin__contentForm .checkbox input[type=checkbox]:focus+label::before,
.ed-gestionLogin__contentForm .checkbox input[type=radio]:focus+label::before {
    outline: none !important;
    outline-offset: 0;
}

.btn-instructions {
    display: block;
    padding: 6px 10px;
    background-color: #5a9b9c;
    border-radius: 10px;
    color: #fff !important;
    font-weight: bold;
    text-align: center;
    margin-top: 20px;
}

.gestion_login_form a.btn-instructions {
    color: #fff !important;
    font-size: 1rem !important;
}


/* Footer */

.contact-block {
    position: absolute;
    bottom: 10px;
    right: 10px;
    display: flex;
    flex-direction: column;
    align-items: end;
    display: none;
}

.customers_login .contact-block {
    display: flex;
}

.contact-item {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
    border-radius: 2rem 5px 5px 2rem;
    padding: 5px 10px;
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.2);
    border-right: 4px solid #2A5859;
    transition: all .3s;
}

.contact-item:hover {
    padding: 5px 20px 5px 10px;
}

.contact-item:first-child {
    background: var(--color__marca3);
    cursor: pointer;
}

.contact-item:last-child {
    margin-bottom: 0;
    background: var(--color__marca1);
}

.contact-icon img {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 10px;
}

.contact-item:first-child img {
    width: 40px;
}

.contact-item:last-child img {
    width: 50px;
}

.contact-info {
    display: flex;
    flex-direction: column;
}

.contact-label {
    color: #fff;
}

a.contact-text {
    display: flex;
    align-items: center;
}

.contact-text {
    color: #fff;
    text-decoration: none;
    font-size: .9rem;
}

.contact-text:hover,
.contact-text:focus {
    text-decoration: none;
    color: #fff;
}




/*------------------------------------
   ?HEADER
------------------------------------*/

#header {
    box-shadow: 0 0 4px hsl(0deg 0% 0% / 15%);
}

#logo {
    text-align: center;
    display: flex;
    align-items: center;
}

#logo img {
    margin-top: 0;
}






/*------------------------------------
   ?CRUD PROYECTOS
------------------------------------*/

.table-projects a[href*="projects"] {
    font-weight: bold;
}







/*------------------------------------
   ?HEADER PROYECTOS
------------------------------------*/

.project-top-panel .row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.project-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

#project_view_name {
    max-width: 100%;
}

#project_view_name .bootstrap-select button[data-id=project_top] {
    font-size: 26px;
    height: 48px;
    color: #060506 !important;
}

.dropdown-toggle .filter-option-inner-inner {
    text-overflow: ellipsis;
}






/*------------------------------------
   ?PROYECTOS
------------------------------------*/

.tc-content.project-overview-description .hr-panel-heading.project-area-separation {
    order: 2;
    display: flex;
}

.project-overview-left {
    display: flex;
    flex-direction: column;
}

.tc-content.project-overview-description {
    order: -1;
    display: flex;
    flex-direction: column;
}







/*------------------------------------
   ?PANELES
------------------------------------*/

.panel_s .panel-body,
.top_stats_wrapper {
    border-radius: 20px;
    border: none;
}

.panel_s.project-top-panel.panel-full .panel-body {
    padding: 20px 10px;
    border-radius: 0;
}






/*------------------------------------
   ?SCROLL BAR
------------------------------------*/

*::-webkit-scrollbar {
    width: 12px;
    height: 12px;
    background-color: #fff;
}

*::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background-color: #c1c1c1;
    border: 2px solid #fff;
}

*::-webkit-scrollbar-track {
    box-shadow: 0 0 0 1px hsl(0deg 0% 0% / 15%);
    -webkit-box-shadow: 0 0 0 1px hsl(0deg 0% 0% / 15%);
    border-radius: 0;
    background-color: #fff;
}







/*------------------------------------
   ?TAREAS
------------------------------------*/

.main-tasks-table-href-name {
    font-size: 19px;
    font-weight: bold;
}

.modal-title {
    margin: 0 0 5px;
    line-height: 1.2;
    font-size: 1.8rem;
    font-weight: bold;
}

.modal-header .modal-title~p {
    font-size: 0.9rem;
}

.task-info h5 {
    font-size: 0.84rem;
}

h4.task-info-heading {
    font-size: 0.84rem !important;
}

.task-single-col-left #task_single_timesheets~h4.font-medium.mbot15 {
    font-size: 1rem !important;
}

a#taskCommentSlide h4 {
    font-size: 1rem !important;
}

.tc-content ol,
.tc-content ul {
    margin-left: 2rem !important;
}

.kan-ban-step-indicator {
    width: 44px;
    height: 44px;
}

.kan-ban-content small {
    font-size: 14px;
    margin-bottom: 3px;
}

.kan-ban-content small [style="color:#2d2d2d;"] {
    font-weight: bold;
    color: var(--color__marca3) !important;
}

.kan-ban-content .media {
    display: flex;
}

.kan-ban-content .media-left {
    display: inline-flex;
}

.kan-ban-content .media-body {
    display: inline-flex;
    flex-wrap: wrap;
    flex-direction: column;
    width: auto;
    font-size: 0;
}

.kan-ban-content .media-body a {
    font-size: 1rem;
}

.checklist {
    border-bottom: 1px dashed #ccc;
    padding: 3px 6px 8px;
}

.checklist [name="checklist-description"] {
    font-size: 1rem;
}






/*------------------------------------
   ?KAN BAN
------------------------------------*/

.kan-ban-content-wrapper {
    min-height: 62vh;
}

#kan-ban .panel-heading-bg {
    border-radius: 15px 15px 0 0;
}

.kan-ban-content {
    background: hsl(213deg 24% 96%);
    border-radius: 0 0 15px 15px;
}


.panel-heading.task-phase .pointer {
    font-size: 0.8rem;
    display: none;
}

a.edit-milestone-phase {
    font-size: 1.1rem;
    color: var(--color__texto);
    margin-left: -7px;
}

a.edit-milestone-phase span.bold.heading {
    font-weight: bold;
}

#kan-ban .panel-body {
    border-radius: 8px;
    padding: 12px;
}

.task_milestone {
    font-weight: bold;
    color: var(--color__texto);
    margin-top: 0;
}







/*------------------------------------
   ?GANTT
------------------------------------*/

.gantt .bar-label {
    font-size: 14px !important;
    font-weight: normal !important;
}






/*------------------------------------
   ?CALENDARIO
------------------------------------*/

.fc-event-container .fc-event {
    font-size: 16px;
}

[role="tooltip"].tooltip {
    font-size: 15px;
    line-height: 1.4;
}

[role="tooltip"].tooltip>div {
    color: hsl(0, 0%, 94%) !important;
}






/*------------------------------------
   ?FORMS
------------------------------------*/

.uneditable-input,
input[type=color],
input[type=date],
input[type=datetime-local],
input[type=datetime],
input[type=email],
input[type=file],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week],
select.form-control {
    font-size: 1rem;
    height: 44px;
    border-radius: 10px;
}

textarea.form-control {
    font-size: 1rem;
    height: 160px;
    border-radius: 10px;
}

[type="file"]~span.input-group-btn .btn {
    height: 44px;
}






/*------------------------------------
   ?CLIENTE
------------------------------------*/

/* Ajuste ED */
body.customers {
    background-color: #f3f3f3;
}

.customers .navbar-default {
    background: #ffffff;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.15);
}

.customers .navbar-fixed-bottom {
    position: relative;
    color: #fff;
    background-color: var(--color__textoVerde);
}

.customers .btn {
    font-size: 1rem;
    text-transform: capitalize;
}


.customers .nav.navbar-nav {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

li.customers-nav-item-support {
    margin-right: 10px;
}

.navbar-default .navbar-nav>li.customers-nav-item-support a {
    line-height: 1.4;
    font-size: 1rem;
    color: #fff;
    background-color: #87b23b;
    border-radius: 8px;
    padding: 6px 12px;
    transition: color 300ms, background-color 300ms;
    text-transform: capitalize;
}

.navbar-default .navbar-nav>li.customers-nav-item-support a:hover {
    color: #fff;
    background-color: #99b94b;
}


/* Ajuste ED */

.list-status.ticket-status a {
    border-radius: 15px;
    box-shadow: 0px 1px 4px rgb(0 0 0 / 10%), 0px 1px 3px 1px rgb(0 0 0 / 5%);
    background-color: #fff;
    /* border: 3px solid #e3e8ee; */
    /* transition: border 300ms; */
}

.list-status.ticket-status a:hover {
    border-color: #5fa3a5;
    background-color: #fff;
}

.list-status.ticket-status a.active {
    border: 2px solid #1F9393;
    /* box-shadow: none; */
}

.list-status.ticket-status a.active:after {
    content: "";
    position: absolute;
    left: 50%;
    top: calc(100% - 1px);
    transform: translateX(-50%);
    width: 24px;
    height: 10px;
    background-color: #5fa3a5;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    display: none;
}



/*-- TICKET --*/

.panel_s {
    border-radius: 20px;
    /* background-color: #fff; */
}

.panel_s>.panel-heading {
    font-size: 1.2rem;
    border: none;
    color: var(--color__marca1);
    font-weight: bold;
    text-transform: initial;
}

label,
.control-label {
    font-size: 1rem;
    color: var(--color__textoVerde);
}

.customers .bootstrap-select .btn {
    font-size: 1rem;
}

.customers .bootstrap-select .btn-default {
    height: 44px;
}

.panel_s>.panel-footer {
    background-color: #fff;
    border-radius: 20px;
    margin-top: 10px;
    border: none;
}

.createTicket__footer {
    padding-top: 20px;
    border-top: 1px dashed #ccc;
    margin-top: 10px;
}

.customers .panel-body h4.section-text {
    font-size: 1.2rem;
    color: #0f969b;
    font-weight: bold !important;
}

@media (min-width: 992px) {
    .customers .contact-profile-save-section {
        border-right: 1px dashed #ccc;
    }
}



/*------------------------------------
   ?FORMULARIO EXTERNO
------------------------------------*/

.ticket_form #form_submit {
    font-size: 1.1rem;
    padding: 5px 20px;
    margin-top: 20px;
}