/* ----- Reset & base ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-weight:300;
  color:#111;
  background:#fafafa;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.section-title,.hero__title,.card__title{
  font-family:'Manrope',system-ui,sans-serif;
  font-feature-settings:"ss01","ss02";
}
img,picture,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit}
ul{list-style:none}

:root{
  --bg:#fafafa;
  --bg-alt:#f4f4f2;
  --bg-dark:#141414;
  --ink:#111;
  --ink-soft:#6b6b6b;
  --line:#e5e3df;
  --accent:#1f4d3a;
  --accent-soft:#2d6649;
  --max:1320px;
  --pad:clamp(20px,4vw,48px);
}

.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.container--narrow{max-width:980px}

/* ----- Typography ----- */
.section-title{
  font-weight:300;
  font-size:clamp(2rem,4vw,3.2rem);
  letter-spacing:-.025em;
  line-height:1.05;
}
.section-head{margin:0 0 56px}
.section-head--center{text-align:center}
.section-rule{width:64px;height:2px;background:var(--accent);margin-top:18px}
.section-head--center .section-rule{margin:18px auto 0}
.section-rule--light{background:var(--accent);opacity:1}
.section-head--light .section-title{color:var(--ink)}

/* ----- Buttons ----- */
.btn{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:14px 28px;
  border:1px solid currentColor;
  transition:all .25s ease;
  cursor:pointer;
}
.btn--outline{color:var(--ink);background:transparent}
.btn--outline:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn--solid{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn--solid:hover{background:var(--ink);border-color:var(--ink)}
.btn--ghost{color:#fff;background:var(--accent);border-color:var(--accent);font-size:.7rem;padding:11px 22px}
.btn--ghost:hover{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn--light{
  color:var(--ink);
  background:rgba(255,255,255,.35);
  border-color:rgba(255,255,255,.55);
  -webkit-backdrop-filter:blur(14px) saturate(180%);
          backdrop-filter:blur(14px) saturate(180%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55), 0 8px 24px rgba(20,30,40,.08);
}
.btn--light:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ----- Nav ----- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.78);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
          backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(255,255,255,.4);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 4px 14px rgba(20,30,40,.05);
  transition:background .3s ease, padding .3s ease;
  padding:6px 0;
  will-change:background, padding;
}
.nav.is-scrolled{background:rgba(255,255,255,.88);padding:3px 0;border-bottom-color:rgba(0,0,0,.06)}
.nav__inner{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav__logo{display:inline-flex;align-items:center}
.nav__logo img{height:46px;width:auto;display:block;transition:height .3s ease}
.nav.is-scrolled .nav__logo img{height:32px}
.nav__links{display:flex;align-items:center;gap:38px;transition:gap .3s ease}
.nav.is-scrolled .nav__links{gap:30px}
.nav__links a{
  font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:400;
  position:relative;transition:opacity .2s, font-size .3s ease;
}
.nav.is-scrolled .nav__links a{font-size:.74rem}
.nav__links a:hover{color:var(--accent)}
.nav__links a{position:relative;padding-bottom:4px}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--accent);
  transform:scaleX(0);transform-origin:left center;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.nav__links a.is-active::after,
.nav__links a:hover::after{transform:scaleX(1)}
.nav__links a.is-active{color:var(--accent)}
.nav__lang{
  padding:4px;border:1px solid rgba(0,0,0,.08);border-radius:999px;
  display:inline-flex;gap:2px;align-items:center;background:rgba(255,255,255,.4);
}
.nav__lang span{
  width:28px;height:20px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;overflow:hidden;
  opacity:.35;transition:opacity .2s, transform .2s, width .3s ease, height .3s ease;
}
.nav.is-scrolled .nav__lang span{width:22px;height:16px}
.nav__lang span svg{width:100%;height:100%;display:block;border-radius:2px}
.nav__lang span.active{opacity:1;transform:scale(1.08)}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:24px;height:1px;background:var(--ink);transition:transform .2s}

