/* =========================================================================
   Les Ateliers DIY — Lydie Larexiste
   Palette chaleureuse & créative, mobile-first.
   ========================================================================= */
:root{
  --cream:#fff7f3; --cream-2:#fdeee6; --ink:#2a211f; --ink-soft:#6b5d58;
  --coral:#e8643c; --coral-d:#c94e2c; --plum:#7a3b54; --gold:#e9a23b;
  --sage:#8aa18a; --line:#efddd2; --white:#ffffff;
  --r:18px; --r-lg:28px; --shadow:0 18px 50px -22px rgba(120,60,40,.4);
  --shadow-sm:0 8px 24px -14px rgba(120,60,40,.35);
  --maxw:1140px; --ease:cubic-bezier(.22,1,.36,1);
  --serif:"Fraunces",Georgia,serif; --sans:"Manrope",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.65;
  font-size:clamp(16px,1.1vw,17px);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 10px 0}
.skip:focus{left:0}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}

/* ---- Typo ---- */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:-.01em}
.h2{font-size:clamp(1.9rem,4.4vw,3rem);color:var(--ink)}
.lead{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--ink-soft)}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.8rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--coral-d);margin-bottom:14px}
.eyebrow--center{justify-content:center}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(232,100,60,.18)}

/* ---- Boutons ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;background:var(--coral);color:#fff;
  font-weight:700;font-family:var(--sans);padding:13px 24px;border-radius:100px;border:0;cursor:pointer;
  font-size:1rem;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  box-shadow:0 12px 28px -12px rgba(232,100,60,.7)}
.btn:hover{background:var(--coral-d);transform:translateY(-2px);box-shadow:0 18px 34px -12px rgba(232,100,60,.75)}
.btn:active{transform:translateY(0)}
.btn--lg{padding:16px 30px;font-size:1.06rem}
.btn--sm{padding:10px 18px;font-size:.92rem}
.btn--block{width:100%;justify-content:center}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--line)}
.btn--ghost:hover{background:var(--white);color:var(--coral-d);box-shadow:inset 0 0 0 2px var(--coral);transform:translateY(-2px)}
.link-arrow{display:inline-flex;align-items:center;gap:.4em;font-weight:700;color:var(--coral-d);margin-top:6px}
.link-arrow span{transition:transform .25s var(--ease)}
.link-arrow:hover span{transform:translateX(5px)}

/* ---- Placeholders photo ---- */
.ph,.ph-pic{display:block;width:100%;height:100%;border-radius:inherit;object-fit:cover}
.ph-pic img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
.ph{display:grid;place-items:center;color:rgba(255,255,255,.7)}
.ph svg{width:34%;max-width:64px;height:auto;opacity:.55}
.ph--0{background:linear-gradient(135deg,#f3a87f,#e8643c)}
.ph--1{background:linear-gradient(135deg,#b98aa0,#7a3b54)}
.ph--2{background:linear-gradient(135deg,#f0c27b,#e9a23b)}
.ph--3{background:linear-gradient(135deg,#a8bda0,#7e9c7e)}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:100;transition:background .3s,box-shadow .3s,padding .3s}
.nav__in{display:flex;align-items:center;gap:18px;padding:16px 0}
.nav.scrolled{background:rgba(255,247,243,.88);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.brand{display:flex;align-items:center;gap:10px;margin-right:auto}
.brand__mark{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;
  background:var(--coral);color:#fff;font-size:1.1rem;box-shadow:var(--shadow-sm)}
.brand__txt{font-family:var(--serif);font-weight:600;font-size:1.18rem;line-height:1;display:flex;flex-direction:column}
.brand__txt small{font-family:var(--sans);font-weight:600;font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.nav__links{display:flex;gap:22px}
.nav__links a{font-weight:600;font-size:.95rem;color:var(--ink-soft);position:relative;padding:4px 0}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--coral);transition:width .25s var(--ease)}
.nav__links a:hover{color:var(--ink)}.nav__links a:hover::after{width:100%}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---- Reveal ---- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal="right"]{transform:translateY(20px) translateX(26px)}
[data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important}}

/* ---- Hero ---- */
.hero{position:relative;padding:36px 0 70px;overflow:hidden}
.hero__in{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero__blob{position:absolute;border-radius:50%;filter:blur(50px);opacity:.5;z-index:-1;animation:float 12s ease-in-out infinite}
.hero__blob--1{width:420px;height:420px;background:#f7c9b1;top:-120px;right:-80px}
.hero__blob--2{width:360px;height:360px;background:#e7c6d4;bottom:-140px;left:-120px;animation-delay:-4s}
.hero__title{font-size:clamp(2.3rem,5.4vw,3.7rem);margin:6px 0 18px}
.hero__title::after{content:"✦";color:var(--gold);font-size:.5em;vertical-align:.4em;margin-left:.15em}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--ink-soft);max-width:34ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin:26px 0 22px}
.hero__trust{list-style:none;display:flex;flex-wrap:wrap;gap:10px 22px;padding-top:18px;border-top:1px dashed var(--line)}
.hero__trust li{display:flex;flex-direction:column;font-size:.86rem;color:var(--ink-soft);line-height:1.25}
.hero__trust strong{font-family:var(--serif);font-size:1.12rem;color:var(--ink)}
.hero__media{position:relative}
.hero__frame{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow);border:6px solid #fff;rotate:2deg;transition:rotate .4s var(--ease)}
.hero__frame:hover{rotate:0deg}
.hero__badge{position:absolute;left:-18px;bottom:30px;background:#fff;border-radius:18px;padding:12px 18px;
  box-shadow:var(--shadow);text-align:center;rotate:-5deg;animation:float 7s ease-in-out infinite}
.hero__badge-price{display:block;font-family:var(--serif);font-size:1.9rem;color:var(--coral-d);line-height:1}
.hero__badge-price small{font-size:.6em}
.hero__badge-per{font-size:.74rem;font-weight:600;color:var(--ink-soft)}
.hero__chip{position:absolute;background:#fff;color:var(--plum);font-weight:700;font-size:.82rem;
  padding:7px 14px;border-radius:100px;box-shadow:var(--shadow-sm);animation:float 8s ease-in-out infinite}
.hero__chip--1{top:14px;right:-10px;animation-delay:-1s}
.hero__chip--2{top:42%;left:-28px;color:var(--coral-d);animation-delay:-3s}
.hero__chip--3{bottom:-12px;right:18px;color:var(--sage);animation-delay:-5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---- USP ---- */
.usp{padding:20px 0 10px}
.usp__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.usp__card{background:#fff;border-radius:var(--r);padding:22px 20px;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);transition:transform .3s var(--ease)}
.usp__card:hover{transform:translateY(-5px)}
.usp__ico{font-size:1.7rem}
.usp__card h3{font-size:1.06rem;margin:8px 0 5px}
.usp__card p{font-size:.92rem;color:var(--ink-soft)}

/* ---- Sections génériques ---- */
section{position:relative}
.concept,.steps,.creator,.gallery,.place{padding:74px 0}
.occ,.ateliers,.reviews,.price,.faq{padding:74px 0}
.sec-head{text-align:center;max-width:640px;margin:0 auto 44px}
.sec-head--left{text-align:left;margin-left:0}
.sec-head__sub{color:var(--ink-soft);font-size:1.08rem;margin-top:10px}
.ticks{list-style:none;margin:22px 0;display:grid;gap:11px}
.ticks li{position:relative;padding-left:32px;color:var(--ink-soft)}
.ticks li::before{content:"✓";position:absolute;left:0;top:-1px;width:22px;height:22px;border-radius:50%;
  background:var(--cream-2);color:var(--coral-d);font-weight:800;font-size:.8rem;display:grid;place-items:center}

/* ---- Concept ---- */
.concept{background:linear-gradient(180deg,var(--cream),#fff)}
.concept__in,.creator__in,.price__in,.place__in,.cta__in{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.concept__media{position:relative;aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff}
.concept__sticker{position:absolute;right:-12px;top:-12px;background:var(--gold);color:#fff;font-family:var(--serif);
  font-size:.95rem;width:92px;height:92px;border-radius:50%;display:grid;place-items:center;text-align:center;
  rotate:-12deg;box-shadow:var(--shadow-sm);line-height:1.1}

/* ---- Occasions ---- */
.occ{background:var(--cream-2)}
.occ__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.occ__card{background:#fff;border-radius:var(--r-lg);padding:34px 28px;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);transition:transform .3s var(--ease),box-shadow .3s}
.occ__card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.occ__ico{font-size:2.2rem;display:block}
.occ__card h3{font-size:1.4rem;margin:14px 0 8px;color:var(--plum)}
.occ__card p{color:var(--ink-soft)}

/* ---- Steps ---- */
.steps__list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;counter-reset:s}
.steps__item{position:relative;padding-top:14px}
.steps__num{display:grid;place-items:center;width:54px;height:54px;border-radius:50%;background:var(--coral);
  color:#fff;font-family:var(--serif);font-size:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:16px}
.steps__item h3{font-size:1.25rem;margin-bottom:6px}
.steps__item p{color:var(--ink-soft)}
.steps__item:not(:last-child)::after{content:"";position:absolute;top:27px;left:64px;right:-13px;height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 8px,transparent 8px 16px)}

/* ---- Ateliers ---- */
.ateliers__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.atelier{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);transition:transform .3s var(--ease),box-shadow .3s}
.atelier:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.atelier__media{aspect-ratio:1/1;overflow:hidden}
.atelier__media .ph,.atelier__media .ph-pic{transition:transform .5s var(--ease)}
.atelier:hover .atelier__media .ph,.atelier:hover .atelier__media .ph-pic{transform:scale(1.06)}
.atelier__body{padding:20px}
.atelier__body h3{font-size:1.2rem;margin-bottom:6px}
.atelier__body p{font-size:.92rem;color:var(--ink-soft)}

/* ---- Créatrice ---- */
.creator{background:linear-gradient(180deg,#fff,var(--cream-2))}
.creator__media{position:relative;max-width:420px;aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow);border:6px solid #fff}
.creator__years{position:absolute;right:-14px;bottom:18px;background:var(--plum);color:#fff;border-radius:16px;
  padding:10px 16px;text-align:center;box-shadow:var(--shadow);line-height:1.1;font-size:.78rem;rotate:4deg}
.creator__years strong{display:block;font-family:var(--serif);font-size:1.7rem}
.creator__role{font-weight:700;color:var(--coral-d);margin:4px 0 14px}
.creator__quote{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--plum);
  border-left:3px solid var(--coral);padding-left:18px;margin-top:22px}

/* ---- Tarif ---- */
.price{background:var(--cream-2)}
.price__card{background:#fff;border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow);
  border:1px solid var(--line);position:relative;overflow:hidden}
.price__card::before{content:"";position:absolute;inset:0 0 auto 0;height:7px;background:linear-gradient(90deg,var(--coral),var(--gold))}
.price__tag{display:flex;align-items:baseline;gap:6px;margin-bottom:22px;flex-wrap:wrap}
.price__num{font-family:var(--serif);font-size:4rem;line-height:1;color:var(--coral-d)}
.price__cur{font-family:var(--serif);font-size:1.8rem;color:var(--coral-d)}
.price__per{font-weight:600;color:var(--ink-soft);margin-left:4px}
.price__list{list-style:none;display:grid;gap:13px}
.price__list li{position:relative;padding-left:34px;font-weight:500}
.price__list li::before{content:"✓";position:absolute;left:0;top:0;width:24px;height:24px;border-radius:50%;
  background:var(--coral);color:#fff;font-weight:800;font-size:.82rem;display:grid;place-items:center}
.price__fine{margin-top:22px;padding-top:18px;border-top:1px dashed var(--line);color:var(--ink-soft);font-size:.92rem}

/* ---- Galerie ---- */
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery__item{border:0;padding:0;background:none;cursor:pointer;aspect-ratio:1/1;border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-sm)}
.gallery__item .ph,.gallery__item .ph-pic{transition:transform .5s var(--ease)}
.gallery__item:hover .ph,.gallery__item:hover .ph-pic{transform:scale(1.07)}

/* ---- Avis ---- */
.reviews{background:linear-gradient(180deg,var(--cream-2),#fff)}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{background:#fff;border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.review__stars{color:var(--gold);letter-spacing:2px;margin-bottom:10px}
.review blockquote{font-size:1.04rem;color:var(--ink)}
.review figcaption{margin-top:16px;display:flex;flex-direction:column}
.review figcaption strong{color:var(--plum)}
.review figcaption span{font-size:.85rem;color:var(--ink-soft)}

/* ---- FAQ ---- */
.faq__in{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:start}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:16px;margin-bottom:12px;overflow:hidden}
.faq__item summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:700;font-size:1.05rem;
  display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__plus{position:relative;width:18px;height:18px;flex:none}
.faq__plus::before,.faq__plus::after{content:"";position:absolute;background:var(--coral);border-radius:2px;transition:.3s}
.faq__plus::before{top:8px;left:0;width:18px;height:2px}
.faq__plus::after{left:8px;top:0;width:2px;height:18px}
.faq__item[open] .faq__plus::after{transform:rotate(90deg);opacity:0}
.faq__a{padding:0 22px 20px;color:var(--ink-soft)}

/* ---- Lieu ---- */
.place__map{aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff}
.place__map iframe{width:100%;height:100%;border:0;display:block}
.place__addr{font-weight:700;margin:18px 0 20px;font-size:1.05rem}

/* ---- CTA / Contact ---- */
.cta{padding:74px 0;background:linear-gradient(135deg,var(--plum),#532538);color:#fff}
.cta .h2,.cta__title{color:#fff}
.cta__title{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:12px}
.cta__text{color:rgba(255,255,255,.82);font-size:1.1rem;max-width:42ch}
.cta__contact{list-style:none;margin-top:26px;display:grid;gap:12px}
.cta__contact a{border-bottom:1px solid rgba(255,255,255,.4)}
.cta__contact a:hover{border-color:#fff}
.cta__form{background:#fff;color:var(--ink);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow)}
.cta__form h3{font-size:1.4rem;margin-bottom:18px}
.field{margin-bottom:14px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:12px;font:inherit;font-size:.98rem;background:var(--cream);transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--coral);
  box-shadow:0 0 0 3px rgba(232,100,60,.16);background:#fff}
.cta__formnote{margin-top:12px;font-size:.92rem;font-weight:600;min-height:1.2em}
.cta__formnote.ok{color:var(--sage)}.cta__formnote.err{color:var(--coral-d)}

/* ---- Footer ---- */
.foot{background:var(--ink);color:#e9dcd5;padding:42px 0}
.foot__in{display:flex;flex-wrap:wrap;gap:22px;align-items:center;justify-content:space-between}
.foot__brand{display:flex;align-items:center;gap:12px}
.foot__brand small{color:#b6a59d}
.foot__links{display:flex;flex-wrap:wrap;gap:18px}
.foot__links a{color:#cdbcb4;font-size:.92rem}
.foot__links a:hover{color:#fff}
.foot__copy{width:100%;text-align:center;font-size:.82rem;color:#9c8b83;border-top:1px solid #3a302c;padding-top:18px;margin-top:6px}
.foot__copy a{border-bottom:1px solid #5a4d47}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;background:rgba(30,18,14,.92);display:none;place-items:center;z-index:300;padding:24px}
.lightbox.open{display:grid}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__close{position:absolute;top:18px;right:24px;background:none;border:0;color:#fff;font-size:2.6rem;cursor:pointer;line-height:1}

/* ===================== Responsive ===================== */
@media (max-width:980px){
  .usp__grid{grid-template-columns:repeat(2,1fr)}
  .ateliers__grid{grid-template-columns:repeat(2,1fr)}
  .occ__grid,.steps__list,.reviews__grid,.gallery__grid{grid-template-columns:1fr 1fr}
  .faq__in{grid-template-columns:1fr;gap:28px}
  .steps__item::after{display:none}
}
@media (max-width:820px){
  .nav__links{position:fixed;inset:64px 0 auto 0;background:var(--cream);flex-direction:column;gap:0;
    padding:10px 22px 22px;box-shadow:0 20px 30px -20px rgba(0,0,0,.3);transform:translateY(-130%);
    transition:transform .35s var(--ease);border-top:1px solid var(--line)}
  .nav.open .nav__links{transform:none}
  .nav__links a{padding:14px 0;border-bottom:1px solid var(--line);width:100%}
  .burger{display:flex}
  .nav.open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.open .burger span:nth-child(2){opacity:0}
  .nav.open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav.scrolled,.nav.open{background:rgba(255,247,243,.95);backdrop-filter:blur(12px)}
  .hero__in,.concept__in,.creator__in,.price__in,.place__in,.cta__in{grid-template-columns:1fr;gap:38px}
  .hero{padding-top:20px}
  .hero__media{max-width:420px;margin:0 auto}
  .creator__media{margin:0 auto}
  [data-reveal="right"]{transform:translateY(28px)}
  /* Chips : on les garde à l'intérieur du cadre sur tablette/mobile */
  .hero__chip--1{right:6px}
  .hero__chip--2{left:6px}
  .hero__chip--3{right:14px}
  .hero__badge{left:6px}
}
@media (max-width:560px){
  .usp__grid,.occ__grid,.steps__list,.ateliers__grid,.reviews__grid,.gallery__grid{grid-template-columns:1fr}
  .field--row{grid-template-columns:1fr}
  .wrap{padding:0 18px}
  .concept,.steps,.creator,.gallery,.place,.occ,.ateliers,.reviews,.price,.faq,.cta{padding:54px 0}
  .gallery__grid{grid-template-columns:1fr 1fr}
  .nav__links{inset:60px 0 auto 0}
  /* Chips plus compactes et bien dans le cadre sur petit mobile */
  .hero__media{max-width:340px}
  .hero__chip{font-size:.72rem;padding:5px 11px}
  .hero__chip--1{top:8px;right:4px}
  .hero__chip--2{top:46%;left:4px}
  .hero__chip--3{bottom:-8px;right:8px}
  .hero__badge{left:2px;bottom:18px;padding:9px 13px}
  .hero__badge-price{font-size:1.5rem}
}
