/* ===================================================================
   SErvolution — Design System v3
   Palette Servolution : #B05A3B marron brule, #F6A858 orange chaud
   =================================================================== */

:root {
  --brown:     #B05A3B;
  --brown-dk:  #8A3F25;
  --brown-lt:  #D4795A;
  --orange:    #F6A858;
  --orange-dk: #E8932E;
  --orange-lt: #FFF3E0;
  --peach:     #FDEAE3;
  --warm-sand: #FBF3EC;
  --cream:     #FDFAF7;
  --dark:      #1E1810;
  --dark-mid:  #2C2016;
  --txt:       #2C2016;
  --txt-mid:   #5C4A3A;
  --txt-lt:    #9A8070;
  --border:    #E8DDD4;
  --white:     #FFFFFF;
  --bg:        #FAF7F4;
  --bg-alt:    #F5EFE8;
  --success:   #3D8B5E;
  --danger:    #C45040;
  --maxw:      1200px;
  --radius:    10px;
  --radius-lg: 14px;
  --shadow:    0 2px 8px rgba(44,32,22,.06);
  --shadow-md: 0 8px 24px rgba(44,32,22,.08);
  --shadow-lg: 0 16px 48px rgba(44,32,22,.12);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Open Sans',system-ui,-apple-system,sans-serif;
  color:var(--txt);
  background:var(--white);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brown);text-decoration:none}
a:hover{text-decoration:underline}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}
h1,h2,h3,h4{color:var(--dark);line-height:1.2;letter-spacing:-.03em}

/* ── Container ── */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;overflow-x:hidden}
.container [style*="overflow-x"]{overflow-x:auto !important;display:block;max-width:100%;-webkit-overflow-scrolling:touch}

/* ── Section ── */
section{padding:112px 0}
.section--bg{background:var(--bg)}
.section--dark{background:var(--dark);color:var(--white)}
.section--dark h2,.section--dark h3,.section--dark p{color:var(--white)}
.section--dark .lead{color:rgba(255,255,255,.65)}
.section--alt{background:var(--bg)}
.section--warm{background:var(--warm-sand)}
.section--peach{background:var(--peach)}

