/* ===================================================================
   LE BOCAL — Tattoo Shop & Galerie
   DA: éditorial sombre, type géante, N&B plein cadre, rouge coquelicot
   =================================================================== */
:root{
  --bg:#0c0b0a; --bg-2:#131110; --bg-3:#1a1714;
  --bone:#f2ebdd; --bone-2:#cfc7b8; --dim:#7c7468;
  --poppy:#e0392c; --poppy-2:#ff5a45;
  --line:rgba(242,235,221,.13);
  --f-display:"Anton", Impact, sans-serif;
  --f-serif:"Fraunces", Georgia, serif;
  --f-body:"Space Grotesk", system-ui, sans-serif;
  --ease:cubic-bezier(.19,1,.22,1);
  --maxw:1480px;
  --pad:clamp(20px,4.5vw,80px);
}
/* === THÈME couleur rétro 70s (bascule via le bouton de la nav) === */
html.theme-retro{
  --bg:#2e1a13; --bg-2:#3c241a; --bg-3:#4f291e;
  --bone:#efe6cf; --bone-2:#d8c8a4; --dim:#a98c6f;
  --poppy:#e44422; --poppy-2:#ef9594;
  --yellow:#f6bf02; --teal:#27a49e; --salmon:#ef9594;
  --line:rgba(228,217,186,.16);
}
html.theme-retro .nav.is-scrolled{background:rgba(46,26,19,.94)}
html.theme-retro .loader__panels span:nth-child(2){background:#4f291e}
/* quelques accents chauds en thème rétro */
html.theme-retro .marquee{background:var(--teal);color:#10302e}
html.theme-retro .marquee .star{color:var(--bg)}
html.theme-retro .eyebrow i,html.theme-retro .loader__pct,html.theme-retro .hero__loc i{color:var(--yellow)}
/* bouton bascule de couleurs (fixe) */
.theme-switch{position:fixed;left:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:810;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--bg-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;box-shadow:0 8px 24px rgba(0,0,0,.35);transition:transform .35s var(--ease),border-color .3s}
.theme-switch span{width:20px;height:20px;border-radius:50%;background:conic-gradient(from 220deg,#e0392c 0 50%,#f6bf02 50% 100%);box-shadow:inset 0 0 0 1px rgba(0,0,0,.25)}
.theme-switch:hover{transform:rotate(25deg) scale(1.06);border-color:var(--poppy)}
.theme-switch::after{content:"Couleurs";position:absolute;left:54px;white-space:nowrap;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--bone-2);opacity:0;transition:opacity .3s;pointer-events:none}
.theme-switch:hover::after{opacity:1}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html.js{scroll-behavior:auto}
body{background:var(--bg);color:var(--bone);font-family:var(--f-body);font-weight:400;line-height:1.6;overflow-x:clip;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--poppy);color:#fff}
.star{color:var(--poppy);font-style:normal}

/* ---------- shared type ---------- */
.eyebrow{font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.22em;color:var(--bone-2);display:flex;align-items:center;gap:10px}
.eyebrow i{color:var(--poppy);font-style:normal;font-feature-settings:"tnum"}
.eyebrow--light{color:var(--bone-2)}
.sec-head{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,10vw,150px) var(--pad) clamp(34px,4vw,60px)}
.sec-title{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(3rem,12vw,9.5rem);line-height:.92;letter-spacing:-.01em;margin-top:.3em}
.sec-title--xl{font-size:clamp(3.4rem,16vw,13rem)}
em{font-style:italic;color:var(--poppy)}

/* ---------- buttons / links ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--f-body);text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;font-weight:500;padding:1.1em 2em;border-radius:60px;transition:transform .5s var(--ease),background .4s,color .4s,border-color .4s}
.btn--solid{background:var(--poppy);color:#fff;border:1px solid var(--poppy)}
.btn--solid:hover{background:#fff;color:var(--bg);border-color:#fff}
.btn--lg{font-size:.95rem;padding:1.3em 2.7em}
.arrow-link{display:inline-flex;align-items:center;gap:.6em;font-family:var(--f-body);text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;font-weight:500;color:var(--bone);padding-bottom:4px;border-bottom:1px solid var(--line);transition:border-color .4s,color .3s}
.arrow-link span{display:inline-block;transition:transform .4s var(--ease);color:var(--poppy)}
.arrow-link:hover{border-color:var(--poppy)}
.arrow-link:hover span{transform:translate(4px,-4px)}
.arrow-link.sm{font-size:.72rem;border:0;padding:0}

/* ---------- grain ---------- */
.grain{position:fixed;inset:-120%;z-index:9990;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(6) infinite}
@keyframes grain{0%{transform:translate(0,0)}30%{transform:translate(4%,-5%)}60%{transform:translate(-3%,4%)}100%{transform:translate(0,0)}}
.scroll-prog{position:fixed;top:0;left:0;width:100%;height:2px;background:var(--poppy);transform:scaleX(0);transform-origin:left;z-index:250;will-change:transform}
.ink-cta{position:fixed;right:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:800;display:inline-flex;align-items:center;gap:10px;padding:.85em 1.35em;border-radius:50px;background:var(--poppy);color:#fff;border:0;cursor:pointer;font-family:var(--f-body);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;font-weight:600;box-shadow:0 14px 32px -10px rgba(224,57,44,.7);opacity:0;transform:translateY(20px) scale(.9);pointer-events:none;transition:opacity .5s var(--ease),transform .5s var(--ease),background .3s}
.ink-cta.is-visible{opacity:1;transform:none;pointer-events:auto}
.ink-cta:hover{background:var(--poppy-2)}
.ink-cta svg{width:20px;height:20px;flex:0 0 auto;animation:inkPulse 2.4s var(--ease) infinite}
@keyframes inkPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}
body.modal-open .ink-cta{opacity:0;pointer-events:none}
@media(max-width:560px){.ink-cta span{display:none}.ink-cta{padding:0;width:54px;height:54px;border-radius:50%;justify-content:center}}

/* ===================================================================
   LOADER
   =================================================================== */
.loader{position:fixed;inset:0;z-index:10000;overflow:hidden}
.loader__panels{position:absolute;inset:0;display:flex}
.loader__panels span{flex:1;background:var(--bg);transition:transform .9s var(--ease)}
.loader__panels span:nth-child(2){background:#100f0d}
.loader__content{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:var(--pad);text-align:center;transition:opacity .5s var(--ease),transform .6s var(--ease)}
.loader__sub{font-size:.72rem;text-transform:uppercase;letter-spacing:.26em;color:var(--bone-2)}
.loader__sub .star{color:var(--poppy)}
.loader__word{--p:0%;font-family:var(--f-display);text-transform:uppercase;font-size:clamp(3.4rem,15vw,12rem);line-height:.86;letter-spacing:-.01em;color:transparent;-webkit-text-stroke:1px rgba(242,235,221,.45);background:linear-gradient(to top,var(--bone) var(--p),transparent var(--p));-webkit-background-clip:text;background-clip:text}
.loader__foot{display:flex;align-items:center;gap:14px;font-size:.74rem;text-transform:uppercase;letter-spacing:.18em}
.loader__lbl{color:var(--dim)}
.loader__pct{font-family:var(--f-display);font-size:1.15rem;color:var(--poppy);min-width:3.2ch;text-align:right}
.loader--out .loader__content{opacity:0;transform:translateY(-22px)}
.loader--out .loader__panels span{transform:translateY(-100%)}
.loader--out .loader__panels span:nth-child(1){transition-delay:.04s}
.loader--out .loader__panels span:nth-child(2){transition-delay:.13s}
.loader--out .loader__panels span:nth-child(3){transition-delay:.22s}
html.no-js .loader{display:none}
html.js .loader{animation:loaderSafety .6s linear 4.6s forwards}   /* filet de sécurité si JS HS */
@keyframes loaderSafety{to{opacity:0;visibility:hidden}}

/* ===================================================================
   NAV
   =================================================================== */
.nav{position:fixed;top:0;left:0;width:100%;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:16px var(--pad);transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s;border-bottom:1px solid transparent}
.nav.is-scrolled{background:rgba(12,11,10,.94);border-bottom-color:var(--line);padding:10px var(--pad)}
.nav__logo img{height:48px;width:auto;transition:height .5s var(--ease)}
.nav.is-scrolled .nav__logo img{height:40px}
.nav__links{display:flex;gap:30px}
.nav__links a{display:flex;align-items:baseline;gap:6px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--bone-2);transition:color .3s}
.nav__links a i{font-size:.62rem;color:var(--poppy);font-style:normal}
.nav__links a:hover{color:var(--bone)}
.nav__cta{display:inline-flex;align-items:center;gap:.5em;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;padding:.7em 1.3em;border:1px solid var(--line);border-radius:60px;transition:background .4s,color .4s,border-color .4s}
.nav__cta span{color:var(--poppy);transition:transform .4s var(--ease)}
.nav__cta:hover{background:var(--poppy);color:#fff;border-color:var(--poppy)}
.nav__cta:hover span{color:#fff;transform:translate(3px,3px)}
.nav__burger{display:none;background:none;border:0;width:40px;height:40px;flex-direction:column;gap:7px;align-items:center;justify-content:center}
.nav__burger span{width:24px;height:2px;background:var(--bone);transition:transform .4s var(--ease)}
.nav.is-open .nav__burger span:nth-child(1){transform:translateY(4.5px) rotate(45deg)}
.nav.is-open .nav__burger span:nth-child(2){transform:translateY(-4.5px) rotate(-45deg)}

/* ===================================================================
   HERO
   =================================================================== */
.hero{position:relative;z-index:2;height:100svh;min-height:640px;display:flex;flex-direction:column;justify-content:center}
/* scène = hero + galerie ; le bocal (canvas) est collant et descend derrière le texte */
.scene{position:relative;z-index:0}
.scene__bocal{position:sticky;top:0;height:100svh;margin-bottom:-100svh;z-index:1;pointer-events:none}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:0;transition:opacity 1s var(--ease)}
.scene__bocal.webgl-on .hero__canvas{opacity:1}
.hero__grid{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--pad)}
.hero__grid--center{display:flex;flex-direction:column;align-items:center;text-align:center}
.hero__kicker{font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:var(--bone-2);display:flex;align-items:center;gap:10px;margin-bottom:1.4rem}
.hero__word{font-family:"Bagel Fat One","Space Grotesk",sans-serif;font-weight:400;text-transform:uppercase;font-size:clamp(2.6rem,8.5vw,7.5rem);line-height:1;letter-spacing:.01em;color:var(--bone);max-width:7ch}
.hero__word--stack{display:flex;flex-direction:column;line-height:.72;align-items:center}
.hero__word sup{font-size:.16em;vertical-align:super;color:var(--poppy);font-family:var(--f-body)}
.hero__tag{font-family:var(--f-serif);font-style:italic;font-size:clamp(1.4rem,3.4vw,2.6rem);color:var(--poppy);margin-top:.3rem}
.hero__foot{position:absolute;left:0;bottom:clamp(20px,3vw,40px);z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);left:50%;transform:translateX(-50%);display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.hero__loc{display:flex;flex-direction:column;gap:4px;font-size:.82rem;letter-spacing:.04em;color:var(--bone-2)}
.hero__loc i{color:var(--poppy);font-style:normal;padding:0 4px}
.hero__scroll{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.66rem;text-transform:uppercase;letter-spacing:.2em;color:var(--bone-2)}
.hero__scroll b{width:1px;height:42px;background:var(--line);position:relative;overflow:hidden}
.hero__scroll b::after{content:"";position:absolute;top:-42px;left:0;width:100%;height:42px;background:var(--poppy);animation:scrollLine 2.2s var(--ease) infinite}
@keyframes scrollLine{0%{top:-42px}60%,100%{top:42px}}

/* ===================================================================
   MARQUEE
   =================================================================== */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;overflow:hidden;white-space:nowrap;background:var(--bg-2)}
.marquee__track{display:inline-flex;align-items:center;gap:38px;will-change:transform}
.marquee__track span{font-family:var(--f-serif);font-style:italic;font-size:clamp(1.6rem,3.6vw,2.8rem);color:var(--bone)}
.marquee__track b{font-size:1.1rem}

/* ===================================================================
   MANIFESTO
   =================================================================== */
.manifesto{max-width:var(--maxw);margin:0 auto;padding:clamp(80px,12vw,180px) var(--pad)}
.manifesto__text{font-family:var(--f-serif);font-weight:400;font-size:clamp(1.8rem,4.4vw,3.6rem);line-height:1.16;letter-spacing:-.01em;margin-top:1.6rem;max-width:24ch}
.manifesto__row{display:flex;flex-wrap:wrap;gap:24px 70px;align-items:flex-end;justify-content:space-between;margin-top:3rem}
.manifesto__row p{max-width:52ch;color:var(--dim)}

/* ===================================================================
   SALONS
   =================================================================== */
.salons{padding-bottom:clamp(40px,6vw,80px)}
.salon{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(36px,5vw,70px) var(--pad);display:grid;grid-template-columns:0.85fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
.salon--rev{direction:rtl}.salon--rev>*{direction:ltr}
.salon__num{position:absolute;top:-.4rem;left:var(--pad);font-family:var(--f-display);font-size:clamp(2.6rem,6vw,6rem);line-height:1;color:transparent;-webkit-text-stroke:1px var(--line);z-index:0;pointer-events:none}
.salon--rev .salon__num{left:auto;right:var(--pad)}
.salon__media{position:relative;overflow:hidden;aspect-ratio:5/6;z-index:1}
.salon__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.06);transition:transform 1.2s var(--ease),filter .8s}
.salon:hover .salon__media img{transform:scale(1.04);filter:grayscale(0)}
.salon__body{position:relative;z-index:1}
.salon__name{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:clamp(2.6rem,6vw,5rem);line-height:.92}
.salon__place{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--poppy);margin:.4rem 0 1.3rem}
.salon__desc{color:var(--bone-2);max-width:46ch;font-size:1.05rem}
.salon__facts{list-style:none;margin:1.8rem 0;border-top:1px solid var(--line)}
.salon__facts li{display:flex;gap:16px;padding:.8rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
.salon__facts li span{flex:0 0 92px;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--dim);padding-top:.2em}
.salon__facts li i{color:var(--dim);font-style:italic}
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tags b{font-weight:400;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;padding:.5em .95em;border:1px solid var(--line);border-radius:40px;color:var(--bone-2)}
.sec-lead{max-width:48ch;color:var(--bone-2);margin-top:1.2rem;font-size:clamp(1rem,1.4vw,1.15rem)}
.sec-lead b{color:var(--bone);font-weight:600}
.salon__kicker{text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;font-weight:600;color:var(--poppy);margin-bottom:.5rem}
.salon__pin{position:absolute;top:14px;right:14px;z-index:3;background:rgba(12,11,10,.72);border:1px solid var(--line);color:var(--bone);font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;padding:.4em .8em;border-radius:30px}
.salon__book{margin-top:1.9rem}
.salon__book span{display:inline-block;transition:transform .4s var(--ease)}
.salon__book:hover span{transform:translate(3px,3px)}

