/*section 1*/
p{
    font-size: 20px;
}
.hero-section {
    margin-top: 60px;
    padding   : 4rem 2rem;
}

.btn-purple {
    background-color: #5b5bf0;
    color           : white;
    font-weight     : bold;
}

.btn-purple:hover {
    background-color: #4a4ad1;
}

.hero-section h1 {
    font-size  : 3rem;
    font-weight: 700;
}

.hero-section .col-md-5 p {
    padding-right: 80px;
    font-size: 20px;
}

.hero-section {
    padding-left : 30px;
    padding-right: 30px;
}

/*section 2*/

.features-section {
    margin-top: 50px;
}

.features-section .comparison-section p.text-muted {
    margin-top: 30px;
    font-size: 20px;
}

.features-section .comparison-section h2 {
    font-size    : 45px;
    margin-bottom: 30px;
}

.features-section .comparison-section .row {
    margin-top: 50px;
}

.features-section .comparison-section {
    padding   : 4rem 1rem;
    text-align: center;
}
.comparison-list li .text{
    display: inline-block;
}
.features-section .comparison-card {
    border-radius: 15px;
    padding      : 0.7rem;
}

.features-section .old-method {
    background-color: #f5f7fb;
    border          : 1px solid #dee2e6;
}

.features-section .neatik-method {
    background: linear-gradient(135deg, #8a5cf5, #5b5bf0);
    color     : white;
}

.features-section .neatik-method .card-body {
    background   : white;
    border-radius: 10px;
    color        : #000;
    padding      : 1rem;
    margin-top   : 1rem;
}

.features-section .btn-dark-gradient {
    background   : black;
    color        : white;
    font-weight  : bold;
    width        : 100%;
    border-radius: 8px;
    margin-top   : 1rem;
}

.features-section .comparison-title {
    font-size    : 1.2rem;
    font-weight  : bold;
    margin-bottom: 1.5rem;
}

.features-section .comparison-list li {
    margin-top   : 5px;
    margin-bottom: 5px;
}

.features-section .comparison-list.old-method-list {
    background-color: white;
    padding         : 1rem;
    border-radius   : 20px;
}

.features-section .comparison-list li img{
    width: 25px;
    border-radius: 50px;
    margin-right: 7px;
    display: inline-block;
    margin-top: -2px;
}
.features-section .comparison-list {
    text-align    : left;
    list-style    : none;
    padding-left  : 0;
    padding-bottom: 0;
    margin-bottom : 0;
}

.features-section .comparison-list li::before {
    content     : "";
    margin-right: 8px;
    color       : #5b5bf0;
}

.features-section .old-method .comparison-list li::before {
    content: "";
    color  : #6c757d;
}

.features-section .subtitle {
    font-size     : 0.85rem;
    margin-bottom : 20px;
    letter-spacing: 1px;
    font-weight   : bold;
    color: #5b5bf0;
}

.ai-section .subtitle{
    color: #5b5bf0;
}


/*section 3*/

.ai-section {
    padding   : 8rem 50px;
    text-align: center;
}

.ai-section .row .card .card-body {
    text-align: left;
    padding   : 0;

}

.ai-section .row .card .card-body .card-text {
    font-size: 20px;
}

.ai-section .row .card .card-body .card-title {
    margin-top   : 20px;
    margin-bottom: 20px;
    font-size    : 25px;
    font-weight  : 400 !important;
}

.ai-section .row .card {
    border-radius: 20px;
    padding      : 1rem;
    background   : white;
    border       : 1px solid #dee2e6;
    transition   : box-shadow 0.2s;

}
.ai-section.app-avance .row .card {
    display: block;
    text-align: center;
height: 400px;
}

.ai-section .row {
    margin-top: 50px;
}

.ai-section h2 {
    font-size: 45px;
}

.ai-section p.text-muted {
    margin-top: 30px;
    font-size: 20px;
}

.subtitle {
    font-size     : 0.85rem;
    letter-spacing: 1px;
    font-weight   : bold;
}

.card img {
    max-height: 300px;
    object-fit: cover;
    border-radius: 30px;
}
.ai-section.app-avance .card .image {
height: 100px;
    display: table;
    padding-top: 20px;
}
.ai-section.app-avance .card .image img {
    height: 60px;
    object-fit: contain;
    border-radius: 20px;
}

/*section 4*/


.section-prix {
    padding   : 8rem 50px;
    text-align: center;
}

.section-prix h2 {
    font-size: 45px;
}

.section-prix p.text-muted {
    margin-top: 30px;
    font-size: 20px;
}

.section-prix p.text-muted.description-prix {
    font-size: 20px;
}

.section-prix .subtitle {
    font-size     : 0.85rem;
    text-transform: uppercase;
    color         : #5b5bf0;
    letter-spacing: 1px;
    font-weight   : bold;
}

.section-prix h5 {
    font-size  : 1.8em;
    font-weight: 600;
}

.section-prix .badge-custom {
    font-size       : 0.7rem;
    background-color: #e5e7f8;
    color           : #5b5bf0;
    font-weight     : 600;
    padding         : 0.2rem 0.5rem;
    border-radius   : 0.5rem;
}

.section-prix .divider {
    border-left: 1px solid #ccc;
    margin-left: 50%;
}

.section-prix .btn-purple {
    background-color: #5b5bf0;
    color           : white;
    font-weight     : 500;
}

.section-prix .btn-purple:hover {
    background-color: #4a4ae0;
}



/*setion 5*/
.section-spacing {
    padding: 8rem 50px;
}

.section-spacing h4 {
    font-size  : 2.2em;
    font-weight: 600;
}

.section-spacing .badge-custom {
    font-size       : 0.7rem;
    background-color: #e5e7f8;
    color           : #5b5bf0;
    font-weight     : 600;
    padding         : 0.2rem 0.5rem;
    border-radius   : 0.5rem;
}

.section-spacing .btn-purple {
    background-color: #5b5bf0;
    color           : white;
    font-weight     : 500;
}

.section-spacing .btn-purple:hover {
    background-color: #4a4ae0;
}

.section-spacing .section-spacing {
    padding: 4rem 1rem;
}

.section-spacing .img-mockup {
    max-width    : 100%;
    border-radius: 1rem;
    /* box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1);*/
}


/*section 6*/
.section-advantages {
    padding: 10rem 50px;
}

.section-advantages .advantage-card {
    border          : 1px solid #e1e1f0;
    border-radius   : 2rem;
    padding         : 1.4rem;
    height          : 100%;
    transition      : all 0.3s ease-in-out;
    background-color: #fff;
}

.section-advantages .advantage-card:hover {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.05);
}

