/* ============================================================================
 * GreenVisuaLED Nature Vivante — home.css — HOME uniquement (index), p210.
 *
 * Tout est scopé sous #gvl-home (le wrapper de templates/index.tpl), comme
 * bloomled-spectre scope sa home sous #bl-home. Depend des tokens --gvl-*
 * (theme-global.css) et des .btn (idem). Sections : hero (<h1> unique),
 * reassurance, selecteur (tuiles + grille produit), pourquoi LED, bloc marque,
 * projet pro (compteurs), preuve sociale.
 * ============================================================================ */

/* Full bleed : la home s'affranchit du .container Bootstrap (~1140px) du layout
   classic pour que les FONDS de section couvrent toute la largeur de l'ecran.
   Le CONTENU reste centre via .gvl-wrap (max 1360 + padding). overflow-x:hidden
   sur #gvl-home empeche tout debordement horizontal de ses propres enfants. */
#gvl-home{overflow-x:hidden;width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;}
#gvl-home img{max-width:100%;display:block;}
#gvl-home .gvl-wrap{width:100%;max-width:var(--gvl-wrap);margin-inline:auto;padding-inline:24px;}

/* reveals (home.js ajoute .is-in ; sans JS, tout est visible -> .gvl-no-js) */
#gvl-home.gvl-no-js .gvl-reveal,
#gvl-home.gvl-no-js .gvl-reveal-stagger > *{opacity:1;transform:none;}
#gvl-home .gvl-reveal,#gvl-home .gvl-reveal-stagger > *{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease;}
#gvl-home .gvl-reveal.is-in,#gvl-home .gvl-reveal-stagger.is-in > *{opacity:1;transform:none;}

/* ---------- HERO (unique <h1>) ---------- */
#gvl-home .gvl-hero{position:relative;overflow:hidden;padding:64px 0 30px;}
#gvl-home .gvl-blob{position:absolute;z-index:0;pointer-events:none;border-radius:46% 54% 58% 42% / 54% 42% 58% 46%;}
#gvl-home .gvl-blob--1{top:-120px;right:-120px;width:640px;height:640px;background:radial-gradient(circle at 40% 40%,var(--gvl-accent),rgba(166,216,107,.18));opacity:.7;}
#gvl-home .gvl-blob--2{bottom:-180px;left:-180px;width:520px;height:520px;background:radial-gradient(circle at 60% 40%,var(--gvl-accent-2),rgba(200,230,160,0));opacity:.45;}
#gvl-home .gvl-hero .gvl-wrap{position:relative;z-index:2;}
#gvl-home .gvl-hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
#gvl-home .gvl-hero__sup{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;font-family:var(--gvl-mono);font-size:12.5px;letter-spacing:.06em;color:var(--gvl-green-text);}
#gvl-home .gvl-hero__sup .dot{width:9px;height:9px;border-radius:50%;background:var(--gvl-green);box-shadow:0 0 0 5px var(--gvl-accent);flex:none;}
#gvl-home .gvl-hero h1{font-family:var(--gvl-display);font-weight:800;font-size:clamp(36px,6.4vw,66px);line-height:1.06;letter-spacing:-.025em;color:var(--gvl-green-deep);margin:0;}
#gvl-home .gvl-hero h1 .hl{position:relative;color:var(--gvl-green-deep);}
#gvl-home .gvl-hero h1 .hl::after{content:"";position:absolute;left:-3px;right:-3px;bottom:.04em;height:.22em;z-index:-1;background:var(--gvl-green);opacity:.28;border-radius:14px 18px 16px 20px / 18px 14px 22px 12px;transform:rotate(-1.2deg);}
#gvl-home .gvl-hero__lede{margin:24px 0 12px;font-size:18.5px;color:var(--gvl-muted);max-width:46ch;}
#gvl-home .gvl-hero__since{margin:0 0 26px;font-family:var(--gvl-mono);font-size:13px;letter-spacing:.06em;color:var(--gvl-green-text);}
#gvl-home .gvl-hero__cta{display:flex;gap:14px;flex-wrap:wrap;}
#gvl-home .gvl-hero__pills{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px;}
#gvl-home .gvl-pill-mini{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1.5px solid var(--gvl-line);border-radius:var(--r-pill);padding:9px 16px;font-size:13.5px;font-weight:600;color:var(--gvl-green-deep);box-shadow:var(--sh-1);}
#gvl-home .gvl-pill-mini svg{width:17px;height:17px;color:var(--gvl-green-700);flex:none;}
#gvl-home .gvl-hero__visual{position:relative;}
#gvl-home .gvl-hero__shape{position:relative;border-radius:var(--r-lg) var(--r-lg) var(--r-lg) 64px;overflow:hidden;box-shadow:var(--sh-3);border:6px solid #fff;aspect-ratio:4/4.4;background:#eef5e6;}
#gvl-home .gvl-hero__shape img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
#gvl-home .gvl-hero__badge{position:absolute;top:18px;left:18px;z-index:4;background:rgba(255,255,255,.94);border-radius:var(--r-pill);padding:9px 16px;display:flex;align-items:center;gap:9px;font-family:var(--gvl-display);font-weight:700;font-size:13.5px;box-shadow:var(--sh-1);color:var(--gvl-green-deep);}
#gvl-home .gvl-hero__badge svg{width:18px;height:18px;color:var(--gvl-green-700);}

