@import "../swiper.css";

/*
    Sommaire :
    1. Hero
    2. Présentation
    3. Journée portes ouvertes
    4. Coordonnées
    5. Logements
    6. Remerciements
*/

/*
    ==============================
    📱 Mobile
    ==============================
*/

.section:nth-of-type(odd) {
	background-color: var(--color-grey-200);
}

.section:nth-of-type(even) {
	background-color: var(--color-grey-100);
}

.section {
	padding: var(--space-vertical) var(--space-horizontal);
}

.section-container {
	display: grid;
	grid-template-columns: 1fr;
	align-items: center;
	--row-gap: 1.25rem;
	row-gap: var(--row-gap);
	column-gap: 6.25rem;
}

.section h2 {
	margin-bottom: 1.25rem;
}

.text-content + .side-content > h2:first-child,
.side-content + .text-content > h2:first-child {
	margin-top: 1.25rem;
}

.side-content img {
	object-fit: cover;
	aspect-ratio: 16/9;
	border-radius: var(--space-xs);
}

.section li {
	line-height: 1.5rem;
}

:is(.text-content, .side-content) :is(p, ul, li) {
	max-width: 75ch;
}

:is(.text-content, .side-content) :is(p, ul) + :is(p, ul) {
	margin-top: 0.5rem;
}

:is(.text-content, .side-content) li + li {
	margin-top: 0.25rem;
}

.visually-hidden {
	clip-path: inset(50%);
	width: 1px;
	height: 1px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
}

/* 1. Hero */

.hero {
	background-image: url(/assets/images/views/school/bibliotheque-ecole.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.hero-container {
	display: grid;
	gap: 10px;
	background-color: var(--color-grey-900-50);
	padding: var(--space-xl) var(--space-horizontal);
	height: 100%;
	place-items: center;
	text-align: center;
}

.hero-title {
	color: var(--color-grey-100);
}

/* 2. Présentation */

.presentation > .section-container {
	grid-template-rows:
		auto 0.625rem [side-content] auto var(--row-gap)
		[text-content] auto var(--row-gap) [responsables] auto 1fr;
	row-gap: 0; /* On insère des lignes de hauteur var(--row-gap) à la place, pour éviter le gap avant la dernière ligne quand elle fait 0 de hauteur */
}

.presentation .text-content {
	grid-row: text-content;
}

.presentation .side-content {
	grid-row: side-content;
}

.responsables {
	grid-row: responsables;
}

.presentation ul li {
	display: list-item;
	list-style: square;
	color: var(--color-grey-700);
}

.responsables {
	display: flex;
	flex-direction: row;
	justify-content: start;
	align-items: start;
	gap: 1.25rem;
	flex-wrap: wrap;
}

.un-responsable {
	display: grid;
	grid-template-areas: "photo infos";
	flex-direction: column;
	align-items: center;
	line-height: 1.5rem;
	gap: 1.25rem;
}

.un-responsable img {
	grid-area: photo;
	border-radius: 5px;
	object-fit: cover;
	width: 80px;
	height: 80px;
}

.un-responsable figcaption {
	grid-area: infos;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: start;
}

.responsable-nom {
	font-size: calc(var(--font-text) * 1.25);
	color: var(--color-grey-900);
}

.responsable-titre {
	color: var(--color-grey-700);
}

.presentation .side-content {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.presentation .side-img {
	display: none;
}

/* 3. Journée portes ouvertes */

.portes-ouvertes time {
	font-weight: bold;
}

/* 4. Coordonnées */

.coordonnees-infos h3 {
	display: inline;
	margin: 0;
	padding: 0;
	font-size: inherit;
}

.coordonnees-infos h3::after {
	content: " : ";
}

.coordonnees-infos li + li {
	margin-top: 0.5rem;
}

:is(img, video, iframe).side-content,
.side-content :is(.side-img, video, iframe),
.swiper-logements {
	width: 100%;
	height: auto;
	aspect-ratio: 16/9;
	border-radius: var(--space-xs);
	border: none;
	box-shadow: var(--shadow-default);
	object-fit: cover;
}

img.side-content,
video.side-content {
	display: none;
}

:is(.text-content, .side-content) p.link-container {
	margin-top: 1.25rem;
}

/* 5. Logements */

.swiper-container {
	margin: 0;
	min-height: 0; /* Empêche le swiper-container d'être plus large que la page */
}

.swiper-logements .swiper-slide {
	width: 100% !important;
}

.logements-liste {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.logements .text-content,
.logements .side-content {
	align-self: start;
}

.adele-link,
.jpo-link {
	margin-top: 1.25rem;
	max-width: 500px;
	display: inline-block;
}

/* 6. Remerciements */

.section.section-remerciements {
	background-color: var(--color-grey-100);
	border-top: 2px solid var(--color-grey-200);
}

.remerciements {
	text-align: center;
}

.remerciements p {
	margin: auto;
	margin-bottom: 1.25rem;
}

.remerciements img {
	max-height: 55px;
	width: auto;
	margin: 2px;
}

/*
    ==============================
    🖥️ Desktop
    ==============================
*/
@media only screen and (min-width: 1200px) {
	.section-container {
		grid-template-columns: repeat(2, 1fr);
		--row-gap: 3.125rem;
	}

	.text-content + .side-content > h2:first-child,
	.side-content + .text-content > h2:first-child {
		margin-top: 0;
	}

	.text-content {
		grid-column: 1;
	}

	.section:nth-child(odd) .text-content {
		grid-column: 2;
	}

	.side-content {
		grid-column: 2;
		grid-row: 1;
	}

	.logements-proprietaires .side-content {
		position: sticky;
		top: calc(1.5rem + var(-s-header-height) * 1px);
		bottom: 1.5rem;
	}

	.section:nth-child(odd) .side-content {
		grid-column: 1;
	}

	img.side-content,
	video.side-content {
		display: revert;
	}

	.section-centered .section-container {
		grid-template-columns: 1fr 3fr 1fr;
		column-gap: 0;
	}

	.section-centered :is(.text-content, .side-content) {
		grid-column: 2;
	}

	.section-centered h2 {
		text-align: center;
	}

	/* 2. Présentation */

	.presentation > .section-container {
		display: grid;
		grid-template-columns: [text-content] 1fr [side-content] 1fr;
		--row-gap: 3.125rem;
		grid-template-rows:
			auto 1.25rem [text-content-start] 1fr [side-content] auto var(--row-gap)
			[responsables] auto 1fr [text-content-end];
	}

	.presentation .text-content {
		grid-row: text-content-start / text-content-end;
		grid-column: text-content;
	}

	.presentation .side-content {
		align-self: start;
		grid-row: side-content;
	}

	.presentation .side-img {
		display: flex;
	}

	.responsables {
		grid-row: responsables;
		flex-direction: column;
	}

	/* 3. Portes ouvertes */

	.portes-ouvertes .text-content {
		display: flex;
		flex-direction: column;
	}

	.jpo-link {
		align-self: center;
	}

	/* 4. Coordonnées */

	.coordonnees:not(:has(.coordonnees-guide)) .google-map {
		grid-row: 1;
	}

	.google-map {
		grid-column: 2;
		grid-row: 1 / 3;
	}

	/* 5. Logements */

	section:not(.section-centered):nth-of-type(odd).logements .text-content {
		grid-column: 1;
	}

	section:nth-of-type(odd).logements .side-content {
		grid-column: 2;
	}
}
