/*
Theme Name: France Renov Custom FR
Description: Thème WordPress personnalisé en français pour France Rénov Online.
Version: 1.1
Text Domain: france-renov-custom-fr
*/
:root{--green:#1a6b3c;--green-dark:#124a29;--green-soft:#e8f5ee;--gold:#f0a500;--bg:#f7f8f7;--surface:#fff;--text:#18201b;--muted:#617062;--border:rgba(24,32,27,.09);--shadow:0 10px 30px rgba(0,0,0,.08);--radius:18px;--container:1200px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.container{width:min(var(--container),calc(100% - 32px));margin:auto}.section{padding:80px 0}.section-sm{padding:56px 0}.section-soft{background:linear-gradient(180deg,#f8fbf9 0%,#f2f7f4 100%)}.eyebrow{display:inline-block;padding:6px 12px;border-radius:999px;background:var(--green-soft);color:var(--green);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.section-title{font-size:clamp(30px,4vw,52px);line-height:1.08;margin:16px 0 14px;font-weight:800}.section-sub{color:var(--muted);max-width:760px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:12px;font-weight:700;border:1px solid transparent;transition:.25s ease}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}.btn-secondary{background:#fff;color:var(--green);border-color:var(--green)}.btn-gold{background:var(--gold);color:#fff}.grid{display:grid;gap:24px}.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}.cards-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:26px;box-shadow:var(--shadow)}.muted{color:var(--muted)}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:20px}.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--green)}.brand-mark{width:38px;height:38px;border-radius:12px;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:800}.brand small{display:block;color:var(--muted);font-weight:600}.main-nav ul{display:flex;gap:24px;list-style:none;padding:0;margin:0}.main-nav a{font-weight:600;color:#243328}.header-actions{display:flex;gap:12px;align-items:center}
.hero{position:relative;overflow:hidden;padding:88px 0 56px;background:linear-gradient(135deg,#f4f8f5 0%,#eef5f0 100%)}.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(26,107,60,.08),transparent 35%),radial-gradient(circle at 80% 30%,rgba(240,165,0,.08),transparent 30%);pointer-events:none}.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:40px;align-items:center}.hero h1{font-size:clamp(38px,5vw,70px);line-height:1.02;margin:18px 0;font-weight:900}.hero h1 .accent{color:var(--green)}.hero-lead{font-size:19px;line-height:1.8;color:var(--muted);max-width:680px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.hero-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:26px 0}.hero-point{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);font-weight:600;transition:transform .3s ease}.hero-card{position:relative;background:#fff;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);transition:transform .3s ease}.hero-card img{aspect-ratio:4/3;object-fit:cover;width:100%}.hero-badge{position:absolute;top:18px;right:18px;background:#fff;color:var(--green);font-weight:800;padding:10px 14px;border-radius:12px;box-shadow:var(--shadow)}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}.hero-stat{background:#fff;padding:18px 14px;text-align:center}.hero-stat strong{display:block;font-size:28px;color:var(--green)}
.section-head{margin-bottom:28px}.steps-grid .card,.service-card,.panel,.hero-card,.hero-point{transition:transform .3s ease,box-shadow .3s ease,opacity .4s ease}.steps-grid .card:hover,.service-card:hover,.panel:hover,.hero-card:hover,.hero-point:hover{transform:translateY(-6px)}.step-number{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:999px;background:var(--green-soft);color:var(--green);font-weight:800;margin-bottom:14px}.service-card{overflow:hidden;padding:0}.service-card img{aspect-ratio:16/10;object-fit:cover;width:100%}.service-card .content{padding:20px}.service-card h3{margin:0 0 8px}.split{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}.panel{background:#fff;border-radius:24px;padding:28px;border:1px solid var(--border);box-shadow:var(--shadow)}.panel-highlight{border:1px solid rgba(26,107,60,.14);background:linear-gradient(180deg,#ffffff 0%,#f5fbf7 100%)}.panel-cta{background:linear-gradient(135deg,#ffffff 0%,#f4faf6 100%)}.big-amount{font-size:58px;line-height:1;margin:14px 0;color:var(--green);font-weight:900}.checklist{display:grid;gap:12px}.check{display:flex;gap:12px;align-items:flex-start}.check i{width:24px;height:24px;border-radius:999px;background:var(--green-soft);color:var(--green);display:grid;place-items:center;font-style:normal;font-weight:800;flex:0 0 24px}.faq-list{display:grid;gap:14px}.faq-item{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden}.faq-q{width:100%;padding:20px 22px;background:#fff;border:0;text-align:left;font-weight:700;display:flex;justify-content:space-between;align-items:center;cursor:pointer}.faq-a{padding:0 22px 20px;color:var(--muted);display:none}.faq-item.active .faq-a{display:block}.page-hero{padding:70px 0 24px;background:linear-gradient(135deg,#f4f8f5 0%,#eef5f0 100%)}.content-box{background:#fff;border:1px solid var(--border);border-radius:24px;padding:28px;box-shadow:var(--shadow)}.site-footer{background:#0f1c14;color:#d7ded9;padding:56px 0 28px}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px}.site-footer h4{color:#fff;margin-top:0}.footer-note{padding-top:24px;margin-top:24px;border-top:1px solid rgba(255,255,255,.12);color:#a8b5ad}.reveal{opacity:0;transform:translateY(26px);transition:all .7s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.12s}.reveal-delay-2{transition-delay:.24s}.reveal-delay-3{transition-delay:.36s}.wpforms-container .wpforms-field input,.wpforms-container .wpforms-field textarea,.wpforms-container .wpforms-field select{border-radius:12px!important;border:1px solid #dbe3dc!important;padding:12px 14px!important}.wpforms-container .wpforms-submit{background:var(--green)!important;color:#fff!important;border:none!important;border-radius:12px!important;padding:14px 22px!important;font-weight:700!important}@media (max-width:980px){.hero-grid,.split,.footer-grid,.cards-3,.cards-4{grid-template-columns:1fr}.main-nav ul{flex-wrap:wrap;gap:14px}.hero-badge{position:static;display:inline-block;margin:16px 16px 0}.hero-actions{flex-direction:column;align-items:flex-start}.big-amount{font-size:44px}}
/* ===== RESPONSIVE HEADER ===== */

.site-header{
  position: sticky;
  top: 0;
  z-index: 999;
  background: #fff;
  box-shadow: 0 1px 8px rgba(0,0,0,0.08);
  padding: 12px 0;
}

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

.brand{
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.brand .custom-logo,
.brand .site-logo{
  width: 38px !important;
  height: 38px !important;
  max-width: 38px !important;
  max-height: 38px !important;
  object-fit: contain !important;
  display: block !important;
}

.brand > span{
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  font-weight: 700;
  font-size: 15px;
  color: #166534;
}

.brand > span small{
  font-size: 11px;
  font-weight: 400;
  color: #6b7280;
  margin-top: 2px;
}

/* Desktop nav */
.main-nav ul{
  display: flex;
  align-items: center;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.main-nav a{
  text-decoration: none;
  color: #1f2937;
  font-weight: 600;
  font-size: 15px;
  transition: color .2s;
}

.main-nav a:hover{
  color: #166534;
}

.header-actions{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

/* Hamburger button */
.nav-toggle{
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  flex-shrink: 0;
}

.nav-toggle span{
  display: block;
  width: 24px;
  height: 2px;
  background: #1f2937;
  border-radius: 2px;
  transition: all .25s ease;
}

.nav-toggle.is-open span:nth-child(1){
  transform: translateY(7px) rotate(45deg);
}

.nav-toggle.is-open span:nth-child(2){
  opacity: 0;
}

.nav-toggle.is-open span:nth-child(3){
  transform: translateY(-7px) rotate(-45deg);
}

.nav-actions-mobile{
  display: none;
}

/* Mobile */
@media (max-width: 900px){

  .nav-toggle{
    display: flex;
    order: 3;
  }

  .header-actions{
    display: none;
  }

  .main-nav{
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
    padding: 20px 24px;
    z-index: 998;
  }

  .main-nav.nav-open{
    display: block;
  }

  .main-nav ul{
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .main-nav ul li{
    width: 100%;
    border-bottom: 1px solid #f0f0f0;
  }

  .main-nav ul li:last-child{
    border-bottom: none;
  }

  .main-nav a{
    display: block;
    padding: 14px 0;
    font-size: 16px;
  }

  .nav-actions-mobile{
    display: block;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #f0f0f0;
  }

  .nav-actions-mobile .btn{
    display: block;
    text-align: center;
    width: 100%;
  }
/* ================================================
   PARTNERS BAR — paste at the bottom of style.css
   ================================================ */

.partners-section {
  padding: 28px 0;
  background: #f9fafb;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
}

.partners-section .container {
  display: block !important;
}

.partners-label {
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #9ca3af;
  margin-bottom: 20px;
}

.partners-logos {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 20px !important;
}

.partner-logo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 120px !important;
  height: 70px !important;
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  overflow: hidden !important;
  transition: box-shadow .2s ease, transform .2s ease;
  flex-shrink: 0 !important;
}

.partner-logo:hover {
  box-shadow: 0 4px 14px rgba(0,0,0,0.10) !important;
  transform: translateY(-2px);
}

.partner-logo img {
  display: block !important;
  width: 80px !important;
  height: 50px !important;
  max-width: 80px !important;
  max-height: 50px !important;
  object-fit: contain !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}

/* Tablet */
@media (max-width: 768px) {
  .partners-logos {
    flex-wrap: wrap !important;
    gap: 14px !important;
  }
  .partner-logo {
    width: 100px !important;
    height: 60px !important;
    padding: 8px 10px !important;
  }
  .partner-logo img {
    width: 66px !important;
    height: 42px !important;
    max-width: 66px !important;
    max-height: 42px !important;
  }
}

/* Mobile */
@media (max-width: 480px) {
  .partners-logos {
    gap: 10px !important;
  }
  .partner-logo {
    width: 85px !important;
    height: 52px !important;
    padding: 6px 8px !important;
  }
  .partner-logo img {
    width: 56px !important;
    height: 36px !important;
    max-width: 56px !important;
    max-height: 36px !important;
  }
}