/* ----- Ticker mobile ----- */
.ticker{
  display:none;
  position:fixed;top:62px;left:0;right:0;z-index:98;
  height:28px;
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
          backdrop-filter:blur(10px) saturate(140%);
  border-bottom:1px solid rgba(0,0,0,.06);
  overflow:hidden;
  pointer-events:none;
  opacity:1;
  transition:opacity .5s ease;
}
.ticker.is-hidden{opacity:0}
.ticker__track{
  display:flex;align-items:center;
  white-space:nowrap;
  height:100%;
  animation:tickerScroll 14s linear infinite;
  will-change:transform;
}
.ticker__track span{
  font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink);opacity:.7;
  padding:0 18px;
}
.ticker__track .ticker__sep{opacity:.3;padding:0 4px}
@keyframes tickerScroll{
  from{transform:translateX(0)}
  to  {transform:translateX(-50%)}
}
@media(max-width:768px){
  .ticker{display:flex}
}

/* ----- Hero ----- */
.hero{
  position:relative;
  min-height:100vh;
  width:100%;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{position:absolute;inset:0;z-index:-2;display:block}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center right}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 38%,rgba(255,255,255,.55) 62%,rgba(255,255,255,.25) 82%,rgba(255,255,255,.1) 100%);
}
.hero__overlay{
  position:relative;z-index:1;
  max-width:var(--max);margin:0 auto;
  padding:160px var(--pad) 100px;
  display:flex;align-items:center;min-height:100vh;
}
.hero__content{max-width:560px}
.hero__eyebrow{
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink);opacity:.85;margin-bottom:6px;
}
.hero__eyebrow .w{
  display:inline-block;opacity:0;transform:translateY(6px);
  animation:wordIn .55s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay:calc(var(--i,0) * 140ms + 200ms);
}
@keyframes wordIn{to{opacity:1;transform:translateY(0)}}
.hero__title{
  font-family:'Open Sauce One','Manrope',system-ui,sans-serif;
  font-weight:600;
  font-size:clamp(1.7rem,3.6vw,3rem);
  line-height:1.05;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:32px;
  color:var(--ink);
  white-space:nowrap;
}
.hero__title span{display:inline}
.hero__tagline{
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink);opacity:.85;
  margin-bottom:48px;
  min-height:1.5em;
  overflow:hidden;
}
@media (min-width:769px){
  .hero__tagline{
    font-size:clamp(.9rem,1.4vw,1.1rem);
    letter-spacing:.38em;
    min-height:2em;
  }
}
.hero__tagline-word{
  display:inline-block;
  animation:taglineIn .5s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero__tagline-word.is-out{
  animation:taglineOut .35s cubic-bezier(.4,0,1,1) forwards;
}
@keyframes taglineIn{
  from{opacity:0;transform:translateY(10px)}
  to  {opacity:1;transform:translateY(0)}
}
@keyframes taglineOut{
  from{opacity:1;transform:translateY(0)}
  to  {opacity:0;transform:translateY(-10px)}
}

/* Scroll-down indicator */
.hero__scroll{
  position:absolute;left:50%;bottom:28px;transform:translateX(-50%);
  z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--ink);opacity:.75;
  font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;font-weight:500;
  transition:opacity .25s,color .25s;
  cursor:pointer;
}
.hero__scroll:hover{opacity:1;color:var(--accent)}
.hero__scroll svg{width:18px;height:24px;animation:scrollBob 1.8s ease-in-out infinite}
.hero__scroll svg path{stroke:currentColor;stroke-width:1.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
@keyframes scrollBob{
  0%,100%{transform:translateY(0);opacity:.65}
  50%    {transform:translateY(6px);opacity:1}
}
@media (prefers-reduced-motion:reduce){
  .hero__scroll svg{animation:none}
}

/* ----- Sections shared ----- */
section{scroll-margin-top:60px}
.prestations{padding:120px 0;background:linear-gradient(180deg,#fff 0%,#f6f6f4 100%);border-top:1px solid var(--line)}
.galerie{padding:120px 0;background:#fff}
.signature{
  padding:120px 0;
  background:
    radial-gradient(1200px 400px at 50% -10%, rgba(31,77,58,.07), transparent 60%),
    linear-gradient(180deg,#f4f4f2 0%, #ececea 100%);
  color:var(--ink);
  border-top:1px solid var(--line);
}
.contact{padding:120px 0;background:#fff;border-top:1px solid var(--line)}

/* ----- Prestations cards (editorial premium) ----- */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:48px;counter-reset:card}
.card{
  counter-increment:card;
  position:relative;
  background:#fff;
  color:var(--ink);
  padding:64px 52px 56px;
  display:flex;flex-direction:column;align-items:flex-start;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease;
  border:1px solid rgba(20,30,40,.06);
  box-shadow:0 1px 0 rgba(20,30,40,.02);
}
.card::before{
  content:"0" counter(card);
  position:absolute;top:30px;right:36px;
  font-family:'Open Sauce One','Manrope',sans-serif;
  font-size:.78rem;font-weight:500;letter-spacing:.2em;
  color:var(--accent);opacity:.85;
}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(20,30,40,.1)}
.card__icon{width:36px;height:36px;color:var(--accent);margin-bottom:36px;opacity:.9}
.card__icon svg{width:100%;height:100%;stroke-width:1}
.card__title{
  font-family:'Manrope',sans-serif;
  font-weight:300;
  font-size:1.7rem;letter-spacing:-.02em;line-height:1.1;
  margin-bottom:18px;
}
.card__sub{display:none}
.card__list{
  list-style:none;padding:0;margin:0 0 32px;
  display:flex;flex-direction:column;gap:8px;
  width:100%;
}
.card__list li{
  font-size:.86rem;color:var(--ink);
  padding:10px 0;border-top:1px solid rgba(20,30,40,.08);
  display:flex;justify-content:space-between;align-items:center;
  letter-spacing:.01em;
}
.card__list li::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--accent);opacity:.55;flex-shrink:0;margin-right:14px;
}
.card__list li span{flex:1}
.card__body{font-size:.92rem;line-height:1.75;color:var(--ink-soft);margin-bottom:36px}
.card .btn--ghost{
  color:var(--accent);background:transparent;border:0;
  padding:0;font-size:.72rem;letter-spacing:.22em;
  border-bottom:1px solid var(--accent);border-radius:0;
  padding-bottom:4px;
  transition:gap .2s,opacity .2s;
  display:inline-flex;align-items:center;gap:8px;
}
.card .btn--ghost::after{content:"→";transition:transform .25s ease;font-size:.85rem}
.card .btn--ghost:hover{background:transparent;color:var(--accent);border-color:var(--accent);opacity:.75}
.card .btn--ghost:hover::after{transform:translateX(4px)}

/* ----- Gallery marquee (JS scroll) ----- */
.gallery-marquee{
  position:relative;
  overflow:hidden;
  width:100vw;
  margin-left:calc(50% - 50vw);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);
  cursor:grab;
  touch-action:pan-y;
  contain:layout paint style;
}
.galerie{content-visibility:auto;contain-intrinsic-size:auto 600px}
.gallery-marquee.is-dragging{cursor:grabbing;user-select:none}
.gallery-marquee.is-dragging .tile{pointer-events:none}
.gallery-track{
  display:flex;
  gap:32px;
  width:max-content;
  padding:0 4vw;
  will-change:transform;
  transform:translate3d(0,0,0);
  backface-visibility:hidden;
}
.tile{
  position:relative;
  flex:0 0 auto;
  width:clamp(200px,18vw,290px);
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--bg-alt);
  cursor:pointer;
  opacity:0;
  transform:translateY(28px);
  transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--i, 0) * 80ms);
}
.gallery-marquee.tiles-visible .tile{
  opacity:1;
  transform:translateY(0);
}
.tile picture{display:block;width:100%;height:100%;pointer-events:none}
.tile img,.tile video{width:100%;height:100%;object-fit:cover;transition:transform .8s ease,filter .4s ease;display:block;-webkit-user-drag:none;user-select:none}
.tile video{pointer-events:none}
.tile:hover img{transform:scale(1.04);filter:brightness(.82)}
.tile__label{
  position:absolute;left:22px;bottom:20px;color:#fff;
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
  font-weight:500;
}
.tile__count{
  position:absolute;right:22px;bottom:20px;color:#fff;
  font-size:.7rem;letter-spacing:.1em;opacity:.85;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
}

