/* 
    Created on : 20 janv. 2025, 19:32:15
    Author     : DucoteWeb
*/
html {
    scroll-behavior: smooth;
}

/* Style pour le mot Cashoo */
.cashoo {
    font-weight: bold;
    color: #3c8f69; /* Vert pour la partie "Cash" */
}

/* Dégradé pour les lettres "oo" */
.cashoo-oo {
    background: linear-gradient(45deg, #f7f041, #1f4120); /* Dégradé */
    -webkit-background-clip: text; /* Applique le dégradé uniquement sur le texte */
    color: transparent; /* Cache la couleur du texte pour laisser apparaître le dégradé */
}









/* connexion */
#Top_bar .menu > li.menu-account-item{
    display: inline-flex !important;
    align-items: center !important;
    height: 100% !important;
    margin-left: 10px !important;
    vertical-align: middle !important;
    margin-top: 30px;
}

#Top_bar .menu > li.menu-account-item > a.menu-account-link{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;

    height: 34px !important;
    padding: 0 12px !important;
    margin: 0 !important;

    position: relative !important;
    top: auto !important;
    bottom: auto !important;

    border-radius: 999px !important;
    background: rgba(255,255,255,0.08) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;

    color: #fff !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    white-space: nowrap !important;

    transform: none !important;
    box-sizing: border-box !important;
}

#Top_bar .menu > li.menu-account-item > a.menu-account-link:hover{
    background: rgba(255,255,255,0.14) !important;
    border-color: rgba(255,255,255,0.18) !important;
    transform: translateY(-1px) !important;
}

#Top_bar .menu > li.menu-account-item > a.menu-account-link.is-connected{
    background: #3c8f69 !important;
    border-color: rgba(60,143,105,0.35) !important;
}

#Top_bar .menu > li.menu-account-item > a.menu-account-link.is-connected:hover{
    background: rgba(60,143,105,0.26) !important;
    border-color: rgba(60,143,105,0.42) !important;
}

#Top_bar .menu > li.menu-account-item > a.menu-account-link i{
    display: inline-block !important;
    position: static !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
    line-height: 1 !important;
    vertical-align: middle !important;
}

#Top_bar .menu > li.menu-account-item > a.menu-account-link span{
    display: inline-block !important;
    position: static !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    vertical-align: middle !important;
    white-space: nowrap !important;
}

#Top_bar.is-sticky .menu > li.menu-account-item > a.menu-account-link,
#Top_bar.sticky .menu > li.menu-account-item > a.menu-account-link,
#Top_bar.sticky-header .menu > li.menu-account-item > a.menu-account-link{
    height: 30px !important;
    margin-top: -16px !important;
    font-size: 12px !important;
}



/* SPINNER */
#loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    color: white;
    font-size: 20px;
    font-family: Arial, sans-serif;
    z-index: 9999;
}

/* Container pour l'animation du spinner */
.cashoo-container {
    display: inline-block;
    font-size: 50px;
    font-weight: bold;
    animation: spin-text 3s infinite linear;
}

/* Animation de la rotation du texte */
@keyframes spin-text {
    0% { transform: rotateY(0deg); }
    100% { transform: rotateY(360deg); }
}





.btnPrec{
    background-color: #6c757d !important;
    border-color: #6c757d !important;
    font-family: Poppins;
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  letter-spacing: 0px;
  padding: 18px 35px 18px 35px;
}
.btnSuivant{
    background-color: #3c8f69 !important;
    border-color: #3c8f69 !important;
    font-family: Poppins;
  font-size: 16px;
  line-height: 16px;
  font-weight: 700;
  letter-spacing: 0px;
  padding: 18px 35px 18px 35px;
}
#Top_bar .logo {
	float: left;
	margin: 0px 30px 20px 20px;
}

.cta {
	left: 230px !important;
	top: 0px;
        font-size: 53px !important;
}
.cta2 {
	left: 230px !important;
	top: -70px;
}
.cta3 {
	left: 230px !important;
	top: -110px;
}
@media only screen and (min-width: 768px) and (max-width: 991px) {
    .cta {
	left: 20px !important;
        font-size: 25px !important;
        top: 20px !important;
    }
    .cta2{
        left: 20px !important;
        font-size: 15px !important;
        top: -20px !important;
    }
    .cta3 {
	left: 25px !important;
	top: -30px !important;
    }
}


#Top_bar .menu > li.current-menu-item > a, #Top_bar .menu > li.current_page_item > a, #Top_bar .menu > li.current-menu-parent > a, #Top_bar .menu > li.current-page-parent > a, #Top_bar .menu > li.current-menu-ancestor > a, #Top_bar .menu > li.current-page-ancestor > a, #Top_bar .menu > li.current_page_ancestor > a, #Top_bar .menu > li.hover > a {
	color: #fff;
}

#Top_bar .menu > li > a, #Top_bar #menu ul li.submenu .menu-toggle {
	color: #fff;
}

#Top_bar .top_bar_right .top-bar-right-icon, #Top_bar .top_bar_right .top-bar-right-icon svg .path {
    color: #d3c8f69;
    stroke: #3c8f69;
}

.paddingConnexion{
    padding-top: 160px;
}
.paddingBrouillon{
    padding-top: 160px;
}
.paddingBlog{
    padding-top: 160px;
}
@media only screen and (max-width: 767px) {
    .paddingConnexion{
        padding-top: 20px;
    }
    .paddingBrouillon{
        padding-top: 40px;
    }
    .paddingBlog{
        padding-top: 40px;
    }
}


.section1{
    padding-top:80px;
    padding-bottom:80px;
    background-color:#f2f4f8;
}


@media only screen and (max-width: 767px) {
    .cta {
	left: -60px !important;
        font-size: 20px !important;
        top: 5px !important;
    }
    .cta2{
        left: 20px !important;
        font-size: 17px !important;
        top: -20px !important;
    }
    .ctaImg{
        left: 110px !important;
    }
    .cta3 {
	left: -65px !important;
	top: -270px;
    }
    .section1{
        padding-top:40px;
    }
    
    .bgConnexion{
        margin-top: 50px !important;
    }
    .responsiveMt40{
        margin-top: 40px;
    }
    .mt-10{
        margin-top: -10px;
    }
}

.bgConnexion{
    background-color: #3c8f69;
    margin-top: 0px;
    padding: 10px 10px 30px 10px;
    border-radius: 10px;
}
.bgConnexion2{
    padding: 10px 10px 10px 10px;
}

.bq_wrapper{
    background: #3c8f69 !important;
}

.agency7-heading {
	background-color: #3c8f69;
	color: #fff;
}

#Top_bar .menu > li > a, #Top_bar #menu ul li.submenu .menu-toggle {
	color: #3c8f69;
}
#Top_bar .menu > li.current-menu-item > a, #Top_bar .menu > li.current_page_item > a, #Top_bar .menu > li.current-menu-parent > a, #Top_bar .menu > li.current-page-parent > a, #Top_bar .menu > li.current-menu-ancestor > a, #Top_bar .menu > li.current-page-ancestor > a, #Top_bar .menu > li.current_page_ancestor > a, #Top_bar .menu > li.hover > a {
	color: #3c8f69;
}

.eye-icon {
    font-size: 1.2rem;
    color: #6c757d;
}
.eye-icon:hover {
    color: #3c8f69; /* Changez selon votre palette de couleurs */
}


