/* ============================================================
   LE JARDIN DU CRAPAUD FOU — Redesign
   Direction : « Carnet du jardinier botanique »
   Fraunces (display) · Hanken Grotesk (texte) · Caveat (manuscrit)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..700&family=Hanken+Grotesk:wght@300..800&family=Caveat:wght@500;600;700&display=swap');

/* ---------- TOKENS ---------- */
:root{
  --paper:        #f6efe0;
  --paper-2:      #efe5d1;
  --paper-3:      #e7dac0;
  --card:         #fffaf0;
  --ink:          #20322c;
  --ink-soft:     #4f5f55;
  --ink-faint:    #7c8a7e;

  --teal:         #0f5a4e;
  --teal-deep:    #0a3d34;
  --teal-bright:  #1c8270;
  --terracotta:   #c8552e;
  --terracotta-2: #b0461f;
  --gold:         #dca33a;
  --moss:         #7d8a47;
  --rose:         #a8326a;

  --line:         rgba(32,50,44,.16);
  --line-strong:  rgba(32,50,44,.30);
  --shadow:       18px 24px 50px -28px rgba(20,40,34,.45);
  --shadow-sm:    8px 12px 28px -18px rgba(20,40,34,.4);

  --r-lg: 26px;
  --r-md: 16px;
  --r-sm: 10px;

  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Hanken Grotesk', system-ui, sans-serif;
  --font-hand:'Caveat', cursive;

  --container: 1200px;
  --ease: cubic-bezier(.2,.7,.2,1);
}

[data-theme="dark"]{
  --paper:        #0e1a16;
  --paper-2:      #122420;
  --paper-3:      #16302a;
  --card:         #14241f;
  --ink:          #eee5d0;
  --ink-soft:     #b6c2b3;
  --ink-faint:    #8198896b;
  --ink-faint:    #859288;

  --teal:         #3db59f;
  --teal-deep:    #0a3d34;
  --teal-bright:  #5fd2bb;
  --terracotta:   #e07a4d;
  --terracotta-2: #ec8a5e;
  --gold:         #e7b65a;
  --moss:         #a3b066;
  --rose:         #d06497;

  --line:         rgba(238,229,208,.14);
  --line-strong:  rgba(238,229,208,.26);
  --card:         #15282231;
  --card:         #14272126;
  --card:         #16302a;
  --shadow:       18px 24px 50px -26px rgba(0,0,0,.6);
  --shadow-sm:    8px 12px 28px -18px rgba(0,0,0,.55);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .5s var(--ease), color .4s var(--ease);
}
img{max-width:100%;display:block}
svg{width:1.15em;height:1.15em;flex-shrink:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none;padding:0}

/* paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
}
[data-theme="dark"] body::before{mix-blend-mode:screen;opacity:.06}

/* ---------- TYPE ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:560;line-height:1.04;letter-spacing:-.015em;font-optical-sizing:auto}
.display{font-variation-settings:'SOFT' 30,'opsz' 144}
p{text-wrap:pretty}

.kicker{
  font-family:var(--font-hand);
  color:var(--terracotta);
  font-size:1.5rem;
  line-height:1;
  transform:rotate(-2deg);
  display:inline-block;
}
.eyebrow{
  font-size:.74rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:currentColor;display:inline-block;opacity:.6}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.section{padding-block:clamp(64px,9vw,128px);position:relative}
.section--tight{padding-block:clamp(48px,6vw,84px)}

.lede{font-size:clamp(1.1rem,1.7vw,1.32rem);color:var(--ink-soft);max-width:60ch;line-height:1.55}

.sec-head{display:flex;flex-direction:column;gap:.5rem;margin-bottom:clamp(2rem,4vw,3.5rem);max-width:42ch}
.sec-head .num{font-family:var(--font-display);font-size:.9rem;color:var(--terracotta);letter-spacing:.1em}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.4rem)}
.sec-head--center{margin-inline:auto;text-align:center;align-items:center}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.85em 1.5em;border-radius:100px;font-weight:600;font-size:.98rem;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
  position:relative;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--terracotta);color:#fff7ed;box-shadow:0 12px 26px -12px var(--terracotta)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 18px 34px -12px var(--terracotta)}
.btn--ink{background:var(--teal);color:#f4ecdc}
[data-theme="dark"] .btn--ink{color:#0a1f1a}
.btn--ink:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn--ghost{border:1.5px solid var(--line-strong);color:var(--ink)}
.btn--ghost:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px)}
.btn--lg{padding:1.05em 2em;font-size:1.05rem}

/* ---------- HEADER ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  backdrop-filter:saturate(1.3) blur(14px);
  background:color-mix(in srgb, var(--paper) 78%, transparent);
  border-bottom:1px solid var(--line);
  transition:background .4s, border-color .4s;
}
.nav{display:flex;align-items:center;gap:1.4rem;height:74px}
.brand{display:flex;align-items:center;gap:.7rem;margin-right:auto;font-family:var(--font-display);font-weight:600}
.brand img{width:46px;height:46px;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(0,0,0,.18))}
.brand .b-name{font-size:1.08rem;line-height:1;letter-spacing:-.01em}
.brand .b-sub{font-family:var(--font-hand);font-size:1rem;color:var(--terracotta);line-height:1}
.nav-links{display:flex;align-items:center;gap:.3rem}
.nav-links a{
  padding:.5em .85em;border-radius:100px;font-weight:500;font-size:.96rem;color:var(--ink-soft);
  transition:color .25s, background .25s;position:relative;
}
.nav-links a:hover{color:var(--ink);background:var(--paper-2)}
.nav-links a.active{color:var(--teal);font-weight:600}
.nav-links a.active::after{content:"";position:absolute;left:50%;bottom:.18em;width:5px;height:5px;border-radius:50%;background:var(--terracotta);transform:translateX(-50%)}
.nav-tools{display:flex;align-items:center;gap:.6rem}

.theme-toggle{
  width:42px;height:42px;border-radius:50%;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;transition:transform .4s var(--ease), border-color .3s,background .3s;
}
.theme-toggle:hover{transform:rotate(18deg);border-color:var(--teal)}
.theme-toggle svg{width:19px;height:19px;stroke:var(--ink)}
.theme-toggle .moon{display:none}
[data-theme="dark"] .theme-toggle .sun{display:none}
[data-theme="dark"] .theme-toggle .moon{display:block}

.burger{display:none;width:42px;height:42px;border-radius:50%;border:1.5px solid var(--line-strong);place-items:center}
.burger span{display:block;width:18px;height:2px;background:var(--ink);position:relative;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);transition:.3s}
.burger span::before{top:-6px}.burger span::after{top:6px}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
  padding-block:clamp(3rem,7vw,6rem);
}
.hero-eyebrow{margin-bottom:1.4rem}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);letter-spacing:-.025em;margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:var(--terracotta);font-variation-settings:'SOFT' 60}
.hero .kicker{position:absolute;margin-top:-3.2rem;margin-left:.2rem}
.hero-lede{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-soft);max-width:46ch;margin-bottom:2.2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;gap:2.2rem;margin-top:3rem;flex-wrap:wrap}
.hero-stat .n{font-family:var(--font-display);font-size:2rem;color:var(--teal);line-height:1}
.hero-stat .l{font-size:.82rem;color:var(--ink-faint);letter-spacing:.04em;max-width:14ch}

.hero-art{position:relative}
.hero-photo{
  position:relative;aspect-ratio:4/5;border-radius:50% 50% 48% 48%/56% 56% 44% 44%;overflow:hidden;
  box-shadow:var(--shadow);border:6px solid var(--card);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-medallion{
  position:absolute;left:-5%;bottom:-4%;width:42%;max-width:200px;
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.25));
  animation:float 7s ease-in-out infinite;
}
.hero-seal{position:absolute;right:-4%;top:4%;width:108px;animation:spin 36s linear infinite}

/* decorative organic blob behind hero */
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:-1}
.blob--teal{width:520px;height:520px;background:radial-gradient(circle,var(--teal-bright),transparent 70%);top:-180px;right:-120px;opacity:.16}
.blob--terra{width:460px;height:460px;background:radial-gradient(circle,var(--terracotta),transparent 70%);bottom:-200px;left:-160px;opacity:.13}

