
/* #region FONT */

@font-face
{
    font-family: 'NeueHaasBold';
    src: url('../fonts/NeueHaasDisplayBold.ttf') format('truetype');
    font-display: swap
}

@font-face
{
    font-family: 'NeueHaas';
    src: url('../fonts/NeueHaasDisplayRoman.ttf') format('truetype');
    font-display: swap
}

@font-face
{
    font-family: 'Raleway-MediumItalic';
    src: url('../fonts/Raleway-MediumItalic.ttf') format('truetype');
    font-display: swap
}



/* #endregion FONT */

:root
{
    --bold-font: 'NeueHaasBold';
    --normal-font: 'NeueHaas';
    --italic-font: 'Raleway-MediumItalic';

    --primary-color: #6165D7;
    --secondary-color: #A979F5;
    --gray-color: #BABFC9;
    --gray-text-color:#768194;
    --line-gray-color: #E7E5F0;
    --text-muted: var(--gray-text-color);
    --text-color: #2F3C53;

    --font-h1: 2em;
    --font-h2: 1.5em;
    --font-h3: 1.17em;
    --font-h4: 1em;
    --font-h5: 0.83em;
    --font-h6: 0.67em;
}

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

html, body
{
    height: 100vh;
    width: 100vw;
    overflow: hidden;
    display: flex;
    font-family: var(--normal-font);
}

a
{
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}

a.link-button
{
    color: var(--primary-color);
    font-family: var(--bold-font);
}

h1, h2, h3, h4, h5, h6
{
    font-family: var(--bold-font);
    font-weight: normal;
    color: var(--text-color);
}

p
{
    color: var(--gray-text-color);
}


hr
{
    border-color: var(--line-gray-color);
    border-radius: 16px;
    border-style: solid;
    border-width: 1px;
}

hr.vr
{
    writing-mode: vertical-lr;
    border-radius: 16px;
    width: 2px;
    background-color: var(--line-gray-color);;
    border: none;
}

button
{
    cursor: pointer;
    outline: none;
    appearance: inherit;
    border: inherit;
    border-radius: inherit;
    font-size: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 6px;
    white-space: nowrap;
}

