@import url('https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,600,700,300italic,400italic,600italic');

/* Using font in CSS:
    font-family: 'GeorgiaCustom', Georgia, serif;
 */

/* Regular Font */
@font-face {
    font-family: 'GeorgiaCustom';
    font-style: normal;
    font-weight: 400;
    src: url('fonts/georgia.woff') format('woff');
}

/* Italic Font */
@font-face {
    font-family: 'GeorgiaCustom';
    font-style: italic;
    font-weight: 400;
    src: url('fonts/georgiai.woff') format('woff');
}

/* Bold Font */
@font-face {
    font-family: 'GeorgiaCustom';
    font-style: normal;
    font-weight: 700;
    src: url('fonts/georgiab.woff') format('woff');
}

/* Bold Italic Font */
@font-face {
    font-family: 'GeorgiaCustom';
    font-style: italic;
    font-weight: 700;
    src: url('fonts/georgiaz.woff') format('woff');
}
/* GENERAL */

.cursor-default {
    cursor: default !important;
}

.cursor-pointer {
    cursor: pointer !important;
}

.cursor-not-allowed {
    cursor: not-allowed !important;
}

/* BORDER WIDTH */

.border-1 {
    border-width: 1px !important;
}

.border-2 {
    border-width: 2px !important;
}

.border-3 {
    border-width: 3px !important;
}

.border-4 {
    border-width: 4px !important;
}

.border-5 {
    border-width: 5px !important;
}

/* OPACITY */

.opacity-25 {
    opacity: 0.25 !important;
}

.opacity-50 {
    opacity: 0.50 !important;
}

.opacity-75 {
    opacity: 0.75 !important;
}

.opacity-100 {
    opacity: 1.0 !important;
}

/* HOVER / TRANSITION */

.transition-03 {
    transition: 0.3s;
}

/* FONT / TEXT */

.font-size-sm {
    font-size: small !important;
}

.font-size-md {
    font-size: medium !important;
}

.font-size-lg {
    font-size: large !important;
}

.text-limited {
    display: -webkit-box;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
}

.text-limited-lines-1 { -webkit-line-clamp: 1; }
.text-limited-lines-2 { -webkit-line-clamp: 2; }
.text-limited-lines-3 { -webkit-line-clamp: 3; }

/* BADGES */

.badge-limited {
    text-align: center;
    white-space: pre-line;
    word-wrap: break-word;
    vertical-align: middle;
    max-width: 120px;
    line-height: 1.4;
    padding: 5px;
}

span.badge-limited {
    display: inline-block !important;
    vertical-align: middle !important;
    align-self: center !important;
    height: auto !important;
    white-space: normal;
}

button.badge-limited,
.btn.badge-limited {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    vertical-align: middle;
    white-space: pre-line;
}

.badge-limited i {
    display: block;
    margin-bottom: 2px;
    font-size: 0.95em;
    line-height: 1;
}

.badge-limited-ellipsis span {
    display: -webkit-box;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
}

.badge-limited-lines-1 span { -webkit-line-clamp: 1; }
.badge-limited-lines-2 span { -webkit-line-clamp: 2; }
.badge-limited-lines-3 span { -webkit-line-clamp: 3; }
.badge-limited-lines-4 span { -webkit-line-clamp: 4; }

/* CHECKBOX SIZES */

.checkbox-md {
    height: 20px;
    width: 20px;
}

.checkbox-lg {
    height: 30px;
    width: 30px;
}

/* INPUTS */

.input-sm {
    max-width: 120px;
}

.input-md {
    max-width: 180px;
}

.input-lg {
    max-width: 240px;
}

.input-number {
    max-width: 90px;
}

.input-date-range {
    max-width: 200px;
}

.input-date {
    max-width: 100px;
}

.input-time {
    max-width: 80px;
}

.input-phone {
    max-width: 150px;
}

.input-zipcode {
    max-width: 100px;
}

.input-currency {
    max-width: 150px;
}

.input-id-document {
    max-width: 160px;
}

.input-password {
    max-width: 150px;
}

.input-with-prepend-slot {
    border-right: solid 1px #ced4da !important;
    border-bottom-right-radius: 3.2px !important;
    border-top-right-radius: 3.2px !important;
}

/* CARD CUSTOMIZATION */

.card-pt-0 .card-body {
    padding-top: 0 !important;
}

/* LOGIN AND REGISTER BOX */

.login-box {
    width: 400px;
}

.register-box {
    width: 500px;
}

@media (max-width: 576px) {
    .login-box {
        width: 90%;
    }

    .register-box {
        width: 90%;
    }
}

/* MODAL */

.modal-max > .modal-dialog {
    max-width: 90%;
}

/*@media (min-width: 576px) {
    .modal-max > .modal-dialog {
        max-width: 700px;
    }
}

@media (min-width: 768px) {
    .modal-max > .modal-dialog {
        max-width: 800px;
    }
}

@media (min-width: 992px) {
    .modal-max > .modal-dialog {
        max-width: 1000px;
    }
}
@media (min-width: 1200px) {
    .modal-max > .modal-dialog {
        max-width: 1400px;
    }
}*/

/* TOAST */

.toast-middle-center {
    top: 33%;
    left: 40%;
    width: 100%;
}

.toast-custom-size {
    min-width: 400px !important;
}

/* SELECT2 */

.select-sm + .select2-container {
    max-width: 120px !important;
}

.select-md + .select2-container {
    max-width: 180px !important;
}

.select-lg + .select2-container {
    max-width: 240px !important;
}

.select-xl + .select2-container {
    max-width: 480px !important;
}

.select-100 + .select2-container {
    max-width: 100% !important;
}

