/*
Theme Name: LUDO SNTS
Theme URI: https://ludosnts.fr
Template: twentytwentyfive
Author: Ludo Snts
Author URI: https://ludosnts.fr
Description: Thème LUDOSNTS
Tags: one-column,custom-colors,custom-menu,custom-logo,editor-style,featured-images,full-site-editing,block-patterns,rtl-language-support,sticky-post,threaded-comments,translation-ready,wide-blocks,block-styles,style-variations,accessibility-ready,blog,portfolio,news
Version: 1.1.1755700778
Updated: 2025-08-20 16:39:38

*/
/* ========================================
  VARIABLES
======================================== */
:root {
  --primary: #3b4b59;
  --secondary: #f39f18;
  --dark: #222;
  --light: #eee;

  --shadow-1: 0 1px 2px rgba(19, 19, 22, 0.08), 0 1px 3px rgba(19, 19, 22, 0.06);
  --shadow-2: 0 10px 20px rgba(19, 19, 22, 0.1), 0 4px 10px rgba(19, 19, 22, 0.06);

  --speed: 180ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

/* ========================================
  RÉGLAGES
======================================== */
html {
  scroll-behavior: smooth;
}

body {
  background: var(--dark);
  color: var(--light);
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
}

a {
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
}

/* ========================================
  MENU BURGER MENU
======================================== */
#custom-menu {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 65px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  backdrop-filter: blur(10px);
  background: color-mix(in srgb, var(--dark) 84%, transparent);
  transition: background 0.5s ease, backdrop-filter 0.5s ease;
  box-shadow: 0 1px 0 color-mix(in srgb, var(--light) 8%, transparent);
}
body.menu-open #custom-menu {
  background: transparent;
  backdrop-filter: none;
}

/* Les deux côtés sont flex, pour aligner proprement texte + bouton */
.menu-left,
.menu-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Marges latérales inchangées (restent cohérentes après swap) */
.menu-left { margin-left: 20px; }
.menu-right { margin-right: 20px; }

/* Quand le burger est à droite, on ne change rien d’autre :
  - le gap gère l’espacement "MENU" <-> bouton
  - l'id #burger-icon reste identique pour le JS */


.menu-text {
  font-weight: 700;
  letter-spacing: 0.3px;
}

.burger-menu {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 30px;
  height: 19px;
  cursor: pointer;
  border: 0;
  background: none;
  padding: 0;
}
.burger-menu span {
  display: block;
  width: 100%;
  height: 3px;
  border-radius: 2px;
  background: var(--light);
  transition: transform 0.3s ease, opacity 0.3s ease;
}
body.menu-open #custom-menu .burger-menu span {
  background: var(--dark);
}
body.menu-open #custom-menu .menu-text {
  color: var(--dark);
}
body.menu-open #custom-menu .bouton-contact {
  color: var(--light);
  background-color: var(--dark);
  border-color: var(--dark);
}
body.menu-open #custom-menu .bouton-contact:hover {
  color: var(--dark);
  background-color: transparent;
}
.burger-menu.open span:nth-child(1) {
  transform: rotate(45deg) translate(6px, 7px);
  background: var(--dark);
}
.burger-menu.open span:nth-child(2) {
  opacity: 0;
}
.burger-menu.open span:nth-child(3) {
  transform: rotate(-45deg) translate(4px, -5px);
}

.menu-center {
  position: absolute;
  left: 50%;
  transform: translate(-50%, 6px);
}
.menu-center img {
  height: 46px;
  width: auto;
}

/* Bouton contact */
.bouton-contact {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: var(--light);
  background-color: var(--secondary);
  padding: 10px 16px;
  border: 2px solid var(--secondary);
  border-radius: 999px;
  box-shadow: var(--shadow-1);
  transition: background-color var(--speed), transform var(--speed), box-shadow var(--speed);
}
.bouton-contact:hover {
  color: var(--secondary);
  background-color: var(--dark);  
  box-shadow: var(--shadow-2);
}
.bouton-contact i {
  font-size: 18px;
}

/* ========================================
  MENU OVERLAY PLEIN ÉCRAN
======================================== */
/* Backdrop global */
#menu-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.38);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
  z-index: 9997;
}

