/* ICAI Photovoltaïque — style.css */
:root {
  --orange:#f97316;--orange-dark:#ea580c;--orange-light:#fed7aa;
  --orange-bg:#fff7ed;--orange-bg2:#fffbf5;
  --slate-900:#0f172a;--slate-700:#334155;--slate-500:#64748b;
  --slate-400:#94a3b8;--slate-100:#f1f5f9;--slate-50:#f8fafc;
  --border:#e2e8f0;--white:#ffffff;--red:#ef4444;
  --radius:8px;--radius-lg:16px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.07);
  --shadow:0 4px 6px -1px rgba(0,0,0,.08),0 2px 4px -1px rgba(0,0,0,.05);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.08);
  --shadow-xl:0 20px 25px -5px rgba(0,0,0,.08);
  --transition:.2s ease;
  --font-title:'Outfit',sans-serif;
  --font-body:'DM Sans',sans-serif;
  --max-w:1200px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--slate-700);background:var(--white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-title);color:var(--slate-900);line-height:1.2;font-weight:700}
h1{font-size:clamp(2rem,4vw,3rem)}
h2{font-size:clamp(1.5rem,3vw,2.25rem)}
h3{font-size:clamp(1.1rem,2vw,1.5rem)}
h4{font-size:1.1rem}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
.section-pad{padding:80px 0}
.section-pad-sm{padding:48px 0}
.text-center{text-align:center}
.text-orange{color:var(--orange)}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);background:var(--orange-bg);border:1px solid var(--orange-light);padding:.3rem .9rem;border-radius:50px;margin-bottom:1.2rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-weight:600;font-size:.95rem;padding:.75rem 1.75rem;border-radius:50px;transition:all var(--transition);white-space:nowrap}
.btn-primary{background:var(--orange);color:var(--white);box-shadow:0 4px 14px rgba(249,115,22,.3)}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(249,115,22,.35)}
.btn-outline{border:2px solid var(--border);color:var(--slate-700);background:var(--white)}
.btn-outline:hover{border-color:var(--orange);color:var(--orange)}
.btn-white{background:var(--white);color:var(--orange-dark);font-weight:700}
.btn-white:hover{background:var(--orange-bg)}
.btn-sm{padding:.55rem 1.2rem;font-size:.875rem}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:1.5rem}
.logo{display:flex;align-items:center;gap:.6rem;font-family:var(--font-title);font-weight:700;font-size:1.3rem;color:var(--slate-900);flex-shrink:0;text-decoration:none}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));border-radius:9px;display:flex;align-items:center;justify-content:center;color:white;font-size:1rem;flex-shrink:0}
.logo-text-group{display:flex;flex-direction:column;gap:0}
.logo-name{line-height:1.1}
.logo-sub{font-size:.6rem;font-weight:400;color:var(--slate-500);letter-spacing:.05em}
.nav-desktop{display:flex;align-items:center;gap:.2rem}
.nav-desktop a{font-size:.875rem;font-weight:500;color:var(--slate-700);padding:.4rem .7rem;border-radius:var(--radius);transition:all var(--transition)}
.nav-desktop a:hover,.nav-desktop a.active{color:var(--orange);background:var(--orange-bg)}
.has-dropdown{position:relative}
.dropdown{position:absolute;top:calc(100% + .5rem);left:0;min-width:220px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:.5rem;opacity:0;pointer-events:none;transform:translateY(-6px);transition:all .2s}
.has-dropdown:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0)}
.dropdown a{display:block;padding:.55rem 1rem;font-size:.85rem;border-radius:var(--radius)}
.burger{display:none;flex-direction:column;gap:5px;padding:.5rem;border-radius:var(--radius)}
.burger span{display:block;width:24px;height:2px;background:var(--slate-700);transition:all var(--transition);border-radius:2px}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;background:var(--white);border-bottom:1px solid var(--border);padding:0 1.5rem;max-height:0;overflow:hidden;transition:max-height .35s ease}
.mobile-nav.open{max-height:700px;padding:1rem 1.5rem 1.5rem}
.mobile-nav a{display:block;padding:.65rem 0;font-weight:500;color:var(--slate-700);border-bottom:1px solid var(--border);font-size:.9rem}
.mobile-nav a:last-of-type{border-bottom:none}
.mobile-cta{margin-top:1rem;display:block;text-align:center}
.mobile-section{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-400);padding:.75rem 0 .2rem;border-bottom:none !important}
.hero{background:linear-gradient(160deg,var(--slate-900) 0%,#1e293b 60%,#0f172a 100%);color:var(--white);padding:60px 0 70px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 70% 50%,rgba(249,115,22,.12) 0%,transparent 70%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-content{max-width:600px}
.hero-eyebrow{background:rgba(249,115,22,.15);border-color:rgba(249,115,22,.3);color:#fdba74}
.hero h1{color:var(--white);margin-bottom:1.25rem}
.hero h1 em{color:var(--orange);font-style:normal}
.hero-sub{font-size:1.05rem;color:#94a3b8;margin-bottom:2rem;line-height:1.75}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.5rem}
.hero-stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:1.25rem}
.hero-stat-value{font-family:var(--font-title);font-size:1.9rem;font-weight:800;color:var(--orange);line-height:1}
.hero-stat-label{font-size:.8rem;color:#94a3b8;margin-top:.3rem}
.breadcrumb-bar{background:var(--slate-50);border-bottom:1px solid var(--border);padding:.75rem 0}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--slate-500)}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb-sep{color:var(--slate-400)}
.breadcrumb-current{color:var(--slate-700);font-weight:500}
.page-hero{background:linear-gradient(160deg,var(--slate-900) 0%,#1e293b 100%);color:var(--white);padding:60px 0 70px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 40% 60% at 85% 50%,rgba(249,115,22,.1),transparent 70%);pointer-events:none}
.page-hero-eyebrow{background:rgba(249,115,22,.15);border-color:rgba(249,115,22,.3);color:#fdba74;margin-bottom:1rem}
.page-hero h1{color:var(--white);margin-bottom:1rem;max-width:750px}
.page-hero-sub{font-size:1.05rem;color:#94a3b8;max-width:650px;margin-bottom:1.75rem;line-height:1.75}
.page-hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.two-col{display:grid;grid-template-columns:1fr 340px;gap:3rem;align-items:start}
.sidebar-sticky{position:sticky;top:90px}
.sidebar-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}
.sidebar-card h4{font-size:1rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.sidebar-card .btn{display:block;text-align:center;width:100%;margin-top:1rem;justify-content:center}
.sidebar-card ul{display:flex;flex-direction:column;gap:.6rem}
.sidebar-card ul li{display:flex;align-items:flex-start;gap:.6rem;font-size:.875rem;color:var(--slate-700)}
.sidebar-card ul li::before{content:'✓';color:var(--orange);font-weight:700;flex-shrink:0;margin-top:.1rem}
.contact-card{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);color:var(--white);border-color:transparent}
.contact-card h4{color:var(--white);border-bottom-color:rgba(255,255,255,.2)}
.contact-card p{color:rgba(255,255,255,.85);font-size:.875rem;margin-bottom:.6rem}
.contact-card .contact-tel{font-family:var(--font-title);font-size:1.2rem;font-weight:700;color:var(--white);display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}
.contact-card .contact-hours{font-size:.78rem;opacity:.75}
.contact-card .btn-white{width:100%;display:block;text-align:center;margin-top:1rem;justify-content:center}
.content-section{margin-bottom:2.5rem}
.content-section h2{font-size:1.45rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--orange-light)}
.content-section h3{font-size:1.1rem;margin:1.25rem 0 .5rem;color:var(--slate-900)}
.config-block{background:var(--orange-bg);border:1px solid var(--orange-light);border-left:4px solid var(--orange);border-radius:var(--radius-lg);padding:1.75rem;margin:2rem 0}
.config-block h4{color:var(--orange-dark);font-size:.85rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.07em}
.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.config-item label{display:block;font-size:.72rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--slate-500);margin-bottom:.2rem}
.config-item value{display:block;font-family:var(--font-title);font-size:1rem;font-weight:700;color:var(--slate-900)}
.maillage{background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-top:2.5rem}
.maillage h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.07em;color:var(--slate-500);margin-bottom:1rem}
.maillage-links{display:flex;flex-wrap:wrap;gap:.5rem}
.maillage-links a{font-size:.85rem;color:var(--slate-700);background:var(--white);border:1px solid var(--border);padding:.4rem .9rem;border-radius:50px;transition:all var(--transition);font-weight:500}
.maillage-links a:hover{background:var(--orange-bg);border-color:var(--orange-light);color:var(--orange)}
.cards-grid{display:grid;gap:1.5rem}
.cards-grid-2{grid-template-columns:repeat(2,1fr)}
.cards-grid-3{grid-template-columns:repeat(3,1fr)}
.cards-grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm);transition:all .25s}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--orange-light)}
.card-icon{width:46px;height:46px;background:var(--orange-bg);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem;border:1px solid var(--orange-light)}
.card h3{font-size:1rem;margin-bottom:.5rem}
.card p{font-size:.875rem;color:var(--slate-500)}
.card-link{display:block;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm);transition:all .25s;text-decoration:none;color:inherit}
.card-link:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--orange)}
.card-link h3{color:var(--slate-900);font-size:1rem;margin-bottom:.4rem}
.card-link p{font-size:.85rem;color:var(--slate-500);margin-bottom:.75rem}
.card-link .card-arrow{color:var(--orange);font-weight:700;font-size:.85rem}
.section-title{margin-bottom:3rem}
.section-title h2{margin-bottom:.75rem}
.section-title p{font-size:1rem;color:var(--slate-500);max-width:650px}
.section-title.center{text-align:center}
.section-title.center p{margin:0 auto}
.cta-band{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);color:var(--white);padding:64px 0;text-align:center}
.cta-band h2{color:var(--white);margin-bottom:.75rem}
.cta-band p{color:rgba(255,255,255,.85);max-width:580px;margin:0 auto 2rem;font-size:1.05rem}
.cta-band .ctas{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.faq-section{background:var(--slate-50)}
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:.5rem}
.faq-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.faq-question{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;font-weight:600;font-size:.95rem;color:var(--slate-900);cursor:pointer;transition:background var(--transition);width:100%;text-align:left}
.faq-question:hover{background:var(--slate-50)}
.faq-icon{width:24px;height:24px;background:var(--orange-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--orange);font-size:.9rem;flex-shrink:0;transition:transform var(--transition)}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease;font-size:.9rem;color:var(--slate-700);line-height:1.7}
.faq-answer-inner{padding:0 1.5rem 1.5rem}
.faq-item.open .faq-answer{max-height:500px}
.contact-section{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info h2{margin-bottom:1rem}
.contact-info p{color:var(--slate-500);margin-bottom:2rem}
.contact-reassurance{display:flex;flex-direction:column;gap:.75rem}
.contact-reassurance li{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:var(--slate-700)}
.contact-reassurance li::before{content:'✓';width:22px;height:22px;background:var(--orange-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--orange);font-weight:700;font-size:.75rem;flex-shrink:0}
.contact-form{background:var(--slate-50);border-radius:var(--radius-lg);padding:2rem;border:1px solid var(--border)}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--slate-700);margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;color:var(--slate-900);background:var(--white);transition:border-color var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--orange)}
.form-group textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-check{display:flex;align-items:flex-start;gap:.6rem}
.form-check input{width:16px;height:16px;margin-top:.2rem;accent-color:var(--orange);flex-shrink:0}
.form-check label{font-size:.8rem;color:var(--slate-500);cursor:pointer}
.form-check a{color:var(--orange)}
.form-rgpd{display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;font-size:.8rem;color:var(--slate-500);line-height:1.5}
.form-rgpd input[type="checkbox"]{width:16px;height:16px;margin-top:.2rem;accent-color:var(--orange);flex-shrink:0}
.form-rgpd span{flex:1}
.form-rgpd a{color:var(--orange)}
.form-submit{width:100%;margin-top:1.25rem;justify-content:center;font-size:1rem;padding:.9rem 2rem;border-radius:50px}
.form-msg{display:none;padding:1rem;border-radius:var(--radius);font-size:.875rem;margin-top:1rem;text-align:center}
.form-msg.success{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;display:block}
.form-msg.error{background:#fef2f2;color:var(--red);border:1px solid #fecaca;display:block}
.disclaimer-band{background:var(--slate-50);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1rem 0}
.disclaimer-band p{font-size:.8rem;color:var(--slate-500);text-align:center;max-width:900px;margin:0 auto;line-height:1.6}
.site-footer{background:var(--slate-900);color:#94a3b8;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand .logo{color:var(--white);margin-bottom:1rem}
.footer-brand p{font-size:.875rem;line-height:1.7;max-width:280px}
.footer-brand .footer-contact{margin-top:1.5rem}
.footer-brand .footer-contact a{display:block;color:#cbd5e1;font-size:.875rem;margin-bottom:.4rem;transition:color var(--transition)}
.footer-brand .footer-contact a:hover{color:var(--orange)}
.footer-col h5{font-family:var(--font-title);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:1rem}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul a{font-size:.875rem;color:#94a3b8;transition:color var(--transition)}
.footer-col ul a:hover{color:var(--orange)}
.footer-bottom{border-top:1px solid #1e293b;padding:1.25rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-bottom p{font-size:.8rem}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{font-size:.8rem;color:#64748b;transition:color var(--transition)}
.footer-bottom-links a:hover{color:var(--orange)}
.scroll-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;background:var(--orange);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:900;opacity:0;transform:translateY(12px);transition:all .3s;box-shadow:0 4px 14px rgba(249,115,22,.35);border:none}
.scroll-top.visible{opacity:1;transform:translateY(0)}
.scroll-top:hover{background:var(--orange-dark)}
.steps{display:flex;flex-direction:column;gap:0}
.step{display:flex;gap:1.5rem;padding-bottom:2rem;position:relative}
.step:not(:last-child)::before{content:'';position:absolute;left:19px;top:42px;bottom:0;width:2px;background:var(--border)}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--orange);color:var(--white);font-family:var(--font-title);font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.step-content h4{margin-bottom:.35rem;font-size:1rem}
.step-content p{font-size:.875rem;color:var(--slate-500);margin:0}
.simulator{background:var(--slate-900);border-radius:var(--radius-lg);padding:2rem;color:var(--white)}
.sim-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.sim-label{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-400);margin-bottom:.4rem;display:block}
.sim-input{width:100%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius);color:var(--white);padding:.6rem .9rem;font-family:var(--font-body);font-size:.9rem}
.sim-input:focus{outline:none;border-color:var(--orange)}
.sim-results{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem}
.sim-result{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:1.25rem;text-align:center}
.sim-result-value{font-family:var(--font-title);font-size:1.6rem;font-weight:800;color:var(--orange)}
.sim-result-label{font-size:.75rem;color:var(--slate-400);margin-top:.3rem}
.sim-note{font-size:.72rem;color:var(--slate-500);margin-top:1rem;text-align:center}
.qual-badges{display:flex;flex-wrap:wrap;gap:.75rem}
.qual-badge{display:flex;align-items:center;gap:.6rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:.6rem 1rem;font-size:.85rem;font-weight:600;color:var(--slate-700);box-shadow:var(--shadow-sm)}
.qual-badge-icon{color:var(--orange);font-size:1.1rem}
.highlight-box{background:var(--orange-bg);border:1px solid var(--orange-light);border-radius:var(--radius-lg);padding:1.5rem;margin:1.5rem 0}
.highlight-box h4{color:var(--orange-dark);margin-bottom:.5rem;font-size:1rem}
.highlight-box p{font-size:.9rem;margin:0}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat-item{text-align:center}
.stat-value{font-family:var(--font-title);font-size:2.25rem;font-weight:800;color:var(--orange);line-height:1}
.stat-label{font-size:.875rem;color:var(--slate-500);margin-top:.35rem}
.rgpd-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9998}
.rgpd-overlay.active{display:block}
.rgpd-banner{display:none;position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);width:calc(100% - 3rem);max-width:880px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:9999;padding:1.75rem}
.rgpd-banner.active{display:block}
.rgpd-banner h4{font-size:1rem;margin-bottom:.5rem}
.rgpd-banner p{font-size:.875rem;color:var(--slate-500);margin-bottom:1.25rem}
.rgpd-banner p a{color:var(--orange)}
.rgpd-btns{display:flex;gap:.75rem;flex-wrap:wrap}
.rgpd-detail{display:none;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}
.rgpd-detail.open{display:block}
.rgpd-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--border);font-size:.875rem}
.rgpd-toggle-row:last-child{border-bottom:none}
.rgpd-toggle-row span{color:var(--slate-700)}
.rgpd-always{font-size:.75rem;color:var(--slate-400)}
.switch{position:relative;display:inline-block;width:40px;height:22px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:var(--border);border-radius:22px;cursor:pointer;transition:.3s}
.slider:before{position:absolute;content:'';width:16px;height:16px;left:3px;bottom:3px;background:white;border-radius:50%;transition:.3s}
input:checked+.slider{background:var(--orange)}
input:checked+.slider:before{transform:translateX(18px)}
/* ===== Chaîne de valeur (homepage) ===== */
.chaine-valeur-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
@media(max-width:1024px){.chaine-valeur-grid{grid-template-columns:1fr;gap:2rem}}
@media(max-width:768px){.chaine-valeur-grid{gap:1.5rem}}
@media(max-width:1024px){.two-col{grid-template-columns:1fr}.sidebar-sticky{position:static}.footer-grid{grid-template-columns:1fr 1fr}.stats-row{grid-template-columns:repeat(2,1fr)}.hero-grid{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:2.5rem}.sim-grid{grid-template-columns:1fr}}
@media(max-width:768px){.section-pad{padding:56px 0}.nav-desktop{display:none}.burger{display:flex}.mobile-nav{display:block}.cards-grid-3,.cards-grid-4{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;text-align:center}.form-row{grid-template-columns:1fr}.hero{padding:60px 0}.hero-stats{grid-template-columns:1fr 1fr}.sim-results{grid-template-columns:1fr}}
@media(max-width:480px){.cards-grid-2,.cards-grid-3,.cards-grid-4{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(2,1fr)}.hero-stats{grid-template-columns:1fr 1fr}}

