.img-article {
    width: 100%;
    border-radius: 20px;
}

.article {
    margin-left: 10% !important;
    margin-right: 10% !important;
}

.btnLigne {
    margin-left: 10%;
    width: 15%;
}

.btnLigneT {
    margin-left: 10%;
    width: 20%;
}

.certification {
    width:10%;
    float: right;
    margin: -1% 5% 0 3%;
}

.margReduiteP {
    margin-left: 2% !important;
    margin-top: 0 !important;
}

.margReduitecode {
    margin-left: 8% !important;
}

.apropos {
    margin-top: auto;
}

.imgAcc {
    width:20%;
    margin-left: 4%;
}

.pBlockquote {
    margin-left: 3.5rem;
}

.h1_index {
    font-size: 3em;
    margin-top: 0;
    font-weight: 600;
    background: none !important;
    color: white !important;
    -webkit-text-fill-color: unset;
}

.h2_index {
    font-size : 1.4em;
    font-weight: 500;
    color: white;
    font-variant-caps: unset;
    text-align: center;
}

.h3_index {
    color : #607D8B;
    font-variant-caps: unset;
    font-weight: 500;
}

.backAcc {
    width: 100%;
}

.Img_Fb {
    margin-bottom: -40%;
    margin-top: -12%;
}

.menuPaypal {
    margin-top: 18px;
    margin-left: 30px;
    margin-right: 30px;
}

.bordArr {
    border-radius: 7px;
}

.marque {
    text-align: center;
    font-family: "Open Sans", sans-serif;
}

.LogoSH {
    height: 16px;
}


.ImgCenter {
    display:block;
    margin-left:auto;
    margin-right:auto;
}

.Info, .Alerte {
    margin-left:5%;
    margin-right:5%;
}

.Information {
    margin-left: 2%;
    font-family:'Orbitron',sans-serif;
    font-size:large;
    text-align:justify;
    line-height:30px;
    color:black;
}

.Solution {
    font-family:'Orbitron',sans-serif;
    margin-left:100px;
    margin-right:80px;
    font-size:x-large;
    text-align:justify;
    line-height:30px;
    color:green;
}

.CableRJ45 {
    float: right;
    margin-right: 10%;
    border:1px double grey;
    box-shadow:5px 5px 5px #888;
}

.SSHX11 {
    display:block;
    margin-left: auto;
    margin-right: auto;
}

.Img_Completed {
    margin-left:auto;
    margin-right:auto;
}

.ImgWifi {
    width:400px;
    height:180px;
    margin-left:auto;
    margin-right:25px;
    box-shadow:5px 5px 5px #888
}

.Img_ChooseBoot {
    width: 25%;
    border:1px double grey;
    box-shadow:5px 5px 5px #888;
    margin-left:auto;
    margin-right:auto;
    display:block;
    float: right;
}

.Img_Rasp-Conf, .Img_Desk {
    width: 50%;
}

.SchServo {
    width: 80%;
}

.ImgCentreBordure {
    display:block;
    margin-left:auto;
    margin-right:auto;
    border-radius: 15px;
}

.configRasp {
    margin-left: 20%;
    margin-right: 20%;
}

.h3marg {
    margin-left: 8% !important;
}

.t10p {
    width: 10%;
}
.t20p {
    width: 20%;
}
.t30p {
    width: 30%;
}
.t40p {
    width: 40%;
}
.t50p {
    width: 50%;
}
.t60p {
    width:60%;
}
.t70p {
    width: 70%;
}
.t80p {
    width: 80%;
}
.t90p {
    width: 90%;
}
.t100p {
    width: 100%;
}

.t2Im, .t3Im, .t4Im, .t6Im {
    border-radius: 15px;
}

.t2Im {
    width: 40%;
    margin-left: 6.6%;
    margin-top: 20px;
}
.no-margin-top {
    margin-top: 0 !important;
}

