/* Jardins & Co — feuille de style partagée */
:root{--vert:#1F3D2B;--vert2:#2c5a3e;--sauge:#8DA47E;--terra:#C46A4B;--terra-d:#a9512f;--ciel:#CFE3E6;--creme:#F2F0E6;--max:1180px}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Quicksand",system-ui,sans-serif;color:var(--vert);background:var(--creme);line-height:1.7;font-weight:500;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.serif{font-family:"Source Serif 4",Georgia,serif}
h1,h2,h3,h4{font-family:"Source Serif 4",Georgia,serif;font-weight:600;line-height:1.1}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

.demo-bar{background:var(--vert);color:var(--creme);font-size:13px;text-align:center;padding:8px 14px}
.demo-bar a{color:var(--ciel);text-decoration:underline;font-weight:600}

.btn{display:inline-flex;align-items:center;gap:9px;background:var(--terra);color:#fff;font-weight:700;
  padding:14px 30px;border:none;cursor:pointer;font-size:15px;font-family:"Quicksand",sans-serif;border-radius:40px;
  transition:transform .2s,box-shadow .2s}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px -10px rgba(196,106,75,.6)}
.btn.green{background:var(--vert)}
.btn.ghost{background:transparent;color:var(--vert);box-shadow:inset 0 0 0 2px var(--vert)}
.btn.ghost:hover{background:var(--vert);color:var(--creme)}
.btn.sm{padding:11px 22px;font-size:14px}

/* nav douce, ronde, flottante + menus déroulants */
header{position:sticky;top:14px;z-index:50;margin:14px auto 0;max-width:var(--max);padding:0 28px}
.nav{background:rgba(242,240,230,.9);backdrop-filter:blur(10px);border:1px solid #dfe0cf;border-radius:50px;
  display:flex;align-items:center;justify-content:space-between;padding:10px 12px 10px 22px;box-shadow:0 10px 30px -18px rgba(31,61,43,.4)}
.logo{display:flex;align-items:center;gap:10px;font-family:"Source Serif 4",serif;font-weight:600;font-size:20px;flex:none}
.logo svg{width:30px;height:30px}
.navlinks{display:flex;gap:22px;align-items:center;margin-left:auto;margin-right:14px}
.navlinks a{font-size:14px;font-weight:600;color:var(--vert2)}
.navlinks a:hover,.navlinks a.active{color:var(--terra)}
.has-drop{position:relative}
.has-drop>button{background:none;border:none;font:inherit;font-size:14px;font-weight:600;color:var(--vert2);cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.has-drop>button:hover{color:var(--terra)}
.drop{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);min-width:230px;background:#fff;border:1px solid #dfe0cf;
  border-radius:18px;padding:10px;box-shadow:0 20px 40px -20px rgba(31,61,43,.45);opacity:0;visibility:hidden;transition:.2s;display:grid;gap:2px}