.section-advantages .advantage-icon img {
    margin-bottom: 15px;
    width        : 60px;
}

.section-advantages .advantage-title {
    font-weight: 600;
    font-size  : 20px;
}

.section-advantages .advantage-text {
    font-size: 16px;
    color    : #555;
}

/*section 7*/
.section-eshop {
    margin-top: 70px;
    padding   : 10rem 50px;
}

.section-eshop .custom-img {
    border-radius: 1rem;
    width    : 100%;
    height       : auto;
}

.section-eshop .section-title {
    font-weight: 600;
    font-size  : 2.4rem;
}

.section-eshop .section-text {
    font-size: 20px;
    color    : #444;
}

.section-eshop .tag {
    font-size    : 0.7rem;
    font-weight  : 600;
    color        : #5B50E8;
    background   : #f0f0ff;
    border-radius: 0.4rem;
    padding      : 2px 6px;
    display      : inline-block;
    margin-bottom: 0.5rem;
}

.section-eshop .btn-purple {
    background-color: #6f42c1;
    color           : white;
    font-weight     : 500;
}

.section-eshop .btn-purple:hover {
    background-color: #5b34a7;
}

/*section 8*/
.highlight-section {
    margin-top      : 50px;
    background-color: #f1f3fc;
}

.highlight-section .container {
    padding: 100px 150px;
}

.highlight-section .container .highlight-text {
    padding-right: 80px;
}

.highlight-text h3 {
    font-weight: bold;
    font-size  : 2.4em;
}

.highlight-text span {
    color      : #4f46e5;
    /* Bleu foncé pour le mot "toujours complet" */
    font-weight: bold;
}

.highlight-text p {
    color    : #333;
    font-size: 0.95rem;
}

.highlight-img {
    border-radius: 0.75rem;
    max-width    : 100%;
    height       : auto;
    width        : 100%;
}

.btn-link-custom {
    font-size      : 0.9rem;
    color          : #4f46e5;
    text-decoration: none;
    font-weight    : 500;
}

.btn-link-custom:hover {
    text-decoration: underline;
}

.col-md-6.order-md-1.order-2{
    padding-right: 40px;
}
.col-md-6.simplifiez-gestion{
    padding-left: 60px;
}