/* ===== PAGES INTÉRIEURES SUPPLÉMENTAIRES ===== */

/* Maillage interne (pages intérieures) */
.maillage-section{padding:56px 0;background:var(--slate-50)}
.maillage-title{font-size:1.3rem;font-family:var(--font-title);color:var(--slate-900);margin-bottom:1.5rem;font-weight:700}
.maillage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.maillage-card{display:flex;flex-direction:column;gap:.35rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;text-decoration:none;color:var(--slate-800);transition:all var(--transition)}
.maillage-card:hover{border-color:var(--orange-light);box-shadow:0 4px 16px rgba(249,115,22,.1);transform:translateY(-2px)}
.maillage-card strong{font-size:.95rem;font-weight:700;color:var(--slate-900)}
.maillage-card span{font-size:.82rem;color:var(--slate-500);line-height:1.4}
.maillage-card svg{width:16px;height:16px;margin-top:.25rem;color:var(--orange);flex-shrink:0}

/* Réassurance */
.reassurance-section{padding:56px 0;background:var(--white)}
.reassurance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}
.reassurance-card{background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}
.reassurance-card h4{font-family:var(--font-title);font-size:1rem;font-weight:700;color:var(--slate-900);margin-bottom:.6rem}
.reassurance-card p{font-size:.87rem;color:var(--slate-600);line-height:1.6;margin:0}

