/* LAYOUT */

.hidden,
[hidden] {
    display: none;
}

.hidden-force {
    display: none !important;
}

.invisible {
    visibility: hidden;
}

.force-inline {
    display: inline !important;
}

.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.text-left {
    text-align: left;
}

.flex-row {
    display: flex;
    flex-direction: row;
}

.flex-col {
    display: flex;
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.justify-center {
    justify-content: center;
}

.justify-between {
    justify-content: space-between;
}

.justify-end {
    justify-content: flex-end;
}

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

.items-start {
    align-items: flex-start;
}

.items-end {
    align-items: flex-end;
}

.self-end {
    align-self: flex-end;
}

.flex-1 {
    flex: 1;
}

.flex-2 {
    flex: 2;
}

.grid {
    display: grid;
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.col-span-2 {
    grid-column: span 2 / span 2;
}

.w-full {
    width: 100%;
}

.w-1\/2 {
    width: 50%;
}

.w-1\/3 {
    width: 33%;
}

.w-35 {
    width: 35px;
}

.w-48 {
    width: 48px;
}

.w-105 {
    width: 105px;
}

.w-120 {
    width: 120px;
}

.w-175 {
    width: 175px;
}

.w-200 {
    width: 200px;
}

.w-225 {
    width: 225px;
}

.w-400 {
    width: 400px;
}

.w-500 {
    width: 500px;
}

.w-840 {
    width: 840px;
}

.w-fit {
    width: fit-content;
}

.h-56 {
    height: 56px;
}

.h-400 {
    height: 400px;
    max-height: 50vh;
}

.h-full {
    height: 100%;
}

.min-h-full {
    min-height: 100%;
}

.max-w-200 {
    max-width: 200px;
}

.max-h-half-screen {
    max-height: 50vh;
}

.max-h-80vh {
    max-height: 80vh;
}

.fixed {
    position: fixed;
}

.relative {
    position: relative;
}

.bottom-0 {
    bottom: 0;
}

/* SPACING */

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.m-0 {
    margin: 0 !important;
}

.p-0 {
    padding: 0 !important;
}

.p-5 {
    padding: 5px;
}

.pt-5 {
    padding-top: 5px;
}

.pb-5 {
    padding-bottom: 5px;
}

.px-5 {
    padding-right: 5px;
    padding-left: 5px;
}

.mb-8 {
    margin-bottom: 8px;
}

.m-10 {
    margin: 10px;
}

.mt-10 {
    margin-top: 10px;
}

.mx-10 {
    margin-left: 10px;
    margin-right: 10px;
}

.mb-10 {
    margin-bottom: 10px;
}

.p-10 {
    padding: 10px;
}

.pt-10 {
    padding-top: 10px;
}

.pb-10 {
    padding-bottom: 10px;
}

.px-10 {
    padding-right: 10px;
    padding-left: 10px;
}

.m-16 {
    margin: 16px;
}

.mt-16 {
    margin-top: 16px;
}

.ml-16 {
    margin-left: 16px;
}

.mr-16 {
    margin-right: 16px;
}

.m-20 {
    margin: 20px;
}

.mt-20 {
    margin-top: 20px;
}

.mx-20 {
    margin-left: 20px;
    margin-right: 20px;
}

.mb-20 {
    margin-bottom: 20px;
}

.p-20 {
    padding: 20px;
}

.pt-20 {
    padding-top: 20px;
}

.pb-20 {
    padding-bottom: 20px;
}

.pl-20 {
    padding-left: 20px;
}

.pr-20 {
    padding-right: 20px;
}

.px-20 {
    padding-right: 20px;
    padding-left: 20px;
}

.m-24 {
    margin: 24px;
}

.mx-24 {
    margin-left: 24px;
    margin-right: 24px;
}

.mb-24 {
    margin-bottom: 24px;
}

.m-30 {
    margin: 30px;
}

.mt-30 {
    margin-top: 30px;
}

.mx-30 {
    margin-left: 30px;
    margin-right: 30px;
}

.mb-30 {
    margin-bottom: 30px;
}

.p-30 {
    padding: 30px;
}

.pt-30 {
    padding-top: 30px;
}

.pb-30 {
    padding-bottom: 30px;
}

.px-30 {
    padding-right: 30px;
    padding-left: 30px;
}

.m-40 {
    margin: 40px;
}

.mt-40 {
    margin-top: 40px;
}

.mx-40 {
    margin-left: 40px;
    margin-right: 40px;
}

.mb-40 {
    margin-bottom: 40px;
}

.p-40 {
    padding: 40px;
}

.pt-40 {
    padding-top: 40px;
}

.pb-40 {
    padding-bottom: 40px;
}

.px-40 {
    padding-right: 40px;
    padding-left: 40px;
}

.gap-0 {
    gap: 0px;
}

.gap-10 {
    gap: 10px;
}

.gap-20 {
    gap: 20px;
}

.gap-30 {
    gap: 30px;
}

.gap-40 {
    gap: 40px;
}

/* TYPOGRAPHY */

.font-normal {
    font-family: "Roboto", sans-serif;
}

.font-condensed {
    font-family: "Roboto-Condensed", sans-serif;
}

.font-thin {
    font-weight: 100;
}

.font-light {
    font-weight: 300;
}

.font-regular {
    font-weight: 400;
}

.font-medium {
    font-weight: 500;
}

.font-bold {
    /* La valeur devrait être 700, mais on ne veut pas de police aussi grasse dans cette application */
    font-weight: 500;
}

.font-12 {
    font-size: 12px;
}

.font-14 {
    font-size: 14px;
}

.font-16 {
    font-size: 16px;
}

.font-18 {
    font-size: 18px;
}

.font-20 {
    font-size: 20px;
}

.font-24 {
    font-size: 24px;
}

.font-32 {
    font-size: 32px;
}

.uppercase {
    text-transform: uppercase;
}

.underline {
    text-decoration: underline;
}

.opacity-50 {
    opacity: 0.5;
}

.overflow-ellipsis {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.overflow-auto {
    overflow: auto;
}

.overflow-hidden {
    overflow: hidden;
}

.break-words {
    overflow-wrap: break-word;
}

/* COLORS */

.background-none {
    background: none;
}

.background-opacity-50 {
    background-color: rgba(0, 0, 0, 0.5);
}

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

.background-primary-50-muted {
    background-color: var(--primary-50-muted);
}

.background-primary-55-muted {
    background-color: var(--primary-55-muted);
}

.background-neutral-50 {
    background-color: var(--neutral-50);
}

.background-primary-600 {
    background-color: var(--primary-600);
}

.background-primary-gradient {
    background: var(--gradient-primary);
}

.color-white {
    color: var(--white);
}

.color-black {
    color: var(--neutral-670);
}

.color-primary-200-muted {
    color: var(--primary-200-muted);
}

.color-primary-300 {
    color: var(--primary-300);
}

.color-primary-400 {
    color: var(--primary-400);
}

.color-primary-400-muted {
    color: var(--primary-400-muted);
}

.color-primary-500-muted {
    color: var(--primary-500-muted);
}

.color-neutral-50 {
    color: var(--neutral-50);
}

.color-neutral-300 {
    color: var(--neutral-300);
}

.color-neutral-400 {
    color: var(--neutral-400);
}

.color-success {
    color: var(--success);
}

.color-info {
    color: var(--info);
}

.color-warning {
    color: var(--warning);
}

.color-error {
    color: var(--error);
}

/* BORDERS */

.border-1-solid {
    border-width: 1px;
    border-style: solid;
}

.border-primary-200 {
    border-color: var(--primary-200);
}

.border-neutral-55 {
    border-color: var(--neutral-55);
}

.border-neutral-75 {
    border-color: var(--neutral-75);
}

.rounded-5 {
    border-radius: 5px;
}

.shadowless {
    box-shadow: none;
}

.borderless {
    border: none;
}

/* INTERACTIVITY */

.events-none {
    pointer-events: none;
}

.cursor-pointer {
    cursor: pointer;
}

.resize-none {
    resize: none;
}

.rotate-180 {
    transform: rotate(180deg);
}