/* ----- Signature ----- */
.bio{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;max-width:780px;margin:0 auto}
.bio__photo{
  width:140px;height:140px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:#ddd;
  box-shadow:0 10px 30px rgba(20,30,40,.12);
  border:3px solid rgba(255,255,255,.9);
}
.bio__photo img{width:100%;height:100%;object-fit:cover}
.bio__text p{color:var(--ink);font-size:1rem;line-height:1.85}
.bio__text p+p{margin-top:18px}
.bio__text strong{color:var(--accent);font-weight:500}
.link-more{
  margin-top:24px;
  font-style:italic;font-size:.95rem;color:var(--accent);
  border-bottom:1px solid var(--accent);padding-bottom:2px;
  transition:color .2s,border-color .2s,opacity .2s;
}
.link-more:hover{opacity:.7}

/* ----- Contact ----- */
.contact__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
.contact__lead{font-size:1.05rem;color:var(--ink-soft);margin-bottom:32px;line-height:1.7}
.contact__list li{margin-bottom:18px;display:flex;flex-direction:column;gap:4px}
.contact__list span{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-soft)}
.contact__list a{font-size:1.02rem;color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:2px;transition:color .2s,border-color .2s;align-self:flex-start}
.contact__list a:hover{color:var(--accent);border-color:var(--accent)}

