/* Défilement fluide */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 10%;
  overflow-x: hidden;
  text-align: justify;
}
@font-face {
  font-family: "Mirage", sans-serif;
  src: url("/assets/fonts/Mirage.ttf") format("truetype");
}
/* Variables CSS globales */
:root {
  /* Couleurs principales */
  --black-color: rgba(0, 0, 0, 1);
  --pink: rgba(252, 228, 219, 1);
  --pink-opa: rgba(252, 228, 219, 0.5);
  --pink-opa-plus: rgba(252, 228, 219, 0.4);
  --beige: rgba(178, 167, 153, 1);
  --beige-opa: rgba(178, 167, 153, 0.7);

  /* Couleurs neumorphisme */
  --neuro-light: rgba(255, 255, 255, 0.5);
  --neuro-dark: rgba(178, 167, 153, 0.5);
  --neuro-shadow-1: 8px 8px 16px var(--neuro-dark);
  --neuro-shadow-2: -8px -8px 8px var(--neuro-light);
  --neuro-shadow-inset-1: inset 4px 4px 8px var(--neuro-dark);
  --neuro-shadow-inset-2: inset -2px -2px 8px var(--neuro-light);
  --neuro-hover-1: 4px 4px 8px var(--neuro-dark);
  --neuro-hover-2: -4px -4px 6px var(--neuro-light);

  /* Tailles de police */
  --fontsize-a: clamp(0.7rem, 1.2vw + 0.5rem, 1.2em);
  --fontsize-p: clamp(0.7rem, 1.2vw + 0.5rem, 1.2em);
  --fontsize-nav: clamp(0.7rem, 1vw + 0.5rem, 1em);
  --fontsize-h1: clamp(1rem, 1.8vw + 0.5rem, 1.8em);
  --fontsize-h2: clamp(0.8rem, 1.6vw + 0.5rem, 1.6em);
  --fontsize-h3: clamp(0.6rem, 1.4vw + 0.5rem, 1.4em);

  /* Espacements */
  --spacing-xs: 1%;
  --spacing-sm: 2%;
  --spacing-md: 3%;
  --spacing-lg: 4%;
  --spacing-xl: 6%;
  --spacing-small: clamp(0.2em, 0.5rem, 1em);
  --spacing-medium: clamp(0.2em, 1rem, 2em);
  --spacing-large: clamp(0.2em, 1.5rem, 3em);
  --spacing-xlarge: clamp(0.2em, 2rem, 4em);
  --spacing-xxlarge: clamp(0.2em, 3rem, 5em);

  /* Marges */
  --margin-section: 4%;
  --margin-article: 4% auto 0 auto;

  /* Bordures */
  --border-radius-sm: 10px;
  --border-radius-md: 15px;
  --border-radius-lg: 20px;
  --border-radius-full: 50%;

  /* Largeurs */
  --width-full: 100%;
  --width-article: 80%;
  --width-content: 50%;
  --width-logo-img: 32%;
  --width-backtop: 5%;

  /* Transitions */
  --transition-fast: 0.8s;
  --transition-slow: 1.6s;

  /* Z-index */
  --z-header: 1000;
  --z-backtop: 1001;

  /* Padding */
  --padding-sm: 1%;
  --padding-md: 2%;
  --padding-lg: 4%;
}
/* Structure globale */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  transition: var(--transition-slow);
}
body {
  font-family: "Mirage", sans-serif;
  src: url("/assets/fonts/Mirage.ttf") format("truetype");
}
/* Textes généraux */
img {
  object-fit: contain;
  transition: var(--transition-fast);
}
h1 {
  font-size: var(--fontsize-h1);
  color: var(--black-color);
  transition: var(--transition-slow);
}
h2 {
  padding: var(--padding-md) 0;
  text-align: center;
  font-size: var(--fontsize-h2);
  color: var(--beige);
  transition: var(--transition-slow);
}
h3 {
  padding-bottom: var(--padding-md);
  text-align: center;
  font-size: var(--fontsize-h3);
  color: var(--beige);
  transition: var(--transition-slow);
}
a {
  font-size: var(--fontsize-a);
  color: var(--beige);
  text-decoration: none;
  transition: var(--transition-slow);
}
nav a {
  color: var(--beige);
  font-size: var(--fontsize-nav);
}
p {
  font-size: var(--fontsize-p);
  color: var(--beige);
  transition: var(--transition-slow);
}
/* Effets hover */
strong:hover,
header li a:hover,
footer li a:hover,
h1:hover,
h2:hover,
h3:hover,
p:hover,
article li:hover {
  color: var(--black-color);
  transition: var(--transition-fast);
}
a:hover {
  text-decoration: underline;
  transition: var(--transition-fast);
}
a:focus-visible {
  outline: 1px solid var(--beige);
  outline-offset: 8px;
  transition: 0.1s;
  border-radius: 5px;
  color: var(--black-color);
}
article img:hover {
  transform: scale(1.05);
  transition: var(--transition-fast);
}
/* En-tête sticky */
header {
  width: var(--width-full);
  position: sticky;
  top: 0;
  z-index: 1002;
  margin-bottom: 0;
  padding: var(--padding-sm) 0;
  background-color: var(--pink);
  align-items: center;
  box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
  border-radius: var(--border-radius-md);
  display: flex;
}
/* Barre de navigation */
nav {
  width: var(--width-full);
  transition: var(--transition-slow);
  text-align: center;
  border-radius: var(--border-radius-md);
  z-index: 1003;
}
nav ul {
  margin: 0 auto;
  display: flex;
  justify-content: space-around;
  list-style: none;  
  z-index: 1003;
  border-radius: var(--border-radius-md);
}
/* Pied de page */
footer {
  margin-top: var(--padding-md);
  padding: var(--padding-sm) 0;
  width: var(--width-full);
  box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
  align-items: center;
  display: flex;
  justify-content: center;
  transition: var(--transition-slow);
  background-color: var(--pink);
  border-radius: var(--border-radius-md);
}
.footbar {
  width: var(--width-full);
  text-align: center;
}
footer ul {
  display: flex;
  justify-content: space-around;
  transition: var(--transition-slow);
  list-style: none;
}
/* Section logo */
.logo {
  width: 70%;
  margin: 0 auto;
  align-items: center;
  justify-content: space-evenly;
  display: flex;
  padding-top: 0;
  transition: var(--transition-slow);
}
.left-anim {
  width: 50%;
    animation: apear 2s ease-in-out forwards;
}
.right-anim {
  width: 10%;
    animation: fadeBottom 2s ease-in-out forwards;
}
.prez {
  width: var(--width-article);
  margin: 0 auto;
  padding: var(--padding-lg);
  box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
  border-radius: var(--border-radius-sm);
  background-color: var(--pink);
  line-height: 2;
  text-align: justify;
}
/* Section articles */
article {
  width: var(--width-article);
  margin: var(--margin-article);
  text-align: justify;
  background-color: var(--pink);
  border-radius: var(--border-radius-md);
  padding: var(--padding-sm) var(--padding-md);
  box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
  transition: var(--transition-slow);
  line-height: 2;
}
article ul {
  list-style-type: disc;
  color: var(--beige);
  padding: 0 2.5%;
  font-size: var(--fontsize-p);
  text-align: center;
  width: var(--width-content);
  margin: 0 auto;
}
article img {
  width: var(--width-logo-img);
  margin: 0 auto;
  border-radius: var(--border-radius-md);
  box-shadow: var(--neuro-shadow-1), var(--neuro-shadow-2);
}
#massage-holistique ul {
  padding: var(--padding-md) 0;
}
#flex {
  padding: var(--padding-lg);
  border-radius: 2px;
}
#flex:hover {
  box-shadow: var(--neuro-shadow-1), var(--neuro-shadow-2);
  transition: var(--transition-fast);
  border-radius: var(--border-radius-sm);
}
/* Bouton retour haut de page */
.backtop {
  width: var(--width-backtop);
  position: fixed;
  right: var(--spacing-xs);
  bottom: var(--padding-md);
  z-index: 1002;
  transition: var(--transition-slow);
  animation: fadeBottom 2s ease-in-out forwards;
}
.backtop a:hover img {
  transition: var(--transition-fast);
  box-shadow: var(--neuro-shadow-1), var(--neuro-shadow-2);
  transform: scale(1.1);
}
.backtop img {
  width: var(--width-full);
  border-radius: var(--border-radius-full);
}
.hidden {
  display: none;
}
.contact-flower {
  display: flex;
  justify-content: space-evenly;
  width: 80%;
  align-items: center;
  margin: 0 auto;
}
.contact-flower img{
  width: 20%;
  margin: 0 auto;
}
.contact-btn {
    box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
    border-radius: var(--border-radius-sm);
    background-color: var(--pink);
    width: max-content;
    text-align: center;
    align-items: center;
    margin: 0 auto;
    padding: 2%;
    transition: var(--transition-fast);
    opacity: 0;
    animation: fadeBottom 2s ease-in-out forwards;
  }
  .art-hide {
    display: none;
    transition: var(--transition-fast);
    z-index: 1002;
    position: absolute;
  }
  .contact-flower:hover article.art-hide {
    display: grid;
    transition: var(--transition-fast);
    animation: apear 2s ease-in-out forwards;
  }
  .contact-flower:hover .contact-btn {
    animation: disapear 2s ease-in-out forwards;
    transition: var(--transition-fast);
  }
  .contact-flower:hover .right-anim {
    animation: disapear 2s ease-in-out forwards;
    transition: var(--transition-fast);
  }
  
