/* ==========================================================================
   WOOFY : centre aéré pour chiens, Aubagne
   Charte relevée sur @woofy_officiel : rayures bonbon rose/orange, ton famille
   Prototype MarsAI (démonstration) · v5 passe design 4 lentilles
   ========================================================================== */

:root{
  --cream:      #FFF7EC;
  --cream-2:    #FBEBD7;
  --rose:       #EF5D9B;   /* surfaces / décor */
  --rose-deep:  #D6216E;   /* texte + CTA (4,9:1 avec blanc) */
  --rose-soft:  #F9A8C6;
  --rose-pale:  #FDE3EE;
  --orange:     #F5921E;   /* surfaces / décor */
  --orange-deep:#A85A05;   /* texte orange (4,8:1 sur crème) */
  --orange-soft:#FBBB6B;
  --orange-pale:#FCE9CF;
  --sun:        #FFD166;
  --ink:        #3B2417;
  --muted:      #7A5F4C;   /* 5,5:1 sur crème */
  --green:      #6FA95C;
  --white:      #FFFFFF;
  --stripe: repeating-linear-gradient(90deg,
      var(--orange-soft) 0 26px, var(--rose-soft) 26px 52px);
  --stripe-v: repeating-linear-gradient(180deg,
      var(--orange-soft) 0 26px, var(--rose-soft) 26px 52px);
  --stripe-dim: repeating-linear-gradient(90deg,
      rgba(245,146,30,.09) 0 26px, rgba(239,93,155,.09) 26px 52px);
  --radius: 22px;
  --shadow: 0 10px 30px -12px rgba(59,36,23,.18);
  --ease-out: cubic-bezier(.23, 1, .32, 1);
  --display: "Fredoka", "Nunito", system-ui, sans-serif;
  --body: "Nunito", system-ui, sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-padding-top:84px; }
@media (prefers-reduced-motion: no-preference){
  html{ scroll-behavior:smooth; }
}
body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
  font-size:16.5px;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
::selection{ background:var(--rose-soft); color:var(--ink); }

h1,h2,h3,h4{ font-family:var(--display); font-weight:600; line-height:1.15; }
.wrap{ max-width:1120px; margin:0 auto; padding:0 22px; }

/* ---- accessibilité / feel ---- */
:focus-visible{ outline:3px solid var(--rose-deep); outline-offset:3px; border-radius:6px; }
a, button, .choice, .dayc{ -webkit-tap-highlight-color:transparent; }
.choice, .dayc{ touch-action:manipulation; }
button, .btn{ cursor:pointer; }
button:active, .btn:active{ transform:translateY(0) scale(.97); transition-duration:.1s; }

/* ---- surligneur "scotch" façon captions Insta Woofy (dosé) ---- */
.tape{
  background:var(--rose-soft);
  padding:.05em .28em; border-radius:6px;
  box-decoration-break:clone; -webkit-box-decoration-break:clone;
  transform:rotate(-.5deg); display:inline-block;
}
.tape.or{ background:var(--orange-soft); transform:rotate(.4deg); }
.wavy{
  text-decoration:underline wavy var(--rose-soft);
  text-decoration-thickness:3px; text-underline-offset:9px;
}