.section-tag,.badge,.tag{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.03em;
  color:var(--brown);
  background:rgba(176,90,59,.08);
  padding:6px 16px;
  border-radius:20px;
  margin-bottom:16px;
}
.tag--orange{color:var(--orange-dk);background:rgba(246,168,88,.12)}
.tag--green{color:var(--success);background:rgba(61,139,94,.1)}
.tag--blue{color:#1565C0;background:rgba(21,101,192,.08)}
.tag--purple{color:#7B1FA2;background:rgba(123,31,162,.08)}
.section-head{text-align:center;margin-bottom:56px}
.section-title,
section>.container>h2{
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;
  margin-bottom:24px;
  text-align:center;
}
.lead,
section>.container>.lead{
  font-size:1.05rem;
  color:var(--txt-mid);
  max-width:640px;
  margin:0 auto 40px;
  line-height:1.8;
  text-align:center;
}
section>.container>.tag,
section>.container>.badge,
section>.container>.section-tag{
  display:block;
  text-align:center;
}
/* Constrain standalone text blocks in sections */
section>.container>p{
  max-width:780px;
  margin-left:auto;
  margin-right:auto;
  text-align:center;
  font-size:.95rem;
  color:var(--txt-mid);
  line-height:1.8;
  margin-bottom:16px;
}
.text-center{text-align:center}

/* ══════════════════════════════════════
   NAVIGATION
══════════════════════════════════════ */
.nav{
  position:sticky;
  top:0;
  z-index:10000;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid rgba(232,221,212,.5);
}
.nav__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:80px;
}
.nav__logo img{height:72px;width:auto;object-fit:contain}
.nav__hamburger{
  display:none;
  background:none;
  border:none;
  flex-direction:column;
  gap:5px;
  padding:8px;
  color:var(--dark);
}
.nav__hamburger span{
  display:block;
  width:24px;
  height:2.5px;
  background:currentColor;
  border-radius:2px;
  transition:all .3s ease;
}
.nav__menu{
  display:flex;
  align-items:center;
  gap:32px;
}
.nav__links{
  display:flex;
  align-items:center;
  gap:28px;
}
.nav__links li a{
  font-size:.88rem;
  font-weight:500;
  color:var(--txt-mid);
  text-decoration:none;
  transition:color .2s;
  position:relative;
}
.nav__links li a:hover,
.nav__links li a.active{color:var(--brown);text-decoration:none}
.nav__links li a.active::after{
  content:'';
  position:absolute;
  bottom:-4px;left:0;right:0;
  height:2px;
  background:var(--brown);
  border-radius:1px;
}
.nav__actions{display:flex;align-items:center;gap:12px}

/* ── Buttons ── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-family:inherit;
  font-weight:700;
  font-size:.88rem;
  border-radius:var(--radius);
  padding:12px 28px;
  text-decoration:none;
  transition:all .25s ease;
  cursor:pointer;
  border:2px solid transparent;
  white-space:nowrap;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--accent{
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dk) 100%);
  color:var(--white);border-color:var(--orange);
  box-shadow:0 4px 12px rgba(246,168,88,.35);
}
.btn--accent:hover{box-shadow:0 6px 20px rgba(246,168,88,.45)}
.btn--primary{
  background:var(--brown);color:var(--white);border-color:var(--brown);
  box-shadow:0 4px 12px rgba(176,90,59,.2);
}
.btn--primary:hover{background:var(--brown-dk);border-color:var(--brown-dk);box-shadow:0 6px 20px rgba(176,90,59,.3)}
.btn--outline{background:transparent;color:var(--brown);border-color:var(--brown)}
.btn--outline:hover{background:var(--brown);color:var(--white)}
.btn--ghost{background:var(--white);color:var(--txt);border-color:var(--border);box-shadow:var(--shadow)}
.btn--ghost:hover{border-color:var(--brown);color:var(--brown)}
.btn--white{background:var(--white);color:var(--brown);border-color:var(--white);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.btn--white:hover{background:var(--cream)}
.btn--lg{padding:15px 36px;font-size:.95rem;border-radius:12px}
.btn--sm{padding:9px 20px;font-size:.82rem}
.btn--full{width:100%;justify-content:center}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{
  background:linear-gradient(170deg,var(--cream) 0%,var(--warm-sand) 50%,var(--peach) 100%);
  padding:96px 0 80px;
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:'';position:absolute;right:-120px;top:-120px;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(246,168,88,.12) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero__inner,.hero__grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:72px;
  align-items:center;
}
.hero__badge{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.03em;
  color:var(--brown);
  background:rgba(176,90,59,.1);
  padding:6px 16px;
  border-radius:20px;
  margin-bottom:24px;
}
.hero h1{
  font-size:clamp(2.2rem,5vw,3.5rem);
  font-weight:800;
  line-height:1.08;
  margin-bottom:28px;
  color:var(--dark);
}
.hero h1 em{font-style:italic;color:var(--brown)}
.hero__sub{
  font-size:1.1rem;
  color:var(--txt-mid);
  line-height:1.7;
  margin-bottom:16px;
  font-weight:500;
}
.hero p{
  font-size:.95rem;
  color:var(--txt-mid);
  line-height:1.75;
  margin-bottom:14px;
}
.hero__ctas{
  display:flex;
  gap:14px;
  margin-top:32px;
  flex-wrap:wrap;
}
.hero__visual{position:relative;overflow:hidden;border-radius:var(--radius-lg)}
.hero__visual img{
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  width:100%;
  height:100%;
  max-height:520px;
  object-fit:cover;
  object-position:center top;
}

/* ══════════════════════════════════════
   GRIDS
══════════════════════════════════════ */
.grid{display:grid}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.grid-3,.grid--3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}

/* ══════════════════════════════════════
   CARDS
══════════════════════════════════════ */
.card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:32px;
  box-shadow:var(--shadow);
  border:1px solid rgba(232,221,212,.5);
  transition:all .3s ease;
}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-6px) scale(1.01);border-color:transparent}
.card h3{font-size:1.05rem;font-weight:700;margin-bottom:10px;color:var(--dark)}
.card p{font-size:.9rem;color:var(--txt-mid);line-height:1.75}
.card--danger-border{border-top:3px solid var(--danger)}
.card--accent-border{border-top:3px solid var(--orange)}
.card__icon{
  width:52px;height:52px;
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.card__icon svg{width:24px;height:24px}
.card__link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.85rem;
  font-weight:600;
  color:var(--brown);
  margin-top:16px;
  text-decoration:none;
}
.card__link:hover{text-decoration:underline}
.card__link svg{width:16px;height:16px}

/* Card module variant */
.card--module{
  display:flex;flex-direction:column;
  padding:36px 28px;
}
.card--module p{flex:1}
.card--module .card__link{margin-top:auto;padding-top:16px}

