/* ============================================================
   Direction 2 — COUTURE
   Editorial haute-couture. Bodoni Moda + Outfit.
   High-contrast type, ghost numerals, overlap, sharp rules.
   ============================================================ */
body{font-family:"Outfit",system-ui,sans-serif;font-weight:300;line-height:1.7;
  color:var(--ink);font-size:17px;letter-spacing:.005em}
h1,h2,h3,.disp{font-family:"Bodoni Moda","Didot",Georgia,serif;font-weight:500;
  line-height:1;letter-spacing:-.01em}
.wrap{width:min(1280px,92vw);margin-inline:auto}
.section{padding:140px 0;position:relative}
.kick{font-family:"Outfit",sans-serif;font-weight:500;font-size:11px;letter-spacing:.42em;
  text-transform:uppercase;color:var(--blush-deep);display:inline-flex;align-items:center;gap:14px}
.kick::before{content:"";width:42px;height:1px;background:var(--blush-deep)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:14px;cursor:pointer;border:0;
  font-family:"Outfit",sans-serif;font-weight:500;font-size:12px;letter-spacing:.2em;
  text-transform:uppercase;padding:19px 36px;background:var(--ink);color:var(--cream);
  border-radius:0;transition:transform .4s var(--ease),background .4s,letter-spacing .4s}
.btn:hover{background:var(--blush-deep);letter-spacing:.26em}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(6px)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1px var(--ink);padding:16px 30px}
.btn-ghost:hover{background:var(--ink);color:var(--cream);box-shadow:inset 0 0 0 1px var(--ink)}

/* ---------- nav (centered editorial) ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.5s;padding:22px 0;
  border-bottom:1px solid transparent}
.nav.scrolled{background:color-mix(in srgb,var(--cream) 85%,transparent);backdrop-filter:blur(20px) saturate(150%);
  border-color:var(--line);padding:14px 0}
.nav .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.nav-l,.nav-r{display:flex;align-items:center;gap:34px;font-family:"Outfit",sans-serif;
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:400}
.nav-r{justify-content:flex-end}
.nav-l a,.nav-r a{color:var(--ink-soft);position:relative;transition:color .3s}
.nav-l a:hover,.nav-r a:hover{color:var(--ink)}
.nav-l a::after,.nav-r a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;
  background:var(--blush-deep);transition:width .35s var(--ease)}
.nav-l a:hover::after,.nav-r a:hover::after{width:100%}
.brand{font-family:"Bodoni Moda",serif;font-weight:500;font-size:25px;letter-spacing:.02em;
  text-align:center;white-space:nowrap}
.brand sup{font-family:"Outfit",sans-serif;font-size:8px;letter-spacing:.3em;
  vertical-align:super;color:var(--muted);margin-left:4px;text-transform:uppercase}
.burger{display:none;flex-direction:column;gap:5px;background:0;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:1.5px;background:var(--ink);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ---------- hero (monumental woven masthead) ---------- */
.hero{position:relative;min-height:100svh;overflow:hidden;
  background:linear-gradient(150deg,var(--hero-a) 0%,var(--hero-b) 52%,var(--hero-c) 100%)}
.hero-inner{position:relative;z-index:2;width:min(1360px,94vw);min-height:100svh;margin:0 auto;
  display:flex;flex-direction:column;justify-content:center}
.hero-kicker{position:absolute;top:130px;right:0;margin:0;text-align:right;z-index:5;
  font-family:"Outfit",sans-serif;font-size:12px;font-weight:500;letter-spacing:.26em;
  text-transform:uppercase;color:var(--blush-deep);line-height:2.1;
  animation:rise 1s var(--ease) .35s backwards}
.hero-type{position:relative;margin:0;font-family:"Bodoni Moda",serif;text-transform:uppercase;
  line-height:.88;letter-spacing:-.02em;color:var(--ink)}