@media (max-width: 600px) {
    body {
        overflow-x: hidden !important;
    }
    p{
        font-size: 18px;
    }
    .hero-section h1{
        font-size: 45px;
        text-align: center;
    }
    .features-section .comparison-section h2{
        font-size: 30px;
    }
    .ai-section h2{
        font-size: 30px;
    }
    .section-prix h2{
        font-size: 30px;
    }
    .ai-section .subtitle{
        color: #5b5bf0;
        font-size: 15px;
    }
    .section-prix .subtitle{
        color: #5b5bf0;
        font-size: 15px;
    }
    .features-section .subtitle{
        color: #5b5bf0;
        font-size: 15px;
    }
    .hero-section{
       margin-top: -60px;
        padding-left: 20px;
        padding-right: 20px;
    }
    .hero-section {
        text-align: center;
    }
    .hero-section a{
        margin-bottom: 50px;
    }
    .hero-section .col-md-5 p {
        padding-right: 0;
        text-align   : center;
    }
    .comparison-list li .text{
        display: inline-block;
        width: 80%;
        line-height: 1.2;
    }
    .features-section .comparison-list li img{
        display: inline-block;
        vertical-align: top;
        margin-top: 2px;
    }
    .ai-section,
    .section-prix,
    .section-spacing,
    .section-advantages,
    .section-eshop{
        padding: 4rem 20px;
        text-align: center;
    }
    .highlight-section {
        padding: 4rem 20px;
        text-align: left;
    }
    .features-section .comparison-list li{
        margin-bottom: 20px;
    }
    .section-spacing,
    .section-eshop {
        padding   : 4rem 20px;
        text-align: left;
    }
    .col-md-6.order-md-1.order-2{
        padding-right: 20px;
    }
    .col-md-6.simplifiez-gestion{
        padding-left: 20px;
    }
    .section-eshop .section-text {
        font-size: 14px;
    }
    .section-spacing h4, .section-eshop .section-title{
        font-size: 24px;
        font-weight: 600;
        text-align: left;
    }
    .highlight-section .container {
        padding: 0px 0px;
    }

    .highlight-section .container .highlight-text {
        padding-right: 0px;
    }

    .section-eshop .inedit {
        padding-left: 0px;
    }

    .section-10 .head {
        padding: 10px 30px;
    }
    .section-10 .head{
        padding: 10px 20px;
    }

    .features-section{
        margin-top: 0;
    }

    .section-prix h5{
        font-size: 24px;
    }
    /*.app-overview {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 1rem;
        padding-bottom: 10px;
    }

    .app-overview .col-md-4 {
        flex: 0 0 auto;
        width: 340px;
    }

    .app-overview::-webkit-scrollbar {
        height: 8px;
    }

    .app-overview::-webkit-scrollbar-thumb {
        background: #ccc;
        border-radius: 4px;
    }*/



    .app-overview {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 1rem;
        padding-bottom: 10px;
        scroll-snap-type: x mandatory;
        scroll-padding: 0 1rem;
    }

    .app-overview .col-md-4 {
        flex: 0 0 auto;
        width: 340px;
        scroll-snap-align: start;
    }

    .app-overview::-webkit-scrollbar {
        height: 8px;
    }

    .app-overview::-webkit-scrollbar-thumb {
        background: #ccc;
        border-radius: 4px;
    }




    .boost-nettoyage{
        margin-top: 0 !important;
    }
    .ai-section .row .card .card-body .card-title{
        font-size: 20px;
    }
    .ai-section .row .card .card-body .card-text{
        font-size: 14px;
    }
}

/* === Compat ex-thème : utilitaires utilisés par /menage-airbnb === */

/* Visibilité responsive */
.desktop-only { display:block !important; }
.desktop-only-inline { display:inline !important; }
.responsive-only { display:none !important; }
.desktop-only-visibility { visibility:visible !important; }
.responsive-only-visibility { visibility:hidden !important; }