/* ===================================================================
   ARTISTES
   =================================================================== */
.artists{background:var(--bg-2);padding-bottom:clamp(70px,10vw,140px)}
.artists__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,36px)}
.artist__media{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bg-3)}
.artist__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.07) brightness(.92);transition:filter .7s,transform 1.2s var(--ease)}
.artist:hover .artist__media img{filter:grayscale(0) brightness(1);transform:scale(1.05)}
.artist__idx{position:absolute;top:12px;left:14px;font-family:var(--f-display);font-size:1.2rem;color:var(--bone);mix-blend-mode:difference}
.artist__head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-top:1.1rem;border-top:1px solid var(--line);padding-top:1rem}
.artist__head h3{font-family:var(--f-serif);font-weight:500;font-size:1.32rem;line-height:1.05}
.artist__head span{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--poppy);text-align:right;flex:0 0 auto}
.artist__bio{font-size:.9rem;color:var(--dim);margin:.7rem 0 1rem;line-height:1.55}
.artist--ph .artist__media img{opacity:.5}
.artist--ph .artist__head h3{color:var(--dim)}

/* ===================================================================
   GALERIE (horizontale)
   =================================================================== */
.gallery{padding-bottom:clamp(60px,9vw,120px)}
.gallery__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);columns:3;column-gap:clamp(16px,2vw,30px)}
.plate{position:relative;display:block;break-inside:avoid;margin-bottom:clamp(16px,2vw,30px);overflow:hidden;background:var(--bg-3)}
.plate img{width:100%;height:auto;display:block;filter:grayscale(1) contrast(1.05);transition:transform 1.3s var(--ease),filter .8s}
.plate:hover img{transform:scale(1.04);filter:grayscale(0)}
.plate figcaption{position:absolute;left:0;bottom:0;width:100%;padding:1.4rem;display:flex;justify-content:space-between;align-items:flex-end;gap:10px;background:linear-gradient(transparent,rgba(12,11,10,.82));z-index:2}
.plate figcaption b{font-family:var(--f-serif);font-style:italic;font-weight:500;font-size:1.1rem}
.plate figcaption span{font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;color:var(--bone-2);text-align:right}
.plate--cta{display:flex;flex-direction:column;justify-content:space-between;min-height:300px;padding:1.8rem;background:var(--poppy);color:#fff}
.plate__ig{width:46px;height:46px;color:#fff}
.plate--cta b{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:1.85rem;line-height:.95;margin-top:auto}
.plate__handle{display:inline-flex;align-items:center;gap:8px;margin-top:.9rem;font-size:.84rem;font-weight:500;letter-spacing:.01em}
.plate__handle i{font-style:normal;transition:transform .4s var(--ease)}
.plate--cta:hover .plate__handle i{transform:translate(3px,-3px)}

/* ===================================================================
   MACHINE 3D
   =================================================================== */
.machine{position:relative;min-height:100svh;display:flex;align-items:flex-end;background:radial-gradient(120% 90% at 70% 30%,#1c1815,var(--bg) 70%);overflow:hidden}
#machineCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1;cursor:grab}
#machineCanvas:active{cursor:grabbing}
.machine__fallback{position:absolute;top:40%;left:62%;transform:translate(-50%,-50%);width:42vw;height:42vw;border-radius:50%;z-index:0;background:radial-gradient(circle,rgba(224,57,44,.22),transparent 62%);filter:blur(40px)}
.machine__text{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 var(--pad) clamp(50px,8vw,110px)}
.machine__title{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:clamp(2.6rem,8vw,7rem);line-height:.9;margin:.6rem 0 1.1rem;max-width:14ch}
.machine__sub{color:var(--bone-2);max-width:44ch;font-size:1.05rem}
.machine__hint{margin-top:1.8rem;font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--dim)}

/* ===================================================================
   STYLES
   =================================================================== */
.styles{background:var(--bg-2)}
.styles__showcase{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(60px,8vw,110px);display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,72px);align-items:start}
.styles__list{list-style:none;border-top:1px solid var(--line)}
.styles__list li{display:grid;grid-template-columns:46px 1fr 22px;gap:16px;align-items:center;padding:clamp(15px,2vw,26px) 0;border-bottom:1px solid var(--line);cursor:pointer;opacity:.5;transition:opacity .4s,padding-left .4s var(--ease)}
.styles__list li.is-active,.styles__list li:hover{opacity:1;padding-left:10px}
.styles__list li>span{font-family:var(--f-display);color:var(--poppy);font-size:1.1rem}
.styles__list li h3{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:clamp(1.4rem,2.7vw,2.2rem);line-height:.95}
.styles__list li p{color:var(--dim);font-size:.92rem;margin-top:.3rem;max-width:50ch}
.styles__list li>i{font-style:normal;color:var(--poppy);opacity:0;transform:translateX(-6px);transition:.4s var(--ease)}
.styles__list li.is-active>i{opacity:1;transform:none}
.styles__preview{position:sticky;top:96px}
.styles__frame{overflow:hidden;background:var(--bg-3);aspect-ratio:4/5}
.styles__frame img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:opacity .35s var(--ease),filter .6s}
.styles__preview:hover .styles__frame img{filter:grayscale(0)}
.styles__info{margin-top:1.2rem}
.styles__row{display:flex;justify-content:space-between;gap:14px;padding:.7rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
.styles__row span{text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--dim)}
.styles__row b{font-family:var(--f-serif);font-style:italic;font-weight:500}
.styles__cta{margin-top:1.4rem;width:100%;justify-content:center}

/* ===================================================================
   BOOKING (réservation multi-étapes)
   =================================================================== */
.booking__steps{list-style:none;display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1.2rem}
.bk-step{display:flex;align-items:center;gap:8px;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);padding:.3rem .4rem .3rem .3rem;border-radius:40px}
.bk-step b{display:grid;place-items:center;width:25px;height:25px;border:1px solid var(--line);border-radius:50%;font-family:var(--f-body);font-size:.68rem;color:var(--dim);transition:.3s}
.bk-step.is-current{color:var(--bone)}.bk-step.is-current b{border-color:var(--poppy);color:var(--poppy)}
.bk-step.is-done{color:var(--bone-2);cursor:pointer}.bk-step.is-done b{background:var(--poppy);border-color:var(--poppy);color:#fff}
.bk-step span{display:none}.bk-step.is-current span{display:inline}
@media(min-width:700px){.bk-step span{display:inline}}
.booking__panel{min-height:170px}
.bk-q{font-family:var(--f-serif);font-size:clamp(1.2rem,2vw,1.5rem);margin-bottom:.85rem;line-height:1.2}
.bk-q em{font-style:italic;color:var(--poppy)}
.bk-note{font-size:.8rem;color:var(--dim);margin:-.7rem 0 1.1rem}
.bk-grid{display:grid;gap:14px}.bk-grid--2{grid-template-columns:1fr 1fr}
.bk-card{text-align:left;background:var(--bg-2);border:1px solid var(--line);border-radius:7px;padding:1.1rem 1.2rem;cursor:pointer;color:var(--bone);transition:border-color .3s,background .3s,transform .35s var(--ease)}
.bk-card:hover{transform:translateY(-2px);border-color:var(--bone-2)}
.bk-card.is-sel{border-color:var(--poppy);background:rgba(224,57,44,.08)}
.bk-card b{font-family:var(--f-serif);font-size:1.15rem;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bk-card>span,.bk-card small{display:block;color:var(--dim);font-size:.85rem;margin-top:3px}
.bk-card>i{display:block;font-style:normal;font-size:.7rem;color:var(--poppy);text-transform:uppercase;letter-spacing:.08em;margin-top:6px}
.bk-tag{font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);border:1px solid var(--line);border-radius:30px;padding:.15em .6em;font-weight:400}
.bk-card--artist{display:flex;align-items:center;gap:14px}
.bk-card__img{flex:0 0 54px;width:54px;height:54px;border-radius:50%;overflow:hidden;background:var(--bg-3)}
.bk-card__img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1)}
.bk-card__txt b{font-size:1.08rem}.bk-card__txt small{margin-top:2px}
.bk-chips{display:flex;flex-wrap:wrap;gap:10px}
.bk-chip{background:var(--bg-2);border:1px solid var(--line);border-radius:40px;padding:.6em 1.1em;font-size:.85rem;color:var(--bone-2);cursor:pointer;transition:.3s}
.bk-chip:hover{border-color:var(--bone-2);color:var(--bone)}
.bk-chip.is-sel{background:var(--poppy);border-color:var(--poppy);color:#fff}
.bk-styles{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.bk-style{position:relative;background:var(--bg-2);border:1px solid var(--line);border-radius:7px;overflow:hidden;cursor:pointer;color:var(--bone);transition:border-color .3s,transform .35s var(--ease)}
.bk-style:hover{transform:translateY(-3px);border-color:var(--bone-2)}
.bk-style.is-sel{border-color:var(--poppy);box-shadow:0 0 0 1px var(--poppy)}
.bk-style__img{display:block;aspect-ratio:3/2;overflow:hidden;background:var(--bg-3)}
.bk-style__img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:filter .5s,transform .8s var(--ease)}
.bk-style:hover .bk-style__img img,.bk-style.is-sel .bk-style__img img{filter:grayscale(0)}
.bk-style:hover .bk-style__img img{transform:scale(1.06)}
.bk-style__q{display:grid;place-items:center;aspect-ratio:3/2;font-family:var(--f-display);font-size:1.8rem;color:var(--dim)}
.bk-style b{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:.45rem .5rem;font-size:.72rem;font-weight:500;line-height:1.15;background:linear-gradient(transparent,rgba(12,11,10,.92))}
.bk-style__chk{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:var(--poppy);color:#fff;display:grid;place-items:center;font-size:.78rem;font-style:normal;opacity:0;transform:scale(.5);transition:.3s var(--ease)}
.bk-style.is-sel .bk-style__chk{opacity:1;transform:none}
.bk-slotwrap{animation:bkIn .42s var(--ease);margin-top:1.4rem}
.bk-slotlabel{font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--bone-2);margin-bottom:.8rem}
.bk-hint-day{margin-top:1.2rem;font-size:.85rem;color:var(--dim);font-style:italic}
.bk-field{display:flex;flex-direction:column;gap:.5rem;margin-top:.9rem}
.bk-field label{text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--dim)}
.bk-field input,.bk-field textarea{background:var(--bg-2);border:1px solid var(--line);color:var(--bone);padding:.85rem 1rem;border-radius:4px;font-family:var(--f-body);font-size:1rem;resize:vertical;transition:border-color .3s}
.bk-field input:focus,.bk-field textarea:focus{outline:none;border-color:var(--poppy)}
.bk-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:.4rem}
.bk-fields .bk-field{grid-column:1/-1;margin-top:0}.bk-fields .bk-field--half{grid-column:auto}
.bk-days{display:flex;gap:10px;flex-wrap:wrap}
.bk-day{display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--bg-2);border:1px solid var(--line);border-radius:7px;padding:.65rem .9rem;min-width:62px;cursor:pointer;color:var(--bone-2);transition:.3s}
.bk-day:hover{border-color:var(--bone-2)}
.bk-day.is-sel{background:var(--poppy);border-color:var(--poppy);color:#fff}
.bk-day b{text-transform:uppercase;font-size:.64rem;letter-spacing:.06em}
.bk-day span{font-family:var(--f-display);font-size:1.5rem;line-height:1.05}
.bk-day i{font-style:normal;font-size:.62rem;text-transform:uppercase}
.bk-slots{display:flex;gap:10px;flex-wrap:wrap;margin-top:1.3rem}
.bk-slot{background:var(--bg-2);border:1px solid var(--line);border-radius:40px;padding:.6em 1.1em;font-size:.9rem;color:var(--bone);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.3s}
.bk-slot:hover:not(.is-taken){border-color:var(--poppy)}
.bk-slot.is-sel{background:var(--poppy);border-color:var(--poppy);color:#fff}
.bk-slot.is-taken{opacity:.4;cursor:not-allowed;text-decoration:line-through}
.bk-slot i{font-style:normal;font-size:.58rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);text-decoration:none}
.bk-recap{background:var(--bg-2);border:1px solid var(--line);border-radius:7px;padding:.9rem 1.1rem;margin-bottom:.9rem}
.bk-recap ul{list-style:none;margin-top:.6rem}
.bk-recap li{display:flex;justify-content:space-between;gap:14px;padding:.5rem 0;border-bottom:1px solid var(--line);font-size:.92rem}
.bk-recap li:last-child{border-bottom:0}
.bk-recap li span{text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;color:var(--dim)}
.bk-recap li b{font-family:var(--f-serif);font-style:italic;font-weight:500;text-align:right}
.bk-status{margin-top:1rem;font-size:.9rem;color:var(--poppy-2);min-height:1.2em}
.booking__bar{display:flex;align-items:center;gap:16px;margin-top:1.3rem;border-top:1px solid var(--line);padding-top:1rem}
.booking__back{background:none;border:0;color:var(--bone-2);font-family:var(--f-body);text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;cursor:pointer;transition:color .3s}
.booking__back:hover{color:var(--bone)}
.booking__bar .btn{margin-left:auto}
.btn.is-disabled{opacity:.35;pointer-events:none}
.bk-success{text-align:center;padding:1.5rem 0}
.bk-success__mark{display:grid;place-items:center;width:62px;height:62px;margin:0 auto 1.2rem;border-radius:50%;background:var(--poppy);color:#fff;font-size:1.7rem}
.bk-success h3{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:1.9rem;margin-bottom:.6rem}
.bk-success p{color:var(--bone-2);max-width:42ch;margin:0 auto}
.bk-shake{animation:bkShake .4s}
@keyframes bkShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-7px)}75%{transform:translateX(7px)}}
.bk-anim{animation:bkIn .45s var(--ease)}
@keyframes bkIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ===================================================================
   CONTACT (carte RDV + modale)
   =================================================================== */