/* ================= NAV ================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:90;
  background:rgba(255,247,236,.92);
  backdrop-filter:blur(10px);
  border-bottom:2px solid rgba(59,36,23,.06);
  transition:box-shadow .25s;
}
.nav.scrolled{ box-shadow:0 6px 24px -14px rgba(59,36,23,.28); }
.nav .in{
  max-width:1120px; margin:0 auto; padding:10px 22px;
  display:flex; align-items:center; gap:20px;
}
.brand{ display:flex; align-items:center; gap:11px; text-decoration:none; }
.brand .badge{ width:46px; height:46px; flex:none; }
.brand .t{
  font-family:var(--display); font-weight:600; font-size:1.35rem; letter-spacing:.02em;
}
.brand .t small{ display:block; font-family:var(--body); font-weight:700;
  font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.nav .links{ display:flex; gap:20px; margin-left:auto; align-items:center; }
.nav .links a{
  text-decoration:none; font-weight:800; font-size:.92rem; color:var(--ink);
  padding:6px 2px; border-bottom:3px solid transparent; transition:border-color .2s;
}
.nav .links.solo{ display:flex; }
.nav .cta{ margin-left:6px; }
.btn.cta-mobile{ display:none; }
.burger{
  display:none; background:none; border:none;
  width:44px; height:44px; align-items:center; justify-content:center; flex:none;
}
.burger svg{ width:28px; height:28px; stroke:var(--ink); }

.btn{
  display:inline-flex; align-items:center; gap:9px;
  background:var(--rose-deep); color:#fff; text-decoration:none;
  font-family:var(--display); font-weight:600; font-size:1rem;
  padding:12px 24px; border-radius:999px; border:none;
  box-shadow:0 8px 18px -8px rgba(214,33,110,.5);
  transition:transform .18s var(--ease-out), box-shadow .18s var(--ease-out), background .18s var(--ease-out);
}
.btn.or{ background:var(--orange); color:var(--ink); box-shadow:0 8px 18px -8px rgba(245,146,30,.55); }
.btn.ghost{
  background:transparent; color:var(--ink);
  border:2.5px solid var(--ink); box-shadow:none;
}
.btn.big{ font-size:1.12rem; padding:15px 30px; }
.btn.block{ width:100%; justify-content:center; }
.btn:disabled{ opacity:.5; cursor:not-allowed; transform:none; box-shadow:none; pointer-events:none; }

@media (hover:hover) and (pointer:fine){
  .nav .links a:hover{ border-bottom-color:var(--orange); }
  .btn:hover{ transform:translateY(-2px); box-shadow:0 12px 22px -8px rgba(214,33,110,.55); }
  .btn.or:hover{ box-shadow:0 12px 22px -8px rgba(245,146,30,.6); }
  .btn.ghost:hover{ background:var(--ink); color:var(--cream); }
  .card:hover{ transform:translateY(-4px); }
  .parc-item:hover img{ transform:scale(1.045); }
  .reel-card:hover{ transform:translateY(-4px); }
  .reel-card:hover .play{ transform:scale(1.08); }
  .choice:hover:not(.sel){ border-color:var(--rose-soft); }
  .dayc:not(.full):hover:not(.sel){ border-color:var(--orange-soft); }
}

/* ================= HERO ================= */
.hero{
  position:relative; padding:150px 0 90px; overflow:hidden;
  background:
    radial-gradient(58% 70% at 82% 12%, rgba(255,209,102,.35), transparent 60%),
    radial-gradient(45% 55% at 8% 90%, rgba(249,168,198,.28), transparent 60%),
    var(--cream);
}
.hero .in{ position:relative; display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; }
.kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:900; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--orange-deep); margin-bottom:18px;
}
.kicker::before{ content:""; width:26px; height:3px; background:var(--orange); border-radius:2px; }
.hero h1{ font-size:clamp(2.4rem, 5.2vw, 4rem); margin-bottom:20px; }
.hero h1 .accent{ color:var(--rose-deep); }
.hero .sub{ font-size:1.16rem; color:var(--muted); max-width:33em; margin-bottom:30px; font-weight:600; }
.hero .sub strong{ color:var(--ink); }
.hero .ctas{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-bottom:28px; }
.trust{
  display:inline-flex; align-items:center; gap:11px;
  background:var(--white); border-radius:999px; padding:9px 18px 9px 12px;
  box-shadow:var(--shadow); font-weight:800; font-size:.93rem;
}
.trust .stars{ color:var(--orange); letter-spacing:.1em; font-size:1rem; }
.trust small{ color:var(--muted); font-weight:700; }

