body {
    margin: 0;
    font-family: Arial, Verdana, Helvetica, sans-serif;
    color: #292F33;
    background-color: #F7F7F7;
    font-size: 14px;
}

/* Style de la zone centrale */
main {
    background-color: white;

    box-sizing: border-box;
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    padding: 10px 30px;
    padding-top: 25px;

    counter-reset: section;
}

@media screen and (max-width: 400px) {
    main {
        padding-left: 10px;
        padding-right: 10px;
    }
}

h1.title {
    color: #00538E;
    font-family: Arial, sans-serif;
    font-style: normal;
    font-size: 230%;
    font-weight: bold;
    text-align: left;
    margin-top: 0.5em;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0px;
    background-repeat: no-repeat;
}

div.subtitle {
    color: #10639E;
    font-size: 130%;
    font-style: italic;
    padding-left: 0px;
    margin-bottom: 1em;
}

h1 {
    color: #00538E;
    font-size: 150%
}

h2 {
    font-size: 125%;
}

h2.counter:before {
    content: counter(section)". ";
    counter-increment: section;
}

a:link    { text-decoration: underline; color: #000080; }
a:visited { text-decoration: underline; color: #000080; }
a:hover   { text-decoration: underline; color: #0000FF; }
a:active  { text-decoration: none; color: black; }

a img { border-width: 0 }

.link1:link {
    text-decoration: none;
    color: #0000C0;
}

.link1:visited {
    text-decoration: none;
    color: #0000C0;
}

.link1:hover {
    text-decoration: underline;
    color: #0000DD;
}

.link1:active {
    text-decoration: none;
    color: #0000C0;
}

.link2:link {
    text-decoration: none;
    color: #01a551;
}

.link2:visited {
    text-decoration: none;
    color: #01a551;
}

.link2:hover {
    text-decoration: underline;
    color: #01a551;
}

.link2:active {
    text-decoration: none;
    color: #01a551;
}

/* Liens de navigations en bas de page */

footer {
    color: #666666;
    margin-top: 1.5em;
    padding-bottom: 1.5em;
}

footer a:link, footer a:visited, footer a:active {
    text-decoration: none;
    color: #627D8F;
}

footer a:hover {
    text-decoration: underline;
}

.copyright {
    font-family: Verdana, sans-serif;
    font-size: 9px;
    text-align: center;
}

.navlinks {
    text-align: center;
    margin-bottom: 1em;
}

.navlinks a {
    font-size: 8pt;
    text-transform: uppercase;
}


table.bordures {
    border-collapse: collapse;
    border-top: 1px solid #C0C0C0;
    border-left: 1px solid #C0C0C0;
}

table.bordures th {
    border-bottom: 1px solid #C0C0C0;
    border-right: 1px solid #C0C0C0;
}

table.bordures td {
    border-bottom: 1px solid #C0C0C0;
    border-right: 1px solid #C0C0C0;
}

table.nobordures td {
    border-width: 0;
}

table.borduresdown {
    border-bottom: 1px solid #C0C0C0;
}

table.thin {
    border-collapse: collapse;
    border-width: 0;
}

table.thin tr {
    background-color: #eeeeee;
}

table.thin tr.selected {
    background-color: #D5E0E8;
}

table.thin td {
    border-color: transparent;
}

table.thin th {
    background-color: #CCCCCC;
        
    border-color: transparent;
    font-size: 14px;
    padding-top: 0.2em;
    padding-bottom: 0.2em;
    height: 1.5em;
}

table.invisible tr {
    background-color: transparent;
}

.axial {
    font-weight: bold;
    color: #00538E;
}

.coloraxial {
    color: #00538E;
}

.finance {
    font-weight: bold;
    color: #808080;
}

.axial2 {
    font-size: 125%;
    font-weight: bold;
    color: #00538E;
}

.axial3 {
    font-size: 150%;
    font-weight: bold;
    color: #00538E;
}

.axial2black {
    font-size: 125%;
    font-weight: bold;
     color: black;
}

.finance2 {
    font-size: 125%;
    font-weight: bold;
    color: #808080;
}

.finance3 {
    font-size: 150%;
    font-weight: bold;
    color: #808080;
}

.version {
    font-size: 20px;
    font-weight: bold;
    color: black;
}

.version2 {
    font-size: 18px;
    font-weight: bold;
    color: black;
}

.version3 {
    font-size: 150%;
    font-weight: bold;
    color: black;
}

.version4 {
    font-size: 130%;
    font-weight: bold;
    color: black;
}

.topoversion {
    font-size: 15px;
    font-weight: bold;
    color: #00538E;
}

.registered {
    font-size: 12px;
    font-weight: normal;
    color: black;
}

.ariane {
    font-size: 14px;
    font-weight: bold;
    font-style: italic;
    color: black;
}

.texte {
    padding-left: 4px;
    padding-top: 0;
}


.texteSmall {
    font-size: 11px;
    color: black;
}

.texteMini {
    font-size: 10px;
    color: black;
}

.redevance {
    font-size: 10px;
    color: black;
}

.mentionMot {
    color: #000080;
    font-weight: bold;
}

em {
    color: #00538E;
    font-weight: bold;
    font-style: normal;
}

tt {
    font-size: 125%
}

input.invisible {
    background-color: transparent;
    border-width: 0;
    text-align: right
}

input.price_L {
     background-color: transparent;
     font-weight: bold;
     font-size: 125%;
     border-width: 0;
     text-align: right
}

input.price_Ls {
    background-color: transparent;
    font-weight: normal;
    border-width: 0;
    text-align: right
}

input.price_A {
    background-color: transparent;
    font-weight: bold;
    font-size: 125%;
    margin-top: 1.0em;
    border-width: 0;
    text-align: right
}

/* Marqueur 'New' en marge des items de la liste de fonctionnalités */
.newitem {
    color: red;
    font-weight: bold;
    position: absolute;
    left: -4em;
}

/* Liste des fonctionnalités */
ul.features {
    /*border: 1px solid red;*/
    padding-left: 4px;
    padding-top: 0;
    margin-left: 2em;
    text-align: left;
    position: relative;
    margin-top: 0.0em;
    margin-bottom: 1em;
}

ul.features ul, ul.features ol {
    padding-left: 2em;
}

ul.features > li {
    margin-bottom: 0.75em;
}

/* Actualités */

#news {
    background-color: #EEEEEE;
    margin: 0;
    padding: 0;
}

#news li {
    border-left: 1px solid #848484;
    border-right: 1px solid #848484;
    border-bottom: 1px solid #848484;
    list-style: none;
    padding: 4px;
    text-align: left;
}

/* Avantages de notre offre */

#avantages {
    padding-left: 2em;
    margin: 0;
}

