/* ═══════════════════════════════════════════════════════
   GINOFORÊT — Groupement Forestier Familial du Morvan
   Design system : registre forestier / cernes de croissance
   ═══════════════════════════════════════════════════════ */

:root{
  --forest-deep:#1F2E22;
  --forest:#35513C;
  --forest-soft:#4C6B54;
  --paper:#F3F5EF;
  --paper-alt:#EAEEE3;
  --paper-line:#DCE3D6;
  --ink:#1B2620;
  --ink-soft:#55645A;
  --accent:#6E7F42;
  --accent-light:#A9BB7C;
  --accent-pale:#EEF1E2;
  --cream:#F8F7F2;
  --r:6px;
  --r-lg:10px;
  --shadow:0 2px 14px rgba(27,38,32,.08);
  --shadow-lg:0 8px 32px rgba(27,38,32,.14);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Work Sans',sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Fraunces',serif;color:var(--forest-deep);line-height:1.15;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.mono{font-family:'IBM Plex Mono',monospace}
.container{max-width:1180px;margin:0 auto;padding:0 1.5rem}
.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--accent);
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
}
.eyebrow::before{content:'';width:18px;height:1px;background:var(--accent)}
.section{padding:4.5rem 0}
.section-tight{padding:2.5rem 0}
.divider{border:none;border-top:1px solid var(--paper-line);margin:0}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.8rem 1.5rem;border-radius:var(--r);
  font-family:'Work Sans',sans-serif;font-weight:600;font-size:.92rem;
  border:1px solid transparent;cursor:pointer;transition:.2s;
}
.btn-primary{background:var(--forest-deep);color:var(--cream)}
.btn-primary:hover{background:var(--forest)}
.btn-accent{background:var(--accent);color:var(--cream)}
.btn-accent:hover{background:#5f6f38}
.btn-outline{border-color:var(--forest-deep);color:var(--forest-deep)}
.btn-outline:hover{background:var(--forest-deep);color:var(--cream)}
.btn-ghost{color:var(--forest-deep);text-decoration:underline;text-underline-offset:3px}

/* ═══ UTILITY BAR ═══ */
.utility-bar{background:var(--forest-deep);color:rgba(248,247,242,.72);font-family:'IBM Plex Mono',monospace;font-size:.72rem}
.utility-bar .container{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1.5rem;flex-wrap:wrap;gap:.4rem}
.utility-bar a{color:rgba(248,247,242,.9)}
.utility-bar a:hover{color:var(--accent-light)}

/* ═══ HEADER ═══ */
header{background:var(--paper);border-bottom:1px solid var(--paper-line);position:sticky;top:0;z-index:100}
.nav-inner{max-width:1180px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;cursor:pointer}
.brand-mark{width:38px;height:38px;flex-shrink:0}
.brand-word{font-family:'Fraunces',serif;font-weight:700;font-size:1.3rem;color:var(--forest-deep);letter-spacing:-.01em}
.brand-sub{display:block;font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:1px}
nav.main-nav{display:flex;align-items:center;gap:2rem}
nav.main-nav a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;padding:.2rem 0}
nav.main-nav a:not(.nav-cart)::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--forest-deep);transition:.2s}
nav.main-nav a:not(.nav-cart):hover::after{width:100%}
.nav-cart{display:flex;align-items:center;gap:.4rem;border:1px solid var(--forest-deep);border-radius:var(--r);padding:.5rem .9rem;font-family:'IBM Plex Mono',monospace;font-size:.78rem}
.nav-cart-count{background:var(--accent);color:var(--cream);border-radius:50%;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:.68rem}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.hamburger span{width:24px;height:2px;background:var(--forest-deep)}

.mob-nav{position:fixed;inset:0;background:var(--forest-deep);z-index:200;display:none;flex-direction:column;padding:2rem 1.5rem;gap:1.5rem}
.mob-nav.open{display:flex}
.mob-nav a{color:var(--cream);font-family:'Fraunces',serif;font-size:1.5rem;font-weight:600}
.mob-close{align-self:flex-end;background:none;border:none;color:var(--cream);font-size:1.6rem;cursor:pointer}

@media(max-width:860px){
  nav.main-nav{display:none}
  .hamburger{display:flex}
}

/* ═══ HERO (accueil) ═══ */
.hero{background:var(--paper);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;padding:4rem 0 3rem}
.hero-title{font-size:clamp(2.1rem,4.8vw,3.4rem);font-weight:700;letter-spacing:-.01em;margin:1rem 0 1.2rem}
.hero-lede{font-size:1.08rem;color:var(--ink-soft);max-width:520px;margin-bottom:1.8rem}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-stats{display:flex;gap:2.2rem;padding-top:1.5rem;border-top:1px solid var(--paper-line)}
.hstat-num{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:700;color:var(--forest-deep)}
.hstat-lbl{font-family:'IBM Plex Mono',monospace;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.rings-wrap{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.rings-wrap svg{width:100%;height:100%}

@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;padding-top:2rem}
  .rings-wrap{max-width:320px;margin:0 auto}
}