/* Conteneur overlay */
#full-screen-menu {
  position: fixed;
  top: 0; bottom: 0;
  width: 100vw; /* sera réduit via classes size-... */
  background: var(--secondary); /* adapte si besoin */
  color: var(--dark);
  z-index: 9998;
  transform: translateX(-100%); /* défaut: side-left fermé */
  transition: transform .35s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
  overflow-y: auto;
}
/* Ouverture : la classe .open est ajoutée par le JS */
/* #full-screen-menu.open { transform: translateX(0); } */
#menu-backdrop.open { opacity: 1; pointer-events: auto; }

/* Direction (fermé) */
#full-screen-menu.side-left  { left: 0;  transform: translateX(-100%); }
#full-screen-menu.side-right { right: 0; transform: translateX(100%);  }

/* OUVERT — ces lignes DOIVENT être après les deux ci-dessus */
#full-screen-menu.side-left.open,
#full-screen-menu.side-right.open { transform: translateX(0); }


/* Largeurs (desktop/tablette) */
#full-screen-menu.size-full    { width: 100vw; }
#full-screen-menu.size-half    { width: clamp(560px, 50vw, 720px); }
#full-screen-menu.size-quarter { width: clamp(320px, 25vw, 420px); }

/* Mobile : toujours pleine largeur */
@media (max-width: 768px) {
  #full-screen-menu { width: 100vw !important; }
}

/* Exemple de style interne (facultatif) */
#full-screen-menu .menu {
  padding: clamp(16px, 3vw, 32px);
}
/* #full-screen-menu.open {
  left: 0;
} */

#full-screen-menu .menu-items {
  list-style: none;
  margin: clamp(24px, 6vw, 60px);
  margin-top: 100px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  z-index: 2;
}
#full-screen-menu .menu-item {
  list-style: none;
}

#full-screen-menu .menu-item a,
#full-screen-menu .submenu-toggle {
  text-decoration: none;
  color: var(--dark);
  font-weight: 700;
  line-height: 1;
  font-size: clamp(28px, 6vw, 60px);
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.5s ease, transform 0.5s ease, color 0.2s ease;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 0;
}
#full-screen-menu.open .menu-item > a,
#full-screen-menu.open .submenu-toggle {
  opacity: 1;
  transform: translateX(0);
}
#full-screen-menu .menu-item a:hover,
#full-screen-menu .submenu-toggle:hover {
  color: var(--light);
}

/* Sous-menus */
 /* Animation d’accordéon */
#full-screen-menu .sub-menu {
  transition: max-height 0.3s ease;
}

/* Entrée·s avec sous-menus */
.menu-item-has-children > a {
  position: relative; /* Pour afficher le pseudo-élément (::after) */
}

/* Icône en pseudo-élément (Font Awesome) */
.menu-item-has-children > a::after {
  content: "\f061"; /* <i class="fa-solid fa-arrow-right"></i> */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(150% , -50%) rotate(0deg);
  transition: transform 0.3s ease;
  line-height: 1;
}

/* État ouvert : rotation de l’icône (45°) */
.menu-item-has-children.open > a::after {
  transform: translate(150% , -50%) rotate(45deg)
}

/* Menu en bas */
#full-screen-menu .menu-bottom {
  position: absolute;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
}

/* Responsive */
@media (max-width: 768px) {
  .menu-center {
    right: 0;
    left: auto;
    transform: translate(-16px, 4px);
  }
  .menu-center img {
    height: 46px;
    transform: translate(-4px, -1px);
  }
  .menu-right {
    display: none;
  }
  #full-screen-menu .menu-items {
    margin: 0;
    padding: 40px 24px;
  }
  #full-screen-menu .menu-item a {
    font-size: clamp(24px, 9vw, 50px);
  }
}