/* ---------- REASSURANCE (4 items) ---------- */
#gvl-home .gvl-assurance{background:var(--gvl-green-deep);color:#EAF3E1;padding:26px 0;}
#gvl-home .gvl-assurance__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
#gvl-home .gvl-assurance__item{display:flex;align-items:center;gap:14px;}
#gvl-home .gvl-assurance__item .ic{flex:none;width:48px;height:48px;border-radius:var(--r-pill);background:rgba(200,230,160,.16);display:flex;align-items:center;justify-content:center;color:var(--gvl-accent);}
#gvl-home .gvl-assurance__item .ic svg{width:24px;height:24px;}
#gvl-home .gvl-assurance__item b{display:block;color:#fff;font-family:var(--gvl-display);font-size:14.5px;font-weight:700;letter-spacing:.01em;}
#gvl-home .gvl-assurance__item span{font-size:12.5px;color:rgba(234,243,225,.72);}

/* ---------- SECTIONS generiques ---------- */
#gvl-home .gvl-section{padding:78px 0;position:relative;}
#gvl-home .gvl-section--soft{background:var(--gvl-surface);}
#gvl-home .gvl-section--leafy{background:var(--gvl-bg);}
#gvl-home .gvl-section-head{max-width:760px;margin-bottom:38px;}
#gvl-home .gvl-section-head h2{font-family:var(--gvl-display);font-size:clamp(30px,3.7vw,46px);font-weight:800;margin:12px 0 0;letter-spacing:-.02em;}
#gvl-home .gvl-section-head p{margin-top:14px;color:var(--gvl-muted);font-size:17px;max-width:60ch;}

/* tuiles categories (raccourcis mega menu) */
#gvl-home .gvl-cats{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:34px;}
#gvl-home .gvl-cat{display:flex;flex-direction:column;align-items:flex-start;gap:12px;text-align:left;background:var(--gvl-surface);border:1.5px solid var(--gvl-line);border-radius:var(--r-md);padding:16px;text-decoration:none;color:var(--gvl-green-deep);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease;}
#gvl-home .gvl-cat:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--gvl-green-700);background:var(--gvl-tint);}
#gvl-home .gvl-cat .ic{width:42px;height:42px;border-radius:14px;background:var(--gvl-accent);display:flex;align-items:center;justify-content:center;color:var(--gvl-green-deep);}
#gvl-home .gvl-cat .ic svg{width:23px;height:23px;}
#gvl-home .gvl-cat .lab{font-family:var(--gvl-display);font-size:14px;font-weight:700;line-height:1.15;}