.select2-results {
    /* force text-dark, because bg-secondary use color #fff */
    color: #343a40 !important;
}

.select2-selection__rendered {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.select2-selection__choice {
    margin: 5px !important;
    display: inline-block;
    white-space: nowrap;
}
    
/* BOOTSTRAP SWITCH */

.input-group .bootstrap-switch-default-size .bootstrap-switch-handle-on,
.input-group .bootstrap-switch-default-size .bootstrap-switch-handle-off {
    height: unset !important;
}

/* LOGO */

.brand-image-custom {
    max-width: 50px !important;
}

@media (max-width: 576px) {  
    .brand-image-custom-xl {
        max-width: 64px !important;
    }
}

@media (min-width: 576px) {
    .brand-image-custom-xl {
        max-width: 100px !important;
    }
}

@media (min-width: 768px) {
    .brand-image-custom-xl {
        max-width: 128px !important;
    }
}

@media (min-width: 992px) {
    .brand-image-custom-xl {
        max-width: 150px !important;
    }
}

@media (min-width: 1200px) {
    .brand-image-custom-xl {
        max-width: 180px !important;
    }
}

.brand-image-custom-xs {
    max-width: 20px !important;
}

/* CUSTOM COLORS - BACKGROUND */

/*.bg-custom-color-name {
    background-color: #COLOR !important;
}*/

/* CUSTOM COLORS - BADGE */

/*.badge-custom-color-name {
    color: #ffffff;
    background-color: #COLOR !important;
}*/

/* CUSTOM COLORS - TEXT */

/*.text-custom-color-name {
    color: #COLOR !important;
}*/

/* CUSTOM COLORS - BORDER */

/*.border-custom-color-name {
    border-color: #COLOR !important;
}*/

/* CUSTOM COLORS - CALLOUT */

/*.callout-custom-color-name {
    border-left-color: #COLOR !important;
}*/

/* CUSTOM COLORS - MODAL */

/*.modal-custom-color-name .modal-header {
    background-color: #COLOR !important;
}
.modal-custom-color-name .modal-header button {
    color: #ffffff !important;
}*/

/* SIDEBAR */

.sidebar-custom {
    max-height: 95% !important;
    margin-top: 60px;
}

.sidebar-custom .sidebar {
    margin-top: 0 !important;
}

.sidebar-custom .os-content {
    overflow-x: hidden !important;
    overflow-y: auto !important;
}

@media (min-width: 992px) {
    .sidebar-custom {
        max-height: 84% !important;
    }

    .sidebar-custom .os-content {
        max-height: 90% !important;
    }
}

aside .nav-link.active {
    /* background-color: #COLOR !important; */
}

aside .nav-link.active i {
    /* color: #COLOR !important; */
}

/* NAV TABS */

.nav-tabs .nav-link {
    border: 1px solid #ffffff !important;
}

.nav-tabs .nav-link.disabled {
    border: 1px solid #ffffff !important;
    opacity: 0.66;
}

/* DATATABLES */

table.dataTable th {
    /* background-color: #COLOR !important; */
}

table.dataTable th:not(:first-child) {
    border-left-color: #ffffff !important;
}

table.dataTable th:not(:last-child) {
    border-right-color: #ffffff !important;
}

table.dataTable td {
    color: #000000 !important;
}

.dataTables_processing {
    background-color: #f8f9fa !important;
    border-color: #000000 !important;
    border-width: 1px !important;
}

.dataTables_paginate .page-item .page-link {
    /*color: #COLOR !important;*/
}

.dataTables_paginate .page-item.active .page-link {
    background-color: #000000 !important;
    border-color: #000000 !important;
    color: #ffffff !important;
}

/* CHARTS */

.chart-canvas {
    height: 100% !important;
    max-height: 100%;

    width: 100% !important;
    max-width: 100%;
}

/* IFRAME */

.iframe-video {
    height: 100vh;
}

@media (max-width: 576px) {  
    .iframe-video {
        max-height: 300px;
    }
}

@media (min-width: 576px) {
    .iframe-video {
        max-height: 350px;
    }
}

@media (min-width: 768px) {
    .iframe-video {
        max-height: 400px;
    }
}

@media (min-width: 992px) {
    .iframe-video {
        max-height: 450px;
    }
}

@media (min-width: 1200px) {
    .iframe-video {
        max-height: 500px;
    }
}

/* CIRCLE DIVS */

.circle {
    border-radius: 50%;
}

.circle-sm {
    width: 30px !important;
    height: 30px !important;
}
  
.circle-quarter-info {
    background-image: linear-gradient(00deg, #ffffff 50%, transparent 50%), linear-gradient(-90deg, #054842 50%, transparent 50%);
}
  
.circle-half-info {
    background-image: linear-gradient(90deg, #ffffff 50%, transparent 50%), linear-gradient(-90deg, #054842 50%, transparent 50%);
}
  
.circle-three-quarter-info {
    background-image: linear-gradient(-90deg, #054842 50%, transparent 50%), linear-gradient(-180deg, transparent 50%, #054842 50%);
}
  
.circle-full-info {
    background: #054842 !important;
}

/* PUBLIC PAGES */

@media (max-width: 576px) {  
    .main-title {
        font-size: 45px;
    }
}

@media (min-width: 576px) {  
    .main-title {
        font-size: 50px;
    }
}

@media (min-width: 768px) {  
    .main-title {
        font-size: 60px;
    }
}

@media (min-width: 992px) { 
    .main-title {
        font-size: 70px;
    }
}

@media (min-width: 1200px) {  
    .main-title {
        font-size: 80px;
    }
}