/* ═══ LEDGER LIST (boutique + related) ═══ */
.ledger{border-top:1px solid var(--paper-line)}
.ledger-row{
  display:grid;grid-template-columns:110px 1fr auto auto;gap:1.5rem;align-items:center;
  padding:1.6rem 0;border-bottom:1px solid var(--paper-line);
  transition:.2s;
}
.ledger-row:hover{background:var(--accent-pale)}
.ledger-row:hover .ledger-thumb img{transform:scale(1.04)}
.ledger-ref{font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:var(--accent);font-weight:600}
.ledger-thumb{width:88px;height:88px;border-radius:var(--r);overflow:hidden;background:var(--paper-alt)}
.ledger-thumb img{width:100%;height:100%;object-fit:cover;transition:.35s}
.ledger-main{display:flex;flex-direction:column;gap:.25rem}
.ledger-cat{font-family:'IBM Plex Mono',monospace;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.ledger-name{font-family:'Fraunces',serif;font-size:1.25rem;font-weight:600;color:var(--forest-deep)}
.ledger-desc{font-size:.86rem;color:var(--ink-soft);max-width:440px}
.ledger-price{font-family:'IBM Plex Mono',monospace;font-weight:600;color:var(--forest-deep);text-align:right;white-space:nowrap}
.ledger-price small{display:block;font-weight:400;color:var(--ink-soft);font-size:.68rem}
.ledger-arrow{font-size:1.3rem;color:var(--accent)}

@media(max-width:700px){
  .ledger-row{grid-template-columns:70px 1fr;gap:1rem}
  .ledger-price,.ledger-arrow{grid-column:2;justify-self:start}
  .ledger-thumb{width:70px;height:70px}
}

/* ═══ FICHE PRODUIT ═══ */
.fiche-wrap{max-width:1180px;margin:0 auto;padding:2.5rem 1.5rem 5rem}
.fiche-back{display:inline-flex;align-items:center;gap:.4rem;font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--ink-soft);margin-bottom:1.5rem}
.fiche-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem}
.fiche-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--paper-alt)}
.fiche-img img{width:100%;height:100%;object-fit:cover}
.ledger-card{border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:1.4rem;margin-top:1.5rem;background:var(--cream)}
.ledger-card-title{font-family:'IBM Plex Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:700;margin-bottom:.9rem}
.spec-line{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px dashed var(--paper-line);font-size:.86rem}
.spec-line:last-child{border-bottom:none}
.spec-line span:first-child{color:var(--ink-soft)}
.spec-line span:last-child{font-family:'IBM Plex Mono',monospace;font-weight:600;color:var(--forest-deep)}
.fiche-ref{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--accent);font-weight:600;margin-bottom:.5rem}
.fiche-title{font-size:clamp(1.7rem,3.4vw,2.3rem);margin-bottom:1rem}
.fiche-desc{color:var(--ink-soft);margin-bottom:1.5rem}
@media(max-width:860px){.fiche-grid{grid-template-columns:1fr}}

/* ═══ CONFIGURATEUR (achat depuis fiche via JS) ═══ */
.buy-box{border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:1.5rem;background:var(--paper)}
.buy-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.buy-price{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:700;color:var(--forest-deep)}
.qty-box{display:flex;align-items:center;border:1px solid var(--paper-line);border-radius:var(--r)}
.qty-box button{width:36px;height:36px;background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--forest-deep)}
.qty-box input{width:44px;text-align:center;border:none;background:none;font-family:'IBM Plex Mono',monospace;font-weight:600}
select.buy-select{width:100%;padding:.65rem .8rem;border:1px solid var(--paper-line);border-radius:var(--r);margin-bottom:1rem;font-family:'Work Sans',sans-serif;background:var(--cream)}