/* ========================================
  OVERLAYS PARTIELS : tailles de texte & espacements
  (actifs dès ≥ 769px)
======================================== */
@media (min-width: 769px) {

  /* Marges internes + espacements entre entrées */
  #full-screen-menu.size-half .menu-items {
    margin: clamp(20px, 4vw, 40px);
    gap: clamp(10px, 1.5vw, 18px);
    margin-top: 100px;
  }
  #full-screen-menu.size-quarter .menu-items {
    margin: clamp(16px, 3vw, 28px);
    gap: clamp(8px, 1.2vw, 14px);
    margin-top: 100px;
  }

  /* Top-level links (entrées principales) */
  #full-screen-menu.size-half .menu-item > a,
  #full-screen-menu.size-half .submenu-toggle {
    font-size: clamp(22px, 3.2vw, 34px);
    line-height: 1.15;
    /* anim d’entrée moins “longue” */
    transform: translateX(-30px);
  }
  #full-screen-menu.size-quarter .menu-item > a,
  #full-screen-menu.size-quarter .submenu-toggle {
    font-size: clamp(18px, 2.4vw, 26px);
    line-height: 1.2;
    transform: translateX(-16px);
  }
  /* État ouvert (garde ta transition d’apparition) */
  #full-screen-menu.size-half.open .menu-item > a,
  #full-screen-menu.size-half.open .submenu-toggle {
    transform: translateX(0);
  }
  #full-screen-menu.size-quarter.open .menu-item > a,
  #full-screen-menu.size-quarter.open .submenu-toggle {
    transform: translateX(0);
  }

  /* Sous-menus : taille/padding plus compacts */
  #full-screen-menu.size-half .sub-menu a {
    font-size: clamp(16px, 1.4vw, 18px);
    padding: 8px 10px;
  }
  #full-screen-menu.size-quarter .sub-menu a {
    font-size: clamp(14px, 1.2vw, 16px);
    padding: 8px 10px;
  }

  /* Icône “→” des parents : rapprocher pour éviter le débordement */
  #full-screen-menu.size-half .menu-item-has-children > a::after {
    transform: translate(40px, -50%) rotate(0deg);
  }
  #full-screen-menu.size-quarter .menu-item-has-children > a::after {
    transform: translate(35px, -50%) rotate(0deg);
  }
  /* État ouvert : même rotation que ton style de base */
  #full-screen-menu.size-half .menu-item-has-children.open > a::after {
    transform: translate(40px, -50%) rotate(45deg);
  }
  #full-screen-menu.size-quarter .menu-item-has-children.open > a::after {
    transform: translate(35px, -50%) rotate(45deg);
  }

  /* Optionnel : réduire légèrement la hauteur de ligne globale
     pour densifier le panneau étroit */
  #full-screen-menu.size-quarter .menu-items {
    line-height: 1.3;
  }
}


/* ========================================
  MENU INLINE (second menu, sans burger)
  Scope: #siteHeaderInline, .nav-inline
======================================== */
#siteHeaderInline {
  position: relative;
  z-index: 50;
  padding-block: clamp(10px, 1.5vh, 16px);
  background: var(--header-bg, transparent);
  font-size: clamp(0.95rem, 0.9rem + 0.2vw, 1.05rem);
}

#siteHeaderInline .nav-inline {
  display: grid;
  grid-template-columns: auto 1fr auto; /* logo | menu | bouton */
  align-items: center;
  gap: clamp(12px, 2vw, 28px);
  width: min(1200px, 100% - clamp(24px, 6vw, 96px));
  margin-inline: auto;
}

/* Logo */
#siteHeaderInline .nav-inline-left .brand-logo {
  max-height: clamp(28px, 4.5vh, 48px);
  width: auto;
}

/* Bouton contact (isolation par classe dédiée) */
#siteHeaderInline .bouton-contact-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.5ch;
  padding: 0.6em 0.9em;
  border-radius: 999px;
  background-color: var(--page-accent, var(--secondary));
  color: #fff;
  text-decoration: none;
  transition: transform .2s ease, background-color .2s ease, opacity .2s ease;
  will-change: transform;
}
#siteHeaderInline .bouton-contact-inline:hover { opacity: 0.9; transform: translateY(-1px); }
#siteHeaderInline .bouton-contact-inline i { font-size: 1em; }

/* ===========================
   NAV CENTRE
=========================== */
#siteHeaderInline .nav-inline-center {
  display: flex;
  justify-content: center;
}

/* Reset & layout de la liste */
#siteHeaderInline .menu-inline-root,
#siteHeaderInline .menu-inline-root ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
#siteHeaderInline .menu-inline-root {
  display: flex;
  align-items: center;
  gap: clamp(12px, 2.2vw, 28px);
}

/* Liens top-level */
#siteHeaderInline .menu-inline-root > li > a {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 0.4em 0.2em;
  text-decoration: none;
  color: inherit;
  transition: color .2s ease;
}

/* Soulignement subtil au hover */
#siteHeaderInline .menu-inline-root > li > a::before {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -0.35em;
  height: 2px;
  transform: scaleX(0);
  transform-origin: left;
  background: currentColor;
  opacity: .15;
  transition: transform .25s ease;
}
#siteHeaderInline .menu-inline-root > li:hover > a::before,
#siteHeaderInline .menu-inline-root > li:focus-within > a::before {
  transform: scaleX(1);
}