.contact-btn:hover {
  box-shadow: var(--neuro-shadow-1), var(--neuro-shadow-2);
  transition: var(--transition-fast);
}
.contact-btn a:hover {
  color: var(--black-color);
  transition: var(--transition-fast);
}
/* Media Queries - Orientation paysage */
@media (orientation: landscape) {
  header,
  footer {
    display: flex;
    justify-content: center;
    flex-direction: row;
    transition: var(--transition-slow);
  }
  header:hover {
    background-color: var(--pink);
    transition: var(--transition-fast);
  }
  #flex {
    display: flex;
  }
  #flex div {
    width: var(--width-content);
    text-align: justify;
    margin: auto;
  }
  #flex img {
    display: flex;
    width: var(--width-content);
    margin: 0 auto;
  }
  article ul li {
    margin: var(--spacing-xl) 0;
    background-color: var(--pink);
    border-radius: var(--border-radius-md);
    box-shadow: var(--neuro-shadow-1), var(--neuro-shadow-2);
    padding: var(--padding-md);
    transition: var(--transition-slow);
  }
  article ul li:hover {
    box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
    transition: var(--transition-slow);
  }
}
/* Media Queries - Orientation portrait */
@media (orientation: portrait) {
  body {
    display: flex;
    flex-direction: column;
  }
  header,
  footer {
    display: flex;
    justify-content: center;
    flex-direction: column;
    box-shadow: none;
    box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
  }
  nav li {
    display: grid;
    overflow: hidden;
  }
  nav ul {
    position: fixed;
    background-color: var(--pink-opa);
    box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
    width: var(--width-full);
    padding: 3% 0;
  }
  nav:hover li {
    display: grid;
    position: static;
    margin: var(--padding-md) auto;
  }
  .logo .left-anim {
    width: 100%;
    display: grid;
    margin: 0 auto;
    overflow: hidden;
    padding-top: 5%;
  }
  .contact-flower img {
    width: 40%;
  }
  article p,
  article ul {
    padding: var(--padding-md) 0;
  }
  article {
    background-color: var(--pink);
    width: 95%;
    margin-top: 15%;
  }
  article ul li {
    width: var(--width-full);
    margin: var(--spacing-large) auto;
    border-radius: var(--border-radius-md);
    padding: var(--padding-lg);
    box-shadow: var(--neuro-shadow-inset-1), var(--neuro-shadow-inset-2);
  }
  article ul li:hover {
    box-shadow: var(--neuro-hover-1), var(--neuro-hover-2);
    transition: var(--transition-fast);
  }
  #flex img {
    width: var(--width-content);
    display: flex;
  }
  nav:hover {
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
    transition: 0s;
  }
  nav:hover > ul,
  footer:hover {
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
    background-color: var(--pink);
    transition: 0.6s;
  }
  .prez {
    margin-top: 15%;
  }
  .important,
  .droit {
    margin-bottom: 5%;
  }
  #btn-contact {
    padding: 5%;
  }
}
/* Animations */
@keyframes fadeBottom{
  from {
    opacity:calc(0);
  }
  to {
    opacity: calc(1);
  }
}
@keyframes apear{
  from {
    opacity:calc(0);
    transform: translateY(-200px);
  }
  to {
    opacity: calc(1);
    
    transform: translateY(0);
  }
}
@keyframes disapear{
  from {
    opacity:calc(1);
  }
  to {
    opacity: calc(0);
  }
}