/* ================================================================
   ÉDUC'KANINE v4 — Design System Ultra Premium
   Thème : Dark Luxury + Nature Feuillage
   ================================================================ */

/* ——— TOKENS ——— */
:root {
  /* Backgrounds */
  --bg:          #0c0f0d;
  --bg2:         #0f120f;
  --bg3:         #131612;
  --surf:        #171b16;
  --surf2:       #1c211b;
  --surf3:       #21271f;

  /* Borders */
  --border:      rgba(255,255,255,0.055);
  --border-h:    rgba(255,255,255,0.14);
  --border-acc:  rgba(192,57,43,0.28);
  --border-leaf: rgba(88,140,75,0.22);

  /* Text */
  --txt:         #eeeae0;
  --txt-m:       rgba(238,234,224,0.58);
  --txt-d:       rgba(238,234,224,0.32);

  /* Accent rouge */
  --acc:         #c0392b;
  --acc2:        #e74c3c;
  --acc-dim:     rgba(192,57,43,0.16);
  --acc-glow:    rgba(192,57,43,0.38);

  /* Accent nature */
  --leaf:        #5e9e4a;
  --leaf2:       #7bbf61;
  --leaf-dim:    rgba(94,158,74,0.14);
  --leaf-glow:   rgba(94,158,74,0.28);
  --leaf-border: rgba(94,158,74,0.25);

  /* Gold */
  --gold:        rgba(210,172,90,0.85);
  --gold-dim:    rgba(210,172,90,0.2);

  /* Fonts */
  --ff-display:  "Cormorant Garamond", Georgia, serif;
  --ff-body:     "Plus Jakarta Sans", system-ui, sans-serif;

  /* Easing */
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Layout */
  --header-h:    93px;
  --mobile-nav-strip-h: 0px;
  /* Hauteur réelle du header fixe (mesurée en JS) — évite chevauchement hero / bandeau */
  --site-header-offset: 93px;
  --hero-below-header-gap: clamp(4rem, 8vw, 6.5rem);
  --radius-sm:   8px;
  --radius:      14px;
  --radius-lg:   20px;
  --radius-xl:   28px;
  --container:   1060px;
  --tr:          0.22s var(--ease-out);

  /* Spine */
  --gap:         2.5rem;
  --branch-y:    1.1rem;

  /* Touch & motion */
  --touch-min:   2.75rem;
  --transition-ui: 0.25s ease;
}

/* ——— RESET ——— */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;font-size:16px;
  scroll-padding-top:calc(var(--site-header-offset) + 12px);
}
html,body{background:#08090c}
body{
  font-family:var(--ff-body);
  font-size:1rem;
  line-height:1.74;
  color:var(--txt);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition-ui),opacity var(--transition-ui),transform var(--transition-ui),border-color var(--transition-ui),background var(--transition-ui),box-shadow var(--transition-ui)}
ul{list-style:none}
button,input,textarea,select{font:inherit}
.btn,.form-submit,.gallery-tab,.social-btn,.cta-fixed,.modal-close,.mobile-nav-strip .nav-link,.site-nav .nav-link--cta{min-height:var(--touch-min)}
.modal-close{min-width:var(--touch-min)}
.gallery-tab{padding-block:max(.45rem,calc((var(--touch-min) - 1em)/2))}
button:focus-visible,.btn:focus-visible,.form-submit:focus-visible,.gallery-tab:focus-visible,.nav-link:focus-visible,.social-btn:focus-visible,.contact-card:focus-visible,.cta-fixed:focus-visible,.modal-close:focus-visible,.review-card:focus-visible{outline:2px solid var(--leaf2);outline-offset:2px}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ================================================================
   CANVAS + GRAIN + LEAVES
   ================================================================ */
.neural-bg{display:none!important}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
}

/* Feuilles décoratives SVG intégrées */
.leaf-deco{position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.leaf-deco svg{position:absolute}

/* ================================================================
   SCROLL PROGRESS
   ================================================================ */
.scroll-bar{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--acc),var(--leaf));
  z-index:960;box-shadow:0 0 10px var(--acc-glow);
  transition:width .08s linear;
}

/* ================================================================
   SKIP LINK
   ================================================================ */
.skip{position:absolute;left:-9999px;top:0;padding:.5rem 1rem;background:var(--txt);color:var(--bg);z-index:1000}
.skip:focus{left:0}

/* ================================================================
   CONTAINER
   ================================================================ */
.container{width:min(var(--container),100% - 2.5rem);margin-inline:auto}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{
  position:fixed;inset:0 0 auto;z-index:900;height:var(--header-h);
  display:flex;flex-direction:column;align-items:stretch;
  background:transparent;
  backdrop-filter:blur(0);
  border-bottom:1px solid transparent;
  transition:background .4s,backdrop-filter .4s,border-color .4s,box-shadow .4s;
}
/* Bloc unique : logo / réseaux + bandeau mobile (évite tout chevauchement avec le hero) */
.site-header__shell{
  display:flex;flex-direction:column;width:100%;
  flex:1 1 auto;min-height:0;
}
.site-header.scrolled{
  background:rgba(7,8,8,.93);
  backdrop-filter:blur(22px);
  border-bottom-color:var(--border);
  box-shadow:0 1px 0 rgba(255,255,255,.03),0 12px 40px rgba(0,0,0,.65);
}
.header-inner{
  width:100%;padding-inline:clamp(1.8rem,4vw,3.2rem);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  flex:1;min-height:0;
}
@media(min-width:901px){
  .site-header{height:var(--header-h)}
}

/* Logo brand */
.brand{display:flex;align-items:center;gap:1.2rem;flex-shrink:0;z-index:902;transition:opacity var(--tr)}
.brand:hover{opacity:.8}
.brand-logo{
  width:63px;height:63px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.12);
  background:radial-gradient(circle at 50% 35%, rgba(255,255,255,.08), rgba(18,22,18,.95));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
  box-shadow:0 0 0 2px rgba(7,8,8,.9),0 4px 16px rgba(0,0,0,.6),0 0 20px var(--leaf-glow);
  position:relative;
}
/* Pulsation dorée sur le logo */
.brand-logo::after{
  content:'';position:absolute;inset:-3px;border-radius:50%;
  border:1px solid var(--gold-dim);
  animation:logo-pulse 3s ease-in-out infinite;
}
@keyframes logo-pulse{
  0%,100%{opacity:.4;transform:scale(1)}
  50%{opacity:1;transform:scale(1.06)}
}
.brand-logo img{
  width:100%;height:100%;object-fit:contain;display:block;
  padding:2px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));
}
.brand-logo-fallback{font-size:1.1rem;line-height:1}