#avantages li {
    margin-bottom: 0.5em;
}


/* Tableaux de Règles */

table.regles {
    background-color: #BBBBBB;
    width: 100%
}

table.regles td {
    vertical-align: top;
    height: 1.5em;
}

table.regles .impair td {
    vertical-align: middle;
    height: 1em;
}

table.regles caption {
    background-color: #AAAAAA;
    height: 30px;
    font-size: 100%;
    line-height: 30px;
    font-weight: bold;
}

table.regles tr {
    background-color: #EEEEEE;
}

table.regles .impair {
    background-color: #CCCCCC;
    color: #000080;
    font-weight: bold;
}


/* Blocs de texte avec une image en marge */

.icone5 { background-image: url(../images/icone5.gif); }
.icone14 { background-image: url(../images/icone14.gif); }
.icone16 { background-image: url(../images/icone16.gif); }
.icone20 { background-image: url(../images/icone20.gif); }
.iconejlc { background-image: url(../images/iconejlc.png); }


.icone5, .icone14, .icone16, .icone20, .iconejlc {
    background-repeat: no-repeat;
    padding-left: 80px;
    padding-right: 1em;
    margin-left: 5px;
    min-height: 70px;
}

/* Style pour les listes de questions de la FAQ */

.faq {
    margin-bottom: 3em;
    padding-left: 3em;
}

.faq dt {
    font-weight: bold;
    font-size: 110%;
    color: #00538E;
    padding-top: 0.3em;
    padding-bottom: 0.3em
}

