:root{
  --pink:#cbcbcb;
  --pink-soft:#f0efed;
  --pink-deep:#161616;
  --nude:#efe1d6;
  --ink:#161616;
  --ink-soft:#6f6f6f;
  --bg:#ffffff;
  --bg-alt:#f4f4f3;
  --white:#ffffff;
  --radius:22px;
  --shadow:0 18px 50px rgba(0,0,0,.10);
  --maxw:1120px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden;width:100%;max-width:100%;position:relative}
body{
  font-family:'Jost',sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.1}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* BUTTONS */
.btn{
  display:inline-block;
  background:var(--ink);
  color:#fff;
  padding:.9rem 1.8rem;
  border-radius:50px;
  font-weight:500;
  letter-spacing:.3px;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
  font-size:.95rem;
  text-align:center;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(44,37,40,.25)}
.btn--small{padding:.6rem 1.3rem;font-size:.85rem}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--light{background:#fff;color:var(--ink)}
.btn--ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.btn--ghost-light:hover{background:#fff;color:var(--ink)}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.2rem,5vw,3.5rem);
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;
}
.nav.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 24px rgba(0,0,0,.10);padding-top:.8rem;padding-bottom:.8rem}
.nav__logo{display:flex;align-items:center;gap:.32rem;font-family:'Carter One',sans-serif;font-weight:400;letter-spacing:.3px;font-size:1.5rem;line-height:1;text-transform:lowercase;z-index:60}
.nav__logo span{color:var(--pink-deep)}
.nav__links{display:flex;gap:2rem;align-items:center}
.nav__links a{font-size:.95rem;position:relative}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1.5px;background:var(--pink-deep);transition:width .3s}
.nav__links a:hover::after{width:100%}
.nav__cta-mobile{display:none}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;z-index:60;padding:6px}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:.3s;display:block;border-radius:2px}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* HERO */
.hero{
  min-height:100vh;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:7rem 1.5rem 4rem;position:relative;
  background:linear-gradient(180deg,#ffffff 0,#f3f2f0 100%);
}
.hero__brand{display:flex;flex-direction:column;align-items:center;margin-bottom:1.8rem;line-height:1}
.hero__brand-name{font-family:'Carter One',sans-serif;font-weight:400;font-size:clamp(2.7rem,9.5vw,4rem);letter-spacing:.5px;line-height:.95;text-transform:lowercase;color:var(--ink)}
.hero__brand-name .accent{color:var(--pink-deep)}
.hero__brand-tag{margin-top:.6rem;font-family:'Cutive Mono',monospace;text-transform:uppercase;letter-spacing:3px;font-size:clamp(.62rem,2.4vw,.76rem);color:var(--pink-deep);padding-left:3px}
.hero__brand-tag::after{content:" ♡";letter-spacing:0}
.hero__eyebrow{text-transform:uppercase;letter-spacing:2.5px;font-size:clamp(.68rem,2.5vw,.8rem);color:var(--pink-deep);margin-bottom:1.2rem;font-weight:500}
.hero__title{font-size:clamp(2.7rem,11vw,6.5rem);letter-spacing:-1px}
.hero__title em{font-style:italic;color:var(--pink-deep)}
.hero__sub{max-width:540px;margin:1.6rem auto 2.2rem;color:var(--ink-soft);font-size:clamp(1rem,2.6vw,1.1rem)}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero__rating{margin-top:1.8rem;color:var(--pink-deep);font-size:.92rem;letter-spacing:.5px}
.hero__rating strong{color:var(--ink)}
.hero__scroll{position:absolute;bottom:1.4rem;font-size:1.4rem;color:var(--pink-deep);animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* MARQUEE */
.marquee{background:var(--ink);color:#fff;overflow:hidden;padding:.9rem 0}
.marquee__track{display:flex;gap:2rem;white-space:nowrap;animation:scroll 24s linear infinite;width:max-content}
.marquee__track span{font-size:clamp(.8rem,2.4vw,.95rem);letter-spacing:2px;text-transform:uppercase;padding-right:2rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* SECTIONS */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(3.5rem,9vw,7rem) clamp(1.2rem,5vw,2rem)}
.section--alt{background:var(--bg-alt);max-width:100%}
.section--alt > *{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.section__head{text-align:center;margin-bottom:3rem}
.section__head h2{font-size:clamp(2.2rem,7vw,3.6rem)}
.section__lead{max-width:580px;margin:.8rem auto 0;color:var(--ink-soft)}
.overline{text-transform:uppercase;letter-spacing:3px;font-size:.78rem;color:var(--pink-deep);font-weight:500;margin-bottom:.6rem}
.overline--light{color:var(--pink-soft)}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.4rem}
.card{
  position:relative;background:var(--white);border-radius:var(--radius);padding:2.2rem 1.8rem 1.8rem;
  box-shadow:var(--shadow);transition:transform .3s ease;border:1px solid rgba(0,0,0,.08);
}
.card:hover{transform:translateY(-6px)}
.card__dur{position:absolute;top:1.2rem;right:1.3rem;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--pink-deep);background:var(--pink-soft);padding:.25rem .7rem;border-radius:50px}
.card h3{font-size:1.55rem;margin-bottom:.5rem;padding-right:3rem}
.card p{color:var(--ink-soft);font-size:.93rem;margin-bottom:1.2rem}
.card__price{display:inline-block;font-weight:600;font-size:1.15rem;color:var(--pink-deep);letter-spacing:.5px}
.card--featured{background:linear-gradient(160deg,var(--pink-soft),#fff);border:1px solid var(--pink)}
.note{text-align:center;margin-top:2rem;color:var(--ink-soft);font-size:.88rem;font-style:italic}
.tarifs{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem}
.tarifs .card h3{font-size:1.5rem;margin-bottom:.9rem}
.pricelist li{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px dashed rgba(0,0,0,.12);font-size:.95rem}
.pricelist li:last-child{border-bottom:none}
.pricelist li span:last-child{font-weight:600;white-space:nowrap}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.5rem}
.gallery__item{
  aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .35s ease;background:var(--pink-soft);
}
.gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gallery__item:hover{transform:translateY(-4px)}
.gallery__item:hover img{transform:scale(1.06)}
.center{text-align:center}

/* ABOUT */
.about{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about__media{display:flex;justify-content:center}
.about__photo{
  width:min(360px,78vw);aspect-ratio:1;overflow:hidden;
  background:linear-gradient(150deg,var(--pink-soft),#e7e7e5);
  border-radius:42% 58% 60% 40%/45% 45% 55% 55%;box-shadow:var(--shadow);
  animation:morph 9s ease-in-out infinite;
}
.about__photo img{width:100%;height:100%;object-fit:cover;display:block}
@keyframes morph{0%,100%{border-radius:42% 58% 60% 40%/45% 45% 55% 55%}50%{border-radius:58% 42% 40% 60%/55% 55% 45% 45%}}
.about__text h2{font-size:clamp(2rem,6vw,3.2rem);margin:.3rem 0 1rem}
.about__text p{color:var(--ink-soft);margin-bottom:1rem}
.ticks{margin:1.2rem 0 1.6rem;display:grid;gap:.5rem}
.ticks li{position:relative;padding-left:1.7rem;color:var(--ink);font-size:.95rem}
.ticks li::before{content:"✓";position:absolute;left:0;color:var(--pink-deep);font-weight:700}

/* INFOS */
.infos{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.6rem}
.infos__block{background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}
.infos__block h3{font-size:1.45rem;margin-bottom:.8rem}
.infos__block h3.mt{margin-top:1.6rem}
.infos__block p{color:var(--ink-soft);margin-bottom:.5rem}
.infos__block .small{font-size:.85rem;margin-top:1rem;color:var(--pink-deep)}
.hours li{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px dashed rgba(0,0,0,.25);font-size:.95rem}
.hours li:last-child{border:none}
.hours span:last-child{color:var(--pink-deep);font-weight:500;text-align:right}
.tags{display:flex;flex-wrap:wrap;gap:.5rem}
.tags span{background:var(--bg-alt);color:var(--ink);font-size:.82rem;padding:.4rem .8rem;border-radius:50px}

/* CONTACT */
.contact{
  background:#161616;
  color:#fff;text-align:center;padding:clamp(3.5rem,9vw,7rem) 1.5rem;
}
.contact__inner{max-width:620px;margin:0 auto}
.contact h2{font-size:clamp(2.2rem,7vw,3.6rem);margin-bottom:1rem}
.contact p{opacity:.95;margin-bottom:2rem}
.contact__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* FOOTER */
.footer{background:var(--ink);color:#fff;text-align:center;padding:3rem 1.5rem 2.4rem}
.footer__logo{font-family:'Carter One',sans-serif;font-weight:400;font-size:1.8rem;letter-spacing:.3px;text-transform:lowercase;margin-bottom:.5rem}
.footer__logo span{color:var(--pink)}
.footer p{color:rgba(255,255,255,.6);font-size:.9rem}
.footer__links{display:flex;gap:1.4rem;justify-content:center;margin:1.4rem 0;flex-wrap:wrap}
.footer__links a{font-size:.9rem;opacity:.85;transition:opacity .2s}
.footer__links a:hover{opacity:1;color:var(--pink-soft)}
.footer__copy{margin-top:1rem;font-size:.8rem !important}

/* FAB (bouton flottant mobile) */
.fab{
  display:none;position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);z-index:45;
  background:var(--pink-deep);color:#fff;padding:.85rem 2rem;border-radius:50px;font-weight:500;
  box-shadow:0 10px 30px rgba(0,0,0,.5);font-size:.95rem;
}

/* CONFIGURATEUR */
.builder-section [hidden]{display:none !important}
.builder{max-width:880px;margin:0 auto}
.builder__progress{display:flex;gap:.5rem;justify-content:center;margin-bottom:2.4rem}
.builder__progress .dot{width:34px;height:4px;border-radius:4px;background:var(--pink-soft);transition:background .3s ease}
.builder__progress .dot.is-done{background:var(--pink)}
.builder__progress .dot.is-active{background:var(--pink-deep)}

.step{animation:stepin .35s ease}
@keyframes stepin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.step__title{font-size:1.7rem;display:flex;align-items:center;gap:.6rem;margin-bottom:.3rem}
.step__title span{flex:none;display:inline-grid;place-items:center;width:1.9rem;height:1.9rem;border-radius:50%;background:var(--pink-deep);color:#fff;font-family:'Jost',sans-serif;font-size:.95rem;font-weight:600}
.step__title small{font-family:'Jost',sans-serif;font-weight:400;font-size:.82rem;color:var(--ink-soft)}
.step__hint{color:var(--ink-soft);font-size:.92rem;margin-bottom:1.3rem}
.step--error .opts{outline:2px solid var(--pink);outline-offset:8px;border-radius:18px}

.opts{display:grid;gap:.55rem;width:100%}
.opts--presta{grid-template-columns:repeat(auto-fit,minmax(138px,1fr));gap:1.3rem .6rem}
.opts--shapes{grid-template-columns:repeat(auto-fit,minmax(72px,1fr))}
.opts--len{grid-template-columns:repeat(5,1fr);align-items:end;gap:.35rem}
.opts--styles{grid-template-columns:repeat(auto-fit,minmax(94px,1fr))}
.opts--colors{grid-template-columns:repeat(auto-fit,minmax(58px,1fr))}

.opt{
  position:relative;cursor:pointer;min-width:0;border:2px solid rgba(0,0,0,.18);background:#fff;
  border-radius:16px;padding:.7rem .5rem;text-align:center;font:inherit;color:inherit;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;
  overflow-wrap:anywhere;hyphens:auto;
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.opt:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.opt.is-sel{border-color:var(--pink-deep);box-shadow:0 10px 26px rgba(0,0,0,.25)}
.opt.is-sel::after{content:"✓";position:absolute;top:.45rem;right:.45rem;width:1.3rem;height:1.3rem;display:grid;place-items:center;background:var(--pink-deep);color:#fff;border-radius:50%;font-size:.76rem;z-index:2}
.opt__name{font-weight:600;font-size:clamp(.78rem,2.5vw,.95rem);line-height:1.2;text-wrap:balance}

/* Prestations */
.opt--presta{padding:1rem .8rem;gap:.25rem}
.opt--presta .opt__emoji{font-size:1.5rem}
.opt--presta .opt__name{font-size:clamp(.9rem,2.6vw,1rem)}
.opt__desc{font-size:clamp(.7rem,2.2vw,.78rem);color:var(--ink-soft);line-height:1.25;text-wrap:balance}
.opt__price{font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:var(--pink-deep);font-weight:600;margin-top:.1rem}
.opt--featured{background:linear-gradient(160deg,var(--pink-soft),#fff);border-color:var(--pink)}
.opt__tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--pink-deep);color:#fff;font-size:.6rem;letter-spacing:1px;text-transform:uppercase;padding:.2rem .65rem;border-radius:50px}

/* Formes */
.opt--shape{min-height:108px;gap:.4rem;padding:.6rem .3rem}
.opt--shape svg{width:clamp(32px,8.5vw,42px);height:auto;aspect-ratio:60/100;fill:var(--pink-soft);stroke:var(--pink-deep);stroke-width:2;transition:fill .2s ease}
.opt--shape.is-sel svg{fill:var(--pink)}
.opt--shape span{font-size:clamp(.68rem,2.4vw,.8rem);font-weight:500;line-height:1.1}

/* Longueur */
.opt--len{min-height:138px;justify-content:flex-end;gap:.45rem;padding:.7rem .15rem .7rem}
.len__bar{display:block;width:clamp(16px,5vw,30px);min-height:22px;height:var(--h);border-radius:8px 8px 3px 3px;background:linear-gradient(var(--pink),var(--pink-deep))}
.opt--len span:last-child{font-size:clamp(.66rem,2.3vw,.82rem);font-weight:500;line-height:1.1;min-height:2.2em;display:flex;align-items:flex-start;justify-content:center}

/* Styles (vignettes photo) */
.opt--style{padding:0;overflow:hidden;justify-content:flex-start;gap:0}
.opt--style .opt__img{width:100%;aspect-ratio:1;background-size:cover;background-position:center;background-color:var(--pink-soft);display:grid;place-items:center;font-size:1.9rem}
.opt--noimg .opt__img{background:linear-gradient(150deg,var(--pink-soft),#e7e7e5)}
.opt--style .opt__name{display:flex;align-items:center;justify-content:center;width:100%;min-height:2.4em;padding:.35rem .3rem;font-size:clamp(.68rem,2.2vw,.8rem)}
.opt--style.is-sel::after{top:.35rem;right:.35rem}

/* Couleurs */
.opt--color{min-height:80px;gap:.32rem;padding:.45rem .2rem;border-radius:14px}
.swatch{width:clamp(32px,8.5vw,42px);aspect-ratio:1;border-radius:50%;border:2px solid rgba(0,0,0,.07);box-shadow:inset 0 0 0 2px #fff}
.opt--color .opt__name{font-size:clamp(.62rem,2vw,.72rem);line-height:1.1;min-height:2.1em;display:flex;align-items:center;justify-content:center}
.opt--color.is-sel::after{top:.3rem;right:.35rem;width:1.1rem;height:1.1rem;font-size:.66rem}

.builder__nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:2.2rem}
.builder__count{font-size:.85rem;color:var(--ink-soft)}
.builder__nav .btn{min-width:135px}

.bld-note{display:block;margin-bottom:1.1rem}
.bld-note > span{display:block;font-size:.88rem;color:var(--ink-soft);margin-bottom:.4rem}
.bld-note textarea{width:100%;border:2px solid rgba(0,0,0,.2);border-radius:14px;padding:.8rem 1rem;font:inherit;background:#fff;resize:vertical}
.bld-note textarea:focus{outline:none;border-color:var(--pink-deep)}
.recap{background:var(--bg-alt);border-radius:18px;padding:1.4rem 1.5rem;margin-bottom:1.3rem}
.recap h4{font-family:'Cormorant Garamond',serif;font-size:1.5rem;margin-bottom:.7rem}
.recap ul{display:grid;gap:.5rem}
.recap li{display:flex;justify-content:space-between;gap:1rem;font-size:.95rem;padding-bottom:.45rem;border-bottom:1px dashed rgba(0,0,0,.25)}
.recap li span:first-child{color:var(--ink-soft)}
.recap li span:last-child{font-weight:500;text-align:right}
.recap__total{margin-top:.8rem;font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--pink-deep);font-weight:600}
.builder__actions{display:flex;gap:.8rem;flex-wrap:wrap}
.bld-tip{font-size:.82rem;color:var(--ink-soft);margin-top:1rem;font-style:italic}

.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%,160%);background:var(--ink);color:#fff;padding:.85rem 1.4rem;border-radius:50px;font-size:.9rem;box-shadow:var(--shadow);z-index:80;transition:transform .35s ease;max-width:90vw;text-align:center}
.toast.show{transform:translate(-50%,0)}

@media(max-width:560px){
  .builder__nav .btn{min-width:0;flex:1}
  .builder__count{display:none}
  .toast{bottom:5.5rem}
}

/* CTA configurateur (accueil) */
.composer-cta{text-align:center}
.composer-cta__inner{max-width:620px;margin:0 auto;background:linear-gradient(160deg,var(--pink-soft),#fff);border:1px solid var(--pink);border-radius:var(--radius);padding:clamp(2rem,6vw,3.2rem);box-shadow:var(--shadow)}
.composer-cta__inner h2{font-size:clamp(1.9rem,6vw,2.8rem);margin:.2rem 0 .8rem}
.composer-cta__inner p{color:var(--ink-soft);margin-bottom:1.6rem}

/* Page dédiée configurateur */
.composer-page{background:var(--bg);height:100svh;min-height:100svh;overflow:hidden;display:flex;flex-direction:column}
.composer-page .footer{display:none}
.cpage-nav{flex:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem clamp(1.2rem,5vw,3rem);background:rgba(255,255,255,.94);box-shadow:0 4px 24px rgba(0,0,0,.10)}
.cpage-back{font-size:.9rem;color:var(--pink-deep);font-weight:500}
.cpage{flex:1;min-height:0;width:100%;max-width:760px;margin:0 auto;padding:.7rem clamp(1rem,5vw,1.6rem) 1rem;display:flex;flex-direction:column}
.cpage__head{display:none}
.cpage__grid{display:grid;grid-template-columns:1fr 340px;gap:2.2rem;align-items:start}
.cpage__main{display:grid;gap:1.5rem}
.cpage__main .step{background:#fff;border-radius:var(--radius);padding:1.7rem 1.5rem;box-shadow:var(--shadow);animation:none}
.cpage [hidden]{display:none !important}

/* Récap latéral */
.summary{position:sticky;top:86px;background:linear-gradient(160deg,var(--pink-soft),#fff);border:1px solid var(--pink);border-radius:var(--radius);padding:1.6rem 1.5rem;box-shadow:var(--shadow)}
.summary h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.7rem;margin-bottom:1rem}
.summary__list{display:grid;gap:.55rem;margin-bottom:1rem}
.summary__row{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;padding-bottom:.5rem;border-bottom:1px dashed rgba(0,0,0,.3)}
.summary__row span:first-child{color:var(--ink-soft)}
.summary__row span:last-child{font-weight:500;text-align:right}
.summary__total{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.4rem;color:var(--pink-deep);margin:.2rem 0 1.1rem}
.summary__actions{display:grid;gap:.6rem}
.summary__actions .btn{width:100%}
.summary__reset{display:block;width:100%;text-align:center;margin-top:.9rem;font:inherit;font-size:.82rem;color:var(--ink-soft);background:none;border:none;cursor:pointer;text-decoration:underline}
.summary .bld-tip{margin-top:1rem}

/* Assistant guidé (wizard) — application plein écran, sans scroll de page */
.wizard{flex:1;min-height:0;width:100%;max-width:720px;margin:0 auto;display:flex;flex-direction:column}
.wizard__head{flex:none;margin-bottom:.8rem}
.wizard__track{display:flex;gap:.4rem;margin-bottom:.6rem}
.wizard__seg{flex:1;height:6px;border-radius:6px;background:var(--pink-soft);transition:background .3s ease}
.wizard__seg.is-done{background:var(--pink)}
.wizard__seg.is-active{background:var(--pink-deep)}
.wizard__seg.is-clickable{cursor:pointer}
.wizard__step{font-size:.78rem;color:var(--pink-deep);letter-spacing:1.5px;text-transform:uppercase;font-weight:600;text-align:center}
.wizard__stage{flex:1;min-height:0;overflow:hidden;display:flex;background:#fff;border-radius:var(--radius);padding:clamp(1.1rem,4vw,1.8rem);box-shadow:var(--shadow)}
.wstep{flex:1;min-width:0;display:flex;flex-direction:column;animation:stepin .35s ease}
.wstep__title{flex:none;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:clamp(1.4rem,4.8vw,2rem);line-height:1.05;margin-bottom:.2rem;text-align:center}
.wstep__title small{font-family:'Jost',sans-serif;font-weight:400;font-size:.76rem;color:var(--ink-soft)}
.wstep__hint{flex:none;color:var(--ink-soft);font-size:.85rem;margin-bottom:.8rem;text-align:center}
.wstep > .opts{flex:1;min-height:0;align-content:safe center;overflow-y:auto;overscroll-behavior:contain;padding:10px 4px}
.wstep .bld-note{flex:none;text-align:left}
.wstep .recap{flex:1;min-height:0;overflow-y:auto}
.wstep .builder__actions{flex:none}
.wstep .bld-tip{flex:none}
.cb-banner,.cb-or{flex:none}
.wizard__nav{flex:none;display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-top:.8rem}
.wizard__nav .btn{min-width:120px}
.wizard__live{font-weight:600;font-size:1rem;white-space:nowrap;color:var(--ink)}
.opt__dur{font-size:.72rem;color:var(--ink-soft);letter-spacing:.3px}
.btn.is-disabled{opacity:.5;filter:grayscale(.15)}

/* Carte blanche */
.cb-banner{display:block;width:100%;font:inherit;font-weight:600;color:var(--ink);text-align:center;cursor:pointer;
  background:linear-gradient(135deg,var(--pink-soft),#e7e7e5);border:2px dashed var(--pink-deep);border-radius:16px;
  padding:1rem 1.1rem;margin-bottom:.7rem;transition:transform .2s ease,box-shadow .2s ease}
.cb-banner:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.cb-banner.is-sel{background:var(--pink-deep);color:#fff;border-style:solid}
.cb-or{text-align:center;color:var(--ink-soft);font-size:.85rem;margin:0 0 1rem}
.swatch--cb{display:grid;place-items:center;font-size:1.25rem;background:conic-gradient(from 0deg,#eee,#cfcfcf,#9a9a9a,#cfcfcf,#eee)}
.chip--cb{background:var(--pink-deep);color:#fff;border-color:var(--pink-deep)}

/* Récap final */
.recap__top{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.recap__shape{flex:none;width:56px;height:70px;display:grid;place-items:center;background:var(--pink-soft);border-radius:14px}
.recap__shape svg{width:30px;height:54px;fill:var(--pink);stroke:var(--pink-deep);stroke-width:2}
.recap__presta{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;line-height:1.1}
.recap__price{color:var(--pink-deep);font-weight:500;font-size:.95rem}
.recap__wrap{flex-wrap:wrap}
.chips{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}
.chip{background:#fff;border:1px solid var(--pink);color:var(--ink);font-size:.8rem;padding:.25rem .65rem;border-radius:50px}
.chip--muted{border-color:rgba(0,0,0,.3);color:var(--ink-soft)}
.cdot{display:inline-flex;align-items:center;gap:.35rem;background:#fff;border:1px solid rgba(0,0,0,.25);font-size:.8rem;padding:.2rem .6rem .2rem .35rem;border-radius:50px}
.cdot i{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.08)}

/* Aperçu try-on */
.tryon{text-align:center;margin-bottom:1.1rem;padding-bottom:1rem;border-bottom:1px dashed rgba(0,0,0,.12)}
.tryon__cap{font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-soft);margin-bottom:.5rem}
.tryon__hand{display:flex;justify-content:center}
.hand{width:100%;max-width:330px;height:auto;display:block}
.apercu{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.7rem;padding-top:.3rem}
.picker{width:100%;max-width:430px;background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:16px;padding:.8rem .9rem;box-shadow:var(--shadow)}
.picker__head{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.92rem;margin-bottom:.3rem}
.picker__close{background:none;border:none;font:inherit;font-size:.78rem;color:var(--ink-soft);cursor:pointer}
.picker__lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft);margin:.5rem 0 .35rem}
.picker__row{display:flex;flex-wrap:wrap;gap:.4rem}
.pk-c{width:26px;height:26px;border-radius:50%;border:2px solid rgba(0,0,0,.12);cursor:pointer;padding:0}
.pk-c.is-on{border-color:var(--ink);box-shadow:inset 0 0 0 2px #fff}
.pk-custom{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;border:2px dashed var(--ink-soft);cursor:pointer;font-size:.72rem;position:relative;overflow:hidden}
.pk-custom input{position:absolute;inset:0;opacity:0;cursor:pointer}
.pk-d{min-width:30px;height:30px;border-radius:9px;border:1.5px solid rgba(0,0,0,.15);background:#fff;cursor:pointer;font-size:1rem;line-height:1;padding:0 .25rem}
.pk-d.is-on{border-color:var(--ink);background:var(--bg-alt)}
.apercu .tryon{margin-bottom:0;padding-bottom:0;border-bottom:none}
.apercu .hand{max-width:380px}
.apercu .tryon{background:radial-gradient(circle at 50% 38%,#fbf9f7,#ece9e4);border-radius:20px;padding:1rem .4rem .6rem;width:100%}
#apercu g[data-nail]{cursor:pointer}
.nailpick-hint{text-align:center;font-size:.84rem;color:var(--ink-soft);margin-top:.7rem}

/* Photo d'inspiration */
.bld-photo{flex:none;display:flex;flex-direction:column;align-items:center;gap:.6rem;margin:.4rem 0 1rem}
.bld-photo__btn{display:inline-block;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--ink);border:1.5px dashed var(--ink);border-radius:50px;padding:.6rem 1.3rem;transition:background .2s ease,color .2s ease}
.bld-photo__btn:hover{background:var(--ink);color:#fff}
.bld-photo__prev{max-width:140px;max-height:140px;border-radius:14px;object-fit:cover;box-shadow:var(--shadow)}

@media(max-width:900px){
  .cpage__grid{grid-template-columns:1fr}
  .summary{position:static}
}
@media(max-width:560px){
  .cpage__main .step{padding:1.3rem 1.1rem}
  .step__title{font-size:1.45rem}
  .wizard__stage{padding:1.1rem 1rem}
  .wizard__nav .btn{min-width:0;flex:1}
  .chips{justify-content:flex-start}
}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee__track,.about__photo,.hero__scroll{animation:none}
  html{scroll-behavior:auto}
}

/* RESPONSIVE */
@media(max-width:820px){
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__links{
    position:fixed;inset:0;background:rgba(255,255,255,.98);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    flex-direction:column;justify-content:center;gap:2rem;
    opacity:0;visibility:hidden;pointer-events:none;
    transform:translateY(-12px);
    transition:opacity .3s ease,transform .3s ease,visibility .3s;
  }
  .nav__links.open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
  .nav__links a{font-size:1.4rem;font-family:'Cormorant Garamond',serif}
  .nav__cta-mobile{
    display:inline-block;background:var(--ink);color:#fff;padding:.7rem 2rem;border-radius:50px;font-size:1.1rem !important;
  }
  .about{grid-template-columns:1fr;text-align:center}
  .about__media{order:-1}
  .ticks{display:inline-grid;text-align:left}
  .tags{justify-content:center}
  .fab{display:inline-block}
  body{padding-bottom:4.5rem}
  .footer{padding-bottom:5.5rem}
}
@media(max-width:680px){
  .gallery{grid-template-columns:repeat(2,1fr);gap:.7rem}
}
@media(max-width:400px){
  .hero__cta .btn{width:100%}
  .cards{grid-template-columns:1fr}
}