.contact__cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px 40px;border-bottom:1px solid var(--line);padding-bottom:clamp(28px,4vw,44px)}
.contact__lead{font-family:var(--f-serif);font-size:clamp(1.15rem,2vw,1.7rem);color:var(--bone-2);max-width:30ch;line-height:1.35}
.contact__cta .btn span{display:inline-block;transition:transform .4s var(--ease)}
.contact__cta .btn:hover span{transform:translate(3px,3px)}

.bk-upload{margin-top:.85rem}
.bk-drop{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px 12px;padding:.8rem 1rem;border:1px dashed var(--line);border-radius:8px;cursor:pointer;color:var(--bone-2);transition:border-color .3s,background .3s}
.bk-drop:hover,.bk-drop.is-drag{border-color:var(--poppy);background:rgba(224,57,44,.06)}
.bk-drop svg{width:24px;height:24px;color:var(--poppy)}
.bk-drop b{font-family:var(--f-serif);font-style:italic;font-weight:500;font-size:.95rem;color:var(--bone)}
.bk-drop small{flex-basis:100%;text-align:center;font-size:.72rem;color:var(--dim)}
.bk-thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.bk-thumb{position:relative;width:74px;height:74px;border-radius:6px;overflow:hidden;border:1px solid var(--line);margin:0}
.bk-thumb img{width:100%;height:100%;object-fit:cover}
.bk-thumb__x{position:absolute;top:3px;right:3px;width:20px;height:20px;border:0;border-radius:50%;background:rgba(12,11,10,.82);color:#fff;font-size:.7rem;cursor:pointer;display:grid;place-items:center;line-height:1;transition:background .3s}
.bk-thumb__x:hover{background:var(--poppy)}

body.modal-open{overflow:hidden}
.modal{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:clamp(14px,4vw,40px);visibility:hidden;pointer-events:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(6,5,5,0);transition:background .5s var(--ease),backdrop-filter .5s var(--ease)}
.modal__dialog{position:relative;z-index:1;width:100%;max-width:700px;max-height:92vh;overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:clamp(18px,2.6vw,30px);opacity:0;transform:translateY(42px) scale(.97);transition:opacity .5s var(--ease),transform .65s var(--ease);scrollbar-width:thin}
.modal.is-open{visibility:visible;pointer-events:auto}
.modal.is-open .modal__backdrop{background:rgba(6,5,5,.8);backdrop-filter:blur(5px)}
.modal.is-open .modal__dialog{opacity:1;transform:none}
.modal__close{position:absolute;top:16px;right:16px;width:42px;height:42px;border:1px solid var(--line);border-radius:50%;background:var(--bg-2);cursor:pointer;display:grid;place-items:center;transition:border-color .3s,transform .4s var(--ease);z-index:2}
.modal__close span{position:absolute;width:16px;height:1.6px;background:var(--bone)}
.modal__close span:first-child{transform:rotate(45deg)}.modal__close span:last-child{transform:rotate(-45deg)}
.modal__close:hover{border-color:var(--poppy);transform:rotate(90deg)}
.modal__head{margin-bottom:1.1rem;padding-right:46px}
.modal__eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:var(--bone-2)}
.modal__eyebrow .star{color:var(--poppy)}
.modal__title{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:clamp(1.5rem,3.2vw,2.2rem);line-height:.95;margin-top:.4rem}
@media(prefers-reduced-motion:reduce){.modal__dialog{transition:none}}