/* ══════════════════════════════════════
   MODULE CARDS (with colored icons)
══════════════════════════════════════ */
.module-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:36px 28px;
  box-shadow:var(--shadow);
  border:1px solid rgba(232,221,212,.5);
  transition:all .3s;
  display:flex;
  flex-direction:column;
}
.module-card:hover{box-shadow:var(--shadow-md);transform:translateY(-6px) scale(1.02);border-color:transparent}
.module-card__icon{
  width:56px;height:56px;
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
}
.module-card__icon svg{width:28px;height:28px}
.module-card h3{font-size:1.1rem;font-weight:700;margin-bottom:12px}
.module-card p{font-size:.9rem;color:var(--txt-mid);line-height:1.75;flex:1}
.module-card .card__link{margin-top:auto;padding-top:16px}

/* Module color system */
:root{
  --mod-treso:#2E7D32;--mod-treso-bg:#E8F5E9;
  --mod-comm:#1565C0;--mod-comm-bg:#E3F2FD;
  --mod-crm:#E65100;--mod-crm-bg:#FFF3E0;
  --mod-proj:#7B1FA2;--mod-proj-bg:#F3E5F5;
  --mod-acad:#B05A3B;--mod-acad-bg:#FDEAE3;
}
.module-card--tresorerie .module-card__icon,.module-card--tresorerie .card__icon{background:var(--mod-treso-bg);color:var(--mod-treso)}
.module-card--tresorerie .module-card__icon svg,.module-card--tresorerie .card__icon svg{color:var(--mod-treso)}
.module-card--commercial .module-card__icon,.module-card--commercial .card__icon{background:var(--mod-comm-bg);color:var(--mod-comm)}
.module-card--commercial .module-card__icon svg,.module-card--commercial .card__icon svg{color:var(--mod-comm)}
.module-card--crm .module-card__icon,.module-card--crm .card__icon{background:var(--mod-crm-bg);color:var(--mod-crm)}
.module-card--crm .module-card__icon svg,.module-card--crm .card__icon svg{color:var(--mod-crm)}
.module-card--projets .module-card__icon,.module-card--projets .card__icon{background:var(--mod-proj-bg);color:var(--mod-proj)}
.module-card--projets .module-card__icon svg,.module-card--projets .card__icon svg{color:var(--mod-proj)}
.module-card--academie .module-card__icon,.module-card--academie .card__icon{background:var(--mod-acad-bg);color:var(--mod-acad)}
.module-card--academie .module-card__icon svg,.module-card--academie .card__icon svg{color:var(--mod-acad)}

/* ── Section-level module colors (liserés + gradient backgrounds) ── */
section.module-card--tresorerie{border-left:4px solid var(--mod-treso);background:linear-gradient(135deg,var(--mod-treso-bg) 0%,var(--bg) 25%)}
section.module-card--tresorerie h2{color:var(--mod-treso)}
section.module-card--tresorerie .section-tag{color:var(--mod-treso);background:var(--mod-treso-bg)}
section.module-card--tresorerie .card__link{color:var(--mod-treso)}

section.module-card--commercial{border-left:4px solid var(--mod-comm);background:linear-gradient(135deg,var(--mod-comm-bg) 0%,var(--white) 25%)}
section.module-card--commercial h2{color:var(--mod-comm)}
section.module-card--commercial .section-tag{color:var(--mod-comm);background:var(--mod-comm-bg)}
section.module-card--commercial .card__link{color:var(--mod-comm)}

section.module-card--crm{border-left:4px solid var(--mod-crm);background:linear-gradient(135deg,var(--mod-crm-bg) 0%,var(--bg) 25%)}
section.module-card--crm h2{color:var(--mod-crm)}
section.module-card--crm .section-tag{color:var(--mod-crm);background:var(--mod-crm-bg)}
section.module-card--crm .card__link{color:var(--mod-crm)}

section.module-card--projets{border-left:4px solid var(--mod-proj);background:linear-gradient(135deg,var(--mod-proj-bg) 0%,var(--white) 25%)}
section.module-card--projets h2{color:var(--mod-proj)}
section.module-card--projets .section-tag{color:var(--mod-proj);background:var(--mod-proj-bg)}
section.module-card--projets .card__link{color:var(--mod-proj)}

section.module-card--academie{border-left:4px solid var(--mod-acad);background:linear-gradient(135deg,var(--mod-acad-bg) 0%,var(--bg) 25%)}
section.module-card--academie h2{color:var(--mod-acad)}
section.module-card--academie .section-tag{color:var(--mod-acad);background:var(--mod-acad-bg)}
section.module-card--academie .card__link{color:var(--mod-acad)}

/* ── Content-text inside module sections inherits color ── */
section[class*="module-card--"] .content-grid__text ul li::before{border-color:currentColor}
section[class*="module-card--"] .content-text ul li::before{border-color:currentColor}