/* Config table (pages intérieures) */
.config-table{width:100%;border-collapse:collapse;font-size:.88rem;margin-top:0}
.config-table td{padding:.55rem .75rem;border-bottom:1px solid var(--border)}
.config-table tr:last-child td{border-bottom:none}
.config-table td:first-child{color:var(--slate-600);font-weight:500}
.config-table td:last-child{color:var(--slate-900);text-align:right}
.config-table td strong{color:var(--orange-dark)}

/* Sidebar extras */
.sidebar-text{font-size:.85rem;color:var(--slate-600);line-height:1.6;margin:0 0 .75rem}
.sidebar-link{display:inline-block;font-size:.85rem;color:var(--orange);font-weight:600;text-decoration:none}
.sidebar-link:hover{text-decoration:underline}

/* Content list */
.content-list{list-style:none;padding:0;margin:.75rem 0 1.25rem}
.content-list li{padding:.5rem 0 .5rem 1.5rem;position:relative;font-size:.93rem;color:var(--slate-700);border-bottom:1px solid var(--border);line-height:1.6}
.content-list li:last-child{border-bottom:none}
.content-list li::before{content:"→";position:absolute;left:0;color:var(--orange);font-weight:700}

/* Hero inner (pages intérieures) */
.hero-inner{background:linear-gradient(135deg,var(--slate-900) 0%,#1e293b 100%);padding:60px 0 48px;color:var(--white)}
.hero-inner .breadcrumb{margin-bottom:1.25rem}
.hero-inner .breadcrumb ol{list-style:none;padding:0;margin:0;font-size:.82rem;color:rgba(255,255,255,.5)}
.hero-inner .breadcrumb a{color:rgba(255,255,255,.7);text-decoration:none}
.hero-inner .breadcrumb a:hover{color:var(--orange)}
.hero-inner .eyebrow{color:var(--orange);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;display:block;margin-bottom:.75rem}
.hero-inner h1{font-family:var(--font-title);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;line-height:1.2;margin-bottom:1rem;color:var(--white)}
.hero-inner .hero-subtitle{font-size:1rem;color:rgba(255,255,255,.7);line-height:1.7;max-width:680px;margin-bottom:1.75rem}

/* Two-col layout */
.two-col-section{padding:72px 0;background:var(--white)}
.two-col-grid{display:grid;grid-template-columns:1fr 360px;gap:4rem;align-items:start}
.two-col-main h2{font-family:var(--font-title);font-size:1.5rem;font-weight:800;color:var(--slate-900);margin:2rem 0 .75rem;line-height:1.25}
.two-col-main h2:first-child{margin-top:0}
.two-col-main h3{font-family:var(--font-title);font-size:1.1rem;font-weight:700;color:var(--slate-800);margin:1.75rem 0 .6rem}
.two-col-main p{font-size:.95rem;color:var(--slate-700);line-height:1.75;margin-bottom:1rem}

/* Sidebar */
.two-col-sidebar{display:flex;flex-direction:column;gap:1.25rem}
.sidebar-card{background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}
.sidebar-card.sidebar-contact{background:var(--orange-bg);border-color:var(--orange-light)}
.sidebar-card h3{font-family:var(--font-title);font-size:1rem;font-weight:700;color:var(--slate-900);margin-bottom:.5rem}
.sidebar-card h4{font-family:var(--font-title);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--slate-500);margin-bottom:.75rem}
.sidebar-card p{font-size:.875rem;color:var(--slate-600);margin-bottom:1rem;line-height:1.6}
.sidebar-card .btn{width:100%;text-align:center;margin-bottom:.5rem;font-size:.88rem}
.sidebar-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}
.sidebar-list li{font-size:.87rem;color:var(--slate-700);padding:.25rem 0;border-bottom:1px solid var(--border)}
.sidebar-list li:last-child{border-bottom:none}
.sidebar-list a{color:var(--slate-700);text-decoration:none;font-weight:500}
.sidebar-list a:hover{color:var(--orange)}

