/**
 * Front-page styles — extracted from front-page.php.
 *
 * Toutes les valeurs dynamiques côté PHP (URL d'image hero notamment) sont
 * exposées via CSS custom properties dans une balise <style> ultra-courte de
 * front-page.php (voir variable --nco-hero-image). Les chemins vers les SVG
 * statiques du thème sont relatifs à ce fichier (../img/...).
 *
 * @package nuance-co
 */

/* Header chrome supprimé — on utilise uniquement le brand-mark du hero,
   qui devient fixed au scroll (cf. .brand-mark.is-fixed plus bas). */

/* Kill the existing site.css hero background noise overlay */
.hero::before{ display:none !important; }

/* ══════════════════════════════════════════════════════════
   HERO — d'après le Figma Hero-Dark
   Ajout : esperluette géante (logomark) sur la moitié droite,
   remplie de la photo intérieur via CSS mask-image.
   ══════════════════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh; min-height:100svh;
  padding-bottom:20vh;
  box-sizing:content-box;
  width:100%;
  overflow:hidden;
  background:#25232E;  /* charbon */
  isolation:isolate;
}

/* ── Esperluette photo géante (droite) ─────────────────────
   On utilise le logomark & de la marque (amp.svg) comme masque
   sur une div remplie de la photo — JAMAIS la glyphe d'une font. */
.hero .hero-amp{
  position:absolute;
  top:-50%; left:25%;
  height:180%; width:auto;
  aspect-ratio:1/1;
  pointer-events:none;
  /* photo fixée au viewport — l'esperluette se déplace au scroll, la photo non */
  background:
    var(--nco-hero-image) center center / cover no-repeat fixed;
  -webkit-mask:url("../img/logos/amp-rotated.svg") center/contain no-repeat;
          mask:url("../img/logos/amp-rotated.svg") center/contain no-repeat;
  z-index:2;
}

/* ── Grande esperluette magenta (gauche) ──────────────────
   Reproduit le fragment Figma : forme splatter-main.svg remplie
   en magenta, positionnée hors-cadre pour ne montrer qu'une
   portion sur la moitié gauche (position "bien placée" approuvée). */
.hero .splatter-color{
  position:absolute;
  top:0; left:0;
  width:max(calc(95 * 1vw), calc(95 * 1vh)); height:auto;
  aspect-ratio:92/104;
  transform: translate(-70%, -70%) rotate(-8deg);
  overflow:visible;
  pointer-events:none;
  color:#9D063A;
  z-index:3;
}
.hero .splatter-color > svg{
  width:100%; height:100%; display:block; overflow:visible;
}

/* ── Logo + tagline, bas-gauche du hero (sticky → fixed au scroll) ─ */
.hero .brand-mark{
  position:absolute;
  left:2.86%; bottom:calc(20vh + 20vh);
  z-index:50;
  display:block;
  pointer-events:none;
}
.hero .brand-mark img,
.hero .brand-mark .logo-svg{
  width:clamp(220px, 19.8vw, 380px);
  height:auto; display:block;
  color:#F3F1EE;            /* lettres + tagline crème */
  --logo-bg:#25232E;        /* fond charbon, splatter fondu */
  transition: width .25s ease;
}
.hero .brand-mark img{ mix-blend-mode: multiply; }
.hero .brand-mark .logo-svg svg{ width:100%; height:auto; display:block; }
/* État verrouillé : cluster [lang][theme] en haut-gauche, logo à droite du theme.
   Lang = 64px @ left:2.86%, gap 12px ; theme = 40px ; gap 14px avant logo. */
.brand-mark.is-fixed{
  position:fixed !important;
  top:32px !important; bottom:auto !important;
  right:auto !important;
  left:calc(2.86% + 64px + 12px + 40px + 14px) !important;
  z-index:9999;
}
.brand-mark.is-fixed img,
.brand-mark.is-fixed .logo-svg{
  display:block;
  width:clamp(140px, 10.5vw, 200px);
  height:auto;
  color:#F3F1EE;
  --logo-bg:#25232E;
  transition: width .3s ease;
}
.brand-mark.is-fixed .logo-svg svg{ width:100%; height:auto; display:block; }

/* ── CTA haut-droite (splatter-button + texte blanc) ─────
   Note: rendered as direct child of <body> via JS, so styles
   target plain .hero-cta (escapes .hero's isolation:isolate). */