.position-relative {
    position: relative;
}

#passwordBox {
    padding-right: 40px; /* Ajoute un padding à droite pour l'icône */
}

/* le eye dans le brouillon */
.position-relative {
    position: relative;
}
#passwordBox {
    padding-right: 40px; /* Ajoute de l'espace à droite pour l'icône */
}
#togglePasswordIcon1 {
    position: absolute;
    top: 50%;
    right: 10px;  /* Ajuste la distance de l'icône par rapport à l'input */
    transform: translateY(50%); /* Centrage vertical */
    cursor: pointer;
    color: #aaa;
}
#togglePasswordIcon2 {
    position: absolute;
    top: 38%;
    right: 15px;  /* Ajustez en fonction de l'espace souhaité */
    transform: translateY(-50%); /* Centrage vertical */
    cursor: pointer;
    color: #aaa;
}
/* le eye dans récupération de mot de passe */
#togglePasswordIcon3 {
    position: absolute;
    top: 47%;
    left: 565px;  /* Ajustez en fonction de l'espace souhaité */
    transform: translateY(-50%); /* Centrage vertical */
    cursor: pointer;
    color: #aaa;
}

@media only screen and (max-width: 767px) {
    #togglePasswordIcon2 {
        top: 37%;
        right: 10px; /* Ajustez pour mobile */
    }
    #togglePasswordIcon3 {
        top: 43%;
        left: 300px;  /* Ajustez en fonction de l'espace souhaité */
    }
}
@media only screen and (min-width: 768px) and (max-width: 991px) {
    #togglePasswordIcon3 {
        top: 46%;
        left: 360px;  /* Ajustez en fonction de l'espace souhaité */
    }
}


.editor {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.preview {
    margin-top: 20px;
    padding: 10px;
    border: 1px solid #ddd;
}
.editable {
    border: 1px solid #ccc;
    padding: 5px;
    min-height: 30px;
}


.modal-backdrop {
    display: none !important;
}

#map {
    height: 400px;
    width: 100%;
    border: 2px solid #333;
    border-radius: 8px;
}


/* btn de présentation des modèles dans création box */
.btnCreaBox{
    background-color: #ff9501 !important; 
    border-color: #ff9501 !important;
    color: #fff !important;
    padding: 10px 10px 10px 10px !important;
}
.btnCreaBox:hover{
    background-color: #fff !important; 
    border-color: #ff9501 !important;
    color: #ff9501 !important;
}
.btnCreaBox2{
    background-color: #d54d8a !important; 
    border-color: #d54d8a !important;
    color: #fff !important;
    padding: 10px 10px 10px 10px !important;
}
.btnCreaBox2:hover{
    background-color: #fff !important; 
    border-color: #d54d8a !important;
    color: #d54d8a !important;
}
.btnCreaBox3{
    background-color: #323c48 !important; 
    border-color: #323c48 !important;
    color: #fff !important;
    padding: 10px 10px 10px 10px !important;
}
.btnCreaBox3:hover{
    background-color: #fff !important; 
    border-color: #323c48 !important;
    color: #323c48 !important;
}
.btnCreaBox4{
    background-color: #302f2d !important; 
    border-color: #302f2d !important;
    color: #fff !important;
    padding: 10px 10px 10px 10px !important;
}
.btnCreaBox4:hover{
    background-color: #fff !important; 
    border-color: #302f2d !important;
    color: #302f2d !important;
}

/* bouton envoyer les emails */
.paddingPerso{ 
    padding: 10px 10px 10px 10px !important;
    margin-bottom: 20px;
}

  .inactive-link {
    pointer-events: none !important; /* Empêche le clic */
    opacity: 0.5 !important; /* Rend visuellement l'élément inactif */
    cursor: default !important; /* Change le curseur */
  }
  
  /* boutons tarifs */
/* Applique Flexbox à chaque colonne */
.column_pricing_item {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 500px; /* Définit une hauteur minimale pour toutes les colonnes */
}

/* Assure une hauteur égale entre toutes les colonnes */
.pricing-box {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Le bouton doit être poussé en bas */
.plan-footer {
    margin-top: auto;
}



/* BLOG */
.blogPT{
    padding-top: 160px; padding-bottom:80px
}
@media only screen and (max-width: 767px) {
    .blogPT{
        padding-top: 80px; padding-bottom:80px
    }    
}

.presentation{
    padding-top:120px; padding-bottom:80px
}
.ptCagnotte{
    padding-top:80px;
}
.presentationBlog{
    padding-top:120px; padding-bottom:40px
}

@media only screen and (max-width: 767px) {
    .presentation{
        padding-top:60px; padding-bottom:40px
    }
    .ptCagnotte{
        padding-top:40px;
    }
    .presentationBlog{
        padding-top:60px; padding-bottom:20px
    }
}






















/* TABLEAU DE BORD */
.dashboard-card{
    display:block;
    background:white;
    border-radius:12px;
    padding:30px 20px;
    box-shadow:0 5px 20px rgba(0,0,0,0.05);
    transition:all .25s ease;
    border:1px solid #f1f1f1;
}

.dashboard-card:hover{
    transform:translateY(-5px);
    box-shadow:0 10px 30px rgba(0,0,0,0.1);
}

.dashboard-card .icon{
    width:70px;
    height:70px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    margin:0 auto 15px auto;
    color:white;
    font-size:28px;
}

.dashboard-card h5{
    font-weight:600;
    margin-bottom:5px;
}

.dashboard-card p{
    font-size:14px;
}

.dashboard-card.logout:hover{
    background:#fff5f5;
}


/* LES BOITES */
.dashboard-section-title{
  text-align:center;
  margin: 2.5rem 0 1.5rem 0;
}
.dashboard-section-title h3{
  font-weight:700;
  margin:0;
}
.dashboard-section-title p{
  margin:.35rem 0 0 0;
  color:#6c757d;
}

.box-card{
  background:#fff;
  border:1px solid #f1f1f1;
  border-radius:14px;
  box-shadow:0 6px 22px rgba(0,0,0,.06);
  overflow:hidden;
  transition: all .25s ease;
}
.box-card:hover{
  transform: translateY(-4px);
  box-shadow:0 14px 40px rgba(0,0,0,.10);
}

.box-card-header{
  padding:18px 18px 12px 18px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.box-title{
  margin:0;
  font-weight:700;
}
.box-subtitle{
  margin:4px 0 0 0;
  font-size:13px;
  color:#6c757d;
}

.badge-soft{
  border-radius:999px;
  padding:.35rem .6rem;
  font-size:12px;
  font-weight:600;
  border:1px solid rgba(0,0,0,.05);
  background:#f8f9fa;
}

.badge-soft.success{ background:#eaf7ef; color:#1b7a3a; }
.badge-soft.warning{ background:#fff6e5; color:#8a5a00; }
.badge-soft.danger{  background:#fdecec; color:#b02a37; }

.box-card-body{
  padding: 0 18px 18px 18px;
}

.box-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}

.action-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid #e9ecef;
  background:#fff;
  text-decoration:none;
  transition: all .2s ease;
  font-weight:600;
  font-size:14px;
}
.action-btn:hover{ transform: translateY(-2px); }

.action-btn.primary{ border-color: rgba(13,110,253,.25); }
.action-btn.success{ border-color: rgba(25,135,84,.25); }
.action-btn.danger{  border-color: rgba(220,53,69,.25); }

.action-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f8f9fa;
}

.box-tools{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.tool-btn{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid #e9ecef;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  background:#fff;
  transition: all .2s ease;
}
.tool-btn:hover{ transform: translateY(-2px); }

.box-divider{
  height:1px;
  background:#f1f1f1;
  margin:14px 0;
}

.accordion-lite{
  border:1px solid #e9ecef;
  border-radius:14px;
  overflow:hidden;
}
.accordion-lite summary{
  cursor:pointer;
  list-style:none;
  padding:14px 16px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:#f8f9fa;
}
.accordion-lite summary::-webkit-details-marker{ display:none; }
.accordion-lite .content{
  padding: 14px 16px 16px 16px;
  background:#fff;
}

.danger-zone{
  margin-top:14px;
  padding:14px;
  border-radius:14px;
  background:#fff5f5;
  border:1px solid rgba(220,53,69,.2);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.danger-zone p{
  margin:0;
  color:#b02a37;
  font-size:13px;
}

.stripe-alert{
    margin-top:18px;
    padding:18px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:15px;
    border:1px solid;
}

.stripe-alert-warning{
    background:#fff4e5;
    border-color:#ffb74d;
}

.stripe-alert-danger{
    background:#fdecec;
    border-color:#f44336;
}

.stripe-alert-left{
    display:flex;
    align-items:center;
    gap:12px;
}

.stripe-alert-left i{
    font-size:22px;
}

.stripe-alert-text{
    font-weight:600;
}

.stripe-cta{
    padding:10px 18px;
    border-radius:10px;
    font-weight:700;
    background:#22a06b;
    color:white;
    text-decoration:none;
    display:flex;
    align-items:center;
    gap:8px;
    transition:all .2s;
}

.stripe-cta:hover{
    transform:translateY(-2px);
    background:#1c8b5d;
}





.action-btn-cta{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:12px 18px;
    border-radius:12px;
    background:#22a06b;
    color:white !important;
    font-weight:700;
    border:none;
    text-decoration:none;
    box-shadow:0 6px 18px rgba(34,160,107,0.35);
    transition:all .25s ease;
}

.action-btn-cta:hover{
    transform:translateY(-3px) scale(1.02);
    box-shadow:0 10px 25px rgba(34,160,107,0.45);
    background:#1c8b5d;
}

.action-btn-cta .action-icon{
    background:rgba(255,255,255,0.2);
    color:white;
}





/*section header */
.site-header{
    position: relative;
    z-index: 30;
}

.site-header-home{
    background: #131b22;
}

.site-header-inner{
    background: #131b22;
}

.site-topbar{
    background: #131b22;
    transition: background .25s ease, box-shadow .25s ease;
}

.site-header-home .site-topbar{
    background: #131b22;
}

.site-header-inner .site-topbar{
    background: #131b22;
}

/* sticky */
#Top_bar.is-sticky,
#Top_bar.sticky,
#Top_bar.sticky-header{
    background: #131b22 !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.16);
}

/* menu */
#Top_bar .menu > li > a span{
    font-weight: 600;
}

#Top_bar .menu > li > a{
    transition: opacity .2s ease, transform .2s ease;
}

#Top_bar .menu > li > a:hover{
    opacity: .85;
    transform: translateY(-1px);
}

