


/* === MISE EN PAGE GLOBALE === */

* {
	padding: 0; /* Supprime les paddings par défaut */
	box-sizing: border-box; /* Inclut les paddings et bordures dans les dimensions */
	text-decoration: none; /* Supprime les soulignements des liens */
	list-style: none; /* Supprime les puces des listes */
	scroll-behavior: smooth;
}

body {
  margin: 0;
	color: var(--couleur-fonce); /* Couleur du texte */
	background-color: var(--couleur-clair); /* Couleur de fond */
	align-items: center; /* Centre verticalement (utile en flex) */
	justify-content: center; /* Centre horizontalement */
	font-family: arial, sans-serif; /* Police de base */
	transition: color 1.0s ease-out, background-color 1.0s ease-out;
}


/* === VARIABLES CSS GLOBALES === */

:root {
	--s: 300px; /* Taille des cellules (grille astuces) */
	--g: 10px; /* Gouttière entre les cellules */
	--f: 1.5; /* Facteur de zoom au survol */
	--font-size: 40px; /* Taille de police pour la galerie */
	--couleur-fonce: #FF8A8C; /* Couleur principale */
	--couleur-clair: white; /* Couleur secondaire */
}


/* === IMPORT DES TYPOGRAPHIE === */

@font-face {
  font-family: 'kindora';
  src: url('./font/kindora.otf') format('opentype'),
       url('./font/kindora.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'chillax';
  src: url('./font/chillax.otf') format('opentype'),
		url('./font/chillax.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'montserrat';
  src: url('./font/montserrat.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}


/* === STRUCTURE DES GRANDES SECTIONS === */

.titre-site, .texte-intro, .podcast {
	height: 100vh; /* Hauteur = hauteur de la fenêtre */
}

.astuces {
	height: 50vh; /* Hauteur = hauteur de la fenêtre */
}

.titre-site, .texte-intro, .astuces {
	display: flex; /* Utilise flexbox */
	justify-content: center; /* Centre horizontalement */
	align-items: center; /* Centre verticalement */
}









/* === NAVBAR === */

.navbar {
	font-family: 'chillax', sans-serif; /* Police de caractères pour la navbar */
	padding: 30px; /* Espacement interne autour du contenu */
	height: 120px; /* Hauteur fixe pour stabilité d'affichage */
	display: flex; /* Utilise Flexbox pour aligner horizontalement */
	justify-content: space-between; /* Écarte les éléments au maximum */
	align-items: center; /* Centre verticalement les éléments */
	width: 100%; /* Navbar prend toute la largeur */
	box-sizing: border-box; /* Inclut padding et bordures dans le width */
	position: relative; /* Nécessaire pour positionner les éléments enfants en absolute */
}

.navbar a {
	color: var(--couleur-fonce); /* Couleur des liens */
	background-color: transparent; /* Pas de fond pour les liens */
	text-decoration: none; /* Enlève le soulignement */
}

.navbar .nom {
	font-size: 32px; /* Taille du texte pour le nom */
	font-weight: bold; /* Texte en gras */
	margin-left: 15px;
}

.navbar .nav-links ul {
	display: flex; /* Aligne les liens horizontalement */
	font-size: 18px;
}

.navbar .nav-links ul li {
	margin: 0 30px; /* Espace horizontal entre chaque lien */
}

.navbar .menu-hamburger {
	display: none; /* Caché en desktop */
	position: absolute; /* Positionné par rapport à .navbar */
	top: 50%; /* Centré verticalement */
	right: 30px; /* Décalé du bord droit */
	transform: translateY(-50%); /* Corrige le centrage vertical */
	width: 35px; /* Taille de l'icône hamburger */
	cursor: pointer; /* Curseur en forme de main au survol */
}



/* === Version hamburger === */

@media screen and (max-width: 900px) {

	.navbar {
		padding: 50px; /* Réduit le padding en mobile */
		height: 120px; /* Hauteur fixe pour stabilité d'affichage */
	}

	.navbar .menu-hamburger {
		display: block; /* Affiche le menu hamburger */
		z-index: 1000;
	}

	.navbar .nav-links {
		position: fixed; /* Fixe la position du menu sur tout l'écran */
		top: 0; /* Collé en haut */
		left: 0; /* Collé à gauche */
		width: 100%; /* Prend toute la largeur */
		height: 100vh; /* Prend toute la hauteur visible */
		background-color: rgba(255, 255, 255, 0.1); /* Fond semi-transparent */
		backdrop-filter: blur(10px); /* Floute l'arrière-plan */
		-webkit-backdrop-filter: blur(10px); /* Adpater pour ipad */
		display: flex; /* Flexbox pour aligner contenu */
		flex-direction: column; /* Direction verticale */
		justify-content: center; /* Centre verticalement */
		align-items: center; /* Centre horizontalement */
		transform: translateX(-100%); /* Cacher complètement sur la gauche au départ */
		transition: transform 0.5s ease; /* Animation douce pour le menu */
		z-index: 999; /* Superposition par-dessus le reste */
	}

	.navbar .nav-links.mobile-menu {
		transform: translateX(0); /* Fait glisser le menu pour l'afficher */
	}

	.navbar .nav-links ul {
		flex-direction: column; /* Les liens sont empilés verticalement */
	}

	.navbar .nav-links ul li {
		font-size: 32px;
		margin: 40px 0; /* Espacement vertical entre les liens */
		text-shadow: 2px 2px 5px rgba(0,0,0,0.2); /* ← Ajoute juste une ombre portée */
	}
}



/* === Responsive pour téléphone === */

@media screen and (min-width: 320px) and (max-width: 767px) {

	.navbar .nom {
		font-size: 24px;
		margin-left: -7px;
	}
}

/* === Responsive pour tablette === */

@media screen and (min-width: 768px) and (max-width: 1024px) {

	.navbar .nom {
		font-size: 30px;
		margin-left: -90px;
	}
}









/* === TITRE PRINCIPAL (ANXIETE & UNIVERSITE) === */

.titre-site {
	font-family: 'kindora', sans-serif; /* Police spécifique pour le titre principal */
	position: relative; /* Pour positionner les textes enfants en absolute */
	padding-top: 150px; /* Espace au-dessus pour ne pas coller à la navbar */
	text-align: center; /* Centre le contenu horizontalement */
}

.main-title {
	position: relative; /* Nécessaire pour la position des éléments enfants */
	display: inline-block; /* Permet au titre de ne prendre que sa taille utile */
}

.text-anxiete,
.text-universite,
.text-et {
	position: absolute; /* Positionnement précis par rapport au .main-title */
	left: 50%; /* Place au centre horizontalement */
	white-space: nowrap; /* Empêche le texte de passer à la ligne */
	transform: translateX(-50%); /* Centre parfaitement (décale de moitié la largeur) */
	transition: all 0.5s ease; /* Transition fluide pour toutes les propriétés */
}

.text-anxiete {
	top: -21rem; /* Position verticale par rapport au centre */
	font-size: 100px; /* Grande taille pour impact visuel */
	font-weight: normal; /* Poids normal */
}

.text-universite {
	top: -13rem; /* Moins haut que "anxiété" */
	font-size: 100px; /* Même taille */
	font-weight: normal;
}

.text-et {
	top: -25rem; /* Encore plus haut */
	font-size: 520px; /* Très grand pour l'effet "&" de fond */
	opacity: 0.1; /* Semi-transparent */
	line-height: 1; /* Ligne serrée */
}



/* Responsive pour téléphone */

@media screen and (min-width: 320px) and (max-width: 767px) {
	.text-anxiete {
		top: -19rem; /* Descend encore */
		font-size: 40px; /* Plus petit pour téléphones */
	}

	.text-universite {
		top: -15rem;
		font-size: 40px;
	}

		.text-et {
	top: -24rem; /* Encore plus haut */
	font-size: 380px; /* Très grand pour l'effet "&" de fond */
	opacity: 0.1; /* Semi-transparent */
	line-height: 1; /* Ligne serrée */
}
}

/* Responsive pour tablette */

@media screen and (min-width: 768px) and (max-width: 1024px) {
	.text-anxiete {
		top: -19rem; /* Descend encore */
		font-size: 60px; /* Plus petit pour téléphones */
	}

	.text-universite {
		top: -13rem;
		font-size: 60px;
	}

		.text-et {
	top: -24rem; /* Encore plus haut */
	font-size: 440px; /* Très grand pour l'effet "&" de fond */
	opacity: 0.1; /* Semi-transparent */
	line-height: 1; /* Ligne serrée */
}
}










/* === TEXTE SOUS TITRE PRINCIPAL === */

.texte-intro {
	  position: relative;
	  font-family: "Montserrat";
	  margin-left: 50px;
	  margin-right: 50px;
	  gap: 40px; /* Espace de 20px entre CHAQUE enfant */

		font-size: 27px;
		top: -32rem;
	}

.texte-intro1 {
		align-content: center;
	}





/* Responsive pour téléphone */

@media screen and (min-width: 320px) and (max-width: 767px) {

	.texte-intro {
		top: -26rem; /* Descend encore */
		display: flex;
		flex-direction: column;
		gap: 30px; /* Espace de 20px entre CHAQUE enfant */
		margin-right: 30px;
		margin-top: -70px;
		margin-bottom: -100px;
	}

	.texte-intro1 {
		font-size: 20px; /* Plus petit pour téléphones */
	}

	.texte-intro2 {
		font-size: 20px;
	}
}

/* === Responsive pour tablette === */

@media screen and (min-width: 768px) and (max-width: 1024px) {

	.texte-intro {
		top: -37rem; /* Descend encore */
		margin-right: 30px;
	}

	.texte-intro1 {
		font-size: 25px; /* Plus petit pour téléphones */
	}

	.texte-intro2 {
		font-size: 25px;
		margin-left: 50px;
	}
}

/* Responsive pour petit téléphone */
@media (max-width: 375px) {

	.texte-intro {
		top: -21rem; /* Descend encore */
		display: flex;
		flex-direction: column;
		gap: 30px; /* Espace de 20px entre CHAQUE enfant */
		margin-right: 30px;
		margin-top: -70px;
		margin-bottom: -100px;
	}

	.texte-intro1 {
		font-size: 20px; /* Plus petit pour téléphones */
	}

	.texte-intro2 {
		font-size: 20px;
	}

}









/* === PODCAST (CARROUSEL HORIZONTAL) === */

#podcast-wrapper {
	scroll-margin-top:2em;
	}

/* Flèche */

.podcast-wrapper {
  position: relative;
  top: -40rem; /* <-- ici au lieu de sur .podcast */
  margin-left: 10px;
}


.podcast {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth; /* Effet de défilement fluide */
  padding-right: 60px; /* Laisse un peu de place à droite pour la flèche */
}

.podcast::-webkit-scrollbar {
  display: none;
}



/* Flèche */

.arrow-right {
	font-family: "montserrat";
	font-size: 120px;
  position: absolute;
  right: 1px;
  top: 80%;
  transform: translateY(-50%);
  color: var(--couleur-fonce);
  border-radius: 50%;
  padding: 10px;
}



.item {
	background-color: var(--couleur-fonce);
	display: flex;
	flex-direction: column;
	min-width: 350px;
	height: 520px;
	line-height: 110px;
	margin-right: 15px;
	border-radius: 25px;
}

.episode {
	font-family: 'chillax', sans-serif;
	font-size: 62px;
	color: var(--couleur-clair);
	margin-top: 90px;
	margin-bottom: 70px;
	margin-left: 20px;
	line-height: 3rem;
}



/* Texte sur 2 lignes */

.special {
	font-family: 'chillax', sans-serif;
	font-size: 65px;
	color: var(--couleur-clair);
	margin-top: 40px;
	margin-left: 20px;
	line-height: 3rem;
}

/* Texte pour 2 lignes */

.description2 {
	font-family: 'montserrat', sans-serif;
	color: var(--couleur-clair);
	margin: 0 20px;
	line-height: 1.8rem;
	font-size: 18px;
	margin-top: 90px; /* Colle en bas */
}

.description {
	font-family: 'montserrat', sans-serif;
	color: var(--couleur-clair);
	margin: 0 20px;
	line-height: 1.8rem;
	font-size: 18px;
	margin-top: 20px; /* Colle en bas */
}



/* Responsive pour téléphone */

@media screen and (min-width: 375px) and (max-width: 767px) {

	.podcast-wrapper {
		position: relative;
		top: -27rem; /* Descend encore */
	}

	.arrow-right {
    display: none;
}
}

	/* === Responsive pour tablette === */

@media screen and (min-width: 768px) and (max-width: 1024px) {

	.podcast-wrapper {
		position: relative;
		top: -50rem; /* Descend encore */
	}

	.arrow-right {
  top: 65%;
}
}


/* Responsive pour petit téléphone */
@media (max-width: 375px) {

	.podcast-wrapper {
		position: relative;
		top: -19rem; /* Descend encore */
	}

	.arrow-right {
  top: 75%;
  display: block; /* Car display:none avant */
}
}










/* === ASTUCES === */

#astuces {
	scroll-margin-top:2em;
	}

.gallery {
	position: relative;
	top: 0px;
  display: grid; /* Utilise CSS Grid pour organiser les éléments */
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); /* Crée des colonnes flexibles : min 250px, max prend tout l'espace */
  gap: var(--g); /* Espace entre les cellules (défini dans les variables CSS) */
  padding: 20px; /* Marge intérieure autour de la grille */
  max-width: 1200px; /* Limite la largeur maximale de la galerie */
  margin: 0 auto; /* Centre la galerie horizontalement */
  font-size: var(--font-size); /* Taille de police héritée de la variable globale */
  position: relative; /* Nécessaire pour z-index si besoin de superposer des éléments */
  z-index: 1; /* S'assure que la galerie reste visible par-dessus d'autres éléments */
}


.cellule {
  background-color: var(--couleur-fonce); /* Couleur de fond des cellules */
  font-size: inherit; /* Hérite de la taille de police de .gallery */
  text-align: center; /* Centre le texte horizontalement */
  display: grid; /* Pour centrer le contenu verticalement et horizontalement */
  place-items: center; /* Centre le contenu dans les deux axes */
  border-radius: 25px; /* Coins arrondis */
  margin-bottom: 5px; /* Petit espace sous chaque cellule */
}


.gallery > .cellule {
  width: 100%; /* Prend toute la largeur disponible dans la colonne */
  aspect-ratio: 1; /* Garde un format carré */
  object-fit: cover; /* Ajuste le contenu pour remplir sans déformer */
  cursor: pointer; /* Curseur main au survol */
  transition: transform 0.3s ease, filter 0.3s ease, color 0.3s ease-out, background-color 0.3s ease-out; /* Animations douces */
}


.gallery .cellule:hover {
  filter: grayscale(10%); /* Applique un léger filtre gris */
  transform: scale(var(--f)); /* Zoom selon le facteur défini dans :root */
  z-index: 1; /* Fait passer l’élément au-dessus des autres */
}


.nom {
  font-family: 'chillax', sans-serif; /* Police personnalisée */
  color: var(--couleur-clair); /* Texte en couleur claire */
}



/* === Responsive pour téléphone === */

@media screen and (min-width: 320px) and (max-width: 575px) {

  .gallery {
    grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur petit écran */
    gap: 10px;
    margin-top: -300px;
    max-width: 100%;
  }

  .gallery > .cellule {
    aspect-ratio: 1; /* Garde le format carré même sur mobile */
  }

  .nom {
    font-size: 30px; /* Réduit la taille du texte dans les cellules */
  }

  .astuces {
    display: block;
  }
}

/* === Responsive pour tablette === */

@media screen and (min-width: 576px) and (max-width: 1024px) {

  .gallery {
    grid-template-columns: repeat(2, 1fr); /* 3 colonnes sur tablette */
    gap: 15px;
    padding: 15px;
    max-width: 100%;
    margin-top: -1000px;
  }

  .gallery > .cellule {
    aspect-ratio: 1; /* Garde le format carré même sur mobile */
  }

  .nom {
    font-size: 25px; /* Taille de police intermédiaire */
    padding: 3em 2.5em;
  }
}

/* Responsive pour petit téléphone */
@media (max-width: 375px) {

  .gallery {
    grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur petit écran */
    gap: 10px;
    margin-top: -100px;
    max-width: 100%;
    margin-left: 7px;
  }

  .gallery > .cellule {
    aspect-ratio: 1; /* Garde le format carré même sur mobile */
  }

  .nom {
    font-size: 27px; /* Réduit la taille du texte dans les cellules */
  }

  .astuces {
    display: block;
  }
}

/* === Décalage sur iphone 12 === */

@media screen (max-width: 390px) {

  .gallery {
    grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur petit écran */
    gap: 10px;
    margin-top: -100px;
    max-width: 100%;
    margin-left: 7px;
  }

  .gallery > .cellule {
    aspect-ratio: 1; /* Garde le format carré même sur mobile */
  }

  .nom {
    font-size: 27px; /* Réduit la taille du texte dans les cellules */
  }

  .astuces {
    display: block;
  }
}



/* Enlever la couleur des liens */

.astuces a {
	color: var(--couleur-clair); /* Couleur des liens */
	background-color: var(--couleur-fonce); /* Fond clair */
	background-color: transparent; /* Enlever le fond qui créer boîte */
}










/* LA FIN */

.fin a, .astuces {
	font-family: "chillax";
	font-size: 25px;
	color: var(--couleur-fonce); /* Couleur des liens */
	display: flex;
	flex-direction: column;
	margin-top: 10px;
}








/* === PAGE CARNET MOCHE === */

.fond {
	background-color: #FF8A8C;
	width: 100%;
	height: 100vh; /* pleine hauteur d’écran */
	display: flex;
	flex-direction: column;
	justify-content: center; /* centre verticalement */
	align-items: center;     /* centre horizontalement */
}

.carnet {
	margin-top: 5px;
	width: 400px;
	height: 720px;
}

.texte-clic {
	margin-bottom: 10px;
}

.texte-clic a {
	font-family: "chillax", sans-serif;
	font-size: 30px;
	color: white;
	text-align: center;
	text-decoration: none;
}

/* === Responsive pour téléphone === */

@media screen and (min-width: 320px) and (max-width: 767px) {

.carnet {
	margin-top: -30px;
	width: 320px;
	height: 570px;
}

.texte-clic {
	margin-bottom: 10px;
}

.texte-clic a {
	font-family: "chillax", sans-serif;
	font-size: 25px;
	color: white;
	text-align: center;
	text-decoration: none;
}
}



/* === Responsive pour tablette === */

@media screen and (min-width: 768px) and (max-width: 1024px) {

.carnet {
	margin-top: 5px;
	width: 400px;
	height: 730px;
}

.texte-clic {
	margin-bottom: 10px;
}

.texte-clic a {
	font-family: "chillax", sans-serif;
	font-size: 30px;
	color: white;
	text-align: center;
	text-decoration: none;
}

}