.hero-cta{
  position:fixed;
  right:3%; top:3.5%;
  z-index:9999;
  min-width:clamp(240px, 22%, 400px);
  height:clamp(56px, 5.6vw, 86px);
  padding:0 clamp(28px, 3vw, 48px) clamp(4px, .5vw, 8px);
  display:inline-flex; align-items:center; justify-content:center;
  text-decoration:none;
  font-family:"Barlow", system-ui, sans-serif;
  font-weight:700;
  font-size:clamp(13px, 1.05vw, 18px);
  letter-spacing:.06em; text-transform:uppercase;
  color:#FFFFFF;
  white-space:nowrap;
}
.hero-cta > span.label{ position:relative; z-index:2; }
.hero-cta .splat-button{
  position:absolute; inset:-8% -4%;
  color:#9D063A;
  z-index:1;
  transition: color .2s ease;
}
.hero-cta .splat-button > svg{
  width:100%; height:100%; display:block; overflow:visible;
}
.hero-cta:hover .splat-button,
.hero-cta:focus-visible .splat-button{
  color:#25232E;
}
.hero-cta:focus-visible{ outline:none; }

/* ── Language switcher (FR / EN) ──────────────────────────
   Dropdown fixe en haut-à-gauche, à GAUCHE du theme switcher.
   Bouton compact "FR ▾" / "EN ▾" qui ouvre une liste verticale. */
.lang-switch{
  position:fixed;
  top:30px;
  left:2.86%;
  right:auto;
  z-index:10000;
  width:64px; height:40px;
}
.lang-switch .lang-trigger{
  display:flex; align-items:center; justify-content:center; gap:6px;
  width:100%; height:100%;
  background:var(--charbon);
  border:1px solid rgba(var(--ink-rgb),.32);
  border-radius:20px;
  color:var(--neutre);
  cursor:pointer;
  font-family:"Barlow Condensed"; font-weight:600; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
  -webkit-tap-highlight-color:transparent;
}
[data-theme="light"] .lang-switch .lang-trigger{
  background:#F3F1EE;
  border-color:rgba(var(--ink-rgb),.22);
}
.lang-switch .lang-trigger:hover{
  background:var(--charbon-2);
  border-color:rgba(var(--ink-rgb),.5);
}
[data-theme="light"] .lang-switch .lang-trigger:hover{
  background:#EAE7E2;
  border-color:rgba(var(--ink-rgb),.42);
}
.lang-switch .lang-trigger:focus-visible{
  outline:2px solid var(--magenta); outline-offset:3px;
}
.lang-switch .caret{
  width:6px; height:6px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:translateY(-2px) rotate(45deg);
  transform-origin:center;
  transition:transform .2s ease;
}
.lang-switch.open .caret{ transform:translateY(1px) rotate(-135deg); }
.lang-switch .lang-menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  width:100%;
  background:var(--charbon);
  border:1px solid rgba(var(--ink-rgb),.28);
  border-radius:14px;
  overflow:hidden;
  display:none;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
[data-theme="light"] .lang-switch .lang-menu{
  background:#F3F1EE;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.lang-switch.open .lang-menu{ display:block; }
.lang-switch .lang-menu .lang-option{
  display:block; width:100%;
  padding:10px 14px;
  background:transparent; border:0;
  color:var(--neutre);
  cursor:pointer;
  font-family:"Barlow Condensed"; font-weight:600; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase; text-align:center;
  transition:background .15s ease, color .15s ease;
}
.lang-switch .lang-menu .lang-option:hover,
.lang-switch .lang-menu .lang-option:focus-visible{
  background:rgba(var(--ink-rgb),.08);
  color:var(--magenta);
  outline:none;
}
.lang-switch .lang-menu .lang-option[aria-selected="true"]{
  color:var(--magenta);
}
@media (max-width:720px){
  .lang-switch{ top:22px; left:5%; width:56px; height:36px; }
  .lang-switch .lang-trigger{ font-size:12px; }
}
@media (max-width:480px){
  .lang-switch{ left:4%; }
}

/* ── Theme switcher (sun/moon) ──────────────────────────── */
/* Cluster fixe en haut-à-gauche : [FR ▾] [☀/🌙].
   Le language switch est à left:2.86% ; le theme switch suit à droite. */
.theme-switch{
  position:fixed;
  top:30px;
  left:calc(2.86% + 64px + 12px); /* aligne à droite du language switch */
  right:auto;
  z-index:10000;
  transition: left .3s ease, top .3s ease;
  width:40px; height:40px;
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--charbon);
  border:1px solid rgba(var(--ink-rgb),.32);
  border-radius:50%;
  color:var(--neutre);
  cursor:pointer;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
  -webkit-tap-highlight-color:transparent;
}
[data-theme="light"] .theme-switch{
  background:#F3F1EE;
  border-color:rgba(var(--ink-rgb),.22);
}
.theme-switch:hover{
  background:var(--charbon-2);
  border-color:rgba(var(--ink-rgb),.5);
}
[data-theme="light"] .theme-switch:hover{
  background:#EAE7E2;
  border-color:rgba(var(--ink-rgb),.42);
}
.theme-switch:focus-visible{
  outline:2px solid var(--magenta); outline-offset:3px;
}
.theme-switch svg{ width:18px; height:18px; display:block; }
/* Au scroll : le switcher reste à gauche, le logo se loge à sa droite.
   (La classe .is-shifted est conservée pour compat ; pas de décalage. */
