@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root {
    --color-primary: rgba(230, 24, 85, 1);/* #e61855 */
    --color-primary-light: rgba(230, 24, 85, 0.8);
    --color-secondary: rgb(0, 50, 91); /* #00325B */
    --color-secondary-05: rgba(0, 50, 91, 0.5);
    --color-secondary-01: rgba(0, 50, 91, 0.1);
    --color-success: rgb(0, 183, 74); /* #00b74a - bootstrap default */
    --color-danger: rgb(249, 49, 84); /* #f93154 - Bootstrap default */
    --color-text-gray: rgb(127, 152, 173);
}

body {
    font-family: 'Montserrat', sans-serif;
    background-color: #f2f4f7;
    -webkit-font-smoothing: subpixel-antialiased;
    -webkit-text-stroke: 1px transparent;
    color: var(--color-secondary);
    overflow-x: hidden;
}

h1 {
    font-weight: 700;
    font-size: 1.375rem;
}

h2 {
    font-weight: 600;
    font-size: 1.25rem;
}

h3 {
    font-weight: 600;
    font-size: 1.125rem;
}

h4 {
    font-weight: 600;
    font-size: 1rem;
}

h5 {
    font-weight: 600;
    font-size: 0.875rem;
}

h6 {
    font-weight: 600;
    font-size: 0.75rem;
}


/* General classes */
.cursor-pointer {
    cursor: pointer;
}

.btn {
    box-shadow: 0px 3px 21px 2px #00000017;
}

.vertical-middle {
    vertical-align: middle;
}
/*  */

* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

.sidebar {
    min-height: 100vh;
}

.sidebar li {
    min-height: 42px;
}

.sidebar .active {
    background-color: rgb(253, 232, 238);
}

.sidebar a {
    color: var(--color-secondary-05);
    font-size: 1rem;
    font-weight: 600;
    transition: all linear 0.1s;
}

.sidebar a:hover,
.sidebar a:focus {
    color: var(--color-secondary);
    font-size: 1rem;
    font-weight: 600;
}

.sidebar a > i {
    margin-right: 10px;
}

.sidebar a.active {
    color: var(--color-secondary);
}

.sidebar a.active > i {
    color: var(--color-primary);
}

.sidebar img {
    max-width: 190px;
}

.sidebar > div {
    position: sticky;
    top: 24px;
    left: 0;
}

#header-bar {
    background-color: white;
    border-radius: 10px;
    padding: 10px;
    margin-bottom: 20px;
}

#header-bar-right {
    align-content: flex-end;
}

#main-container {
    background-color: #fff;
}

#hero {
    margin-top: 70px;
}

#hero h2 {
    font-size: 48px;
    font-weight: 900;
}

.cardiclub-text-primary {
    color: #e61855;
}

#main-header {
    padding: 25px 70px 10px;
}

.login-row {
    height: calc(100vh - 75px);
}

.login-screenshot {
    width: 100%;
}

/* Patient */
.button-add i {
    color: var(--color-primary);
    font-size: 1.9rem;
}

.button-add--sm i {
    font-size: 1.3rem;
    color: var(--color-primary);
}

.tox-tinymce {
    border-radius: 15px !important;
}

.patient_notes .tox.tox-tinymce {
    width: 100% !important;
}

.select2-container .select2-selection--single {
    height: 39.5px !important;
}

/*  */

/* Add assessments */
.diagnosis_notes div.tox.tox-tinymce,
.medication_notes div.tox.tox-tinymce,
.plan_notes div.tox.tox-tinymce,
#div_id_description .tox.tox-tinymce {
    width: 100% !important;
}

.div_id_cv_risk_factors label {
    display: block;
}

.select2-container {
    width: 100%;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    border: none !important;
    margin-left: 4px !important;
    margin-top: 7px !important;
}

.select2-selection__choice {
    background-color: white !important;
    box-shadow: 0px 4px 10px 0px rgba(3, 98, 175, 0.05);

}

.select2-selection__choice button,
.select2-selection__choice span {
    background-color: white;
}

.select2.select2-container.select2-container--default {
    width: 100% !important;
}

.select2-container--default .select2-selection--multiple {
    padding: 1px 6px 6px !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__display {
    padding: 0 8px !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    padding: 0 6px !important;
    border-right: 1px solid white !important;
}

/*  */

/* Dashboard styles */
.card-image {
    width: 40px;
    height: 40px;
    background-color: rgb(255, 246, 240);
    padding: 8px;
    border-radius: 5px;
}

.card-text {
    font-size: 0.9rem;
    font-weight: 600;
}

.card-counter {
    font-size: 1.2rem;
    font-weight: 600;
    line-height: 18px;
}

.module-card-img {
    height: 200px;
    width: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.program-action--icon {
    font-size: 1.2rem;
}

#div_id_cover_page .form-control {
    display: block !important;
}

#div_id_cover_page .text-break a,
#div_id_video .text-break a {
    display: inline-block;
    width: 180px;
    white-space: nowrap;
    overflow: hidden !important;
    text-overflow: ellipsis;
}