.brand-name{
  font-family:var(--ff-display);font-weight:600;font-size:1.59rem;
  letter-spacing:.025em;color:#fff;white-space:nowrap;
  animation:name-shimmer 4s ease-in-out infinite;
  background:linear-gradient(90deg,#fff 0%,rgba(210,172,90,.9) 35%,#fff 65%,rgba(210,172,90,.7) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
@keyframes name-shimmer{
  0%{background-position:0% center}
  100%{background-position:200% center}
}

/* Nav */
.site-nav{display:flex;align-items:center;gap:.1rem}
.nav-list{display:flex;align-items:center;gap:.05rem;flex-wrap:nowrap}
.nav-link{
  position:relative;font-size:1.26rem;font-weight:500;
  color:rgba(238,234,224,.68);letter-spacing:.02em;
  padding:.28rem .58rem;border-radius:var(--radius-sm);
  transition:color var(--tr),background var(--tr);white-space:nowrap;
}
.nav-link::after{
  content:'';position:absolute;left:50%;bottom:.1rem;
  width:0;height:1px;background:var(--acc);
  transform:translateX(-50%);transition:width .3s var(--ease-out);
}
.nav-link:hover,.nav-link.active{color:var(--txt)}
.nav-link:hover::after,.nav-link.active::after{width:calc(100% - 1.16rem)}
.nav-link--cta{
  color:#fff!important;padding:.51rem 1.5rem;border-radius:999px;
  border:1px solid rgba(192,57,43,.5);background:rgba(192,57,43,.12);
  transition:background .22s,border-color .22s,box-shadow .22s,transform .2s!important;
}
.nav-link--gold{
  color:var(--gold)!important;
  text-shadow:0 0 8px rgba(210,172,90,.22);
}
.nav-link--cta::after{display:none}
.nav-link--cta:hover{
  background:rgba(192,57,43,.3)!important;border-color:rgba(192,57,43,.75)!important;
  box-shadow:0 4px 20px rgba(192,57,43,.35)!important;transform:translateY(-1px)!important;
}

/* Socials */
.header-end{display:flex;align-items:center;gap:1rem;flex-shrink:0;z-index:902}
.social-btn{
  display:inline-flex;align-items:center;gap:.38rem;
  height:52px;padding:0 1.08rem 0 .93rem;
  border-radius:999px;border:1px solid transparent;
  font-size:1.12rem;font-weight:500;letter-spacing:.01em;
  transition:border-color .22s,background .22s,transform .2s,box-shadow .22s;
  white-space:nowrap;
}
.social-btn:hover{border-color:rgba(255,255,255,.14);background:rgba(255,255,255,.05);transform:translateY(-1px)}
.social-btn svg{width:26px;height:26px;flex-shrink:0}

/* Instagram */
.social-btn--ig{color:#e1306c}
.social-btn--ig:hover{
  border-color:rgba(225,48,108,.4);
  box-shadow:0 4px 16px rgba(225,48,108,.25);
}
/* TikTok */
.social-btn--tt{color:#fff}
.social-btn--tt:hover{
  border-color:rgba(105,201,208,.4);
  box-shadow:0 4px 16px rgba(105,201,208,.2);
}

/* Navigation mobile : bandeau horizontal sous logo / réseaux (sans menu burger) */
.mobile-nav-strip{
  display:none;
}

@media(max-width:900px){
  /* Bandeau : scroll horizontal si besoin — hauteur stable, incluse dans #header pour --site-header-offset */
  :root{--mobile-nav-strip-h:clamp(52px, 11vw, 64px)}
  .site-header{
    height:auto;
    min-height:calc(env(safe-area-inset-top, 0px) + var(--header-h) + var(--mobile-nav-strip-h));
    padding-top:env(safe-area-inset-top, 0px);
    border-bottom-color:rgba(255,255,255,.06);
  }
  .site-header.scrolled{
    border-bottom-color:var(--border);
  }
  .header-inner{
    min-height:var(--header-h);
    height:auto;
    flex:0 0 auto;
    align-items:center;
  }
  #siteNav{display:none!important}
  .social-btn span{display:none}
  .social-btn{padding:0 .5rem;min-width:44px;min-height:44px;justify-content:center}
  .mobile-nav-strip{
    display:block;
    flex:0 0 auto;
    width:100%;
    min-height:var(--mobile-nav-strip-h);
    height:auto;
    border-top:1px solid rgba(255,255,255,.1);
    background:rgba(7,8,8,.96);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    box-sizing:border-box;
  }
  .mobile-nav-strip__list{
    display:flex;
    flex-wrap:nowrap;
    align-items:stretch;
    justify-content:flex-start;
    gap:.35rem;
    list-style:none;margin:0;
    min-height:var(--mobile-nav-strip-h);
    padding:.35rem max(.45rem, env(safe-area-inset-left)) .4rem max(.45rem, env(safe-area-inset-right));
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    width:100%;
    box-sizing:border-box;
  }
  .mobile-nav-strip__list::-webkit-scrollbar{display:none;height:0}
  .mobile-nav-strip__list li{
    flex:0 0 auto;
    display:flex;
  }
  .mobile-nav-strip .nav-link{
    font-family:var(--ff-body);
    font-size:clamp(0.58rem, 2.65vw, 0.78rem);
    font-weight:600;
    letter-spacing:0.02em;
    text-transform:uppercase;
    padding:.38rem .5rem;
    border-radius:var(--radius-sm);
    border:1px solid rgba(255,255,255,.14);
    background:rgba(255,255,255,.06);
    color:#eef2ef!important;
    white-space:nowrap;
    line-height:1.15;
    text-align:center;
    display:flex;
    align-items:center;
    justify-content:center;
    width:auto;
    box-sizing:border-box;
  }
  .mobile-nav-strip .nav-link::after{display:none}
  .mobile-nav-strip .nav-link--gold{
    color:var(--gold)!important;
    border-color:rgba(210,172,90,.35);
    background:rgba(210,172,90,.08);
  }
  .mobile-nav-strip .nav-link--cta{
    border-color:rgba(192,57,43,.55);
    background:rgba(192,57,43,.18);
    color:#fff!important;
  }
  .mobile-nav-strip .nav-link:active{transform:scale(.98)}
}
@media(max-width:380px){
  .brand-name{font-size:clamp(1rem,4.8vw,1.35rem)}
  .brand{gap:.65rem}
  .brand-logo{width:52px;height:52px}
  .header-inner{gap:.55rem;padding-inline:clamp(.65rem,3.2vw,1.1rem)}
  .header-end{gap:.4rem}
  :root{--mobile-nav-strip-h:clamp(50px, 12vw, 62px)}
  .mobile-nav-strip__list{gap:.28rem;padding-inline:max(.35rem, env(safe-area-inset-left))}
  .mobile-nav-strip .nav-link{
    font-size:clamp(0.52rem, 2.5vw, 0.72rem);
    padding:.34rem .42rem;
    letter-spacing:0.01em;
  }
}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  position:relative;
  min-height:clamp(30rem,90svh,46rem);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  /* offset = hauteur réelle #header (logo + bandeau mobile), pas une estimation CSS */
  padding-top:calc(env(safe-area-inset-top, 0px) + var(--site-header-offset) + var(--hero-below-header-gap));
  padding-bottom:clamp(2rem,4vh,3.5rem);
  padding-inline:1.5rem;
  overflow-x:clip;
  overflow-y:visible;
}
@media(max-width:900px){
  :root{
    /* Avant mesure JS : marge sûre (safe-area + logo + bandeau) — écrasée par le script */
    --site-header-offset:210px;
    --hero-below-header-gap:clamp(2.75rem, 9vw, 4.5rem);
  }
  /* Safe-area déjà dans la hauteur du header mesurée — évite double comptage avec le hero */
  .hero{
    justify-content:flex-start;
    align-items:stretch;
    min-height:min(100svh, 52rem);
    padding-bottom:clamp(2.5rem, 6vh, 4rem);
    padding-top:calc(var(--site-header-offset) + var(--hero-below-header-gap));
  }
  .hero-content{
    width:100%;
    max-width:min(60rem, 100%);
    padding-top:clamp(1rem, 4vw, 2rem);
    padding-bottom:.25rem;
  }
}

/* Fond hero */
.hero-bg{display:none}
.hero-overlay{display:none}
.hero-vignette{display:none}

/* Contenu hero */
.hero-content{
  position:relative;z-index:2;
  width:100%;max-width:min(60rem,100%);
  margin-inline:auto;text-align:center;
  padding-top:clamp(1.25rem,3.5vw,2.75rem);
}

/* Hero card */
.hero-card{
  position:relative;
  padding:clamp(2.2rem,5vw,3.2rem) clamp(1.8rem,4vw,2.8rem);
  border-radius:var(--radius-xl);
  border:1px solid rgba(255,255,255,.08);
  background:rgba(7,8,8,.48);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  box-shadow:0 0 0 1px rgba(192,57,43,.1),0 36px 90px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.07);
  overflow:hidden;
  max-width:52rem;margin-inline:auto;
}
.hero-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:
    radial-gradient(ellipse 110% 80% at 50% -15%,rgba(192,57,43,.14) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 100% 100%,rgba(94,158,74,.06) 0%,transparent 55%);
}
/* Shimmer top */
.hero-card::after{
  content:'';position:absolute;top:0;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(210,172,90,.55),rgba(192,57,43,.65),rgba(210,172,90,.55),transparent);
  border-radius:999px;
}
.hero-card>*{position:relative;z-index:1}
@media(max-width:900px){
  .hero-card{
    padding-top:clamp(2.6rem, 6.5vw, 3.4rem);
  }
}

/* Eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);padding:.32rem .9rem;border-radius:999px;
  border:1px solid var(--gold-dim);background:rgba(210,172,90,.06);
  margin:0 auto 1.2rem;
}
.eyebrow-dot{
  width:5px;height:5px;border-radius:50%;background:var(--gold);
  animation:dot-pulse 2.8s ease-in-out infinite;flex-shrink:0;
}
@media(max-width:600px){
  .eyebrow{
    white-space:normal;
    max-width:100%;
    text-align:center;
    line-height:1.35;
    padding:.4rem .75rem;
    letter-spacing:.12em;
  }
}
@keyframes dot-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.75)}}

.hero-title{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem,5.5vw,3.6rem);
  font-weight:700;line-height:1.08;letter-spacing:-.02em;
  color:#fff;margin-bottom:1.05rem;
}
.hero-title em{color:var(--acc2);font-style:italic}
.hero-sub{
  color:#eef2ef;font-size:clamp(.9375rem,1.5vw,1.0625rem);
  line-height:1.72;max-width:38em;margin-inline:auto;
  font-weight:300;margin-bottom:1.85rem;text-align:center;
}

/* Badges certif */
.hero-badges{
  display:flex;flex-wrap:wrap;gap:.55rem;
  justify-content:center;margin-bottom:1.75rem;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.71rem;font-weight:600;letter-spacing:.06em;
  padding:.28rem .78rem;border-radius:999px;
  border:1px solid rgba(126,190,97,.42);
  background:linear-gradient(180deg,rgba(94,158,74,.2),rgba(94,158,74,.1));
  color:#9ed07f;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 6px 18px rgba(0,0,0,.2);
  text-decoration:none;
}
.hero-badges a.hero-badge{
  cursor:pointer;
  position:relative;
  transition:transform .22s var(--ease-spring),box-shadow .22s,border-color .22s,filter .22s;
  animation:badge-callout 3.2s ease-in-out infinite;
}
.hero-badges a.hero-badge::after{
  content:'↗';
  font-size:.62rem;
  opacity:0;
  transform:translateX(-2px);
  transition:opacity .2s,transform .2s;
}
.hero-badges a.hero-badge:hover,
.hero-badges a.hero-badge:focus-visible{
  transform:translateY(-2px) scale(1.02);
  border-color:rgba(158,208,127,.8);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 10px 24px rgba(0,0,0,.3),0 0 16px rgba(94,158,74,.22);
  filter:brightness(1.06);
}
.hero-badges a.hero-badge:hover::after,
.hero-badges a.hero-badge:focus-visible::after{
  opacity:.95;
  transform:translateX(1px);
}
@keyframes badge-callout{
  0%,100%{box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 6px 18px rgba(0,0,0,.2)}
  50%{box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 8px 22px rgba(0,0,0,.24),0 0 12px rgba(94,158,74,.16)}
}

