/* ============================================
   Site Lead Template — CSS Premium Conversion-First
   Colors are injected via config.php in header.php
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700;9..144,900&display=swap');

/* ---- Variables (defaults — overridden by config.php via <style> in header.php) ---- */
:root {
  /* Terre Clim — palette terre & eco (vert foret + terracotta) */
  --primary: #15803D;
  --primary-dark: #14532D;
  --primary-light: #86EFAC;
  --secondary: #16A34A;
  --accent: #CB6843;
  --accent-hover: #B0542F;
  --success: #16A34A;
  --warning: #CA8A04;
  --text: #1C2A22;
  --text-muted: #4B5A50;
  --text-light: #768577;
  --bg: #FFFFFF;
  --bg-light: #F8F6F1;
  --bg-blue: #EDF4EC;
  --bg-sand: #FFFDF9;
  --bg-forest: #0E2A1A;
  --border: #E6E2D8;
  --border-light: #EFEBE1;
  --shadow-sm: 0 1px 3px rgba(20,40,25,.07);
  --shadow: 0 6px 20px rgba(20,40,25,.09);
  --shadow-lg: 0 16px 44px rgba(20,40,25,.13);
  --shadow-xl: 0 26px 64px rgba(20,40,25,.16);
  --radius: 16px;
  --radius-sm: 10px;
  --radius-lg: 26px;
  --radius-full: 9999px;
  --radius-organic: 26px 26px 26px 8px;
  --font: 'Inter', sans-serif;
  --font-heading: 'Fraunces', Georgia, 'Times New Roman', serif;
  --transition: all .2s ease;
  /* RGB triplets for rgba() usage */
  --primary-rgb: 21,128,61;
  --accent-rgb: 203,104,67;
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font); color: var(--text); background: var(--bg); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; font-family: var(--font); }

/* ---- Typography ---- */
h1, h2, h3, h4, h5 { font-family: var(--font-heading); font-weight: 700; line-height: 1.2; color: var(--text); }
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.1rem; }
p { color: var(--text-muted); line-height: 1.75; }