.contact__form{display:flex;flex-direction:column;gap:22px}
.contact__form .field{display:flex;flex-direction:column;gap:10px}
.contact__form .field[hidden]{display:none}
.contact__form .field > span{
  font-size:.78rem;font-weight:500;letter-spacing:.04em;color:var(--ink);
  display:inline-flex;align-items:center;gap:6px;
}
.contact__form .field > span > span{display:inline}
.contact__form .req{color:var(--accent);font-style:normal;font-size:.85em;font-weight:500}
.contact__form input,
.contact__form textarea,
.contact__form select{
  font:inherit;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:8px;
  padding:14px 16px;transition:border-color .2s,box-shadow .2s;
  font-size:.95rem;
  width:100%;
}
.contact__form input::placeholder,
.contact__form textarea::placeholder{color:#a8a8a4}
.contact__form input:focus,
.contact__form textarea:focus,
.contact__form select:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(31,77,58,.08);
}
.contact__form select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23111' stroke-width='1.3' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;background-size:12px;
  padding-right:42px;
  color:var(--ink-soft);
}
.contact__form select:valid{color:var(--ink)}
.contact__form textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field--company{animation:fadeSlide .3s ease both}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* Info tooltip */
.info{
  width:18px;height:18px;border-radius:50%;
  background:var(--accent);color:#fff;
  font-style:italic;font-size:.7rem;font-weight:600;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:help;position:relative;
}
.info:hover::after,.info:focus::after{
  content:attr(data-tip);
  position:absolute;left:50%;bottom:calc(100% + 8px);transform:translateX(-50%);
  background:var(--ink);color:#fff;
  padding:8px 12px;border-radius:6px;
  font-size:.72rem;font-style:normal;font-weight:400;letter-spacing:.02em;
  white-space:nowrap;z-index:5;
  box-shadow:0 8px 24px rgba(0,0,0,.18);
}
/* Field error state */
.contact__form .field.has-error input,
.contact__form .field.has-error textarea,
.contact__form .field.has-error select{
  border-color:#c0392b;
  box-shadow:0 0 0 4px rgba(192,57,43,.07);
}
.field__error{
  font-size:.75rem;color:#c0392b;letter-spacing:.02em;margin-top:-4px;
}

/* Global submission error */
.form__global-error{
  font-size:.88rem;color:#c0392b;
  padding:14px 18px;
  background:rgba(192,57,43,.06);
  border:1px solid rgba(192,57,43,.2);
  border-radius:6px;
}

/* Success state */
.form__success{
  display:flex;flex-direction:column;align-items:flex-start;gap:16px;
  padding:48px 40px;
  background:linear-gradient(135deg,rgba(31,77,58,.04) 0%,rgba(31,77,58,.08) 100%);
  border:1px solid rgba(31,77,58,.15);
  border-radius:4px;
  animation:fadeSlide .4s cubic-bezier(.2,.7,.2,1) both;
}
.form__success svg{
  width:44px;height:44px;color:var(--accent);flex-shrink:0;
}
.form__success h4{
  font-family:'Manrope',sans-serif;font-weight:300;
  font-size:1.5rem;letter-spacing:-.02em;color:var(--ink);
}
.form__success p{font-size:.95rem;line-height:1.75;color:var(--ink-soft)}