.t3Im{
    width:27%;
    margin-left: 5%;
}
.t4Im {
    width: 20%;
    margin-left: 4%;
}
.t4ImCont, .t2ImCont, .t3ImCont {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
.t2ImCont2 {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
.t2ImCont3 {
    width: 75%;
    margin-left: auto;
    margin-right: auto;
}
.t6Im {
    width:14%;
    margin-left: 2.1%;
}

.Img_Tipee {
    width: 53px;
    height: 53px;
    margin-bottom: -40%;
    margin-top: -12%;
}

.LienTipee {
    width: 10%;
    display:block;
    margin-left:auto;
    margin-right:auto;
}

.getInOnGooglePlay {
    margin-left:20%;
    margin-right: 20%;
}

.MAJ_Page{
    text-align: right;
    font-family:'Open Sans',sans-serif;
    color: grey;
    font-style : italic;
    margin-top: -35px;
}

.hrTitre{
    border-radius: 10px;
    margin-top: 20px;
    margin-left: auto;
    margin-right: auto;
    width: 80px;
    height: 8px;
    background: rgb(8,178,227);
    background: linear-gradient(90deg, rgba(6,146,192,1) 0%, rgba(87,167,115,1) 100%);
}

.ationPR {
    font-family:'Orbitron',sans-serif;
    font-size:small;
    color:grey;
}

.anotationDI {
    font-family:'Orbitron',sans-serif;
    margin-left:10%;
    font-size:small;
    text-align:justify;
    line-height:5px;
    color:grey;
}

.ChampInfo {
    font-family:'Orbitron',sans-serif;
    margin-left:100px;
    margin-right:80px;
    margin-top:-20px;
    font-size:60%;
    text-align:justify;
    line-height:30px
}

.MsgValide
{
    font-family: 'Orbitron', sans-serif;
    margin-left : 100px;
    margin-right : 80px;
    font-size : large;
    text-align:justify;
    line-height: 30px;
    color:green;
}

.MsgInvalide
{
    font-family: 'Orbitron', sans-serif;
    margin-left : 100px;
    margin-right : 80px;
    font-size : large;
    text-align:justify;
    line-height: 30px;
    color:red;
}

.ChampCompteDDN {
    font-family:'Orbitron',sans-serif;
    font-weight : bold;
    margin-left:100px;
    margin-right:20px;
    font-size:80%;
    line-height:30px
}

.BoutonEnvoi{
    background-color: #A0A0A0  ;
    font-family:'Orbitron',sans-serif;
    color : white;
    font-weight : bold;
    text-align:center;
    margin-left: 90%;
    width: 120px;
}

.ChampCompteSelect{
    font-family:'Orbitron',sans-serif;
    font-weight : bold;
    font-size:80%;
    text-align:justify;
}

.CadreCompte{
    border-radius: 8px;
    width: 500px;
    display:block;
}

.ChampCompte {
    font-family:'Orbitron',sans-serif;
    font-weight : bold;
    margin-left:100px;
    margin-right:80px;
    font-size:80%;
    text-align: left;
    line-height:30px
}

#Afficheur7Segments {
    float: right;
    margin-left:20px;
    margin-right:10px;
    padding: 1% 3%;
}

.afficheursBonus {
    display: inline-block;
    width: 15%;
    margin-left: 13.75%;
    text-align: center;
}

.tuileAcc2 {
    margin-left: 20%;
}

/* ====================
   Article / tutorial pages
   ==================== */

.articlePage {
    width: 94%;
    max-width: 1680px;
    margin: 0 auto 4rem;
    padding: 1.5rem 0.5rem 0;
}

.articlePage-header {
    text-align: center;
    margin-bottom: 2.25rem;
}

.articlePage-title {
    margin: 0 0 0.85rem;
    font-size: clamp(1.75rem, 3.2vw, 2.35rem);
    font-weight: 800;
    line-height: 1.25;
    text-align: center;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 10%, rgba(87, 167, 115, 1) 61%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.articlePage-header .hrTitre {
    margin-bottom: 0;
}

.articlePage-layout {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.articlePage-main {
    text-align: left;
}

.articlePage-meta {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-bottom: 1.75rem;
    text-align: right;
}

.articlePage-metaItem {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.45rem 0.95rem 0.45rem 0.5rem;
    font-size: 0.88rem;
    font-weight: 500;
    line-height: 1.3;
    color: #455a64;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 999px;
    box-shadow: 0 1px 8px rgba(44, 62, 80, 0.05);
}

.articlePage-metaIcon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 1.75rem;
    height: 1.75rem;
    font-size: 0.78rem;
    border-radius: 50%;
}

.articlePage-metaValue {
    padding-right: 0.15rem;
}

.articlePage-metaItem--date .articlePage-metaIcon {
    color: #0692C0;
    background: rgba(6, 146, 192, 0.12);
}

.articlePage-metaItem--comments .articlePage-metaIcon {
    color: #607d8b;
    background: rgba(96, 125, 139, 0.12);
}

.articlePage-metaItem--rating .articlePage-metaIcon {
    color: #e6a700;
    background: rgba(230, 167, 0, 0.14);
}

.articlePage-metaItem--rating .articlePage-metaValue {
    font-weight: 700;
    color: #29434e;
}

.articlePage-content {
    font-size: 1rem;
    line-height: 1.7;
    color: #37474f;
}

.articlePage-content > h2,
.articlePage-content h2 {
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    padding-bottom: 0.55rem;
    font-size: clamp(1.35rem, 2.5vw, 1.7rem);
    font-weight: 700;
    color: #29434e;
    border-bottom: 2px solid #e8ecef;
    position: relative;
}

.articlePage-content > h2::before,
.articlePage-content h2::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 3.5rem;
    height: 2px;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
}

.articlePage-content > h3,
.articlePage-content h3 {
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    font-size: clamp(1.15rem, 2vw, 1.35rem);
    font-weight: 600;
    font-variant-caps: normal;
    color: #455a64;
}

.articlePage-content > p,
.articlePage-content p {
    margin-bottom: 1.1rem;
}

.articlePage-content .intro,
.articlePage-content > p.intro {
    margin-bottom: 1.5rem;
    padding: 1.15rem 1.35rem;
    font-size: 1.05rem;
    line-height: 1.65;
    border-left: 4px solid #0692C0;
    border-radius: 0 12px 12px 0;
    position: relative;
    z-index: 0;
}

.articlePage-content .intro:not(.text-gradient),
.articlePage-content > p.intro:not(.text-gradient) {
    background: linear-gradient(135deg, rgba(6, 146, 192, 0.06) 0%, rgba(87, 167, 115, 0.06) 100%);
}

.articlePage-content .intro.text-gradient,
.articlePage-content > p.intro.text-gradient {
    font-size: 1.12rem;
    line-height: 1.7;
    background: linear-gradient(to right, #057aa1, #3d8f58);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.articlePage-content .intro.text-gradient::before,
.articlePage-content > p.intro.text-gradient::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(135deg, rgba(6, 146, 192, 0.08) 0%, rgba(87, 167, 115, 0.08) 100%);
    border-radius: 0 12px 12px 0;
}

.articlePage-content .img-article {
    margin-bottom: 1.75rem;
    box-shadow: 0 8px 28px rgba(44, 62, 80, 0.1);
}

.articlePage-content .Code,
.articlePage-content pre {
    margin-top: 0.75rem;
    margin-bottom: 1.25rem;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(44, 62, 80, 0.06);
}

.articlePage-content .Code {
    border-left: 4px solid #0692C0;
}

.articlePage-content pre {
    border-left: 4px solid #607d8b;
}

.articlePage-content .card {
    margin-bottom: 1.5rem;
    border-radius: 14px;
    border-color: rgba(6, 146, 192, 0.22);
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.06);
    overflow: hidden;
}

.articlePage-content .card-header {
    font-weight: 600;
    background: linear-gradient(135deg, rgba(6, 146, 192, 0.08) 0%, rgba(87, 167, 115, 0.08) 100%);
    border-bottom-color: rgba(6, 146, 192, 0.15);
}

.articlePage-content .alert {
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(44, 62, 80, 0.05);
}

.articlePage-content .disclaimer {
    margin-bottom: 1.25rem;
    padding: 1rem 1.25rem;
    background: #fff8f7;
    border-radius: 0 12px 12px 0;
}

.articlePage-content blockquote {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    background: #f7fafc;
    border-left: 4px solid #90a4ae;
    border-radius: 0 12px 12px 0;
}

.articlePage-content ul,
.articlePage-content ol {
    margin-bottom: 1.25rem;
    padding-left: 1.5rem;
}

.articlePage-content .prerequis-box {
    margin-bottom: 1.25rem;
    padding: 0.75rem 1rem 0.5rem;
    background: #f7fafc;
    border-radius: 12px;
    border: 1px solid #e8ecef;
}

.articlePage-content .prerequis-box .prerequis {
    margin-bottom: 0;
    padding: 0 0 0 1rem;
    background: none;
    border: none;
    border-radius: 0;
}

.articlePage-content .prerequis {
    margin-bottom: 1.25rem;
    padding: 0.75rem 1rem 0.75rem 2rem;
    background: #f7fafc;
    border-radius: 12px;
    border: 1px solid #e8ecef;
}

.sponsored-links-note {
    display: block;
    text-align: right;
    margin-top: 0.35rem;
}

.prerequis-box .sponsored-links-note {
    padding-right: 0.15rem;
}

.articlePage-content .table {
    margin-bottom: 1.5rem;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.06);
}

.articlePage-content .table thead th {
    font-weight: 600;
    color: #455a64;
    border-bottom-width: 2px;
}

/* Product comparison table (shared component) */
.kitCompare {
    margin: 1.75rem 0 1.25rem;
}

.kitCompare-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border: 1px solid #e8ecef;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(44, 62, 80, 0.07);
    background: #fff;
}

.kitCompare-table {
    width: 100%;
    min-width: 760px;
    margin-bottom: 0;
    border-collapse: separate;
    border-spacing: 0;
}

.kitCompare-table thead th,
.kitCompare-table tbody th,
.kitCompare-table tbody td {
    padding: 0.95rem 1rem;
    vertical-align: middle;
    border: none;
    border-bottom: 1px solid #eef2f5;
}

.kitCompare-table thead th {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    background: linear-gradient(180deg, #f8fafb 0%, #fff 100%);
    border-bottom: 2px solid #e8ecef;
}

.kitCompare-table tbody tr:nth-child(even) td,
.kitCompare-table tbody tr:nth-child(even) th.kitCompare-featureCol {
    background: #fafcfd;
}

.kitCompare-table tbody tr:last-child td,
.kitCompare-table tbody tr:last-child th {
    border-bottom: none;
}

.kitCompare-featureCol {
    position: sticky;
    left: 0;
    z-index: 2;
    min-width: 9.5rem;
    max-width: 11rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: #607d8b;
    text-align: left;
    background: #fff;
    box-shadow: 4px 0 8px -4px rgba(44, 62, 80, 0.08);
}

.kitCompare-table tbody tr:nth-child(even) .kitCompare-featureCol {
    background: #fafcfd;
}

.kitCompare-kitCol {
    width: 28%;
    text-align: center;
}

.kitCompare-value {
    text-align: center;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #455a64;
}

.kitCompare-kitHead {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    position: relative;
}

.kitCompare-kitHead--featured {
    padding-top: 0.35rem;
}

.kitCompare-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
    border-radius: 999px;
    box-shadow: 0 4px 12px rgba(6, 146, 192, 0.22);
}

.kitCompare-imageSlot {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 180px;
    height: 140px;
    margin: 0 auto;
    padding: 0.65rem;
    background: #fff;
    border: 1px solid #eef2f5;
    border-radius: 12px;
    box-shadow: 0 4px 16px rgba(44, 62, 80, 0.1);
    overflow: hidden;
}

.kitCompare-imageSlot--empty {
    font-size: 1.65rem;
    color: #0692C0;
    background: linear-gradient(135deg, rgba(6, 146, 192, 0.1) 0%, rgba(87, 167, 115, 0.1) 100%);
    border-color: rgba(6, 146, 192, 0.18);
}

.kitCompare-imageLink {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 180px;
    height: 140px;
    line-height: 0;
    text-decoration: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.kitCompare-imageLink picture {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.kitCompare-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: none;
    transition: transform 0.25s ease;
}

.kitCompare-imageLink:hover,
.kitCompare-imageLink:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(6, 146, 192, 0.18);
}

.kitCompare-kitName {
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.35;
    color: #29434e;
}

.kitCompare-check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: 0.35rem;
    vertical-align: middle;
    flex-shrink: 0;
    color: #fff;
    font-size: 0.58rem;
    line-height: 1;
    background: linear-gradient(135deg, #0692C0 0%, #57a773 100%);
    border-radius: 50%;
    box-shadow: 0 1px 4px rgba(6, 146, 192, 0.22);
}