/* ---------- BIO SEAL ---------- */
.seal{display:inline-grid;place-items:center;position:relative}
.seal-ring{font-family:var(--font-body);font-size:.5rem}

/* ---------- PILIERS ---------- */
.piliers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.pilier{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:2rem 1.8rem;position:relative;overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.pilier:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pilier .ic{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:1.1rem;background:color-mix(in srgb,var(--teal) 14%,transparent)}
.pilier .ic svg{width:28px;height:28px;stroke:var(--teal);fill:none;stroke-width:1.6}
.pilier h3{font-size:1.35rem;margin-bottom:.5rem}
.pilier p{color:var(--ink-soft);font-size:.98rem}
.pilier .tag{position:absolute;top:1.2rem;right:1.4rem;font-family:var(--font-hand);color:var(--terracotta);font-size:1.4rem;transform:rotate(6deg)}

/* ---------- GAMMES / CATEGORY CARDS ---------- */
.gammes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.gamme{
  position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;display:block;
  box-shadow:var(--shadow-sm);transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.gamme:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.gamme img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.gamme:hover img{transform:scale(1.07)}
.gamme::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,30,25,.86) 4%,rgba(10,30,25,.22) 46%,transparent 70%)}
.gamme-body{position:absolute;inset:auto 0 0 0;padding:1.5rem;z-index:2;color:#f6efe0}
.gamme-body .c{font-family:var(--font-hand);font-size:1.2rem;color:#ffd9a8}
.gamme-body h3{font-size:1.5rem;color:#fff}
.gamme-body .count{font-size:.85rem;opacity:.85;display:flex;align-items:center;gap:.4em;margin-top:.3rem}
.gamme-arrow{position:absolute;top:1.3rem;right:1.3rem;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);display:grid;place-items:center;transition:.4s}
.gamme:hover .gamme-arrow{background:var(--terracotta);transform:rotate(-45deg)}
.gamme-arrow svg{width:18px;height:18px;stroke:#fff}

/* ---------- STEPS (commander) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;counter-reset:step}
.step{position:relative;padding:2rem 1.6rem;border-radius:var(--r-lg);background:var(--card);border:1px solid var(--line)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--font-display);font-size:2.6rem;color:var(--terracotta);opacity:.32;line-height:1;display:block;margin-bottom:.6rem}
.step h3{font-size:1.25rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5em}
.step p{color:var(--ink-soft);font-size:.95rem}

/* ---------- SPLIT (about / philosophy) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split--rev .split-media{order:2}
.split-media{position:relative}
.split-media img{border-radius:var(--r-lg);box-shadow:var(--shadow);width:100%;object-fit:cover}
.split-note{
  position:absolute;background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:.9rem 1.1rem;box-shadow:var(--shadow-sm);max-width:230px;
}
.split-note .h{font-family:var(--font-hand);color:var(--terracotta);font-size:1.3rem;line-height:1}
.split-note p{font-size:.85rem;color:var(--ink-soft);margin-top:.2rem}

/* ---------- BAND / CTA ---------- */
.band{
  background:var(--teal-deep);color:#f3ead8;border-radius:var(--r-lg);overflow:hidden;position:relative;
  padding:clamp(2.4rem,5vw,4rem);
}
.band h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.8rem);max-width:18ch}
.band p{color:#cfe0d3;max-width:46ch;margin-top:.8rem}
.band .btn--ghost{border-color:rgba(255,255,255,.35);color:#fff}
.band .btn--ghost:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.08)}
.band-deco{position:absolute;right:-40px;bottom:-40px;width:280px;opacity:.16;color:var(--teal-bright)}

/* ---------- CATALOGUE ---------- */
.cat-toolbar{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-bottom:2.4rem}
.chip{
  padding:.55em 1.1em;border-radius:100px;border:1.5px solid var(--line-strong);font-size:.9rem;font-weight:500;
  color:var(--ink-soft);transition:.25s;display:inline-flex;align-items:center;gap:.45em;
}
.chip:hover{color:var(--ink);border-color:var(--teal)}
.chip.active{background:var(--teal);border-color:var(--teal);color:#f4ecdc}
[data-theme="dark"] .chip.active{color:#0a1f1a}
.chip .n{font-size:.78em;opacity:.7}
.cat-search{margin-left:auto;position:relative;display:flex;align-items:center}
.cat-search input{
  background:var(--card);border:1.5px solid var(--line-strong);border-radius:100px;
  padding:.6em 1em .6em 2.5em;font-family:inherit;font-size:.92rem;color:var(--ink);min-width:220px;transition:.25s;
}
.cat-search input:focus{outline:none;border-color:var(--teal)}
.cat-search svg{position:absolute;left:.9em;width:17px;height:17px;stroke:var(--ink-faint);pointer-events:none}
/* grosse barre de recherche centrée au-dessus des filtres */
.cat-search--big{margin:0 auto 2rem;max-width:600px;width:100%}
.cat-search--big input{width:100%;min-width:0;padding:1em 1.3em 1em 3.2em;font-size:1.08rem;box-shadow:var(--shadow-sm)}
.cat-search--big svg{left:1.2em;width:21px;height:21px}
/* recherche dans l'en-tête (remplace le bouton "Le catalogue") */
.nav-search{position:relative;display:flex;align-items:center}
.nav-search input{background:var(--card);border:1.5px solid var(--line-strong);border-radius:100px;
  padding:.55em 1em .55em 2.5em;font-family:inherit;font-size:.9rem;color:var(--ink);width:185px;transition:width .25s,border-color .25s}
.nav-search input:focus{outline:none;border-color:var(--teal);width:230px}
.nav-search svg{position:absolute;left:.95em;width:16px;height:16px;stroke:var(--ink-faint);pointer-events:none}
/* lien "Mes réservations" + badge compteur */
.nav-resa{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;
  border-radius:50%;border:1.5px solid var(--line-strong);color:var(--ink);transition:border-color .25s,color .25s}
.nav-resa:hover{border-color:var(--teal);color:var(--teal)}
.nav-resa svg{width:20px;height:20px}
.resa-count{position:absolute;top:-5px;right:-5px;min-width:19px;height:19px;padding:0 4px;border-radius:20px;
  background:var(--terracotta);color:#fff7ed;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.resa-count.empty{display:none}
/* page Mes réservations */
.resa-items{display:flex;flex-direction:column;gap:.7rem}
.resa-row{display:flex;align-items:center;gap:1rem;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-md);padding:.7rem .9rem;box-shadow:var(--shadow-sm)}
.resa-thumb{width:60px;height:60px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--paper-2);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem}
.resa-thumb img{width:100%;height:100%;object-fit:cover}
.resa-name{flex:1;min-width:0;font-family:var(--font-display);font-size:1.05rem}
.resa-name a{color:var(--ink)}.resa-name a:hover{color:var(--teal)}
.resa-qty{display:flex;align-items:center;gap:.5rem}
.resa-qty button{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-strong);font-size:1.1rem;
  line-height:1;color:var(--ink);background:var(--card);cursor:pointer;transition:.2s}
.resa-qty button:hover{border-color:var(--teal);color:var(--teal)}
.resa-qty span{min-width:1.4em;text-align:center;font-weight:600}
.resa-del{width:32px;height:32px;border-radius:50%;border:1.5px solid #e3b4a6;color:var(--terracotta);background:var(--card);cursor:pointer;font-size:.9rem;transition:.2s}
.resa-del:hover{background:color-mix(in srgb,var(--terracotta) 10%,transparent)}

.plant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.3rem}
.pcard{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
  position:relative;
}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.pcard-img{aspect-ratio:1/1;overflow:hidden;position:relative;background:var(--paper-3)}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.pcard:hover .pcard-img img{transform:scale(1.08)}
.pcard-cat{position:absolute;top:.7rem;left:.7rem;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(4px);color:var(--teal);padding:.35em .7em;border-radius:100px}
.pcard-body{padding:.95rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.15rem;flex:1}
.pcard-body h3{font-size:1.12rem;line-height:1.1}
.pcard-body .latin{font-style:italic;font-size:.82rem;color:var(--ink-faint);font-family:var(--font-display);font-weight:400}
.pcard-meta{display:flex;gap:.7rem;margin-top:.7rem;flex-wrap:wrap}
.pcard-meta span{display:inline-flex;align-items:center;gap:.3em;font-size:.76rem;color:var(--ink-soft)}
.pcard-meta svg{width:14px;height:14px;stroke:var(--teal);fill:none;stroke-width:1.6}
.pcard-link{position:absolute;inset:0;z-index:3}
.pcard .seemore{margin-top:.8rem;font-size:.82rem;font-weight:600;color:var(--terracotta);display:inline-flex;align-items:center;gap:.35em;transition:gap .3s}
.pcard:hover .seemore{gap:.6em}
.empty-state{grid-column:1/-1;text-align:center;padding:4rem 1rem;color:var(--ink-faint)}

/* ---------- FICHE BOTANIQUE (plant detail) ---------- */
.fiche-hero{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start;padding-top:2rem}
.fiche-gallery{position:sticky;top:96px}
.fiche-photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid var(--card);aspect-ratio:4/5;background:var(--paper-3)}
.fiche-photo img{width:100%;height:100%;object-fit:cover}
.fiche-thumbs{display:flex;gap:.6rem;margin-top:.8rem;flex-wrap:wrap}
.fiche-thumbs img{width:64px;height:64px;border-radius:10px;object-fit:cover;cursor:pointer;border:2px solid transparent;transition:.25s;opacity:.7}
.fiche-thumbs img:hover,.fiche-thumbs img.active{border-color:var(--terracotta);opacity:1}