/* carte visuelle du hero : vidéo encadrée par le mur rayé */
.hero-frame{
  background:var(--stripe); padding:10px; border-radius:40px;
  box-shadow:0 24px 50px -20px rgba(59,36,23,.35);
}
.hero-card{
  position:relative; border-radius:32px; overflow:hidden;
  background-size:cover; background-position:center 18%;
  min-height:500px;
}
.hero-card video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0;
}
.hero-card::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(59,36,23,0) 55%, rgba(59,36,23,.4));
}
.hero-card .photo-hint{
  position:absolute; top:16px; left:16px; z-index:2;
  background:rgba(255,247,236,.92); border-radius:999px; padding:7px 15px;
  font-size:.8rem; font-weight:800; color:var(--ink);
}
.vbtn{
  position:absolute; right:14px; bottom:14px; z-index:3;
  width:42px; height:42px; border-radius:50%; border:none;
  background:rgba(255,247,236,.92); color:var(--ink);
  font-size:.9rem; display:flex; align-items:center; justify-content:center;
}
@media (prefers-reduced-motion: reduce){
  .hero-card video, .vbtn{ display:none; }
}

/* ================= MARQUEE ================= */
.marquee{
  background:var(--ink); color:var(--cream);
  overflow:hidden; padding:13px 0; white-space:nowrap;
}
.marquee .track{
  display:inline-block; animation:slide 28s linear infinite;
  font-family:var(--display); font-weight:500; font-size:1.02rem; letter-spacing:.06em;
}
.marquee .track span{ margin:0 18px; }
.marquee .track .dot{ color:var(--orange-soft); }
.marquee:hover .track{ animation-play-state:paused; }
@keyframes slide{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@media (prefers-reduced-motion: reduce){
  .marquee .track{ animation:none; }
}

/* ================= SECTIONS ================= */
section{ padding:86px 0; }
.sec-head{ max-width:640px; margin-bottom:48px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head h2{ font-size:clamp(1.8rem, 3.6vw, 2.6rem); margin:10px 0 14px; }
.sec-head p{ color:var(--muted); font-weight:600; font-size:1.05rem; }

/* ---- concept : bento asymétrique ---- */
.concept-grid{
  display:grid; grid-template-columns:1.35fr 1fr 1fr; grid-auto-rows:1fr; gap:20px;
}
.card{
  background:var(--white); border-radius:var(--radius); padding:28px 24px;
  box-shadow:var(--shadow); position:relative; overflow:hidden;
  transition:transform .2s var(--ease-out);
}
.card h3{ font-size:1.18rem; margin-bottom:8px; }
.card p{ font-size:.94rem; color:var(--muted); font-weight:600; }
.card.photo{
  grid-row:1 / 3; display:flex; align-items:flex-end;
  background-size:cover; background-position:center; min-height:340px;
  color:var(--cream); padding:0;
}
.card.photo .scrim{
  width:100%; padding:80px 24px 26px;
  background:linear-gradient(180deg, rgba(59,36,23,0), rgba(59,36,23,.72));
}
.card.photo h3{ color:#fff; }
.card.photo p{ color:rgba(255,247,236,.9); }
.card.rose{ background:var(--rose-pale); }
.card.peach{ background:var(--orange-pale); }
.card.wide{ grid-column:2 / 4; }

/* ---- le parc (galerie photos réelles) ---- */
.parc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.parc-item{
  position:relative; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); aspect-ratio:4/5;
}
.parc-item img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .35s var(--ease-out);
}
.parc-item .lbl{
  position:absolute; left:14px; bottom:14px;
  background:rgba(255,247,236,.94); border-radius:999px; padding:7px 15px;
  font-family:var(--display); font-weight:600; font-size:.88rem; color:var(--ink);
  box-shadow:0 6px 16px -6px rgba(59,36,23,.4);
}
.parc-item:nth-child(odd) .lbl{ transform:rotate(-1.2deg); }
.parc-item:nth-child(even) .lbl{ transform:rotate(1deg); }

/* ---- journée type (timeline) ---- */
.day{ background:var(--stripe-dim), var(--cream-2); position:relative; }
.timeline{ position:relative; max-width:760px; margin:0 auto; }
.timeline::before{
  content:""; position:absolute; left:26px; top:6px; bottom:6px; width:4px;
  border-radius:2px; background:var(--stripe-v);
}
.tstep{
  position:relative; padding:0 0 38px 84px;
}
.tstep:last-child{ padding-bottom:0; }
.tstep .h{
  position:absolute; left:0; top:0; width:56px; height:56px; border-radius:50%;
  background:var(--white); box-shadow:var(--shadow);
  display:flex; align-items:center; justify-content:center; font-size:1.4rem;
  border:3px solid var(--orange-soft);
}
.tstep:nth-child(2n) .h{ border-color:var(--rose-soft); }
.tstep .time{
  font-family:var(--display); font-weight:600; color:var(--orange-deep);
  font-size:.95rem; letter-spacing:.04em;
}
.tstep:nth-child(2n) .time{ color:var(--rose-deep); }
.tstep h3{ font-size:1.25rem; margin:2px 0 6px; }
.tstep p{ color:var(--muted); font-weight:600; max-width:30em; }
.tstep .snap{
  position:absolute; right:0; top:-4px; width:132px; aspect-ratio:4/5; object-fit:cover;
  border:6px solid #fff; border-radius:8px; box-shadow:var(--shadow);
  transform:rotate(3deg);
}
.tstep .snap.l{ transform:rotate(-2.5deg); }

/* ---- services ---- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.svc{
  background:var(--white); border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); display:flex; flex-direction:column;
}
.svc .top{
  position:relative; height:12px; background:var(--stripe); flex:none;
}
.svc .top::after{
  content:""; position:absolute; top:100%; left:0; right:0; height:13px;
  background:
    radial-gradient(circle 13px at 13px 0, var(--orange-soft) 98%, transparent) 0 0/52px 13px repeat-x,
    radial-gradient(circle 13px at 13px 0, var(--rose-soft) 98%, transparent) 26px 0/52px 13px repeat-x;
}
.svc .body{ padding:34px 24px 24px; flex:1; display:flex; flex-direction:column; }
.svc h3{ font-size:1.3rem; margin-bottom:8px; }
.svc p{ color:var(--muted); font-weight:600; font-size:.95rem; flex:1; }
.svc .price{
  margin-top:16px; font-family:var(--display); font-weight:600;
  color:var(--rose-deep); font-size:1.05rem;
}
.svc .price small{ font-family:var(--body); font-weight:700; color:var(--muted); font-size:.8rem; }
.svc.lead{ grid-column:1 / -1; background:var(--rose-pale); }
.svc.lead .body{
  flex-direction:row; align-items:center; gap:28px; flex-wrap:wrap; padding:30px 28px 26px;
}
.svc.lead .txt{ flex:1 1 380px; }
.svc.lead h3{ font-size:1.6rem; }
.svc.lead p{ font-size:1rem; }
.svc.lead .go{ flex:none; display:flex; flex-direction:column; gap:10px; align-items:flex-start; }
.svc.lead .price{ margin-top:0; font-size:1.2rem; }

/* ---- tarifs ---- */
.tarifs{ background:var(--rose-pale); }
.pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
.price-card{
  background:var(--white); border:2.5px solid rgba(59,36,23,.1);
  border-radius:var(--radius); padding:30px 26px; position:relative;
  display:flex; flex-direction:column;
}
.price-card.star{
  border:10px solid transparent;
  background:linear-gradient(var(--white),var(--white)) padding-box, var(--stripe) border-box;
  box-shadow:0 18px 40px -14px rgba(59,36,23,.35);
  transform:rotate(-.8deg);
}
.price-card .tag{
  position:absolute; top:-16px; left:20px;
  background:var(--orange); color:var(--ink); font-weight:900; font-size:.74rem;
  letter-spacing:.1em; text-transform:uppercase; padding:5px 12px; border-radius:999px;
}
.price-card h3{ font-size:1.15rem; margin-bottom:4px; }
.price-card .amount{
  font-family:var(--display); font-weight:600; font-size:2.5rem; margin:8px 0 2px;
  color:var(--rose-deep);
}
.price-card .amount small{ font-size:1rem; font-weight:500; color:var(--muted); }
.price-card ul{ list-style:none; margin:16px 0 22px; flex:1; }
.price-card li{
  padding:7px 0 7px 26px; position:relative; font-weight:700; font-size:.92rem;
}
.price-card li::before{
  content:"🐾"; position:absolute; left:0; font-size:.85rem;
}
.tarifs .note{
  margin-top:26px; text-align:center; font-size:.85rem; color:var(--muted); font-weight:700;
}

/* ---- essai bandeau ---- */
.essai{ background:var(--stripe); position:relative; padding:0; }
.essai .in{
  background:rgba(255,247,236,.95); margin:0 auto; max-width:860px;
  border-radius:28px; padding:44px 40px; text-align:center;
  box-shadow:var(--shadow);
}
.essai-outer{ padding:70px 22px; }
.essai h2{ font-size:clamp(1.7rem,3.4vw,2.4rem); margin-bottom:12px; }
.essai p{ color:var(--muted); font-weight:700; max-width:36em; margin:0 auto 26px; }

/* ---- avis ---- */
.reviews .grid-3{ align-items:stretch; }
.review{
  background:var(--white); border-radius:var(--radius); padding:28px 26px;
  box-shadow:var(--shadow); display:flex; flex-direction:column; gap:14px;
}
.review .stars{ color:var(--orange); font-size:1.05rem; letter-spacing:.12em; }
.review p{ font-weight:600; color:var(--ink); font-size:.98rem; flex:1; }
.review .who{ display:flex; align-items:center; gap:12px; }
.review .avatar{
  width:44px; height:44px; border-radius:50%; flex:none;
  background:var(--orange-pale); display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:600; font-size:1.15rem; color:var(--ink);
}
.review:nth-child(2n) .avatar{ background:var(--rose-pale); }
.review .who b{ font-family:var(--display); font-weight:600; display:block; line-height:1.2; }
.review .who small{ color:var(--muted); font-weight:700; }
.gbadge{ margin-top:34px; display:flex; justify-content:center; }
.gbadge a{
  display:inline-flex; align-items:center; gap:12px; text-decoration:none;
  background:var(--white); border-radius:999px; padding:12px 24px; box-shadow:var(--shadow);
  font-weight:800;
}
.gbadge .stars{ color:var(--orange); }
.gbadge small{ color:var(--muted); font-weight:700; }

/* ---- instagram ---- */
.insta{ background:var(--cream-2); }
.insta-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.reel-card{
  position:relative; display:flex; align-items:center; justify-content:center;
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  background:var(--stripe); aspect-ratio:4/5; text-decoration:none;
  transition:transform .2s var(--ease-out);
}
.reel-card .bg{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
}
.reel-card .bgv{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  pointer-events:none;
}
@media (prefers-reduced-motion: reduce){
  .reel-card .bgv{ display:none; }
}
.reel-card::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(59,36,23,.06) 40%, rgba(59,36,23,.62));
}
.reel-card .play{
  position:relative; z-index:2; width:70px; height:70px; border-radius:50%;
  background:rgba(255,247,236,.95); color:var(--rose-deep);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; padding-left:6px;
  box-shadow:0 12px 28px -10px rgba(59,36,23,.5);
  transition:transform .2s var(--ease-out);
}
.reel-card .cap{
  position:absolute; left:20px; right:20px; bottom:18px; z-index:2;
  color:var(--cream); font-weight:800; font-size:.98rem; line-height:1.4;
}
.reel-card .cap small{
  display:block; margin-top:5px; font-size:.78rem; font-weight:800; opacity:.85;
}
.insta .more{ text-align:center; margin-top:30px; }