.contact__form .btn{align-self:flex-start;margin-top:8px}

@media (max-width:560px){
  .field-row{grid-template-columns:1fr}
}

/* ----- Instagram feed ----- */
.instagram{
  padding:120px 0;
  background:linear-gradient(180deg,#fff 0%,#f6f6f4 100%);
  border-top:1px solid var(--line);
}
.instagram .section-head{margin-bottom:12px}
.instagram__handle{
  margin-top:14px;
  font-size:.88rem;letter-spacing:.08em;
}
.instagram__handle a{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--ink-soft);transition:color .2s;
}
.instagram__handle a:hover{color:var(--accent)}
.instagram__icon{width:17px;height:17px;flex-shrink:0}
.instagram .section-rule--center{margin:18px auto 0}

.instagram__feed{
  margin-top:52px;
  /* Override widget default styles for coherence */
  --behold-font-family: 'Inter', system-ui, sans-serif;
}
/* Behold widget full-width override */
.instagram__feed > div[id^="behold"]{width:100%!important}

/* Placeholder shown until Behold is configured */
.instagram__placeholder{
  display:flex;align-items:center;justify-content:center;
  min-height:260px;
  border:1px dashed var(--line);
  border-radius:4px;
  background:var(--bg-alt);
}
.instagram__placeholder-link{
  display:inline-flex;flex-direction:column;align-items:center;gap:16px;
  color:var(--ink-soft);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  transition:color .2s;
}
.instagram__placeholder-link svg{width:36px;height:36px;opacity:.5}
.instagram__placeholder-link:hover{color:var(--accent)}
.instagram__placeholder-link:hover svg{opacity:.85}

@media (max-width:768px){
  .instagram{padding:80px 0}
}

