/* ================================================
   HEADER DESKTOP : logo gauche / menu droite
   ================================================ */
header#masthead.site-header {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 20px 48px !important;
  box-sizing: border-box !important;
  width: 100% !important;
  background: #fff !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  border-bottom: 1px solid rgba(0,0,0,0.07) !important;
}

header#masthead .site-branding {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

nav#site-navigation.main-navigation {
  flex: 0 0 auto !important;
  margin: 0 !important;
  position: static !important;
  background: transparent !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  transform: none !important;
}

/* ================================================
   BOUTON TOGGLE (label#toggle-menu)
   ================================================ */
label#toggle-menu.button {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: #1a1a1a !important;
  color: #fff !important;
  padding: 11px 26px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  border: none !important;
  border-radius: 0 !important;
  transition: background 0.2s !important;
  user-select: none !important;
  white-space: nowrap !important;
}

label#toggle-menu.button:hover {
  background: #333 !important;
}

/* ================================================
   PANNEAU MENU : fermé par défaut
   ================================================ */
nav#site-navigation .menu-primary-container {
  display: none !important;
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  width: 360px !important;
  height: 100vh !important;
  background: #111 !important;
  z-index: 9999 !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: 80px 50px !important;
  box-sizing: border-box !important;
  box-shadow: -8px 0 40px rgba(0,0,0,0.25) !important;
}

/* Panneau ouvert */
nav#site-navigation #toggle:checked ~ .menu-primary-container {
  display: flex !important;
}

/* Overlay sombre derrière le panneau */
nav#site-navigation #toggle:checked ~ .menu-primary-container::before {
  content: "" !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 360px !important;
  bottom: 0 !important;
  background: rgba(0,0,0,0.45) !important;
  z-index: -1 !important;
}

/* ================================================
   LIENS PRINCIPAUX
   ================================================ */
nav#site-navigation ul#menu-primary-1.main-menu {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

nav#site-navigation ul#menu-primary-1 > li > a {
  display: block !important;
  color: #fff !important;
  text-decoration: none !important;
  font-size: 30px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
  padding: 7px 0 !important;
  transition: opacity 0.2s !important;
  border: none !important;
}

nav#site-navigation ul#menu-primary-1 > li > a:hover {
  opacity: 0.4 !important;
}

/* ================================================
   SOUS-MENU
   ================================================ */
nav#site-navigation ul.sub-menu {
  list-style: none !important;
  padding: 4px 0 4px 16px !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

nav#site-navigation ul.sub-menu li a {
  display: block !important;
  color: #888 !important;
  text-decoration: none !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  padding: 4px 0 !important;
  transition: color 0.15s !important;
}

nav#site-navigation ul.sub-menu li a:hover {
  color: #fff !important;
}

/* ================================================
   MOBILE
   ================================================ */
@media (max-width: 768px) {
  header#masthead.site-header {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 14px 20px !important;
    gap: 0 !important;
  }

  header#masthead .site-branding {
    flex: 0 0 auto !important;
    max-width: 60px !important;
  }

  header#masthead .site-branding img.custom-logo {
    width: 60px !important;
    height: auto !important;
  }

  nav#site-navigation.main-navigation {
    flex: 0 0 auto !important;
    margin-left: auto !important;
  }

  label#toggle-menu.button {
    white-space: nowrap !important;
    font-size: 11px !important;
    padding: 10px 18px !important;
  }

  nav#site-navigation .menu-primary-container {
    width: 100% !important;
  }

  nav#site-navigation ul#menu-primary-1 > li > a {
    font-size: 22px !important;
  }
}

/* ================================================
   FOOTER
   ================================================ */
footer#colophon.site-footer {
  background: #111 !important;
  color: #aaa !important;
  padding: 10px 48px 24px !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
  margin-top: 80px !important;
}

/* Zone widgets */
footer#colophon aside.widget-area {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 40px !important;
  flex-wrap: wrap !important;
}

footer#colophon aside.widget-area * {
  color: #aaa !important;
  font-size: 13px !important;
  line-height: 1.8 !important;
}

footer#colophon aside.widget-area a {
  text-decoration: none !important;
  transition: color 0.2s !important;
}

footer#colophon aside.widget-area a:hover {
  color: #fff !important;
}

footer#colophon .widget-title {
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  margin-bottom: 16px !important;
}

/* Ligne de séparation pleine largeur */
footer#colophon nav.footer-navigation {
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  padding-top: 20px !important;
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

footer#colophon nav.footer-navigation ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 24px !important;
}

footer#colophon nav.footer-navigation ul li a {
  color: #666 !important;
  text-decoration: none !important;
  font-size: 12px !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  transition: color 0.2s !important;
}

footer#colophon nav.footer-navigation ul li a:hover {
  color: #fff !important;
}

/* Copyright */
footer#colophon .site-info {
  font-size: 11px !important;
  color: #444 !important;
  letter-spacing: 0.04em !important;
}

footer#colophon .site-info a {
  color: #555 !important;
  text-decoration: none !important;
}

footer#colophon .site-info a:hover {
  color: #fff !important;
}

/* ================================================
   FOOTER MOBILE
   ================================================ */
@media (max-width: 768px) {
  footer#colophon.site-footer {
    padding: 28px 20px 20px !important;
    margin-top: 40px !important;
  }

  footer#colophon aside.widget-area {
    flex-direction: column !important;
    gap: 32px !important;
  }

  footer#colophon nav.footer-navigation {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }

  footer#colophon nav.footer-navigation ul {
    gap: 16px !important;
  }
}


/* La classe à ajouter sur tes sections ou tes images de projet */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.8s cubic-bezier(0.2, 1, 0.3, 1); /* Courbe fluide */
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

.scroll-container {
    overflow: hidden;
    white-space: nowrap;
    display: flex;
}

.scroll-content {
    display: flex;
    animation: marquee 20s linear infinite;
}

/* On duplique visuellement le contenu pour l'effet infini */
@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}



body {
    font-family: 'DM Sans', sans-serif;
    background: var(--warm-white);
    color: var(--text);
    overflow-x: hidden;
    
  }
 
  /* Custom cursor */
  .cursor {
    width: 10px; height: 10px;
    background: var(--accent);
    border-radius: 50%;
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 9999;
    transition: transform 0.15s ease;
  }
  .cursor-follower {
    width: 32px; height: 32px;
    border: 1.5px solid var(--accent);
    border-radius: 50%;
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 9998;
    transition: transform 0.35s ease, opacity 0.3s;
    opacity: 0.6;
  }

/*
Bienvenue dans l'éditeur de CSS !

Pour en savoir plus sur le fonctionnement de l'éditeur, vous pouvez vous
rendre sur cette page :
http://wp.me/PEmnE-Bt
*/
@media screen and (max-width: 750px) {
	.gifweb {
		display: none !important;
		visibility: hidden !important;
	}
}

@media screen and (min-width: 751px) {
	.gifmob {
		display: none !important;
		visibility: hidden !important;
	}
}

@media screen and (max-width: 750px) {
	.gifmob {
		visibility: visible !important;
		display: visible !important;
	}
}