/* ===================================================================
   CTA
   =================================================================== */
.cta{text-align:center;padding:clamp(90px,15vw,200px) var(--pad);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta__small{font-family:var(--f-serif);font-style:italic;font-size:clamp(1.6rem,4vw,2.6rem);color:var(--poppy)}
.cta__big{font-family:var(--f-display);text-transform:uppercase;font-weight:400;font-size:clamp(3rem,13vw,11rem);line-height:.88;margin:.3rem 0 2.2rem}

/* ===================================================================
   CONTACT
   =================================================================== */
.contact__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(70px,9vw,130px);display:flex;flex-direction:column;gap:clamp(34px,5vw,56px)}
.contact__form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:.5rem;grid-column:1/-1}
.field--half{grid-column:auto}
.field label{text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;color:var(--dim)}
.field input,.field select,.field textarea{background:var(--bg-2);border:1px solid var(--line);color:var(--bone);padding:.9rem 1rem;border-radius:3px;font-family:var(--f-body);font-size:1rem;transition:border-color .3s;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--poppy)}
.field input::placeholder,.field textarea::placeholder{color:#5a5347}
.contact__form .btn{grid-column:1/-1;justify-self:start;margin-top:.4rem}
.contact__status{grid-column:1/-1;font-size:.9rem;color:var(--poppy-2);min-height:1.2em}
.contact__info{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px);align-items:start}
.cblock{border-top:1px solid var(--line);padding-top:1rem;display:flex;flex-direction:column;gap:.6rem}
.cblock>span{text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:var(--poppy)}
.cblock p{color:var(--bone-2);font-size:.95rem;line-height:1.6}
.cblock a{border-bottom:1px solid var(--line);width:fit-content}
.cblock__soc{display:flex;flex-direction:column;gap:.45rem}
.contact__map{grid-column:1/-1;margin-top:.6rem;border:1px solid var(--line);overflow:hidden;height:clamp(220px,30vw,340px)}
.contact__map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(1) invert(.92) contrast(.9) hue-rotate(180deg)}

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{padding:clamp(36px,5vw,56px) var(--pad) 30px;max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.footer__bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px 30px;padding-bottom:clamp(20px,3vw,30px)}
.footer__brand img{height:40px;width:auto;display:block}
.footer__links{display:flex;flex-wrap:wrap;gap:22px}
.footer__links a{text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--bone-2);transition:color .3s}
.footer__links a:hover{color:var(--poppy)}
.footer__soc{display:flex;flex-wrap:wrap;gap:16px}
.footer__soc a{font-size:.82rem;color:var(--bone-2);transition:color .3s}
.footer__soc a:hover{color:var(--poppy)}
.footer__row{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:.78rem;color:var(--dim);border-top:1px solid var(--line);padding-top:22px}
.footer__row a{color:var(--poppy)}

