/* bourgognefleurs.com — design system "bfx" partagé (toutes pages profondes) */
/* Schémas techniques SVG — style botanique à l'encre, dessinés à la main (jamais généré/inventé) */
.bfx-schema{margin:30px 0;border-radius:var(--r);background:radial-gradient(120% 100% at 0% 0%,#fcfdfb,#eef1e8);border:1px solid var(--line);padding:clamp(16px,3vw,28px);box-shadow:0 1px 2px rgba(16,33,22,.05)}
.bfx-schema svg{width:100%;height:auto;display:block}
.bfx-schema-h{display:flex;align-items:center;gap:9px;font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#245f3d;margin-bottom:6px}
.bfx-schema-h svg{width:16px;height:16px;flex:none}
.bfx-schema-cap{font-size:.85rem;color:#59665c;margin-top:12px;text-align:center;font-style:italic}
.sch-ink{fill:none;stroke:#2b463a;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.sch-ink-b{fill:none;stroke:#2b463a;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.sch-thin{fill:none;stroke:#6a8272;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.sch-leaf{fill:#cfe3d1;stroke:#2f7d4f;stroke-width:1.8;stroke-linejoin:round}
.sch-leaf-2{fill:#bcd8bf;stroke:#2f7d4f;stroke-width:1.6}
.sch-stem{fill:#e7efe3;stroke:#2b463a;stroke-width:2.2;stroke-linejoin:round}
.sch-faint{fill:none;stroke:#b7c4b8;stroke-width:1.6;stroke-linecap:round;stroke-dasharray:1 5}
.sch-cut{fill:none;stroke:#c0603f;stroke-width:2.6;stroke-dasharray:7 5;stroke-linecap:round}
.sch-acc{fill:#c0603f}
.sch-acc-s{fill:none;stroke:#c0603f;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.sch-soil{fill:#e6dcc9}
.sch-soil-2{fill:#dccdb3}
.sch-soilline{fill:none;stroke:#bda887;stroke-width:1.3;stroke-linecap:round}
.sch-mulch{fill:#cdb083}
.sch-pot{fill:#e6d2c1;stroke:#b07d5c;stroke-width:2.2;stroke-linejoin:round}
.sch-gold{fill:#c39a3d}
.sch-gold-s{fill:none;stroke:#c39a3d;stroke-width:2;stroke-linecap:round}
.sch-water{fill:none;stroke:#3f7fa8;stroke-width:2;stroke-linecap:round}
.sch-lbl{font-family:Inter,system-ui,sans-serif;font-size:14px;fill:#2b463a;font-weight:600}
.sch-lbl-s{font-family:Inter,system-ui,sans-serif;font-size:12.5px;fill:#59665c;font-weight:500}
.sch-num{font-family:Inter,system-ui,sans-serif;font-size:13px;font-weight:700;fill:#fff}
.sch-numbg{fill:#245f3d}
.sch-lead{fill:none;stroke:#93a596;stroke-width:1.1;stroke-dasharray:3 3}
@media (max-width:560px){.sch-lbl{font-size:15px}.sch-lbl-s{font-size:13.5px}}

.bfx-page{--bf-forest:#0e1912;--bf-forest-2:#14241a;--bf-leaf:#2f7d4f;--bf-leaf-deep:#245f3d;--bf-sage:#86b493;--bf-gold:#c39a3d;--bf-gold-soft:#e6c877;--bf-terra:#c9886a;--bf-stone:#f2f4ed;--bf-stone-2:#e9ece1;--ink:#16211a;--muted:#59665c;--line:rgba(22,33,26,.10);--line-d:rgba(255,255,255,.13);--r:18px;--serif:"DM Serif Display",Georgia,serif;--ease:cubic-bezier(.22,.61,.36,1)}
.bfx-page{font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);line-height:1.62}
.bfx-page *{box-sizing:border-box}
.bfx-page svg{display:block}
.bfx-wrap{width:min(1120px,100% - 44px);margin-inline:auto}
.bfx-narrow{width:min(760px,100% - 44px);margin-inline:auto}
.bfx-ic{width:16px;height:16px}
.bfx-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--bf-leaf)}
.bfx-eyebrow--gold{color:var(--bf-gold)}.bfx-eyebrow--light{color:var(--bf-sage)}
.bfx-h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.1;letter-spacing:.005em;margin:14px 0 0}
.bfx-lead{color:var(--muted);font-size:clamp(1.02rem,1.4vw,1.16rem);max-width:62ch;margin:15px 0 0}
.bfx-btn{display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;border:0;text-decoration:none;transition:transform .25s var(--ease),box-shadow .25s,background .2s}
.bfx-btn .bfx-ic{width:18px;height:18px}
.bfx-btn--leaf{background:var(--bf-leaf-deep);color:#fff;box-shadow:0 12px 28px rgba(36,95,61,.26)}
.bfx-btn--leaf:hover{transform:translateY(-2px);background:var(--bf-leaf)}
.bfx-btn--ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.24)}
.bfx-btn--ghost:hover{background:rgba(255,255,255,.13);transform:translateY(-2px)}
.bfx-btn--outline{background:transparent;color:var(--bf-leaf-deep);border:1px solid rgba(36,95,61,.3)}
.bfx-btn--outline:hover{background:rgba(36,95,61,.06);transform:translateY(-2px)}
/* Hero */
.bfx-hero{position:relative;overflow:hidden;color:#fff;background:var(--bf-forest);isolation:isolate;padding:clamp(72px,11vw,120px) 0 clamp(60px,9vw,100px)}
.bfx-hero::before{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(1000px 620px at 80% 2%,rgba(47,125,79,.34),transparent 58%),radial-gradient(880px 560px at 4% 100%,rgba(10,18,12,.6),transparent 60%),linear-gradient(180deg,rgba(10,20,14,.72),rgba(12,22,16,.6) 52%,rgba(8,14,10,.84))}
.bfx-hero-bg{position:absolute;left:0;right:0;top:-9%;width:100%;height:118%;object-fit:cover;opacity:.62;z-index:0;will-change:transform}
.bfx-hero-in{position:relative;z-index:2}
.bfx-hero-credit{position:absolute;right:14px;bottom:9px;z-index:3;font-size:.66rem;letter-spacing:.02em;color:rgba(255,255,255,.5)}
.bfx-hero-credit a{color:inherit;text-decoration:none}
/* Entrée du héros — 100% CSS, toujours visible à la fin (aucune dépendance JS) */
@keyframes bfxRise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.bfx-hero h1{animation:bfxRise .9s cubic-bezier(.22,.61,.36,1) both}
.bfx-hero .bfx-eyebrow{animation:bfxRise .8s cubic-bezier(.22,.61,.36,1) both}
.bfx-hero-lead{animation:bfxRise .9s cubic-bezier(.22,.61,.36,1) .12s both}
.bfx-hero .bfx-hero-cta{animation:bfxRise .9s cubic-bezier(.22,.61,.36,1) .2s both}
@media (prefers-reduced-motion:reduce){.bfx-hero h1,.bfx-hero .bfx-eyebrow,.bfx-hero-lead,.bfx-hero .bfx-hero-cta{animation:none}}
.bfx-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,5.4vw,3.8rem);line-height:1.07;letter-spacing:.01em;margin:16px 0 0;max-width:19ch}
.bfx-hero h1 em{font-style:italic;color:var(--bf-sage)}
.bfx-hero-lead{color:rgba(255,255,255,.8);font-size:clamp(1.02rem,1.5vw,1.2rem);max-width:56ch;margin:18px 0 0}
.bfx-hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin:30px 0 0}
.bfx-hero-small h1{font-size:clamp(2rem,4.6vw,3.1rem)}
/* Breadcrumb */
.bfx-crumb{display:flex;flex-wrap:wrap;gap:7px;align-items:center;font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:6px}
.bfx-crumb a{color:rgba(255,255,255,.78);text-decoration:none}.bfx-crumb a:hover{color:#fff}
.bfx-crumb span{opacity:.5}
/* Sections */
.bfx-sec{padding:clamp(54px,8vw,100px) 0}
.bfx-sec--stone{background:var(--bf-stone)}
.bfx-sec--dark{background:var(--bf-forest);color:#fff}
.bfx-sec--dark .bfx-lead{color:rgba(255,255,255,.76)}
.bfx-head{max-width:64ch}
/* Cards généralistes */
.bfx-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.bfx-cards--2{grid-template-columns:repeat(2,1fr)}
.bfx-card{border-radius:var(--r);background:#fff;padding:26px;box-shadow:0 8px 26px rgba(16,33,22,.08);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s;color:inherit;text-decoration:none}
.bfx-card:hover{transform:translateY(-4px);box-shadow:0 24px 54px rgba(16,33,22,.14)}
.bfx-card-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;background:linear-gradient(140deg,rgba(47,125,79,.16),rgba(195,154,61,.12));color:var(--bf-leaf-deep);flex:none}
.bfx-card-ic svg{width:26px;height:26px}
.bfx-card h3{font-family:var(--serif);font-weight:400;font-size:1.3rem;margin:0 0 7px;line-height:1.15}
.bfx-card p{color:var(--muted);font-size:.97rem;margin:0 0 16px}
.bfx-card-link{margin-top:auto;font-weight:600;font-size:.9rem;color:var(--bf-leaf-deep);display:inline-flex;align-items:center;gap:6px}
.bfx-card-link svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.bfx-card:hover .bfx-card-link svg{transform:translateX(4px)}
.bfx-card-tags{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 14px}
.bfx-tag{font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:4px 10px;border-radius:999px;background:rgba(47,125,79,.1);color:var(--bf-leaf-deep)}
.bfx-tag--gold{background:rgba(195,154,61,.14);color:#8a6b1f}
.bfx-tag--terra{background:rgba(201,136,106,.16);color:#a35a3c}
/* Cartes photo (encyclopédie / flore / journal) */
.bfx-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.bfx-tiles--4{grid-template-columns:repeat(4,1fr)}
.bfx-tile{border-radius:var(--r);background:#fff;overflow:hidden;box-shadow:0 8px 26px rgba(16,33,22,.08);border:1px solid var(--line);display:flex;flex-direction:column;color:inherit;text-decoration:none;transition:transform .3s var(--ease),box-shadow .3s}
.bfx-tile:hover{transform:translateY(-5px);box-shadow:0 26px 56px rgba(16,33,22,.16)}
.bfx-tile-ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--bf-stone-2)}
.bfx-tile-ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.bfx-tile:hover .bfx-tile-ph img{transform:scale(1.06)}
.bfx-tile-ph--empty{display:grid;place-items:center;background:linear-gradient(150deg,var(--bf-forest-2),var(--bf-forest));color:var(--bf-sage)}
.bfx-tile-ph--empty svg{width:60px;height:60px;opacity:.55}
.bfx-tile-badge{position:absolute;top:12px;left:12px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:5px 11px;border-radius:999px;background:rgba(14,25,18,.72);color:#fff;backdrop-filter:blur(4px)}
.bfx-tile-b{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.bfx-tile-b h3{font-family:var(--serif);font-weight:400;font-size:1.22rem;margin:0;line-height:1.16}
.bfx-tile-lat{font-style:italic;color:var(--muted);font-size:.86rem;margin:3px 0 0}
.bfx-tile-b p{color:var(--muted);font-size:.94rem;margin:11px 0 16px}
.bfx-tile-link{margin-top:auto;font-weight:600;font-size:.88rem;color:var(--bf-leaf-deep);display:inline-flex;align-items:center;gap:6px}
.bfx-tile-link svg{width:15px;height:15px;transition:transform .25s var(--ease)}.bfx-tile:hover .bfx-tile-link svg{transform:translateX(4px)}
/* Figure + crédit */
.bfx-fig{margin:0;border-radius:var(--r);overflow:hidden;background:var(--bf-stone-2);position:relative}
.bfx-fig img{display:block;width:100%;height:auto}
.bfx-fig-c{font-size:.74rem;color:var(--muted);padding:7px 12px;background:rgba(242,244,237,.9);border-top:1px solid var(--line)}
.bfx-fig-c a{color:var(--muted);text-decoration:none}.bfx-fig-c a:hover{text-decoration:underline}
.bfx-fig--hero{aspect-ratio:16/10}.bfx-fig--hero img{height:100%;object-fit:cover}
/* Fiche plante — 2 colonnes */
.bfx-fiche{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,48px);align-items:start}
.bfx-fiche-media{position:sticky;top:88px}
.bfx-specs{list-style:none;margin:26px 0 0;padding:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.bfx-specs li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;padding:14px 18px;border-bottom:1px solid var(--line)}
.bfx-specs li:last-child{border-bottom:0}
.bfx-spec-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:rgba(47,125,79,.1);color:var(--bf-leaf-deep);flex:none}
.bfx-spec-ic svg{width:18px;height:18px}
.bfx-spec-k{font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.bfx-spec-v{font-size:.98rem;font-weight:500;margin-top:1px}
/* Corps rédactionnel */
.bfx-prose{font-size:1.05rem;line-height:1.72;color:#22302a}
.bfx-prose>*+*{margin-top:1.05em}
.bfx-prose h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.5rem,3vw,2rem);line-height:1.18;margin:1.7em 0 .1em;color:var(--ink)}
.bfx-prose h3{font-size:1.2rem;font-weight:700;margin:1.5em 0 .1em;color:var(--ink)}
.bfx-prose p{margin:0}
.bfx-prose ul,.bfx-prose ol{margin:0;padding-left:1.3em}
.bfx-prose li{margin:.4em 0}
.bfx-prose strong{color:var(--ink);font-weight:700}
.bfx-prose a{color:var(--bf-leaf-deep);text-decoration:underline;text-underline-offset:2px}
.bfx-prose blockquote{margin:1.4em 0;padding:16px 22px;border-radius:14px;background:var(--bf-stone);font-style:italic;color:#37473e}
/* Étapes numérotées */
.bfx-steps{list-style:none;counter-reset:st;margin:26px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}
.bfx-steps li{counter-increment:st;position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px 22px 20px 66px;box-shadow:0 1px 2px rgba(16,33,22,.05)}
.bfx-steps li::before{content:counter(st);position:absolute;left:18px;top:18px;width:34px;height:34px;border-radius:50%;background:var(--bf-leaf-deep);color:#fff;font-weight:700;display:grid;place-items:center;font-size:.95rem}
.bfx-steps b{display:block;font-size:1.03rem;margin-bottom:3px}
.bfx-steps p{margin:0;color:var(--muted);font-size:.96rem}
/* Encadré (conseil, attention) */
.bfx-callout{display:grid;grid-template-columns:auto 1fr;gap:15px;padding:18px 20px;border-radius:var(--r);background:rgba(47,125,79,.07);border:1px solid rgba(47,125,79,.16);margin:22px 0}
.bfx-callout--warn{background:rgba(201,136,106,.09);border-color:rgba(201,136,106,.24)}
.bfx-callout--gold{background:rgba(195,154,61,.09);border-color:rgba(195,154,61,.24)}
.bfx-callout-ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:rgba(47,125,79,.14);color:var(--bf-leaf-deep);flex:none}
.bfx-callout--warn .bfx-callout-ic{background:rgba(201,136,106,.16);color:#a35a3c}
.bfx-callout--gold .bfx-callout-ic{background:rgba(195,154,61,.16);color:#8a6b1f}
.bfx-callout-ic svg{width:20px;height:20px}
.bfx-callout b{display:block;margin-bottom:2px}
.bfx-callout p{margin:0;color:#3a473f;font-size:.96rem}
/* Task list (réutilisé) */
.bfx-tasks{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.bfx-task{display:grid;grid-template-columns:auto 1fr;gap:15px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:17px 19px;box-shadow:0 1px 2px rgba(16,33,22,.05);transition:transform .25s var(--ease),box-shadow .25s}
.bfx-task:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(16,33,22,.09)}
.bfx-tic{width:21px;height:21px}
.bfx-task-ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(47,125,79,.1);color:var(--bf-leaf-deep);flex:none}
.bfx-task b{font-size:1.01rem}.bfx-task p{margin:3px 0 0;color:var(--muted);font-size:.94rem}
/* Chips filtres */
.bfx-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px}
.bfx-chip{font-size:.86rem;font-weight:600;padding:9px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--muted);text-decoration:none;transition:all .2s}
.bfx-chip:hover{border-color:var(--bf-leaf);color:var(--bf-leaf-deep)}
.bfx-chip.is-active{background:var(--bf-leaf-deep);color:#fff;border-color:var(--bf-leaf-deep)}
/* CTA centré */
.bfx-cta{text-align:center}
.bfx-cta .bfx-h2{margin-inline:auto;max-width:24ch}.bfx-cta .bfx-lead{margin-inline:auto}
.bfx-cta-act{display:flex;flex-wrap:wrap;gap:13px;justify-content:center;margin-top:28px}
/* Chiffres clés (KPI) */
.bfx-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.bfx-kpi{border-radius:var(--r);padding:26px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 26px rgba(16,33,22,.06)}
.bfx-kpi-n{font-family:var(--serif);font-size:clamp(1.7rem,3.6vw,2.4rem);line-height:1.05;color:var(--bf-leaf-deep)}
.bfx-kpi-l{margin-top:10px;color:var(--ink);font-size:.97rem;font-weight:500}
.bfx-kpi-s{margin-top:8px;color:var(--muted);font-size:.78rem;font-style:italic}
.bfx-sources{margin-top:36px;font-size:.84rem;color:var(--muted);font-style:italic;border-top:1px solid var(--line);padding-top:16px}
@media(max-width:760px){.bfx-kpis{grid-template-columns:1fr}}
/* Pub */
.bfx-ad{margin:34px 0;min-height:1px}
.bfx-ad ins{margin:0 auto}
/* Nav mois / pager */
.bfx-pager{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.bfx-pager a{color:var(--bf-leaf-deep);font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:7px}
.bfx-pager a svg{width:16px;height:16px}
/* Reveal */
.bfx-rev{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.bfx-rev.is-in{opacity:1;transform:none}
@media (max-width:860px){.bfx-cards,.bfx-cards--2{grid-template-columns:1fr}.bfx-tiles,.bfx-tiles--4{grid-template-columns:repeat(2,1fr)}.bfx-fiche{grid-template-columns:1fr}.bfx-fiche-media{position:static}}
@media (max-width:560px){.bfx-tiles,.bfx-tiles--4{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){.bfx-rev{opacity:1;transform:none;transition:none}}
/* Fix couleur titres (style.css force h1,h2,h3,h4 en sombre → réaffirmer sur fonds foncés) */
.bfx-hero h1,.bfx-hero .bfx-h2,.bfx-sec--dark h1,.bfx-sec--dark h2,.bfx-sec--dark .bfx-h2,.bfx-sec--dark h3{color:#fff !important}
.bfx-hero h1 em{color:var(--bf-sage) !important}
.bfx-hero .bfx-eyebrow,.bfx-hero-lead,.bfx-crumb{color:rgba(255,255,255,.82)}
.bfx-h2{color:var(--ink)}
.bfx-hero h1,.bfx-h2,.bfx-hero-lead,.bfx-lead,.bfx-prose p{text-wrap:pretty}
.bfx-card h3,.bfx-tile-b h3,.bfx-steps b{color:var(--ink)}