.fiche-cat{margin-bottom:.8rem}
.fiche h1{font-size:clamp(2.2rem,4.5vw,3.4rem);margin-bottom:.2rem}
.fiche .latin{font-family:var(--font-display);font-style:italic;font-size:1.15rem;color:var(--ink-faint);margin-bottom:1.4rem}
.fiche-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.6rem}
.badge{display:inline-flex;align-items:center;gap:.4em;font-size:.82rem;font-weight:600;padding:.45em .85em;border-radius:100px;background:var(--paper-2);border:1px solid var(--line)}
.badge svg{width:15px;height:15px}
.badge--bio{color:var(--teal);background:color-mix(in srgb,var(--teal) 12%,transparent);border-color:transparent}
.badge--rare{color:var(--terracotta)}

.fiche-specs{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;margin:1.8rem 0;
}
.spec{background:var(--card);padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.35rem}
.spec .s-ic{width:34px;height:34px;border-radius:10px;background:color-mix(in srgb,var(--teal) 12%,transparent);display:grid;place-items:center}
.spec .s-ic svg{width:18px;height:18px;stroke:var(--teal);fill:none;stroke-width:1.7}
.spec .s-l{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:700}
.spec .s-v{font-size:1.02rem;font-weight:600;line-height:1.2}

.fiche-desc{max-width:62ch}
.fiche-desc h2{font-size:1.5rem;margin:1.8rem 0 .7rem}
.fiche-desc h3{font-size:1.15rem;color:var(--teal);margin:1.4rem 0 .4rem;font-family:var(--font-body);font-weight:700}
.fiche-desc p{color:var(--ink-soft);margin-bottom:.9rem}
.fiche-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:2rem;padding-top:1.8rem;border-top:1px solid var(--line)}