.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-bottom:1.75rem}

/* Stats strip */
.stats-strip{
  display:flex;flex-wrap:wrap;border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(180deg,rgba(28,33,28,.72),rgba(16,20,17,.62));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 12px 30px rgba(0,0,0,.25);
}
.stat{flex:1;min-width:7rem;padding:1.1rem .75rem;text-align:center;position:relative}
.stat+.stat::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:var(--border)}
.stat-val{
  display:block;font-family:var(--ff-display);font-size:1.65rem;font-weight:700;
  color:#eef2ef;line-height:1;margin-bottom:.28rem;
}
.stat-lbl{display:block;font-size:.69rem;color:#d4a843;letter-spacing:.1em;text-transform:uppercase}

/* Reveal anims */
.reveal{opacity:0;transform:translateY(14px);animation:fade-up .9s var(--ease-out) forwards;animation-delay:var(--d,0ms)}
@keyframes fade-up{to{opacity:1;transform:translateY(0)}}

/* ——— BOUTONS ——— */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.78rem 1.65rem;border-radius:999px;font-family:var(--ff-body);
  font-weight:600;font-size:.875rem;letter-spacing:.01em;
  border:1px solid transparent;cursor:pointer;
  transition:background .22s,border-color .22s,transform .2s var(--ease-spring),box-shadow .22s;
}
.btn-primary{
  background:var(--acc);color:#fff;
  box-shadow:0 4px 22px rgba(192,57,43,.38),inset 0 1px 0 rgba(255,255,255,.16);
}
.btn-primary:hover{background:#a93020;transform:translateY(-2px) scale(1.02);box-shadow:0 12px 34px rgba(192,57,43,.52)}
.btn-ghost{border-color:rgba(238,234,224,.2);color:#fff;background:rgba(238,234,224,.04)}
.btn-ghost:hover{border-color:rgba(238,234,224,.38);background:rgba(238,234,224,.09);transform:translateY(-2px)}
.btn-leaf{
  border-color:var(--leaf-border);color:var(--leaf2);background:var(--leaf-dim);
}
.btn-leaf:hover{background:rgba(94,158,74,.25);border-color:rgba(94,158,74,.5);transform:translateY(-2px);box-shadow:0 6px 20px rgba(94,158,74,.2)}
.btn-arrow{display:inline-block;transition:transform .2s var(--ease-out)}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* ================================================================
   SECTIONS — structure commune
   ================================================================ */
/* padding-block séparé : le hero définit son propre padding-top (sous le header fixe) */
.section{
  scroll-margin-top:calc(var(--site-header-offset) + 14px);
  position:relative;z-index:2;background:transparent;
}
.section:not(.hero){padding-block:4.5rem}

/* Neon divider — battement de cœur ECG vert scintillant */
@keyframes ecg-scroll{
  from{background-position:500px center}
  to{background-position:0px center}
}
.section::before{display:none}
.section-divider{display:none}

/* Section head card — fond gris, liseré rouge unifié */
.section-head,
.section-head--clean{
  position:relative;padding:clamp(1.5rem,3vw,2.1rem) clamp(1.25rem,2.8vw,2.2rem);
  border-radius:var(--radius-lg);
  border:1px solid rgba(192,57,43,.55);
  background:#16191d;
  overflow:hidden;
  box-shadow:0 12px 38px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.04);
  margin-bottom:3.25rem;max-width:50rem;margin-inline:auto;text-align:center;
}
.section-head::before,
.section-head--clean::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  background:radial-gradient(ellipse 70% 55% at 15% 40%,rgba(192,57,43,.1) 0%,transparent 55%),
             radial-gradient(ellipse 50% 40% at 90% 70%,rgba(192,57,43,.07) 0%,transparent 50%);
}
@keyframes head-aura{
  0%,100%{box-shadow:0 12px 38px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.04),0 0 0 1px rgba(192,57,43,.32) inset,0 0 22px rgba(192,57,43,.22)}
  50%{box-shadow:0 12px 38px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.04),0 0 0 1px rgba(192,57,43,.58) inset,0 0 38px rgba(192,57,43,.38)}
}
.section-head,
.section-head--clean{animation:head-aura 4.2s ease-in-out infinite}
.section-head>*,
.section-head--clean>*{position:relative;z-index:1}
@media(prefers-reduced-motion:reduce){
  .section-head::after{animation:head-aura 4.2s ease-in-out infinite}
}

.section-title{
  font-family:var(--ff-display);font-size:clamp(2rem,4vw,2.65rem);font-weight:700;
  letter-spacing:-.022em;color:#fff;position:relative;display:inline-block;
  margin-bottom:.6rem;
}
.section-title::after{
  content:'';position:absolute;left:18%;right:18%;bottom:-.28em;height:1px;
  background:linear-gradient(90deg,transparent,rgba(192,57,43,.65),rgba(94,158,74,.45),transparent);
  border-radius:999px;
}
.section-lead{color:#eef2ef;font-size:.9375rem;line-height:1.68;font-weight:400}

/* ================================================================
   SPINE FLOW — alternance gauche / droite
   ================================================================ */
.spine-flow{
  list-style:none;display:flex;flex-direction:column;gap:1.5rem;
  max-width:56rem;margin-inline:auto;position:relative;z-index:2;
}
.spine-item{position:relative}
.spine-card{padding-top:0;position:relative;z-index:2}

@media(min-width:720px){
  .spine-flow--alt .spine-item:nth-child(odd){width:calc(50% - var(--gap));margin-right:auto;padding-right:2rem}
  .spine-flow--alt .spine-item:nth-child(even){width:calc(50% - var(--gap));margin-left:auto;padding-left:2rem}
  .spine-flow--alt .spine-item:nth-child(odd) .spine-card{margin-left:0;margin-right:auto}
  .spine-flow--alt .spine-item:nth-child(even) .spine-card{margin-right:0;margin-left:auto}
  .spine-flow--alt .spine-item:nth-child(odd)::before{
    content:'';position:absolute;left:100%;top:var(--branch-y);width:var(--gap);height:1.5px;
    background:linear-gradient(90deg,rgba(255,255,255,.75),rgba(255,255,255,.25),transparent);
    border-radius:1px;z-index:0;
    animation:spine-shimmer 2.8s ease-in-out infinite;
  }
  .spine-flow--alt .spine-item:nth-child(even)::before{
    content:'';position:absolute;right:100%;top:var(--branch-y);width:var(--gap);height:1.5px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),rgba(255,255,255,.75));
    border-radius:1px;z-index:0;
    animation:spine-shimmer 2.8s ease-in-out infinite;
  }
  .spine-flow--alt .spine-item:nth-child(odd) .content-card{text-align:left}
  .spine-flow--alt .spine-item:nth-child(even) .content-card{text-align:right}
}
@media(max-width:719px){.spine-flow--alt .spine-item::before{display:none}}

/* ——— CONTENT CARD ——— */
.content-card{
  background:var(--surf);border:1px solid rgba(255,255,255,.13);
  border-radius:var(--radius-lg);padding:1.65rem 1.8rem;
  position:relative;overflow:hidden;z-index:2;isolation:isolate;
  transition:transform .22s var(--ease-out),border-color .22s,box-shadow .22s;
}
.content-card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  border:1px solid rgba(255,255,255,.09);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.02);
  animation:card-shimmer 3.4s ease-in-out infinite;
}
.content-card::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(192,57,43,.05) 0%,transparent 55%);
  opacity:0;transition:opacity .4s;
}
.content-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.24);box-shadow:0 14px 44px rgba(0,0,0,.52),0 0 16px rgba(255,255,255,.12)}
.content-card:hover::before{opacity:1}
/* Leaf accent top */
.content-card--leaf{border-color:rgba(255,255,255,.13)}
.content-card--leaf:hover{border-color:rgba(255,255,255,.24);box-shadow:0 14px 44px rgba(0,0,0,.52),0 0 16px rgba(255,255,255,.12)}
.content-card>*{position:relative;z-index:1}
@keyframes spine-shimmer{
  0%,100%{opacity:.55;filter:drop-shadow(0 0 2px rgba(255,255,255,.15))}
  50%{opacity:1;filter:drop-shadow(0 0 7px rgba(255,255,255,.32))}
}
@keyframes card-shimmer{
  0%,100%{opacity:.55}
  50%{opacity:.95}
}
.card-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:var(--radius-sm);
  background:var(--acc-dim);border:1px solid var(--border-acc);
  font-size:1.15rem;margin-bottom:.9rem;
}
.card-icon--leaf{background:var(--leaf-dim);border-color:var(--leaf-border)}
.card-title{
  font-family:var(--ff-display);font-size:1.1rem;font-weight:600;
  color:#fff;margin-bottom:.6rem;
}
.card-body{color:var(--txt-m);font-size:.9375rem;line-height:1.7;font-weight:300}
.card-body strong{color:var(--txt);font-weight:600}
.card-list{padding-left:0;color:var(--txt-m);font-size:.9375rem;list-style:none}
.card-list li{padding-left:1.2rem;position:relative;margin-bottom:.3rem}
.card-list li::before{content:'→';position:absolute;left:0;color:var(--leaf);font-size:.75rem;top:.15em}

/* ================================================================
   RÉVEIL SCROLL
   ================================================================ */