/* grille produits phares (vraie miniature classic OU placeholders .gvl-pcard) */
#gvl-home .gvl-prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;padding:0;margin:0;}
#gvl-home .gvl-prod-grid .product-miniature{margin:0;}
#gvl-home .gvl-pcard{background:var(--gvl-surface);border:1.5px solid var(--gvl-line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease;}
#gvl-home .gvl-pcard:hover{transform:translateY(-4px);box-shadow:var(--sh-2);}
#gvl-home .gvl-pcard__media{position:relative;background:#fff;padding:14px;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:hidden;}
#gvl-home .gvl-pcard__media::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(120% 120% at 50% 0%,#F1F6E9 0%,#fff 62%);}
#gvl-home .gvl-pcard__media img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;max-height:78%;}
#gvl-home .gvl-pcard__body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1;}
#gvl-home .gvl-pcard__body h3{font-family:var(--gvl-display);font-size:15.5px;font-weight:700;line-height:1.25;margin:0;color:var(--gvl-green-deep);}
#gvl-home .gvl-pcard__meta{font-size:12.5px;color:var(--gvl-muted);font-family:var(--gvl-mono);margin:0;}
#gvl-home .gvl-ph-note{margin-top:auto;font-family:var(--gvl-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gvl-muted);opacity:.7;}
#gvl-home .gvl-selecteur__all{margin-top:34px;}

/* ---------- POURQUOI LA LED (4 cartes) ---------- */
#gvl-home .gvl-why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
#gvl-home .gvl-why-card{background:var(--gvl-surface);border-radius:var(--r-lg);padding:28px 24px;border:1.5px solid var(--gvl-line);position:relative;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease;}
#gvl-home .gvl-why-card:hover{transform:translateY(-4px);box-shadow:var(--sh-2);}
#gvl-home .gvl-why-card .ic{width:58px;height:58px;border-radius:18px;background:var(--gvl-accent);display:flex;align-items:center;justify-content:center;color:var(--gvl-green-deep);margin-bottom:18px;}
#gvl-home .gvl-why-card .ic svg{width:30px;height:30px;}
#gvl-home .gvl-why-card h3{font-family:var(--gvl-display);font-size:19px;font-weight:800;margin:0 0 10px;}
#gvl-home .gvl-why-card p{font-size:14.5px;color:var(--gvl-muted);margin:0;}

/* ---------- BLOC MARQUE (mur vegetal) ---------- */
#gvl-home .gvl-brand-block{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
#gvl-home .gvl-brand-block__shape{position:relative;background:linear-gradient(160deg,#2C5A3E,#1F4D33);border-radius:var(--r-lg) var(--r-lg) var(--r-lg) 64px;padding:30px;overflow:hidden;box-shadow:var(--sh-3);border:6px solid #fff;}
#gvl-home .gvl-brand-block__shape img{margin:0 auto;filter:drop-shadow(0 16px 26px rgba(0,0,0,.28));max-height:420px;width:auto;}
#gvl-home .gvl-brand-block h2{font-family:var(--gvl-display);font-size:clamp(28px,3.4vw,42px);font-weight:800;margin:8px 0 0;}
#gvl-home .gvl-brand-block p{color:var(--gvl-muted);margin-top:16px;font-size:16.5px;}
#gvl-home .gvl-brand-block__feats{display:flex;flex-direction:column;gap:12px;margin:22px 0 26px;list-style:none;padding:0;}
#gvl-home .gvl-brand-block__feats li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--gvl-ink);}
#gvl-home .gvl-brand-block__feats svg{width:22px;height:22px;color:var(--gvl-green-700);flex:none;margin-top:1px;}
#gvl-home .gvl-brand-block__cta{display:flex;gap:14px;flex-wrap:wrap;}