/* ---- Layout ---- */
.f0hy0 { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.zz0dv { max-width: 1400px; margin: 0 auto; padding: 0 20px; }
.deatx { padding: 80px 0; }
.nazv7 { padding: 50px 0; }
.pp5nm { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.g1udf { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ercs7 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }

/* ---- Buttons ---- */
.g67f2 { display: inline-flex; align-items: center; gap: 8px; padding: 14px 28px; border-radius: var(--radius-full); font-weight: 700; font-size: .95rem; transition: var(--transition); border: none; white-space: nowrap; }
.x3ctn { background: var(--accent); color: #fff; box-shadow: 0 4px 16px rgba(var(--accent-rgb),.35); }
.x3ctn:hover { background: var(--accent-hover); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(var(--accent-rgb),.45); }
.hd1v1 { background: var(--primary); color: #fff; box-shadow: 0 4px 16px rgba(var(--primary-rgb),.25); }
.hd1v1:hover { background: var(--primary-dark); transform: translateY(-2px); }
.kwcpb { background: transparent; color: var(--primary); border: 2px solid var(--primary); }
.kwcpb:hover { background: var(--primary); color: #fff; }
.ihejn { background: #fff; color: var(--primary); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.ihejn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.2); }
.bzy9h { padding: 18px 40px; font-size: 1.05rem; }
.xx6j2 { padding: 10px 20px; font-size: .85rem; }

/* ---- Badges ---- */
.m49mt { display: inline-flex; align-items: center; gap: 5px; padding: 4px 12px; border-radius: var(--radius-full); font-size: .78rem; font-weight: 600; }
.l0pel { background: rgba(46,204,113,.12); color: #27AE60; }
.szh4p { background: rgba(var(--primary-rgb),.1); color: var(--primary); }
.oiobj { background: rgba(var(--accent-rgb),.12); color: var(--accent); }
.be5qu { background: rgba(243,156,18,.12); color: var(--warning); }

/* ---- Cards ---- */
.jlvwp { background: #fff; border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px; transition: var(--transition); }
.jlvwp:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.g4b4e { border: 1px solid var(--border); box-shadow: none; }
.g4b4e:hover { border-color: var(--primary-light); box-shadow: var(--shadow); }

/* ---- Header ---- */
.ah05l { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.95); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); transition: var(--transition); }
.ah05l.scrolled { box-shadow: var(--shadow); }
.c6suo { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.r9gy0 { display: flex; align-items: center; gap: 10px; font-family: var(--font-heading); font-size: 1.35rem; font-weight: 800; color: var(--primary); }
.es72z { width: 38px; height: 38px; background: linear-gradient(135deg, var(--primary), var(--secondary)); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.es72z svg { color: #fff; }
.hcqe0 { display: flex; align-items: center; gap: 20px; }
.hcqe0 a { font-weight: 500; font-size: .9rem; color: var(--text-muted); transition: var(--transition); }
.hcqe0 a:hover { color: var(--primary); }

/* Dropdown */
.l0mc7 { position: relative; display: flex; align-items: center; height: 100%; }
.l0mc7 .oh5q5 {
  display: none; position: absolute; top: 100%; left: -20px;
  background: #fff; box-shadow: var(--shadow-lg); border-radius: var(--radius);
  padding: 10px 0; min-width: 250px; border: 1px solid var(--border);
}
.l0mc7:hover .oh5q5 { display: block; }
.oh5q5 a { display: block; padding: 10px 20px; font-size: 0.9rem; color: var(--text); border-bottom: none!important; }
.oh5q5 a:hover { background: var(--bg-light); color: var(--primary); }

.haxpn { display: flex; align-items: center; gap: 12px; }
.nd4rz { font-weight: 700; color: var(--primary); font-size: .95rem; display: flex; align-items: center; gap: 6px; }

/* Mobile nav */
.l062x { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 8px; }
.l062x span { width: 24px; height: 2px; background: var(--text); border-radius: 2px; transition: var(--transition); }
.naigp { display: none; background: #fff; border-top: 1px solid var(--border); padding: 20px; }
.naigp.open { display: block; }
.naigp a { display: block; padding: 12px 0; font-weight: 500; border-bottom: 1px solid var(--border-light); color: var(--text-muted); }
.naigp a:last-child { border-bottom: none; }

/* ---- Hero ---- */
.iejqt { background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 50%, var(--primary-light) 100%); position: relative; overflow: hidden; padding: 100px 0 80px; }
.iejqt::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.narxd { position: relative; z-index: 1; }
.ojt5x { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,.15); color: #fff; padding: 6px 16px; border-radius: var(--radius-full); font-size: .85rem; font-weight: 600; margin-bottom: 20px; border: 1px solid rgba(255,255,255,.2); }
.iejqt h1 { color: #fff; margin-bottom: 20px; text-shadow: 0 2px 8px rgba(0,0,0,.2); }
.iejqt h1 span { color: var(--primary-light); }
.m43sx { font-size: 1.15rem; color: rgba(255,255,255,.85); max-width: 580px; margin-bottom: 36px; }
.bioyp { display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 48px; }
.vmlno { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.m3s1m { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,.9); font-size: .875rem; font-weight: 500; }
.m3s1m svg { color: var(--success); }
.m3d2y { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-xl); position: relative; }
.m3d2y img { width: 100%; height: 420px; object-fit: cover; }
.m8m1n { position: absolute; bottom: 20px; left: 20px; background: #fff; border-radius: var(--radius); padding: 14px 18px; box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 12px; }
.lxpfa { width: 44px; height: 44px; background: linear-gradient(135deg, var(--primary), var(--secondary)); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.pqgts strong { display: block; font-weight: 700; color: var(--text); font-size: .9rem; }
.pqgts span { font-size: .78rem; color: var(--text-muted); }

/* ---- Stats ---- */
.qfb2u { background: #fff; border-bottom: 1px solid var(--border); }
.okqb7 { display: grid; grid-template-columns: repeat(4, 1fr); }
.g624p { text-align: center; padding: 28px 20px; border-right: 1px solid var(--border); }
.g624p:last-child { border-right: none; }
.iiahy { font-family: var(--font-heading); font-size: 2.2rem; font-weight: 800; color: var(--primary); line-height: 1; }
.iiahy span { font-size: 1.4rem; }
.ncobo { font-size: .82rem; color: var(--text-muted); margin-top: 4px; font-weight: 500; }

/* ---- Search widget ---- */
.hxsu1 { background: var(--bg-light); padding: 50px 0; }
.ofnmy { background: #fff; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 36px 40px; max-width: 800px; margin: 0 auto; }
.ofnmy h2 { text-align: center; font-size: 1.6rem; margin-bottom: 8px; }
.ofnmy p { text-align: center; color: var(--text-muted); margin-bottom: 28px; }
.azcdx { display: flex; gap: 12px; }
.cy2ma { flex: 1; padding: 14px 20px; border: 2px solid var(--border); border-radius: var(--radius-full); font-size: .95rem; font-family: var(--font); outline: none; transition: var(--transition); }
.cy2ma:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(var(--primary-rgb),.1); }
.ae722 { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.fqdmh { padding: 6px 14px; background: var(--bg-blue); color: var(--primary); border-radius: var(--radius-full); font-size: .82rem; font-weight: 500; transition: var(--transition); cursor: pointer; border: 1px solid rgba(var(--primary-rgb),.15); }
.fqdmh:hover { background: var(--primary); color: #fff; }

/* ---- Services ---- */
.aq9d3 { background: #fff; border-radius: var(--radius); padding: 32px 28px; border: 1px solid var(--border); transition: var(--transition); }
.aq9d3:hover { border-color: var(--primary); box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.g5jbq { width: 56px; height: 56px; border-radius: var(--radius); background: var(--bg-blue); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.g5jbq svg { color: var(--primary); }
.aq9d3 h3 { margin-bottom: 10px; font-size: 1.1rem; }
.aq9d3 p { font-size: .9rem; }
.aq9d3 .pqjct { display: inline-block; margin-top: 14px; font-weight: 700; color: var(--accent); font-size: .95rem; }

/* ---- Why us ---- */
.kuib5 { background: linear-gradient(135deg, var(--bg-light) 0%, var(--bg-blue) 100%); }
.kvp29 { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.kvp29.l20q3 { direction: rtl; }
.kvp29.l20q3 > * { direction: ltr; }
.h8tiu { display: flex; flex-direction: column; gap: 20px; }
.c37dh { display: flex; gap: 16px; align-items: flex-start; }
.tsr0d { width: 44px; height: 44px; border-radius: 10px; background: linear-gradient(135deg, var(--primary), var(--secondary)); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.tsr0d svg { color: #fff; }
.c37dh h4 { margin-bottom: 4px; }
.c37dh p { font-size: .88rem; }
.iiaoj { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-xl); }
.iiaoj img { width: 100%; height: 380px; object-fit: cover; }

/* ---- Process steps ---- */
.g7fym { background: #fff; }
.b7j8x { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; position: relative; }
.b7j8x::before { content: ''; position: absolute; top: 40px; left: calc(12.5% + 20px); right: calc(12.5% + 20px); height: 2px; background: linear-gradient(90deg, var(--primary-light), var(--secondary)); z-index: 0; }
.qfmaw { text-align: center; padding: 0 20px; position: relative; z-index: 1; }
.krkah { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--secondary)); color: #fff; font-family: var(--font-heading); font-size: 1.6rem; font-weight: 800; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; box-shadow: 0 8px 24px rgba(var(--primary-rgb),.35); }
.qfmaw h4 { margin-bottom: 8px; }
.qfmaw p { font-size: .875rem; }

/* ---- Regions ---- */
.ogk6o { background: var(--bg-light); }
.arfpj { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
.g56ny { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 14px 18px; transition: var(--transition); display: flex; align-items: center; justify-content: space-between; }
.g56ny:hover { border-color: var(--primary); background: var(--bg-blue); color: var(--primary); }
.g56ny span { font-size: .88rem; font-weight: 500; }
.g56ny svg { color: var(--primary-light); flex-shrink: 0; }

/* ---- Testimonials ---- */
.lf9ow { background: linear-gradient(135deg, var(--primary-dark), var(--primary)); overflow: hidden; }
.lf9ow h2 { color: #fff; text-align: center; margin-bottom: 8px; }
.lf9ow .wyqq5 { color: rgba(255,255,255,.75); text-align: center; margin-bottom: 48px; }
.lxplg { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15); backdrop-filter: blur(10px); border-radius: var(--radius); padding: 28px; }
.g1gm8 { display: flex; gap: 4px; margin-bottom: 14px; }
.g1gm8 svg { color: #FFD700; }
.haco8 { color: rgba(255,255,255,.9); font-size: .95rem; font-style: italic; margin-bottom: 18px; line-height: 1.7; }
.g1i5a { display: flex; align-items: center; gap: 12px; }
.g1w62 { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--secondary), var(--primary-light)); display: flex; align-items: center; justify-content: center; font-weight: 700; color: #fff; font-size: .95rem; }
.m666y strong { display: block; color: #fff; font-size: .9rem; }
.m666y span { color: rgba(255,255,255,.65); font-size: .8rem; }

/* ---- Trust ---- */
.josab { background: #fff; }
.azykn { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.co4lx { text-align: center; padding: 32px 24px; border-radius: var(--radius); border: 2px solid var(--border); transition: var(--transition); }
.co4lx:hover { border-color: var(--success); background: rgba(46,204,113,.04); }
.yunrg { width: 64px; height: 64px; background: rgba(46,204,113,.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.yunrg svg { color: var(--success); }
.co4lx h3 { font-size: 1rem; margin-bottom: 8px; }
.co4lx p { font-size: .875rem; }

/* ---- FAQ ---- */
.g4b2j { background: var(--bg-light); }
.jnmxo { max-width: 760px; margin: 0 auto; }
.okq9b { background: #fff; border-radius: var(--radius-sm); margin-bottom: 12px; border: 1px solid var(--border); overflow: hidden; transition: var(--transition); }
.okq9b.open { border-color: var(--primary-light); box-shadow: var(--shadow-sm); }
.ic3ec { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; cursor: pointer; gap: 16px; }
.ic3ec h4 { font-size: .95rem; font-weight: 600; color: var(--text); flex: 1; }
.nbt1i { width: 32px; height: 32px; border-radius: 50%; background: var(--bg-light); border: none; display: flex; align-items: center; justify-content: center; transition: var(--transition); flex-shrink: 0; }
.okq9b.open .nbt1i { background: var(--primary); }
.okq9b.open .nbt1i svg { color: #fff; transform: rotate(45deg); }
.nbt1i svg { color: var(--text-muted); transition: var(--transition); }
.pmo3a { padding: 0 24px 20px; display: none; }
.okq9b.open .pmo3a { display: block; }
.pmo3a p { font-size: .9rem; }

/* ---- CTA Section ---- */
.gxl8o { background: linear-gradient(135deg, var(--accent) 0%, #FF8C42 100%); padding: 80px 0; overflow: hidden; position: relative; }
.gxl8o::before { content: ''; position: absolute; right: -100px; top: -100px; width: 400px; height: 400px; border-radius: 50%; background: rgba(255,255,255,.08); }
.jy4k0 { text-align: center; position: relative; z-index: 1; }
.jy4k0 h2 { color: #fff; margin-bottom: 12px; }
.jy4k0 p { color: rgba(255,255,255,.85); font-size: 1.1rem; margin-bottom: 36px; max-width: 560px; margin-left: auto; margin-right: auto; }
.nalf0 { display: flex; gap: 12px; max-width: 520px; margin: 0 auto 20px; }
.ifm86 { flex: 1; padding: 14px 20px; border: none; border-radius: var(--radius-full); font-size: .95rem; outline: none; }
.sbcp0 { color: rgba(255,255,255,.7); font-size: .8rem; text-align: center; }

/* ---- Footer ---- */
.hdor4 { background: #0A1628; color: rgba(255,255,255,.75); }
.hbcur { padding: 60px 0 40px; }
.ku44o { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
.lzpsi .r9gy0 { color: #fff; margin-bottom: 16px; }
.lzpsi p { font-size: .875rem; line-height: 1.7; }
.m2xo0 h4 { color: #fff; font-size: .9rem; font-weight: 700; margin-bottom: 16px; text-transform: uppercase; letter-spacing: .05em; }
.m2xo0 ul li { margin-bottom: 8px; }
.m2xo0 ul li a { font-size: .85rem; transition: var(--transition); }
.m2xo0 ul li a:hover { color: var(--secondary); }
.lzu2x { margin-top: 20px; }
.l0yva { display: inline-flex; align-items: center; gap: 8px; background: rgba(46,204,113,.15); border: 1px solid rgba(46,204,113,.3); border-radius: var(--radius-sm); padding: 8px 14px; font-size: .8rem; color: #2ECC71; font-weight: 600; margin-right: 8px; margin-bottom: 8px; }
.t0cs0 { border-top: 1px solid rgba(255,255,255,.1); padding: 20px 0; }
.job8i { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.t0cs0 p { font-size: .8rem; }
.jk8tk { display: flex; gap: 20px; }
.jk8tk a { font-size: .8rem; transition: var(--transition); }
.jk8tk a:hover { color: #fff; }

/* ---- Page content ---- */
.g326s { background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%); padding: 60px 0 50px; }
.a7fyq { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.laz1i { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.laz1i a { color: rgba(255,255,255,.7); font-size: .85rem; transition: var(--transition); }
.laz1i a:hover { color: #fff; }
.laz1i span { color: rgba(255,255,255,.4); font-size: .85rem; }
.laz1i .current { color: rgba(255,255,255,.9); font-size: .85rem; }
.g326s h1 { color: #fff; margin-bottom: 12px; }
.g326s .jla4q { color: rgba(255,255,255,.8); font-size: 1.05rem; max-width: 680px; }
.g326s .b1oq9 { display: flex; align-items: center; gap: 16px; margin-top: 20px; flex-wrap: wrap; }
.yv0wr { display: flex; align-items: center; gap: 6px; color: rgba(255,255,255,.85); font-size: .875rem; }

/* ---- Listing ---- */
.g29a2 { padding: 60px 0; }
.oj5qz { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.g1i71 { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; transition: var(--transition); display: flex; flex-direction: column; }
.g1i71:hover { border-color: var(--primary); box-shadow: var(--shadow); transform: translateY(-2px); }
.jm61a { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; }
.g1i71 h3 { font-size: 1rem; font-weight: 700; }
.g1i71 p { font-size: .85rem; margin-bottom: 14px; flex: 1; }
.g22wc { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 14px; border-top: 1px solid var(--border-light); }
.nbkwu { font-size: .85rem; font-weight: 600; color: var(--primary); display: flex; align-items: center; gap: 4px; transition: var(--transition); }
.nbkwu:hover { gap: 8px; }

/* ---- Sidebar layout ---- */
.ar5st { display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start; }
.br9d9 { position: sticky; top: 90px; }
.hcarj { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; margin-bottom: 20px; }
.hcarj h3 { font-size: 1rem; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid var(--primary); color: var(--primary); }
.gzqyw .pnj8u { margin-bottom: 14px; }
.gzqyw label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: 6px; color: var(--text); }
.gzqyw input, .gzqyw select, .gzqyw textarea { width: 100%; padding: 11px 14px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font-size: .9rem; font-family: var(--font); outline: none; transition: var(--transition); }
.gzqyw input:focus, .gzqyw select:focus, .gzqyw textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(var(--primary-rgb),.1); }
.gzqyw textarea { resize: vertical; min-height: 100px; }
.oix4g { background: linear-gradient(135deg, var(--accent), #FF8C42); border-radius: var(--radius-sm); padding: 14px 16px; margin-bottom: 16px; text-align: center; }
.oix4g p { color: #fff; font-size: .85rem; font-weight: 600; margin: 0; }
.kw146 { text-align: center; padding: 20px; background: var(--bg-blue); border-radius: var(--radius-sm); border: 1px solid rgba(var(--primary-rgb),.15); }
.kw146 .bi4sj { font-family: var(--font-heading); font-size: 1.5rem; font-weight: 800; color: var(--primary); display: flex; align-items: center; justify-content: center; gap: 8px; }
.kw146 p { font-size: .8rem; color: var(--text-muted); margin-top: 4px; }

/* ---- Content sections ---- */
.lyyee { margin-bottom: 36px; }
.lyyee h2 { font-size: 1.4rem; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 2px solid var(--border-light); }
.ojwup { display: flex; flex-direction: column; gap: 8px; }
.ojwup li { display: flex; gap: 10px; align-items: flex-start; font-size: .9rem; color: var(--text-muted); }
.ojwup li::before { content: ''; width: 20px; height: 20px; background: rgba(46,204,113,.15); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ojwup li svg { flex-shrink: 0; color: var(--success); margin-top: 2px; }
.olhjd { background: var(--bg-blue); border: 1px solid rgba(var(--primary-rgb),.2); border-left: 4px solid var(--primary); border-radius: var(--radius-sm); padding: 16px 18px; margin: 16px 0; }
.olhjd p { font-size: .875rem; margin: 0; color: var(--text); }
.g2g86 { background: rgba(243,156,18,.08); border: 1px solid rgba(243,156,18,.3); border-left: 4px solid var(--warning); border-radius: var(--radius-sm); padding: 16px 18px; margin: 16px 0; }
.g2g86 p { font-size: .875rem; margin: 0; color: var(--text); }

/* ===== Contenu SEO des pages service (.iezpc) ===== */
.iezpc { font-size: .98rem; color: var(--text-muted); }
.iezpc h2 {
  font-size: 1.5rem; line-height: 1.25; color: var(--text); font-weight: 800;
  margin: 36px 0 14px; padding: 2px 0 2px 14px; border-left: 4px solid var(--primary);
}
.iezpc h2:first-child { margin-top: 0; }
.iezpc h3 { font-size: 1.15rem; color: var(--primary-dark); font-weight: 700; margin: 26px 0 10px; }
.iezpc p { margin: 0 0 16px; line-height: 1.8; }
.iezpc > p:first-of-type { font-size: 1.08rem; color: var(--text); }
.iezpc strong { color: var(--text); font-weight: 600; }
.iezpc a { color: var(--primary); text-decoration: none; border-bottom: 1px solid rgba(var(--primary-rgb),.35); transition: color .15s, border-color .15s; }
.iezpc a:hover { color: var(--accent); border-bottom-color: var(--accent); }
.iezpc ul { list-style: none; padding: 0; margin: 20px 0; display: grid; gap: 10px; }
@media (min-width: 720px) { .iezpc ul { grid-template-columns: 1fr 1fr; } }
.iezpc li {
  position: relative; padding: 13px 16px 13px 46px;
  background: var(--bg-light); border: 1px solid var(--border-light);
  border-radius: var(--radius); line-height: 1.55; font-size: .92rem; color: var(--text);
}
.iezpc li::before {
  content: "✓"; position: absolute; left: 14px; top: 12px;
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(var(--primary-rgb),.12); color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 800;
}
.ha7tq { width: 100%; border-collapse: collapse; margin: 16px 0; }
.ha7tq th { background: var(--primary); color: #fff; padding: 12px 16px; text-align: left; font-size: .875rem; }
.ha7tq td { padding: 10px 16px; border-bottom: 1px solid var(--border); font-size: .875rem; }
.ha7tq tr:hover td { background: var(--bg-blue); }
.a5phi { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px; margin-top: 12px; }
.hczsq { background: var(--bg-light); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 8px 12px; font-size: .82rem; font-weight: 500; text-align: center; transition: var(--transition); color: var(--text-muted); }
.hczsq:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ---- Pagination ---- */
.yvo68 { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 48px; }
.awefr { width: 40px; height: 40px; border-radius: var(--radius-sm); border: 1px solid var(--border); background: #fff; display: flex; align-items: center; justify-content: center; font-size: .875rem; font-weight: 500; color: var(--text-muted); transition: var(--transition); cursor: pointer; }
.awefr:hover, .awefr.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.awefr.disabled { opacity: .4; cursor: not-allowed; }

/* ---- Department grid ---- */
.jp9w5 { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 16px 20px; display: flex; align-items: center; gap: 12px; transition: var(--transition); }
.jp9w5:hover { border-color: var(--primary); background: var(--bg-blue); }
.a5hm6 { width: 40px; height: 40px; background: linear-gradient(135deg, var(--primary), var(--secondary)); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: .8rem; flex-shrink: 0; }
.kqevw { flex: 1; }
.kqevw strong { display: block; font-size: .9rem; font-weight: 600; }
.kqevw span { font-size: .78rem; color: var(--text-muted); }

/* ---- Section headers ---- */
.ohklg { text-align: center; margin-bottom: 48px; }
.ohklg h2 { margin-bottom: 10px; }
.ohklg p { font-size: 1.05rem; max-width: 600px; margin: 0 auto; }
.ii3gu { display: inline-block; color: var(--primary); font-weight: 700; font-size: .85rem; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }

/* ---- Reveal animations ---- */
.l0v9u { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .6s ease; }
.l0v9u.revealed { opacity: 1; transform: translateY(0); }
.l0v9u.xfg9e { transition-delay: .1s; }
.l0v9u.m366v { transition-delay: .2s; }
.l0v9u.iivmn { transition-delay: .3s; }

/* ---- Utilities ---- */
.jo7fl { text-align: center; }
.pp94c { color: var(--primary); }
.u3cup { color: var(--accent); }
.b9l8u { color: var(--success); }
.w0ueo { margin-top: 16px; }
.jnvfw { margin-top: 32px; }
.h8sgt { margin-bottom: 16px; }
.g1tsa { margin-bottom: 32px; }
.af4oh { display: flex; }
.g4lgr { gap: 8px; }
.ppj0v { gap: 16px; }
.g3gu0 { align-items: center; }
.d6ske { flex-wrap: wrap; }

/* ---- Floating CTA ---- */
.hcjic { position: fixed; bottom: 24px; right: 24px; z-index: 999; }
.j0avj { display: flex; align-items: center; gap: 10px; background: var(--accent); color: #fff; padding: 14px 22px; border-radius: var(--radius-full); font-weight: 700; font-size: .9rem; box-shadow: 0 8px 32px rgba(var(--accent-rgb),.45); transition: var(--transition); animation: pulse 2.5s ease-in-out infinite; }
.j0avj:hover { transform: scale(1.05); animation: none; }
@keyframes pulse { 0%, 100% { box-shadow: 0 8px 32px rgba(var(--accent-rgb),.45); } 50% { box-shadow: 0 8px 40px rgba(var(--accent-rgb),.7); } }

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .ercs7 { grid-template-columns: repeat(2, 1fr); }
  .ku44o { grid-template-columns: 1fr 1fr; gap: 32px; }
  .ar5st { grid-template-columns: 1fr; }
  .br9d9 { position: static; }
  .b7j8x { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .b7j8x::before { display: none; }
  .kvp29 { grid-template-columns: 1fr; gap: 40px; }
  .kvp29.l20q3 { direction: ltr; }
  .okqb7 { grid-template-columns: repeat(2, 1fr); }
  .g624p:nth-child(2) { border-right: none; }
}

@media (max-width: 768px) {
  .deatx { padding: 60px 0; }
  .hcqe0, .haxpn { display: none; }
  .l062x { display: flex; }
  .pp5nm, .g1udf { grid-template-columns: 1fr; }
  .iejqt { padding: 70px 0 60px; }
  .bioyp { flex-direction: column; }
  .bioyp .g67f2 { width: 100%; justify-content: center; }
  .b7j8x { grid-template-columns: 1fr; }
  .azykn { grid-template-columns: 1fr; }
  .azcdx { flex-direction: column; }
  .nalf0 { flex-direction: column; }
  .oj5qz { grid-template-columns: 1fr; }
  .arfpj { grid-template-columns: repeat(2, 1fr); }
  .ku44o { grid-template-columns: 1fr; gap: 24px; }
  .job8i { flex-direction: column; text-align: center; }
  .hcjic { bottom: 16px; left: 50%; right: auto; transform: translateX(-50%); }
  .j0avj { padding: 13px 24px; font-size: .88rem; white-space: nowrap; }
  .ofnmy .g67f2 { width: 100%; justify-content: center; }
  .g67f2 { white-space: normal; text-align: center; justify-content: center; }
}

@media (max-width: 480px) {
  .okqb7 { grid-template-columns: repeat(2, 1fr); }
  .arfpj { grid-template-columns: 1fr; }
  .a5phi { grid-template-columns: repeat(2, 1fr); }
}
/* ============================================================================
   TERRE CLIM — DESIGN FORK (override block, identite "terre & eco")
   Refonte visuelle propre au site : titres serif Fraunces, hero clair organique,
   cartes chaleureuses, fonds sable, footer vert foret. Cascade : ce bloc gagne.
   ============================================================================ */

/* ---- Typographie serif editoriale ---- */
h1, h2, h3 { letter-spacing: -.015em; font-weight: 600; }
h1 { font-weight: 600; }
.ii3gu { font-family: var(--font); }

/* ---- Boutons : pilules terreuses, ombres douces ---- */
.g67f2 { font-family: var(--font); letter-spacing: .005em; }
.x3ctn { box-shadow: 0 8px 22px rgba(var(--accent-rgb),.30); }
.x3ctn:hover { box-shadow: 0 12px 30px rgba(var(--accent-rgb),.40); }
.kwcpb { border-width: 1.5px; }

/* ---- Header / logo ---- */
.ah05l { background: rgba(248,246,241,.88); border-bottom: 1px solid var(--border); }
.es72z { border-radius: 12px 12px 12px 4px; box-shadow: 0 6px 16px rgba(var(--primary-rgb),.28); }

/* ============================ HERO CLAIR ORGANIQUE ======================== */
.iejqt {
  background: radial-gradient(120% 120% at 85% 0%, #EAF3E6 0%, var(--bg-light) 46%, var(--bg-sand) 100%);
  padding: 96px 0 96px;
}
/* Formes organiques (feuille/galets) en decor, douces et discretes */
.iejqt::before {
  content: ''; position: absolute; top: -120px; right: -100px;
  width: 460px; height: 460px; border-radius: 58% 42% 47% 53% / 55% 50% 50% 45%;
  background: radial-gradient(circle at 35% 35%, rgba(22,163,74,.16), rgba(22,163,74,.05) 60%, transparent 72%);
  filter: blur(2px); z-index: 0;
}
.iejqt::after {
  content: ''; position: absolute; bottom: -90px; left: -70px;
  width: 280px; height: 280px; border-radius: 46% 54% 60% 40% / 52% 44% 56% 48%;
  background: radial-gradient(circle at 50% 50%, rgba(203,104,67,.14), rgba(203,104,67,.04) 60%, transparent 74%);
  z-index: 0;
}
.iejqt .f0hy0 { position: relative; z-index: 1; }
.iejqt h1 { color: var(--primary-dark); text-shadow: none; line-height: 1.08; }
.iejqt h1 span { color: var(--accent); position: relative; white-space: nowrap; }
/* Soulignement organique sous le mot cle */
.iejqt h1 span::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -.08em; height: .28em;
  background: rgba(var(--accent-rgb),.18); border-radius: 0 8px 8px 8px; z-index: -1;
}
.m43sx { color: var(--text-muted); }
.m43sx strong { color: var(--primary-dark) !important; }
.ojt5x {
  background: #fff; color: var(--primary-dark); border: 1px solid rgba(var(--primary-rgb),.22);
  box-shadow: var(--shadow-sm);
}
.ojt5x svg { color: var(--primary); }
.m3s1m { color: var(--text-muted); }
.m3d2y { border-radius: var(--radius-lg) var(--radius-lg) var(--radius-lg) 60px; box-shadow: var(--shadow-xl); }
.m3d2y img { height: 460px; }
.m8m1n { border-radius: 16px 16px 16px 4px; }
.lxpfa { border-radius: 10px 10px 10px 3px; }

/* ---- Ruban "eco" sous le hero (markup index.php) ---- */
.pqcgb {
  display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px;
}
.m67mg {
  display: inline-flex; align-items: center; gap: 10px;
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--radius-full); padding: 10px 18px;
  box-shadow: var(--shadow-sm); font-size: .9rem; font-weight: 600; color: var(--primary-dark);
}
.m67mg svg { color: var(--accent); flex-shrink: 0; }
.m67mg strong { color: var(--accent); font-weight: 800; }

/* ============================ STATS ====================================== */
.qfb2u { background: var(--bg-sand); border-bottom: 1px solid var(--border); }
.g624p { border-right: 1px solid var(--border); }
.iiahy { color: var(--primary); }

/* ============================ SEARCH ===================================== */
.hxsu1 { background: var(--bg-light); }
.ofnmy { border-radius: var(--radius-lg); border: 1px solid var(--border); box-shadow: var(--shadow-lg); }
.cy2ma { border-radius: var(--radius-full); }
.fqdmh { background: var(--bg-blue); border: 1px solid rgba(var(--primary-rgb),.18); }

/* ============================ SERVICES (cartes organiques) =============== */
.deatx { background: var(--bg-sand); }
.aq9d3 {
  border-radius: var(--radius); border: 1px solid var(--border);
  box-shadow: var(--shadow-sm); position: relative; overflow: hidden; background: #fff;
}
.aq9d3::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
.aq9d3:hover { border-color: rgba(var(--primary-rgb),.45); box-shadow: var(--shadow-lg); }
.aq9d3:hover::before { transform: scaleX(1); }
.g5jbq {
  width: 58px; height: 58px; border-radius: 16px 16px 16px 5px;
  background: linear-gradient(135deg, rgba(var(--primary-rgb),.12), rgba(var(--accent-rgb),.10));
}
.g5jbq svg { color: var(--primary); }

/* ============================ WHY US ===================================== */
.kuib5 { background: linear-gradient(160deg, var(--bg-light) 0%, #E9F1E6 100%); }
.tsr0d { border-radius: 12px 12px 12px 4px; background: linear-gradient(135deg, var(--primary), var(--secondary)); }
.iiaoj { border-radius: var(--radius-lg) 60px var(--radius-lg) var(--radius-lg); }

/* ============================ PROCESS ==================================== */
.g7fym { background: var(--bg-sand); }
.b7j8x::before { background: linear-gradient(90deg, var(--primary-light), var(--accent)); opacity: .6; }
.krkah {
  border-radius: 50% 50% 50% 12px;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  box-shadow: 0 10px 26px rgba(var(--primary-rgb),.32);
}

/* ============================ AIDES / ECONOMIES ========================== */
.oiln8 { color: var(--accent) !important; }
.olhjd { background: #FCF3EC; border-color: rgba(var(--accent-rgb),.25); border-left-color: var(--accent); }

/* ============================ REGIONS ==================================== */
.ogk6o { background: var(--bg-light); }
.g56ny { border-radius: var(--radius-sm); }
.g56ny:hover { background: var(--bg-blue); border-color: var(--primary); color: var(--primary-dark); }

/* ============================ TESTIMONIALS (vert foret) ================== */
.lf9ow { background: linear-gradient(160deg, var(--primary-dark) 0%, #16432A 100%); }
.lf9ow .aey7a { color: var(--primary-light) !important; }
.lxplg { border-radius: var(--radius); }
.g1w62 { border-radius: 50% 50% 50% 8px; background: linear-gradient(135deg, var(--secondary), var(--primary-light)); color: var(--primary-dark); }

/* ============================ TRUST ===================================== */
.josab { background: var(--bg-sand); }
.co4lx { border-radius: var(--radius); border-width: 1.5px; }
.co4lx:hover { border-color: var(--primary); background: rgba(var(--primary-rgb),.04); }
.yunrg { border-radius: 50% 50% 50% 10px; background: rgba(var(--primary-rgb),.10); }
.yunrg svg { color: var(--primary); }

/* ============================ FAQ ====================================== */
.g4b2j { background: var(--bg-light); }
.okq9b { border-radius: var(--radius-sm); }
.okq9b.open { border-color: var(--primary); }

/* ============================ FOOTER (vert foret) ======================= */
.hdor4 { background: var(--bg-forest); }
.l0yva { background: rgba(var(--primary-rgb),.18); border-color: rgba(var(--primary-rgb),.35); color: var(--primary-light); }
.m2xo0 ul li a:hover { color: var(--primary-light); }

/* ============================ PAGE HERO (pages internes, vert foret) ===== */
.g326s { background: linear-gradient(150deg, var(--primary-dark) 0%, var(--primary) 100%); }
.iezpc h2 { font-family: var(--font-heading); }

/* ============================ RESPONSIVE ================================ */
@media (max-width: 768px) {
  .iejqt { padding: 64px 0 64px; }
  .m3d2y img { height: 320px; }
  .iejqt::before { width: 280px; height: 280px; top: -80px; right: -80px; }
}