/* ===================================================================
   REVEALS / SPLIT
   =================================================================== */
html.js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
html.js [data-reveal].in{opacity:1;transform:none}
.line{display:block;overflow:hidden}
.word{display:inline-block;overflow:hidden;vertical-align:top}
.word__in{display:inline-block;transform:translateY(110%);transition:transform .9s var(--ease)}
.in .word__in,.word.in .word__in{transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html.js [data-reveal]{opacity:1;transform:none}.word__in{transform:none}
  .loader{display:none}
}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(max-width:1024px){
  .artists__grid{grid-template-columns:repeat(2,1fr);gap:34px 22px}
  .gallery__grid{columns:2}
  .footer__cols{grid-template-columns:repeat(3,1fr);row-gap:34px}
}
@media(max-width:860px){
  .nav__links{position:fixed;inset:0;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;gap:26px;transform:translateY(-100%);transition:transform .6s var(--ease);z-index:-1}
  .nav.is-open .nav__links{transform:translateY(0);z-index:150}
  .nav__links a{font-size:1.5rem}.nav__cta{display:none}.nav__burger{display:flex;z-index:200}
  .hero__foot{position:static;transform:none;margin-top:2rem;padding-bottom:30px}
  .hero{justify-content:flex-end;padding-bottom:20px}
  .salon{grid-template-columns:1fr;gap:24px}.salon--rev{direction:ltr}
  .salon__media{aspect-ratio:4/3}
  .machine{align-items:flex-end}.machine__title{max-width:none}
  .contact__grid{grid-template-columns:1fr}
  .styles__showcase{grid-template-columns:1fr;gap:26px}
  .styles__preview{position:static;order:-1}
  .styles__frame{aspect-ratio:16/10}
  .styles__list li{opacity:1}
  .contact__info{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .artists__grid{grid-template-columns:1fr;max-width:400px}
  .gallery__grid{columns:1;max-width:440px;margin:0 auto}
  .contact__form{grid-template-columns:1fr}.field--half{grid-column:1/-1}
  .bk-grid--2{grid-template-columns:1fr}
  .bk-fields{grid-template-columns:1fr}.bk-fields .bk-field--half{grid-column:1/-1}
  .footer__cols{grid-template-columns:repeat(2,1fr)}
  .contact__info{grid-template-columns:repeat(2,1fr)}
  .bk-styles{grid-template-columns:repeat(3,1fr)}
  .hero__foot{flex-direction:column;align-items:flex-start;gap:18px}.hero__scroll{display:none}
}

/* ===================================================================
   SORTIES DU BOCAL — galerie en éventail
   =================================================================== */
.spill{position:relative;z-index:2;padding:clamp(70px,10vw,150px) var(--pad) clamp(80px,9vw,140px);text-align:center}
.spill__head{max-width:920px;margin:0 auto clamp(38px,5vw,72px)}
.spill__title{font-family:var(--f-serif);font-weight:400;font-size:clamp(2rem,5vw,4rem);line-height:1.06;margin-top:.35em}
.spill__fan{position:relative;height:clamp(300px,42vw,470px);max-width:1120px;margin:0 auto}
.spill__card{position:absolute;left:50%;top:50%;width:clamp(150px,19vw,250px);aspect-ratio:3/4;margin:0;background:var(--bone);padding:10px 10px 34px;border-radius:3px;box-shadow:0 26px 54px -18px rgba(0,0,0,.66);
  transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y) + 70px)) rotate(var(--r)) scale(.92);opacity:0;
  transition:transform 1.1s var(--ease),opacity .8s var(--ease),filter .4s}