.kitCompare-check i {
    line-height: 1;
}

.kitCompare-optionLink {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.42rem 0.8rem;
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.35;
    color: #0692C0;
    text-decoration: none;
    background: linear-gradient(135deg, rgba(6, 146, 192, 0.07) 0%, rgba(87, 167, 115, 0.07) 100%);
    border: 1px solid rgba(6, 146, 192, 0.18);
    border-radius: 10px;
    box-shadow: 0 1px 3px rgba(44, 62, 80, 0.04);
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.2s ease;
}

.kitCompare-optionLink:hover,
.kitCompare-optionLink:focus-visible {
    color: #057aa1;
    text-decoration: none;
    background: linear-gradient(135deg, rgba(6, 146, 192, 0.12) 0%, rgba(87, 167, 115, 0.12) 100%);
    border-color: rgba(6, 146, 192, 0.32);
    box-shadow: 0 3px 10px rgba(6, 146, 192, 0.12);
    transform: translateY(-1px);
}

.kitCompare-optionLink i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.15rem;
    height: 1.15rem;
    font-size: 0.58rem;
    color: #0692C0;
    background: rgba(255, 255, 255, 0.85);
    border-radius: 6px;
    box-shadow: inset 0 0 0 1px rgba(6, 146, 192, 0.12);
    transition: background 0.2s ease, color 0.2s ease;
}

.kitCompare-optionLink:hover i,
.kitCompare-optionLink:focus-visible i {
    color: #fff;
    background: linear-gradient(135deg, #0692C0 0%, #57a773 100%);
    box-shadow: none;
}

.kitCompare-rating {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.75rem;
    font-weight: 700;
    color: #29434e;
    background: rgba(230, 167, 0, 0.12);
    border-radius: 999px;
}

.kitCompare-rating i {
    color: #e6a700;
}

.kitCompare-na {
    color: #b0bec5;
    font-size: 1.1rem;
}

.kitCompare-price {
    font-size: 1rem;
    font-weight: 700;
    color: #29434e;
}

.kitCompare-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-width: 9rem;
    padding: 0.62rem 1.1rem;
    font-size: 0.85rem;
    font-weight: 600;
    line-height: 1.3;
    color: #fff;
    text-decoration: none;
    background: linear-gradient(135deg, #0692C0 0%, #57a773 100%);
    border: none;
    border-radius: 12px;
    box-shadow: 0 3px 12px rgba(6, 146, 192, 0.22);
    transition:
        color 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.2s ease;
}

.kitCompare-cta:hover,
.kitCompare-cta:focus-visible {
    color: #fff;
    text-decoration: none;
    box-shadow: 0 6px 18px rgba(6, 146, 192, 0.28);
    transform: translateY(-2px);
}

.kitCompare-cta i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    font-size: 0.62rem;
    color: rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.18);
    border-radius: 6px;
    transition: background 0.2s ease, transform 0.2s ease;
}

.kitCompare-cta:hover i,
.kitCompare-cta:focus-visible i {
    background: rgba(255, 255, 255, 0.28);
    transform: translate(1px, -1px);
}

.kitCompare-actionsRow td,
.kitCompare-actionsRow th {
    padding-top: 1.15rem;
    padding-bottom: 1.25rem;
    background: #f8fafb;
}

.kitCompare-mobile {
    display: none;
}

.kitCompare-note {
    margin-top: 0.85rem;
    font-size: 0.88rem;
    color: #90a4ae;
}

@media screen and (max-width: 991px) {
    .kitCompare-desktop {
        display: none;
    }

    .kitCompare-mobile {
        display: grid;
        gap: 1.25rem;
    }

    .kitCompare-card {
        padding: 1.25rem;
        background: #fff;
        border: 1px solid #e8ecef;
        border-radius: 16px;
        box-shadow: 0 4px 20px rgba(44, 62, 80, 0.06);
    }

    .kitCompare-card--featured {
        border-color: rgba(6, 146, 192, 0.28);
        box-shadow: 0 6px 24px rgba(6, 146, 192, 0.12);
    }

    .kitCompare-specs {
        margin: 1.15rem 0 0;
    }

    .kitCompare-spec {
        display: grid;
        grid-template-columns: minmax(7.5rem, 38%) 1fr;
        gap: 0.75rem;
        padding: 0.75rem 0;
        border-bottom: 1px solid #eef2f5;
    }

    .kitCompare-spec:last-child {
        border-bottom: none;
    }

    .kitCompare-spec dt {
        margin: 0;
        font-size: 0.82rem;
        font-weight: 600;
        color: #78909c;
    }

    .kitCompare-spec dd {
        margin: 0;
        font-size: 0.92rem;
        line-height: 1.5;
        color: #455a64;
    }

    .kitCompare-cardAction {
        margin-top: 1.15rem;
        text-align: center;
    }

    .kitCompare-cardAction .kitCompare-cta {
        width: 100%;
        max-width: 20rem;
    }
}

.articlePage-sidebar {
    padding-left: 0;
}

.articlePage-sidebarArticles {
    padding: 1.35rem;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 16px;
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.06);
}

.articlePage-sidebar .stickySide-deals {
    margin-top: 1.75rem;
    padding: 1.35rem;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 16px;
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.06);
}

/* ====================
   Listing pages (tutoriels, composants, projets, articles)
   ==================== */

.listingPage {
    width: 96%;
    max-width: 1280px;
    margin: 0 auto 4rem;
    padding: 1.5rem 0 0;
}

.listingPage-header {
    text-align: center;
    margin-bottom: 2.75rem;
}

.listingPage-title {
    margin: 0 0 0.65rem;
    font-size: clamp(1.85rem, 3vw, 2.35rem);
    font-weight: 700;
    color: #29434e;
}

.listingPage-subtitle {
    margin: 0 auto 1.35rem;
    max-width: 42rem;
    font-size: 1.05rem;
    line-height: 1.55;
    color: #607d8b;
    font-style: italic;
}

.listingPage-header .hrTitre {
    margin-bottom: 0;
}

.listingGrid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

.listingCard {
    height: 100%;
}

.listingCard-link {
    display: flex;
    flex-direction: column;
    height: 100%;
    color: #29434e;
    text-decoration: none;
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid #e8ecef;
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.07);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.listingCard-link:hover,
.listingCard-link:focus-visible {
    color: #29434e;
    text-decoration: none;
    transform: translateY(-5px);
    box-shadow: 0 14px 32px rgba(6, 146, 192, 0.14);
    border-color: rgba(6, 146, 192, 0.28);
}

.listingCard-media {
    position: relative;
    line-height: 0;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: #eef2f5;
}

.listingCard-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0;
    border: none;
    float: none;
    margin: 0;
    transition: opacity 0.25s ease, transform 0.35s ease;
}

.listingCard-link:hover .listingCard-image,
.listingCard-link:focus-visible .listingCard-image {
    opacity: 0.9;
    transform: scale(1.03);
}

.listingCard-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 0.65rem;
    padding: 1.15rem 1.25rem 1.35rem;
}

.listingCard-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.35;
    color: #29434e;
    transition: color 0.2s ease;
}

.listingCard-link:hover .listingCard-title,
.listingCard-link:focus-visible .listingCard-title {
    color: #0692C0;
}

.listingCard-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    font-size: 0.82rem;
    color: #90a4ae;
}

.listingCard-metaItem {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.listingCard-metaSep {
    color: #cfd8dc;
}

.listingCard-desc {
    flex: 1;
    margin: 0 !important;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #607d8b;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.listingCard-cta {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    margin-top: 0.35rem;
    padding: 0.55rem 1.1rem;
    font-size: 0.85rem;
    font-weight: 600;
    line-height: 1.4;
    color: #0692C0;
    background: #fff;
    border: 2px solid rgba(6, 146, 192, 0.28);
    border-radius: 999px;
    transition:
        color 0.25s ease,
        background 0.25s ease,
        border-color 0.25s ease,
        box-shadow 0.25s ease;
}

.listingCard-cta::after {
    content: '→';
    margin-left: 0.45rem;
    line-height: 1;
    transition: transform 0.25s ease;
}

.listingCard-link:hover .listingCard-cta,
.listingCard-link:focus-visible .listingCard-cta {
    color: #fff;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
    border-color: transparent;
    box-shadow: 0 6px 18px rgba(6, 146, 192, 0.2);
}

.listingCard-link:hover .listingCard-cta::after,
.listingCard-link:focus-visible .listingCard-cta::after {
    transform: translateX(3px);
}

.listingCard-link:focus-visible {
    outline: 2px solid rgba(6, 146, 192, 0.45);
    outline-offset: 3px;
}

/* ====================
   Home page tiles
   ==================== */

.tuileSection {
    margin-bottom: 3.5rem;
    padding: 0;
}

.tuileSection .h3_index {
    margin-bottom: 0.75rem;
}

.tuileSection .hrTitre {
    margin-bottom: 2rem;
}

.tuileGrid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.15rem;
    width: 96%;
    max-width: none;
    margin: 0 auto;
}