/* ---- infos pratiques / contact ---- */
.contact .cols{ display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:stretch; }
.contact .info{
  background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:34px 30px;
}
.contact .info h3{ font-size:1.3rem; margin-bottom:18px; }
.contact .row{
  display:flex; gap:14px; align-items:flex-start; padding:12px 0;
  border-bottom:2px dashed rgba(59,36,23,.08); font-weight:700;
}
.contact .row:last-child{ border-bottom:none; }
.contact .row .i{ font-size:1.25rem; flex:none; width:30px; text-align:center; }
.contact .row small{ display:block; color:var(--muted); font-weight:700; }
.contact .row a{ color:var(--rose-deep); font-weight:900; text-decoration:none; }
.contact .map{
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); min-height:380px;
}
.contact .map iframe{ width:100%; height:100%; min-height:380px; border:0; display:block; }

/* ---- FAQ ---- */
.faq{ background:var(--cream-2); }
.faq .list{ max-width:760px; margin:0 auto; display:grid; gap:14px; }
.faq details{
  background:var(--white); border-radius:18px; box-shadow:var(--shadow);
  padding:20px 24px; font-weight:600;
}
.faq summary{
  font-family:var(--display); font-weight:600; font-size:1.06rem;
  cursor:pointer; list-style:none; display:flex; align-items:center; gap:12px;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::before{
  content:"+"; font-size:1.3rem; color:var(--rose-deep); font-weight:500;
  width:26px; height:26px; border-radius:50%; background:var(--rose-pale);
  display:inline-flex; align-items:center; justify-content:center; flex:none;
  transition:transform .2s var(--ease-out);
}
.faq details[open] summary::before{ transform:rotate(45deg); }
.faq details p{ padding:12px 0 4px 38px; color:var(--muted); }
@supports (interpolate-size: allow-keywords){
  :root{ interpolate-size:allow-keywords; }
  .faq details::details-content{
    block-size:0; overflow:hidden;
    transition:block-size .3s var(--ease-out), content-visibility .3s allow-discrete;
  }
  .faq details[open]::details-content{ block-size:auto; }
}

/* ================= FOOTER ================= */
footer{
  background:var(--ink); color:var(--cream); padding:56px 0 32px;
  position:relative;
}
footer::before{
  content:""; position:absolute; top:0; left:0; right:0; height:8px; background:var(--stripe);
}
footer .cols{
  display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:36px; margin-bottom:36px;
}
footer h4{ font-size:1.05rem; margin-bottom:14px; color:var(--orange-soft); }
footer p, footer li{ font-size:.92rem; opacity:.8; font-weight:600; }
footer ul{ list-style:none; }
footer li{ padding:4px 0; }
footer a{ color:inherit; text-decoration:none; }
footer a:hover{ color:var(--rose-soft); }
footer .base{
  border-top:1px solid rgba(255,247,236,.15); padding-top:22px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:.8rem; opacity:.6; font-weight:700;
}

/* ---- ruban prototype MarsAI ---- */
.proto-ribbon{
  position:fixed; bottom:18px; left:18px; z-index:95;
  background:var(--ink); color:var(--cream);
  border-radius:999px; padding:9px 18px; font-size:.78rem; font-weight:800;
  box-shadow:0 10px 24px -8px rgba(0,0,0,.4);
  display:flex; align-items:center; gap:8px; text-decoration:none;
  opacity:.92;
}
.proto-ribbon:hover{ opacity:1; }
.proto-ribbon .dot{
  width:8px; height:8px; border-radius:50%; background:var(--orange); flex:none;
  animation:pulse 2s infinite;
}
@keyframes pulse{ 0%,100%{ opacity:1;} 50%{ opacity:.4;} }

/* ---- reveals (gatés JS : sans JS tout reste visible) ---- */
.reveal{ transition:opacity .45s var(--ease-out), transform .45s var(--ease-out); }
html.js .reveal{ opacity:0; transform:translateY(16px); }
html.js .reveal.show{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  html.js .reveal{ opacity:1; transform:none; transition:none; }
}

/* ================= RESERVATION ================= */
.resa-page{ padding:140px 0 90px; min-height:100vh; }
.resa-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:44px; align-items:start; }
.resa-form{
  background:var(--white); border-radius:26px; box-shadow:var(--shadow); padding:36px 32px;
}
.resa-form h1{ font-size:1.5rem; margin-bottom:2px; font-family:var(--display); font-weight:600; }
.resa-form h1:focus{ outline:none; }
.step-count{
  display:block; font-size:.82rem; font-weight:900; color:var(--muted);
  letter-spacing:.06em; margin-bottom:4px;
}
.resa-form .steps{ display:flex; gap:8px; margin:16px 0 26px; }
.resa-form .steps .s{
  flex:1; height:6px; border-radius:3px; background:var(--cream-2);
  position:relative; overflow:hidden;
}
.resa-form .steps .s::after{
  content:""; position:absolute; inset:0; border-radius:inherit;
  background:var(--stripe); transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease-out);
}
.resa-form .steps .s.on::after{ transform:scaleX(1); }
.step{ animation:stepIn .28s var(--ease-out); }
@keyframes stepIn{ from{ opacity:0; transform:translateY(8px); } }
@media (prefers-reduced-motion: reduce){ .step{ animation:none; } }