/* Chevron en pseudo-élément (FA \f078) sur parents */
#siteHeaderInline .menu-inline-root > li.menu-item-has-children > a {
  padding-right: 1.2em; /* espace pour l’icône */
}
#siteHeaderInline .menu-inline-root > li.menu-item-has-children > a::after {
  content: "\f078";                 /* chevron-down */
  font: var(--fa-font-solid);       /* FA6 webfonts requis */
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%) rotate(0deg);
  transition: transform .25s ease, opacity .2s ease;
  opacity: .9;
}

/* Sous-menu (niveau 1) */
#siteHeaderInline .menu-inline-root li {
  position: relative;
}
#siteHeaderInline .menu-inline-root > li > .sub-menu {
  position: absolute;
  left: 0;
  top: calc(100% + 10px);
  min-width: 220px;
  padding: 10px;
  border-radius: 10px;
  background: color-mix(in oklab, canvas 92%, black 8%);
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .20s ease, transform .20s ease, visibility 0s linear .2s;
  z-index: 100;
}

/* Items du sous-menu */
#siteHeaderInline .menu-inline-root > li > .sub-menu > li > a {
  display: flex;
  align-items: center;
  gap: 0.6ch;
  white-space: nowrap;
  padding: 10px 12px;
  border-radius: 8px;
  color: inherit;
  text-decoration: none;
  transition: background-color .18s ease, color .18s ease;
}
#siteHeaderInline .menu-inline-root > li > .sub-menu > li > a:hover {
  background: color-mix(in oklab, currentColor 12%, transparent);
}

/* Ouverture : au survol, focus-within ou via classe .open (JS) */
#siteHeaderInline .menu-inline-root > li:hover > .sub-menu,
#siteHeaderInline .menu-inline-root > li:focus-within > .sub-menu,
#siteHeaderInline .menu-inline-root > li.open > .sub-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity .20s ease, transform .20s ease, visibility 0s;
}
#siteHeaderInline .menu-inline-root > li:hover > a::after,
#siteHeaderInline .menu-inline-root > li:focus-within > a::after,
#siteHeaderInline .menu-inline-root > li.open > a::after {
  transform: translateY(-50%) rotate(180deg);
}

/* Sous-sous-menus (niveau 2) si besoin */
#siteHeaderInline .menu-inline-root .sub-menu .menu-item-has-children { position: relative; }
#siteHeaderInline .menu-inline-root .sub-menu .menu-item-has-children > .sub-menu {
  position: absolute;
  left: 100%;
  top: 0;
  margin-left: 8px;
  min-width: 220px;
  padding: 10px;
  border-radius: 10px;
  background: color-mix(in oklab, canvas 92%, black 8%);
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
  opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(8px);
  transition: opacity .20s ease, transform .20s ease, visibility 0s linear .2s;
}
#siteHeaderInline .menu-inline-root .sub-menu .menu-item-has-children:hover > .sub-menu,
#siteHeaderInline .menu-inline-root .sub-menu .menu-item-has-children:focus-within > .sub-menu {
  opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); transition: opacity .20s ease, transform .20s ease, visibility 0s;
}

/* Focus visible */
#siteHeaderInline .menu-inline-root a:focus-visible,
#siteHeaderInline .bouton-contact-inline:focus-visible,
#siteHeaderInline .brand:focus-visible {
  outline: 2px solid var(--secondary);
  outline-offset: 2px;
  border-radius: 6px;
}

/* Responsif simple : en dessous de 900px, on compacte un peu */
@media (max-width: 900px) {
  #siteHeaderInline .menu-inline-root {
    gap: clamp(8px, 1.5vw, 16px);
    font-size: 0.95em;
  }
  #siteHeaderInline .menu-inline-root > li > a { padding: 0.35em 0.15em; }
}

/* Très petit écran : autoriser le wrap des items top-level */
@media (max-width: 640px) {
  #siteHeaderInline .nav-inline { grid-template-columns: 1fr; gap: 10px; }
  #siteHeaderInline .nav-inline-left,
  #siteHeaderInline .nav-inline-right { justify-self: center; }
  #siteHeaderInline .nav-inline-center { justify-content: center; }
  #siteHeaderInline .menu-inline-root { flex-wrap: wrap; justify-content: center; }
}