.tuileLink {
    display: block;
    height: 100%;
    color: #29434e;
    text-decoration: none;
}

.tuileLink:hover,
.tuileLink:focus {
    text-decoration: none !important;
    color: #29434e;
}

.tuileAcc {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
    margin: 0;
    text-align: center;
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid #e8ecef;
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.07);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    position: relative;
}

.tuileLink:hover .tuileAcc,
.tuileLink:focus-visible .tuileAcc {
    transform: translateY(-5px);
    box-shadow: 0 14px 32px rgba(6, 146, 192, 0.14);
    border-color: rgba(6, 146, 192, 0.28);
}

.tuileAcc::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
    opacity: 0;
    transition: opacity 0.25s ease;
}

.tuileLink:hover .tuileAcc::after,
.tuileLink:focus-visible .tuileAcc::after {
    opacity: 1;
}

.tuileAcc picture {
    display: block;
    line-height: 0;
}

.tuileAccImg {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 0;
    border-bottom: 4px solid #e0e0e0;
    transition: opacity 0.2s ease;
}

.tuileLink:hover .tuileAccImg,
.tuileLink:focus-visible .tuileAccImg {
    opacity: 0.85;
}

.tuileAccTextCont {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem 0.85rem 1.2rem;
    min-height: 3.75rem;
}

.tuileAccText {
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1.35;
    margin: 0;
    text-align: center;
    color: #455a64;
    transition: color 0.2s ease;
}

.tuileLink:hover .tuileAccText,
.tuileLink:focus-visible .tuileAccText {
    color: #0692C0;
}

.tuileSectionCta {
    margin-top: 2.25rem;
}

.tuileSectionCtaBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 0.85rem 2.1rem;
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.4;
    color: #0692C0;
    text-decoration: none;
    background: #fff;
    border: 2px solid rgba(6, 146, 192, 0.32);
    border-radius: 999px;
    box-shadow: 0 2px 12px rgba(44, 62, 80, 0.07);
    transition:
        color 0.25s ease,
        background 0.25s ease,
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.25s ease;
}

.tuileSectionCtaBtn::after {
    content: '→';
    font-size: 1.05em;
    line-height: 1;
    transition: transform 0.25s ease;
}

.tuileSectionCtaBtn:hover,
.tuileSectionCtaBtn:focus-visible {
    color: #fff;
    text-decoration: none;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
    border-color: transparent;
    box-shadow: 0 10px 28px rgba(6, 146, 192, 0.22);
    transform: translateY(-2px);
}

.tuileSectionCtaBtn:hover::after,
.tuileSectionCtaBtn:focus-visible::after {
    transform: translateX(4px);
}

.tuileSectionCtaBtn:focus-visible {
    outline: 2px solid rgba(6, 146, 192, 0.45);
    outline-offset: 3px;
}

.floatDroite {
    width: 17%;
    float: right;
    box-shadow: 5px 5px 5px #888;
    margin: auto 2%;
}

.CaptHC501 {
    float: right;
    box-shadow:5px 5px 5px #888;
    margin-left:20px;
}

.New {
    display:block;
    margin-left:auto;
    margin-right:auto;
    margin-top:-110px;
    height:115px;
    box-shadow:10px 10px 5px #888
}

.VideoDemo {
    width:600px
}

.Liens {
    color:green;
    margin-left:100px;
    line-height:50px
}

.Initialisation,.Curseur,.ModeDirect {
    width:320px;
    height:180px;
    margin-left:auto;
    margin-right:25px;
    box-shadow:5px 5px 5px #888
}

.AffichageEcran {
    width:517px;
    height:201px;
}

.EcranBranche {
    width:533px;
    height:320px;
}

.textDon {
    font-family:'Orbitron',sans-serif;
    margin-left:25px;
    margin-right:25px;
    font-size:small;
    text-align:justify;
    line-height:30px
}

.DeskWifi,.ScanResults {
    display:block;
    margin-left:200px;
    margin-right:auto;
    width:298px;
    height:150px;
    box-shadow:5px 5px 5px #888
}

.Desktop,.Scan,.Results {
    display:block;
    margin-left:auto;
    margin-right:200px;
    width:298px;
    height:150px;
    box-shadow:5px 5px 5px #888
}

.Attention {
    font-family:'Orbitron',sans-serif;
    margin-left:100px;
    margin-right:80px;
    font-size:x-large;
    text-align:justify;
    line-height:30px;
    color:red
}

.Annotations {
    font-family:'Orbitron',sans-serif;
    margin-left:100px;
    margin-right:80px;
    font-size:small;
    text-align:justify;
    line-height:30px
}


.Code {
    color: white;
    margin: auto;
    width: 90%;
    padding: .6em 1em;
    background-color: #33475C;
    border-radius: .5em;
    word-wrap: break-word;
    text-justify: none;
}

.info-under-code {
    margin: auto;
    width: 90%;
}

.RaspiConfig {
    width:520px;
    height:250px;
}

.Capt {
    margin-left:70px;
    width:298px;
    height:150px;
    box-shadow:5px 5px 5px #888
}


.ImgServo {
    float:right;
}

.SDCard,.Install {
    float:right;
    width:298px;
    height:150px;
    box-shadow:5px 5px 5px #888
}


.MenuDebutants {
    margin-left:8.5%;
    margin-right:8.5%;
}

.MenuDebutants:hover {
    opacity:.5;
    filter:alpha(opacity=30);
    box-shadow:8px 8px 12px #aaa
}

/*noinspection CssUnusedSymbol*/
.PrDeb {
    width:310px;
    margin-top:-70px;
    margin-left:995px;
    height:115px;
    box-shadow:10px 10px 5px #888
}

.Img_Accueil {
    width:312px;
    margin-top:0;
    margin-left:25px;
    height:125px;
}

.LienContact {
    text-align:Center;
    color:grey;
    display:block;
    margin-left:auto;
    margin-right:auto
}

.iframeBr {
    width:600px;
    height:25px;
    display:block;
    margin-left:auto;
    margin-right:auto
}

pre {
    width:90%;
    display:block;
    margin-left:auto;
    margin-right:auto;
    border-left: 4px solid #607d8b;
    color: black !important;
    padding: .6em 1em;
    background-color: #E7ECEE;
    border-radius: .5em;
    word-wrap: break-word;
    text-justify: none;
}

hr {
    border-top: 1px solid #808080;;
    margin: 23px 5% 23px 5%;
}

.pInfo {
    margin-left: 5%;
    margin-right: 5%;
}

.CodeInfo {
    margin-left: 10%;
    font-family:'Open Sans',sans-serif;
    font-size:large;
    text-align:justify;
    border-left:3px solid grey;
    color:grey;
    line-height:20px;
    padding-left: .3em;
}

.LiensUl {
    margin-left: 15%;
}

.codeGit {
    margin-left: 2%;
    margin-right: 2%;
}

/* ====================
   Home hero
   ==================== */

#imgAcc {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

#textAcc {
    text-align: center;
    padding: 0 1.5rem;
}

.heroCtaBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.35rem;
    padding: 0.9rem 1.85rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.35;
    color: #fff;
    text-decoration: none;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
    border: 2px solid rgba(255, 255, 255, 0.28);
    border-radius: 999px;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.25);
    transition:
        transform 0.25s ease,
        box-shadow 0.25s ease,
        border-color 0.25s ease;
}