.fiche-care{background:var(--paper-2);border-radius:var(--r-md);padding:1.4rem 1.6rem;margin-top:1.6rem;border:1px solid var(--line)}
.fiche-care h3{font-family:var(--font-hand);color:var(--terracotta);font-size:1.5rem;margin-bottom:.6rem}
.fiche-care ul{display:grid;gap:.55rem}
.fiche-care li{display:flex;gap:.7em;font-size:.95rem;color:var(--ink-soft)}
.fiche-care li svg{width:18px;height:18px;stroke:var(--teal);flex-shrink:0;margin-top:.15em;fill:none;stroke-width:1.7}

.related{margin-top:1rem}
.breadcrumb{display:flex;gap:.5em;align-items:center;font-size:.85rem;color:var(--ink-faint);padding-top:1.4rem;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb svg{width:13px;height:13px;opacity:.6}

/* ---------- PAGE HEADER (interior) ---------- */
.page-head{padding-block:clamp(2.6rem,5vw,4.4rem) clamp(1.6rem,3vw,2.4rem);text-align:center;position:relative}
.page-head h1{font-size:clamp(2.4rem,5.5vw,4.2rem);margin:.5rem 0}
.page-head .lede{margin-inline:auto;text-align:center}

/* ---------- CONTACT / VISITER ---------- */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.6rem)}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:2rem}
.info-card h3{font-size:1.3rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5em}
.info-row{display:flex;gap:.9rem;padding:.7rem 0;border-bottom:1px dashed var(--line);align-items:flex-start}
.info-row:last-child{border-bottom:none}
.info-row .ic{width:38px;height:38px;border-radius:11px;background:color-mix(in srgb,var(--teal) 12%,transparent);display:grid;place-items:center;flex-shrink:0}
.info-row .ic svg{width:19px;height:19px;stroke:var(--teal);fill:none;stroke-width:1.7}
.info-row .l{font-size:.78rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.info-row .v{font-weight:500}
.info-row a.v:hover{color:var(--teal)}

.form{display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field label{font-size:.82rem;font-weight:700;letter-spacing:.04em;color:var(--ink-soft)}
.field input,.field textarea,.field select{
  background:var(--paper);border:1.5px solid var(--line-strong);border-radius:12px;
  padding:.8em 1em;font-family:inherit;font-size:.98rem;color:var(--ink);transition:.25s;width:100%;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--teal);background:var(--card)}
.field textarea{min-height:130px;resize:vertical}

.map-frame{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);min-height:340px;height:100%;filter:saturate(.9)}
.map-frame iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
[data-theme="dark"] .map-frame{filter:saturate(.85) brightness(.85) contrast(1.05)}