/* ========================================
  HOMEPAGE
======================================== */

/* Centrage global */
.homepage-launcher {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 115px);
  padding-top: 65px;
  text-align: center;
}

/* Style du texte */
.airport-text {
  font-family: monospace, sans-serif;
  font-size: clamp(2rem, 8vw, 6rem);
  font-weight: bold;
  letter-spacing: 0.2em;
  display: flex;
  gap: 0.1em;
  flex-wrap: wrap;
  perspective: 800px; /* NEW */
}

#ludosnts-text {
  letter-spacing: 0.3em;
  color: var(--secondary);
}

/* Chaque lettre séparée */
.airport-text span {
  display: inline-block;
  position: relative;
  transform-origin: center bottom;
  backface-visibility: hidden; /* anti-flicker */
  opacity: 0; /* visible quand le scramble démarre */
  will-change: transform, opacity; /* perf hint */
}

/* Classe appliquée à l’instant où la bonne lettre se fixe */
.airport-text span.settle {
  animation: flip-in 0.35s ease both; /* NEW */
}

/* Animation style flip */
@keyframes flip {
  0% {
    transform: rotateX(90deg);
    opacity: 0;
  }
  50% {
    transform: rotateX(0deg);
    opacity: 1;
  }
  100% {
    transform: rotateX(0deg);
    opacity: 1;
  }
}

/* ========================================
  PAGE·S LÉGALE·S
======================================== */
.page-legale {
  margin-inline: auto;
  padding-inline: 20px;
  padding-bottom: 60px;
  max-width: 900px;
  padding-top: 85px;
  min-height: calc(100svh - 170px);
  margin: 0 auto;
  line-height: 1.6;
  color: var(--light);
}

.page-legale-title {
  font-size: 2.2rem;
  margin-bottom: 25px;
  font-weight: 600;
  text-align: center;
  color: var(--secondary); /* utilise ta variable CSS si dispo */
}

.page-legale-content h2,
.page-legale-content h3 {
  margin-top: 30px;
  margin-bottom: 15px;
  font-weight: 500;
  color: var(--light);
}

.page-legale-content p {
  margin-bottom: 15px;
}

.page-legale-content a {
  color: var(--secondary);
  text-decoration: underline;
}

.page-legale-content ul {
  padding-left: 20px;
  margin-bottom: 20px;
  list-style-type: disc;
}


/* ========================================
  FOOTER — responsive + typographie fluide
======================================== */
.site-footer {
  padding-block: clamp(16px, 2.5vh, 40px);
  font-size: clamp(0.95rem, 0.9rem + 0.25vw, 1.125rem);
  line-height: 1.6;
  text-align: center;
  /* Optionnel : séparateur visuel
  border-top: 1px solid color-mix(in oklab, currentColor 12%, transparent);
  */
}

.site-footer .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(8px, 1.2vh, 16px);
  width: min(1100px, 100% - clamp(24px, 6vw, 96px));
  margin-inline: auto;
}

.site-footer p {
  margin: 0;
  max-width: 75ch;
  overflow-wrap: anywhere;
}

/* Icône FA : taille fluide + alignement */
.site-footer .container i {
  /* color: var(--secondary); */
  font-size: clamp(1em, 0.95em + 0.2vw, 1.2em);
  vertical-align: -0.12em;
  margin-inline: 0.35ch;
}

/* Liens : style, hover et focus */
.site-footer .container a {
  color: inherit;
  text-decoration: none;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.22em;
  transition: color 0.2s ease, text-underline-offset 0.2s ease;
}
.site-footer .container a:hover {
  /* color: var(--secondary); */
  text-underline-offset: 0.34em;
}
.site-footer .container a:focus-visible {
  /* outline: 2px solid var(--secondary); */
  outline-offset: 2px;
  border-radius: 3px;
}

/* ===== Ligne des liens avec séparateur non cliquable ===== */
.site-footer .footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5ch 1ch; /* espace horizontal/vertical entre blocs */
  margin: 0;
}

.site-footer .footer-link {
  position: relative;
  padding-left: 1.2ch; /* réserve l’espace pour le séparateur */
}

/* Le séparateur est sur le SPAN (non interactif), pas sur l’ancre */
.site-footer .footer-link:not(:first-child)::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.65;
  pointer-events: none; /* par sécurité */
}

/* Accessibilité petites largeurs */
@media (max-width: 360px) {
  .site-footer { line-height: 1.55; }
}