/* ══════════════════════════════════════
   BEFORE / AFTER
══════════════════════════════════════ */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:40px}
.compare__col{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:36px;
  border:1px solid var(--border);
}
.compare__col--before{border-top:3px solid var(--danger)}
.compare__col--after{border-top:3px solid var(--success)}
.compare__col h3{font-size:1rem;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.compare__item{font-size:.9rem;color:var(--txt-mid);line-height:1.75;padding:10px 0;border-bottom:1px solid var(--border)}
.compare__item:last-child{border-bottom:none}

/* ══════════════════════════════════════
   PRICING
══════════════════════════════════════ */
.pricing-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.pricing-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:36px 24px;
  border:1px solid var(--border);
  text-align:center;
  transition:all .3s;
  position:relative;
  display:flex;
  flex-direction:column;
}
.pricing-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:transparent}
.pricing-card--featured{border:2px solid var(--orange);box-shadow:0 8px 32px rgba(246,168,88,.15)}
.pricing-card--featured:hover{box-shadow:0 12px 40px rgba(246,168,88,.22)}
.pricing-badge,.pricing-card__badge{
  display:inline-block;
  background:linear-gradient(135deg,var(--orange),var(--orange-dk));
  color:var(--white);
  font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  padding:5px 16px;border-radius:20px;
  margin-bottom:12px;
}
.pricing-card__name,.card__title{font-size:1.05rem;font-weight:700;color:var(--dark);margin-bottom:4px}
.pricing-card__price,.card__price{font-size:2.2rem;font-weight:800;color:var(--brown);margin:12px 0 4px}
.pricing-card__price span,.card__currency{font-size:.85rem;font-weight:500;color:var(--txt-lt)}
.pricing-card__amount,.card__amount{font-size:2.2rem;font-weight:800;color:var(--brown)}
.pricing-card__desc,.pricing-card__users{font-size:.85rem;color:var(--txt-lt);margin-bottom:20px}
.pricing-card__features{text-align:left;margin-bottom:24px}
.pricing-card__features li{
  font-size:.85rem;color:var(--txt-mid);
  padding:6px 0;display:flex;align-items:flex-start;gap:8px;
}
.pricing-card__features li::before{
  content:'';display:inline-block;
  width:18px;height:18px;min-width:18px;margin-top:2px;
  background:rgba(176,90,59,.08);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B05A3B' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}
.pricing-card .btn,.pricing-card__cta .btn{margin-top:auto}
.pricing-card .btn--outline,.pricing-card .btn--primary{
  background:var(--brown);color:var(--white);border-color:var(--brown);width:100%;
}
.pricing-card .btn--outline:hover,.pricing-card .btn--primary:hover{
  background:var(--brown-dk);border-color:var(--brown-dk);
}
.pricing-card--featured .btn--accent{width:100%}
.pricing-card__header{margin-bottom:16px}

/* ══════════════════════════════════════
   FAQ
══════════════════════════════════════ */
.faq,.faq-list{max-width:800px;margin:0 auto}
.faq-item,.faq__item{
  border:1px solid var(--border);
  border-left:3px solid var(--orange);
  border-radius:var(--radius);
  margin-bottom:12px;
  padding:0 24px;
  background:var(--white);
  transition:all .25s ease;
}
.faq-item:hover,.faq__item:hover{
  border-left-color:var(--brown);
  box-shadow:0 4px 16px rgba(176,90,59,.1);
  transform:translateX(4px);
}
.faq-question,.faq__question{
  width:100%;background:none;border:none;text-align:left;
  font-size:1rem;font-weight:600;color:var(--dark);
  padding:22px 0;display:flex;justify-content:space-between;
  align-items:center;gap:16px;cursor:pointer;line-height:1.4;
}
.faq-question:hover,.faq__question:hover{color:var(--brown)}
.faq-question svg,.faq__question svg,.faq-chevron{
  width:22px;height:22px;min-width:22px;
  color:var(--white);
  background:linear-gradient(135deg,var(--orange),var(--orange-dk));
  border-radius:50%;
  padding:4px;
  transition:transform .3s,background .3s;
}
.faq-question:hover svg,.faq__question:hover svg{background:linear-gradient(135deg,var(--brown),var(--brown-dk))}
.faq-question[aria-expanded="true"] svg,.faq__question[aria-expanded="true"] svg{transform:rotate(180deg)}
.faq-answer,.faq__answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
.faq-answer.open,.faq__answer.open{max-height:600px;padding-bottom:20px}
.faq-answer p,.faq__answer p{font-size:.92rem;color:var(--txt-mid);line-height:1.8}
.faq-answer a,.faq__answer a{color:var(--brown);font-weight:600;border-bottom:1px solid rgba(176,90,59,.3);transition:border-color .2s}
.faq-answer a:hover,.faq__answer a:hover{border-bottom-color:var(--brown);text-decoration:none}

/* FAQ section headings */
.faq-section-title{
  font-size:1.3rem;
  font-weight:800;
  color:var(--white);
  margin-bottom:28px;
  padding:18px 28px;
  background:linear-gradient(135deg,var(--brown) 0%,var(--brown-dk) 100%);
  border-radius:var(--radius-lg);
  text-align:left;
  box-shadow:0 4px 16px rgba(176,90,59,.2);
  position:relative;
  overflow:hidden;
}
.faq-section-title::after{
  content:'';position:absolute;right:-20px;top:-20px;
  width:100px;height:100px;
  background:radial-gradient(circle,rgba(246,168,88,.25) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.faq h2,.faq-list h2{
  font-size:1.15rem;
  font-weight:700;
  color:var(--brown);
  margin:40px 0 16px;
  padding:12px 20px;
  background:rgba(176,90,59,.05);
  border-left:3px solid var(--brown);
  border-radius:0 var(--radius) var(--radius) 0;
}
.faq h2:first-child,.faq-list h2:first-child{margin-top:0}

/* FAQ color variants per section */
/* Use real module colors for coherence */
.faq--brown .faq-item{border-left-color:var(--brown)}
.faq--orange .faq-item{border-left-color:var(--mod-crm, #E65100)}
.faq--green .faq-item{border-left-color:var(--mod-treso, #2E7D32)}
.faq--blue .faq-item{border-left-color:var(--mod-comm, #1565C0)}
.faq--brown .faq-question svg{background:linear-gradient(135deg,var(--brown),var(--brown-dk))}
.faq--orange .faq-question svg{background:linear-gradient(135deg,#E65100,#BF360C)}
.faq--green .faq-question svg{background:linear-gradient(135deg,#2E7D32,#1B5E20)}
.faq--blue .faq-question svg{background:linear-gradient(135deg,#1565C0,#0D47A1)}

/* ══════════════════════════════════════
   CTA BANNER
══════════════════════════════════════ */
.cta-banner{
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-mid) 50%,#3D2A1A 100%);
  padding:88px 0;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;right:-80px;top:-80px;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(246,168,88,.1) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.cta-banner h2{color:var(--white);font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:20px}
.cta-banner p{color:rgba(255,255,255,.6);font-size:1.05rem;max-width:560px;margin:0 auto 32px;line-height:1.75}

/* ══════════════════════════════════════
   CONTENT SECTIONS
══════════════════════════════════════ */
.content-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:center;
}
.content-grid--reverse{direction:rtl}
.content-grid--reverse>*{direction:ltr}
.content-text h2,.content-grid__text h2{font-size:clamp(1.5rem,3.2vw,2.2rem);font-weight:800;margin-bottom:20px}
.content-text .section-tag,.content-grid__text .tag,.content-grid__text .badge{margin-bottom:12px}
.content-text p,.content-grid__text p{font-size:.95rem;color:var(--txt-mid);line-height:1.8;margin-bottom:16px}
.content-text ul,.content-grid__text ul{margin:16px 0}
.content-text ul li,.content-grid__text ul li{
  font-size:.92rem;color:var(--txt-mid);
  padding:6px 0 6px 28px;position:relative;line-height:1.6;
}
.content-text ul li::before,.content-grid__text ul li::before{
  content:'';position:absolute;left:0;top:12px;
  width:8px;height:8px;border-radius:50%;
  background:rgba(176,90,59,.15);border:2px solid var(--brown);
}
.content-img img,.content-grid__visual img,.content-grid__media img,.content-grid__aside img{
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  width:100%;
  max-height:480px;
  object-fit:cover;
  object-position:center;
}

/* ── Photo + screenshot overlay ── */
.content-grid__visual[style*="position:relative"]{overflow:visible}
.content-grid__visual[style*="position:relative"] > img:first-child{max-height:none}

/* ── Long text / SEO ── */
.long-text{max-width:820px;margin:0 auto;columns:1}
.long-text h2{font-size:1.6rem;font-weight:800;margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid var(--border)}
.long-text h3{
  font-size:1.1rem;font-weight:700;
  margin:48px 0 16px;color:var(--brown);
  padding:16px 20px;
  background:rgba(176,90,59,.04);
  border-left:3px solid var(--brown);
  border-radius:0 var(--radius) var(--radius) 0;
}
.long-text h3:first-of-type{margin-top:0}
.long-text p{font-size:.95rem;color:var(--txt-mid);line-height:1.85;margin-bottom:18px}
.long-text blockquote,.long-text .highlight{
  background:var(--warm-sand);
  border-radius:var(--radius);
  padding:20px 24px;
  margin:24px 0;
  font-size:.95rem;
  color:var(--txt);
  line-height:1.8;
  border-left:3px solid var(--orange);
}

/* Two-column layout for long text on desktop */
@media(min-width:1024px){
  .long-text--cols{columns:2;column-gap:48px}
  .long-text--cols h2,.long-text--cols h3{column-span:all}
}

/* ── Stats ── */
.stats{display:flex;justify-content:center;gap:48px;padding:40px 0;flex-wrap:wrap}
.stat{
  text-align:center;
  padding:28px 32px;
  background:var(--white);
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  transition:all .3s cubic-bezier(.19,1,.22,1);
  min-width:180px;
}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--orange)}
.stat__number{font-size:2.4rem;font-weight:800;color:var(--brown);display:block;line-height:1.1;margin-bottom:6px}
.stat__label{font-size:.82rem;color:var(--txt-lt);font-weight:500;line-height:1.4}

/* Check list */
.check-list{list-style:none;margin:16px 0}
.check-list li{
  font-size:.92rem;color:var(--txt-mid);
  padding:8px 0 8px 28px;position:relative;line-height:1.6;
}
.check-list li::before{
  content:'';position:absolute;left:0;top:10px;
  width:18px;height:18px;
  background:rgba(176,90,59,.08);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B05A3B' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}

/* CTA buttons group */
.cta-btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px;justify-content:center}

/* Reassurance */
.reassurance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.reassurance-card{
  background:var(--white);border-radius:var(--radius-lg);padding:28px;
  text-align:center;box-shadow:var(--shadow);border:1px solid rgba(232,221,212,.5);
}
.reassurance-card h3{font-size:.95rem;font-weight:700;margin-bottom:6px}
.reassurance-card p{font-size:.85rem;color:var(--txt-mid)}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.footer{
  background:var(--dark);
  color:rgba(255,255,255,.7);
  padding:72px 0 0;
}
.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;
  padding-bottom:48px;
}
.footer__brand p{font-size:.88rem;line-height:1.7;margin-top:16px;color:rgba(255,255,255,.5)}
.footer__brand img{height:56px;width:auto;opacity:.9;border-radius:8px}
.footer__heading{
  font-size:.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.85);
  margin-bottom:16px;
}
.footer__col ul li{margin-bottom:8px}
.footer__col ul li a{
  font-size:.85rem;
  color:rgba(255,255,255,.5);
  text-decoration:none;
  transition:color .2s;
}
.footer__col ul li a:hover{color:var(--orange);text-decoration:none}
.footer__seo{
  font-size:.82rem;
  color:rgba(255,255,255,.3);
  line-height:1.7;
  padding:24px 0;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding:20px 0;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.footer__bottom p{font-size:.78rem;color:rgba(255,255,255,.3)}
.footer__bottom a{color:rgba(255,255,255,.35);font-size:.78rem;text-decoration:none}
.footer__bottom a:hover{color:var(--orange)}
.footer__bottom-links{display:flex;gap:20px}

/* ══════════════════════════════════════
   FORMS
══════════════════════════════════════ */
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--txt);margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:12px 16px;
  border:1.5px solid var(--border);border-radius:var(--radius);
  font-family:inherit;font-size:.9rem;color:var(--txt);background:var(--white);
  transition:border-color .2s;
}
.form-group input:focus,.form-group textarea:focus{
  outline:none;border-color:var(--brown);
  box-shadow:0 0 0 3px rgba(176,90,59,.08);
}
.form-group textarea{min-height:120px;resize:vertical}
.contact-form{
  background:var(--white);border-radius:var(--radius-lg);
  padding:40px;box-shadow:var(--shadow);border:1px solid var(--border);
}

/* ══════════════════════════════════════
   PAGE HERO
══════════════════════════════════════ */
.page-hero{
  background:linear-gradient(170deg,var(--cream) 0%,var(--warm-sand) 40%,var(--peach) 100%);
  padding:72px 0 56px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;
  right:-60px;top:-60px;
  width:260px;height:260px;
  background:radial-gradient(circle,rgba(246,168,88,.1) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.page-hero::after{
  content:'';position:absolute;
  left:-80px;bottom:-80px;
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(176,90,59,.06) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.page-hero h1{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;margin-bottom:16px}
.page-hero .lead,.page-hero__lead{
  font-size:1.05rem;color:var(--txt-mid);max-width:640px;margin:0 auto 24px;line-height:1.8;
}
.page-hero .breadcrumb,.breadcrumb{
  font-size:.8rem;color:var(--txt-lt);margin-bottom:20px;
  display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;
  list-style:none;padding:0;
}
.breadcrumb li{display:inline-flex;align-items:center;gap:6px}
.breadcrumb li+li::before{content:'/';color:var(--txt-lt);font-size:.75rem}
.breadcrumb li::marker{content:none;display:none}
.breadcrumb a{color:var(--txt-lt);text-decoration:none}
.breadcrumb a:hover{color:var(--brown)}

/* Aside */
.aside-card{
  background:var(--bg);border-radius:var(--radius-lg);padding:28px;
  border:1px solid var(--border);margin-bottom:20px;
}
.aside-card h3{font-size:1rem;font-weight:700;margin-bottom:12px}
.aside-list{list-style:none}
.aside-list li{font-size:.9rem;color:var(--txt-mid);padding:6px 0;border-bottom:1px solid var(--border)}
.aside-list li:last-child{border-bottom:none}
.aside-list li a{color:var(--brown);font-weight:600;text-decoration:none}
.aside-list li a:hover{text-decoration:underline}

/* Section aliases */
.section__title{font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:800;margin-bottom:16px}
.section__content{max-width:800px}
.content-grid__main{order:0}
.content-grid__aside{order:1}

/* ══════════════════════════════════════
   APP WINDOW (polished)
══════════════════════════════════════ */
.app-window{
  border-radius:12px;
  overflow:hidden;
  background:var(--white);
  border:1px solid rgba(232,221,212,.6);
  box-shadow:0 8px 32px rgba(44,32,22,.1);
  transition:transform .4s cubic-bezier(.19,1,.22,1),box-shadow .4s cubic-bezier(.19,1,.22,1);
}
.app-window:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(44,32,22,.15);
}
.app-titlebar{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 16px;
  background:linear-gradient(180deg,#faf8f6 0%,#f4f0ec 100%);
  border-bottom:1px solid rgba(232,221,212,.5);
}
.app-dots{display:flex;gap:6px}
.app-dots span{width:10px;height:10px;border-radius:50%;background:var(--border)}
.app-dots span:first-child{background:#E8685A}
.app-dots span:nth-child(2){background:#F5BC42}
.app-dots span:last-child{background:#61C554}
.app-url{
  font-size:.72rem;
  color:var(--txt-lt);
  font-weight:500;
  letter-spacing:.02em;
  background:rgba(232,221,212,.3);
  padding:3px 12px;
  border-radius:6px;
  flex:1;
  text-align:center;
}
.app-window img{width:100%;display:block;max-height:420px;object-fit:cover;object-position:70% top}
.app-body{display:grid;grid-template-columns:180px 1fr;background:#1a1a2e;color:#e2d9c8;font-size:12px;min-height:280px}
.app-sidebar{background:rgba(255,255,255,.04);padding:14px 12px;border-right:1px solid rgba(255,255,255,.06);display:none}
.app-content{padding:16px;overflow:hidden}
.app-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.app-title{font-size:13px;font-weight:700;color:#e2d9c8}
.app-btn-sm{font-size:10px;padding:4px 10px;background:rgba(246,168,88,.15);color:var(--orange);border-radius:6px;font-weight:600}
@media(min-width:768px){.app-sidebar{display:block}}

/* ══════════════════════════════════════
   BACK TO TOP BUTTON
══════════════════════════════════════ */
.back-to-top{
  position:fixed;
  bottom:28px;
  right:28px;
  z-index:900;
  width:48px;height:48px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brown) 0%,var(--brown-dk) 100%);
  color:var(--white);
  border:none;
  box-shadow:0 4px 16px rgba(176,90,59,.3);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .3s ease,transform .3s ease,background .2s;
  pointer-events:none;
}
.back-to-top.visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.back-to-top:hover{
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dk) 100%);
  box-shadow:0 6px 24px rgba(246,168,88,.4);
  transform:translateY(-2px);
}
.back-to-top svg{width:22px;height:22px}

/* ══════════════════════════════════════
   SCROLL ANIMATIONS
══════════════════════════════════════ */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
.fade-in{
  opacity:0;
  transform:translateY(32px);
  transition:opacity .7s cubic-bezier(.19,1,.22,1),transform .7s cubic-bezier(.19,1,.22,1);
}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-5{grid-template-columns:repeat(3,1fr)}
  .pricing-cards{grid-template-columns:repeat(3,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
}

/* ── Tableaux comparatifs → cards sur mobile ── */
@media(max-width:768px){
  .container [style*="overflow-x"]{overflow:visible !important}
  .container [style*="overflow-x"] table{min-width:0 !important;width:100% !important}
  .container [style*="overflow-x"] table thead{display:none}
  .container [style*="overflow-x"] table tbody{display:flex;flex-direction:column;gap:16px}
  .container [style*="overflow-x"] table tr{
    display:grid;grid-template-columns:1fr;gap:0;
    border:1px solid var(--border);border-radius:var(--radius-lg);
    padding:0;background:var(--white);box-shadow:var(--shadow);
    border-bottom:none !important;
  }
  .container [style*="overflow-x"] table td{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 14px !important;border-bottom:1px solid var(--border);
    text-align:left !important;font-size:.85rem;min-height:0;
  }
  .container [style*="overflow-x"] table td::before{
    font-size:.72rem;font-weight:700;text-transform:uppercase;
    letter-spacing:.04em;color:var(--txt-lt);margin-right:8px;white-space:nowrap;
  }
  /* Premiere cellule = titre de la carte, pleine largeur */
  .container [style*="overflow-x"] table td:first-child{
    grid-column:1/-1;font-weight:700;font-size:.95rem;
    background:var(--bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    padding:14px 16px !important;border-bottom:2px solid var(--border);
  }
  .container [style*="overflow-x"] table td:first-child::before{display:none}
  /* Labels — Tableau formules */
  .table-formules td:nth-child(2)::before{content:'Solo'}
  .table-formules td:nth-child(3)::before{content:'Essentiel'}
  .table-formules td:nth-child(4)::before{content:'Pro'}
  .table-formules td:nth-child(5)::before{content:'Business'}
  .table-formules td:nth-child(6)::before{content:'Cabinet'}
  /* Labels — Tableau concurrents */
  .table-concurrents td:nth-child(2)::before{content:'SErvolution'}
  .table-concurrents td:nth-child(3)::before{content:'Odoo'}
  .table-concurrents td:nth-child(4)::before{content:'Tiime'}
  .table-concurrents td:nth-child(5)::before{content:'HubSpot'}
}

@media(max-width:960px){
  .nav__hamburger{display:flex}
  .nav{
    position:fixed;left:0;right:0;top:0;
    z-index:10000;
    background:#FFFFFF;
    border-bottom:1px solid var(--border);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
  }
  .nav__menu{
    display:none;
    position:fixed;
    top:80px;left:0;right:0;bottom:0;
    background:#FFFFFF;
    flex-direction:column;
    padding:32px 24px;gap:0;
    overflow-y:auto;
    z-index:10001;
    -webkit-overflow-scrolling:touch;
  }
  .nav__menu--open{display:flex}
  .nav__links{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav__links li a{display:block;padding:14px 0;font-size:1rem;border-bottom:1px solid var(--border)}
  .nav__actions{flex-direction:column;width:100%;margin-top:24px;gap:12px}
  .nav__actions .btn{width:100%;justify-content:center}
  .nav__hamburger[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .nav__hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav__hamburger[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  body.nav-open{overflow:hidden}
  body{padding-top:80px}

  .hero__inner,.hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__visual{order:-1;max-width:480px;margin:0 auto}
  .content-grid{grid-template-columns:1fr !important;gap:40px}
  .content-grid--reverse{direction:ltr}
  .compare{grid-template-columns:1fr}
  .grid-3,.grid--3{grid-template-columns:repeat(2,1fr)}
  .pricing-cards{grid-template-columns:repeat(2,1fr) !important}
  .reassurance-grid{grid-template-columns:repeat(2,1fr)}
  /* Force inline grid-template-columns override on tablet */
  [style*="grid-template-columns"]{grid-template-columns:repeat(2,1fr) !important}
  /* Tables comparatives : wrapper scrollable */
  [style*="overflow-x"]{-webkit-overflow-scrolling:touch;max-width:100%}
}

@media(max-width:640px){
  section{padding:64px 0}
  .hero{padding:56px 0 48px}
  .grid-2,.grid-3,.grid--3,.grid-4,.grid-5{grid-template-columns:1fr !important}
  .hero__ctas{flex-direction:column}
  .hero__ctas .btn{width:100%;justify-content:center}
  .stats{gap:32px}
  .footer__grid{grid-template-columns:1fr}
  .pricing-cards{grid-template-columns:1fr !important;max-width:380px;margin:0 auto}
  .footer__bottom{flex-direction:column;text-align:center}
  .reassurance-grid{grid-template-columns:1fr}
  /* Force ALL inline grids to 1 column on mobile */
  [style*="grid-template-columns"]{grid-template-columns:1fr !important}
  .content-grid{grid-template-columns:1fr !important}
  /* Tables comparatives : wrapper scrollable */
  [style*="overflow-x"]{-webkit-overflow-scrolling:touch;max-width:100%}
}
