#content_page h2, #head_page h1 {
    font-family: 'nexa-bold', Arial, Helvetica, sans-serif;
    font-weight: 400;
    color: #04a599;
    margin: 0
}
#head_page h1 {
    text-align: center
}
.two_column {
    float: left;
    text-align: left
}
#content_page h2 {
    font-family: 'nexa-heavy', Arial, Helvetica, sans-serif;
    text-align: left;
    padding: 0;
    line-height: 1
}
table td h3 {
    line-height: inherit;
    font-size: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: inherit;
    display: initial;
    letter-spacing: inherit;
    text-transform: inherit
}
#content_page h2 span {
    font-family: 'nexa-regular', Arial, Helvetica, sans-serif;
}
#content_page p,
#content_page p.info,
table {
    font-family: open_sansregular, Arial, Helvetica, sans-serif;
    margin: 0;
    color: #616566
}
#content_page p {
    text-align: justify;
    padding: 0;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto
}
#content_page p.info {text-align: left;}
table tr:nth-child(even) {background-color: #e9f5f4}
table tr:nth-child(odd) {background-color: #f5fafa}
table td {
    line-height: 1.25
}
table td span {
    font-family: 'nexa-bold', Arial, Helvetica, sans-serif;
    color: #04a599
}
#offre, #offre_mobile {
    position: relative;
    color: #04a599;
    margin: 0;
    background: #ebff38;
}
#offre p, #offre_mobile p {
    font-family: 'nexa-bold', Arial, Helvetica, sans-serif;
    color: #04a599;
    margin: 0;
    padding: 0
}
#offre img, #offre_mobile img {
    width: auto;
}
#offre a,
#offre_mobile a,
a.achat {
    text-align: center;
    text-decoration: none;
    padding: 12px;
    cursor: pointer
}
#offre a,
#offre_mobile a {
    position: absolute;
    font-family: open_sansbold, Arial, Helvetica, sans-serif;
    color: #FFF;
    display: block;
    border: 2px solid #04a599;
    bottom: 12px;
    left: 12px;
    font-size: 14px;
    -webkit-transition: all .25s ease;
    -moz-transition: all .25s ease;
    -o-transition: all .25s ease;
    -ms-transition: all .25s ease;
    transition: all .25s ease;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;
    background: #04a599;
}
#offre a:hover,
#offre_mobile a:hover {
    border-color: #ebff38
}
#offre a:after,
#offre_mobile a:after {
    font-family: FontAwesome;
    content: '\f07a';
    display: inline-block;
    margin: 0 0 0 6px
}
a.achat {
    font-family: open_sansregular, Arial, Helvetica, sans-serif;
    color: #FFF;
    display: block;
    background-color: #04a599;
    border:solid 1px #04a599;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;
    -webkit-transition: all .25s ease;
    -moz-transition: all .25s ease;
    -o-transition: all .25s ease;
    -ms-transition: all .25s ease;
    transition: all .25s ease;
    padding: 12px 16px;
    width: auto;
}
a.achat:hover {
    border-color: #FFF
}
a.achat:after {
    font-family: FontAwesome;
    content: '\f07a';
    display: inline-block;
    margin: 0
}
@media only screen and (max-width:767px) {
    #offre {
        display: none
    }
    .two_column {
        width: 94%;
        padding: 3%
    }
    #content_page {
        line-height: 1;
        padding: 12px 0
    }
    #head_page h1 {
        font-size: 24px;
        line-height: 30px;
        padding: 24px 0
    }
    #content_page #offre_mobile {
        height: 192px;
        padding: 12px;
        -webkit-border-radius: 6px;
        -moz-border-radius: 6px;
        border-radius: 6px;
        margin: 0 0 18px
    }
    #content_page #offre_mobile img {
        position: absolute;
        top: 12px;
        right: 12px;
        height: 66px
    }
    #content_page #offre_mobile .offre_titre {
        font-size: 30px;
        line-height: 0.9;
        margin-top: 6px;
    }
    #content_page #offre_mobile .offre_texte {
        font-size: 16px;        
        line-height: 1;
    }
    #content_page #offre_mobile .info_texte {
        font-size: 12px;
        line-height: 1.25;
    }
    #content_page h2 {
        font-size: 22px;
        line-height: 22px
    }
    #content_page h2 span {
        font-size: 18px
    }
    #content_page p {
        font-size: 12px;
        line-height: 16px
    }
    #content_page p.info {
        font-size: 8px;
        line-height: 18px;
        padding: 0
    }
    table,
    table td span {
        font-size: 12px
    }
    table td {
        padding: 6px;
    }
    table td span.price {
        font-size: 16px
    }
    table td em {
        font-size: 10px;
        font-style: normal
    }
    a.achat {
        font-size: 12px;
    }
}
@media only screen and (min-width:768px) {
    #offre_mobile {
        display: none
    }
    .two_column {
        width: 360px;
        padding: 12px
    }
    #content_page {
        line-height: 20px;
        padding: 24px 0
    }
    #head_page h1 {
        font-size: 30px;
        line-height: 30px;
        padding: 36px 0
    }
    #content_page h2 {
        font-size: 24px;
    }
    #content_page h2 span {
        font-size: 20px
    }
    #content_page p {
        font-size: 14px;
        line-height: 18px
    }
    #content_page p.info {
        font-size: 11px;
        line-height: 20px;
        padding: 0
    }
    table {
        font-size: 14px
    }
    table td {
        padding: 6px;
    }
    table td span {
        font-size: 12px
    }
    table td span.price {
        font-size: 18px
    }
    table td em {
        font-size: 12px;
        font-style: normal
    }
    #offre {
        height: 195px;
        padding: 12px;
        -webkit-border-radius: 12px;
        -moz-border-radius: 12px;
        border-radius: 12px
    }
    #offre img {
        position: absolute;
        top: 12px;
        right: 12px;
        height: 40% 
    }
    #offre .offre_titre {
        font-size: 34px;
        line-height: 1;
        margin-top: 16px
    }
    #offre .offre_texte {
        font-size: 18px;
        line-height: 1;
    }
    #offre .info_texte {
        text-align: left;
        margin: 0;
        padding: 0;
        position: absolute;
        font-size: 11px;
        line-height: 1.5;
        bottom: 12px;
        right: 12px;
        width: 50%
    }
    #offre a {
        bottom: 12px;
        left: 12px;
        font-size: 16px;
        padding: 12px;
        -webkit-border-radius: 6px;
        -moz-border-radius: 6px;
        border-radius: 6px
    }
    a.achat {
        font-size: 16px;
    }
}
@media only screen and (min-width:1024px) {
    .two_column {
        width: 464px;
        padding: 24px
    }
    #content_page {
        line-height: 24px;
        padding: 24px 0
    }
    #head_page h1 {
        font-size: 36px;
        line-height: 36px;
        padding: 48px 0
    }
    #content_page h2 {
        font-size: 30px;
    }
    #content_page h2 span {
        font-size: 24px
    }
    #content_page p {
        font-size: 16px;
        line-height: 24px
    }
    #content_page p.info {
        font-size: 14px;
        line-height: 24px;
        padding: 0 12px
    }
    table {
        font-size: 18px
    }
    table td {
        padding: 12px;
    }
    table td span {
        font-size: 16px
    }
    table td span.price {
        font-size: 24px;
    }
    table td em {
        font-size: 16px;
        font-style: normal
    }
    #offre {
        height: 242px;
        padding: 24px;
        -webkit-border-radius: 12px;
        -moz-border-radius: 12px;
        border-radius: 12px
    }
    #offre img {
        position: absolute;
        top: 24px;
        right: 24px;
    }
    #offre .offre_titre {
        text-align: left;
        font-size: 48px;
        line-height: 1;
        margin-top: 24px
    }
    #offre .offre_texte {
        font-size: 20px;
        line-height: 1
    }
    #offre .info_texte {
        font-size: 14px;
        line-height: 1.25;
        bottom: 24px;
        right: 24px;
        width: 50%
    }
    #offre a {
        bottom: 24px;
        left: 24px;
        font-size: 18px
    }
    a.achat {
        font-size: 18px;
    }
}