.active-sessions--icon {
    transform: scale(-1, 1);
}

.input-group-text {
    padding-top: 0.2rem;
}

.invalid-feedback {
    position: static;
}

#id-pdf-on-page-wrapper {
    height: 50vh;
}

#id-pdf-full-screen-wrapper {
    position: relative;
}

#id-slide-display {
    width: 100%;
    height: 100%;
}

#pdf-controls {
    position: absolute;
    bottom: 20px;
    left: 10px;
}

.pdf-controls-shown {
    opacity: 100%;
    transition: opacity 0.2s linear;
}

.pdf-controls-hidden {
    opacity: 20%;
    transition: opacity 0.5s linear;
}

ul.dropdown-menu {
    border: 1px solid var(--color-primary);
}

.form-label {
    margin-bottom: 0;
    font-weight: 500;
    color: var(--color-secondary-05);
}

.cc-list .list-group-item {
    border-right: none;
    border-left: none;
}

.cc-list .list-group-item:first-child {
    border-top: none;
    border-left: none;
    border-right: none;
}

.cc-list .list-group-item:last-child {
    border: none !important;
}

.list-group-item {
    background-color: transparent;
}

.list-group-item.active {
    background-color: var(--color-primary);
    border: 1px solid var(--color-primary);
}

.list-group-item.active a {
    color: white;
}

/* --- Nav Tabs --- */
.cc-nav-tabs .nav-link {
    font-weight: 700 !important;
    font-size: 1rem;
    padding: 0 0 5px;
    margin-right: 30px;
    background-color: transparent !important;
}

.cc-nav-tabs .nav-link:not(.active) {
    color: var(--color-secondary-05);
   
}

.cc-nav-tabs .nav-link.active {
    color: var(--color-secondary);
    border-color: var(--color-primary);
}

.cc-nav-tabs .nav-item {
    flex-basis: unset;
    flex-grow:unset;
}
/* --- END of Nav Tabs -- */

/* --- Text Editor (tox) --- */
.tox .tox-toolbar-overlord {
    background-color: transparent !important;
}

.tox-toolbar__primary {
    background-color: transparent !important;
}

.tox .tox-edit-area__iframe {
    background-color: transparent !important;
}

.tox-statusbar {
    background-color: transparent !important;
}
/* --- END OFText Editor (tox) --- */

/* --- Buttons --- */
.button-primary {
    width: 100%;
    max-width: 300px;
    background-color: var(--color-primary) !important;
    border-radius: 15px;
    padding: 12px 20px;
    color: white;
    font-weight: 700;
    font-size: 0.875rem;
    transition: all 0.3s;
    border: none;
    border: 1px solid var(--color-primary) !important;
}

.button-primary:hover {
    background-color: white !important;
    color: var(--color-primary) !important;
    box-shadow: none;
}

.button-primary-icon--sm {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 300px;
    background-color: white;
    border-radius: 15px;
    padding: 6px 10px;
    color: var(--color-secondary);
    font-weight: 700;
    font-size: 0.875rem;
    transition: all 0.3s;
    border: none;
    box-shadow: 2px 2px 20px 0px rgba(3, 98, 175, 0.15);
}

.button-primary-icon--sm i {
    font-size: 1.4rem;
    color: var(--color-primary);
    border-radius: 50%;
    transition: all 0.3s;
}

.button-primary-icon--sm:hover {
    color: var(--color-primary-light);
}

.button-primary-icon--sm:hover i {
    color: var(--color-primary-light);
}

.button-primary--sm {
    width: 100%;
    max-width: 300px;
    background-color: var(--color-primary);
    border-radius: 15px;
    padding: 6px 20px;
    color: white;
    font-weight: 700;
    font-size: 0.875rem;
    transition: all 0.3s;
    border: none;
    border: 1px solid var(--color-primary);
}

.button-primary--sm:hover {
    border-color: var(--color-primary);
    background-color: white;
    color: var(--color-primary);
    box-shadow: none;
}

.button-secondary {
    width: 100%;
    max-width: 300px;
    background-color: transparent;
    border-radius: 15px;
    padding: 12px 20px;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
    border: 1px solid var(--color-primary);
    transition: all 0.3s;
}

.button-secondary:hover {
    color: white;
    background-color: var(--color-primary);
}

.button-secondary--sm {
    width: 100%;
    max-width: 300px;
    background-color: transparent;
    border-radius: 15px;
    padding: 6px 20px;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
    border: 1px solid var(--color-primary);
    transition: all 0.3s;
}