.theme-switch.is-shifted{ left:calc(2.86% + 64px + 12px); right:auto; }
.theme-switch .icon-sun{ display:none; }
.theme-switch .icon-moon{ display:block; }
[data-theme="light"] .theme-switch .icon-sun{ display:block; }
[data-theme="light"] .theme-switch .icon-moon{ display:none; }
@media (max-width:720px){
  .theme-switch{ top:22px; left:calc(5% + 56px + 10px); right:auto; width:36px; height:36px; }
  .theme-switch svg{ width:16px; height:16px; }
}
@media (max-width:480px){
  .theme-switch{ left:calc(4% + 56px + 10px); right:auto; }
}

/* ── Scroll indicator centre-bas (splatter-scroll charbon) ── */
.hero .scroll-indicator{
  position:absolute;
  left:calc(2.86% + clamp(220px, 19.8vw, 380px) / 2);
  bottom:30vh;
  transform:translateX(-50%);
  z-index:10;
  width:clamp(170px, 13%, 260px);
  pointer-events:none;
}
.hero .scroll-indicator .scroll-content{
  position:absolute;
  top:30%; left:50%;
  transform:translate(-50%, -50%);
  display:flex; flex-direction:column;
  align-items:center;
  gap:clamp(10px, 1vh, 18px);
  z-index:2;
}
.hero .scroll-indicator .splat-scroll{
  position:absolute; inset:0;
  color:var(--charbon);
  z-index:1;
}
.hero .scroll-indicator .splat-scroll > svg{
  width:100%; height:100%; display:block; overflow:visible;
}
.hero .scroll-indicator .mouse,
.hero .scroll-indicator .scroll-label{ position:relative; z-index:2; }
.hero .scroll-indicator .mouse{
  width:clamp(22px, 1.55vw, 29px);
  aspect-ratio:29/45;
  border:1.5px solid var(--neutre);
  border-radius:999px;
  background: radial-gradient(circle 2.5px at 50% 22%, var(--neutre) 99%, transparent 100%) no-repeat;
  margin-top:0;
}
.hero .scroll-indicator .scroll-label{
  font-family:"AGaramondPro", Georgia, serif;
  font-style:italic; font-weight:400;
  font-size:clamp(14px, 1.05vw, 20px);
  color:var(--neutre);
  letter-spacing:.01em;
}

/* ── Mobile ──────────────────────────────────────────────── */
@media (max-width: 720px){
  .hero .hero-amp{ left:0; top:0; height:100%; width:auto; transform:translateX(-10%) translateY(-30%); }
  .hero .splatter-color{ left:-100%; top:-100%; width:160%; height:180%; }
  .hero .brand-mark{ left:5%; bottom:calc(20vh + 10vh); }
  .hero .brand-mark img,
  .hero .brand-mark .logo-svg{ width:70vw; max-width:280px; }
  .brand-mark.is-fixed{ left:calc(5% + 36px + 12px) !important; top:22px !important; right:auto !important; }
  .brand-mark.is-fixed img,
  .brand-mark.is-fixed .logo-svg{ width:140px; }
  .hero-cta{ right:4%; top:14px; min-width:160px; height:44px; font-size:10px; padding:0 14px 4px; letter-spacing:.08em; }
  .hero .scroll-indicator{ display:none; }
}

/* Petit mobile */
@media (max-width: 480px){
  .hero .brand-mark{ left:4%; bottom:calc(20vh + 12vh); }
  .hero .brand-mark img,
  .hero .brand-mark .logo-svg{ width:75vw; max-width:240px; }
  .brand-mark.is-fixed{ left:calc(4% + 36px + 10px) !important; right:auto !important; }
  .brand-mark.is-fixed img,
  .brand-mark.is-fixed .logo-svg{ width:120px; }
  .hero-cta{ min-width:140px; height:40px; font-size:9.5px; padding:0 12px 3px; }
}

/* Services — sans numéros ni tags : 2 colonnes (titre / description) */
.service{ grid-template-columns: minmax(280px, 1fr) 2fr !important; gap: 60px !important; }
.service .num, .service .tags{ display:none !important; }

/* Splatter décoratif en fond, à droite de la section */
@media (max-width: 720px){
  .service{ grid-template-columns: 1fr !important; gap: 16px !important; }
  .service h3{ grid-column: 1 !important; }
  .service p{ grid-column: 1 !important; }
}

/* Separateur de section organique au-dessus de chaque section,
   meme couleur que le fond de sa section (alterne entre 2 SVG) */