.ros{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.ros.visible{opacity:1;transform:translateY(0)}

/* ================================================================
   PRÉSENTATION
   ================================================================ */
.section--pres{padding-top:3.5rem}
.presentation-trail{position:relative}
.section--pres .spine-item::before{display:none!important;content:none!important}

/* Cards "Qui suis-je ?" — liseré vert scintillant, contenu centré */
.section--pres .content-card,
.section--pres .content-card--leaf{
  background:#1c1f23;
  border:1px solid rgba(123,191,97,.55);
  padding:1.4rem 1.65rem;
  text-align:center;
  box-shadow:
    0 0 0 1px rgba(94,158,74,.15),
    0 0 18px rgba(94,158,74,.18),
    0 14px 36px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.04);
  animation:pres-card-glow 3.6s ease-in-out infinite;
}
.section--pres .content-card::after{
  border:1px solid rgba(123,191,97,.35);
  box-shadow:inset 0 0 14px rgba(94,158,74,.12);
  animation:pres-card-shimmer 3.4s ease-in-out infinite;
}
.section--pres .content-card::before{
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(94,158,74,.18) 0%,transparent 60%);
}
.section--pres .content-card:hover,
.section--pres .content-card--leaf:hover{
  border-color:rgba(160,220,130,.85);
  box-shadow:
    0 0 0 1px rgba(123,191,97,.35),
    0 0 26px rgba(123,191,97,.45),
    0 18px 48px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.section--pres .card-icon,
.section--pres .card-icon--leaf{
  display:flex;margin:0 auto .9rem;
  background:rgba(94,158,74,.18);
  border-color:rgba(123,191,97,.55);
}
.section--pres .card-title{
  display:inline-block;
  color:#fff;text-align:center;font-weight:700;
  padding:.28rem .85rem;
  border:1px solid rgba(123,191,97,.45);
  border-radius:999px;
  background:rgba(94,158,74,.1);
  box-shadow:0 0 8px rgba(94,158,74,.18),inset 0 1px 0 rgba(255,255,255,.06);
  margin-bottom:.7rem;
}
.section--pres .card-body{
  color:#f4f6f3;text-align:center;font-weight:400;
}
.section--pres .card-body strong{color:#fff}
@media(min-width:720px){
  .section--pres .spine-flow--alt .spine-item:nth-child(odd) .content-card,
  .section--pres .spine-flow--alt .spine-item:nth-child(even) .content-card{
    text-align:center;
  }
}
@keyframes pres-card-glow{
  0%,100%{
    box-shadow:
      0 0 0 1px rgba(94,158,74,.15),
      0 0 14px rgba(94,158,74,.16),
      0 14px 36px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(255,255,255,.04);
  }
  50%{
    box-shadow:
      0 0 0 1px rgba(123,191,97,.32),
      0 0 26px rgba(123,191,97,.38),
      0 14px 36px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(255,255,255,.06);
  }
}
@keyframes pres-card-shimmer{
  0%,100%{opacity:.55}
  50%{opacity:1}
}
@media(prefers-reduced-motion:reduce){
  .section--pres .content-card,
  .section--pres .content-card::after{animation:none}
}

/* ================================================================
   MÉTHODE — timeline
   ================================================================ */
.timeline{
  position:relative;z-index:2;max-width:56rem;
  margin-inline:auto;margin-bottom:3.25rem;
}
.timeline-list{display:flex;flex-direction:column;gap:1.5rem;list-style:none}
.timeline-item{position:relative;width:100%}
.timeline-step{
  display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:var(--radius-sm);
  background:rgba(94,158,74,.18);border:1px solid rgba(123,191,97,.55);
  font-size:1.15rem;line-height:1;margin:0 auto .9rem;
}
.trail-layer{display:none}
@media(min-width:640px){
  .timeline-item .timeline-card{width:calc(50% - var(--gap));max-width:none}
  .timeline-item:nth-child(odd) .timeline-card{margin-right:auto;margin-left:0;text-align:center}
  .timeline-item:nth-child(even) .timeline-card{margin-left:auto;margin-right:0;text-align:center}
}
@media(min-width:720px){
  .timeline-item:nth-child(odd)::before{
    content:'';position:absolute;left:calc(50% - var(--gap));top:1.1rem;
    width:var(--gap);height:1.5px;border-radius:1px;z-index:0;
    background:linear-gradient(90deg,rgba(123,191,97,.7),transparent);
  }
  .timeline-item:nth-child(even)::before{
    content:'';position:absolute;left:50%;top:1.1rem;
    width:var(--gap);height:1.5px;border-radius:1px;z-index:0;
    background:linear-gradient(90deg,transparent,rgba(123,191,97,.7));
  }
  .timeline-item:nth-child(odd) .timeline-card,
  .timeline-item:nth-child(even) .timeline-card{text-align:center}
}
@media(max-width:719px){.timeline-item::before{display:none}}
.timeline-card{
  background:#1c1f23;
  border:1px solid rgba(123,191,97,.55);border-radius:var(--radius-lg);
  padding:1.4rem 1.65rem;position:relative;z-index:2;overflow:hidden;
  text-align:center;isolation:isolate;
  transition:transform .22s var(--ease-out),border-color .22s,box-shadow .22s;
  box-shadow:
    0 0 0 1px rgba(94,158,74,.15),
    0 0 18px rgba(94,158,74,.18),
    0 14px 36px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.04);
  animation:pres-card-glow 3.6s ease-in-out infinite;
}
.timeline-card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  border:1px solid rgba(123,191,97,.35);
  box-shadow:inset 0 0 14px rgba(94,158,74,.12);
  animation:pres-card-shimmer 3.4s ease-in-out infinite;
}
.timeline-card::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(94,158,74,.18) 0%,transparent 60%);
  opacity:0;transition:opacity .4s;
}
.timeline-card>*{position:relative;z-index:1}
.timeline-item:hover .timeline-card{
  transform:translateY(-4px);
  border-color:rgba(160,220,130,.85);
  box-shadow:
    0 0 0 1px rgba(123,191,97,.35),
    0 0 26px rgba(123,191,97,.45),
    0 18px 48px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.timeline-item:hover .timeline-card::before{opacity:1}
.timeline-title{
  font-family:var(--ff-display);font-size:1.05rem;font-weight:700;color:#fff;
  text-align:center;
  display:inline-block;
  padding:.28rem .85rem;
  border:1px solid rgba(123,191,97,.45);
  border-radius:999px;
  background:rgba(94,158,74,.1);
  box-shadow:0 0 8px rgba(94,158,74,.18),inset 0 1px 0 rgba(255,255,255,.06);
  margin-bottom:.6rem;
}
.timeline-card p{color:#f4f6f3;font-size:.9375rem;font-weight:400;margin:0;text-align:center}
@media(prefers-reduced-motion:reduce){
  .timeline-card,
  .timeline-card::after{animation:none}
}
/* Composition arbre visuelle (desktop) */
.timeline-tree{
  display:none;
  position:absolute;inset:0;
  width:100%;height:100%;
  pointer-events:none;z-index:0;
}
@media(min-width:980px){
  .timeline{
    max-width:78rem;
    min-height:980px;
    margin-top:.4rem;
  }
  .timeline-tree{display:none!important}
  .timeline::before{content:none}
  .trail-layer{
    display:block;
    position:absolute;
    inset:0;
    z-index:1;
    pointer-events:none;
    overflow:hidden;
  }
  .paw{
    position:absolute;
    opacity:0;
    animation:pawLand .45s cubic-bezier(.22,1,.36,1) var(--d) both;
    will-change:transform,opacity;
  }
  .paw::before{
    content:'';
    position:absolute;
    inset:0;
    background:rgba(255,255,255,.82);
    mask-image:var(--paw-mask);
    mask-size:contain;
    mask-repeat:no-repeat;
    mask-position:center;
    -webkit-mask-image:var(--paw-mask);
    -webkit-mask-size:contain;
    -webkit-mask-repeat:no-repeat;
    -webkit-mask-position:center;
    filter:drop-shadow(0 0 1px rgba(0,0,0,.35));
  }
  @keyframes pawLand{
    0%{opacity:0;transform:scale(.35) rotate(var(--tilt-start))}
    20%{opacity:1;transform:scale(1.08) rotate(var(--tilt-end))}
    38%{opacity:.88;transform:scale(1) rotate(var(--tilt-end))}
    100%{opacity:.82;transform:scale(1) rotate(var(--tilt-end))}
  }
  .timeline-list{
    position:relative;
    min-height:980px;
    display:block;
    padding:0;
  }
  .timeline-item{
    position:absolute;
    width:min(33%,390px);
  }
  .timeline-item .timeline-card{
    width:100%;
    max-width:none;
    margin:0;
    z-index:12;
  }
  .timeline-item:nth-child(1){left:10%;top:12%}
  .timeline-item:nth-child(2){right:9%;top:29%}
  .timeline-item:nth-child(3){left:10%;top:51%}
  .timeline-item:nth-child(4){right:9%;top:70%}
  .timeline-item::before{display:none!important}

  .timeline-item::after{content:none}
}

/* Method intro block — card mise en valeur, liseré vert scintillant */
.method-intro{
  max-width:none;margin-inline:auto;margin-bottom:3rem;
  padding:2.2rem 2.4rem;border-radius:var(--radius-lg);
  border:1.5px solid rgba(123,191,97,.65);
  background:#1c1f23;text-align:center;position:relative;z-index:2;overflow:hidden;
  transition:transform .26s var(--ease-spring),border-color .22s,box-shadow .22s;
  box-shadow:
    0 0 0 1px rgba(94,158,74,.18),
    0 0 26px rgba(94,158,74,.28),
    0 22px 52px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.05);
  animation:pres-card-glow 3.6s ease-in-out infinite;
}
.method-intro::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  border:1px solid rgba(123,191,97,.35);
  box-shadow:inset 0 0 18px rgba(94,158,74,.15);
  animation:pres-card-shimmer 3.4s ease-in-out infinite;
}
.method-intro>*{position:relative;z-index:1}
@media(min-width:720px){
  .method-intro{width:calc(50% - var(--gap));max-width:none}
}
.method-intro:hover{
  transform:translateY(-3px) scale(1.012);
  border-color:rgba(170,225,135,.95);
  box-shadow:
    0 0 0 1px rgba(123,191,97,.4),
    0 0 38px rgba(123,191,97,.5),
    0 26px 64px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(255,255,255,.07);
}
.method-intro-title{
  font-family:var(--ff-display);font-size:1.32rem;font-weight:600;
  color:#fff;margin-bottom:.9rem;text-align:center;
}
.method-intro .card-body{color:#f4f6f3;text-align:center;font-weight:400}
.method-intro .card-body strong{color:#fff}
.method-intro .card-list{display:inline-block;text-align:left;margin-inline:auto}
@media(prefers-reduced-motion:reduce){
  .method-intro,
  .method-intro::after{animation:none}
}

/* Puppy block — card mise en valeur */
.puppy-block{
  background:#1c1f23;
  border:1.5px solid rgba(123,191,97,.65);
  border-radius:var(--radius-lg);padding:3.4rem 2.4rem 2.2rem;
  text-align:center;position:relative;z-index:2;overflow:hidden;
  transition:transform .26s var(--ease-spring),border-color .22s,box-shadow .22s;
  margin-inline:auto;max-width:none;
  box-shadow:
    0 0 0 1px rgba(94,158,74,.18),
    0 0 26px rgba(94,158,74,.28),
    0 22px 52px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.05);
  animation:pres-card-glow 3.6s ease-in-out infinite;
}
.puppy-block::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  border:1px solid rgba(123,191,97,.35);
  box-shadow:inset 0 0 18px rgba(94,158,74,.15);
  animation:pres-card-shimmer 3.4s ease-in-out infinite;
}
.puppy-block>*{position:relative;z-index:1}
@media(min-width:720px){.puppy-block{width:calc(50% - var(--gap));max-width:none}}
.puppy-block:hover{
  transform:translateY(-3px) scale(1.012);
  border-color:rgba(170,225,135,.95);
  box-shadow:
    0 0 0 1px rgba(123,191,97,.4),
    0 0 38px rgba(123,191,97,.5),
    0 26px 64px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(255,255,255,.07);
}
.puppy-title{font-family:var(--ff-display);font-size:1.32rem;font-weight:600;color:#fff;margin-bottom:.9rem;text-align:center}
.puppy-block .card-body{color:#f4f6f3;font-weight:400;text-align:center}
.puppy-block .card-body strong{color:#fff}
.puppy-grid{display:grid;gap:1.5rem;margin-top:1.4rem;text-align:left}
@media(min-width:800px){.puppy-grid{grid-template-columns:1fr 1fr}}
.puppy-sub{font-size:1rem;font-weight:600;color:#fff;margin-bottom:.55rem}
.puppy-grid ul{list-style:none;color:#e9ede7;font-size:.9375rem}
.puppy-grid ul li{padding-left:1.2rem;position:relative;margin-bottom:.35rem}
.puppy-grid ul li::before{content:'🌿';position:absolute;left:0;font-size:.65rem;top:.2em}

/* Badge "EN BONUS" — coin sup. droit, doré scintillant */
.bonus-badge{
  position:absolute;top:1rem;left:50%;transform:translateX(-50%);z-index:3;white-space:nowrap;
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.32rem .65rem .32rem .55rem;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(232,189,98,.95),rgba(196,148,63,.95));
  color:#1a1208;
  font-family:var(--ff-body);font-size:.66rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;
  border:1px solid rgba(255,225,150,.85);
  box-shadow:
    0 4px 14px rgba(210,172,90,.45),
    0 0 18px rgba(255,228,160,.3),
    inset 0 1px 0 rgba(255,255,255,.45);
  animation:bonus-pulse 2.2s ease-in-out infinite;
}
.bonus-star{font-size:.85rem;display:inline-block;animation:bonus-spin 4s linear infinite}
.bonus-label{line-height:1}
@keyframes bonus-pulse{
  0%,100%{box-shadow:0 4px 14px rgba(210,172,90,.45),0 0 18px rgba(255,228,160,.3),inset 0 1px 0 rgba(255,255,255,.45)}
  50%{box-shadow:0 6px 22px rgba(210,172,90,.65),0 0 32px rgba(255,228,160,.55),inset 0 1px 0 rgba(255,255,255,.5)}
}
@keyframes bonus-spin{
  0%{transform:rotate(0deg) scale(1)}
  50%{transform:rotate(180deg) scale(1.18)}
  100%{transform:rotate(360deg) scale(1)}
}
@media(prefers-reduced-motion:reduce){
  .puppy-block,.puppy-block::after,
  .bonus-badge,.bonus-star{animation:none}
}

/* ================================================================
   GALERIE — système intelligent par filtres
   ================================================================ */
.gallery-tabs{
  display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem;
}
.gallery-tab{
  padding:.38rem .9rem;border-radius:999px;font-size:.78rem;font-weight:600;
  border:1px solid var(--border);background:transparent;color:var(--txt-m);
  cursor:pointer;transition:all .2s;letter-spacing:.02em;
}
.gallery-tab:hover,.gallery-tab.active{
  background:var(--leaf-dim);border-color:var(--leaf-border);color:var(--leaf2);
  box-shadow:0 4px 14px rgba(94,158,74,.15);
}
.gallery-tab.active-acc{background:var(--acc-dim);border-color:var(--border-acc);color:var(--acc2)}
.gallery-tab--mine{
  border-color:rgba(210,172,90,.42);color:var(--gold);
}
.gallery-tab--mine:hover,.gallery-tab--mine.active{
  background:rgba(210,172,90,.12);border-color:var(--gold-dim);color:var(--gold);
  box-shadow:0 4px 16px rgba(210,172,90,.18);
}
/* Séparateur visuel entre « Chiots » et « Mon chien » (hors des pastilles) */
.gallery-tab-sep{
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
  font-size:1.05rem;line-height:1;
  padding:0 .1rem;
  opacity:.72;
  user-select:none;pointer-events:none;
}

.gallery-grid{
  display:grid;gap:1.1rem;
  grid-template-columns:repeat(auto-fill,minmax(min(18rem,100%),1fr));
  max-width:58rem;margin-inline:auto;
}
.dog-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);background:var(--surf);
  transition:border-color .22s,box-shadow .22s,transform .22s;cursor:pointer;
}
.dog-card:hover{border-color:var(--border-h);box-shadow:0 12px 42px rgba(0,0,0,.55);transform:translateY(-3px)}
.dog-card--mine{
  border-color:rgba(210,172,90,.35);
  box-shadow:0 0 0 1px rgba(210,172,90,.12);
}
.dog-card--mine:hover{border-color:rgba(210,172,90,.55);box-shadow:0 12px 42px rgba(0,0,0,.55),0 0 20px rgba(210,172,90,.12)}
/* Carte « récit » (modèle Mon chien) : centrée, pleine largeur de grille, texte lisible mobile */
.gallery-grid .dog-card--story{
  grid-column:1/-1;
  width:100%;
  max-width:min(42rem,100%);
  margin-inline:auto;
  justify-self:center;
  overflow:hidden;
}
.dog-card--story{cursor:pointer}
.dog-card--story:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 52px rgba(0,0,0,.52),0 0 0 1px rgba(210,172,90,.28);
}
.dog-card-story__media{
  position:relative;
  width:100%;
  max-height:min(52vh,28rem);
  min-height:11rem;
  background:var(--surf2);
  overflow:hidden;
  border-bottom:1px solid rgba(210,172,90,.12);
}
.dog-card-story__img{
  width:100%;
  height:100%;
  min-height:11rem;
  max-height:min(52vh,28rem);
  object-fit:cover;
  object-position:center 28%;
  display:block;
}
.dog-card-story__body{
  padding:clamp(1.15rem,3.5vw,1.65rem) clamp(1rem,3.2vw,1.5rem) clamp(1.35rem,3.8vw,1.85rem);
  text-align:left;
}
.dog-card-story__badges{
  display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;
  margin-bottom:.85rem;
}
.dog-card-story__heading{
  font-family:var(--ff-display);
  font-size:clamp(1.05rem,3.2vw,1.28rem);
  font-weight:600;
  color:var(--txt);
  line-height:1.38;
  margin-bottom:.75rem;
  letter-spacing:.01em;
}
.dog-card-story__cta-hint{
  font-size:.8rem;font-weight:500;color:var(--gold);
  letter-spacing:.04em;margin:0;
  display:inline-flex;align-items:center;gap:.35rem;
  opacity:.9;
}
.dog-card-story__cta-hint::after{content:'→';font-size:.95rem;opacity:.85}
@media(max-width:479px){
  .dog-card-story__body{padding-inline:clamp(.85rem,4vw,1.1rem)}
}
.dog-card-visual{aspect-ratio:4/3;position:relative;overflow:hidden}
.dog-card-img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.dog-card:hover .dog-card-img{transform:scale(1.06)}
.dog-card-placeholder{
  width:100%;height:100%;
  background:linear-gradient(165deg,rgba(24,28,23,.95),rgba(12,14,12,.98));
  border-bottom:1px solid rgba(210,172,90,.12);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.5rem;
  text-align:center;
}
.dog-card-placeholder__icon{
  font-size:clamp(2.25rem,7vw,3.05rem);
  line-height:1;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.5));
}
.dog-card-placeholder__hint{
  font-size:.64rem;
  font-weight:600;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--txt-d);
}
.dog-card-visual:has(.dog-card-img) .dog-card-placeholder{display:none}
.dog-card-overlay{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1rem 1.1rem;
  background:linear-gradient(180deg,transparent 30%,rgba(7,8,8,.95) 100%);
  opacity:.92;transition:opacity .2s;
}
.dog-card:hover .dog-card-overlay{opacity:1}
.dog-card-name{font-family:var(--ff-display);font-size:1.05rem;font-weight:600;color:#fff;margin-bottom:.18rem;text-align:center}
.dog-card-meta{font-size:.8rem;color:var(--txt-m);display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.dog-card-badge{
  display:inline-flex;align-items:center;gap:.25rem;font-size:.68rem;font-weight:600;
  padding:.18rem .55rem;border-radius:999px;background:rgba(94,158,74,.18);
  border:1px solid var(--leaf-border);color:var(--leaf2);
}

/* Ajout facile — instruction */
.gallery-add-hint{
  text-align:center;margin-top:1.5rem;
  padding:.85rem 1.2rem;border:1px dashed var(--border);border-radius:var(--radius);
  color:var(--txt-d);font-size:.82rem;line-height:1.6;
}

/* ================================================================
   LIVRE D'OR — scroll infini horizontal
   ================================================================ */
.reviews-ticker-wrap{
  position:relative;overflow:hidden;margin-bottom:1.5rem;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);
}
.reviews-ticker-wrap:focus-within{
  outline:2px solid var(--leaf2);outline-offset:4px;border-radius:var(--radius-sm);
}
.reviews-ticker{
  display:flex;gap:1.1rem;
  animation:ticker-scroll 40s linear infinite;
  width:max-content;
  will-change:transform;
}
.reviews-ticker-wrap:hover .reviews-ticker,
.reviews-ticker-wrap:focus-within .reviews-ticker{animation-play-state:paused}
@keyframes ticker-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.review-card{
  width:clamp(17.5rem,32vw,21.25rem);flex-shrink:0;
  background:var(--surf);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:1.6rem 1.75rem;
  position:relative;overflow:hidden;
  transition:border-color var(--transition-ui),box-shadow var(--transition-ui),transform var(--transition-ui);
  cursor:default;
}
.review-card:hover{border-color:var(--border-h);box-shadow:0 8px 28px rgba(0,0,0,.45)}
.review-card:focus-visible{outline:2px solid var(--leaf2);outline-offset:3px}
.review-card::before{
  content:'\201C';position:absolute;top:.4rem;left:1.1rem;
  font-family:var(--ff-display);font-size:4.5rem;line-height:1;
  color:rgba(192,57,43,.12);user-select:none;pointer-events:none;
}
.review-card>*{position:relative;z-index:1}
.review-photo{
  width:48px;height:48px;border-radius:50%;object-fit:cover;
  border:2px solid var(--border-leaf);margin-bottom:.9rem;
  background:var(--surf2);overflow:hidden;flex-shrink:0;
}
.review-photo-placeholder{
  width:48px;height:48px;border-radius:50%;
  background:var(--surf2);border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;margin-bottom:.9rem;
}
.review-stars{
  color:#e7c56a;font-size:.9rem;letter-spacing:.08em;margin-bottom:.65rem;
  text-shadow:0 0 8px rgba(231,197,106,.26),0 0 16px rgba(231,197,106,.14);
}
.review-stars .dim{color:rgba(231,197,106,.35)}
.review-text{
  font-family:var(--ff-display);font-size:.975rem;font-style:italic;
  color:rgba(238,234,224,.88);line-height:1.72;margin-bottom:.85rem;font-weight:400;
}
.review-author{
  font-size:.8rem;color:var(--txt-m);font-weight:500;text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.review-screen{
  width:100%;border-radius:var(--radius-sm);overflow:hidden;
  border:1px solid var(--border);margin-bottom:.85rem;
  background:var(--surf2);max-height:160px;object-fit:cover;
}

/* Galerie perso en défilement */
.personal-ticker-wrap{
  position:relative;overflow:hidden;margin-top:.2rem;
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  transform:none;
  padding-inline:clamp(.45rem,2.4vw,1.25rem);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 6%,#000 94%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 6%,#000 94%,transparent 100%);
  box-sizing:border-box;
}
.personal-ticker{
  display:flex;gap:1.1rem;
  animation:ticker-scroll 120s linear infinite;
  width:max-content;
  will-change:transform;
}
.personal-ticker-wrap:hover .personal-ticker,
.personal-ticker-wrap:focus-within .personal-ticker{animation-play-state:paused}
.personal-ticker-wrap.ticker--user-paused .personal-ticker{animation-play-state:paused!important}
.personal-ticker-wrap.ticker--user-running .personal-ticker,
.personal-ticker-wrap.ticker--user-running:hover .personal-ticker,
.personal-ticker-wrap.ticker--user-running:focus-within .personal-ticker{animation-play-state:running!important}
.personal-ticker-wrap:focus-within{
  outline:2px solid var(--leaf2);outline-offset:4px;border-radius:var(--radius-sm);
}
.personal-photo-card{
  width:clamp(17.5rem,30vw,21.5rem);flex-shrink:0;
  background:var(--surf);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:0;
  overflow:hidden;
  cursor:pointer;
  display:flex;flex-direction:column;
  transition:border-color var(--transition-ui),box-shadow var(--transition-ui),transform var(--transition-ui);
}
.personal-photo-card:hover{
  border-color:rgba(123,191,97,.45);
  box-shadow:0 14px 36px rgba(0,0,0,.48),0 0 24px rgba(94,158,74,.12);
  transform:translateY(-3px);
}
.personal-photo-card::before{display:none}
.personal-photo-visual{
  position:relative;margin:.65rem .65rem 0;
  aspect-ratio:4/3;border-radius:calc(var(--radius-lg) - 8px);
  overflow:hidden;border:1px solid rgba(255,255,255,.08);
  background:var(--surf2);
}
.personal-photo-visual::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(7,8,8,0) 35%,rgba(7,8,8,.82) 100%);
  opacity:.88;transition:opacity var(--transition-ui);
}
.personal-photo-card:hover .personal-photo-visual::after{opacity:.95}
.personal-photo-img{
  width:100%;height:100%;object-fit:cover;object-position:center 28%;
  display:block;transition:transform .5s var(--ease-out);
}
.personal-photo-card:hover .personal-photo-img{transform:scale(1.06)}
.personal-photo-badges{
  position:absolute;bottom:.6rem;left:.6rem;right:.6rem;z-index:2;
  display:flex;flex-wrap:wrap;gap:.32rem;
}
.personal-badge{
  display:inline-flex;align-items:center;
  padding:.24rem .58rem;border-radius:999px;
  font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(7,8,8,.78);border:1px solid rgba(255,255,255,.16);
  color:#eef2ef;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  white-space:nowrap;
  transition:border-color var(--transition-ui),background var(--transition-ui);
}
.personal-badge--leaf{border-color:rgba(123,191,97,.5);color:#b8e8a4}
.personal-badge--gold{border-color:rgba(210,172,90,.5);color:#e8d4a0}
.personal-photo-placeholder{
  aspect-ratio:4/3;border-radius:calc(var(--radius-lg) - 10px);
  border:1px solid var(--border);background:linear-gradient(135deg,var(--surf2),var(--surf3));
  display:flex;align-items:center;justify-content:center;font-size:2.6rem;
}
.personal-photo-meta{padding:1rem 1.15rem 1.2rem;text-align:left}
.personal-photo-name{
  font-family:var(--ff-display);font-size:1.08rem;color:#fff;
  margin-bottom:.42rem;text-align:left;line-height:1.28;
}
.personal-photo-tag{
  font-size:.84rem;color:var(--txt-m);line-height:1.58;text-align:left;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
@media(max-width:900px){
  /* Mobile : défilement auto un peu plus lent */
  .personal-ticker{
    animation-duration:180s;
    gap:.8rem;
  }
  .reviews-ticker{
    animation-duration:55s;
  }
  .personal-photo-placeholder{
    font-size:clamp(2rem,8.5vw,2.45rem);
  }
  .personal-photo-meta{
    padding:.85rem .95rem 1rem;
  }
  .personal-photo-name{
    font-size:clamp(.98rem,4.2vw,1.08rem);
    line-height:1.28;
  }
  .personal-photo-tag{
    font-size:clamp(.76rem,3.1vw,.84rem);
    line-height:1.45;
  }
}

/* ================================================================
   CONTACT
   ================================================================ */
.section--contact{
  border-top:1px solid var(--border);
  padding-block:4.5rem 5.5rem;
}
.contact-grid{
  display:grid;gap:.9rem;max-width:44rem;margin-inline:auto;
}
@media(min-width:640px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-card{
  display:flex;flex-direction:column;gap:.5rem;align-items:center;text-align:center;
  padding:1.55rem 1.8rem;border-radius:var(--radius-lg);
  background:#1c1f23;border:1px solid rgba(255,255,255,.09);color:#f4f6f8;
  position:relative;overflow:hidden;
  box-shadow:0 6px 22px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.04);
  transition:background .22s,border-color .22s,transform .22s var(--ease-spring),box-shadow .22s;
}
.contact-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(192,57,43,.08) 0%,transparent 55%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.contact-card:hover,.contact-card:focus-visible{
  background:#23272c;border-color:rgba(255,255,255,.18);
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 18px 52px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.06);
}
.contact-card:hover::before{opacity:1}
.contact-card--wide{grid-column:1/-1}
.contact-card--rover{
  border-color:rgba(255,90,57,.4);
  background:linear-gradient(180deg,rgba(40,22,18,.95),rgba(32,18,16,.95));
}
.contact-card--rover:hover{
  background:linear-gradient(180deg,rgba(48,26,22,.98),rgba(38,22,18,.98));
  border-color:rgba(255,90,57,.65);
  box-shadow:0 18px 52px rgba(0,0,0,.55),0 0 24px rgba(255,90,57,.22),inset 0 1px 0 rgba(255,255,255,.06);
}
.contact-label{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:#cfd4da;font-weight:600;
}
.contact-emoji{font-size:1.05rem;line-height:1;text-transform:none;letter-spacing:0}
.contact-value{font-family:var(--ff-display);font-weight:600;font-size:1.1rem;color:#fff;word-break:break-word}

/* Paiement */
.payment-section{
  max-width:44rem;margin:1.75rem auto 0;text-align:center;
  padding:1.1rem 1.2rem 1.2rem;border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.1);
  background:#1c1f23;
  box-shadow:0 6px 22px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.04);
}
.payment-title{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;
  color:#fff;margin-bottom:1rem;font-weight:700;
}
.payment-methods{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;align-items:center}
.payment-pill{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.5rem 1rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:#23272c;
  font-size:.82rem;font-weight:500;color:#f0f3f5;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 4px 14px rgba(0,0,0,.3);
  transition:transform .2s var(--ease-spring),border-color .2s,background .2s;
}
.payment-pill:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.28);
  background:#2a2e34;
}
.payment-pill svg{width:18px;height:18px;flex-shrink:0}