.heroCtaBtn:hover,
.heroCtaBtn:focus-visible {
    color: #fff;
    text-decoration: none;
    transform: translateY(-3px);
    box-shadow: 0 14px 36px rgba(6, 146, 192, 0.38);
    border-color: rgba(255, 255, 255, 0.5);
}

.heroCtaBtn:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.65);
    outline-offset: 3px;
}

.heroCtaBtn-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.heroCtaBtn-tag {
    font-size: 0.72em;
    font-weight: 500;
    padding: 0.18rem 0.5rem;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    letter-spacing: 0.02em;
}

.navRight {
    margin-left: 60% !important;
    font-size: 120% !important;
}

.bQArticle {
    margin-left: 13%;
    margin-right: 13%;
}

/* ====================
   Home search
   ==================== */

.homeSearchSection {
    margin-bottom: 3rem;
    padding: 0 1rem;
}

.homeSearchSection .hrTitre {
    margin-bottom: 1.75rem;
}

.homeSearch {
    width: 96%;
    max-width: 900px;
    margin: 0 auto;
}

.homeSearch-field {
    position: relative;
    display: flex;
    align-items: center;
}

.homeSearch-icon {
    position: absolute;
    left: 1.35rem;
    display: flex;
    align-items: center;
    color: #90a4ae;
    pointer-events: none;
}

.homeSearch-input {
    width: 100%;
    padding: 1.15rem 3.25rem 1.15rem 3.35rem;
    font-size: 1.15rem;
    line-height: 1.4;
    color: #29434e;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 999px;
    box-shadow: 0 2px 14px rgba(44, 62, 80, 0.07);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    -webkit-appearance: none;
    appearance: none;
}

.homeSearch-input::placeholder {
    color: #90a4ae;
}

.homeSearch-input:focus {
    outline: none;
    border-color: rgba(6, 146, 192, 0.45);
    box-shadow: 0 4px 20px rgba(6, 146, 192, 0.14);
}

.homeSearch-input::-webkit-search-cancel-button,
.homeSearch-input::-webkit-search-decoration {
    -webkit-appearance: none;
    appearance: none;
}

.homeSearch-clear {
    position: absolute;
    right: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    padding: 0;
    font-size: 1.5rem;
    line-height: 1;
    color: #78909c;
    background: transparent;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.homeSearch-clear:hover,
.homeSearch-clear:focus {
    color: #29434e;
    background: #f0f4f7;
    outline: none;
}

.homeSearch-results {
    margin-top: 0.85rem;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 16px;
    box-shadow: 0 8px 28px rgba(44, 62, 80, 0.1);
    overflow: hidden;
}

.homeSearch-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 340px;
    overflow-y: auto;
}

.homeSearch-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f0f3f5;
    transition: background-color 0.15s ease;
}

.homeSearch-item:last-child {
    border-bottom: none;
}

.homeSearch-item:hover,
.homeSearch-item:focus-within {
    background: #f7fafc;
}

.homeSearch-link {
    flex: 1;
    min-width: 0;
    color: #29434e;
    font-weight: 500;
    text-decoration: none;
    line-height: 1.35;
}

.homeSearch-link:hover,
.homeSearch-link:focus {
    color: #0692c0;
    text-decoration: none;
}

.homeSearch-badge {
    flex-shrink: 0;
    padding: 0.2rem 0.55rem;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #546e7a;
    background: #eef2f5;
    border-radius: 999px;
}

.homeSearch-item[data-category="components"] .homeSearch-badge {
    color: #0277bd;
    background: #e1f5fe;
}

.homeSearch-item[data-category="projects"] .homeSearch-badge {
    color: #2e7d32;
    background: #e8f5e9;
}

.homeSearch-item[data-category="getting_started"] .homeSearch-badge {
    color: #00695c;
    background: #e0f2f1;
}

.homeSearch-item[data-category="tutorials"] .homeSearch-badge {
    color: #4527a0;
    background: #ede7f6;
}

.homeSearch-item[data-category="configure"] .homeSearch-badge {
    color: #e65100;
    background: #fff3e0;
}

.homeSearch-item[data-category="articles"] .homeSearch-badge {
    color: #ad1457;
    background: #fce4ec;
}

.homeSearch-item[data-category="contact"] .homeSearch-badge {
    color: #455a64;
    background: #eceff1;
}

.homeSearch-empty {
    margin: 0;
    padding: 1.25rem 1rem;
    text-align: center;
    font-size: 0.92rem;
    color: #90a4ae;
}

.centre {
    text-align: center !important;
    vertical-align: middle !important;
}

.textCentre {
    text-align: center;
    margin: auto !important;
}

.h4Cat {
    color: #455a64;
    padding-left: 0.2em;
    padding-right: 0.2em;
}

.tabPied {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
}

.colonneTitre {
    text-align: center;
    color: #757575;
}

.colonnePied {
    border-width: 2px 2px 2px 2px !important;
    border-left: #E0E0E0 ;
    border-right: #E0E0E0;
    border-left-style: solid;
    border-right-style: solid;
    margin-left: 2%;
    padding-left: 10px;
    padding-right: 10px;
}

.aPied {
    text-decoration: none;
    color: #9E9E9E;
}

.aPied:hover {
    text-decoration: none;
    color: #212121;
}

.txtCentre {
    text-align: center;
}

.txtCentre {
    margin-left: auto !important;
}

#searchbarMenu {
    display: none;
}

.nePasAfficher {
    display: none;
}

.imgInclus {
    width: 35px;
}

.btnRep {
    padding: 0.5rem 0.5rem;
}

.repTxt {
    vertical-align: middle;
}

.floatRightImg {
    float: right;
    margin: 0 2%;
    box-shadow: 3px 3px 6px 0px #656565;
}

.starImg {
    width: 2.25rem;
    height: 2.25rem;
    margin: 0;
    padding: 0.2rem;
    cursor: pointer;
    transition: transform 0.15s ease;
}

.starImg:hover {
    transform: scale(1.12);
}

blockquote p {
    margin-left: 3% !important;
    margin-right: 3% !important;
}

.t3Btn {
    text-align: center;
    margin-left: 10%;
    margin-right: 10%;
}

.fleches {
    width: 4em;
    margin: 0 7% 0 7%;
}

.videoYT {
    float: none;
    clear: both;
    width: 700px;
    position: relative;
    padding-top: 25px;
    margin: 0 auto;
    max-width: 100%;
    text-align: center;
}

ul {
    margin-left: 1em;
    margin-right: 10%;
}

.card-body p {
    margin-left: 1.5em !important;
}

/* ====================
   Modern navbar
   ==================== */

.rl-navbar {
    background: linear-gradient(135deg, #1a263a 0%, #2c3e50 55%, #243447 100%) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.45rem 0;
}

.rl-navbar-container {
    width: 100%;
    max-width: none;
    padding-left: 0;
    padding-right: 0.75rem;
    justify-content: flex-start !important;
}

.rl-navbar .navbar-collapse {
    flex-grow: 0;
}

.rl-navbar-brand {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-right: 0.35rem;
    padding-left: 0.75rem;
    font-weight: 700;
    font-size: 1.15rem;
    letter-spacing: -0.02em;
    transition: opacity 0.2s ease;
}

.rl-navbar-brand:hover,
.rl-navbar-brand:focus {
    opacity: 0.92;
    color: #fff !important;
    text-decoration: none;
}

.rl-navbar-logo {
    border-radius: 7px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}

.rl-navbar-nav {
    gap: 0;
    margin-left: 0 !important;
}

.rl-nav-link {
    position: relative;
    padding: 0.5rem 0.75rem !important;
    border-radius: 8px;
    font-weight: 500;
    font-size: 0.9rem;
    letter-spacing: 0.01em;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.rl-navbar.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.88) !important;
}

.rl-navbar.navbar-dark .navbar-nav .rl-nav-link:hover,
.rl-navbar.navbar-dark .navbar-nav .rl-nav-link:focus {
    background-color: rgba(255, 255, 255, 0.1);
    color: #fff !important;
}

.rl-navbar.navbar-dark .nav-item.active > .rl-nav-link {
    background: linear-gradient(90deg, rgba(6, 146, 192, 0.35) 0%, rgba(87, 167, 115, 0.35) 100%);
    color: #fff !important;
}