section.block{ position:relative; overflow:visible; box-shadow: 0 -1px 0 0 var(--charbon-2); }
section.block.alt{ box-shadow: 0 -1px 0 0 var(--charbon); }
section.block::after{
  content:"";
  position:absolute;
  left:0;
  top:1px;
  width:100vw;
  height:100%;
  transform: translate(0, -100%);
  background-color: var(--charbon-2);
  -webkit-mask: url("../img/figma/section-topside.svg") bottom center / auto auto no-repeat;
          mask: url("../img/figma/section-topside.svg") bottom center / auto auto no-repeat;
  pointer-events:none;
  z-index:2;
}
/* Sections en .alt : fond charbon-2 + 2e separateur */
section.block.alt::after{
  background-color: var(--charbon);
  -webkit-mask: url("../img/figma/section-topside-2.svg") bottom center / auto auto no-repeat;
          mask: url("../img/figma/section-topside-2.svg") bottom center / auto auto no-repeat;
}
section.block > .wrap{ position:relative; z-index:1; }
/* Footer : meme separateur (alterne) en charbon-2 */
footer.footer{ position:relative; overflow:visible; box-shadow: 0 -1px 0 0 var(--charbon); }
footer.footer::after{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100vw;
  height:100%;
  transform: translate(0, -100%);
  background-color: var(--charbon);
  -webkit-mask: url("../img/figma/section-topside-2.svg") bottom center / auto auto no-repeat;
          mask: url("../img/figma/section-topside-2.svg") bottom center / auto auto no-repeat;
  pointer-events:none;
  z-index:2;
}
footer.footer > *{ position:relative; z-index:1; }
footer.footer .phone-magenta{ color: #9D063A; }
footer.footer .phone-magenta:hover{ color: #9D063A; opacity:.8; }
footer.footer .footer-area{ color: currentColor; opacity:.6; }

/* ═ L'approche — editorial grid ═ */
.process.approach{ grid-template-columns:repeat(3, 1fr) !important; }
.process.approach .process-step:nth-child(4){ grid-column:1 / span 1; }
.process.approach .process-step:nth-child(5){ grid-column:2 / span 2; }
/* Carte en magenta plein — activée via le toggle ACF `principe_destacar`. */
.process.approach .process-step.is-accent{ background:#9D063A !important; }
.process.approach .process-step.is-accent .n{ color:#F3F1EE !important; opacity:.75; }
.process.approach .process-step.is-accent p{ color:rgba(243,241,238,.88) !important; }
@media (max-width: 960px){
  .process.approach{ grid-template-columns:repeat(2, 1fr) !important; }
  .process.approach .process-step:nth-child(4),
  .process.approach .process-step:nth-child(5){ grid-column:auto !important; }
}
@media (max-width: 640px){
  .process.approach{ grid-template-columns:1fr !important; }
}
/* .service.zone : ancienne règle (le bloc est maintenant un .zone-banner séparé sous la liste) */

/* ── Zone-banner : bandeau magenta sous la liste de services ─── */
.zone-banner{
  margin-top:clamp(40px, 5vw, 72px);
  padding:clamp(28px, 3.6vw, 48px) clamp(28px, 3.6vw, 56px);
  background:#9D063A;
  color:#F3F1EE;
  border-radius:6px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:clamp(14px, 1.6vw, 22px);
}
.zone-banner .zone-banner-eyebrow{
  font-family:"Barlow Condensed";
  font-weight:600;
  font-size:clamp(13px, 1vw, 15px);
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(243,241,238,.75);
}
.zone-banner p{
  margin:0;
  font-family:"Inter";
  font-weight:400;
  font-size:clamp(15px, 1.05vw, 17px);
  line-height:1.55;
  color:rgba(243,241,238,.92);
}
.zone-banner p strong{
  display:block;
  font-family:"Barlow Condensed";
  font-weight:700;
  font-size:clamp(22px, 1.9vw, 30px);
  letter-spacing:.02em;
  color:#F3F1EE;
  margin-bottom:6px;
}
.zone-banner p em{ font-style:italic; color:#F3F1EE; }
@media (max-width:720px){
  .zone-banner{
    padding:24px 22px;
  }
}

/* ── Service "Bientôt" : mention inline dans le titre, texte magenta seul ─── */
.service .soon-badge{
  display:inline-block;
  margin-left:10px;
  color:#9D063A;
  font-family:"Barlow Condensed";
  font-weight:600;
  font-size:.55em;
  letter-spacing:.18em;
  text-transform:uppercase;
  vertical-align:middle;
  white-space:nowrap;
}
/* "Bientôt" : titre + texte légèrement en retrait pour signaler l'état */
.service.is-soon h3{ opacity:.92; }
.service.is-soon p{ opacity:.78; }