/* Formulaire devis */
.devis-section{max-width:44rem;margin:2.5rem auto 0}
.devis-title{
  font-family:var(--ff-display);font-size:1.35rem;font-weight:600;color:#fff;
  margin-bottom:1.25rem;text-align:center;
}
.devis-sub{color:var(--txt-m);font-size:.875rem;text-align:center;margin-bottom:1.5rem;font-weight:300}
.devis-form{
  background:#1c1f23;border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);padding:1.85rem 2rem;display:flex;flex-direction:column;gap:1rem;
  box-shadow:0 6px 22px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.04);
}
.form-row{display:grid;gap:1rem}
@media(min-width:540px){.form-row--2{grid-template-columns:1fr 1fr}}
.form-field{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#cfd4da}
.form-input,.form-textarea{
  width:100%;padding:.78rem 1rem;border-radius:var(--radius-sm);
  border:1px solid rgba(255,255,255,.14);background:#15181c;
  color:#fff;font-family:var(--ff-body);font-size:.92rem;
  outline:none;transition:border-color .2s,box-shadow .2s,background .2s;
}
.form-input:hover,.form-textarea:hover{border-color:rgba(255,255,255,.22);background:#181b1f}
.form-input:focus,.form-textarea:focus{
  border-color:rgba(192,57,43,.6);background:#181b1f;
  box-shadow:0 0 0 3px rgba(192,57,43,.18);
}
/* États de validation email */
.form-field--email{position:relative}
.email-status{
  position:absolute;right:.85rem;top:50%;transform:translateY(-50%);
  font-size:.88rem;line-height:1;pointer-events:none;transition:opacity .2s;
}
.form-input--valid{border-color:rgba(94,180,74,.7)!important;box-shadow:0 0 0 3px rgba(94,180,74,.15)!important}
.form-input--invalid{border-color:rgba(192,57,43,.75)!important;box-shadow:0 0 0 3px rgba(192,57,43,.2)!important}
.email-hint{
  font-size:.72rem;margin-top:.22rem;min-height:.9rem;
  transition:color .2s;
}
.email-hint--ok{color:#6bbf52}
.email-hint--err{color:#e05a4a}
.email-hint--loading{color:#9ca3af}
.form-textarea{resize:vertical;min-height:120px;line-height:1.6}
.form-input::placeholder,.form-textarea::placeholder{color:#8b929a}
.form-submit{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.78rem 1.65rem;border-radius:999px;border:0;cursor:pointer;
  background:var(--acc);color:#fff;font-family:var(--ff-body);font-weight:600;font-size:.875rem;
  box-shadow:0 4px 20px rgba(192,57,43,.36),inset 0 1px 0 rgba(255,255,255,.15);
  transition:background .22s,transform .2s var(--ease-spring),box-shadow .22s;align-self:flex-start;
}
.form-submit:hover{background:#a93020;transform:translateY(-2px) scale(1.02);box-shadow:0 10px 30px rgba(192,57,43,.5)}
.form-status{font-size:.83rem;padding:.55rem .9rem;border-radius:var(--radius-sm);display:none}
.form-status--ok{display:block;background:rgba(94,158,74,.15);border:1px solid var(--leaf-border);color:var(--leaf2)}
.form-status--err{display:block;background:var(--acc-dim);border:1px solid var(--border-acc);color:var(--acc2)}

/* ================================================================
   CARTE GOOGLE MAP
   ================================================================ */
.map-section{max-width:58rem;margin-inline:auto;margin-top:3.25rem}
.map-title{font-family:var(--ff-display);font-size:1.2rem;font-weight:600;color:#fff;text-align:center;margin-bottom:1.25rem}
.map-wrap{
  border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--leaf-border);
  box-shadow:0 12px 40px rgba(0,0,0,.5),0 0 0 1px rgba(94,158,74,.08);
  position:relative;height:340px;
}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(30%) brightness(.85) contrast(1.1) saturate(.9)}
.map-overlay-tag{
  position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);
  background:rgba(7,8,8,.9);backdrop-filter:blur(10px);
  border:1px solid var(--leaf-border);border-radius:999px;
  padding:.45rem 1.1rem;font-size:.78rem;font-weight:600;color:var(--leaf2);
  display:flex;align-items:center;gap:.45rem;white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,.45);
}

/* ================================================================
   FOOTER
   ================================================================ */
.footer{
  position:relative;z-index:2;padding:3rem 0 5rem;
  border-top:none;background:transparent;
}
/* ——— Balade canine — séparateur premium ——— */
.footer-ecg{
  display:block;width:100%;height:90px;
  position:relative;z-index:2;overflow:visible;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 5%,#000 95%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 5%,#000 95%,transparent 100%);
}
.footer-ecg::before{display:none}
#pawWalkerCanvas{display:block;width:100%;height:100%}
@media(prefers-reduced-motion:reduce){.footer-ecg{opacity:0;pointer-events:none}}
@media(min-width:901px){.footer{padding-bottom:3rem}}
.footer-inner{
  display:flex;flex-direction:column;align-items:center;gap:2.25rem;
  max-width:48rem;margin-inline:auto;text-align:center;
}
.footer-brand-name{font-family:var(--ff-display);font-size:1.15rem;font-weight:600;color:var(--txt);letter-spacing:.02em}
.footer-tagline{font-size:.78rem;color:#eef2ef;letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem}
.footer-meta p{font-size:.83rem;color:#eef2ef;line-height:1.6;margin-bottom:.35rem}
.footer-mentions{
  width:100%;
  max-width:42rem;
  padding:1.15rem 1.1rem;
  border:1px solid rgba(192,57,43,.42);
  border-radius:16px;
  background:#1c1f23;
  box-shadow:0 14px 36px rgba(0,0,0,.35),0 0 0 1px rgba(192,57,43,.18),inset 0 1px 0 rgba(255,255,255,.04);
}
.mentions-title{
  font-size:.67rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:#f2f6f2;margin-bottom:.9rem;display:inline-flex;align-items:center;gap:.5rem;
}
.mentions-title a{
  color:#f2f6f2;text-decoration:none;border-bottom:1px solid rgba(242,246,242,.45);
  padding-bottom:.15rem;transition:color .2s,border-color .2s;
}
.mentions-title a:hover{color:#fff;border-color:rgba(255,255,255,.95)}
.mentions-body p{font-size:.8rem;color:#eef2ef;line-height:1.65;margin-bottom:.45rem;font-weight:300;text-wrap:balance}
.siret-banner{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  margin-top:.5rem;
  padding:.45rem .9rem;
  border-radius:999px;
  border:1px solid rgba(123,191,97,.55);
  background:rgba(94,158,74,.14);
  color:#d6f0c4;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.05em;
  position:relative;
  overflow:hidden;
  text-decoration:none;
  cursor:pointer;
  box-shadow:0 0 10px rgba(94,158,74,.22),inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .26s var(--ease-spring),box-shadow .26s,border-color .26s,background .26s;
}
.siret-banner::after{
  content:'';
  position:absolute;
  top:-130%;
  left:-55%;
  width:34%;
  height:360%;
  transform:rotate(24deg);
  background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.52),rgba(255,255,255,0));
  opacity:0;
  pointer-events:none;
}
.siret-banner:hover{
  transform:translateY(-2px) scale(1.03);
  border-color:rgba(160,220,130,.9);
  background:rgba(94,158,74,.24);
  box-shadow:0 8px 24px rgba(94,158,74,.32),0 0 22px rgba(123,191,97,.28);
  animation:siret-pulse 1.6s ease-in-out infinite;
}
.siret-banner:hover::after{
  opacity:1;
  animation:siret-glint 1.2s ease-in-out infinite;
}
@keyframes siret-pulse{
  0%,100%{transform:translateY(-2px) scale(1.03);box-shadow:0 8px 24px rgba(94,158,74,.32),0 0 22px rgba(123,191,97,.28)}
  50%{transform:translateY(-2px) scale(1.065);box-shadow:0 10px 32px rgba(94,158,74,.48),0 0 34px rgba(123,191,97,.44)}
}
@keyframes siret-glint{
  0%{left:-55%;opacity:0}
  18%{opacity:.75}
  100%{left:125%;opacity:0}
}
@media (prefers-reduced-motion:reduce){
  .siret-banner:hover,
  .siret-banner:hover::after{animation:none}
}

/* ================================================================
   CTA FLOTTANT MOBILE
   ================================================================ */
.cta-fixed{
  position:fixed;bottom:1.75rem;right:1.75rem;z-index:800;
  display:flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;
  background:var(--acc);color:#fff;
  box-shadow:0 6px 26px rgba(192,57,43,.58),0 0 0 1px rgba(192,57,43,.38),inset 0 1px 0 rgba(255,255,255,.2);
  transition:transform .22s var(--ease-spring),box-shadow .22s;
}
.cta-fixed:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 12px 38px rgba(192,57,43,.68)}
.cta-fixed span{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
@media(min-width:901px){.cta-fixed{display:none}}

/* ================================================================
   FEUILLAGE — Décorations SVG nature
   ================================================================ */
.leaves-fixed{display:none}

/* ================================================================
   MODAL lightbox (galerie)
   ================================================================ */
.modal{
  position:fixed;inset:0;z-index:950;background:rgba(0,0,0,.85);
  backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .28s,visibility .28s;padding:1.5rem;
}
.modal.open{opacity:1;visibility:visible}
.modal-inner{
  max-width:min(600px,100%);width:100%;
  background:var(--surf2);border:1px solid var(--border);border-radius:var(--radius-xl);
  overflow:hidden;position:relative;
  box-shadow:0 32px 80px rgba(0,0,0,.7);
  max-height:calc(100dvh - 3rem);
  display:flex;
  flex-direction:column;
}
.modal-img{width:100%;max-height:60vh;object-fit:cover;display:block}
.modal-body{padding:1.5rem 1.75rem;overflow-y:auto;min-height:0}
.modal-name{font-family:var(--ff-display);font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.modal-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}
.modal-result{color:var(--txt-m);font-size:.9375rem;font-weight:300}
.modal.modal--story .modal-inner{max-width:min(38rem,100%)}
.modal.modal--story #modalImgPlaceholder{
  border-bottom:1px solid rgba(210,172,90,.12);
}
.modal-result--rich{
  color:rgba(238,234,224,.92);
  font-size:.94rem;line-height:1.72;font-weight:400;
  max-height:none;
  overflow-y:visible;
  padding-right:.25rem;
}
.modal-result--rich .story-modal-heading{
  font-family:var(--ff-display);
  font-size:clamp(1.12rem,3.2vw,1.32rem);
  font-weight:600;color:var(--txt);
  line-height:1.38;margin:0 0 1rem;
  letter-spacing:.01em;
}
.modal-result--rich .story-modal-body p{margin:0 0 1rem}
.modal-result--rich .story-modal-body p:last-child{margin-bottom:0}
.modal-close{
  position:absolute;top:1rem;right:1rem;width:var(--touch-min);height:var(--touch-min);border-radius:50%;
  background:rgba(0,0,0,.5);backdrop-filter:blur(8px);border:1px solid var(--border);
  color:var(--txt);display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1.1rem;z-index:2;
  transition:background .2s,transform .2s;
}
.modal-close:hover{background:rgba(192,57,43,.3);transform:scale(1.1)}

/* ================================================================
   HARDENING RESPONSIVE — cartes lisibles partout
   ================================================================ */
/* Empêche les débordements de texte dans toutes les cartes/modales */
.dog-card,
.review-card,
.personal-photo-card,
.contact-card,
.hero-card,
.content-card,
.timeline-card,
.modal-inner{
  min-width:0;
}
.dog-card-name,
.dog-card-meta,
.dog-card-badge,
.review-text,
.review-author,
.personal-photo-tag,
.contact-card p,
.card-body,
.card-list li,
.modal-name,
.modal-result{
  overflow-wrap:anywhere;
  word-break:break-word;
  hyphens:auto;
}
/* Scroll vertical local quand un contenu devient long */
.dog-card-story__text,
.modal-result--rich,
.review-text{
  overscroll-behavior:contain;
}

@media(max-width:900px){
  .gallery-grid{
    grid-template-columns:1fr;
    gap:1rem;
    max-width:min(42rem,100%);
  }
  .gallery-grid .dog-card--story{
    max-width:100%;
  }
  .dog-card{
    border-radius:clamp(14px,3.8vw,18px);
  }
  .dog-card-overlay{
    padding:.9rem .9rem;
  }
  .dog-card-name{
    font-size:clamp(1rem,4.5vw,1.16rem);
  }
  .dog-card-meta{
    font-size:clamp(.76rem,2.95vw,.86rem);
    gap:.35rem;
  }
  .dog-card-badge{
    font-size:clamp(.64rem,2.5vw,.72rem);
    padding:.16rem .5rem;
  }
  .review-card,
  .personal-photo-card{
    width:min(92vw,360px);
  }
  .personal-ticker-wrap{
    padding-inline:clamp(.5rem,2.8vw,.95rem);
  }
  .review-text{
    font-size:clamp(.93rem,3.2vw,1rem);
    line-height:1.68;
  }
  .contact-card{
    padding:clamp(1.1rem,4.2vw,1.45rem) clamp(1rem,4vw,1.25rem);
  }
  .modal{
    padding:clamp(.75rem,3.4vw,1.15rem);
  }
  .modal-inner{
    max-height:calc(100dvh - 1.4rem);
  }
  .modal-img{
    max-height:min(42dvh,320px);
  }
  .modal-body{
    padding:clamp(1rem,4vw,1.3rem);
    overflow-y:auto;
  }
}

/* ================================================================
   RESPONSIVE GLOBAL
   ================================================================ */
@media(min-width:768px){
  .container{width:min(var(--container),100% - 2rem)}
  .hero-actions{gap:1rem}
}
@media(min-width:1200px){
  .container{width:min(var(--container),100% - 2.5rem)}
  .section:not(.hero){padding-block:5rem}
}
@media(max-width:479px){
  .section:not(.hero){padding-block:3.5rem}
  .contact-grid{grid-template-columns:1fr}
  .contact-card--wide{grid-column:1}
  .stats-strip{flex-direction:column}
  .stat+.stat::before{top:0;left:20%;right:20%;bottom:auto;width:auto;height:1px}
  .container{width:min(var(--container),100% - 1.15rem)}
  .gallery-tabs{
    gap:.4rem;
    margin-bottom:1.35rem;
  }
  .gallery-tab{
    font-size:.72rem;
    padding:.34rem .72rem;
  }
  .personal-ticker{
    gap:.62rem;
  }
  .personal-photo-card{
    width:min(88vw,310px);
    padding:.82rem;
    border-radius:clamp(12px,4vw,16px);
  }
  .personal-photo-placeholder{
    aspect-ratio:16/11;
    border-radius:calc(var(--radius-lg) - 12px);
  }
  .personal-photo-meta{
    padding:.62rem .15rem .2rem;
  }
  .personal-photo-name{
    font-size:clamp(.94rem,4.8vw,1.02rem);
  }
  .personal-photo-tag{
    font-size:clamp(.72rem,3.5vw,.8rem);
  }
  .dog-card-story__heading{
    font-size:clamp(1rem,5.2vw,1.22rem);
    line-height:1.34;
  }
  .dog-card-story__cta-hint{
    font-size:.76rem;
  }
  .modal-result--rich{
    font-size:.92rem;
    line-height:1.7;
    max-height:min(54dvh,24rem);
  }
}
@media(max-width:360px){
  .container{width:min(var(--container),100% - .9rem)}
  .gallery-tab{
    font-size:.68rem;
    padding:.32rem .6rem;
  }
  .personal-photo-card{
    width:min(92vw,292px);
    padding:.72rem;
  }
  .personal-photo-placeholder{
    aspect-ratio:3/2;
  }
}
@media(max-height:540px) and (orientation:landscape){
  .personal-ticker{
    animation-duration:72s;
  }
  .personal-photo-card{
    width:clamp(230px,30vw,300px);
  }
  .personal-photo-placeholder{
    aspect-ratio:16/9;
  }
}
@media(prefers-reduced-motion:reduce){
  .personal-ticker,.reviews-ticker{
    animation:none;
  }
  .reviews-ticker-wrap,.personal-ticker-wrap{
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .review-card,.personal-photo-card{
    scroll-snap-align:start;
  }
}