.rl-navbar .nav-item.active > .rl-nav-link::after {
    content: '';
    position: absolute;
    bottom: 4px;
    left: 50%;
    transform: translateX(-50%);
    width: 22px;
    height: 3px;
    border-radius: 2px;
    background: linear-gradient(90deg, #0692C0 0%, #57A773 100%);
}

.rl-navbar-toggler {
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 8px;
    padding: 0.4rem 0.65rem;
}

.rl-navbar-toggler:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(24, 188, 156, 0.35);
}

.site-header-spacer {
    height: 58px;
}

.headerPB {
    width: 100%;
    background-color: transparent;
}

.rl-header-progress .progress-container {
    z-index: 0;
    width: 100%;
    height: 3px;
    background: rgba(255, 255, 255, 0.12);
}

.rl-header-progress .progress-bar {
    height: 3px;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%) !important;
    width: 0%;
    transition: width 0.1s ease-out;
}

@media screen and (max-width: 991px) {
    .rl-navbar-toggler {
        margin-left: auto;
    }

    .rl-navbar .navbar-collapse {
        margin-top: 0.75rem;
        padding: 0.75rem;
        background: rgba(26, 38, 58, 0.97);
        border-radius: 12px;
        border: 1px solid rgba(255, 255, 255, 0.08);
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
    }

    .rl-navbar-nav {
        gap: 0.1rem;
    }

    .rl-navbar .nav-item.active > .rl-nav-link::after {
        display: none;
    }

    .site-header-spacer {
        height: 54px;
    }
}


.btnCentre {
    margin: auto;
    display: block !important;
}

.nordvpn {
    margin: auto;
}

.nordvpn-img {
    width: 90%;
}


@media screen and (max-width: 991px) {
    .tuileGrid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.1rem;
    }

    .listingGrid {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }
}

@media screen and (max-width: 1150px){
    .t2ImCont2 {
        width: 90% !important;
        margin-left: auto;
        margin-right: auto;
    }
    .btnShopMenu {
        display: none !important;
    }
    .h1_index {
        font-size: 1.5em;
    }
    .h2_index {
        font-size: 1em;
    }
    .t4Im {
        width: 40%;
        margin-left: 6.5%;
        margin-top: 20px;
    }
}

@media screen and (max-width: 1000px){

    .t40p {
        width: 60%;
    }

    .btn-marg-mob {
        margin-top: 15px;
        width: 80% !important;
    }

}

@media screen and (max-width: 1200px){
    .margin-card {
        margin-left: 7% !important;
        margin-right: 7% !important;
    }
}

@media screen and (max-width: 1500px){
    .article:not(.articlePage-layout) {
        margin-left: 5% !important;
        margin-right: 5% !important;
    }
}

@media screen and (max-width: 700px) {


    .btnComparatif {
        width: 100% !important;
    }

    h1 {
        margin-left: 5% !important;
        margin-right: 5% !important;
    }

    .articlePage-title {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .article:not(.articlePage-layout), .margin-card {
        margin-left: .5em !important;
        margin-right: .5em !important;
    }

    .t2Im {
        width: 80%;
        margin-left: 10%;
        margin-right: 10%;
    }

    .getInOnGooglePlay {
        margin-left: 20%;
        margin-right: 20%;
    }
    .tuileGrid {
        grid-template-columns: 1fr;
        gap: 1.1rem;
        width: 88%;
        max-width: none;
    }

    .tuileSection {
        padding: 0;
    }

    .homeSearch {
        width: 88%;
    }

    .homeSearch-input {
        font-size: 1.05rem;
        padding: 1rem 3rem 1rem 3.1rem;
    }

    .homeSearch-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
        padding: 0.85rem 0.9rem;
    }

    .homeSearch-list {
        max-height: 280px;
    }

    .tuileSectionCtaBtn {
        width: 88%;
        max-width: 320px;
        padding: 0.9rem 1.5rem;
        font-size: 0.9rem;
    }

    .heroCtaBtn {
        width: 92%;
        max-width: 360px;
        padding: 0.85rem 1.35rem;
        font-size: 0.88rem;
    }

    .btn {
        width: 60%;
        font-size: 0.8em;
        vertical-align: middle;
    }
    .h1_index {
        margin-top: 5%;
        font-size: 1.3em;
        color: #29434e;
    }
    .h2_index {
        color: #29434e;
        font-size: .8em;
    }
    .form-group {
        margin-top: -10%;
    }
    .MAJ_Page, .certification {
        display: none;
    }

    .hrTitre {
        display: none;
    }

    .articlePage-header .hrTitre,
    .listingPage-header .hrTitre {
        display: block;
    }
    .g-recaptcha {
        transform:scale(0.77);
        -webkit-transform:scale(0.77);
        transform-origin:0 0;
        -webkit-transform-origin:0 0;
    }

    .topnav li:not(:first-child) {
        display: none;
    }

    .navigation {
        background: #e2f1f8;
    }

    .imgAcc {
        width:100%;
        margin-top: 2%;
    }

    #searchbarMenu {
        display: inline-block;
        width: 50%;
    }

    .nePasAfficherMob, .tabPied {
        display: none;
    }
    .nePasAfficher {
        display: inline;
    }
    .list-group, .noMargeMob {
        margin-right: 5% !important;
    }

    .t90p, .t100p {
        width: 100%;
    }
    .t80p {
        width: 100%;
    }
    .t70p {
        width: 95%;
    }
    .t60p {
        width: 80% !important;
    }
    .t50p {
        width: 75%;
    }
    .t40p {
        width: 70% !important;
    }
    .t30p {
        width: 65%;
    }
    .t20p, .t10p {
        width: 30%;
    }
    .t3Im, .t6Im, .t2Im, .t4Im {
        margin-top: 20px;
    }
    .t3Im, .t4Im {
        width: 70%;
        margin-left: 15%;
    }
    .t4ImCont, .t2ImCont {
        width: 100%;
    }
    .t6Im {
        width:40%;
        margin-left: 6%;
    }

    h1 {
        font-size: 1.85em;
    }
    h2 {
        font-size: 1.5em;
        margin-top: 15%;
    }
    h3 {
        font-size: 1.3em;
    }
    h4 {
        margin-left: 0.5rem;
    }
    label {
        margin-top: 2em;
    }
    .bQArticle {
        margin-left: 5%;
    }
    .pBlockquote {
        margin-left: 1rem;
        margin-right: 0;
    }
    .btnLigne {
        width: 60%;
        margin-left: 25%;
        margin-top: 10px;
    }
    .btnMob {
        margin-left: 15%;
    }
    pre {
        width: 85%;
    }

    .articlePage {
        width: 96%;
        padding-top: 1rem;
    }

    .articlePage-header {
        margin-bottom: 1.75rem;
    }

    .articlePage-meta {
        gap: 0.5rem;
        margin-bottom: 1.35rem;
    }

    .articlePage-metaItem {
        font-size: 0.82rem;
        padding: 0.4rem 0.8rem 0.4rem 0.45rem;
    }

    .articlePage-metaIcon {
        width: 1.55rem;
        height: 1.55rem;
        font-size: 0.72rem;
    }

    .articlePage-content > h2,
    .articlePage-content h2 {
        margin-top: 2rem;
    }

    .articlePage-content .intro,
    .articlePage-content > p.intro {
        padding: 1rem 1.1rem;
        font-size: 1rem;
    }

    .articlePage-content .intro.text-gradient,
    .articlePage-content > p.intro.text-gradient {
        font-size: 1.05rem;
    }

    .listingPage {
        width: 92%;
        padding-top: 1rem;
    }

    .listingPage-header {
        margin-bottom: 2rem;
    }

    .listingCard-desc {
        -webkit-line-clamp: 2;
    }
}