/* ═══ BLOG (liste type journal) ═══ */
.journal-list{border-top:1px solid var(--paper-line)}
.journal-row{display:grid;grid-template-columns:130px 1fr;gap:1.8rem;padding:2rem 0;border-bottom:1px solid var(--paper-line)}
.journal-thumb{width:130px;height:130px;border-radius:var(--r);overflow:hidden;background:var(--paper-alt)}
.journal-thumb img{width:100%;height:100%;object-fit:cover}
.journal-date{font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.journal-title{font-family:'Fraunces',serif;font-size:1.35rem;margin:.35rem 0 .5rem}
.journal-excerpt{color:var(--ink-soft);font-size:.92rem}
@media(max-width:640px){.journal-row{grid-template-columns:1fr}.journal-thumb{width:100%;height:180px}}

.article-body p{margin-bottom:1.2rem;color:var(--ink);font-size:1.02rem}
.article-body h2{font-size:1.5rem;margin:2.2rem 0 .9rem}
.article-body strong{color:var(--forest-deep)}

/* ═══ À PROPOS ═══ */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:3.5rem;align-items:start}
.about-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4}
.about-img img{width:100%;height:100%;object-fit:cover}
.timeline{margin-top:2rem;border-left:2px solid var(--paper-line);padding-left:1.5rem}
.tl-item{margin-bottom:1.6rem;position:relative}
.tl-item::before{content:'';position:absolute;left:-1.56rem;top:.3rem;width:9px;height:9px;border-radius:50%;background:var(--accent)}
.tl-year{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--accent);font-weight:700}
.tl-text{font-size:.92rem;color:var(--ink-soft);margin-top:.15rem}
@media(max-width:860px){.about-grid{grid-template-columns:1fr}}

/* ═══ CONTACT ═══ */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:3.5rem}
.contact-block{margin-bottom:1.6rem;display:flex;gap:1rem}
.contact-ico{width:38px;height:38px;border-radius:50%;background:var(--forest-deep);color:var(--cream);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}
.contact-lbl{font-family:'IBM Plex Mono',monospace;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:700;margin-bottom:.2rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.4rem;color:var(--forest-deep)}
.field input,.field select,.field textarea{
  width:100%;padding:.75rem .9rem;border:1px solid var(--paper-line);border-radius:var(--r);
  font-family:'Work Sans',sans-serif;font-size:.94rem;background:var(--cream);color:var(--ink)
}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

/* ═══ PANIER (drawer sombre) ═══ */
.cart-fab{
  position:fixed;bottom:1.8rem;right:1.8rem;z-index:150;
  background:var(--forest-deep);color:var(--cream);border:none;border-radius:50px;
  padding:.9rem 1.4rem;display:flex;align-items:center;gap:.6rem;
  font-family:'IBM Plex Mono',monospace;font-size:.82rem;font-weight:600;
  box-shadow:var(--shadow-lg);cursor:pointer;
}
.cart-badge{background:var(--accent);border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem}
.overlay{position:fixed;inset:0;background:rgba(20,28,22,.55);z-index:190;display:none}
.overlay.show{display:block}
.drawer{
  position:fixed;top:0;right:-420px;width:100%;max-width:420px;height:100%;
  background:var(--forest-deep);color:var(--cream);z-index:200;transition:.3s;
  display:flex;flex-direction:column;
}
.drawer.open{right:0}
.drawer-head{padding:1.5rem;border-bottom:1px solid rgba(248,247,242,.15);display:flex;justify-content:space-between;align-items:center}
.drawer-head h2{color:var(--cream);font-size:1.2rem}
.drawer-x{background:none;border:none;color:var(--cream);font-size:1.4rem;cursor:pointer}
.drawer-body{flex:1;overflow-y:auto;padding:1.5rem}
.dline{display:flex;gap:.9rem;margin-bottom:1.2rem;padding-bottom:1.2rem;border-bottom:1px solid rgba(248,247,242,.12)}
.dline img{width:56px;height:56px;border-radius:var(--r);object-fit:cover}
.dline-name{font-weight:600;font-size:.9rem}
.dline-meta{font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:rgba(248,247,242,.6)}
.dline-x{background:none;border:none;color:rgba(248,247,242,.6);cursor:pointer;font-size:.85rem}
.drawer-foot{padding:1.5rem;border-top:1px solid rgba(248,247,242,.15)}
.dtotal{display:flex;justify-content:space-between;margin-bottom:1rem;font-family:'IBM Plex Mono',monospace;font-weight:700;font-size:1.1rem}
.empty-cart{color:rgba(248,247,242,.5);font-size:.9rem;text-align:center;padding:2rem 0}

