body {
    font-family: "Roboto" !important;
    font-size: 16px;
    color: var(--color1);
    background-color: #f3f2f1 !important;
}

#oav-content {
    background-color: #fff !important;
    padding-bottom: 50px;
}

#oav-sub-content {
    margin: 20px 80px;
}

.oav-header {
    padding: 20px 50px;
}

#oav-footer {
    border-top: 1px solid #f3f2f1;
    background-color: #fff !important;
    padding: 20px 50px;
    margin-top: 20px;
    text-align: center;
    font-size: 12px;
}

@media (min-width: 992px) {
    #oav-footer {
        position: fixed;
        left: 0;
        bottom: 0;
        width: 100% !important;
    }

    #oav-content {
        margin-bottom: 60px;
    }
}

@media (max-width: 768px) {
    #oav-sub-content {
        margin: 20px 5px;
    }
    
    .oav-header {
        padding: 20px 5px;
    }
}

.oav-header img {
    width: 200px;
}

a {
    color: var(--color3);
}

.oav-error {
    color: #F77171;
    font-style: italic;
}

/* bouton de test ----------------------------- */

#fillTestDatasBtn {
    position: fixed;
    bottom: 50px;
    left: 20px;
    z-index: 1000;
    background-color: var(--color2) !important;
    border-color: var(--color2) !important;
}


/* couleurs du thème ----------------------------- */

.oav-color1 {
    color: var(--color1);
}

.oav-color2 {
    color: var(--color2);
}

.oav-color3 {
    color: var(--color3);
}

/* top barre de navigation ----------------------------- */

.navbar {
    background-color: var(--color1) !important;
}

.nav-link {
    color: #FFFFFF !important;
}

.nav-link.active {
    color: var(--color2) !important;
    font-weight: bold;
}

.dropdown-item.active, .dropdown-item:active {
    background-color: var(--color2) !important;
}

.oav-username {
    font-size: 16px;
    color: #FFFFFF;
}

.oav-username i {
    margin-right: 10px;
}

.oav-username select {
    height: 30px;
}

.oav-navbar-seller-logo {
    max-height: 40px;
    margin-right: 20px;
    background-color: #FFFFFF;
    padding: 5px;
    border-radius: 5px;
}

/* titres ---------------------------- */
h6, h5, h4, h3, h2, h1 {
    color: var(--color3) ;
    /* font-family: "Raleway" !important; */
}

h1 {
    font-size: 48px !important;
}

h2 {
    font-size: 40px !important;
}

h3 {
    font-size: 32px !important;
}

h4 {
    font-size: 24px !important;
}

h5 {
    font-size: 20px !important;
}

h6 {
    font-size: 16px !important;
}

/* Boutons --------------------------------------- */

.btn-primary:hover, .btn-outline-primary:hover {
    background-color: var(--color3);
    border-color: var(--color3);
}

.btn-primary:focus, .btn-outline-primary:focus {
    background-color: var(--color1);
    border-color: var(--color1);
    box-shadow: none !important;
}

.btn-primary {
    background-color: var(--color3) !important;
    border-color: var(--color3) !important;
    padding: 8px 20px;
}

.btn-secondary {
    background-color: #fff !important;
    border-color: var(--color3) !important;
    color: var(--color3) !important;
    padding: 8px 20px;
}

.btn-success {
    background-color: var(--color1) !important;
    border-color: var(--color1) !important;
    color: #fff !important;
    padding: 8px 20px;
}

.btn {
    border-radius: 50px !important;

}

/* boutons radio et checkbox --------------------------------------- */

.form-check-input {
    border: var(--bs-border-width) solid var(--color3) !important;
}

.form-check-input:checked  {
    background-color: var(--color1) !important;
}

.form-check-input:checked[type=radio] {
    --bs-form-check-bg-image: none;
}

.form-check-input:focus {
    box-shadow: none;
}

.form-check-input[type=checkbox] {
    border-radius: 0px;
}

/* Barre de progression --------------------------------------- */

.oav-progress-bar {
    margin-bottom: 40px;
}

.oav-progress-bar-title, .oav-progress-bar-next {
    color: #000;
}

.oav-progress-bar-steps {
    font-weight: bold;
    font-size: 24px;
    color: var(--color3);
}

.oav-progress-bar-section-done {
    background-color: var(--color3);
    height: 12px;
}

.oav-progress-bar-section-todo {
    background-color: #fff;
    border: 1px solid var(--color3);
    height: 12px;    
}

.oav-progress-bar-section {
    padding-right: 5px;
    padding-left: 5px;
}