/* ---------- PROJET PRO (compteurs) ---------- */
#gvl-home .gvl-section--pro{padding:78px 0;}
#gvl-home .gvl-pro{position:relative;overflow:hidden;background:var(--gvl-green-deep);color:#EAF3E1;border-radius:var(--r-lg);padding:54px 44px;display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center;}
#gvl-home .gvl-pro h2{font-family:var(--gvl-display);color:#fff;font-size:clamp(28px,3.4vw,44px);font-weight:800;margin:8px 0 0;}
#gvl-home .gvl-pro__lede{color:rgba(234,243,225,.85);margin:18px 0 24px;font-size:16.5px;max-width:52ch;}
#gvl-home .gvl-pro__targets{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px;}
#gvl-home .gvl-pro__targets span{display:inline-flex;align-items:center;gap:8px;background:rgba(200,230,160,.14);border:1px solid rgba(200,230,160,.3);color:#EAF3E1;border-radius:var(--r-pill);padding:7px 14px;font-size:13px;font-weight:600;}
#gvl-home .gvl-pro__steps{display:flex;flex-wrap:wrap;gap:12px;margin:8px 0 26px;counter-reset:step;list-style:none;padding:0;}
#gvl-home .gvl-pro__steps li{display:flex;align-items:center;gap:11px;font-size:13.5px;color:#fff;font-weight:600;background:rgba(200,230,160,.12);border:1.5px solid rgba(200,230,160,.34);border-radius:var(--r-pill);padding:8px 16px 8px 8px;}
#gvl-home .gvl-pro__steps li::before{counter-increment:step;content:counter(step);flex:none;width:30px;height:30px;border-radius:50%;background:var(--gvl-green);color:#0F1F12;display:flex;align-items:center;justify-content:center;font-family:var(--gvl-display);font-weight:800;font-size:14px;box-shadow:0 0 0 4px rgba(111,180,58,.22);}
#gvl-home .gvl-pro__cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
#gvl-home .gvl-pro__stats{display:grid;grid-template-columns:1fr;gap:16px;}
#gvl-home .gvl-stat{position:relative;background:rgba(255,255,255,.08);border:1.5px solid rgba(200,230,160,.42);border-radius:var(--r-md);padding:22px 24px 22px 28px;display:flex;align-items:baseline;gap:16px;overflow:hidden;transition:border-color .18s ease,background .18s ease,transform .18s ease;}
#gvl-home .gvl-stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--gvl-green);}
#gvl-home .gvl-stat:hover{border-color:var(--gvl-green);background:rgba(255,255,255,.12);transform:translateY(-2px);}
#gvl-home .gvl-stat__num{font-family:var(--gvl-display);font-weight:800;font-size:42px;color:#fff;line-height:1;flex:none;min-width:128px;}
#gvl-home .gvl-stat__lbl{font-size:14px;color:var(--gvl-accent);}

/* ---------- PREUVE SOCIALE (secteurs) ---------- */
#gvl-home .gvl-logos-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:16px;}
#gvl-home .gvl-logo-tile{aspect-ratio:5/3;background:#F1F6E9;border:1px solid var(--gvl-line);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--gvl-green-text);opacity:.82;transition:opacity .2s ease,transform .16s ease,box-shadow .16s ease;}
#gvl-home .gvl-logo-tile:hover{opacity:1;transform:translateY(-2px);box-shadow:var(--sh-1);}
#gvl-home .gvl-logo-tile span{font-family:var(--gvl-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;text-align:center;line-height:1.3;padding:0 6px;}

/* ---------- RESPONSIVE home ---------- */
@media (max-width:1100px){
  #gvl-home .gvl-prod-grid{grid-template-columns:repeat(3,1fr);}
  #gvl-home .gvl-cats{grid-template-columns:repeat(3,1fr);}
  #gvl-home .gvl-logos-grid{grid-template-columns:repeat(4,1fr);}
}
@media (max-width:980px){
  #gvl-home .gvl-hero__grid{grid-template-columns:1fr;gap:36px;}
  #gvl-home .gvl-hero__visual{max-width:480px;margin:0 auto;width:100%;}
  #gvl-home .gvl-pro{grid-template-columns:1fr;gap:34px;}
  #gvl-home .gvl-brand-block{grid-template-columns:1fr;gap:36px;}
  #gvl-home .gvl-why-grid{grid-template-columns:repeat(2,1fr);}
  #gvl-home .gvl-assurance__grid{grid-template-columns:repeat(2,1fr);gap:22px;}
}
@media (max-width:760px){
  #gvl-home .gvl-prod-grid{grid-template-columns:repeat(2,1fr);}
  #gvl-home .gvl-logos-grid{grid-template-columns:repeat(3,1fr);}
  #gvl-home .gvl-stat__num{font-size:36px;min-width:108px;}
  #gvl-home .gvl-pro{padding:38px 24px;}
  #gvl-home .gvl-hero{padding:32px 0 24px;}
}
@media (max-width:560px){
  #gvl-home .gvl-section{padding:56px 0;}
  #gvl-home .gvl-cats{grid-template-columns:repeat(2,1fr);}
  #gvl-home .gvl-why-grid{grid-template-columns:1fr;}
  #gvl-home .gvl-prod-grid{grid-template-columns:repeat(2,1fr);}
  #gvl-home .gvl-stat{flex-direction:column;gap:4px;}
  #gvl-home .gvl-stat__num{min-width:0;}
}