.fgroup{ margin-bottom:20px; }
.fgroup label, .fgroup-label{
  display:block; font-weight:900; font-size:.85rem; letter-spacing:.04em;
  margin-bottom:8px; color:var(--ink);
}
.fgroup input, .fgroup select, .fgroup textarea{
  width:100%; padding:13px 16px; border-radius:14px;
  border:2.5px solid rgba(59,36,23,.12); background:var(--cream);
  font-family:var(--body); font-weight:700; font-size:.98rem; color:var(--ink);
  transition:border-color .15s ease, box-shadow .15s ease;
}
.fgroup input:focus, .fgroup select:focus, .fgroup textarea:focus{
  outline:none; border-color:var(--rose-deep); box-shadow:0 0 0 4px var(--rose-pale);
}
.fgroup input.err{ border-color:#C0392B; }
.fmsg{ display:block; color:#C0392B; font-weight:800; font-size:.8rem; margin-top:6px; }
.choice-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.choice{
  border:2.5px solid rgba(59,36,23,.12); border-radius:16px; padding:16px;
  cursor:pointer; background:var(--cream);
  transition:border-color .15s, background .15s, transform .1s var(--ease-out);
  font-weight:700;
}
.choice:active{ transform:scale(.98); }
.choice small{ display:block; color:var(--muted); font-weight:700; }
.choice b{ font-family:var(--display); font-weight:600; }
.choice.sel{ border-color:var(--rose-deep); background:var(--rose-pale); }
.choice .pr{ color:var(--rose-deep); font-weight:900; }
.day-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:10px; }
.dayc{
  border:2.5px solid rgba(59,36,23,.12); border-radius:14px; padding:10px 6px;
  text-align:center; cursor:pointer; background:var(--cream); font-weight:800;
  transition:border-color .15s, background .15s, transform .1s var(--ease-out);
}
.dayc:not(.full):active{ transform:scale(.98); }
.dayc small{ display:block; font-size:.72rem; color:var(--muted); font-weight:800; text-transform:uppercase; }
.dayc b{ font-family:var(--display); font-weight:600; font-size:1.2rem; }
.dayc.sel{ border-color:var(--orange); background:var(--orange-pale); }
.dayc.full{ opacity:.45; cursor:not-allowed; }
.dayc.full .cpl{ color:#C0392B; font-weight:900; text-transform:uppercase; font-size:.62rem; }
.resa-nav{ display:flex; gap:12px; margin-top:26px; }
.resa-nav .btn{ flex:1; justify-content:center; }
.resa-side .panel{
  background:var(--white); border-radius:26px; box-shadow:var(--shadow);
  padding:30px 28px; margin-bottom:22px;
}
.resa-side .panel h3{ font-size:1.15rem; margin-bottom:12px; }
.recap-line{
  display:flex; justify-content:space-between; padding:9px 0; font-weight:700;
  border-bottom:2px dashed rgba(59,36,23,.08); font-size:.95rem;
}
.recap-line:last-of-type{ border-bottom:none; }
.recap-line .v{ font-weight:900; color:var(--rose-deep); }
.side-review{ font-weight:600; color:var(--ink); font-size:.95rem; margin-bottom:12px; }
.side-review small{ display:block; color:var(--muted); font-weight:700; margin-top:6px; }
.reassure{
  background:var(--orange-pale); border-radius:12px; padding:10px 14px;
  font-size:.85rem; font-weight:800; margin-bottom:16px;
}
.resa-confirm{ text-align:center; padding:40px 20px; }
.resa-confirm .big-emoji{ font-size:3.4rem; margin-bottom:14px; }
.resa-confirm h2{ margin-bottom:10px; }
.resa-confirm p{ color:var(--muted); font-weight:700; max-width:30em; margin:0 auto 8px; }
.demo-note{
  margin-top:18px; background:var(--orange-pale); border-radius:14px; padding:12px 18px;
  font-size:.85rem; font-weight:800; color:var(--ink);
}

/* ================= RESPONSIVE ================= */
@media (max-width: 1140px){
  .nav .links{
    display:none; position:absolute; top:100%; left:0; right:0;
    background:var(--cream); flex-direction:column; align-items:stretch;
    padding:16px 22px 22px; gap:6px; border-bottom:3px solid var(--orange-soft);
    box-shadow:0 20px 30px -18px rgba(59,36,23,.3);
  }
  .nav .links.open{ display:flex; }
  .nav .links a{ padding:12px 6px; border-bottom:2px solid rgba(59,36,23,.06); }
  .nav .cta{ margin:10px 0 0; justify-content:center; }
  .nav .links.solo{
    display:flex; position:static; flex-direction:row;
    background:none; border:0; box-shadow:none; padding:0; margin-left:auto; width:auto;
  }
  .burger{ display:flex; margin-left:auto; }
  .btn.cta-mobile{
    display:inline-flex; margin-left:auto; padding:10px 18px; font-size:.9rem;
  }
  .btn.cta-mobile ~ .burger{ margin-left:0; }
}
@media (max-width: 1020px){
  .hero .in{ grid-template-columns:1fr; gap:34px; }
  .hero-card{ min-height:380px; }
  .concept-grid{ grid-template-columns:1fr 1fr; }
  .card.photo{ grid-row:auto; grid-column:1 / -1; min-height:260px; }
  .card.wide{ grid-column:auto; }
}
@media (max-width: 860px){
  .grid-3, .pricing, .insta-grid{ grid-template-columns:1fr; }
  .price-card.star{ transform:none; }
  .concept-grid{ grid-template-columns:1fr; }
  .contact .cols{ grid-template-columns:1fr; }
  footer .cols{ grid-template-columns:1fr; gap:26px; }
  .resa-grid{ grid-template-columns:1fr; }
  section{ padding:64px 0; }
  .hero{ padding:120px 0 64px; }
  .day-grid{ grid-template-columns:repeat(3,1fr); }
  .choice-grid{ grid-template-columns:1fr; }
  .parc-grid{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .tstep .snap{ display:none; }
  .tstep p{ max-width:36em; }
  .svc.lead .body{ flex-direction:column; align-items:flex-start; }
  .hero-frame{ padding:8px; border-radius:34px; }
}
@media (max-width: 480px){
  body{ font-size:15.5px; }
  .hero .ctas .btn{ width:100%; justify-content:center; }
  .proto-ribbon{ left:12px; bottom:12px; font-size:.7rem; padding:8px 14px; }
}