/* Lien "cartes" --------------------------------------- */

.oav-card-link {
    border: 1px solid var(--color3);
    border-radius: 15px;
    color: var(--color3);
    text-decoration: none;
    vertical-align: middle;
    text-align: center;
    padding: 50px 10px;
    cursor: pointer;
}

/* "cartes" besoins --------------------------------------- */

.oav-need-card {
    border: 1px solid var(--color3);
    border-radius: 15px;
    color: var(--color3);
    text-decoration: none;
    vertical-align: middle;
    text-align: center;
    padding: 10px 10px;
    margin-bottom: 20px;
}

.oav-need-card .btn {
    width: 100%;
}

.oav-need-card-info {
    color: var(--color1);
    text-align: justify;
    padding: 5px;
}

/* Questions oui / non --------------------------- */
.oav-yes-no-info {
    font-style: italic;
    font-size: 14px;
}

/* flash messages ----------------------- */

.oav-flash-success, .oav-flash-error {
    width: fit-content;
    block-size: fit-content;
    padding: 10px 30px;
    background-color: #fff;
    margin: auto;
    margin-bottom: 20px;
    border-radius: 5px;
}

.oav-flash-close-btn {
    cursor: pointer;
    margin-left: 20px;
    display: inline-block;
}

.oav-flash-error {
    border: 1px solid #F77171;
    color: #F77171;
}

.oav-flash-success {
    border: 1px solid var(--color3);
    color: var(--color3);
}

/* input des formulaires ------------------- */

.form-control {
    border-radius: 0px;
    border: 1px solid var(--color3);
}

.form-control.empty {
    border: 1px solid #F77171;
}

.form-control:focus {
    border: 1px solid var(--color3);
    box-shadow: 0 0 0 .25rem rgba(150, 150, 150, .25);
}

/* devis - recap besoins ------------------- */

.oav-recap-besoin {
    border: 1px solid var(--color3);
    border-radius: 15px;
    color: var(--color3);
    margin-top: -15px;
    padding: 20px 20px;
    z-index: 1;
}

.oav-recap-besoin-title {
    border-radius: 10px;
    background-color: var(--color3);
    border-color: var(--color3);
    color: #fff;
    display: inline-block;
    padding: 2px 10px;
    margin-left: 15px;
    width: fit-content;
    z-index: 2;
}

/* cartes prix ----------------- */
.oav-price-card {
    border-radius: 10px;
    border: 1px solid var(--color1);
    padding: 20px 20px;
    margin-top: 15px;
    cursor: pointer;
}

.oav-price-card.oav-option-selected {
    border: 1px solid var(--color3);
}

.oav-price-card.oav-option-selected.best-option {
    border: 2px solid var(--color3);
}

.oav-price-card.oav-option-selected .oav-price-card-title, .oav-price-card.oav-option-selected .oav-price-card-price, .oav-price-card.oav-option-selected .oav-price-card-description {
    color: var(--color3);
}

.oav-price-card.best-option {
    margin-top: -15px;
    border: 2px solid var(--color1);
}

.oav-price-card-best {
    border-radius: 10px;
    background-color: var(--color2);
    border-color: var(--color2);
    color: #fff;
    display: inline-block;
    padding: 2px 10px;
    margin-left: 15px;
    width: fit-content;
    z-index: 2;
}

.oav-price-card-description {
    max-height: 120px;
    overflow: hidden;
}

.oav-price-card-description.oav-full-text {
    max-height: 1000px;
}

/* cartes standards ----------------- */

.oav-card-1, .oav-card-2, .oav-card-3 {
    border-radius: 10px;
    padding: 10px 10px;
    margin-top: 15px;
}

.oav-card-1 {    
    border: 1px solid var(--color1);    
}

.oav-card-2 {
    border: 1px solid var(--color2);
}

.oav-card-3 {
    border: 1px solid var(--color3);
}

/* confirmation lecture document ----------------- */

.oav-confirm-doc div {
    display: inline-block;
}

.oav-confirm-doc-btn-link {
    border: 1px solid var(--color3);
    border-radius: 50%;
    padding: 5px 8px;
    width: 35px;
    height: 35px;
    line-height: 35px;
}

.oav-confirm-doc-label {
    color: var(--color3);
    border: 1px solid var(--color3);
    border-radius: 10px;
    padding: 4px 8px;
    width: 350px;
}

.oav-confirm-doc-link {
    text-decoration: none;
}

.oav-legal-text {
    font-style: italic;
    text-align: justify;
    font-size: 12px;
}