/* Legal pages */
.legal-section{padding:72px 0}
.legal-container{max-width:820px}
.legal-container h2{font-family:var(--font-title);font-size:1.2rem;font-weight:800;color:var(--slate-900);margin:2.5rem 0 .75rem;padding-top:1rem;border-top:1px solid var(--border)}
.legal-container h2:first-child{margin-top:0;border-top:none}
.legal-container h3{font-family:var(--font-title);font-size:1rem;font-weight:700;color:var(--slate-800);margin:1.5rem 0 .5rem}
.legal-container p{font-size:.92rem;color:var(--slate-700);line-height:1.75;margin-bottom:.85rem}
.legal-container a{color:var(--orange)}
.legal-list{list-style:none;padding:0;margin:.5rem 0 1rem}
.legal-list li{font-size:.92rem;color:var(--slate-700);padding:.35rem 0;border-bottom:1px solid var(--border)}
.legal-list li:last-child{border-bottom:none}

/* Zone d'intervention */
.zone-section{padding:72px 0}
.zone-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;margin:2.5rem 0 3rem}
.zone-col h3{font-family:var(--font-title);font-size:1rem;font-weight:700;color:var(--slate-900);margin-bottom:.4rem}
.zone-col p{font-size:.85rem;color:var(--slate-500);margin-bottom:.75rem}
.zone-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}
.zone-list li{font-size:.9rem;color:var(--slate-700);padding:.25rem 0 .25rem 1.25rem;position:relative}
.zone-list li::before{content:"›";position:absolute;left:0;color:var(--orange);font-weight:700}
.address-block{background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;max-width:380px;margin:1rem 0}
.address-info{font-size:.92rem;color:var(--slate-700);line-height:2}
.address-info strong{font-weight:700;color:var(--slate-900)}
.address-info a{color:var(--orange)}

