@font-face {
    font-family: 'SFR-Regular';
    src: url("//static.s-sfr.fr/assets/fonts/Poppins-Regular.woff2")
}

@font-face {
    font-family: 'SFR-Light';
    src: url("//static.s-sfr.fr/assets/fonts/Poppins-Light.woff2")format("woff2")
}

@font-face {
    font-family: 'SFR-Bold';
    src: url("//static.s-sfr.fr/assets/fonts/Poppins-Bold.woff2")format("woff2")
}

@font-face {
    font-family: 'SFR-Black';
    src: url("//static.s-sfr.fr/assets/fonts/Poppins-Black.woff2")format("woff2")
}

#HP{display: flex; flex-direction: column; background: var(--clr-bg);font-size:14px;}
#HP h1, #HP h2{text-align:center;}
#HP .arrow:after {content: ''; position: absolute; width: 7px; height: 7px; background-color: transparent; border: 2px solid; right: 0; transform: rotate(45deg); top: 0; bottom: 0;margin: auto;border-left: 0;border-bottom: 0;transition: all .2s cubic-bezier(.4,0,.2,1);}
#HP .arrow {padding-right: 12px;}
#HP .btn3 {color: var(--clr-black); background: #fff; box-shadow: 0 0 12px rgb(24 24 24 / 16%);}
#HP #Acc5 { width: 100%; height: 460px; position: relative; overflow: hidden; margin-bottom:40px; }
#HP #Acc5 .heroes { position: relative; height: 100%; }
#HP #Acc5 .hero { position: relative; height: 100%; display:block; background-repeat: no-repeat; animation: fadein 1s ease-out; }
#HP #Acc5 .hero:before { content: ''; height: 296px; position: absolute; bottom: 0; left: 0; right: 0; width: 100%; background: rgba(226, 0, 0, 0.8); background-image: linear-gradient(360deg, var(--clr-sfr) 70%, rgba(97, 91, 91, 0) 95%); box-shadow: 0px 0 30px 40px rgb(0 0 0 / 30%); }
#HP #Acc5 .hero>.illu { object-fit: cover; display: flex; width: 100%; height: 100%; z-index: -1;}
#HP #Acc5 .hero>.c { position: absolute; left: 40px; right: 40px; bottom: 0; margin: auto; max-width: 1280px; height: 296px; display: flex; justify-content: space-between; }
#HP #Acc5 .hero>.c>div { display: inline-block; vertical-align: top; }
#HP #Acc5 .hero>.c>.L { width: 290px; margin: -26px 40px 0 0; }
#HP #Acc5 .hero>.c>.L strong { display: block; font-family: 'SFR-Bold'; font-size: 32px; line-height: 48px; color: #fff; margin: 0 0 16px 0; font-weight:100;}
#HP #Acc5 .hero>.c>.L p { display: block; font-family: 'SFR-Regular'; font-size: 16px; line-height: 24px; color: #fff; }
#HP #Acc5 .hero>.c>.L .stars { margin: 16px 0 0 0; }
#HP #Acc5 .hero>.c>.L .stars>i{ width: 90px; height: 16px; background: url(//static.s-sfr.fr/media/stars-12-grey.svg) no-repeat 0 0; background-size: cover; display: inline-block; vertical-align: middle; }
#HP #Acc5 .hero>.c>.L .stars>i mark { height: 16px; background: url(//static.s-sfr.fr/media/stars-12-yellow.svg) no-repeat 0 0; background-size: cover; display: block; filter: invert(75%) sepia(86%) saturate(1646%) hue-rotate(26deg) brightness(150%) contrast(107%); }
#HP #Acc5 .hero>.c>.L .stars>span{ font-size: 12px; color: #fff; line-height: 18px; display: inline-block;vertical-align: middle; margin: 0 0 0 8px; }
#HP #Acc5 .hero>.c>.M { width: 620px; position:relative;bottom:84px;}
#HP #Acc5 .hero>.c>.M > img{display:block;max-height:100%;margin:0 auto;max-width:100%;}
#HP #Acc5 .hero>.c>.R { width: 290px; margin: 0 0 118px 0; align-self: flex-end; }
#HP #Acc5 .hero>.c>.R .sticker { background: var(--clr-yellow); font-family: 'SFR-Bold'; color: var(--clr-black); margin: -20px 0 0 0; font-size: 12px; padding: 0 8px; border-radius: 4px; display: table;}
#HP #Acc5 .hero>.c>.R .sticker + .price { margin-top: 22px;  }
#HP #Acc5 .hero>.c>.R .apd { font-size: 14px; line-height: 22px; font-family: 'SFR-Bold'; display: block; color: #fff;  }
#HP #Acc5 .hero>.c>.R .apd + .price { margin: 0; }
#HP #Acc5 .hero>.c>.R .apd + .info { margin: 0 0 8px 0; }
#HP #Acc5 .hero>.c>.R:has(.sticker + .price) .sticker { margin: 4px 0 -15px 0; }
#HP #Acc5 .hero>.c>.R .price { margin: 20px 0 0 0; justify-content: left; }
#HP #Acc5 .hero>.c>.R .price .L { font-size: 60px; line-height: 48px; color: #fff; }
#HP #Acc5 .hero>.c>.R .price .R { font-size: 16px; line-height: 24px; color: #fff;}
#HP #Acc5 .hero>.c>.R .price + a { margin: 16px 0 0 0; }
#HP #Acc5 .hero>.c>.R>.info { font-family: 'SFR-Bold'; color: #fff; font-size: 12px; line-height: 18px; margin: 8px 0;}
#HP #Acc5 .hero>.c>.R>a { display: table; width: auto; position: static; }
#HP #Acc5 .hero>.c>.R>a:after { content: ''; position: absolute; left: -640px; right: -640px; top: -164px; width: auto; height: 460px; }
#HP #Acc5 .hero>.c>.B { display: block; position: absolute; width: 100%; bottom: 80px; height: 18px; }
#HP #Acc5 .hero>.c>.B>span{ position: absolute; top: 0; right: 0; color: #fff; font-size: 12px; line-height: 18px; display: table;}
#HP #Acc5 .hero>.c>.B>input { display: none; }
#HP #Acc5 .hero>.c>.B>input + label .bubble{ display: none; }
#HP #Acc5 .hero>.c>.B>input:checked + label .bubble { display: block; }
#HP #Acc5 .hero>.c>.B label { position: relative; }
#HP #Acc5 .hero>.c>.B label>span.das{ left: 0; cursor: pointer; color: #fff; font-size: 12px; line-height: 18px; display: table; position: relative; }
#HP #Acc5 .hero>.c>.B label>span.das:after { content: ''; background-image: url(https://static.s-sfr.fr/assets/pictos/aide_plein_40_blanc.svg); width: 14px; height: 14px; display: block; background-size:contain; background-repeat:no-repeat; position: absolute; top: 1px; left: 28px; }
#HP #Acc5 .hero>.c>.B label>span.das + .bubble {  cursor: auto; width: 150px; box-shadow: 0 2px 4px 0 rgb(0 0 0 / 10%); border-radius: 4px; color: #fff; font-family: 'SFR-Regular'; background-color: var(--clr-black); font-size: 10px; padding: 3px; position: absolute; z-index: 9; transition: opacity 0.3s; bottom: 25px; }
#HP #Acc5 .hero>.c>.B label>span.das + .bubble:after {content: ""; position: absolute; bottom: -14px; left: 8px; margin-top: -5px; border-width: 7px; border-style: solid; border-color: var(--clr-black) transparent transparent transparent;}
#HP #Acc5 .capsules { max-width: 1280px; width: calc(100% - 80px); margin: -70px auto 0 auto; position: relative; display: flex; justify-content: space-around; gap: 0 40px; }
#HP #Acc5 .cap { display: inline-block; vertical-align: middle; width: 288px; padding: 0 8px 0 0; background: rgba(255, 255, 255, 0.2);max-width: calc(100% / 4 - 15px); width: 288px; font-family: 'SFR-Regular'; color: #fff; border-radius: 8px; font-size: 14px; line-height: 18px; cursor: pointer;  transition: background .3s ease-out; }
#HP #Acc5 .cap>div { width: 52px; height: 52px; display: inline-block; vertical-align: middle; margin: 0 14px 0 0; }
#HP #Acc5 .cap>div>.vign { height: 100%; }
#HP #Acc5 .cap>span { display:inline-block; vertical-align: middle; width: calc(100% - 70px); }
#HP #Acc5 .cap:hover { background: rgba(24, 24, 24, 0.2);}
#HP #Acc5 .cap.s { background: rgba(24, 24, 24, 0.2); }
#HP #Acc5 .cap:last-child { margin: 0; }
#HP #Acc5 .hero[hidden="true"]{display:none;}
#HP #Choose { background: #fff; box-shadow: 0px 8px 16px rgba(24, 24, 24, 0.02); border-radius: 12px; max-width: 1280px; margin: 0 auto; width: calc(100% - 64px); padding: 24px 24px 90px 24px; display: flex; gap: 22px; flex-wrap: wrap; position: relative; justify-content: space-evenly;  }
#HP #Choose .c { text-align: center; width: 225px; }
#HP #Choose .c>img{ height: 64px; margin: 0 0 16px 0; }
#HP #Choose .c p{ font-family: 'SFR-Bold'; font-size: 14px; margin: 0 0 16px 0; }
#HP  a.link{ text-decoration: none; position: relative; font: normal 14px/18px SFR-Bold; padding: 0 13px 0 0; cursor: pointer;color:#D90D25;}
#HP  a.link:after{content: '';position: absolute; width: 8px; height: 8px;right: 1px; top: 0; bottom: 0; margin: auto;border-radius: 2px; border: 2px solid; border-left: 0; border-bottom: 0;transform: rotate(45deg);transition: all .2s cubic-bezier(.4,0,.2,1);}
#HP a[class^="link"]:hover:after { right: -3px;}
#HP #Choose .btn4{width: fit-content; margin: 0 auto; position: absolute; bottom: 24px; left: 0;right: 0;color: var(--clr-black); border: solid 1px var(--clr-black); box-shadow: 0 0 12px rgb(24 24 24 / 16%);}
#HP a[class^="btn"], input[class^="btn"]{display: block;position: relative; font-family: SFR-Bold; font-size: 14px; line-height: 16px; padding: 12px 24px; text-align: center; width: 100%; border-radius: 8px; cursor: pointer;overflow: hidden; text-decoration: none;transition: box-shadow .2s cubic-bezier(.4,0,.2,1); user-select: none; -webkit-user-select: none;}
#HP #Choose a[class^="btn"]:hover, #HP #Choose input[class^="btn"]:hover { box-shadow: 0 4px 12px rgb(24 24 24 / 32%);}
#HP #Best {position: sticky; /* not my best idea */ padding: 40px 0 8px 0; text-align: center; background-color: var(--clr-bg);}
#HP #Best h2 {font-family: 'SFR-Bold';color: var(--clr-black);font-size: 32px;line-height: 36px;text-transform: none;margin-top: 0;margin-bottom: 44px;}
#HP #Best a {text-decoration: none; color: var(--clr-black);}
#HP #Best .wrap {width: calc(100% - 64px);max-width: 1280px;margin: 40px auto 0 auto;display: grid;grid-template-columns: 1fr 1fr; gap: 40px}
#HP #Best .card {position: relative;text-align: left; box-sizing: border-box; padding: 24px 24px 0 24px; height: 278px; background-color: #fff; border-radius: 12px; }
#HP #Best .card .sticker {position: absolute; background-color: var(--clr-yellow); padding: 3px 8px 14px 8px; z-index: -1; top: -16px; left: 0; border-radius: 4px 4px 0 0; color: var(--clr-black); line-height: 10px; font-size: 12px; font-family: 'SFR-Bold'; }
#HP #Best .card a:not(.ub) {display: block; font-family: 'SFR-Bold'; color: var(--clr-black); font-size: 16px; margin: 0 0 8px 0; position: relative; z-index: 2;}
#HP #Best .card a:not(.ub):before {content: ""; bottom: 0; left: -32px; position: absolute; width: calc(100% + 32px * 2); height: 233px; top: -32px;}
#HP #Best .card > p {font-family: 'SFR-Regular'; font-size: 14px;line-height:22px; margin: 0; margin-bottom: 10px; color: var(--clr-black); position: relative; z-index: 2;max-width:211px;}
#HP #Best .card > p + .price {margin-top: 24px; justify-content: left;}
#HP #Best .card .tadp {font-family: 'SFR-Bold';color: var(--clr-black);font-size: 10px;line-height: 14px;}
#HP #Best .card .price {justify-content: left;}
#HP #Best .card .price>.entier {display: inline-block; vertical-align: middle; font-size: 40px;line-height: 40px; font-family: 'SFR-Bold'; color: var(--clr-black);}
#HP #Best .card .price>div {display: inline-block; vertical-align: middle;}
#HP #Best .card .price>div>.cents{display: inline-block; vertical-align: middle; font-size: 16px; font-family: 'SFR-Bold';  color: var(--clr-black);}
#HP #Best .card .price>div>.granu{display: inline-block; vertical-align: middle; font-size: 16px; font-family: 'SFR-Bold'; text-transform: lowercase; color: var(--clr-black);}
#HP #Best .card .price + p {font-size: 12px; line-height: 18px; font-family: 'SFR-Regular'; font-weight:normal;margin: 0; color: var(--clr-black); z-index: 2; position: relative;}
#HP #Best .card .illu {position: absolute; right: 24px; top: 35px; transition: 0.5s ease-out transform; max-height:64%;max-width:50%;}
#HP #Best .card:hover .illu {transform: scale(1.1);}
.tooltip {cursor: pointer; position: absolute; bottom: 45px; right: 20px;z-index:2;}
#HP #Best .card .tooltip .das {position: relative;font-family: 'SFR-Regular';font-size: 12px;line-height:12px; padding: 0 17px 0 0;}
#HP #Best .card .tooltip .das:after {content: "";position: absolute; bottom: 1px; right: 0; width: 15px; height: 15px; background: url(//static.s-sfr.fr/assets/pictos/aide_plein_40_noir.svg); background-repeat: no-repeat; background-size: cover; }
#HP #Best .card .tooltip .tooltiptext {cursor: auto; width: 130px; box-shadow: 0 2px 4px 0 rgb(0 0 0 / 10%); border-radius: 4px; color: #fff; font-family: 'SFR-Regular'; background-color: var(--clr-black); font-size: 10px; padding: 3px; position: absolute; z-index: 9; right: -20px; top: auto; bottom: 23px;  transition: opacity 0.3s;}
#HP #Best .card .tooltip .tooltiptext::after {content: ""; position: absolute; bottom: -12px; left: 73%; margin-top: -5px; border-width: 7px; border-style: solid; border-color: var(--clr-black) transparent transparent transparent;}
@media(hover: none) {.tooltip .tooltiptext.hov {display:none;}}
@media(hover: hover) {.tooltip .tooltiptext.hov {display:none;} .tooltip:hover .tooltiptext.hov {display:block;}}
#HP #Best .card .ub {position: absolute;display: table;bottom: 22px;left: 50%;transform: translateX(-50%);font-family: 'SFR-Bold';color: #D90D25;z-index:3;font-size: 14px;line-height: 18px;text-align: center;width: max-content;width: -moz-max-content;}
#HP #Best .card .ub:before {content: "";position: absolute;width: 510px;height: 32px;top: -10px;left: 50%;transform: translateX(-50%);}
#HP .tooltip.das.s > div.tooltiptext {visibility: hidden;}
#HP .tooltip.das.s > div.tooltiptext.hide {visibility: hidden;}
#HP .tooltip.das.s > div.tooltiptext.show {visibility: visible; opacity: 1;}
#HP #Seo {font-family:'SFR-Regular'; color: #222; font-size: 12px; line-height: 1.3; position: relative; max-width: 1280px; margin: 0 auto 30px auto;padding: 0 20px;}
#HP #Seo h2 {font-family:'SFR-Bold'; color: #222; font-size: 16px; margin-top: 15px; display: block;}
#HP #Seo a {text-decoration: none; color: #222;}
#HP #Seo strong  {font-family:'SFR-Bold'; color: #222; font-size: 16px; margin-top: 15px; margin-bottom: 15px; display: block; font-weight:100;}
#HP #Seo b {font-weight: bold;}
#HP #Seo input[type="checkbox"] {display: none;}
#HP #Seo input[type="checkbox"] + label {display:block; position:relative;font-size:12px;}
#HP #Seo input[type="checkbox"] + label .curt {width: 100%; height: 86px; position: absolute; bottom: 30px; background: linear-gradient(#ffffff2b, #fff); background: #fff; display:none;}
#HP #Seo input[type="checkbox"]:checked + label .curt {width: 90%; background-color: transparent; height: 0; position: absolute; top: 0;}
#HP #Seo input[type="checkbox"] + label p {height: 80px; overflow: hidden; color: var(--clr-grey);}
#HP #Seo input[type="checkbox"]:checked + label p {height: auto;}
#HP #Seo .vm {display: table; margin: 20px auto 0 auto; cursor: pointer; position: relative; font-family: 'SFR-Bold';font-size:12px; color:var(--clr-black);}
#HP #Seo .vm:after {content: '';width: 8px;height: 8px;border: 2px solid;transform: rotate(45deg);right: -17px;top: 3px;position: absolute;border-top: 0;border-left: 0;}
#HP #Seo .vp {display: none; margin: 20px auto 0 auto; cursor: pointer; position: relative; font-family: 'SFR-Bold';color:var(--clr-black);}
#HP #Seo .vp:after {content: '';width: 8px;height: 8px;border: 2px solid; transform: rotate(-135deg);right: -17px;top: 7px;position: absolute;border-top: 0;border-left: 0;}
#HP #Seo input[type="checkbox"]:checked + label .vp {display: table;}
#HP #Seo input[type="checkbox"]:checked + label .vm {display: none;}
#HP #Mentions {margin-bottom: 25px; border-top: 1px solid #ebebeb; padding-top: 25px;} 
#HP #Mentions .t{display:block;margin:0 auto;}
#HP #Mentions input[type="checkbox"]:checked + .t > p:after {transform: rotate(225deg);top:7px;}
#HP #Mentions .t > p {font-family: 'SFR-Bold'; font-size: 12px; margin: 0 auto; display: table; position: relative; cursor: pointer;color:var(--clr-black);}
#HP #Mentions .t > p:after {position: absolute;border-top: 0;border-left: 0;content: '';width: 8px;height: 8px;border: 2px solid;transform: rotate(45deg);right: -17px;top: 3px;border-top: 0;border-left: 0;}
#HP #Mentions .t.s > p:after {transform: rotate(-135deg);top: 5px;}
#HP #Mentions .cont {max-width: 1280px; margin: 25px auto; display: block; font-family: 'SFR-Regular'; font-size: 12px; color: #222; line-height: 1.3; padding: 0 20px;}
#HP #Mentions .show {display: block;}
#HP #Mentions .hide {display: none;}
#HP #Mentions strong  {font-family:'SFR-Bold'; color: #222; font-size: 16px; margin-top: 15px; margin-bottom: 15px; display: block; font-weight:100;} 
#HP #Mentions b { font-family: 'SFR-Bold';}
#HP #Mentions a {text-decoration:none; color: var(--clr-grey);}
#HP #Mentions input{display:none;}
#HP #Mentions input[type="checkbox"]:checked + .t > div{display:block;}
#HP #Pilier {text-align: center; padding-bottom: 18px;}
#HP #Pilier h1 {font-family: 'SFR-Bold'; font-size: 32px; line-height: 36px;margin: 32px auto 40px;}
#HP #Pilier .z {display: inline-block; vertical-align: middle; width: 720px; text-align: left; margin-bottom: 25px;}
#HP #Pilier .p {position: relative; display: inline-block; text-align: left; vertical-align: top; margin: 0 1% 0 0;}
#HP #Pilier .p:last-child {border:none;}
#HP #Pilier .p .si {display: inline-block; vertical-align: middle; margin: 0px 8px 0 0; }
#HP #Pilier .p .si + div {display: inline-block; vertical-align: middle;}
#HP #Pilier .p a {position: relative; display: inline-block; vertical-align: middle; font-family: 'SFR-Bold'; font-size: 14px; text-decoration: none; color: var(--clr-sfr2); line-height: 16px; margin-right: 15px;}
#HP #Pilier .p a:before {content: ''; position: absolute; width: calc(100% + 92px); height: 70px; top: -50px; left: -63px;}
#HP #Pilier .p a.m {display: none;}
#HP #Pilier .p p {margin: 0 0 10px 0; line-height: 18px; width: 190px; font-family: 'SFR-Regular'; font-size: 14px; color: var(--clr-black);}
#HP #Pilier .m {display: none;}
#HP #TT{display:none;}
#HP #eTav { background: var(--clr-bg);text-align: center; padding: 20px 16px;}
#HP #eTav * {color: #000;box-sizing: border-box; padding: 0; margin: 0; font: 12px SR;}
#HP #eTav>p {font: 20px SFR-Bold;padding: 0 0 20px;}
#HP #eTav>ul {border-radius: 8px; scroll-behavior: smooth;list-style: none;max-width: 1280px;margin: 0 auto;white-space: nowrap;overflow: auto;}
#HP #eTav>ul>li {color: #a0a0a0;transition: margin .4s; position: relative; vertical-align: top;width: 168px; height: 144px;background: #fff; display: inline-block;margin: 0; padding: 40px 8px 0; border-radius: 8px; box-shadow: 0 0 #0001;}
#HP #eTav>ul>li+li{max-width: calc(100vw - 24px); width: 356px; padding: 36px 16px 0; margin-left: 20px;text-align: left; font-size: 10px; overflow: hidden;text-overflow: ellipsis;}
#HP #eTav p > a {text-decoration: none;}
#HP #eTav p b {font-family: 'SFR-Bold';}
#HP #eTav i {display: inline-block;  background: url(//static.s-sfr.fr/eTagP/IC/star.svg);  background-size: 16px 13px;  width: 80px;  height: 13px;  position: absolute;  top: 16px;  left: 46px;}
#HP #eTav i:first-child {  filter: grayscale(1);}
#HP #eTav > ul > li > p > a > b {  text-decoration: underline;}
#HP #eTav > ul > li > label {  display: block;  font-size: 10px;  color: #303030;  text-decoration: underline;  cursor: pointer;}
#HP #eTav > ul > li > label:after {  content: "?";  color: #fff;  background: #000;  padding: 0 5px;  margin-left: 8px;  border-radius: 50%;  font-style: normal;}
#HP #eTav > ul > li + li > i {  left: 16px;}
#HP #eTav > ul > li + li > b {  font-family: 'SFR-Bold';}
#HP #eTav > ul > li + li {  max-width: calc(100vw - 24px);  width: 356px;  padding: 36px 16px 0;  margin-left: 20px;  text-align: left;  font-size: 10px;  overflow: hidden;  text-overflow: ellipsis;}
#HP #eTav img {  width: 116px;  margin: 12px 0 6px;}
#HP #eTav img + p {  font: italic 10px SR;  color: #666;}
#HP #eTav > ul > li + li > p {  text-align: justify;  height: 56px;  margin-top: 12px;  white-space: normal;  overflow: hidden;}
#HP #eTav > ul > li + li > b {  display: block;  text-align: right;}
#HP #eTav > ul > [W] {  position: sticky;  border-radius: 0;  margin: 0;  top: 0;  right: -8px;  width: 24px;  height: 144px;  background: linear-gradient(90deg, #eee0, var(--clr-bg));}
#HP #eTav > ul > [L],#eTav > input,#eTav > ol {  display: none;}
#HP #eTav > input:checked + ol {  display: block;}
#HP #eTav > ol {  background: #000;  padding: 6px;  border-radius: 8px;  font-size: 11px;  position: absolute;  left: 16px;  width: 300px;  z-index: 66666;}
#HP #eTav > ol:before {  content: "";  display: inline-block;  width: 9px;  height: 9px;  transform: rotate(45deg);  position: absolute;  top: -4px;  left: 49%;  background: #000;}
#HP #eTav > ol * {  color: #fff;}
#HP #eTav > ol > li {  list-style: disc;  margin: 0 8px 0 18px;  font-size: 11px;  text-align: justify;}
#HP #eTav > a {  font: 14px/16px 'SFR-Bold';  text-decoration: none;  padding: 11px 24px;  border: 1px solid var(--clr-black);  display: inline-block;  border-radius: 8px;  transition: box-shadow 0.3s;}
#HP #eTav > a:hover {  box-shadow: 0 4px 8px #2226;}