.button-secondary--sm:hover {
    color: white;
    background-color: var(--color-primary);
}

.button-success {
    width: 100%;
    max-width: 300px;
    background-color: var(--color-success);
    border-radius: 15px;
    padding: 12px 20px;
    color: white;
    text-transform: uppercase;
    font-size: 0.875rem;
    font-weight: 700;
    border: none;
    transition: all 0.3s;
    border: 1px solid var(--color-success);
}

.button-success:hover {
    color: var(--color-success) !important;
    background-color: white !important;
}


.button-success--sm {
    width: 100%;
    max-width: 300px;
    background-color: var(--color-success);
    border-radius: 15px;
    padding: 6px 20px;
    color: white;
    text-transform: uppercase;
    font-size: 0.875rem;
    font-weight: 700;
    border: none;
    transition: all 0.3s;
    border: 1px solid var(--color-success);
}

.button-success--sm:hover {
    color: var(--color-success) !important;
    background-color: white !important;
}

.button-danger {
    width: 100%;
    max-width: 300px;
    background-color: var(--color-danger);
    border-radius: 15px;
    padding: 12px 20px;
    color: white;
    text-transform: uppercase;
    font-size: 0.875rem;
    font-weight: 700;
    border: none;
    transition: all 0.3s;
    border: 1px solid var(--color-danger);
}

.button-danger:hover {
    color: var(--color-danger) !important;
    background-color: white !important;
}

.button-danger--sm {
    width: 100%;
    max-width: 300px;
    background-color: var(--color-danger);
    border-radius: 15px;
    padding: 6px 20px;
    color: white;
    text-transform: uppercase;
    font-size: 0.875rem;
    font-weight: 700;
    border: none;
    transition: all 0.3s;
    border: 1px solid var(--color-danger);
}

.button-danger--sm:hover {
    color: var(--color-danger) !important;
    background-color: white !important;
}


/* --- END OF Buttons --- */

/* --- Inputs --- */
.input-primary {
    max-width: 500px;
    border-radius: 8px;
    width: 100%;
    border: 1px solid  var(--color-secondary-05);
    padding: 8px 14px;
    display: block;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.6;
    background-color: transparent;
}

.input-primary.textarea {
    max-width: none;
}

.input-primary.is-invalid {
    padding: 8px 14px !important;
}

.input-primary:focus, 
.input-primary:focus-visible {
    box-shadow: none;
    border: 1px solid var(--color-primary);
    background-color: white;
    outline:none;
}

.input-primary-suffix-wrapper input {
    background-color: transparent;
    height: auto !important;
    padding: 8px 14px !important;
    max-width: 500px;
    border-radius: 8px;
    width: 100%;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.6;
    border: 1px solid  var(--color-secondary-05);
    border-bottom-left-radius: 8px;
    border-top-left-radius: 8px;
}

.input-primary-suffix-wrapper input + span {
    padding: 8px 14px !important;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.6;
    border-radius: 8px;
    border-right: 1px solid  var(--color-secondary-05);
    border-top: 1px solid  var(--color-secondary-05);
    border-bottom: 1px solid  var(--color-secondary-05);
    border-left: none;
    border-bottom-right-radius: 8px;
    border-top-right-radius: 8px;
    transition: all linear 0.2s;
}

.input-primary-suffix-wrapper input:focus,
.input-primary-suffix-wrapper input:focus-visible  {
    box-shadow: none !important;
    border: 1px solid var(--color-primary) !important;
    background-color: white;
    outline:none !important;
}

.upload-input-primary-wrapper input:not([type="checkbox"]) {
    max-width: 500px;
    border-radius: 8px;
    width: 100%;
    border: 1px solid  var(--color-secondary-05);
    padding: 8px 14px;
    display: block;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.6;
    background-color: transparent;
}

.upload-input-primary-wrapper .form-control {
    display: block !important;
    background-color: transparent;
    padding: 8px 14px;
    border: 1px solid var(--color-secondary-05)
}

.upload-input-primary-wrapper .input-group-text {
    padding: 8px 14px;
    border: 1px solid var(--color-secondary-05);
}


.upload-input-primary-wrapper .form-control input[type="checkbox"] {
    background-color: transparent;
    border: 0.125rem solid var(--color-primary);
}

.upload-input-primary-wrapper .form-control input[type="checkbox"]:focus-visible {
    outline: none;
}

.upload-input-primary-wrapper .form-control input[type="checkbox"]:checked {
    background-color: var(--color-primary) !important;
    border: 0.125rem solid var(--color-primary);
}

.upload-input-primary-wrapper .form-control input[type="checkbox"]:checked:focus {
    border: 0.125rem solid var(--color-primary) !important;
}

.upload-input-primary-wrapper a {
    width: 90% !important;
}