.menu-account-item a{
    font-size: 1.05rem;
}

/* bandeau accueil */
.site-header-banner{
    background: linear-gradient(180deg, #131b22 0%, #1b2733 100%);
    border-top: 1px solid rgba(255,255,255,0.05);
    padding-top: 80px;
}

.site-header-banner-inner{
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    padding: 20px 0;
}

.site-header-banner-text{
    color: #fff;
}

.site-header-badge{
    display: inline-block;
    margin-bottom: 10px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(60,143,105,0.18);
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.site-header-banner-text p{
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.7;
    color: rgba(255,255,255,0.88);
    max-width: 520px;
}

.site-header-banner-visual{
    flex-shrink: 0;
}

.site-header-banner-visual img{
    width: 120px;
    height: auto;
    display: block;
}

/* mobile */
@media (max-width: 991px){
    .site-header-banner{
    padding-top:70px;
}
    .site-header-banner-inner{
        min-height:160px;
        gap: 20px;
    }

    .site-header-banner-visual img{
        width: 95px;
    }
}

@media (max-width: 767px){
    .site-header-banner{
    padding-top:65px;
}
    .site-header-banner-inner{
        min-height: 140px;
        flex-direction: column;
        text-align: center;
        padding: 18px 0;
    }

    .site-header-banner-text p{
        max-width: 100%;
        font-size: .95rem;
    }

    .site-header-banner-visual img{
        width: 85px;
    }
}





/* section intro */
.hero-cashoo-premium{
    position: relative;
    overflow: hidden;
    padding: 95px 0 80px 0;
    background:
        radial-gradient(circle at top right, rgba(60,143,105,0.10), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #f7fbf8 100%);
}

.hero-premium-content{
    max-width: 720px;
}

.hero-premium-kicker{
    display: inline-block;
    margin-bottom: 18px;
    padding: 8px 15px;
    border-radius: 999px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.hero-premium-title{
    margin: 0 0 22px 0;
    font-size: 3.3rem;
    line-height: 1.08;
    font-weight: 800;
    color: #1f2933;
}

.hero-premium-text{
    max-width: 620px;
    margin: 0 0 28px 0;
    font-size: 1.08rem;
    line-height: 1.8;
    color: #5b6670;
}

.hero-premium-actions{
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 28px;
}

.hero-premium-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 26px;
    border-radius: 14px;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    transition: all .25s ease;
}

.hero-premium-btn-primary{
    background: #3c8f69;
    color: #fff !important;
    box-shadow: 0 12px 28px rgba(60,143,105,0.22);
}

.hero-premium-btn-primary:hover{
    background: #347e5d;
    transform: translateY(-2px);
    box-shadow: 0 16px 34px rgba(60,143,105,0.28);
}

.hero-premium-btn-secondary{
    background: #fff;
    color: #3c8f69 !important;
    border: 1px solid rgba(60,143,105,0.18);
    box-shadow: 0 8px 20px rgba(0,0,0,0.05);
}

.hero-premium-btn-secondary:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.08);
}

.hero-premium-points{
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hero-premium-point{
    display: flex;
    align-items: center;
    gap: 12px;
    color: #24323d;
    font-size: 1rem;
    font-weight: 500;
}

.hero-premium-point i{
    color: #3c8f69;
    font-size: 16px;
    flex-shrink: 0;
}

.hero-premium-visual{
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-premium-card{
    width: 100%;
    max-width: 460px;
    background: #fff;
    border-radius: 28px;
    box-shadow: 0 25px 60px rgba(0,0,0,0.10);
    overflow: hidden;
    border: 1px solid rgba(0,0,0,0.04);
}

.hero-card-top{
    padding: 18px 22px 0 22px;
}

.hero-card-badge{
    display: inline-block;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    font-size: 13px;
    font-weight: 700;
}

.hero-card-body{
    padding: 22px;
}

.hero-card-icon{
    width: 64px;
    height: 64px;
    border-radius: 18px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin-bottom: 18px;
}

.hero-card-body h3{
    margin: 0 0 10px 0;
    font-size: 1.45rem;
    font-weight: 700;
    color: #1f2933;
}

.hero-card-body p{
    margin: 0;
    color: #5b6670;
    line-height: 1.7;
    font-size: 1rem;
}

.hero-demo-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    padding: 0 22px 22px 22px;
}

.hero-demo-card{
    min-height: 105px;
    border-radius: 18px;
    padding: 18px 16px;
    text-decoration: none !important;
    color: #fff !important;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: all .25s ease;
    box-shadow: 0 10px 24px rgba(0,0,0,0.08);
}

.hero-demo-card:hover{
    transform: translateY(-3px);
    box-shadow: 0 16px 30px rgba(0,0,0,0.12);
    color: #fff !important;
}

.hero-demo-name{
    font-size: 1.15rem;
    font-weight: 700;
    line-height: 1.2;
}

.hero-demo-type{
    font-size: .9rem;
    opacity: .92;
}

.hero-demo-yelho{
    background: linear-gradient(180deg, #ffab2f 0%, #ff9501 100%);
}

.hero-demo-pinky{
    background: linear-gradient(180deg, #df689d 0%, #d54d8a 100%);
}

.hero-demo-blue{
    background: linear-gradient(180deg, #46525f 0%, #323c48 100%);
}

.hero-demo-grey{
    background: linear-gradient(180deg, #4a4946 0%, #302f2d 100%);
}

@media (max-width: 991px){
    .hero-cashoo-premium{
        padding: 75px 0 60px 0;
    }

    .hero-premium-title{
        font-size: 2.6rem;
    }

    .hero-premium-content{
        margin-bottom: 40px;
    }
}

@media (max-width: 767px){
    .hero-cashoo-premium{
        padding: 60px 0 50px 0;
    }

    .hero-premium-title{
        font-size: 2rem;
        line-height: 1.15;
    }

    .hero-premium-text{
        font-size: 1rem;
        line-height: 1.7;
    }

    .hero-premium-actions{
        flex-direction: column;
        align-items: stretch;
    }

    .hero-premium-btn{
        width: 100%;
    }

    .hero-premium-card{
        max-width: 100%;
        border-radius: 22px;
    }

    .hero-demo-grid{
        grid-template-columns: 1fr;
    }
}
.trust-bar{
background:#f5f7f9;
padding:30px 0;
text-align:center;
}

.trust-items{
display:flex;
justify-content:center;
gap:40px;
flex-wrap:wrap;
font-size:16px;
color:#2f3a44;
}

.trust-item strong{
color:#3c8f69;
} 

  



/*section présentation cagnotte */
.cagnotte-modern-section{
    padding: 90px 0;
    background: linear-gradient(180deg, #f4f8f6 0%, #ffffff 100%);
}

.cagnotte-modern-heading{
    margin-bottom: 46px;
}

.cagnotte-kicker{
    display: inline-block;
    margin-bottom: 14px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.cagnotte-logo{
    display: block;
    max-width: 140px;
    height: auto;
    margin: 0 auto 18px auto;
}

.cagnotte-modern-heading h2{
    margin: 0 0 14px 0;
    font-size: 2.4rem;
    line-height: 1.15;
    font-weight: 800;
    color: #1f2933;
}

.cagnotte-modern-heading p{
    max-width: 760px;
    margin: 0 auto;
    font-size: 1.05rem;
    line-height: 1.8;
    color: #5b6670;
}

.cagnotte-feature-grid{
    margin-bottom: 30px;
}

.cagnotte-feature-card{
    height: 100%;
    background: #fff;
    border: 1px solid #edf1ef;
    border-radius: 22px;
    padding: 28px 24px;
    box-shadow: 0 10px 28px rgba(0,0,0,0.05);
    transition: all .25s ease;
    text-align: left;
}

.cagnotte-feature-card:hover{
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(0,0,0,0.08);
}

.cagnotte-feature-icon{
    width: 60px;
    height: 60px;
    border-radius: 18px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    margin-bottom: 18px;
}

.cagnotte-feature-card h3{
    margin: 0 0 10px 0;
    font-size: 1.28rem;
    font-weight: 700;
    color: #1f2933;
}

.cagnotte-feature-card p{
    margin: 0;
    font-size: 1rem;
    line-height: 1.7;
    color: #5b6670;
}

.cagnotte-main-block{
    margin-top: 10px;
    margin-bottom: 34px;
}

.cagnotte-visual-card{
    background: #fff;
    border-radius: 28px;
    padding: 28px;
    box-shadow: 0 18px 44px rgba(0,0,0,0.07);
    text-align: center;
}

.cagnotte-content-card{
    background: #fff;
    border-radius: 24px;
    padding: 30px;
    box-shadow: 0 18px 44px rgba(0,0,0,0.07);
    height: 100%;
}

.cagnotte-content-card h3{
    margin: 0 0 12px 0;
    font-size: 1.8rem;
    font-weight: 700;
    color: #1f2933;
}

.cagnotte-content-card p{
    color: #5b6670;
    line-height: 1.8;
    margin-bottom: 18px;
}

.cagnotte-check-list,
.cagnotte-compare-list{
    list-style: none;
    padding: 0;
    margin: 0;
}

.cagnotte-check-list li,
.cagnotte-compare-list li{
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 12px;
    line-height: 1.6;
    color: #2d3436;
}

.cagnotte-check-list li i{
    color: #3c8f69;
    margin-top: 4px;
    flex-shrink: 0;
}

.cagnotte-compare-box{
    margin-top: 24px;
    padding: 22px;
    background: #f8fbf9;
    border: 1px solid #e8efeb;
    border-radius: 18px;
}

.cagnotte-compare-box h4{
    margin: 0 0 10px 0;
    font-size: 1.2rem;
    font-weight: 700;
    color: #1f2933;
}

.cagnotte-compare-box p{
    margin-bottom: 14px;
}

.cagnotte-compare-list li i{
    color: #88939d;
    margin-top: 4px;
    flex-shrink: 0;
}

.cagnotte-compare-list li.is-good{
    color: #1f2933;
    font-weight: 600;
}

.cagnotte-compare-list li.is-good i{
    color: #3c8f69;
}

.cagnotte-info-card{
    height: 100%;
    background: #fff;
    border-radius: 22px;
    padding: 28px 24px;
    box-shadow: 0 14px 36px rgba(0,0,0,0.06);
}

.cagnotte-info-card h3{
    margin: 0 0 12px 0;
    font-size: 1.35rem;
    font-weight: 700;
    color: #1f2933;
}

.cagnotte-info-card p{
    margin-bottom: 18px;
    line-height: 1.8;
    color: #5b6670;
}

.cagnotte-final-cta{
    margin-top: 36px;
    padding: 38px 26px;
    border-radius: 26px;
    background: linear-gradient(180deg, #4aa57c 0%, #3c8f69 100%);
    color: #fff;
    box-shadow: 0 18px 44px rgba(60,143,105,0.18);
}

.cagnotte-final-cta h3{
    margin: 0 0 12px 0;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
}

.cagnotte-final-cta p{
    margin: 0 auto 20px auto;
    max-width: 620px;
    line-height: 1.8;
    color: rgba(255,255,255,0.95);
}

.cagnotte-cta-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 28px;
    border-radius: 14px;
    background: #fff;
    color: #3c8f69 !important;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: 0 10px 24px rgba(0,0,0,0.12);
    transition: all .25s ease;
}

.cagnotte-cta-btn:hover{
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(0,0,0,0.16);
}

.cagnotte-cta-note{
    margin-top: 14px !important;
    margin-bottom: 0 !important;
    font-size: .94rem;
    color: rgba(255,255,255,0.88) !important;
}
.cagnotte-check-list li,
.cagnotte-compare-list li{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin-bottom:12px;
    line-height:1.6;
    color:#2d3436;
}

.cagnotte-check-list li i,
.cagnotte-compare-list li i{
    flex-shrink:0;
    margin-top:4px;
}

.cagnotte-check-list li span,
.cagnotte-compare-list li span{
    display:block;
    flex:1;
    min-width:0;
}

@media (max-width: 991px){
    .cagnotte-modern-section{
        padding: 75px 0;
    }

    .cagnotte-modern-heading h2{
        font-size: 2rem;
    }
}

@media (max-width: 767px){
    .cagnotte-modern-section{
        padding: 60px 0;
    }

    .cagnotte-modern-heading h2{
        font-size: 1.75rem;
    }

    .cagnotte-feature-card,
    .cagnotte-content-card,
    .cagnotte-info-card{
        padding: 22px 18px;
        border-radius: 18px;
    }

    .cagnotte-visual-card{
        padding: 20px;
        border-radius: 20px;
    }

    .cagnotte-final-cta{
        padding: 28px 18px;
        border-radius: 20px;
    }

    .cagnotte-final-cta h3{
        font-size: 1.6rem;
    }
}




/*section tarif*/
.pricing-section-intro{
    background-color:#fafafa;
    padding-top:40px;
}

.pricing-section-intro .pricing-heading{
    text-align:center;
    max-width:760px;
    margin:0 auto;
}

.pricing-section-intro h2{
    font-size:2.2rem;
    font-weight:700;
    margin-bottom:15px;
}

.pricing-section-intro p{
    font-size:1.05rem;
    color:#6c757d;
    margin-bottom:0;
}

.pricing-section{
    background-color:#fafafa;
    padding:20px 0 90px 0;
}

.pricing-card-wrap{
    display:flex;
    justify-content:center;
}

.pricing-card-cashoo{
    position:relative;
    width:100%;
    max-width:520px;
    background:linear-gradient(180deg, #4aa57c 0%, #3c8f69 100%);
    color:#fff;
    border-radius:22px;
    padding:38px 34px;
    box-shadow:0 18px 50px rgba(0,0,0,0.12);
    overflow:hidden;
}

.pricing-badge{
    position:absolute;
    top:20px;
    right:20px;
    background:rgba(255,255,255,0.18);
    color:#fff;
    padding:7px 14px;
    border-radius:999px;
    font-size:13px;
    font-weight:700;
    letter-spacing:.2px;
}

.pricing-card-header{
    text-align:center;
    margin-bottom:28px;
}

.pricing-card-header h3{
    font-size:2rem;
    font-weight:700;
    margin-bottom:10px;
    color:#fff;
}

.pricing-card-subtitle{
    font-size:1rem;
    line-height:1.6;
    opacity:.95;
    margin-bottom:22px;
}

.pricing-price{
    display:flex;
    align-items:flex-start;
    justify-content:center;
    gap:6px;
    margin-bottom:10px;
    line-height:1;
}

.pricing-price .amount{
    font-size:4.4rem;
    font-weight:800;
}

.pricing-price .currency{
    font-size:1.6rem;
    font-weight:700;
    margin-top:10px;
}

.pricing-price-caption{
    font-size:.98rem;
    opacity:.95;
    margin-bottom:18px;
}

.pricing-note{
    display:inline-block;
    padding:9px 15px;
    border-radius:12px;
    background:rgba(255,255,255,0.16);
    font-size:.95rem;
    font-weight:600;
}

.pricing-divider{
    height:1px;
    background:rgba(255,255,255,0.22);
    margin:26px 0 24px 0;
}

.pricing-features{
    list-style:none;
    padding:0;
    margin:0;
}

.pricing-features li{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin-bottom:14px;
    font-size:1rem;
    line-height:1.5;
}

.pricing-features li i{
    margin-top:4px;
    flex-shrink:0;
    color:#ffffff;
}

.pricing-footer{
    text-align:center;
    margin-top:30px;
}

.pricing-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:54px;
    padding:0 28px;
    border-radius:14px;
    background:#fff;
    color:#3c8f69 !important;
    font-size:1rem;
    font-weight:700;
    text-decoration:none;
    box-shadow:0 8px 20px rgba(0,0,0,0.10);
    transition:all .25s ease;
}

.pricing-cta:hover{
    transform:translateY(-2px);
    box-shadow:0 12px 28px rgba(0,0,0,0.16);
    color:#3c8f69 !important;
}

.pricing-footer-small{
    margin-top:14px;
    margin-bottom:0;
    font-size:.92rem;
    opacity:.95;
    line-height:1.5;
}

.pricing-reassurance{
    margin-top:18px;
    font-size:.9rem;
    opacity:.9;
}

@media (max-width: 767px){
    .pricing-section-intro h2{
        font-size:1.8rem;
    }

    .pricing-card-cashoo{
        padding:32px 22px;
        border-radius:18px;
    }

    .pricing-price .amount{
        font-size:3.5rem;
    }
}




/*section avis clients */
.testimonials-grid-section{
    padding: 80px 0;
    background: #fafafa;
}

.testimonials-grid-heading{
    margin-bottom: 45px;
}

.testimonials-grid-logo{
    max-width: 140px;
    height: auto;
    margin-bottom: 18px;
}

.testimonials-grid-heading h2{
    font-size: 2.1rem;
    font-weight: 700;
    color: #212529;
    margin-bottom: 12px;
}

.testimonials-grid-heading p{
    max-width: 680px;
    margin: 0 auto;
    color: #6c757d;
    line-height: 1.7;
    font-size: 1.02rem;
}

.testimonials-grid-row{
    align-items: stretch;
}

.testimonial-grid-card{
    background: #ffffff;
    border: 1px solid #eef1f3;
    border-radius: 22px;
    padding: 28px 24px;
    height: 100%;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    transition: all .25s ease;
    display: flex;
    flex-direction: column;
}

.testimonial-grid-card:hover{
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(0,0,0,0.08);
}

.testimonial-grid-quote{
    width: 54px;
    height: 54px;
    border-radius: 16px;
    background: rgba(60, 143, 105, 0.10);
    color: #3c8f69;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 21px;
    margin-bottom: 20px;
}

.testimonial-grid-content{
    flex: 1;
}

.testimonial-grid-message{
    margin: 0;
    color: #2d3436;
    font-size: 1.02rem;
    line-height: 1.8;
    font-style: italic;
}

.testimonial-grid-footer{
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid #f1f3f5;
}

.testimonial-grid-author{
    display: flex;
    align-items: center;
    gap: 14px;
}

.testimonial-grid-avatar{
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #3c8f69;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 700;
    flex-shrink: 0;
}

.testimonial-grid-author-info h5{
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: #212529;
}

.testimonial-grid-author-info span{
    display: block;
    margin-top: 2px;
    font-size: .9rem;
    color: #6c757d;
}

@media (max-width: 767px){
    .testimonials-grid-section{
        padding: 60px 0;
    }

    .testimonials-grid-heading h2{
        font-size: 1.7rem;
    }

    .testimonial-grid-card{
        padding: 22px 18px;
        border-radius: 18px;
    }

    .testimonial-grid-message{
        font-size: .98rem;
        line-height: 1.7;
    }
}




/* section contact */
.contact-modern-section{
    background: linear-gradient(180deg, #4aa57c 0%, #3c8f69 100%);
    padding: 85px 0;
    position: relative;
}

.contact-modern-content{
    color: #fff;
    padding-right: 25px;
}

.contact-kicker{
    display: inline-block;
    margin-bottom: 14px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,0.16);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.contact-modern-content h2{
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 18px;
    color: #fff;
}

.contact-modern-text{
    font-size: 1.02rem;
    line-height: 1.8;
    opacity: .96;
    margin-bottom: 28px;
    max-width: 500px;
}

.contact-modern-points{
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 30px;
}

.contact-point{
    display: flex;
    align-items: center;
    gap: 14px;
}

.contact-point-icon{
    width: 44px;
    height: 44px;
    border-radius: 14px;
    background: rgba(255,255,255,0.14);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.contact-point-text{
    font-weight: 600;
    color: #fff;
}

.contact-phone-box{
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px;
    border-radius: 18px;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.14);
    max-width: 420px;
}

.contact-phone-icon{
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: #fff;
    color: #3c8f69;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.contact-phone-label{
    font-size: .92rem;
    opacity: .9;
    color: #fff;
    margin-bottom: 3px;
}

.contact-phone-link{
    color: #fff !important;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
}

.contact-form-card{
    background: #fff;
    border-radius: 24px;
    padding: 30px;
    box-shadow: 0 18px 50px rgba(0,0,0,0.10);
}

.contact-modern-form{
    position: relative;
}

.contact-modern-form .contact-label{
    display: block;
    margin-bottom: 8px;
    font-size: .95rem;
    font-weight: 600;
    color: #212529;
}

.contact-input,
.contact-textarea{
    width: 100%;
    border: 1px solid #e9ecef;
    background: #fff;
    border-radius: 14px;
    padding: 14px 16px;
    font-size: 1rem;
    color: #212529;
    transition: all .2s ease;
    box-shadow: none;
}

.contact-input:focus,
.contact-textarea:focus{
    outline: none;
    border-color: #3c8f69;
    box-shadow: 0 0 0 4px rgba(60,143,105,0.12);
}

.contact-textarea{
    resize: vertical;
    min-height: 160px;
}

.contact-captcha-question{
    width: 100%;
    margin-bottom: 10px;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(60,143,105,0.08);
    border: 1px solid rgba(60,143,105,0.14);
    color: #2d3436;
    font-size: .96rem;
    font-weight: 600;
    line-height: 1.5;
}

.contact-captcha{
    width: 100%;
    font-size: .95rem;
}

.contact-help{
    display: block;
    margin-top: 8px;
    color: #6c757d;
    font-size: .88rem;
}

.contact-submit-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 54px;
    padding: 0 24px;
    border: none;
    border-radius: 14px;
    background: #3c8f69;
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
    box-shadow: 0 10px 24px rgba(60,143,105,0.25);
    transition: all .25s ease;
    cursor: pointer;
}

.contact-submit-btn:hover{
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(60,143,105,0.30);
    background: #347e5d;
}

.contact-hp-wrap{
    position: absolute !important;
    left: -9999px !important;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

@media (max-width: 991px){
    .contact-modern-content{
        padding-right: 0;
        margin-bottom: 10px;
    }
}

@media (max-width: 767px){
    .contact-modern-section{
        padding: 60px 0;
    }

    .contact-modern-content h2{
        font-size: 1.8rem;
    }

    .contact-form-card{
        padding: 22px 18px;
        border-radius: 18px;
    }

    .contact-phone-box{
        max-width: 100%;
    }

    .contact-captcha-question{
        font-size: .92rem;
    }
}




/* section 3 articles blog */
.blog-home-section{
    padding: 85px 0;
    background: #fff;
}

.blog-home-heading{
    margin-bottom: 42px;
}

.blog-home-kicker{
    display: inline-block;
    margin-bottom: 14px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.blog-home-heading h2{
    margin: 0 0 14px 0;
    font-size: 2.3rem;
    line-height: 1.15;
    font-weight: 800;
    color: #1f2933;
}

.blog-home-heading p{
    max-width: 760px;
    margin: 0 auto;
    font-size: 1.04rem;
    line-height: 1.8;
    color: #5b6670;
}

.blog-home-grid{
    align-items: stretch;
    margin-bottom: 14px;
}

.blog-home-card{
    height: 100%;
    background: #fff;
    border: 1px solid #edf1ef;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(0,0,0,0.05);
    transition: all .25s ease;
    display: flex;
    flex-direction: column;
}

.blog-home-card:hover{
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(0,0,0,0.08);
}

.blog-home-image-link{
    display: block;
    text-decoration: none;
}

.blog-home-image-wrap{
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    background: #eef3f0;
}

.blog-home-image{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .35s ease;
}

.blog-home-card:hover .blog-home-image{
    transform: scale(1.04);
}

.blog-home-card-body{
    padding: 22px 22px 24px 22px;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.blog-home-card-title{
    margin: 0 0 14px 0;
    font-size: 1.28rem;
    line-height: 1.35;
    font-weight: 700;
}

.blog-home-card-title a{
    color: #1f2933;
    text-decoration: none;
}

.blog-home-card-title a:hover{
    color: #3c8f69;
}

.blog-home-excerpt{
    color: #5b6670;
    font-size: .98rem;
    line-height: 1.75;
    margin-bottom: 20px;
    flex: 1;
}

.blog-home-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 20px;
    border-radius: 12px;
    background: #3c8f69;
    color: #fff !important;
    text-decoration: none;
    font-size: .96rem;
    font-weight: 700;
    box-shadow: 0 10px 24px rgba(60,143,105,0.20);
    transition: all .25s ease;
    align-self: flex-start;
}

.blog-home-btn:hover{
    background: #347e5d;
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(60,143,105,0.28);
}

.blog-home-footer{
    margin-top: 10px;
}

.blog-home-link-all{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 0 22px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid rgba(60,143,105,0.18);
    color: #3c8f69 !important;
    text-decoration: none;
    font-weight: 700;
    transition: all .25s ease;
    box-shadow: 0 8px 20px rgba(0,0,0,0.04);
}

.blog-home-link-all:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.08);
}

@media (max-width: 991px){
    .blog-home-section{
        padding: 70px 0;
    }

    .blog-home-heading h2{
        font-size: 2rem;
    }
}

@media (max-width: 767px){
    .blog-home-section{
        padding: 60px 0;
    }

    .blog-home-heading h2{
        font-size: 1.75rem;
    }

    .blog-home-card{
        border-radius: 18px;
    }

    .blog-home-card-body{
        padding: 18px 18px 20px 18px;
    }

    .blog-home-btn,
    .blog-home-link-all{
        width: 100%;
    }
}



/* section article blog */
.blog-article-section{
    padding: 120px 0 80px 0;
    background: linear-gradient(180deg, #f8fbf9 0%, #ffffff 100%);
}

.blog-article-hero{
    margin-bottom: 30px;
}

.blog-article-kicker{
    display: inline-block;
    margin-bottom: 14px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(60,143,105,0.10);
    color: #3c8f69;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.blog-article-title{
    margin: 0;
    font-size: 2.8rem;
    line-height: 1.15;
    font-weight: 800;
    color: #1f2933;
}

.blog-article-cover-card{
    overflow: hidden;
    border-radius: 26px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.08);
    background: #fff;
    margin-bottom: 34px;
}

.blog-article-cover-img{
    width: 100%;
    display: block;
    object-fit: cover;
    max-height: 520px;
}

.blog-article-content-card{
    background: #fff;
    border: 1px solid #edf1ef;
    border-radius: 24px;
    padding: 36px 34px;
    box-shadow: 0 14px 36px rgba(0,0,0,0.06);
}

.blog-article-content{
    color: #35424c;
    font-size: 1.05rem;
    line-height: 1.9;
}

.blog-article-content h2,
.blog-article-content h3,
.blog-article-content h4{
    color: #1f2933;
    font-weight: 700;
    line-height: 1.3;
    margin-top: 32px;
    margin-bottom: 14px;
}

.blog-article-content h2{
    font-size: 1.9rem;
}

.blog-article-content h3{
    font-size: 1.5rem;
}

.blog-article-content h4{
    font-size: 1.2rem;
}

.blog-article-content p{
    margin-bottom: 18px;
}

.blog-article-content ul,
.blog-article-content ol{
    margin-bottom: 22px;
    padding-left: 1.2rem;
}

.blog-article-content li{
    margin-bottom: 10px;
}

.blog-article-content a{
    color: #3c8f69;
    text-decoration: underline;
}

.blog-article-content img{
    max-width: 100%;
    height: auto;
    border-radius: 18px;
    margin: 18px 0;
}

.blog-article-content blockquote{
    margin: 24px 0;
    padding: 18px 20px;
    border-left: 4px solid #3c8f69;
    background: rgba(60,143,105,0.06);
    border-radius: 0 14px 14px 0;
    color: #2d3436;
}

.blog-article-cta{
    margin-top: 36px;
    padding: 28px 24px;
    border-radius: 22px;
    background: linear-gradient(180deg, #4aa57c 0%, #3c8f69 100%);
    color: #fff;
    text-align: center;
}

.blog-article-cta h3{
    margin: 0 0 10px 0;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
}

.blog-article-cta p{
    margin: 0 auto 18px auto;
    max-width: 620px;
    color: rgba(255,255,255,0.94);
    line-height: 1.8;
}

.blog-article-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 26px;
    border-radius: 14px;
    background: #fff;
    color: #3c8f69 !important;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: 0 10px 24px rgba(0,0,0,0.12);
    transition: all .25s ease;
}

.blog-article-btn:hover{
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(0,0,0,0.16);
}

@media (max-width: 991px){
    .blog-article-section{
       padding: 100px 0 70px 0;
    }

    .blog-article-title{
        font-size: 2.2rem;
    }

    .blog-article-content-card{
        padding: 28px 24px;
    }
}

@media (max-width: 767px){
    .blog-article-section{
        padding: 85px 0 60px 0;
    }

    .blog-article-title{
        font-size: 1.8rem;
    }

    .blog-article-cover-card{
        border-radius: 18px;
        margin-bottom: 24px;
    }

    .blog-article-content-card{
        padding: 22px 18px;
        border-radius: 18px;
    }

    .blog-article-content{
        font-size: 1rem;
        line-height: 1.8;
    }

    .blog-article-content h2{
        font-size: 1.5rem;
    }

    .blog-article-content h3{
        font-size: 1.3rem;
    }

    .blog-article-cta{
        padding: 24px 18px;
        border-radius: 18px;
    }

    .blog-article-btn{
        width: 100%;
    }
}



/* section footer */
.site-footer-modern{
    background: #131b22;
    color: #d6dde3;
    margin-top: 0;
}

.site-footer-main{
    padding: 80px 0 40px 0;
}

.site-footer-block{
    height: 100%;
}

.site-footer-kicker{
    display: inline-block;
    margin-bottom: 12px;
    padding: 7px 14px;
    border-radius: 999px;
    background: #3c8f69;
    color: #ffffff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .2px;
}

.site-footer-block h3{
    margin: 0 0 14px 0;
    color: #c8d2d9;
    font-size: 1.45rem;
    font-weight: 700;
}

.site-footer-block p{
    margin: 0 0 20px 0;
    color: #5b6670;
    line-height: 1.8;
    font-size: .98rem;
}

.site-footer-logo-link{
    display: inline-block;
    text-decoration: none;
}

.site-footer-logo{
    max-width: 210px;
    height: auto;
    display: block;
}

.site-footer-logo-stripe{
    max-width: 220px;
    border-radius: 12px;
}

.site-footer-links{
    list-style: none;
    padding: 0;
    margin: 0;
}

.site-footer-links li{
    margin-bottom: 12px;
}

.site-footer-links a{
    display: inline-flex;
    align-items: flex-start;
    gap: 10px;
    color: rgba(255,255,255,0.82);
    text-decoration: none;
    transition: all .2s ease;
    line-height: 1.6;
}

.site-footer-links a:hover{
    color: #ffffff;
    transform: translateX(2px);
}

.site-footer-links i{
    color: #3c8f69;
    margin-top: 4px;
    flex-shrink: 0;
}

.site-footer-bottom{
    border-top: 1px solid rgba(255,255,255,0.08);
    padding: 18px 0;
}

.site-footer-bottom-inner{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.site-footer-copy{
    color: #5b6670;
    font-size: .95rem;
    line-height: 1.6;
}

.site-footer-copy a{
    color: #ffffff;
    text-decoration: none;
    font-weight: 600;
}

.site-footer-top{
    width: 46px;
    height: 46px;
    border-radius: 14px;
    background: #3c8f69;
    color: #ffffff !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: all .25s ease;
    flex-shrink: 0;
}

.site-footer-top:hover{
    background: #3c8f69;
    transform: translateY(-2px);
}

@media (max-width: 991px){
    .site-footer-main{
        padding: 65px 0 30px 0;
    }
}

@media (max-width: 767px){
    .site-footer-main{
        padding: 55px 0 25px 0;
    }

    .site-footer-block h3{
        font-size: 1.25rem;
    }

    .site-footer-bottom-inner{
        flex-direction: column-reverse;
        align-items: flex-start;
    }

    .site-footer-top{
        align-self: flex-end;
    }

    .site-footer-logo,
    .site-footer-logo-stripe{
        max-width: 190px;
    }
}




/* formulaire création de box */ 
.boxStepCard{
    background: #fff;
    border-radius: 22px;
    padding: 40px 32px;
    box-shadow: 0 12px 35px rgba(0,0,0,0.06);
    border: 1px solid rgba(0,0,0,0.05);
}

.boxStepBadge{
    display: inline-block;
    padding: 8px 16px;
    border-radius: 999px;
    background: rgba(0,0,0,0.05);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .4px;
    text-transform: uppercase;
}

.boxStepTitle{
    font-size: 30px;
    font-weight: 700;
    color: #1f1f1f;
}

.boxStepText{
    font-size: 17px;
    color: #6b7280;
    max-width: 620px;
    margin: 0 auto;
}

.boxStepUrlPreview{
    background: linear-gradient(135deg, #fff8ef 0%, #fff 100%);
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 18px;
    padding: 20px;
    max-width: 460px;
    margin: 0 auto;
}

.boxStepUrlLabel{
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: #a16207;
    margin-bottom: 8px;
}

.boxStepUrl{
    font-size: 24px;
    font-weight: 700;
    color: #222;
    word-break: break-word;
}

.boxStepRules{
    background: #f8fafc;
    border-radius: 16px;
    padding: 20px;
    max-width: 560px;
    margin: 0 auto;
    color: #475569;
    font-size: 15px;
}

.boxStepMiniBadge{
    display: inline-block;
    padding: 6px 12px;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(0,0,0,0.06);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
}

.boxStepWarning{
    font-size: 15px;
    font-weight: 600;
    color: #b91c1c;
}

.boxInputLabel{
    display: block;
    font-weight: 700;
    margin-bottom: 10px;
    color: #1f1f1f;
}

.boxInputWrap{
    position: relative;
}

.boxInputWrap .form-control{
    height: 58px;
    border-radius: 16px;
    padding-left: 92px;
    padding-right: 110px;
    font-size: 16px;
    border: 1px solid #dbe1ea;
    box-shadow: none;
}

.boxInputWrap .form-control:focus{
    border-color: #c7ced9;
    box-shadow: 0 0 0 4px rgba(0,0,0,0.04);
}

.boxInputPrefix,
.boxInputSuffix{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
    color: #6b7280;
    z-index: 2;
    pointer-events: none;
}

.boxInputPrefix{
    left: 16px;
}

.boxInputSuffix{
    right: 16px;
}

.boxInputHelp{
    display: block;
    margin-top: 10px;
    font-size: 14px;
    color: #6b7280;
}

@media (max-width: 767.98px){
    .boxStepCard{
        padding: 28px 20px;
        border-radius: 18px;
    }

    .boxStepTitle{
        font-size: 24px;
    }

    .boxStepText{
        font-size: 15px;
    }

    .boxStepUrl{
        font-size: 20px;
    }

    .boxInputWrap .form-control{
        padding-left: 78px;
        padding-right: 96px;
        font-size: 15px;
    }

    .boxInputPrefix,
    .boxInputSuffix{
        font-size: 13px;
    }
}
.themePreviewGrid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:16px;
}

.themePreviewCard{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    min-height:120px;
    padding:20px 14px;
    border-radius:18px;
    background:#fff;
    border:1px solid rgba(0,0,0,0.06);
    box-shadow:0 10px 25px rgba(0,0,0,0.05);
    text-decoration:none;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.themePreviewCard:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 35px rgba(0,0,0,0.08);
    border-color:rgba(0,0,0,0.12);
    text-decoration:none;
}

.themePreviewTag{
    display:inline-block;
    padding:6px 12px;
    border-radius:999px;
    background:rgba(0,0,0,0.05);
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.4px;
    color:#6b7280;
    margin-bottom:12px;
}

.themePreviewName{
    font-size:20px;
    font-weight:700;
    color:#1f1f1f;
    line-height:1.2;
    margin-bottom:8px;
}

.themePreviewDesc{
    font-size:14px;
    color:#6b7280;
    line-height:1.4;
}

.selectWrap{
    position:relative;
}

.selectWrap .form-control,
.selectWrap select{
    height:58px;
    border-radius:16px;
    border:1px solid #dbe1ea;
    padding:0 18px;
    font-size:16px;
    box-shadow:none;
    background:#fff;
}

.selectWrap .form-control:focus,
.selectWrap select:focus{
    border-color:#c7ced9;
    box-shadow:0 0 0 4px rgba(0,0,0,0.04);
    outline:none;
}

@media (max-width: 767.98px){
    .themePreviewGrid{
        grid-template-columns:1fr;
    }

    .themePreviewCard{
        min-height:140px;
        padding:20px 16px;
    }

    .themePreviewName{
        font-size:22px;
    }
}
@media (max-width: 991px){
    .themePreviewGrid{
        grid-template-columns:repeat(2, 1fr);
    }
}

@media (max-width: 575px){
    .themePreviewGrid{
        grid-template-columns:1fr;
    }
}


/*mot de passe */
.privacyChoiceWrap{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:18px;
    max-width:820px;
    margin:0 auto;
}

.privacyChoiceCard{
    position:relative;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    min-height:180px;
    padding:28px 22px;
    border-radius:20px;
    background:#fff;
    border:1px solid rgba(0,0,0,0.06);
    box-shadow:0 10px 25px rgba(0,0,0,0.05);
    cursor:pointer;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    text-decoration:none;
}

.privacyChoiceCard:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 35px rgba(0,0,0,0.08);
    border-color:rgba(0,0,0,0.12);
}

.privacyChoiceCard input[type="radio"]{
    position:absolute;
    top:18px;
    left:18px;
    transform:scale(1.15);
}

.privacyChoiceBadge{
    display:inline-block;
    padding:6px 12px;
    border-radius:999px;
    background:rgba(0,0,0,0.05);
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.4px;
    color:#6b7280;
    margin-bottom:14px;
}

.privacyChoiceTitle{
    display:block;
    font-size:22px;
    font-weight:700;
    color:#1f1f1f;
    line-height:1.25;
    margin-bottom:10px;
}

.privacyChoiceText{
    display:block;
    font-size:14px;
    color:#6b7280;
    line-height:1.5;
    max-width:260px;
}

.boxPasswordWrap{
    position:relative;
}

.boxPasswordWrap .form-control{
    height:58px;
    border-radius:16px;
    border:1px solid #dbe1ea;
    padding:0 52px 0 18px;
    font-size:16px;
    box-shadow:none;
    background:#fff;
}

.boxPasswordWrap .form-control:focus{
    border-color:#c7ced9;
    box-shadow:0 0 0 4px rgba(0,0,0,0.04);
    outline:none;
}

#togglePasswordIcon1{
    top:50%;
    right:18px;
    transform:translateY(-50%);
    cursor:pointer;
    color:#6b7280;
    font-size:16px;
    z-index:3;
}

@media (max-width: 767.98px){
    .privacyChoiceWrap{
        grid-template-columns:1fr;
    }

    .privacyChoiceCard{
        min-height:150px;
        padding:24px 18px;
    }

    .privacyChoiceTitle{
        font-size:20px;
    }
}


/*durée en ligne */
.durationChoiceGrid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:18px;
}

.durationChoiceCard{
    position:relative;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    min-height:180px;
    padding:26px 20px;
    border-radius:20px;
    background:#fff;
    border:1px solid rgba(0,0,0,0.06);
    box-shadow:0 10px 25px rgba(0,0,0,0.05);
    cursor:pointer;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.durationChoiceCard:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 35px rgba(0,0,0,0.08);
    border-color:rgba(0,0,0,0.12);
}

.durationChoiceCard input[type="radio"]{
    position:absolute;
    top:16px;
    left:16px;
    transform:scale(1.15);
}

.durationChoiceValue{
    display:block;
    font-size:34px;
    font-weight:700;
    color:#1f1f1f;
    line-height:1;
    margin-bottom:6px;
}

.durationChoiceUnit{
    display:block;
    font-size:15px;
    font-weight:600;
    color:#6b7280;
    margin-bottom:12px;
    text-transform:uppercase;
    letter-spacing:.4px;
}

.durationChoiceText{
    display:block;
    font-size:14px;
    line-height:1.5;
    color:#6b7280;
    max-width:220px;
}

@media (max-width: 991px){
    .durationChoiceGrid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px){
    .durationChoiceGrid{
        grid-template-columns:1fr;
    }

    .durationChoiceCard{
        min-height:150px;
        padding:22px 18px;
    }

    .durationChoiceValue{
        font-size:30px;
    }
}