@media screen and (min-width: 1200px) {
    .listingGrid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media screen and (max-width: 430px){
    .listingCard-body {
        padding: 1rem;
    }
}

.text-gradient {
    background: linear-gradient(to right, #057aa1, #3d8f58);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.intro {
    font-weight: 600;
}

/* ====================
   Sticky sidebar (articles + deals)
   ==================== */

.stickySide-heading {
    margin: 0 0 1.15rem;
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.3;
    background: linear-gradient(90deg, #54A06F 0%, #0687B2 30%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.stickySide-badge {
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
    color: #90a4ae;
    -webkit-text-fill-color: #90a4ae;
}

.stickySide-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.stickySide-deals {
    margin-top: 2rem;
}

#stick {
    position: -webkit-sticky;
    position: sticky;
    top: 72px;
    z-index: 2;
    align-self: flex-start;
}

.stickySide-article {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.35rem;
    color: #29434e;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.stickySide-article:last-of-type {
    margin-bottom: 0;
}

.stickySide-article:hover,
.stickySide-article:focus-visible {
    color: #29434e;
    text-decoration: none;
    opacity: 0.88;
}

.stickySide-articleMedia {
    flex: 0 0 44%;
    line-height: 0;
}

.stickySide-articleMedia img {
    display: block;
    width: 100%;
    height: auto;
    border: none;
    border-radius: 12px;
    margin: 0;
}

.stickySide-articleTitle {
    flex: 1;
    margin: 0;
    padding-top: 0.15rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.45;
    color: #29434e;
}

.stickySide-article:hover .stickySide-articleTitle,
.stickySide-article:focus-visible .stickySide-articleTitle {
    color: #0692C0;
}

.stickySide-deal {
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid #e8ecef;
}

.stickySide-deal:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: none;
}

.stickySide-dealLink {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    color: #29434e;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.stickySide-dealLink:hover,
.stickySide-dealLink:focus-visible {
    color: #29434e;
    text-decoration: none;
}

.stickySide-dealMedia {
    flex: 0 0 44%;
    line-height: 0;
}

.stickySide-dealMedia img {
    display: block;
    width: 100%;
    height: auto;
    border: none;
    border-radius: 12px;
    margin: 0;
    transition: opacity 0.2s ease;
}

.stickySide-dealLink:hover .stickySide-dealMedia img,
.stickySide-dealLink:focus-visible .stickySide-dealMedia img {
    opacity: 0.88;
}

.stickySide-dealBody {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 0.45rem;
    min-width: 0;
}

.stickySide-dealTitle {
    display: block;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.45;
    color: #29434e;
    transition: color 0.2s ease;
}

.stickySide-dealLink:hover .stickySide-dealTitle,
.stickySide-dealLink:focus-visible .stickySide-dealTitle {
    color: #0692C0;
}

.stickySide-dealPriceRow {
    display: block;
    font-size: 1.1rem;
    line-height: 1.35;
}

.stickySide-dealPriceOld {
    color: #90a4ae;
    font-weight: 400;
    text-decoration: line-through;
}

.stickySide-dealPrice {
    color: #EF476F;
    font-weight: 700;
}

.stickySide-dealAction {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.15rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: #0692C0;
    text-decoration: underline;
    text-decoration-color: rgba(6, 146, 192, 0.35);
    text-underline-offset: 3px;
    transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.stickySide-dealLink:hover .stickySide-dealAction,
.stickySide-dealLink:focus-visible .stickySide-dealAction {
    color: #057a9e;
    text-decoration-color: rgba(5, 122, 158, 0.55);
}

.stickySide-dealActionIcon {
    display: inline-block;
    text-decoration: none;
    transition: transform 0.2s ease;
}

.stickySide-dealLink:hover .stickySide-dealActionIcon,
.stickySide-dealLink:focus-visible .stickySide-dealActionIcon {
    transform: translateX(3px);
}

.stickySide-ad {
    margin: 1.25rem 0 0.5rem;
}

.margin-card {
    margin-left: 15%;
    margin-right: 15%;
}

.imgComparatif {
    width: 100% !important;
}

.intro a {
    text-decoration: underline !important;
    text-decoration-color: rgb(6,146,192) !important;
}


/* ====================
   Tutorial engagement (rating + comments)
   ==================== */

.tutorialEngagement {
    margin-top: 3rem;
}

.tutorialEngagement-rating {
    margin-bottom: 0.5rem;
}

.ratingCard {
    padding: 2rem 1.75rem;
    text-align: center;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 1rem;
    box-shadow: 0 4px 24px rgba(44, 62, 80, 0.06);
}

.ratingCard-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.ratingCard-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    font-size: 1.25rem;
    color: #e6a700;
    background: rgba(230, 167, 0, 0.14);
    border-radius: 50%;
}

.ratingCard-title {
    margin: 0;
    font-size: clamp(1.25rem, 2.5vw, 1.55rem);
    font-weight: 700;
    color: #29434e;
}

.ratingCard-stars {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.15rem;
    margin-bottom: 1rem;
}

.ratingCard-stats {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin: 0;
    padding: 0.55rem 1.1rem;
    font-size: 0.92rem;
    color: #607d8b;
    background: #f8fafb;
    border: 1px solid #e8ecef;
    border-radius: 999px;
}

.ratingCard-score {
    display: inline-flex;
    align-items: baseline;
    gap: 0.1rem;
}

.ratingCard-mark {
    font-size: 1.15rem;
    font-weight: 700;
    color: #29434e;
}

.ratingCard-max {
    font-weight: 500;
    color: #90a4ae;
}

.ratingCard-divider {
    width: 1px;
    height: 1rem;
    background: #cfd8dc;
}

.ratingCard-votes {
    font-weight: 500;
}

.ratingCard-feedbackWrap {
    text-align: center;
}

.ratingCard-feedback {
    margin: 0.75rem 0 0;
    font-size: 0.95rem;
    text-align: center;
}

.ratingCard-feedback--success {
    color: #00838f;
}

.ratingCard-feedback--error {
    color: #c62828;
}

.commentsSection-header {
    margin-bottom: 1.25rem;
}

.commentsSection-heading {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 0.35rem;
}

.commentsSection-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1.05rem;
    color: #0692C0;
    background: rgba(6, 146, 192, 0.12);
    border-radius: 50%;
}

.commentsSection-title {
    margin: 0;
    font-size: clamp(1.35rem, 2.5vw, 1.7rem);
    font-weight: 700;
    color: #29434e;
}

.commentsSection-count {
    margin: 0 0 0 3.35rem;
    font-size: 0.9rem;
    font-style: italic;
    color: #90a4ae;
}

.commentsSection-list {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    margin-bottom: 1.75rem;
}

.commentCard {
    display: flex;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 0.85rem;
    box-shadow: 0 2px 12px rgba(44, 62, 80, 0.04);
    transition: box-shadow 0.2s ease;
}

.commentCard:hover {
    box-shadow: 0 4px 18px rgba(44, 62, 80, 0.08);
}

.commentCard.repComm {
    margin-left: 2.5rem;
    border-left: 3px solid rgba(6, 146, 192, 0.35);
    border-top-left-radius: 0.35rem;
    border-bottom-left-radius: 0.35rem;
}

.commentCard-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
    font-weight: 700;
    color: #0692C0;
    background: rgba(6, 146, 192, 0.12);
    border-radius: 50%;
}

.commentCard.repComm .commentCard-avatar {
    width: 2rem;
    height: 2rem;
    font-size: 0.85rem;
    color: #607d8b;
    background: rgba(96, 125, 139, 0.12);
}

.commentCard-body {
    flex: 1;
    min-width: 0;
}

.commentCard-header {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.75rem;
    margin-bottom: 0.45rem;
}

.commentCard-author {
    font-size: 0.95rem;
    color: #29434e;
}

.commentCard-date {
    font-size: 0.82rem;
    color: #90a4ae;
}

.commentCard-content {
    font-size: 0.95rem;
    line-height: 1.65;
    color: #455a64;
    word-break: break-word;
}

.commentCard-reply {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.65rem;
    padding: 0.35rem 0.85rem;
    font-size: 0.82rem;
    font-weight: 500;
    color: #0692C0;
    background: transparent;
    border: 1px solid rgba(6, 146, 192, 0.35);
    border-radius: 999px;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.commentCard-reply:hover {
    color: #fff;
    background: #0692C0;
    transform: translateY(-1px);
}

.commentCard-reply--active {
    color: #fff;
    background: #0692C0;
    border-color: #0692C0;
    animation: commentReplyPulse 2s infinite;
}

@keyframes commentReplyPulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(6, 146, 192, 0.35);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(6, 146, 192, 0);
    }
}

.commentsSection-seeMore {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: fit-content;
    margin: 0.5rem auto 0;
    padding: 0.55rem 1.25rem;
    font-size: 0.9rem;
    font-weight: 500;
    color: #455a64;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 999px;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.commentsSection-seeMore:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(44, 62, 80, 0.1);
}

.seeMore {
    display: none;
}

.seeMore.show {
    display: flex;
}