.hero-type .w{display:block;overflow:hidden}
.hero-type .w b{display:block;font-weight:500}
.hero-type .w-salon b{font-size:clamp(60px,15.5vw,250px);animation:heroWord 1.1s var(--ease) .35s backwards}
.hero-type .w-mtl{position:relative;z-index:4}
.hero-type .w-mtl b{font-size:clamp(50px,12.5vw,205px);letter-spacing:.012em;
  animation:heroWord 1.1s var(--ease) .62s backwards}
.w-elite{display:block;position:relative;z-index:3;margin:-.04em 0 -.04em 7vw;
  font-family:"Bodoni Moda",serif;font-style:italic;font-weight:400;text-transform:none;
  font-size:clamp(78px,19.5vw,312px);color:var(--blush-deep);letter-spacing:-.01em;
  text-shadow:0 26px 55px rgba(58,44,42,.26);
  animation:heroElite 1.2s var(--ease) .82s backwards}
.hero-photo{position:absolute;z-index:2;top:50%;right:0;
  width:min(31vw,398px);height:min(62vh,624px);overflow:hidden;
  box-shadow:44px 54px 96px -44px rgba(58,44,42,.55);
  transform:translateY(-46%) scale(.96);
  animation:heroPhoto 1.3s var(--ease) .7s backwards}
/* rose duotone — neutralises any source photo to warm palette tones */
.hero-photo .ph-img{filter:grayscale(1) contrast(1.06) brightness(1.04)}
.hero-photo::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(150deg,var(--blush-deep) 0%,var(--blush) 52%,var(--gold-soft) 100%);
  mix-blend-mode:multiply;opacity:.82}
.hero-photo::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(150deg,transparent 28%,var(--cream) 132%);
  mix-blend-mode:screen;opacity:.5}
.hero-vmeta{position:absolute;left:-6px;top:50%;transform:translateY(-50%);z-index:5;
  writing-mode:vertical-rl;font-family:"Outfit",sans-serif;font-size:10px;letter-spacing:.36em;
  text-transform:uppercase;color:var(--muted)}
.hero-foot{position:absolute;left:0;right:0;bottom:36px;z-index:5;display:flex;
  align-items:flex-end;justify-content:space-between;gap:24px;
  animation:rise 1s var(--ease) 1.3s backwards}