/* Bouton primaire (violet, pilule) */
.btn { border-radius:999px; font-weight:600; }
.btn-primary { background:#4B31ED !important; border:none; color:#fff !important; }
.btn-primary:hover { background:#4a4ad1 !important; }

/* FAQ (section-10) – titres + accordéon propre */
.section-10 { padding:80px 0 120px; }
.section-10 .head { text-align:center; padding:10px 250px; margin-bottom:40px; }
.section-10 .head h2 { font-size:45px; font-weight:800; }
.section-10 .content .accordion-button { font-size:20px; font-weight:600; }
.section-10 .content .accordion-button:not(.collapsed){ color:#000 !important; background:#fff !important; box-shadow:none !important; }
.section-10 .content .accordion-item { border:none !important; }

/* Images : éviter tout débordement */
.img-mockup, .card-img-top, .custom-img, .highlight-img { max-width:100%; height:auto; }

/* Conteneur un peu resserré (optionnel, style ancien) */
.container { max-width:1140px; }

/* Petites harmonisations de sections si le parent n’applique rien */
.hero-section, .features-section, .ai-section, .section-prix,
.section-spacing, .section-advantages, .section-eshop,
.highlight-section { padding-left:15px; padding-right:15px; }

/* Responsive = comportement identique à l’ancien thème */
@media (max-width: 600px){
  html, body { overflow-x:hidden; }
  .desktop-only, .desktop-only-inline { display:none !important; }
  .responsive-only { display:block !important; }
  .desktop-only-visibility { visibility:hidden !important; }
  .responsive-only-visibility { visibility:visible !important; }

  /* FAQ titre mobile */
  .section-10 .head { padding:10px 0; }
  .section-10 .head h2 { font-size:35px; }
}

body.page-template-menage-airbnb .section-10 .head { padding:10px 250px; }

/* --- Fix header wrap uniquement sur la page Airbnb --- */
.airbnb-page .header .navbar,
.airbnb-page .header .navbar .container,
.airbnb-page .header .navbar-nav {
  flex-wrap: nowrap !important;
}

.airbnb-page .header .navbar-nav .nav-item,
.airbnb-page .header .navbar-nav .nav-link,
.airbnb-page .header .btn,
.airbnb-page .header .menu-container-desktop a {
  white-space: nowrap !important;
}

/* Laisse plus de place au menu en réduisant l’espace après le logo */
.airbnb-page .header .navbar .navbar-brand {
  margin-right: 30px !important; /* était 90px dans l’ancien thème */
}

/* Empêche le CTA à droite de forcer un retour ligne */
.airbnb-page .header .navbar .btn,
.airbnb-page .header .menu-container-desktop .btn {
  flex: 0 0 auto !important;
}

/* Optionnel: compacter un peu la typo du menu si c’est encore juste */
.airbnb-page .header .navbar .nav-link {
  font-size: 0.95rem !important;
}

/* --- Airbnb page: éviter les boutons pleine largeur --- */
.airbnb-page a.btn,
.airbnb-page button.btn,
.airbnb-page .btn {
  display: inline-flex !important;
  align-items: center;
  width: auto !important;
  max-width: max-content;
  white-space: nowrap;
  padding: .6rem 1rem;        /* optionnel: garde un padding propre */
  gap: .5rem;                 /* optionnel: espace avant la flèche → */
}

/* Cas particulier: ce style forçait la largeur pleine */
.airbnb-page .features-section .btn-dark-gradient {
  width: auto !important;
}

/* Si un utilitaire (w-100/d-block) s’invite dans le markup */
.airbnb-page .btn.w-100 { width: auto !important; }
.airbnb-page .btn.d-block { display: inline-flex !important; }

/* =========================
   SECTION — Hook Simulateur
   ========================= */
:root{
  --nsim-bg: #0f1220;           /* fond carte mockup */
  --nsim-grad: radial-gradient(1200px 600px at 20% -10%, rgba(123,104,238,.18), transparent 60%);
  --nsim-accent: #97A4C7;       /* 2e ligne du titre */
  --nsim-primary: #6C5CE7;      /* violet Neatik (bouton) */
  --nsim-primary-dark:#5948e2;
  --nsim-ring: rgba(108,92,231,.35);
}

.neatik-simteaser{
  position: relative;
  padding: clamp(36px, 6vw, 80px) 0;
  background:
    linear-gradient(180deg, #fff 0%, #fafbff 100%);
  overflow: hidden;
}

.neatik-simteaser::before{
  /* petit halo violet discret en fond */
  content:"";
  position:absolute; inset:0;
  background: var(--nsim-grad);
  pointer-events:none;
}

.nsim-wrap{
  max-width: min(1200px, 92vw);
  margin-inline: auto;
}

.nsim-grid{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(18px, 4vw, 42px);
  align-items: center;
}

/* Texte */
.nsim-kicker{
  display:inline-block;
  padding:6px 12px;
  border-radius:999px;
  background:#F3ECFF;
  color:#6B46C1;
  font-weight:600;
  font-size:14px;
  line-height:1;
  margin-bottom: clamp(14px, 2.4vw, 18px);
}

.nsim-title{
  margin:0 0 clamp(8px, 1.2vw, 12px) 0;
  font-size: clamp(28px, 4.4vw, 44px);
  line-height:1.08;
  letter-spacing:-0.02em;
  color:#1A1F1C;
  font-weight:900;
}
.nsim-title .nsim-accent{ color: var(--nsim-accent); font-weight:900; }

.nsim-lead{
  color:#5D6368;
  font-size: clamp(16px, 1.6vw, 18px);
  line-height:1.55;
  margin: 0 0 clamp(16px, 2.2vw, 22px) 0;
  max-width: 52ch;
}

.nsim-ctas{ display:flex; gap:12px; align-items:center; }

.nsim-btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 14px 20px;
  border-radius: 999px;
  background: var(--nsim-primary);
  color:#fff; text-decoration:none; font-weight:700;
  box-shadow: 0 10px 24px -8px var(--nsim-ring);
  transition: transform .16s ease, box-shadow .2s ease, background .2s ease;
}
.nsim-btn:hover{ transform: translateY(-1px); background: var(--nsim-primary-dark); }
.nsim-btn:active{ transform: translateY(0); }

.nsim-note{
  margin: 10px 0 0 0;
  font-size: 13px;
  color:#8590A2;
}

/* Mockup visuel */
.nsim-right{ position:relative; }
.nsim-mock{
  position: relative;
  margin: 0;
  background: var(--nsim-bg);
  border-radius: 20px;
  overflow:hidden;
  box-shadow:
    0 22px 60px -22px rgba(10,16,40,.35),
    0 8px 22px -10px rgba(10,16,40,.2);
  isolation:isolate;
}
.nsim-mock::before{
  /* glow doux autour du mock */
  content:"";
  position:absolute; inset:-1px;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
  pointer-events:none;
}

.nsim-mock img{
  display:block; width:100%; height:auto;
  transform: scale(1.02);
  filter: blur(2px) saturate(1.05) brightness(1.02);
  opacity: .96;
}

/* Ratio et respiration */
.nsim-mock{ aspect-ratio: 16 / 10; }

/* Responsive */
@media (max-width: 980px){
  .nsim-grid{
    grid-template-columns: 1fr;
  }
  .nsim-right{ order:2; }
  .nsim-left { order:1; }
  .nsim-mock{ aspect-ratio: 16/10; }
  .nsim-lead{ max-width: 60ch; }
}

/* Effet shimmer premium */
.nsim-mock {
  position: relative;
  margin: 0;
  background: var(--nsim-bg);
  border-radius: 20px;
  overflow: hidden;
  box-shadow:
    0 22px 60px -22px rgba(10,16,40,.35),
    0 8px 22px -10px rgba(10,16,40,.2);
  isolation: isolate;
}

.nsim-mock img {
  display: block;
  width: 100%;
  height: auto;
  transform: scale(1.02);
  filter: blur(2px) saturate(1.05) brightness(1.02);
  opacity: 0.96;
}

/* Shimmer overlay */
.nsim-shimmer {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    75deg,
    transparent 0%,
    rgba(255, 255, 255, 0.1) 45%,
    rgba(255, 255, 255, 0.35) 50%,
    rgba(255, 255, 255, 0.1) 55%,
    transparent 100%
  );
  transform: translateX(-100%);
  animation: shimmerMove 6s infinite linear;
  pointer-events: none;
  mix-blend-mode: overlay;
  opacity: 0.7;
  z-index: 3;
  border-radius: inherit;
}

@keyframes shimmerMove {
  0% {
    transform: translateX(-100%) rotate(5deg);
  }
  100% {
    transform: translateX(200%) rotate(5deg);
  }
}

/* Halo subtil autour du mock */
.nsim-mock::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.06),
    0 0 30px rgba(108, 92, 231, 0.12);
  pointer-events: none;
}

/* ratio */
.nsim-mock {
  aspect-ratio: 16 / 10;
}

/* ==== Révélation au scroll (fade + slide-up) ==================== */
.neatik-simteaser {
  /* rien */
}

/* État initial tant que la section n'est pas en vue */
.neatik-simteaser:not(.is-inview) .nsim-left,
.neatik-simteaser:not(.is-inview) .nsim-right {
  opacity: 0;
  transform: translateY(18px) scale(.98);
  filter: saturate(.9);
}

/* Transition */
.neatik-simteaser .nsim-left,
.neatik-simteaser .nsim-right {
  transition:
    opacity .6s cubic-bezier(.2,.7,.2,1),
    transform .6s cubic-bezier(.2,.7,.2,1),
    filter .6s linear;
}

/* Stagger léger */
.neatik-simteaser .nsim-left { transition-delay: .05s; }
.neatik-simteaser .nsim-right { transition-delay: .18s; }

/* Accessibilité : si l’utilisateur réduit les animations, on les coupe */
@media (prefers-reduced-motion: reduce) {
  .neatik-simteaser .nsim-left,
  .neatik-simteaser .nsim-right {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
  }
}