.has-drop:hover .drop,.has-drop:focus-within .drop,.drop.open{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{padding:9px 14px;border-radius:12px;font-size:14px;color:var(--vert)}
.drop a:hover{background:var(--creme);color:var(--terra)}
.burger{display:none;background:none;border:none;font-size:22px;color:var(--vert);cursor:pointer;padding:6px 10px}

/* sections */
.wave{display:block;width:100%;height:70px}
section{padding:80px 0}
.lab{display:inline-flex;align-items:center;gap:8px;color:var(--terra);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px}
h2.sec{font-size:clamp(30px,4.5vw,52px)}

/* HERO accueil */
.hero{position:relative;padding:70px 0 40px;overflow:hidden}
.hero .blob1{position:absolute;width:520px;height:520px;background:var(--sauge);opacity:.35;top:-160px;right:-120px;border-radius:42% 58% 63% 37%/41% 44% 56% 59%;filter:blur(10px);z-index:0}
.hero .blob2{position:absolute;width:360px;height:360px;background:var(--ciel);opacity:.5;bottom:-120px;left:-100px;border-radius:60% 40% 47% 53%/52% 51% 49% 48%;z-index:0}
.hero .inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero .kick{display:inline-flex;align-items:center;gap:8px;background:#e4ead9;color:var(--vert);font-weight:700;font-size:13px;padding:7px 16px;border-radius:30px;margin-bottom:18px}
.hero h1{font-size:clamp(40px,6.5vw,76px);letter-spacing:-.01em}
.hero h1 em{color:var(--terra);font-style:italic}
.hero p{font-size:19px;color:var(--vert2);max-width:44ch;margin:20px 0 28px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
.hero .heroimg{position:relative}
.hero .heroimg img{width:100%;height:520px;object-fit:cover;border-radius:48% 52% 52% 48%/58% 56% 44% 42%}
.hero .heroimg .leaf{position:absolute;font-size:46px;animation:sway 5s ease-in-out infinite}
.hero .heroimg .l1{top:-10px;left:10px}.hero .heroimg .l2{bottom:10px;right:0;animation-delay:-2s}
@keyframes sway{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}

/* page hero (pages internes) */
.phero{position:relative;padding:54px 0 34px;overflow:hidden}
.phero .blob1{position:absolute;width:380px;height:380px;background:var(--sauge);opacity:.28;top:-150px;right:-90px;border-radius:42% 58% 63% 37%/41% 44% 56% 59%;z-index:0}
.crumb{position:relative;z-index:2;font-size:13px;color:var(--sauge);font-weight:600;margin-bottom:14px}
.crumb a:hover{color:var(--terra)}
.phero h1{position:relative;z-index:2;font-size:clamp(34px,5.5vw,60px);max-width:18ch}
.phero h1 em{color:var(--terra);font-style:italic}
.phero p{position:relative;z-index:2;font-size:18px;color:var(--vert2);max-width:54ch;margin-top:16px}
.phero .cta{position:relative;z-index:2;margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}

/* services blobs */
.serv{background:#fff}
.scards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:40px}
.scard{text-align:center;padding:14px;display:block;color:inherit}
.scard .ic{width:96px;height:96px;margin:0 auto 18px;background:var(--ciel);display:flex;align-items:center;justify-content:center;font-size:42px;border-radius:46% 54% 60% 40%/52% 46% 54% 48%;transition:transform .4s}
.scard:hover .ic{transform:rotate(6deg) scale(1.05)}
.scard:nth-child(2) .ic{background:#e4ead9}.scard:nth-child(3) .ic{background:#f0ddd4}
.scard h3{font-size:23px;margin-bottom:8px}
.scard p{color:var(--vert2);font-size:15px}
.scard .more{color:var(--terra);font-weight:700;font-size:14px;display:inline-block;margin-top:10px}

/* two-col texte/image */
.tc{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.tc.flip .tcimg{order:2}
.tc .tcimg img{width:100%;height:clamp(300px,42vw,440px);object-fit:cover;border-radius:34px}
.tc p{color:#3f5446;font-size:17px;max-width:52ch}

/* prose + listes */
.prose{max-width:760px}
.prose p{color:#3f5446;font-size:17px;margin-bottom:18px}
.prose h2{font-size:clamp(26px,3.4vw,38px);margin:34px 0 14px}
.prose h3{font-size:22px;margin:24px 0 10px}
.checks{list-style:none;display:grid;gap:12px;margin:8px 0 6px}
.checks li{display:flex;gap:12px;align-items:flex-start;color:#3f5446}
.checks li::before{content:"✓";color:#16B981;font-weight:800;flex:none}

/* galerie */
.real .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.real figure{position:relative}
.real img{width:100%;height:230px;object-fit:cover;border-radius:30px;transition:transform .5s}
.real figure:hover img{transform:scale(1.03)}
.real figcaption{margin-top:10px;font-weight:600;font-size:14px;color:var(--vert2);text-align:center}

/* slider saisons */
.seasons{background:var(--vert);color:var(--creme)}
.seasons h2{color:var(--creme)}.seasons .lab{color:var(--ciel)}
.seasons .int{color:#cdd9c6;max-width:48ch;margin-bottom:34px}
.cmp{position:relative;max-width:900px;margin:0 auto;aspect-ratio:16/9;overflow:hidden;border-radius:24px;background:#0d1f14;--pos:50%;touch-action:none;user-select:none}
.cmp .lay{position:absolute;inset:0}.cmp .lay img{width:100%;height:100%;object-fit:cover}
.cmp .winter{clip-path:inset(0 calc(100% - var(--pos)) 0 0);z-index:2}
.cmp .winter img{filter:none}
.cmp .tag{position:absolute;top:16px;z-index:5;font-weight:700;font-size:13px;padding:7px 16px;border-radius:30px;background:rgba(13,31,20,.7);color:#fff}
.cmp .tag.l{left:16px}.cmp .tag.r{right:16px;background:var(--terra)}
.cmp .handle{position:absolute;top:0;bottom:0;left:var(--pos);width:3px;background:#fff;transform:translateX(-1.5px);z-index:4;pointer-events:none}
.cmp .grab{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:#fff;color:var(--vert);display:flex;align-items:center;justify-content:center;font-size:19px;box-shadow:0 6px 18px rgba(0,0,0,.4)}
.cmp input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:6}
.cmp input:focus-visible + .handle .grab{outline:3px solid var(--terra);outline-offset:3px}

/* zones / villes */
.zones{background:#fff}
.zonegrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px}
.zonegrid a{background:var(--creme);border:1px solid #e2e3d3;border-radius:18px;padding:18px;font-weight:600;color:var(--vert);display:flex;align-items:center;gap:10px;transition:.2s}
.zonegrid a:hover{border-color:var(--terra);color:var(--terra);transform:translateY(-2px)}

/* FAQ */
.faq{max-width:820px;margin-top:24px}
.faq details{border-bottom:1px solid #dcdccc;padding:6px 0}
.faq summary{cursor:pointer;list-style:none;font-family:"Source Serif 4",serif;font-weight:600;font-size:19px;padding:14px 0;display:flex;justify-content:space-between;gap:14px;color:var(--vert)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--terra);font-size:24px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq .ans{color:#3f5446;font-size:16px;padding:0 0 16px}

/* avis */
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.avis-card{background:#fff;border-radius:24px;padding:28px;border:1px solid #e2e3d3}
.avis-card .stars{color:#E2B33C;letter-spacing:2px;margin-bottom:12px}
.avis-card p{color:#3f5446;font-style:italic;margin-bottom:14px}
.avis-card cite{font-style:normal;font-weight:700;color:var(--vert);font-size:14px}

/* devis / contact */
.devis{background:var(--ciel)}
.devis .box{background:#fff;border-radius:34px;padding:clamp(34px,5vw,64px);text-align:center;box-shadow:0 30px 60px -34px rgba(31,61,43,.35)}
.devis h2{font-size:clamp(28px,4vw,44px);margin-bottom:12px}
.devis p{color:var(--vert2);max-width:46ch;margin:0 auto 26px}
.cform{display:grid;gap:14px;max-width:640px;margin:30px auto 0;text-align:left}
.cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform label{font-size:13px;font-weight:700;color:var(--vert2);display:block;margin-bottom:5px}
.cform input,.cform textarea,.cform select{width:100%;padding:13px 16px;border:1px solid #d7d8c6;border-radius:14px;font-family:inherit;font-size:15px;background:var(--creme)}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(196,106,75,.15)}

/* infos contact */
.infos{display:grid;gap:2px;margin-top:10px}
.infos .line{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid #dcdccc;align-items:center}
.infos .ic{width:42px;height:42px;border-radius:50%;background:#e4ead9;display:flex;align-items:center;justify-content:center;flex:none}
.infos b{display:block}.infos span{color:var(--vert2);font-size:14px}

/* footer */
footer{background:var(--vert);color:#bcd0bf;padding:54px 0 28px;font-size:14px}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;margin-bottom:30px}
.fgrid .fl{display:flex;align-items:center;gap:10px;font-family:"Source Serif 4",serif;color:var(--creme);font-size:20px;font-weight:600;margin-bottom:12px}
.fgrid .fl svg{width:30px;height:30px}
.fgrid h4{color:var(--creme);font-size:14px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.fgrid a{display:block;color:#bcd0bf;padding:4px 0}
.fgrid a:hover{color:var(--ciel)}
.fbottom{border-top:1px solid #2c5a3e;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:#9fbaa3}
.madeby a{color:var(--creme);text-decoration:underline}

/* CTA flottant mobile */
.mcta{position:fixed;left:14px;right:14px;bottom:14px;z-index:55;display:none}
.mcta a{width:100%;justify-content:center}

/* reveals */
.rv{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

@media(max-width:900px){
  .navlinks{display:none}.burger{display:block}
  .navlinks.open{display:flex;position:absolute;top:64px;left:14px;right:14px;flex-direction:column;align-items:flex-start;background:var(--creme);padding:18px 24px;gap:12px;border-radius:24px;border:1px solid #dfe0cf;max-height:74vh;overflow:auto}
  .navlinks.open .has-drop{width:100%}
  .navlinks.open .drop{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;padding:4px 0 4px 12px;background:none;min-width:0}
  .hero .inner,.tc{grid-template-columns:1fr;gap:30px}.tc.flip .tcimg{order:0}
  .hero .heroimg img{height:360px}
  .scards,.zonegrid,.avis-grid,.real .grid{grid-template-columns:1fr 1fr}
  .scards{grid-template-columns:1fr}
  .cform .frow{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .mcta{display:block}body{padding-bottom:74px}
}
@media(max-width:560px){.zonegrid,.avis-grid,.real .grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto}.rv{opacity:1!important;transform:none!important;transition:none!important}.hero .heroimg .leaf{animation:none}}