.hero-foot .est{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);line-height:1.8}
.scrollcue{display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:"Outfit",sans-serif;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.scrollcue i{width:1px;height:54px;background:linear-gradient(var(--blush-deep),transparent);
  animation:pulse 2.2s ease-in-out infinite}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroWord{from{transform:translateY(116%)}to{transform:translateY(0)}}
@keyframes heroElite{from{opacity:0;transform:translateY(42px) rotate(-2.5deg)}to{opacity:1;transform:translateY(0) rotate(0)}}
@keyframes heroPhoto{from{opacity:0;transform:translateY(-40%) scale(.9)}to{opacity:1;transform:translateY(-46%) scale(.96)}}
@keyframes pulse{0%,100%{opacity:.25}50%{opacity:1}}

/* ---------- section head ---------- */
.head{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:end;margin-bottom:84px}
.head h2{font-size:clamp(46px,8vw,110px);font-weight:500;text-transform:uppercase;letter-spacing:-.02em}
.head h2 .it{font-family:"Bodoni Moda",serif;font-style:italic;font-weight:400;text-transform:none;color:var(--blush-deep)}
.head .meta{max-width:340px;color:var(--ink-soft);font-size:15px;padding-bottom:14px;
  border-top:1px solid var(--line);padding-top:18px}

/* ---------- services (ghost numerals) ---------- */
.service{position:relative;display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;
  padding:80px 0;border-top:1px solid var(--line)}
.service:last-child{border-bottom:1px solid var(--line)}
.service.flip .s-text{order:2}
.service.flip .media{order:1}
.ghostnum{position:absolute;top:50%;left:-2%;transform:translateY(-50%);z-index:0;
  font-family:"Bodoni Moda",serif;font-style:italic;font-weight:400;font-size:clamp(160px,26vw,360px);
  color:var(--blush);opacity:.5;line-height:.6;pointer-events:none}
.s-text{position:relative;z-index:1}
.s-kick{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.s-text h3{font-size:clamp(42px,5.5vw,82px);margin:14px 0 0;font-weight:500;text-transform:uppercase;letter-spacing:-.02em}
.s-text h3 em{font-family:"Bodoni Moda",serif;font-style:italic;font-weight:400;text-transform:none;color:var(--blush-deep)}
.s-text p{color:var(--ink-soft);margin:24px 0 0;max-width:440px}
.s-price{margin-top:32px;display:flex;align-items:baseline;gap:14px}
.s-price b{font-family:"Bodoni Moda",serif;font-size:42px;font-weight:500}
.s-price span{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.service .media{aspect-ratio:4/3;position:relative;z-index:1;box-shadow:30px 36px 70px -40px rgba(58,44,42,.5)}

/* ---------- boutique masonry ---------- */
.boutique{background:var(--cream-2)}
.masonry{columns:3;column-gap:28px}
.product{break-inside:avoid;margin-bottom:28px;background:var(--cream);
  box-shadow:inset 0 0 0 1px var(--line);transition:transform .5s var(--ease),box-shadow .5s}
.product:hover{transform:translateY(-7px);box-shadow:inset 0 0 0 1px var(--blush-deep),0 30px 60px -36px rgba(58,44,42,.5)}
.product .media{width:100%}
.product.tall .media{aspect-ratio:3/4}
.product.short .media{aspect-ratio:1/1}
.product .info{padding:26px 28px 30px}
.product h4{font-family:"Bodoni Moda",serif;font-weight:500;font-size:27px;margin:0;letter-spacing:-.01em}
.product p{margin:9px 0 0;font-size:13.5px;color:var(--ink-soft)}
.product .row{display:flex;align-items:baseline;justify-content:space-between;margin-top:20px;
  padding-top:18px;border-top:1px solid var(--line)}
.product .price{font-family:"Bodoni Moda",serif;font-size:26px;font-weight:500}
.product .tag{font-family:"Outfit",sans-serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ---------- à propos ---------- */
.apropos{overflow:hidden}
.apropos-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.apropos .media{aspect-ratio:auto;min-height:560px;position:relative}
.apropos .ap-text{padding:0 0 0 80px;display:flex;flex-direction:column;justify-content:center}
.apropos .quote{font-family:"Bodoni Moda",serif;font-weight:400;font-size:clamp(34px,4.2vw,60px);
  line-height:1.08;margin:24px 0 0;letter-spacing:-.01em}
.apropos .quote .it{font-style:italic;color:var(--blush-deep)}
.apropos .body{color:var(--ink-soft);margin-top:28px;max-width:480px}
.signature{font-family:"Bodoni Moda",serif;font-style:italic;font-size:32px;margin-top:24px}
.stats{display:flex;gap:0;margin-top:50px;border-top:1px solid var(--line)}
.stat{flex:1;padding:26px 0;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat b{font-family:"Bodoni Moda",serif;font-weight:500;font-size:46px;display:block;line-height:1}
.stat span{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* ---------- témoignages (warm light panel) ---------- */
.temoignages{color:var(--ink);
  background:radial-gradient(75% 95% at 50% -12%, var(--blush) 0%, transparent 58%), var(--cream-2)}
.temoignages .kick{color:var(--blush-deep)}
.temoignages .kick::before{background:var(--blush-deep)}
.temoignages .head h2{color:var(--ink)}
.temoignages .head h2 .it{color:var(--blush-deep)}
.temoignages .head .meta{border-color:var(--line);color:var(--ink-soft)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.t-card{padding:50px 40px;border-left:1px solid var(--line);transition:background .5s;
  display:flex;flex-direction:column}
.t-card:first-child{border-left:0}
.t-card:hover{background:rgba(255,255,255,.5)}
.t-card .mark{font-family:"Bodoni Moda",serif;font-style:italic;font-size:80px;line-height:.5;
  color:var(--gold);opacity:.75;height:40px}
.t-card p{font-family:"Bodoni Moda",serif;font-size:25px;font-weight:400;line-height:1.36;margin:20px 0 30px}
.t-card .who{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blush-deep)}
.t-stars{color:var(--gold);letter-spacing:3px;margin-top:8px;font-size:13px}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px}
.contact-info .line{padding:24px 0;border-bottom:1px solid var(--line);display:grid;
  grid-template-columns:140px 1fr;gap:20px;align-items:baseline}
.contact-info .line:first-of-type{border-top:1px solid var(--line)}
.contact-info .k{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.contact-info .v{font-family:"Bodoni Moda",serif;font-size:24px}
.form{background:var(--cream-2);box-shadow:inset 0 0 0 1px var(--line);padding:50px}
.form h3{font-size:38px;font-weight:500;margin:0 0 30px;text-transform:uppercase;letter-spacing:-.01em}
.field{margin-bottom:22px}
.field label{display:block;font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.field input,.field select,.field textarea{width:100%;padding:15px 16px;border:0;
  box-shadow:inset 0 0 0 1px var(--line);background:var(--cream);font:inherit;color:var(--ink);transition:box-shadow .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;box-shadow:inset 0 0 0 1px var(--blush-deep)}
.form .btn{width:100%;justify-content:center;margin-top:8px}

/* ---------- footer (warm light) ---------- */
.footer{background:linear-gradient(180deg,var(--cream-2),var(--blush));color:var(--ink);padding:100px 0 44px}
.footer .top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px;padding-bottom:60px;
  border-bottom:1px solid var(--line)}
.footer .brand{text-align:left;color:var(--ink);font-size:40px}
.footer .f-slogan{font-family:"Bodoni Moda",serif;font-style:italic;font-size:24px;margin-top:20px;
  color:var(--blush-deep);max-width:340px}
.footer h5{font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--blush-deep);margin:0 0 22px}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.footer ul a{color:var(--ink-soft);font-size:14px;transition:color .3s}
.footer ul a:hover{color:var(--ink)}
.footer .bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding-top:30px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.footer .bottom a{color:var(--blush-deep)}

/* ===== service menu (la carte) ===== */
.menu{list-style:none;margin:28px 0 0;padding:0}
.menu li{display:grid;grid-template-columns:1fr auto 72px;align-items:baseline;gap:16px;
  padding:14px 2px;border-top:1px solid var(--line);
  transition:background .35s var(--ease),padding-left .35s var(--ease)}
.menu li:last-child{border-bottom:1px solid var(--line)}
.menu li:hover{background:linear-gradient(90deg,var(--blush) 0%,transparent 90%);padding-left:12px}
.menu li:hover .m-name{color:var(--blush-deep)}
.m-name{font-family:"Bodoni Moda",serif;font-size:19px;font-weight:500;letter-spacing:-.01em;
  text-wrap:pretty;transition:color .35s var(--ease)}
.m-dur{font-family:"Outfit",sans-serif;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap}
.m-price{font-family:"Bodoni Moda",serif;font-size:20px;font-weight:500;color:var(--blush-deep);text-align:right}
.menu-foot{margin:16px 0 0;font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)}

/* ============================================================
   EDITORIAL IMAGE GRADE — one cohesive rose duotone
   ============================================================ */
.service .media .ph-img,
.apropos .media .ph-img,
.contact-info .media .ph-img{
  filter:grayscale(.6) sepia(.32) saturate(1.45) hue-rotate(300deg) brightness(1.04) contrast(1.02);
  transition:transform 1s var(--ease),filter .6s var(--ease)}
.service .media::after,
.apropos .media::after,
.contact-info .media::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(150deg,var(--blush-deep) 0%,transparent 50%,var(--gold-soft) 122%);
  mix-blend-mode:multiply;opacity:.22;transition:opacity .6s var(--ease)}
.service:hover .media .ph-img,
.apropos:hover .media .ph-img{transform:scale(1.045)}
.service:hover .media::after{opacity:.15}
.product .media{overflow:hidden;margin:0}
.product .ph-img{filter:grayscale(1) sepia(.55) saturate(1.7) hue-rotate(298deg) brightness(1.07) contrast(1.01);
  object-position:center center;transition:transform .9s var(--ease),filter .6s var(--ease)}
.product .media::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(135% 130% at 28% 8%,transparent 46%,var(--blush-deep) 150%);
  mix-blend-mode:multiply;opacity:.30;transition:opacity .6s var(--ease)}
.product:hover .ph-img{transform:scale(1.05)}
.product:hover .media::after{opacity:.2}

/* ===== testimonial monogram ===== */
.t-by{display:flex;align-items:center;gap:16px;margin-top:auto;padding-top:10px}
.t-mono{display:flex;align-items:center;justify-content:center;width:54px;height:54px;
  border-radius:50%;flex:none;background:var(--blush);box-shadow:0 0 0 1px var(--line);
  font-family:"Bodoni Moda",serif;font-style:italic;font-size:20px;letter-spacing:.02em;
  color:var(--blush-deep)}
.t-by .who{display:block;white-space:nowrap}
.t-by>span:last-child{display:flex;flex-direction:column;gap:4px;min-width:0}
.t-by .t-stars{margin-top:0}

/* ============================================================
   RESPONSIVE — tablet (≤1024px) · mobile (≤768px)
   Desktop styles above are untouched.
   ============================================================ */

/* Nav overlay backdrop */
.nav-overlay{
  display:none;position:fixed;inset:0;z-index:998;
  background:rgba(58,44,42,.4);backdrop-filter:blur(1px)
}
.nav-overlay.show{display:block}

/* ===== TABLET ===== */
@media(max-width:1024px){

  /* layout */
  .section{padding:100px 0}
  .head{grid-template-columns:1fr;margin-bottom:60px}
  .head h2{font-size:clamp(44px,7vw,88px)}

  /* nav — hamburger */
  .nav .wrap{display:flex;align-items:center;justify-content:space-between}
  .nav-l{display:none}
  .brand{text-align:left}
  .burger{display:flex;z-index:1001}
  .nav-r{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);
    background:var(--cream);flex-direction:column;align-items:flex-start;
    justify-content:center;gap:28px;padding:56px;
    transform:translateX(100%);transition:transform .5s var(--ease);
    box-shadow:var(--shadow);z-index:1000
  }
  .nav-r.open{transform:translateX(0)}
  .nav-r a{font-size:13px;letter-spacing:.2em}
  .nav-r .btn-ghost{
    background:var(--ink);color:var(--cream);box-shadow:none;
    width:100%;justify-content:center;margin-top:8px
  }

  /* hero */
  .hero-photo{display:none}
  .hero-vmeta{display:none}
  .w-elite{margin-left:2vw}

  /* services — stack vertically */
  .service{grid-template-columns:1fr;gap:40px;padding:72px 0}
  .service.flip .s-text{order:0}
  .service.flip .media{order:1}
  .service .media{aspect-ratio:16/9}
  .ghostnum{font-size:clamp(110px,16vw,220px)}
  .s-text h3{font-size:clamp(36px,5.5vw,68px)}

  /* boutique — 2 columns */
  .masonry{columns:2;column-gap:22px}
  .product{margin-bottom:22px}

  /* à propos — stack */
  .apropos-grid{grid-template-columns:1fr}
  .apropos .media{min-height:420px;aspect-ratio:16/9}
  .apropos .ap-text{padding:52px 44px 64px}
  .apropos .quote{font-size:clamp(30px,4vw,52px)}

  /* témoignages — stack */
  .t-grid{grid-template-columns:1fr}
  .t-card{border-left:0;border-top:1px solid var(--line)}
  .t-card:first-child{border-top:0}

  /* contact — stack */
  .contact-grid{grid-template-columns:1fr;gap:52px}

  /* footer — stack */
  .footer .top{grid-template-columns:1fr;gap:36px;padding-bottom:44px}
}

/* ===== MOBILE ===== */
@media(max-width:768px){

  /* layout */
  .section{padding:72px 0}
  .wrap{width:min(1280px,91vw)}
  .head{margin-bottom:44px;gap:16px}
  .head h2{font-size:clamp(36px,10.5vw,58px)}
  .head .meta{font-size:14px;padding-top:12px}

  /* hero — stacked layout: full-bleed photo top 60%, text on cream below */
  .hero{min-height:auto;overflow:hidden}
  .hero::before{display:none}
  .hero-inner{min-height:auto;justify-content:flex-start;padding:0}

  /* Photo: reorder to top, break out of constrained container to true full-width */
  .hero-photo{
    order:-1;
    display:block;
    position:relative;
    left:50%;
    transform:translateX(-50%);
    width:100vw;
    max-width:none;
    height:60svh;
    aspect-ratio:auto;
    margin:0;
    animation:none;
    box-shadow:none
  }
  /* remove the blush duotone overlay — portrait reads in natural tones here */
  .hero-photo::after{background:transparent;opacity:0}

  /* Type: below photo on the warm cream background, dark ink */
  .hero-type{padding:clamp(24px,6vw,38px) 0 0}
  .hero-type .w-salon{position:static}
  .hero-type .w-salon b{font-size:clamp(46px,13vw,78px);color:var(--ink);text-shadow:none}
  .hero-type .w-mtl b{font-size:clamp(38px,10.5vw,66px);text-shadow:none}
  .w-elite{font-size:clamp(58px,16vw,96px);margin-left:1vw;text-shadow:none}

  /* Footer lines: sit below the type, natural flow */
  .hero-foot{position:static;z-index:auto;margin-top:16px;padding-bottom:36px;
    flex-direction:column;align-items:flex-start;gap:8px}
  .hero-foot .est{font-size:10px;letter-spacing:.12em;line-height:1.9}
  .scrollcue{display:none}

  /* services */
  .service{padding:50px 0;gap:26px}
  .service .media{aspect-ratio:4/3}
  .ghostnum{font-size:clamp(68px,20vw,108px);opacity:.28}
  .s-text h3{font-size:clamp(28px,8.5vw,46px)}
  .s-text p{margin-top:14px;font-size:15px}

  /* service menu */
  .menu{margin-top:18px}
  .menu li{grid-template-columns:1fr auto;gap:8px;padding:12px 0}
  .m-dur{display:none}
  .m-name{font-size:15.5px}
  .m-price{font-size:17px;white-space:nowrap}
  .menu-foot{font-size:10px}

  /* boutique — single column */
  .masonry{columns:1;column-gap:0}
  .product{margin-bottom:18px}
  .product.tall .media{aspect-ratio:3/2}
  .product.short .media{aspect-ratio:3/2}
  .product h4{font-size:22px}
  .product p{font-size:13px}
  .product .info{padding:20px 22px 22px}

  /* à propos */
  .apropos .media{min-height:260px;aspect-ratio:4/3}
  .apropos .ap-text{padding:36px 0 0}
  .apropos .quote{font-size:clamp(22px,6.5vw,34px)}
  .signature{font-size:20px}
  .stats{flex-wrap:nowrap}
  .stat{flex:1;padding:16px 0}
  .stat b{font-size:26px}
  .stat span{font-size:10px}

  /* témoignages */
  .t-card{padding:34px 26px}
  .t-card p{font-size:20px}
  .t-card .mark{font-size:64px}

  /* contact */
  .contact-grid{gap:34px}
  .contact-info .line{grid-template-columns:1fr;gap:3px;padding:16px 0}
  .contact-info .k{font-size:10px;letter-spacing:.18em}
  .contact-info .v{font-size:17px}
  .form{padding:28px 22px}
  .form h3{font-size:26px;margin-bottom:20px}

  /* footer */
  .footer{padding:56px 0 30px}
  .footer .brand{font-size:26px}
  .footer .f-slogan{font-size:15px;margin-top:10px;max-width:none}
  .footer .top{gap:24px;padding-bottom:28px}
  .footer .bottom{flex-direction:column;align-items:flex-start;gap:5px}

  /* cookie */
  .cookie{flex-direction:column;align-items:flex-start;gap:10px;padding:16px 18px}
  .cookie p{font-size:12px}
}