.faq dd {
    margin: 0;
    padding-left: 0;
    padding-bottom: 2.5em;
    padding-top: 0.5em
}


.indicateur h1 {
    margin-bottom: 1em;
}

.screenshot {
    background-color: #EEF0F2;
    font-weight: bold;
    border-radius: 7px;
    text-align: center;
    cursor: pointer;
}

.screenshot a {
    display: block;
    padding-top: 0.5em;
    outline: none;    
}

.screenshot:hover {
    background-color: #E1E8EC;
    cursor: pointer;
}

.screenshot div { 
    margin-bottom: 0; 
    padding-top: 0.7em;
    padding-bottom: 0.7em;
}

/* Styles pour la page d'accueil */

.productbox-container {
    display: flex;
    align-content: center;
    justify-content: space-between;
    flex-wrap: wrap;
    flex: 2;
    grid-gap: 1em;
}

.productbox {
    border: 1px solid #999999;
    min-height: 230px;
    width: 23%;
    padding: 5px;
    border-radius: 5px;
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.4);
    background-color: white;
    background: linear-gradient(#FAFAFA, #F0F0F0);
    position:relative;
    flex-grow: 1;
    flex-basis: 20%;
}

@media screen and (max-width: 800px) {
    .productbox {
        flex-basis: 40%;
    }
}

@media screen and (max-width: 500px) {
    .productbox {
        flex-basis: 100%;
    }
}