/* ═══ CHECKOUT ═══ */
.checkout-overlay{position:fixed;inset:0;background:var(--paper);z-index:300;display:none;overflow-y:auto}
.checkout-overlay.show{display:block}
.checkout-wrap{max-width:640px;margin:0 auto;padding:2rem 1.5rem 5rem}
.co-head{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.co-back{background:none;border:1px solid var(--paper-line);border-radius:50%;width:38px;height:38px;cursor:pointer;font-size:1.1rem}
.co-card{border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:1.6rem;margin-bottom:1.2rem;background:var(--cream)}
.co-card h3{font-size:1rem;margin-bottom:1rem;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}
.recap-line{display:flex;justify-content:space-between;font-size:.9rem;padding:.4rem 0;color:var(--ink-soft)}
.recap-total{display:flex;justify-content:space-between;font-weight:700;font-family:'IBM Plex Mono',monospace;font-size:1.15rem;padding-top:.8rem;margin-top:.6rem;border-top:1px solid var(--paper-line);color:var(--forest-deep)}
.bank-card{background:var(--forest-deep);color:var(--cream);border-radius:var(--r-lg);padding:1.6rem;margin-bottom:1.2rem}
.bank-card h3{color:var(--accent-light);font-family:'IBM Plex Mono',monospace;text-transform:uppercase;font-size:1rem;letter-spacing:.06em;margin-bottom:1rem}
.bank-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid rgba(248,247,242,.12);font-size:.88rem}
.bank-val{font-family:'IBM Plex Mono',monospace;font-weight:600}
.copy-btn{background:rgba(248,247,242,.12);border:none;color:var(--cream);padding:.3rem .7rem;border-radius:5px;font-size:.72rem;cursor:pointer;margin-left:.6rem}
.ref-box{background:rgba(248,247,242,.08);border-radius:var(--r);padding:.9rem;margin-top:.8rem;text-align:center}
.ref-lbl{font-size:.7rem;color:rgba(248,247,242,.6);margin-bottom:.3rem}
.ref-val{font-family:'IBM Plex Mono',monospace;font-weight:700;font-size:1.05rem;color:var(--accent-light)}
.alert-note{background:var(--accent-pale);border:1px solid var(--accent-light);border-radius:var(--r);padding:.9rem 1.1rem;font-size:.84rem;color:var(--forest-deep);margin-bottom:1.2rem}
.btn-submit{width:100%;background:var(--forest-deep);color:var(--cream);border:none;padding:1rem;border-radius:var(--r);font-weight:700;font-size:1rem;cursor:pointer}
.btn-submit:hover{background:var(--forest)}

.confirm-page{display:none;text-align:center;padding-top:2rem}
.confirm-page.show{display:block}
.confirm-ico{width:64px;height:64px;border-radius:50%;background:var(--accent-pale);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 1.2rem}
.confirm-h{font-size:1.5rem;margin-bottom:.6rem}
.confirm-sub{color:var(--ink-soft);margin-bottom:2rem;font-size:.94rem}
.confirm-bank{background:var(--cream);border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:1.5rem;text-align:left;margin-bottom:2rem}
.confirm-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px dashed var(--paper-line);font-size:.88rem}

/* ═══ FOOTER ═══ */
footer{background:var(--forest-deep);color:rgba(248,247,242,.75);padding:3.5rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem;max-width:1180px;margin:0 auto;padding:0 1.5rem 2.5rem}
.footer-brand p{font-size:.86rem;margin-top:.9rem;line-height:1.6;color:rgba(248,247,242,.6)}
.footer-col h4{color:var(--accent-light);font-family:'IBM Plex Mono',monospace;text-transform:uppercase;font-size:.72rem;letter-spacing:.1em;margin-bottom:1rem}
.footer-col a{display:block;font-size:.86rem;color:rgba(248,247,242,.72);margin-bottom:.6rem}
.footer-col a:hover{color:var(--accent-light)}
.footer-bottom{max-width:1180px;margin:0 auto;padding:1.5rem 1.5rem 0;border-top:1px solid rgba(248,247,242,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.76rem;color:rgba(248,247,242,.5);font-family:'IBM Plex Mono',monospace}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ═══ LEGAL PAGES ═══ */
.legal-wrap{max-width:760px;margin:0 auto;padding:3rem 1.5rem 5rem}
.legal-wrap h1{font-size:2rem;margin-bottom:.4rem}
.legal-wrap .legal-date{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--ink-soft);margin-bottom:2rem}
.legal-wrap h2{font-size:1.15rem;margin:2rem 0 .8rem}
.legal-wrap p,.legal-wrap li{color:var(--ink-soft);font-size:.94rem;margin-bottom:.7rem}
.legal-wrap ul{padding-left:1.3rem}

/* ═══ MISC ═══ */
.breadcrumb{font-family:'IBM Plex Mono',monospace;font-size:.76rem;color:rgba(248,247,242,.55);margin-bottom:1rem}
.breadcrumb a{color:rgba(248,247,242,.75)}
.page-hero{background:var(--forest-deep);color:var(--cream);padding:3.2rem 0 2.4rem}
.page-hero h1{color:var(--cream);font-size:clamp(1.8rem,4vw,2.6rem)}
.page-hero p{color:rgba(248,247,242,.65);margin-top:.6rem;max-width:600px;font-weight:300}