/* Responsive pages intérieures */
@media(max-width:1024px){
  .two-col-grid{grid-template-columns:1fr}
  .two-col-sidebar{display:grid;grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .two-col-sidebar{grid-template-columns:1fr}
  .maillage-grid{grid-template-columns:1fr}
  .reassurance-grid{grid-template-columns:1fr}
  .zone-grid{grid-template-columns:1fr}
  .hero-inner{padding:40px 0 36px}
  .two-col-section,.legal-section,.zone-section{padding:48px 0}
}


/* ===== CORRECTIFS DÉBOGAGE ===== */

/* Logo image */
.logo-img{height:40px;width:auto;display:block;object-fit:contain}
.logo-img-footer{height:34px;filter:brightness(0) invert(1)}
.logo-name-sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* Bouton hero outline lisible */
.btn-hero-outline{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-weight:600;font-size:.95rem;padding:.75rem 1.75rem;border-radius:50px;transition:all var(--transition);white-space:nowrap;border:2px solid rgba(255,255,255,.65);color:#ffffff;background:rgba(255,255,255,.08);backdrop-filter:blur(4px)}
.btn-hero-outline:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.9)}

/* SVG panneau solaire isométrique */
.solar-panel-iso{display:flex;align-items:center;justify-content:center;max-width:380px;margin:0 auto;filter:drop-shadow(0 20px 40px rgba(0,0,0,.5))}
.iso-svg{width:100%;height:auto;overflow:visible}