.hours-list{display:grid;gap:.2rem}
.hours-row{display:flex;justify-content:space-between;padding:.55rem 0;border-bottom:1px dashed var(--line);font-size:.96rem}
.hours-row.closed{color:var(--ink-faint)}
.hours-row b{font-weight:600}

/* ---------- PROSE (about / legal) ---------- */
.prose{max-width:68ch;margin-inline:auto}
.prose p{color:var(--ink-soft);margin-bottom:1.1rem;font-size:1.05rem}
.prose h2{font-size:1.8rem;margin:2.2rem 0 .8rem}
.prose h3{font-size:1.3rem;margin:1.6rem 0 .5rem;color:var(--teal)}
.prose ul.dot{display:grid;gap:.7rem;margin:1rem 0}
.prose ul.dot li{display:flex;gap:.7em;color:var(--ink-soft)}
.prose ul.dot li::before{content:"❦";color:var(--terracotta);flex-shrink:0}
.prose blockquote{border-left:3px solid var(--terracotta);padding:.4rem 0 .4rem 1.4rem;margin:1.6rem 0;font-family:var(--font-display);font-style:italic;font-size:1.3rem;color:var(--ink)}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--teal-deep);color:#d7e4d7;margin-top:clamp(3rem,7vw,6rem);position:relative;overflow:hidden}
[data-theme="dark"] .site-footer{background:#081512;border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem;padding-block:clamp(3rem,5vw,4.5rem)}
.footer-brand img{width:84px;height:84px;object-fit:contain;margin-bottom:1rem}
.footer-brand p{color:#a9c2af;font-size:.95rem;max-width:30ch}
.footer-col h4{font-family:var(--font-body);font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--gold);margin-bottom:1.1rem;font-weight:700}
.footer-col a,.footer-col li{display:block;color:#bcd0bf;padding:.3rem 0;font-size:.96rem;transition:color .25s, transform .25s}
.footer-col a:hover{color:#fff;transform:translateX(4px)}
.footer-bio{display:flex;align-items:center;gap:.8rem;background:rgba(255,255,255,.06);border-radius:14px;padding:.9rem 1.1rem;margin-top:1rem}
.footer-bio .bcircle{width:42px;height:42px;border-radius:50%;border:2px solid var(--gold);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;color:var(--gold);font-size:.7rem;flex-shrink:0;text-align:center;line-height:1}
.footer-bio small{font-size:.78rem;color:#a9c2af;line-height:1.3}
.socials{display:flex;gap:.6rem;margin-top:1.2rem}
.socials a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:.3s}
.socials a:hover{background:var(--terracotta);transform:translateY(-3px)}
.socials svg{width:19px;height:19px;fill:#e8f0e6}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#9fb8a5}
.footer-bottom a:hover{color:#fff}
.footer-deco{position:absolute;left:-60px;bottom:-60px;width:240px;opacity:.07;color:#fff}

/* ---------- PLACEHOLDER (photo à venir) ---------- */
.pcard-img.placeholder,.fiche-photo.placeholder{
  display:grid;place-items:center;position:relative;
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in srgb,var(--teal) 16%,var(--paper-3)) 0%, var(--paper-3) 70%);
}
.pcard-img.placeholder::before,.fiche-photo.placeholder::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(var(--line-strong) 1px, transparent 1.4px);background-size:14px 14px;
}
.placeholder .ph-logo{width:58%;height:auto;max-width:170px;aspect-ratio:1/1;object-fit:contain;opacity:.92;filter:saturate(.96) drop-shadow(0 6px 14px rgba(0,0,0,.16));position:relative;z-index:1;animation:float 8s ease-in-out infinite}
.fiche-photo.placeholder .ph-logo{max-width:230px}
.placeholder .ph-tag{
  position:absolute;bottom:.7rem;z-index:2;font-family:var(--font-hand);font-size:1.15rem;color:var(--terracotta);
  background:color-mix(in srgb,var(--card) 86%,transparent);padding:.1em .8em;border-radius:100px;transform:rotate(-2deg);
}
.fiche-photo.placeholder .ph-tag{font-size:1.5rem;bottom:1.4rem}
.pcard-img.placeholder[data-cat="aromatiques-tisanes"]{background:radial-gradient(120% 90% at 50% 0%,#cfe6da,var(--paper-3))}
.pcard-img.placeholder[data-cat="petits-fruits-fruitiers"]{background:radial-gradient(120% 90% at 50% 0%,#e7d3c5,var(--paper-3))}
.pcard-img.placeholder[data-cat="fleurs-comestibles"]{background:radial-gradient(120% 90% at 50% 0%,#e6cfdd,var(--paper-3))}
.pcard-img.placeholder[data-cat="plantes-compagnes-haies"]{background:radial-gradient(120% 90% at 50% 0%,#d7e0c2,var(--paper-3))}
[data-theme="dark"] .pcard-img.placeholder,[data-theme="dark"] .fiche-photo.placeholder{background:radial-gradient(120% 90% at 50% 0%,var(--paper-3),var(--paper-2))!important}

.hide-sm{display:inline-flex}

/* ---------- BANNER NOTE (mise en ligne en cours) ---------- */
.topnote{background:var(--terracotta);color:#fff7ed;font-size:.86rem;text-align:center;padding:.55rem 1rem;position:relative;z-index:101}
.topnote a{text-decoration:underline;font-weight:600}
.topnote--bottom{z-index:1}

/* ---------- ANIMATIONS ---------- */
@keyframes float{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-12px) rotate(2deg)}}
@keyframes spin{to{transform:rotate(360deg)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.4s}.reveal[data-d="6"]{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .hero-grid,.split,.fiche-hero,.info-grid{grid-template-columns:1fr}
  .split--rev .split-media{order:0}
  .fiche-gallery{position:static}
  .piliers,.gammes,.steps{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .hero-art{max-width:440px;margin-inline:auto}
}
@media(max-width:680px){
  .nav-links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:.2rem;
    background:var(--paper);padding:1rem 1.4rem 1.6rem;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .45s var(--ease);box-shadow:var(--shadow);
    max-height:calc(100vh - 100%);overflow-y:auto;
  }
  .nav-links.open{transform:none}
  .nav-links a{padding:.8em 1em;font-size:1.05rem}
  .burger{display:grid}
  .piliers,.gammes,.steps,.footer-top{grid-template-columns:1fr}
  .hero h1{font-size:clamp(2.4rem,11vw,3.4rem)}
  .hero .kicker{position:static;margin:0 0 .4rem;transform:rotate(-2deg)}
  .fiche-specs{grid-template-columns:1fr 1fr}
  .cat-search{margin-left:0;width:100%}.cat-search input{width:100%}
  .hide-sm{display:none}
}