button img
{
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

button.primary, a.button-primary
{

    font-family: var(--bold-font);
    background-color: var(--primary-color);
    border-radius: 16px;
    color: white;
    padding: 16px 24px;
}

button.neutral,
a.button-neutral
{
    font-family: var(--bold-font);
    background-color: var(--line-gray-color);
    border-radius: 16px;
    color: #2F3C53;
    padding: 16px 24px;
    white-space: nowrap;
}

button.squared
{
    border-radius: 8px;
    padding: 8px;
    width: 30px;
    height: 30px;
}

button.squared > img
{
    width: 14px;
}

a.button-primary,
a.button-neutral
{
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 6px;
}

a.back-button
{
    display: flex;
    align-items: center;
    column-gap: 10px;
}

button.primary.ai
{
    background: linear-gradient(to right, #4B4FC9, #B64BC9);
}

button.text
{
    color: var(--primary-color);
    border: none;
    background-color: transparent;
}

button.text path
{
    fill: var(--primary-color);
}

.inverted-button
{
    font-family: var(--bold-font);
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 4px;
    border: 4px solid var(--primary-color);
    border-radius: 12px;
    background-color: white;
    padding: 12px 16px;
    color: var(--primary-color);
}

button > h1, button > h2, button > h3, button > h4, button > h5, button > h6, button > p,
a > h1, a > h2, a > h3, a > h4, a > h5, a > h6, a > p
{
    color: inherit;
}

button.primary:disabled
{
    pointer-events: none;
    opacity: 50%;
}

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

button.transparent
{
    background-color: transparent;
}

.input-upper-placeholder
{
    font-size: 0.83em;
    font-family: var(--bold-font);
    color: var(--gray-color);
    text-align: left;
    margin-bottom: 8px;
}

input[type="text"], input[type="number"], input[type="date"], input[type="email"], input[type="password"], textarea
{
    font-family: var(--normal-font);
    border: 1px solid #6B768C;
    border-radius: 12px;
    padding: 12px;
    appearance: none;
    outline: none;
}

div.textarea-counter-container
{
    text-align: right;
    margin-top: 24px;
}

input[type="date"]::-webkit-datetime-edit
{
    color: #76819480;
}

input[type="date"]::-webkit-calendar-picker-indicator
{
    filter: brightness(0) saturate(100%) invert(47%) sepia(11%) saturate(223%) hue-rotate(181deg) brightness(91%) contrast(85%);
}

input[type="radio"], input[type="checkbox"].custom
{
    display: none;
}

input[name="assessment-link"]
{
    width: 100%;
    text-overflow: ellipsis;
}

.radio-fake-checkbox,
.custom-checkbox
{
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 1px solid #2F3C53;
    position: relative;
    vertical-align: middle;
    margin-right: 8px;
  }

input[type="checkbox"]:checked + .custom-checkbox,
input[type="radio"]:checked + .radio-fake-checkbox
{
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

input[type="checkbox"]:checked + .custom-checkbox::after,
input[type="radio"]:checked + .radio-fake-checkbox::after
{
    content: "✔";
    color: white;
    font-size: 75%;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

select
{
    outline: none;
    border:  1px solid #6B768C;
    border-radius: 12px;
    padding: 12px;
}

select:invalid
{
    color: #76819480;
}

/* input prefix icons */

input.prefix-icon
{
    background-repeat: no-repeat;
    background-position-x: 12px;
    background-position-y: center;
    padding-left: 45px;
}

input.prefix-icon.user-icon
{
    background-image: url("https://my.trainect.it/img/new/person.svg");
}

input.prefix-icon.password-icon
{
    background-image: url("https://my.trainect.it/img/new/lock-filled.svg");
}

input.prefix-icon.email-icon
{
    background-image: url("https://my.trainect.it/img/new/email.svg");
}

input.prefix-icon.company-icon
{
    background-image: url("../img/icons/company.svg");
}

input.prefix-icon.search-icon
{
    background-image: url("../img/icons/search.svg");
}

div.password-input-container
{
    position: relative;
}

.toggle-password
{
    background-color: transparent;
    position: absolute;
    content: '';
    top: 10px;
    right: 5px;
    height: 20px;
    width: 20px;
    display: block;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    margin-right: 5px;
}

.icon-password-hidden
{
    background-image: url("https://my.trainect.it/img/new/watch-filled-2.svg");
}

.icon-password-showed
{
    background-image: url("https://my.trainect.it/img/new/watch-filled.svg");
}


svg
{
    display: block;
}

aside.main-side-navbar
{
    min-width: 300px;
    padding-left: 12px;
    padding-right: 12px;
    padding-bottom: 40px;
    border-right: 2px solid var(--line-gray-color);
    display: flex;
    flex-flow: column;
}

aside.main-side-navbar > div
{
    min-height: 115px;
    display: flex;
    align-items: center;
}

aside.main-side-navbar > div svg.logo-svg
{
    width: 150px;
}

aside.main-side-navbar ul
{
    display: flex;
    flex-flow: column;
    flex: 1;
}

aside.main-side-navbar li
{
    display: block;
    color: var(--gray-color);
    margin-bottom: 12px;
}

aside.main-side-navbar li.selected
{
    background-color: var(--secondary-color);
    border-radius: 16px;
    color: white;
}

aside.main-side-navbar li:last-child
{
    margin-top: auto;
    margin-bottom: 0;
}

aside.main-side-navbar li a
{
    display: flex;
    align-items: center;
    padding: 16px;
}

aside.main-side-navbar li a div
{
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px;
}

aside.main-side-navbar li a svg
{
    fill: var(--gray-color);
}

aside.main-side-navbar li.selected a svg
{
    fill: white;
}

aside.main-side-navbar li button svg {
    fill: var(--gray-color);
}

aside.main-side-navbar li button {
    color: var(--gray-color);
}

.main-view
{
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 60px 20px 35px 20px;
    min-height: 0;
    position: relative;
}


/* loader */

div.main-view-loader-popup
{
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: #00000033;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    padding: 0;
    margin: 0;
    z-index: 999;
}

div.main-view-loader-container
{

      display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  width: 100%;
}

div.loader
{
    width: 120px;
    height: 120px;
    border-radius: 50%;
    display: inline-block;
    border-top: 3px solid var(--primary-color);
    border-right: 3px solid transparent;
    -webkit-animation: spin 1s linear infinite;
            animation: spin 1s linear infinite;
}

@-webkit-keyframes spin
{
    from
    {
        -webkit-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    to
    {
        -webkit-transform: rotate(360deg);
                transform: rotate(360deg);
    }
}


@keyframes spin
{
    from
    {
        -webkit-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    to
    {
        -webkit-transform: rotate(360deg);
                transform: rotate(360deg);
    }
}

/* popups */

dialog
{
    all: unset;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: #00000033;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    padding: 0;
    margin: 0;
    z-index: 999;
}

dialog.side-popup
{
    flex-flow: column;
    justify-content: start;
    align-items: end;
}

dialog:not([open])
{
    display: none;
}

::backdrop
{
    background: transparent;
}

dialog button.close-cross
{
    background-color: white;
    width: 15px;
    height: 15px;
}

.popup-content
{
    background: white;
    padding: 24px;
    border-radius: 24px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.2);
    border: 1px solid #E7E5F0;
    text-align: center;
    width: 500px;
    max-height: 90vh;
    display: flex;
    flex-flow: column;
}

dialog.side-popup > aside.popup-content
{
    flex: 1 1 0;
    max-height: none;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

dialog.side-popup > aside.popup-content > div.main
{
    margin-left: 40px;
    margin-right: 40px;
    display: flex;
    flex-flow: column;
    flex: 1 1 0;
    align-items: start;
    text-align: left;
}

.popup-content > div.header
{
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--gray-color);
    margin-bottom: 40px;
}

.popup-content > div.header > .title
{
    color: var(--gray-color);
}

.popup-input-container
{
    margin-top: 32px;
    margin-bottom: 60px;
}

dialog.side-popup > aside.popup-content > div.main > div.popup-input-container
{
    display: flex;
    flex-flow: column;
    flex: 1 1 0;
    gap: 24px;
    overflow-y: auto;
    align-items: stretch;
    width: 100%;
    padding-right: 15px;
}

dialog.side-popup > aside.popup-content > div.main > div.popup-input-container select,
dialog.side-popup > aside.popup-content > div.main > div.popup-input-container input
{
    width: 100%;
}

.flexbox-centered
{
    display: flex;
    align-items: center;
    justify-content: center;
}

.gap-40
{
    column-gap: 40px;
}

div.spacer
{
    flex-grow: 1;
}

.fixed-size
{
    flex-shrink: 0;
}
.main-side-navbar .user-link {
    display: flex;
    align-items: center;
    column-gap: 12px;
    padding: 16px;
    border-radius: 16px;
    font-weight: normal;
    text-decoration: none;
}

.main-side-navbar .user-initial {
    background-color: #3B7DED;
    color: white;
    font-weight: bold;
    font-family: var(--bold-font, sans-serif);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95em;
    flex-shrink: 0;
}

.main-side-navbar h4.user-name {
    font-size: 0.95em;
    margin: 0;
}

@media only screen and (max-width: 1440px)
{
    aside.main-side-navbar
    {
        min-width: 230px;
    }
}

@media only screen and (max-width: 1024px)
{

}