.upload-input-primary-wrapper input:not([type="checkbox"]):focus, 
.upload-input-primary-wrapper input:not([type="checkbox"]):focus-visible {
    box-shadow: none;
    border: 1px solid var(--color-primary);
    background-color: white;
    outline:none;
}

.input-primary-select2 + span.select2-container .select2-selection {
    background-color: transparent;
    max-width: 500px;
    min-height: 42px;
    border-radius: 8px;
    width: 100%;
    border: 1px solid  var(--color-secondary-05);
    padding: 8px 14px;
    display: block;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.6;
}

.input-primary-select2.mw-100 + span.select2-container .select2-selection {
    max-width: 100%;
}

.input-primary-select2 + span.select2-container.select2-container--open .select2-selection {
    border: 1px solid var(--color-primary);
    background-color: white;
    border-radius: 8px;
}

.input-primary-select2 + span.select2-container .select2-selection .select2-selection__rendered { 
    line-height: 24px !important;
}

.input-primary-select2 + span.select2-container .select2-selection .select2-selection__arrow { 
    top: 6px;
    right: 6px;
}

.checkbox-primary {
    background-color: transparent;
    border: 0.125rem solid var(--color-primary);
}

.checkbox-primary:focus-visible {
    outline: none;
}

.checkbox-primary:checked {
    background-color: var(--color-primary) !important;
    border: 0.125rem solid var(--color-primary);
}

.checkbox-primary:checked:focus {
    border: 0.125rem solid var(--color-primary) !important;
}

.radio-primary input[type="radio"]:checked {
    border: 2px solid var(--color-primary);
}

.radio-primary input[type="radio"]:checked:after {
    background-color: var(--color-primary);
}
/* --- END OF Inputs --- */

/* --- Links --- */
.link-primary { 
    color: var(--color-primary) !important;
    font-weight: 800;
    text-decoration: underline;
    font-size: 0.875rem;
}
/* --- END OF Links --- */

/* --- Cards --- */
.card-primary {
    box-shadow: 5px 5px 30px 0px rgba(3, 98, 175, 0.10);
    border-radius: 15px;
    background-color: white;
    word-wrap: break-word;
}
/* --- End of Cards --- */

/* --- Tables --- */

.cc-table-filter-container {
    padding: 16px 16px 0;
}

.cc-table-container {
    background-color: white;
    border-radius: 15px;
    border: none;
    font-size: 0.875rem;
    width: 100%;
}
.cc-table {
    width: 100%;
}

.cc-table td,
.cc-table th {
    border: none;
    color: var(--color-secondary);
}

.cc-table tr {
    border-bottom: 1px solid var(--color-secondary-01);
}

.cc-table tbody tr:last-child {
    border-bottom: none;
}

.cc-table thead th {
    color: var(--color-secondary);
    font-weight: 700;
}

.cc-table>:not(caption)>*>* {
    padding: 0.75rem 1rem;
}

.cc-selection-box {
    border: 1px solid var(--color-secondary-05);
    border-radius: 8px;
}

.cc-video-wrapper video {
    height: 400px;
}

/* --- END OF Tables --- */

.cc-card {
    border-radius: 20px;
    background-color: white;
    box-shadow: 20px 20px 50px 0px rgba(3, 98, 175, 0.10);
    overflow: hidden;
    padding: 16px;
}

.cc-card-body {
    padding: 15px;
}

.cc-card-title a {
    color: var(--color-secondary);
}

/* --- Utilities --- */
.cc-bg-priamry {
    background-color: var(--color-primary);
}

.cc-shadow-md {
    box-shadow: 5px 5px 30px 0px rgba(3, 98, 175, 0.10) !important;
}

.cc-shadow-lg {
    box-shadow: 20px 20px 50px 0px rgba(3, 98, 175, 0.10) !important;
}

.width-fit {
    width: fit-content !important;
}

.align-items-center-inner .row {
    align-items: center;
}

/* --- Confidence Slider --- */
.confidence-slider-container {
    padding: 16px;
    background-color: rgba(240, 245, 250, 0.5);
    border-radius: 12px;
    border: 1px solid rgba(0, 50, 91, 0.1);
}

.confidence-slider {
    width: 100% !important;
    height: 8px;
    border-radius: 4px;
    background: #e9ecef;
    outline: none;
    border: none !important;
    -webkit-appearance: none;
}

.confidence-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--color-primary);
    cursor: pointer;
    border: 2px solid white;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.confidence-slider::-moz-range-thumb {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--color-primary);
    cursor: pointer;
    border: 2px solid white;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

#confidence-value-badge {
    font-size: 1rem;
    font-weight: 600;
    min-width: 40px;
    background-color: var(--color-primary) !important;
}
/* ---END OF Utilities --- */