.productbox:hover {
    background: linear-gradient(#EAEAEA, #E0E0E0);
}

.productbox ul {
    list-style-type: square;
    padding-left: 1em;
    margin-top: 0;
}

.productbox li {
    padding-left: 0px;
}

.productbox li span {
    position: relative;
    left: -0.25em
}

.productbox .more {
    position: absolute;
    bottom: 5px;
    left: 0;
    right: 0;
    text-align: center;
}

a.link-softwarebox {
    text-decoration: none;
    color: #000000;
}

a.link-softwarebox:hover {
    text-decoration: none;
}

a.link-softwarebox:visited {
    text-decoration: none;
}

a.link-softwarebox:active {
    text-decoration: none;
}

.title-header {
    background-color: #DAE251;
    margin-top: -25px;
    margin-left: -30px;
    margin-right: -30px;
    padding-top: 25px;
    padding-left: 30px;
    padding-right: 30px;
    padding-bottom: 25px;
    margin-bottom: 2em;
}

@media screen and (max-width: 400px) {
    .title-header {
        margin-left: -10px;
        margin-right: -10px;
        padding-left: 10px;
        padding-right: 10px;
    }
}

.onglets {
    background-color: #DAE251;
    margin-top: -2em;
    margin-left: -30px;
    margin-right: -30px;
    padding-left: 30px;
    margin-bottom: 1em;
}

.onglet {
    display:inline-block;
    font-size: 110%;
    margin-left:0;
    margin-right:0;
    padding-top:0.3em;
    padding-right:1em;
    padding-left: 1em;
    padding-bottom:0.3em;
    cursor:pointer;
}

.onglet a {
    color:#000000;
    text-decoration:none;
    font-size: 110%;
}

@media screen and (max-width: 400px) {
    .onglets {
        margin-left: -10px;
        margin-right: -10px;
        padding-left: 10px;
    }

    .onglet {
        padding-right:0.5em;
        padding-left: 0.5em;
    }
}

.onglet_off {
    background:#FFFFFFAA;
    padding-bottom:4px;
}

.onglet_off:hover {
    background:#FFFFFFD5;
    padding-bottom:4px;
}

.onglet_on {
    background:#FFFFFF;
    padding-bottom:4px;
}

.para-specs {
    column-count:2;
}

@media screen and (max-width: 800px) {
    .para-specs {
        column-count:1;
    }
}

a.button-download {
    font-size: 105%;
    font-weight: bold;

    padding: 0.5em 1em 0.5em 3.5em;

    border-width: 0;
    border-radius: 5px;
    text-decoration: none;
    text-align: center;
    color: white;

    background-color: #627D90;
    background-image: url(../images/download.svg);
    background-repeat: no-repeat;
    background-size: 1.5em;
    background-position: 1em 50%;

    text-wrap: nowrap;
}

/** Suppression de l'icone sur petit écran */
@media screen and (max-width: 350px) {
    a.button-download {
        padding: 0.5em 1em 0.5em 1em;
        background-image: none;
    }
}

a.button-download:hover, input[type=submit]:hover, input[type=button]:hover {
    background-color: #728DA0;
    cursor: pointer;
}

a.button-download:active, input[type=submit]:active, input[type=button]:active {
    background-color: #9AB6C9;
}

input[type=submit], input[type=button] {
    font-size: 105%;
    font-weight: bold;

    padding: 0.5em 1em 0.5em 1em;

    border-width: 0;
    border-radius: 5px;
    text-decoration: none;
    text-align: center;
    color: white;

    background-color: #627D90;
}


.btn-group {
    display: inline-grid;
    gap: 2px;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
}

.btn-group input[type="radio"] {
    display: none;
}

.btn-group label {
    display: inline-block;
    padding: 7px 20px;
    border-radius: 0;
    text-align: center;
    cursor: pointer;
    background: #EEEEEE;
    font-weight: bold;
}

@media screen and (max-width: 400px) {
    .btn-group label {
        padding: 7px 10px;
    }
}

.btn-group label:hover {
    border-color: #999999;
    z-index: 2;
}

.btn-group label:first-of-type {
    border-radius: 5px 0 0 5px;
    margin-left: 0;
}

.btn-group label:last-of-type {
    border-radius: 0 5px 5px 0;
}

.btn-group input[type="radio"]:checked + label {
    background: hsl(205, 19%, 47%);
    color: white;
    z-index: 1;
}


.comparatif {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1em;
    width: 100%;
    border-collapse: collapse;
}

.comparatif tr:nth-child(even) {
    background-color: #E4F0FA
}

.comparatif tr:nth-child(even) td:nth-child(3) {
    background-color: rgba(192, 192, 192, 0.2);
}

.comparatif tr:nth-child(even) td:nth-child(4) {
    background-color: rgba(192, 192, 192, 0.35);
}
.comparatif tr:nth-child(even) td:nth-child(5) {
    background-color: rgba(192, 192, 192, 0.5);
}

.comparatif td {
    text-align: center;
    padding-top: 0.2em;
    padding-bottom: 0.2em;
}

.comparatif td:nth-child(1) {
    text-align: left;
}

.comparatif td:nth-child(2) {
    width: 77px;
}

.comparatif td:nth-child(3) {
    width: 77px;
}

.comparatif td:nth-child(4) {
    width: 77px;
}

.comparatif td:nth-child(5) {
    width: 77px;
}

.comparatif td img {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.comparatif td.item {
    text-align: left;
    padding-left: 1em;
}


/* Style pour les pages tarifs */

.softwarebox-container {
    display: flex;
    grid-gap: 1em;
    justify-content: center;
}

.softwarebox-container > div:nth-child(2) {
    flex-shrink: 2;
    padding-top: 3em;
}

.softwarebox-container > div:first-child, .softwarebox-container > div:last-child {
    flex-basis: 40%;
}

.softwarebox {
    border: 1px solid #999999;
    min-height: 10em;
    width: 100%;
    padding: 0.0em;
    height: 10em;
    border-radius: 5px;
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.4);
    background-color: white;
    background: linear-gradient(#F9F9F9, #E0E0E0);
    cursor:pointer;
}

.softwarebox h2 {
    /* border: 1px solid red; */
    margin-top: 0.25em;
    margin-bottom: 0.25em;
}

.softwarebox h3 {
    margin-top: 0.25em;
    margin-bottom: 0.25em;
}

.softwarebox:hover {
    text-decoration: none;
}

.softwarebox:visited {
    text-decoration: none;
}

.softwarebox:active {
    text-decoration: none;
}

.upgrade-note {
    padding-top:3px;
    font-size: 85%;
    margin-left: auto;
    margin-right: auto;
    width: 90%;
}

@media screen and (max-width: 800px) {
    .softwarebox-container > div:first-child, .softwarebox-container > div:last-child {
        flex-basis: 45%;
    }
}

@media screen and (max-width: 700px) {
    .softwarebox {
        height: 12em;
    }
}

@media screen and (max-width: 700px) {
    .softwarebox-container {
        justify-content: space-evenly;
        flex-direction: column;
    }

    .softwarebox {
        height: 10em;
        /*flex-basis: auto;*/
    }

    .softwarebox-container > div:nth-child(2) {
        padding: 0;
        margin: -1em;
    }
}

@media screen and (max-width: 400px) {
    .upgrade-note {
        width: 95%;
    }
}

/* Style pour la page des partenaires */

.partnerbox {
    width: 49%;
    float: left;
    margin-top: 0.5em;
    margin-bottom: 0.5em;
}

.partnerbox a {
    display: flex;
    height: 90px;
    align-items: center;
    justify-content: center;
}

.partnerbox div {
    height: 2em;
    padding: 0.5em;
    text-align: center;
    color: gray;
}

/* Style pour les pages produits */

.flex-para {
    display: flex;
    flex-direction: row;
    column-gap: 1.5em;
    margin-bottom: 2em;
}
.flex-para-image {
    align-self: start;
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: 33%;
    padding-top: 1.2em;
    text-align: center;
}
.flex-para-text {
    align-self: start;
}

@media screen and (max-width: 800px) {
    .flex-para {
        flex-direction: column-reverse;
    }

    .flex-para-image {
        align-self: center;
    }

    .flex-para-inversed {
        flex-direction: column;
    }
}

.slide {
    box-sizing: border-box;
    width: 100%;
    height: 250px;
    border: 1px solid #374149;
    background: linear-gradient(to bottom, #617C8F, #9AB6CA);
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: stretch;
}

@media screen and (max-width: 900px) {
    .slide-text {
        font-size: 90%;
    }
}

@media screen and (max-width: 850px) {
    .slide-text {
        font-size: 80%;
    }
}

@media screen and (max-width: 800px) {
    .slide-text {
        font-size: 75%;
    }
}

@media screen and (max-width: 750px) {
    .slide-text {
        font-size: 70%;
    }
}

@media screen and (max-width: 700px) {
    .slide {
        flex-direction: column-reverse;
        height: 410px;
    }

    .slide-image {
        margin-bottom: 10px;
    }

    .slide-text {
        padding-left: 10px;
        padding-right: 10px;
    }
}

@media screen and (max-width: 500px) {
    .slide {
        flex-direction: column-reverse;
        height: 460px;
    }

    .slide-image {
        margin-bottom: 5px;
    }

    .slide-text {
        padding-left: 5px;
        padding-right: 5px;
    }
}

.slide-image {
    align-self: center;
    flex-basis: 345px;
}

.slide-image img {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.slide-text {
    align-self: center;
    flex-basis: 555px;
}

.slide h1 {
    font-size: 250%;
    color: white;
    font-family: Roboto, sans-serif;
    margin-top: 0.5em;
}

.slide h2 {
    font-size: 200%;
    color: yellow;
    line-height: 125%;
}


/* Style pour le formulaire de téléchargement de la version de démonstration */

form.slimform {
    width: fit-content;
    margin-left: auto;
    margin-right: auto
}

form.slimform ul {
    padding-left: 0;
}

form.slimform ul li {
    list-style: none;
}

form.slimform label:has(> span) {
    margin: 1em 0;
    position: relative;
    display: inline-block;
}

form.slimform label > span {
    padding: 5px;
    pointer-events: none;
    position: absolute;
    left: 0;
    top: 0;
    transition: 0.2s;
    transition-timing-function: ease;
    opacity: 0.5;
}

form.slimform input[type=text], select {
    box-sizing: border-box;
}

form.slimform input[type=text], select {
    padding: 5px;
    border: 1px solid darkgray;
    border-radius: 3px;
}

form.slimform input[type=text]:focus + span, form.slimform input[type=text]:not(:placeholder-shown) + span {
    opacity: 1;
    transform: translateY(-100%) translateX(-5px);
    font-size: 75%;
}

.radio-button {
    display: flex;
    line-height: 200%;
}

.radio-button label {
    align-self: center;
    margin-left: 0.5em;
}

.radio-button input {
    align-self: center;
    margin-top: 0;
    margin-bottom: 0;
}