/* ----- Footer ----- */
.footer{padding:20px 0;background:var(--bg-alt);color:var(--ink-soft);font-size:.82rem;border-top:1px solid var(--line)}
.footer__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer__right{display:inline-flex;align-items:center;gap:20px}
.footer a{display:inline-flex;align-items:center;transition:color .2s,opacity .2s}
.footer a:hover{color:var(--accent);opacity:.85}
.footer__insta{width:22px;height:22px;color:var(--ink-soft)}
.footer__insta svg{width:100%;height:100%}
.footer__legal-btn{
  font-size:.78rem;letter-spacing:.06em;color:var(--ink-soft);
  border-bottom:1px solid transparent;padding-bottom:1px;
  transition:color .2s,border-color .2s;
}
.footer__legal-btn:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* ----- Modal (Signature) ----- */
.modal{
  position:fixed;inset:0;z-index:200;
  display:none;align-items:center;justify-content:center;
  padding:24px;
}
.modal.is-open{display:flex;animation:modalFade .25s ease both}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal__backdrop{
  position:absolute;inset:0;
  background:rgba(20,20,20,.55);
  -webkit-backdrop-filter:blur(8px) saturate(160%);
          backdrop-filter:blur(8px) saturate(160%);
}
.modal__panel{
  position:relative;
  width:100%;max-width:640px;max-height:88vh;overflow:auto;
  background:#fff;color:var(--ink);
  padding:clamp(32px,5vw,56px);
  box-shadow:0 30px 80px rgba(0,0,0,.25);
  border-radius:4px;
  animation:modalSlide .35s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes modalSlide{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal__close{
  position:absolute;top:14px;right:18px;
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;font-weight:200;line-height:1;color:var(--ink);
  border-radius:50%;transition:background .2s,color .2s;
}
.modal__close:hover{background:var(--accent);color:#fff}
.modal__title{
  font-family:'Manrope',sans-serif;font-weight:300;
  font-size:clamp(1.7rem,3.2vw,2.4rem);letter-spacing:-.025em;line-height:1;
}
.modal__rule{width:48px;height:2px;background:var(--accent);margin:14px 0 28px}
.modal__body{font-size:1rem;line-height:1.85;color:var(--ink)}
.modal__body p{margin:0 0 16px}
.modal__body p:last-child{margin-bottom:0}
.modal__body a{color:var(--accent);border-bottom:1px solid rgba(31,77,58,.3);padding-bottom:1px;transition:border-color .2s}
.modal__body a:hover{border-bottom-color:var(--accent)}

/* ----- Lightbox ----- */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(255,255,255,.38);
  -webkit-backdrop-filter:blur(32px) saturate(180%) brightness(1.06);
          backdrop-filter:blur(32px) saturate(180%) brightness(1.06);
  display:none;align-items:center;justify-content:center;
  padding:80px 24px;
  opacity:0;transition:opacity .3s ease;
}
.lightbox.is-open{display:flex}
.lightbox.is-open.is-ready{opacity:1}
.lightbox__stage{
  max-width:100%;max-height:100%;
  display:flex;align-items:center;justify-content:center;
  will-change:transform,opacity;
}
.lightbox__stage img,.lightbox__stage video{
  max-width:90vw;max-height:80vh;object-fit:contain;
  box-shadow:0 24px 64px rgba(20,30,40,.13);
  display:block;
}
.lightbox__close{
  position:absolute;top:24px;right:32px;color:var(--ink);
  font-size:2.4rem;line-height:1;font-weight:200;padding:8px 14px;
  transition:opacity .2s;z-index:1;
}
.lightbox__close:hover{opacity:.4}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  color:var(--ink);font-size:3.2rem;line-height:1;font-weight:200;
  padding:12px 22px;transition:opacity .2s;z-index:1;
}
.lightbox__nav:hover{opacity:.4}
.lightbox__nav--prev{left:16px}
.lightbox__nav--next{right:16px}
.lightbox__caption{
  position:absolute;bottom:32px;left:0;right:0;text-align:center;
  color:var(--ink-soft);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;
}

/* ----- Responsive ----- */
@media (max-width:1024px){
  .hero__overlay{padding-top:120px;padding-bottom:80px}
  .contact__grid{grid-template-columns:1fr;gap:48px}
}
@media (max-width:768px){
  .hero{
    min-height:100vh;
    min-height:100svh;
  }
  .hero::after{background:rgba(255,255,255,.78)}
  .hero__bg img{object-position:60% center;filter:blur(.8px);transform:scale(1.02)}
  .hero__overlay{
    justify-content:center;
    align-items:center;
    text-align:center;
    min-height:100vh;
    min-height:100svh;
    padding:96px 24px 80px;
  }
  .hero__content{margin:0 auto;max-width:520px}
  .hero__title{
    font-size:clamp(1.5rem,6.5vw,2.2rem);
    letter-spacing:.16em;
  }
  .hero__eyebrow{
    font-size:.68rem;
    letter-spacing:.22em;
    margin-bottom:10px;
  }
  .hero__tagline{display:none} /* remplacé par le ticker sur mobile */
}
@media (max-width:768px){
  /* Header fixe — pas de rétrécissement au scroll sur mobile/tablette */
  .nav{padding:12px 0}
  .nav.is-scrolled{padding:12px 0;background:rgba(255,255,255,.78);border-bottom-color:rgba(255,255,255,.4)}
  .nav__logo img{height:38px}
  .nav.is-scrolled .nav__logo img{height:38px}
  .nav.is-scrolled .nav__links a{font-size:.82rem}
  .nav.is-scrolled .nav__links{gap:38px}
  .nav.is-scrolled .nav__lang span{width:28px;height:20px}

  .nav__inner{position:relative;justify-content:space-between}
  .nav__logo{
    position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  }
  .nav__links{
    position:fixed;top:0;right:-100%;width:78%;max-width:340px;height:100vh;
    background:#fff;flex-direction:column;justify-content:center;
    gap:32px;padding:48px;
    transition:right .3s ease;box-shadow:-20px 0 60px rgba(0,0,0,.1);
  }
  .nav__links.is-open{right:0}
  .nav__burger{display:flex;z-index:101;margin-left:auto}
  .nav__burger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav__burger.is-open span:nth-child(2){opacity:0}
  .nav__burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  .cards{grid-template-columns:1fr;gap:20px}
  .card{padding:40px 28px}
  .tile{width:56vw}
  .gallery-track{gap:20px}
  .bio{grid-template-columns:1fr;text-align:center;gap:24px}
  .bio__photo{margin:0 auto}
  .prestations,.galerie,.signature,.contact{padding:80px 0}
  .section-head{margin-bottom:40px}
  .footer__inner{justify-content:center;text-align:center}
}