.spill__card img{width:100%;height:100%;object-fit:cover;border-radius:2px;filter:grayscale(1) contrast(1.05);transition:filter .5s var(--ease)}
.spill__fan.in .spill__card{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--r)) scale(1);opacity:1}
.spill__fan .spill__card:nth-child(1){transition-delay:.02s}
.spill__fan .spill__card:nth-child(2){transition-delay:.10s}
.spill__fan .spill__card:nth-child(3){transition-delay:.18s}
.spill__fan .spill__card:nth-child(4){transition-delay:.26s}
.spill__fan .spill__card:nth-child(5){transition-delay:.34s}
.spill__fan .spill__card:nth-child(6){transition-delay:.42s}
.spill__fan.in .spill__card:hover{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y) - 20px)) rotate(0deg) scale(1.05);z-index:6;box-shadow:0 34px 64px -16px rgba(0,0,0,.7)}
.spill__card:hover img{filter:none}
.spill__cta{margin-top:clamp(34px,5vw,64px)}
/* desktop avec bocal 3D : les photos sortent du bocal (canvas), on masque la galerie DOM
   et on donne de la hauteur de scroll pour dérouler la sortie des photos */
.has-bocal3d .spill{min-height:155vh;display:flex;flex-direction:column;justify-content:space-between}
.has-bocal3d .spill__fan{display:none}
@media(max-width:760px){
  .spill__fan{height:auto;display:flex;flex-wrap:wrap;justify-content:center;gap:14px;max-width:520px}
  .spill__card{position:static;left:auto;top:auto;width:44%;transform:translateY(40px) rotate(0deg) scale(1)}
  .spill__fan.in .spill__card{transform:translateY(0) rotate(0deg) scale(1)}
  .spill__fan.in .spill__card:hover{transform:translateY(0) rotate(0deg) scale(1.03)}
}