#HP #News {position: relative; background-color: var(--clr-bg); text-align: center; padding: 1px 0 20px;}
#HP #News h2 {font-family: 'SFR-Bold'; font-size: 32px; line-height: 36px; color: var(--clr-black); text-align: center; text-transform: unset; display: block; margin: 40px auto 44px;}
#HP #News .card {display: inline-block; vertical-align: top; height: 320px; width: 30%; max-width: 408px; box-shadow: 0 0 24px 4px rgba(0, 0, 0, 0.06); border-radius: 8px; margin: 0 14px 25px 14px; box-sizing: border-box;}
#HP #News .card a {text-decoration: none;}
#HP #News .card .T {position: relative; height: 192px; width: 100%; background-size: cover; background-position: center center; border-radius: 8px 8px 0 0;} 
#HP #News .card .T span {position: absolute; color: #fff; font-family: 'SFR-Bold'; background-color: var(--clr-black); font-size: 10px; border-radius: 4px; padding: 5px 8px; top: 12px; left: 12px;}
#HP #News .card .T .illu {border-radius: 8px 8px 0 0;}
#HP #News .card .T .illu>img {object-fit: cover;}
#HP #News .card .B {height: calc(320px - 192px); width: 100%; padding: 16px 24px; text-align: left; box-sizing: border-box; white-space: normal; background-color:#fff; border-radius: 0 0 8px 8px;}
#HP #News .card .B .date {font-family: 'SFR-Regular';font-size: 12px;line-height: 16px;color: #a0a0a0;display: block;margin-bottom: 8px;} 
#HP #News .card .B .titre {font-family: 'SFR-Bold';font-size: 16px;line-height: 20px;color: var(--clr-black);margin-bottom: 8px;} 
#HP #News .card .B p {font-family: 'SFR-Regular';font-size: 12px;line-height: 14px;color: var(--clr-black);margin: 8px 0 0;} 
#HP #News>a {position:relative;display: table;margin: 12px auto 30px auto;text-decoration: none;color: var(--clr-black);font-family: 'SFR-Bold';font-size: 14px;padding: 9px 24px;border:1px solid var(--clr-black);border-radius:8px;transition: .3s all ease-out;}
#HP #News>a:hover { box-shadow: 0 4px 12px rgb(24 24 24 / 32%);}
#HP #News>a>.arrow { display:none; }
#HP #News .carousel-preview {display: none;}
#HP #News .amp-carousel-button {display: none}
#HP #News #carousel-actu > div > div {scroll-snap-type: x mandatory;}
#HP #News #actu-dots {display: none;}
#eTsNL, #eTsNL * {box-sizing: border-box;margin: 0;padding: 0;text-align: center;font: inherit;vertical-align: top;}
#eTsNL {position: relative;width: 100%;padding: 20px 16px 40px;font-size: 0;background: var(--clr-bg);}
#eTsNL > div {width: 100%;margin: 0 auto;padding: 0;border-radius: 12px;background: #fff;}
#eTsNL > div > * {display: inline-block;padding: 0;}
#eTsNL > div > h2 {width: 100%;font: 16px/4 'SFR-Bold',Arial;white-space: nowrap;color: var(--clr-black);}
#eTsNL > div > p {width: 90%;margin: 20px auto;text-align: justify;font: 11px/1.2 SR,Arial;}
#eTsNL > div > p > a {text-decoration: underline;color: #000;}
#eTsNL > div > form {border: 1px solid #a0a0a0;border-radius: 8px;overflow: hidden;}
#eTsNL > div > form > * {height: 30px;border: 0;outline: none;}
#eTsNL input {width: 228px;padding: 0 0 0 8px;text-align: left;font: 14px/38px SR,Arial;}
#eTsNL button {width: 48px;overflow: hidden;color: #0000;background: var(--clr-black) no-repeat center url(//static.s-sfr.fr/img/nl.svg);cursor: pointer;}
#eTsNL > div > div {float: right;font: 14px/24px SR,Arial;color: var(--clr-error);}
#eTsNL > div > div > b {font: 14px 'SFR-Bold',Arial;color: #7fc100;}
#eTsNL > div > div > span {color: #000;cursor: pointer;}
/* Pages gammes */
.reassurances_bloc { background: #fff; border-width: 1px 0; padding: 24px 0; margin-top: 40px;}
.reassurances_bloc .list { display: flex; flex-wrap: wrap; justify-content: space-around; margin: auto; max-width: calc(1360px + 30px);}
.reassurances_bloc .list>li { flex: 1; margin: 0 20px; max-width: 195px;list-style:none}
.bloc_reassurance { text-align: center;}
.bloc_reassurance .img { height: 40px; margin-bottom: 16px; text-align: center;}
.bloc_reassurance .img img { max-height: 40px;}
.bloc_reassurance .desc { font-size: 14px; line-height: 20px; padding-top: 15px; text-align: center;}
.bloc_reassurance .title { color: var(--clr-black); text-align: center;}

#Gamme{overflow-x:hidden;}
#Gamme p{font-size:14px;}
#Gamme p a{color:var(--clr-black);font-weight:bold;}
#Gamme h2 { font-style: normal; font-weight: 700; font-size: 27px; line-height: 37px;margin-bottom:16px;}
#Gamme .pb{font-family: 'SFR-Bold'; font-style: normal; font-weight: 700; font-size: 13px; line-height: 20px; text-align: center; color: #fff; text-decoration: none; padding: 10px 37px;background-color: #d90d25; border-radius: 6px; display: table; cursor: pointer; box-shadow: 0 4px 8px rgba(150,0,0,0.16);}
#Gamme .link{color: var(--clr-sfr2);text-decoration:none;}
#Gamme .container{margin:0 auto; max-width:1360px;padding:24px;}
#Gamme .pb1{font-family: 'SFR-Bold'; font-style: normal; font-weight: 700; font-size: 13px; line-height: 20px; text-align: center; color: #000; text-decoration: none; padding: 10px 37px; background-color: #fff; border-radius: 6px; display: table; cursor: pointer; box-shadow: 0 4px 8px rgba(150,0,0,0.16);}
#Gamme .price .L{font: normal 32px/30px SFR-Bold;}
#Gamme sup, #GammeN-2 sup{font-size:10px;}

#BannerGamme{width:100%;height:232px;position:relative;background-size:cover;}
#BannerGamme div{position:relative;top: 48px;left: 25%; width: 550px;}
#BannerGamme:before{content:'';height:100%;width:40%;background: rgba(226, 0, 0, 0.80);position:absolute;z-index:0;}
#BannerGamme h1{line-height:48px;}
#BannerGamme h1,#BannerGamme p{color:#fff;z-index:1;position:relative;}

#TextAndCard{padding: 24px 0; width: 100%; overflow: hidden;}
#TextAndCard .container{display:flex;gap:100px; align-items:flex-end;}
#TextAndCard .container .l p{margin: 28px 0;}
#TextAndCard .container .l .pb{float:right;}
#Gamme .card {width:400px;height:370px;border-radius: 12px; background: #FFF;box-shadow: 0px 8px 16px 0px rgba(24, 24, 24, 10%);padding:24px;position:relative;}
#Gamme .card img{width:100%;border-radius:12px;margin:0 0 24px 0;}
#Gamme .card p{margin: 8px 0;}
#Gamme .card a{margin: 0 auto; display: block; width: fit-content;position: absolute;left: 0; right: 0; bottom: 24px;}}

#ArtiCards { padding:24px 0; width: 100%; overflow: hidden;}
#ArtiCards .cards{display:flex; gap:24px;margin:32px 0 0 0;flex-wrap:wrap;justify-content:center;flex-wrap:wrap;}
#ArtiCards .container .cards .card{width:calc(33% - 12px);height:510px;overflow:hidden;min-width:400px;max-width:100%;}

#lamme-offer{background:var(--clr-error);max-width:1360px;margin:72px auto;padding:32px;display:flex;position:relative;gap:48px;}
#lamme-offer h2, #lamme-offer p{color:#fff;z-index:1;position:relative;}
#lamme-offer .l{max-width:25%;text-align:center;}
#lamme-offer .l > img{position:absolute;top:0;left:0;height:100%;}
#lamme-offer .l:after{content:'';top:0;left:200px;position:absolute;z-index: 0;display:block;height:100%;width:400px;background:linear-gradient(90deg, rgba(226, 0, 26, 0.70) -7.63%, #E2001A 9.82%);}
#lamme-offer .m{display:flex; gap:8px;z-index:1;max-width:40%;align-items:center;}
#lamme-offer .m img{max-width:300px;height:fit-content;}
#lamme-offer .m .bloc-price{text-align:left;color:#fff;}
#lamme-offer .m .bloc-price .price{width:fit-content;margin:8px 0;min-width:126px;}
#lamme-offer .m .bloc-price > p{font-size:12px;}
#lamme-offer .m .bloc-price .generic-promo {color:#000;font-family: SFR-Bold; background: var(--clr-yellow); border-radius: 5px; font-size: 12px; line-height: 18px; padding: 0 8px;margin-bottom:8px;display:inline-block;}
#lamme-offer .m .bloc-price .price .L{font-size:48px; margin-right:4px;}
#lamme-offer .m .bloc-price .price .R{font-size:16px;}
#lamme-offer .m .bloc-price .price .R:first-of-type{margin-bottom:8px;}
#lamme-offer .r .das span:first-child:after { position: absolute; content: ""; background: url(https://static.s-sfr.fr/assets/pictos/aide_plein_40_blanc.svg); background-repeat: no-repeat; background-size: contain; width: 16px; height: 16px; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; line-height: 11px; left: 26px; top: 0px; bottom: 0; margin-top: auto; margin-bottom: auto;}
#lamme-offer .das span {position: relative; cursor: pointer;color:#fff;font-size:12px;}
#lamme-offer .das span:first-of-type{margin-right:24px;}
#lamme-offer .r{display: grid; align-items: end; justify-items: end; width:25%;}
#lamme-offer .das{position:relative;    align-self: start;}
#lamme-offer .dasPopup { opacity: 0; border: 0; cursor: auto; width: 190px; box-shadow: 0px 8px 16px rgba(24, 24, 24, 0.02); border-radius: 8px; padding: 16px; background-color: #222222; color: white; font: 12px/18px SFR-Regular; position: absolute; left: -140px; bottom: 24px; transition: opacity 0.3s; text-align: left;z-index:-1;}
#lamme-offer .dasPopup:after {top: 100%; left: calc(100% - 20px); border-top: 4px solid #222222; border-right: 4px solid transparent; border-bottom: 4px solid transparent; border-left: 4px solid transparent; content: ""; position: absolute; width: 0; height: 0; }
#lamme-offer .dasCta:hover .dasPopup { opacity: 1; z-index: 9;}
#lamme-offer .das:hover .dasPopup { opacity: 1; z-index: 9;}

#Solucards {margin-top:72px;position:relative;margin-bottom:72px;}
#Solucards .list { display: flex;margin: -8px auto 0; padding: 0; position: relative; z-index: 0; gap: 20px 40px;justify-content:center;align-items:center;flex-wrap:wrap;}
#Solucards .list > li { margin: 0; padding: 20px 0 0; position: relative;list-style:none;}
#Solucards .addons-card .engagement { font-family: SFR-Regular; font-size: 12px; line-height: 18px;}
#Solucards .bl_promo { border-radius: 8px; background: var(--clr-yellow); color: var(--clr-black); display: inline-block; padding: 5px 10px 20px; position: absolute; top: 0; font-size: 12px; line-height: 11px; font-family: SFR-Bold;}
#Solucards .addons-card { overflow: hidden; position: relative; box-shadow: 0px 8px 16px rgba(24, 24, 24, 0.08); display: flex; flex-direction: column; justify-content: space-between; width: 100%; max-width: 400px; border-radius: 8px; background: 0 0;}
#Solucards .addons-card .header { position: relative; width: 100%; background: #fff; display: flex; align-items: center; justify-content: center;}
#Solucards .addons-card .header img { width: 100%; height: auto; max-height: 100%; object-fit: cover;}
#Solucards .addons-card .BlackBloc { position: relative; border-top: 0; height: 290px; padding: 24px; background: #fff;}
#Solucards .addons-card .BlackBloc bol-label-refund { position: absolute; margin-left: auto; background: var(--clr-yellow); color: var(--clr-black); font-family: 'SFR-Black'; font-size: 10px; line-height: 20px; border-radius: 4px; right: 16px; top: -10px; left: unset; padding: 0 8px;}
#Solucards .addons-card .title { font-family: 'SFR-Black'; font-size: 16px; line-height: 24px; height: auto; max-height: 45px; margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; padding: 0;}
#Solucards .addons-card .title:before { position: absolute; content: ''; width: 100%; height: 186px; top: -186px; left: 0;}
#Solucards .addons-card .BlackBloc > p { font-family: SFR-Regular; font-size: 14px; line-height: 22px;}
#Solucards .addons-card .bl_prix { position: absolute; bottom: 80px; right: 24px; height: auto; align-self: flex-end; text-align: right; margin-bottom: 0;}
#Solucards .addons-card bol-price { display: inline-block; font-family: SFR-Bold; font-size: 24px; line-height: 30px; margin-bottom: 12px;}
#Solucards .addons-card .engagement {font-family: SFR-Regular;font-size: 12px;line-height: 18px;}
#Solucards .addons-card .bl_btn {display: flex;flex-wrap: wrap; justify-content: flex-end;bottom: 12px; width: calc(100% - 24px); max-width: 100%; position: absolute; right: 0; left: 0; margin-right: auto; margin-left: auto;}
#Solucards .addons-card .btn { bottom: 12px; width: calc(100% - 24px); max-width: 100%; position: absolute; right: 0; left: 0; margin-right: auto; margin-left: auto;    -webkit-user-select: none;border-radius: 8px; box-shadow: 0 4px 8px rgba(24,24,24,0.16); cursor: pointer; overflow: hidden; text-decoration: none; transition: box-shadow .2s cubic-bezier(.4,0,.2,1); font-family: SFR-Bold; font-size: 14px; line-height: 20px; padding: 10px 24px; text-align: center;display: block;}

/*  */

#BannerGamme1 { width: 100%; height: 232px; position: relative;background-size:cover;color:#fff;display:flex;align-items: center;gap:24px;padding: 24px;justify-content:center;}
#BannerGamme1:before { content: ''; height: 100%; width: 50%; background: rgba(226, 0, 0, 0.80); position: absolute; z-index: 0;right:0;}
#BannerGamme1 h1{line-height:48px;}
#BannerGamme1 > div{z-index:20;position:relative;}
#BannerGamme1 > .r >.bloc-price{max-width:250px;}
#BannerGamme1 .l, #BannerGamme1 .r{width:25%;}
#BannerGamme1 .m{width:50%;text-align:center;}
#BannerGamme1 .price{width:fit-content;margin: 24px 0;height: 50px;}
#BannerGamme1 .price .L{font-size:80px;}
#BannerGamme1 .price .R{font-size:24px;}
#BannerGamme1 .bloc-price > .engagement{font-size:12px;}
#BannerGamme1 .bloc-price > p{width:fit-content;}
#BannerGamme1 .bloc-price > p.yellow{background: var(--clr-yellow); color: var(--clr-black);line-height: 20px; border-radius: 4px;padding: 0 8px;font-family:'SFR-bold';}
#BannerGamme1 .m p{font-size:14px;}

#GammeN-2 p, #GammeN-2 span, #GammeN-2 strong, #GammeN-2 li{font-size:14px;}
#GammeN-2 h2 { font-style: normal; font-weight: 700; font-size: 27px; line-height: 37px;margin-bottom:16px;}
#GammeN-2 .pb{font-family: 'SFR-Bold'; font-style: normal; font-weight: 700; font-size: 13px; line-height: 20px; text-align: center; color: #fff; text-decoration: none; padding: 10px 37px;background-color: #d90d25; border-radius: 6px; display: table; cursor: pointer; box-shadow: 0 4px 8px rgba(150,0,0,0.16);}
#GammeN-2 .link{color: var(--clr-sfr2);text-decoration:none;}
#GammeN-2 .container{margin:0 auto; max-width:1360px;padding:24px;}
#GammeN-2 .pb1{font-family: 'SFR-Bold'; font-style: normal; font-weight: 700; font-size: 13px; line-height: 20px; text-align: center; color: #000; text-decoration: none; padding: 10px 37px; background-color: #fff; border-radius: 6px; display: table; cursor: pointer; box-shadow: 0 4px 8px rgba(150,0,0,0.16);}

#BlocList{display:flex;padding:24px 24px 24px 0px; gap:80px;max-width:1360px;justify-content:flex-end;margin:0 auto;min-height:420px;margin-bottom:48px;}
#BlocList .l{ width: 47%; height: fit-content; max-width: 650px; padding-left: 24px; position: relative;}
#BlocList .l:before{content: ''; border-radius: 0px 10px 10px 0px; background: #F9F9F9; box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.10); position: absolute; box-sizing: border-box; left: -100%; right: 0; top: -35px;height: calc(100% + 70px);}
#BlocList .l ul{list-style:none;padding-left:64px;}
#BlocList .l ul li{position:relative;min-height:45px;max-width:95%;}
#BlocList .l ul li img{display:block;position:absolute;height:48px;left:-64px;margin:auto;top:0;bottom:0;}
#BlocList .l ul li:not(:last-of-type){margin-bottom:16px;}
#BlocList .r{width:45vw;}
#BlocList .r .pb{float:right;margin-top:16px;}
#BlocList .r ul{list-style:none;margin-left:16px;}
#BlocList .r ul li:not(:last-of-type){margin:0 0 24px 0}
#BlocList .r ul li:before { content: ''; width: 8px; height: 8px; background: #D90D25; position: absolute; margin-top: 7px; margin-left: -16px;}

#Cloud-c{display:flex;max-width:1360px;margin:0 auto; padding:24px;justify-content: center; align-items: center;gap:48px;margin-top:24px;border-radius: 12px;background: var(--clr-bg);width:calc(100% - 48px);}
#Cloud-c p{width:70%;}

#Choose { background: #fff; box-shadow: 0px 8px 16px rgba(24, 24, 24, 0.02); border-radius: 12px; max-width: 1360px; margin: 24px auto 48px auto; width: calc(100% - 64px); padding: 24px 0 90px 0; display: flex; gap: 22px; flex-wrap: wrap; position: relative; justify-content: space-evenly;}
#Choose .c { text-align: center; width: 225px;}
#Choose .c>img { height: 64px; margin: 0 0 16px 0;}
#Choose .c p { font-family: 'SFR-Bold'; font-size: 14px; margin: 0 0 16px 0;}
#Choose .c a.link { text-decoration: none;}
#Choose .btn4 { width: fit-content; margin: 0 auto; position: absolute; bottom: 24px; left: 0; right: 0;}
#Bestsfr{margin:128px 0 0 0;padding: 0 24px;}
#Bestsfr h2{margin:0 auto;max-width:100%;width:fit-content;}

#Bloctxt{margin-top:48px;}
#Bloctxt a{margin:24px 0;}
#Bloctxt .container{display:flex;justify-content: space-between; align-items: flex-start;gap:24px;}
#Bloctxt .r{width:fit-content;}
#Bloctxt .l{width:50%;}
#Bloctxt .r img{border-radius:12px;max-width:100%;min-width:500px;}
#Bloctxt p{margin-bottom:16px;}
#Bloctxt ul{list-style:none;padding-left:16px;}
#Bloctxt  ul li:not(:last-of-type) { margin: 0 0 24px 0;}
#Bloctxt ul li:before { content: ''; width: 8px; height: 8px; background: #D90D25; position: absolute; margin-top: 7px; margin-left: -16px;}

#ReadArt {margin:64px 0 48px 0;}
#ReadArt .container{display:flex;gap:72px;}
#ReadArt .l, #ReadArt .r{width:30%;}
#ReadArt .l img{width:100%;border-radius:12px;}
#ReadArt .r{width:70%;}
#ReadArt .r .title{font-size: 24px;font-family:'sfr-Bold';margin: 8px 0 16px 0;}
#ReadArt .pb{margin-top:32px;}

#GreyCards{margin-bottom:48px;}
#GreyCards .container{display:flex; gap:24px;justify-content:center;}
#GreyCards .container .greycard{display:flex;background:#F4F4F4;flex-direction:column;border-radius:12px;padding:60px 25px;justify-content:center;align-items:center;gap:24px;flex:1;}
#GreyCards .container .greycard img{width:50px;}


#ReadVideo { margin: 64px 0 48px 0;}
#ReadVideo .container { display: flex; gap: 72px;}
#ReadVideo .l {max-width:640px;width:60%;}
#ReadVideo .l video { width: 100%; border-radius: 12px;position:relative;max-height:360px;object-fit:cover}
#ReadVideo .l iframe{width: 100%; border-radius: 12px;height:360px;}
#ReadVideo .r { width: 46%;}
#ReadVideo .r .title { font-size: 24px; font-family: 'sfr-Bold'; margin: 8px 0 16px 0;}
#ReadVideo .pb { margin-top: 32px;}

#MentionLegales{font-size:12px;font-family: Arial;}
#MentionLegales summary{list-style:none;color:#444;cursor:pointer;margin-bottom:4px;}
#MentionLegales summary:after{content:'';display:inline-block;width:6px;height:10px;background-image:url(https://static.s-sfr.fr/media/n2s-secure-arrow.png);background-size:contain;background-position:center;background-repeat:no-repeat; position: relative; top: 1px; left: 6px;transform: rotate(-90deg);transition:all .3s;}
#MentionLegales[open] summary:after{transform: rotate(90deg);}
#MentionLegales > div{color: #8a8a8a;}
#MentionLegales > div p, #MentionLegales > div a, #MentionLegales > div b,#MentionLegales > div strong{font-size:12px;}

#Txtclass a{color:var(--clr-black);text-decoration:none; font-family:'sfr-Bold';}

@media (min-width:768px) {
    #eTsNL {padding: 20px 32px;}
#eTsNL > div {width: 100%;padding: 36px 20px 0;max-width: 1280px;}
#eTsNL > div > * {width: 352px;}
#eTsNL > div > h2 {width: calc(100% - 352px);font: calc(5vw - 24px) / 40px 'SFR-Bold',Arial;}
#eTsNL > div > form > * {height: 40px;}
#eTsNL input {width: calc(100% - 120px);padding: 0 1vw;}
#eTsNL button {width: 120px;text-align: center;font: 14px/38px 'SFR-Bold',Arial;color: #fff;background: var(--clr-black);}
#eTsNL > div > p {font-size: 12px;}
}
@media (min-width:992px) {
    #eTsNL > div > * {width: 352px;width: calc(100% - 592px);}
    #eTsNL > div > h2 {width: 576px;font-size: 28px;}
}

@media all and (max-width: 1100px) {
    #HP h1 {background: #fff; padding: 24px 16px; margin: 0;width: auto;font-size: 24px;}
    #HP #TT{display:block; margin: 16px 0;}
    
    #HP #Acc5 { height: 560px; }
    #HP #Acc5 .hero:before { height: 448px; }
    #HP #Acc5 .hero>.c { display: block; height: 448px; left: 16px; right: 16px; display: flex; justify-content: space-around; gap: unset; }
    #HP #Acc5 .hero>.c>.L { width: 100%; display: block; text-align: center; margin: -26px 0 0 0; position: absolute; }
    #HP #Acc5 .hero>.c>.L strong { margin: 0 0 0 0; }
    #HP #Acc5 .hero>.c>.L .stars { margin: 8px 0 0 0; }
    #HP #Acc5 .hero>.c>.M { max-width: 50%; width: auto; text-align: right; text-align: center; height:50%;display: flex;align-items: flex-end;bottom:-60px;}
    #HP #Acc5 .hero>.c>.R { max-width: none; width: auto; margin: 0 0 178px 0; }
    #HP #Acc5 .hero>.c>.R>a:after { height: 612px; }
    #HP #Acc5 .hero>.c>.B { bottom: 146px; }
    #HP #Acc5 .capsules { width: 100%; max-width: 1100px; margin: -136px auto 0 auto; flex-wrap: wrap; flex-direction: row; gap: 16px; justify-content: space-evenly; padding: 0 16px 16px 16px;}
    #HP #Acc5 .cap { max-width: none; width: calc(50% - 8px); height: 52px; font-size: 12px; line-height: 18px; padding: 0; }
    #HP #Acc5 .cap>div { margin: 0 8px 0 0; }
    #HP #Acc5 .cap>span { width: calc(100% - 70px); }
    #HP #Acc5 .hero>.c>.M > img{max-height:90%;}
    #HP #Choose { flex-direction: column; gap: 40px; width: calc(100% - 100px); }
    #HP #Choose .c { max-width: none; width: auto; }
    #HP #Choose .c>img { height: 60px; margin: 0 0 8px 0; }
    #HP #Choose .c p { margin: 0 0 8px 0; }
    #HP #Pilier { display: block; background: #fff; }
    #HP #Pilier h1 {font-size: 24px;}
    #HP #Pilier .p {text-align: center; display: block; border-bottom: 1px solid #d8d8d8; padding: 16px 0; border-right: none; margin: 0 32px;}
    #HP #Pilier .p svg.si {display: none;}
    #HP #Pilier .p div>p {display: none;}
    #HP #Pilier .p .si + div {margin-left: 32px;}
    #HP #Pilier .p .m {position: relative;display: block;text-align: left; margin-right: 2px}
    #HP #Pilier .p .m svg {display:inline-block;vertical-align: middle;}
    #HP #Pilier .p .m a{margin-right:0;width: calc(100% - 40px);color: var(--clr-black);}
    #HP #Pilier .p:last-child { color: var(--clr-sfr2); }
    #HP #Pilier .p:last-child .m svg{ filter: invert(13%) sepia(79%) saturate(6072%) hue-rotate(348deg) brightness(86%) contrast(98%); }
    #HP #Pilier .p:last-child .m a{ color: var(--clr-sfr2);}
    #HP #Pilier .p>div:not(.m) {display: none;}
    #HP #Pilier .p a:before {content: '';position: absolute;width: calc(100% + 24px);height: calc(100% + 32px);top: -16px;left: -30px;}
    #HP #Best {padding-left: 18px; padding-right: 18px;}
    #HP #Best h2 {font-size: 24px; line-height: 24px; padding: 0 20px;}
    #HP #Best .card {height: 262px; padding: 12px;box-sizing: border-box;}
    #HP #Best .card .ub:before {width: 327px;}
    #HP #Best .card a:not(.ub) {font-size: 16px; margin-bottom: 0; position: relative; z-index: 2;}
    #HP #Best .card a:not(.ub):before {content: ""; bottom: 0; left: -12px;max-width: calc(100% + 12px * 2);height: 185px; top: -12px;}
    #HP #Best .card >p {font-size: 14px;line-height: 22px;margin-bottom: 5px; z-index: 2; position: relative;}
    #HP #Best .card .tadp {font-size: 9px; line-height: 14px; margin-bottom: -2px; display: table;}
    #HP #Best .card .price>.entier {font-size: 30px;}
    #HP #Best .card .price>div {height: 35px;} 
    #HP #Best .card .price>div>.cents {font-size: 16px;}
    #HP #Best .card .price>div>.granu {font-size: 10px;}
    #HP #Best .card .price p {font-size: 10px;line-height: 14px;margin-top: -3px;}
    #HP #Best .card .illu-r {position: absolute;}
    #HP #Best .card .tooltip {bottom: 38px; right: 10px;}
    #HP #Best .card .tooltip .hov.tooltiptext {display:none;}
    #HP #Best .card .tooltip .tooltiptext {right: -10px;}
    #HP #Best .card .tooltip .tooltiptext:after {left: 83%;}
    #HP #Best .carou {position: absolute; bottom: 35px; right: 6px; z-index: 5;}
    #HP #Best .carou .amp-carousel-button {display: none;}
    #HP #Best .carou-but{position: absolute; right: 55px; bottom: 28px;}
    #HP #Best .carou-but>button {background-color: var(--clr-disable); border: 0; width: 4px; padding: 3px; height: 4px; border-radius: 20px; margin:0 4px;}
    #HP #Best .carou-but>button[option][selected] {background-color: #222; border:0; outline:0;}
    #HP #News {position: relative;}
    #HP #News h2 {font-size: 24px; line-height: 28px; color: var(--clr-black); margin: 24px auto;}
    #HP #News .card {width: 285px; height: 292px;}
    #HP #News .card:nth-child(1) {margin-left: 250px;}
    #HP #News .card .T {height: 162px;}
    #HP #News .card .T span {}
    #HP #News .card .B {height: calc(292px - 162px); box-sizing: border-box;}
    #HP #News .card .B .titre {font-size: 14px;line-height: 18px;}
    #HP #News a {margin: 0 auto 25px auto;}
    #HP #News #carousel-actu {padding-left: 20px; margin-bottom: 0;}
    #HP #News .carousel-preview {display: block; margin: -50px auto 20px auto; position: absolute; left:0; right:0;}
    #HP #News .carousel-preview>button {background-color: var(--clr-disable); border: 0; width: 4px; padding: 3px; height: 4px; border-radius: 20px; margin:0 4px;}
    #HP #News .carousel-preview>button.setBlack {background-color: #222;}
    #HP #News #actu-dots {display: block; margin-bottom: 20px;}
    #HP #News #actu-dots>button {background-color: var(--clr-disable); border: 0; width: 4px; padding: 3px; height: 4px; border-radius: 20px; margin:0 4px;}
    #HP #News #actu-dots>button[option][selected] {background-color: #222; border:0; outline:0;}#News {position: relative;}
    #HP #News h2 {font-size: 24px; line-height: 28px; color: var(--clr-black); margin: 24px auto;}
    #HP #News .card {width: 285px; height: 292px;}
    #HP #News .card:nth-child(1) {margin-left: 250px;}
    #HP #News .card .T {height: 162px;}
    #HP #News .card .T span {}
    #HP #News .card .B {height: calc(292px - 162px); box-sizing: border-box;}
    #HP #News .card .B .titre {font-size: 14px;line-height: 18px;}
    #HP #News a {margin: 0 auto 25px auto;}
    #HP #News #carousel-actu {padding-left: 20px; margin-bottom: 0;}
    #HP #News .carousel-preview {display: block; margin: -50px auto 20px auto; position: absolute; left:0; right:0;}
    #HP #News .carousel-preview>button {background-color: var(--clr-disable); border: 0; width: 4px; padding: 3px; height: 4px; border-radius: 20px; margin:0 4px;}
    #HP #News .carousel-preview>button.setBlack {background-color: #222;}
    #HP #News #actu-dots {display: block; margin-bottom: 20px;}
    #HP #News #actu-dots>button {background-color: var(--clr-disable); border: 0; width: 4px; padding: 3px; height: 4px; border-radius: 20px; margin:0 4px;}
    #HP #News #actu-dots>button[option][selected] {background-color: #222; border:0; outline:0;}
    #HP #Seo h2{text-align:left;}
    /* Page gamme */
    #BannerGamme:before{height:50%;width:100%;bottom:0;}
    #BannerGamme div{top:66px;left:0;right:0;margin:0 auto;max-width:90%;}
    #TextAndCard .container{flex-direction:column;align-items:center;gap:16px}
    #TextAndCard .container .l .pb{float:none;margin:0 auto;}
    #Gamme .card{padding:16px;}
    #lamme-offer{gap:8px}
    #lamme-offer .r{width:32%;z-index:20;}
    #Solucards .list{grid-template-columns: 328px 328px; justify-content: center; gap: 16px;}
    #Solucards .list > li{margin: 0;}
    #Solucards .addons-card .BlackBloc{padding:16px;}
    #ReadArt .container{flex-direction:column;gap:16px}
    #ReadArt .container > div {width:100%;}
    
    #BannerGamme1 {height:400px;flex-direction:column;gap:16px}
    #BannerGamme1 .l, #BannerGamme1 .r, #BannerGamme1 .m{width:100%;}
    #BannerGamme1 .r .bloc-price{width:fit-content;margin:0 auto;}
    #BannerGamme1 .price{margin: 16px auto;}
    #BannerGamme1 .bloc-price > p{margin:0 auto;}
    #BannerGamme1 .bloc-price > .engagement{text-align:center;}
    #BannerGamme1:before{height:80%;width:100%;bottom:0;}
    
    #Cloud-c{align-items: flex-start;gap: 0;flex-direction: column;padding-left:110px;}
    #Cloud-c p{width:100%;}
    #Cloud-c img{position:absolute;margin-left:-60px;}
    
    #Choose { flex-direction: column; order: 7; gap: 40px; width: calc(100% - 100px);}
    #Choose .c { max-width: none; width: auto;}
    #Choose .c>img { height: 60px;}
    
    #Bloctxt .r img{min-width:unset;}
    #BlocList .l, #BlocList .r{width:100%;max-width:unset;}
    #BlocList .l{padding-left:0;}
    #BlocList .l:before{content:none;}
    #BlocList{gap:24px;flex-direction:column;padding:24px;}
    /* #BlocList .l{top:480px; padding: 32px 72px 32px 80px;} */
    
    #ReadVideo .container { flex-direction: column; gap: 16px }
    #ReadVideo .container > div { width: 100%; }
    #ReadVideo .l{max-width:none;width:100%;}
    #ReadVideo .l video{max-height:none;}
}
@media (max-width: 768px){
    .arrow:after {width:6px;height:6px;}
    #HP #Acc5 .hero>.c{ gap: 16px; }
    #HP #Acc5 .hero>.c>.L { margin: -18px 0 0 0; }
    #HP #Acc5 .hero>.c>.L strong { font-size: 24px; line-height: 36px;  margin: 0;}
    #HP #Acc5 .hero>.c>.L p { font-size: 14px; line-height: 22px; }
    #HP #Acc5 .hero>.c>.L p{margin:0;}
    #HP #Pilier .p {margin:0 16px;}
    #HP #Pilier h1 {font-size: 20px;margin:24px auto 8px;}
    #HP #Choose {width: calc(100% - 40px);}
    #HP #Best .card .ub, #Rea a, #Rea .desc {font-size: 12px;line-height: 16px;}
    #HP #Best .wrap {grid-template-columns: 1fr;margin-bottom:24px; width:100%;}
    #HP #Best .card .tooltip {right: 16px;}
    #HP #Best .card .tooltip .das {font-size: 10px;line-height: 10px;}
    #HP #Best .card .price, #Best .card >p {max-width: 172px;}
    #HP #Best .card {padding: 16px 16px 8px;}
    #HP #Best {padding-top: 20px;}
    #HP #Best h2 {font-size: 20px; line-height: 20px;}
    /* Page gamme */
    #BannerGamme div{top:30px;}
    #Gamme .card{max-width:100%;width:unset;}
    #ArtiCards .container .cards .card{min-width:unset;width:400px;}
    #Cloud-c{padding-left:80px;}
    #Bloctxt .container{flex-direction:column;gap:24px}
    #Bloctxt .container .l{width:100%;}
    #ReadArt .container{flex-direction:column;gap:16px}
    #ReadArt .container > div {width:100%;}
    #Choose {width: calc(100% - 40px);}
    #GreyCards .container{flex-direction:column;}
    #BlocList .r .pb{float:unset;margin:16px auto 0 auto;}
    #Bestsfr{margin-top:48px;}
    #Bloctxt .r img{min-width:unset;}
    #lamme-offer{flex-direction:column;}
    #lamme-offer > .l, #lamme-offer > .m, #lamme-offer > .r{width:100%;max-width:100%;}
    #lamme-offer .l:before{width:120px;}
    #lamme-offer .m img{max-width:170px;}
    #lamme-offer .das{position: absolute; width: 100%; left: 16px; bottom: 16px;}
    
    #Solucards .list{grid-template-columns: 1fr; justify-content: center; align-items: center; max-width: 100%;}
    #Solucards .list >li{ max-width: 400px; margin: 0 auto; width: 100%;}
    
    #Bloctxt .r{width:100%;}
    #Bloctxt .r img{width:100%;}
    
    #lamme-offer .dasPopup{left:0;}
    #lamme-offer .dasPopup:after{left:16%;}
    #lamme-offer .pb1{margin:0 auto 8px auto;}
    #Bloctxt .r{order:unset;}
    
    #ReadVideo .l iframe{height:230px;}
  }