.commentFormCard {
    padding: 1.5rem 1.35rem;
    background: #fff;
    border: 1px solid #e8ecef;
    border-radius: 1rem;
    box-shadow: 0 4px 24px rgba(44, 62, 80, 0.06);
}

.commentFormCard-title {
    margin: 0 0 1.25rem;
    padding-bottom: 0.65rem;
    font-size: 1.1rem;
    font-weight: 600;
    color: #29434e;
    border-bottom: 2px solid #e8ecef;
    position: relative;
}

.commentFormCard-title::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 2.5rem;
    height: 2px;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
}

.commentForm {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.commentForm-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.commentForm-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.commentForm-field label {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 600;
    color: #455a64;
}

.commentForm-control {
    width: 100%;
    padding: 0.65rem 0.85rem;
    font-size: 0.95rem;
    color: #37474f;
    background: #f8fafb;
    border: 1px solid #dfe6ea;
    border-radius: 0.55rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.commentForm-control:focus {
    outline: none;
    background: #fff;
    border-color: #0692C0;
    box-shadow: 0 0 0 3px rgba(6, 146, 192, 0.12);
}

.commentForm-hint {
    margin: -0.35rem 0 0;
    font-size: 0.82rem;
    font-style: italic;
    color: #90a4ae;
}

.commentForm-recaptcha {
    margin-top: 0.25rem;
}

.commentForm-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.25rem;
}

.commentForm-notice {
    margin: 0;
    flex: 1;
    min-width: 12rem;
    font-size: 0.82rem;
    color: #90a4ae;
}

.commentForm-submit {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1.35rem;
    font-size: 0.92rem;
    font-weight: 600;
    color: #fff;
    background: linear-gradient(135deg, #0692C0 0%, #57a773 100%);
    border: none;
    border-radius: 999px;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.commentForm-submit:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(6, 146, 192, 0.3);
}

.commentForm-submit:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

.reply-indicator {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    color: #29434e;
    background: rgba(6, 146, 192, 0.08);
    border: 1px solid rgba(6, 146, 192, 0.2);
    border-radius: 0.65rem;
    animation: slideDown 0.3s ease;
}

.reply-indicator-text {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.reply-indicator-cancel {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.3rem 0.75rem;
    font-size: 0.82rem;
    color: #607d8b;
    background: #fff;
    border: 1px solid #cfd8dc;
    border-radius: 999px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.reply-indicator-cancel:hover {
    background: #f5f7f8;
}

.commentAlert {
    position: relative;
    padding: 0.85rem 2.5rem 0.85rem 1rem;
    font-size: 0.92rem;
    border-radius: 0.65rem;
}

.commentAlert--success {
    color: #1b5e20;
    background: #e8f5e9;
    border: 1px solid #c8e6c9;
}

.commentAlert--error {
    color: #b71c1c;
    background: #ffebee;
    border: 1px solid #ffcdd2;
}

.commentAlert-close {
    position: absolute;
    top: 0.5rem;
    right: 0.65rem;
    padding: 0;
    font-size: 1.25rem;
    line-height: 1;
    color: inherit;
    background: none;
    border: none;
    opacity: 0.6;
    cursor: pointer;
}

.commentAlert-close:hover {
    opacity: 1;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media screen and (max-width: 700px) {
    .ratingCard {
        padding: 1.5rem 1.1rem;
    }

    .commentsSection-count {
        margin-left: 0;
    }

    .commentCard.repComm {
        margin-left: 1rem;
    }

    .commentForm-row {
        grid-template-columns: 1fr;
    }

    .commentForm-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .commentForm-submit {
        justify-content: center;
        width: 100%;
    }
}


/* ====================
   Site footer
   ==================== */

.site-footer {
    margin-top: 2rem;
    color: rgba(255, 255, 255, 0.88);
}

.site-footer-main {
    position: relative;
    padding: 3.25rem 0 2.75rem;
    background: linear-gradient(135deg, #1a263a 0%, #2c3e50 55%, #243447 100%);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.site-footer-main::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
}

.site-footer-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1.2fr;
    gap: 2.5rem 2rem;
    align-items: start;
}

.site-footer-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    margin-bottom: 1rem;
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    text-decoration: none;
    letter-spacing: -0.02em;
    transition: opacity 0.2s ease;
}

.site-footer-logo:hover,
.site-footer-logo:focus-visible {
    color: #fff;
    text-decoration: none;
    opacity: 0.92;
}

.site-footer-logo-img {
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}

.site-footer-tagline,
.site-footer-contact-text {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.72);
}

.site-footer-heading {
    position: relative;
    margin: 0 0 1.25rem;
    padding-bottom: 0.85rem;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.92);
}

.site-footer-heading::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 2.5rem;
    height: 3px;
    border-radius: 2px;
    background: linear-gradient(90deg, #0692C0 0%, #57A773 100%);
}

.site-footer-links {
    margin: 0;
    padding: 0;
    list-style: none;
}

.site-footer-links li + li {
    margin-top: 0.55rem;
}

.site-footer-links a {
    display: inline-block;
    color: rgba(255, 255, 255, 0.78);
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 500;
    transition: color 0.2s ease, transform 0.2s ease;
}

.site-footer-links a:hover,
.site-footer-links a:focus-visible {
    color: #7dd3ec;
    text-decoration: none;
    transform: translateX(3px);
}

.site-footerCtaBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 1.25rem;
    padding: 0.75rem 1.65rem;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.4;
    color: #fff;
    text-decoration: none;
    background: transparent;
    border: 2px solid rgba(255, 255, 255, 0.32);
    border-radius: 999px;
    transition:
        color 0.25s ease,
        background 0.25s ease,
        border-color 0.25s ease,
        transform 0.25s ease,
        box-shadow 0.25s ease;
}

.site-footerCtaBtn:hover,
.site-footerCtaBtn:focus-visible {
    color: #fff;
    text-decoration: none;
    background: linear-gradient(90deg, rgba(6, 146, 192, 1) 0%, rgba(87, 167, 115, 1) 100%);
    border-color: transparent;
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(6, 146, 192, 0.28);
}

.site-footerCtaBtn:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.55);
    outline-offset: 3px;
}

.site-footer-social {
    display: flex;
    gap: 0.65rem;
    margin-top: 1.35rem;
}

.site-footer-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    color: rgba(255, 255, 255, 0.88);
    text-decoration: none;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 999px;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
}

.site-footer-social-link:hover,
.site-footer-social-link:focus-visible {
    color: #fff;
    text-decoration: none;
    background: linear-gradient(90deg, rgba(6, 146, 192, 0.85) 0%, rgba(87, 167, 115, 0.85) 100%);
    border-color: transparent;
    transform: translateY(-2px);
}

.site-footer-legal {
    padding: 1.35rem 0 1.5rem;
    background: #151e27;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.site-footer-copyright {
    margin: 0 0 0.65rem;
    font-size: 0.88rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.72);
    text-align: center;
}

.site-footer-disclaimer {
    margin: 0;
    font-size: 0.78rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.45);
    text-align: center;
    font-style: italic;
}

@media screen and (max-width: 991px) {
    .site-footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .site-footer-brand {
        grid-column: 1 / -1;
    }
}

@media screen and (max-width: 640px) {
    .site-footer-main {
        padding: 2.5rem 0 2rem;
    }

    .site-footer-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .site-footerCtaBtn {
        width: 100%;
        max-width: 280px;
    }
}

.thumb-content {
    padding-top: 10px;
    padding-bottom: 10px;
}

.banniere-tiktok {
    width: 50%;
}

.bord-rad {
    border-radius: 20px;
}

.numberCircle {
    width: 40px;
    line-height: 40px;
    border-radius: 50%;
    text-align: center;
    background-color: #0692C0;
    font-weight: bold;
    color: white;
    display: inline-block;
    margin-left: 2em;
}

.prerequis li {
    padding-top: 0.3em;
    padding-bottom: 0.3em;
    font-weight: 500;
}

.fc-consent-root .fc-dialog .fc-header h1, .fc-consent-root .fc-dialog .fc-header h2 {
    -webkit-text-fill-color: black !important;
}

.disclaimer {
    border-left: #FE5F55 5px solid;
    padding-left: 1em;
}

.sponsored-content {
    font-weight: lighter;
    font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    font-size: 12px;
}

.compare-table-link {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    font-weight: 600;
}