/* Fix menu dropdown - gap entre nav item et dropdown pour éviter zone morte */
.has-dropdown{padding-bottom:0}
.has-dropdown > a{display:block}
.dropdown{top:100%;margin-top:0;padding-top:.75rem}
.has-dropdown::after{content:'';position:absolute;left:0;right:0;height:12px;top:100%}

/* Tirets CSS — normalisation via contenu seulement, pas de style global */

/* Header logo fix sur pages intérieures */
.header-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--font-title);font-weight:700;font-size:1.3rem;color:var(--slate-900);flex-shrink:0;text-decoration:none}
.logo-mark{width:36px;height:36px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.logo-mark svg{width:20px;height:20px;fill:white}
.logo-name{line-height:1.1;font-family:var(--font-title);font-weight:700;font-size:1.2rem;color:var(--slate-900)}
.logo-tagline{font-size:.6rem;font-weight:400;color:var(--slate-500);letter-spacing:.05em;display:block}

/* Nav pages intérieures — header-nav */
.header-nav{display:flex;align-items:center}
.nav-links{display:flex;align-items:center;gap:.2rem;list-style:none}
.nav-links li a{font-size:.875rem;font-weight:500;color:var(--slate-700);padding:.4rem .7rem;border-radius:var(--radius);transition:all var(--transition);display:block;text-decoration:none}
.nav-links li a:hover{color:var(--orange);background:var(--orange-bg)}

/* Header CTA pages intérieures */
.header-cta{display:flex;align-items:center;gap:1rem;margin-left:.5rem}
.header-phone{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500;color:var(--slate-600);transition:color var(--transition);text-decoration:none}
.header-phone svg{width:16px;height:16px}
.header-phone:hover{color:var(--orange)}

/* Burger pages intérieures */
.burger-btn{display:none;flex-direction:column;gap:5px;padding:.5rem;border-radius:var(--radius);background:none;border:none;cursor:pointer}
.burger-btn span{display:block;width:24px;height:2px;background:var(--slate-700);transition:all var(--transition);border-radius:2px}
.burger-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger-btn.open span:nth-child(2){opacity:0}
.burger-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav pages intérieures */
.mobile-nav-links{list-style:none;padding:0;margin:0}
.mobile-nav-links li a{display:block;padding:.65rem 0;font-weight:500;color:var(--slate-700);border-bottom:1px solid var(--border);font-size:.9rem;text-decoration:none}
.mobile-nav-links li a:last-child{border-bottom:none}

/* Picto SVG dans sidebar / icon-boxes — fix taille excessive pages intérieures */
.two-col-main svg:not(.faq-question svg){max-width:24px;max-height:24px}
.sidebar-card svg{max-width:20px;max-height:20px;flex-shrink:0}
.footer-col svg{max-width:16px;max-height:16px;vertical-align:middle}

/* Picto dans feature/icon cards — fix général */
.feature-icon svg,.icon-box svg,.info-card svg{max-width:32px;max-height:32px}

/* Fix liens footer pictos */
.footer-contact a svg{width:16px;height:16px;flex-shrink:0}

@media(max-width:768px){
  .header-nav,.header-phone,.header-cta .btn-primary{display:none}
  .burger-btn{display:flex}
  .header-cta{display:none}
}
@media(max-width:1024px){
  .header-phone{display:none}
}

/* Mobile nav pages intérieures — état open */
#mobileNav{display:none;position:absolute;top:70px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);padding:0 1.5rem;z-index:999;box-shadow:var(--shadow-lg)}
#mobileNav.open{display:block;padding:1rem 1.5rem 1.5rem}
#mobileNav .btn{display:block;text-align:center;margin-top:1rem}

/* Fix pictos SVG géants pages intérieures — reset global */
svg{max-width:100%}
.content-list svg,.two-col-main p svg,.hero-inner svg.icon-lg{width:auto;height:auto}

/* Spécifique : fix icône SVG dans footer contact pages intérieures */
.footer-contact-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#94a3b8;margin-bottom:.5rem}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;stroke:#94a3b8}
.footer-contact-item a{color:#cbd5e1;text-decoration:none;transition:color var(--transition)}
.footer-contact-item a:hover{color:var(--orange)}

/* Taille SVG dans les sections de contenu pages intérieures */
.two-col-main .section-icon-wrap svg,
.reassurance-card svg,
.maillage-card svg{width:16px;height:16px}

/* Fix SVG chevron FAQ pages intérieures — taille explicite */
.faq-question svg{width:20px;height:20px;flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-question svg{transform:rotate(180deg)}

/* ── Sécurité SVG global : aucun SVG ne peut dépasser son conteneur ── */
svg{max-width:100%;height:auto}

/* Tailles explicites par contexte */
.faq-question svg{width:20px !important;height:20px !important;flex-shrink:0}
.header-logo svg,.logo-mark svg,.footer-logo svg{display:none}  /* remplacés par img */
.header-phone svg{width:16px;height:16px}
.footer-contact-item svg{width:16px;height:16px}
.footer-col a svg,.footer-bottom svg{width:14px;height:14px}
.burger-btn svg,.burger svg{width:24px;height:24px}
.maillage-card svg{width:16px;height:16px}
.scroll-top svg{width:18px;height:18px}
.btn svg{width:18px;height:18px}
.sidebar-card svg{width:18px;height:18px}
.contact-reassurance svg{width:18px;height:18px}

/* Message de succès formulaire — caché par défaut, affiché par JS après envoi */
.form-success{display:none}
.form-success.visible{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;padding:2.5rem 2rem;background:var(--orange-bg);border:1px solid var(--orange-light);border-radius:var(--radius-lg)}
.form-success h3{color:var(--orange-dark);font-size:1.1rem;margin:0}
.form-success p{color:var(--slate-700);font-size:.9rem;margin:0}
.form-success .success-icon svg{color:var(--orange)}

/* Téléphone dans nav desktop — compact */
.nav-tel{font-size:.8rem;font-weight:600;color:var(--slate-600);padding:.4rem .5rem;white-space:nowrap;display:flex;align-items:center;gap:.3rem;text-decoration:none;border-radius:var(--radius);transition:color var(--transition)}
.nav-tel:hover{color:var(--orange)}

/* Nav desktop — compresser l'espacement pour éviter wrap */
.nav-desktop{gap:0}
.nav-desktop > a,.nav-desktop .has-dropdown > a{padding:.4rem .55rem;font-size:.82rem}
.nav-desktop .btn-sm{padding:.5rem 1rem;font-size:.8rem}

/* Footer contact — style unifié (reprend footer-contact de index) */
.footer-contact a,.footer-contact span{display:block;color:#cbd5e1;font-size:.875rem;margin-bottom:.4rem;transition:color var(--transition);text-decoration:none}
.footer-contact a:hover{color:var(--orange)}
.footer-col h5,.footer-col h4{font-family:var(--font-title);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:1rem}
