/*
Theme Name: St Michel Solesmes
Theme URI: 
Author: Agence Keeo
Author URI: https://www.keeo.fr
Description: 
Requires at least: 6.0
Tested up to: 6.4.3
Requires PHP: 5.7
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: stmichel
Tags: 
*/
* {
	box-sizing: border-box;
}
:root {
	scroll-behavior: smooth;
	/* Typography */
	--heading-letterspacing: -0.03em;
	--heading-lineheight: 1.2;

	/* Layout */
	--l-global-padding: 1rem;

	--bd-rad-small: 0.25rem;
	--bd-rad-medium: 0.5rem;
	--bd-rad-large: 1rem;
	--bd-rad-x-large: 1.5rem;

	--c-shadow: rgba(0, 0, 0, 0.12);
}
@media screen and (min-width: 48rem) {
	:root {
		--l-global-padding: 2rem;
	}
}
@media screen and (min-width: 64rem) {
	:root {
		--l-global-padding: 6rem;
	}
}
@media screen and (max-width: 32rem) {
	body {
		--wp--preset--font-size--xx-large: calc(
			1.2 * var(--wp--preset--font-size--large)
		);
		--wp--preset--font-size--huge: calc(
			1.2 * var(--wp--preset--font-size--large)
		);
	}
}
body {
	--l-gap: var(--wp--preset--spacing--40);
}
img {
	display: block;
	max-width: 100%;
	height: auto;
}

/* Layout global */
/* .footer-content,
main {
	max-width: var(--l-site-max-width);
	padding: 0 var(--l-global-padding);
	margin: 0 auto;
} */
/* main {
	padding-top: var(--wp--preset--spacing--50);
}
 */
/* Links & buttons */
a.button,
.quicknav a,
.menu-toggle {
	cursor: pointer;
	font-size: var(--wp--preset--font-size--normal);
	border: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	text-decoration: none;
	padding: 0.625em 1em;
	line-height: 1.25;
	border-radius: var(--bd-rad-medium);
	background-color: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--contrast);
}
a.button:hover,
a.button:focus,
.menu-toggle:hover,
.menu-toggle:focus {
	background-color: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
}
.menu-toggle:hover svg,
.menu-toggle:focus svg {
	fill: var(--wp--preset--color--base);
}

a.button.secondary,
.quicknav a {
	background-color: transparent;
}
a.button.secondary:hover,
a.button.secondary:focus,
.quicknav .current_page_item a,
.quicknav .current_page_parent a,
.quicknav .current-page-ancestor a,
.quicknav a:hover,
.quicknav a:focus {
	background-color: var(--wp--preset--color--contrast-trans);
	color: var(--wp--preset--color--contrast);
}
.menu-toggle {
	position: relative;
	z-index: 2;
	margin-left: 0.5rem;
}
.menu-toggle rect {
	border-radius: 1px;
	transform-origin: left;
	transition: transform 0.3s;
}
.menu-toggle rect:nth-child(1) {
	transform-origin: 0 1px;
}
.menu-toggle rect:nth-child(3) {
	transform-origin: 0 15px;
}
.main-navigation.toggled .menu-toggle rect:nth-child(1) {
	transform: translateX(3.64px) rotate(45deg);
}
.main-navigation.toggled .menu-toggle rect:nth-child(2) {
	transform: scaleX(0);
}
.main-navigation.toggled .menu-toggle rect:nth-child(3) {
	transform: translateX(3.64px) rotate(-45deg);
}

/* Site Header */
.site-header {
	display: flex;
	align-items: center;
	background-color: var(--wp--preset--color--base);
	position: sticky;
	top: 0;
	z-index: 10;
	width: 100%;
	padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--50)
		var(--wp--preset--spacing--20) var(--wp--preset--spacing--30);
	border-bottom: 1px solid var(--wp--preset--color--neutral);
}
.site-branding {
	margin-right: auto;
}
.custom-logo-link {
	display: block;
}
.custom-logo-link img {
	width: 8rem;
}
.quicknav {
	display: none;
}
.menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

.menu ul {
	list-style: none;
	padding: 0;
}
.main-menu > li {
	padding: var(--wp--preset--spacing--30);
	border-bottom: 1px solid var(--wp--preset--color--base-trans);
	margin: 0;
}
.menu > li > button,
.main-menu > li > a {
	display: block;
	border: 0;
	background: none;
	color: var(--wp--preset--color--base);
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--medium);
	letter-spacing: var(--heading-letterspacing);
	text-decoration: none;
	line-height: 1;
	padding: 0;
}
.main-menu > li:hover,
.main-menu > li:focus-within {
	background-color: var(--wp--preset--color--contrast-trans);
}

.menu > li > button {
	width: 100%;
	text-align: left;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--30);
}
.menu > li > button svg {
	width: 1.5em;
	height: 1.5em;
}
.menu > li > button.toggled svg {
	transform: rotate(180deg);
}
.main-menu > li > a,
.main-menu > li > button span {
	transition: transform 0.3s;
}

.main-menu ul {
	margin-top: var(--wp--preset--spacing--20);
}

.main-menu li:last-child {
	margin: 0;
}
.main-menu ul li {
	margin-bottom: var(--wp--preset--spacing--20);
}
.main-menu ul a {
	text-decoration: none;
	color: var(--wp--preset--color--base);
}
.main-menu ul .current-menu-item {
	font-weight: 700;
}
.main-menu ul a:hover,
.main-menu ul a:focus {
	text-decoration: underline;
}

.main-menu-container {
	position: fixed;
	top: 0;
	right: 0;
	height: 100%;
	width: 30rem;
	max-width: 90vw;
	overflow-y: auto;
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	padding: 8rem var(--wp--preset--spacing--40);
	box-shadow: -0.5em 0 1em var(--c-shadow);
	transform: translateX(110%);
	transition: transform 0.6s;
}
.main-menu-container:focus-within,
.main-navigation.toggled .main-menu-container {
	transform: none;
}

/* Submenus */
.main-menu .sub-menu {
	display: none;
}
.main-menu .sub-menu.toggled {
	display: block;
}
@media screen and (min-width: 48rem) {
	.main-menu-container {
		padding: 8rem var(--wp--preset--spacing--70);
	}
	.main-menu li.hide-desktop {
		display: none;
	}
}

@media screen and (min-width: 48rem) {
	.quicknav {
		display: flex;
		flex-shrink: 0;
		gap: 0.5em;
		margin-left: var(--wp--preset--spacing--50);
	}
}

/* Site Footer */
.site-footer {
	background-color: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
}
.site-footer section {
	padding: var(--wp--preset--spacing--50) var(--wp--preset--spacing--40);
}
.site-footer section + section {
	border-top: 1px solid var(--wp--preset--color--base-trans);
}
/* Footer - Rubriques & contact */
.site-footer .custom-logo-link {
	margin: 0 auto;
	width: fit-content;
}
.site-footer .custom-logo-link img {
	width: 9rem;
}
.site-footer .copyright,
.site-footer .coordonnees {
	margin: 0;
	text-align: center;
}
.site-footer .coordonnees p {
	font-size: var(--wp--preset--font-size--small);
	margin: 0;
}
.footer-nav {
	list-style-type: none;
	padding: 0;
	margin: var(--wp--preset--spacing--50) 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--wp--preset--spacing--20);
}
.footer-nav a {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--large);
	line-height: 1;
	letter-spacing: var(--heading-letterspacing);
	font-weight: 400;
	color: var(--wp--preset--color--tertiary);
	text-decoration: none;
}
.footer-nav a:hover,
.footer-nav a:focus {
	color: var(--wp--preset--color--base);
}
/* Footer - Legal */
.footer-legal {
	font-size: var(--wp--preset--font-size--small);
}
.legal-nav {
	padding: 0;
	margin: var(--wp--preset--spacing--40) 0 0;
	list-style: none;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.legal-nav li::after {
	content: "";
	display: inline-block;
	font-size: 0.25rem;
	width: 1em;
	height: 1em;
	display: inline-block;
	border-radius: 100%;
	background-color: currentColor;
	vertical-align: middle;
	margin: 0 var(--wp--preset--spacing--30);
}
.legal-nav li:last-child::after {
	content: unset;
}
.legal-nav a {
	color: inherit;
	text-decoration: none;
}
.legal-nav a:hover,
.legal-nav a:focus {
	text-decoration: underline;
}

@media screen and (min-width: 32rem) {
	.footer-nav {
		flex-direction: row;
		justify-content: center;
		gap: var(--wp--preset--spacing--40);
	}
}
@media screen and (min-width: 48rem) {
	.footer-nav {
		gap: var(--wp--preset--spacing--70);
	}
	.site-footer .copyright {
		text-align: left;
	}
	.footer-legal {
		display: flex;
		justify-content: space-between;
	}
	.legal-nav {
		margin: 0 0 0 var(--wp--preset--spacing--60);
		flex-shrink: 0;
		justify-content: flex-end;
	}
}
@media screen and (min-width: 64rem) {
	.footer-contact {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.site-footer .custom-logo-link {
		margin: 0;
	}
	.site-footer .coordonnees {
		text-align: left;
	}
}
/* Breadcrumbs */
.breadcrumbs {
	color: var(--wp--preset--color--neutral-dark);
	font-size: var(--wp--preset--font-size--small);
	margin: var(--wp--preset--spacing--20) auto;
}
.breadcrumbs ol {
	list-style: none;
	padding: 0;
	margin: 0;
}
.breadcrumbs li {
	display: inline;
}
.breadcrumbs li::after {
	content: " ›";
}
.breadcrumbs li:last-child::after {
	content: unset;
}
.breadcrumbs li:last-child a {
	text-decoration: none;
	color: inherit;
}

/* Posts List */

@media screen and (min-width: 64rem) {
	.actus-header {
		display: grid;
		grid-template-columns: 1fr 2fr;
		gap: var(--l-gap);
		align-items: end;
		border-bottom: 1px solid;
		padding-top: var(--wp--preset--spacing--50);
	}
	.actus-header .categories-selector {
		margin-bottom: 0;
		width: 100%;
		border: 0;
		justify-content: flex-end;
	}
}
.posts-list {
	container-type: inline-size;
}
.blog .posts-list,
.archive.category .posts-list {
	padding-bottom: var(--wp--preset--spacing--70);
}
.posts-list > ul {
	display: grid;
	gap: var(--l-gap);
	margin: 0;
	padding: 0;
	list-style: none;
}
@media (min-width: 782px) {
	.is-vertically-aligned-stretch > .posts-list {
		min-height: 100%;
		display: flex;
	}
}
@container (min-width: 28rem) {
	.posts-list > ul {
		grid-template-columns: 1fr 1fr;
	}
	.posts-list .wide {
		grid-column: span 2;
	}
	.is-vertically-aligned-stretch > .posts-list > ul,
	.is-vertically-aligned-stretch > .posts-list > ul .actu-card {
		min-height: 100%;
	}
}
@container (min-width: 54rem) {
	.posts-list > ul {
		grid-template-columns: 1fr 1fr 1fr;
	}
}

/* Posts */
.categories {
	display: flex;
	padding: 0;
	margin: 0;
	z-index: 1;
	list-style: none;
}
.categories li {
	font-size: var(--wp--preset--font-size--x-small);
	background-color: var(--wp--preset--color--tertiary);
	color: var(--wp--preset--color--contrast);
	padding: 0.25em 0.75em;
	line-height: 1.33;
	border-radius: 1em;
}
.categories a {
	text-decoration: none;
	color: inherit;
}
.posted-on {
	display: block;
	font-size: var(--wp--preset--font-size--x-small);
}
.post-meta {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	align-items: center;
}
.read-more {
	display: inline-flex;
	align-items: center;
	font-size: var(--wp--preset--font-size--x-small);
	gap: 0.5em;
}
.read-more svg {
	background-color: var(--wp--preset--color--secondary);
	fill: var(--wp--preset--color--contrast);
	border-radius: 0.5rem;
	transition:
		background-color 0.3s,
		fill 0.3s;
}
a:hover .read-more svg,
a:focus .read-more svg {
	background-color: var(--wp--preset--color--contrast);
	fill: var(--wp--preset--color--base);
	color: var(--wp--preset--color--base);
}
.read-more use {
	transform-origin: 50% 50%;
}
.read-more.external use {
	transform: rotate(-45deg);
}

aside.related-posts {
	border-top: 1px solid var(--wp--preset--color--neutral-light);
	padding-top: var(--wp--preset--spacing--70);
	padding-bottom: var(--wp--preset--spacing--70);
	margin-top: var(--wp--preset--spacing--70);
}
aside.latest-news {
	background-color: var(--wp--preset--color--contrast-trans);
}

/* Pagination */
.wp-pagenavi {
	display: flex;
	margin: var(--wp--preset--spacing--50);
	align-items: center;
	gap: var(--wp--preset--spacing--20);
	justify-content: center;
}
.wp-pagenavi a {
	text-decoration: none;
	color: inherit;
	padding: 0.25em var(--wp--preset--spacing--20);
}
.wp-pagenavi a:hover,
.wp-pagenavi a:focus,
.wp-pagenavi .current {
	background-color: var(--wp--preset--color--contrast);
	padding: 0.25em var(--wp--preset--spacing--20);
	color: var(--wp--preset--color--base);
	border-radius: 0.25rem;
}

/* Table des matières */

/* Fix scroll - sticky nav */
.wp-block-heading[id] {
	scroll-margin-top: 7rem;
}
.page-toc {
	border-radius: var(--bd-rad-large);
	width: fit-content;
	min-width: 50%;
	position: relative;
}
.simpletoc-title {
	margin: 0 0 0.5em;
	font-size: var(--wp--preset--font-size--m-large);
	line-height: 1.17;
}
.simpletoc-list {
	padding: 0;
	list-style: none;
	font-size: var(--wp--preset--font-size--small);
	margin: 0;
}
body .is-layout-constrained > .page-toc {
	margin-left: 0 !important;
}
.simpletoc-list li {
	margin-bottom: 0.25rem;
}
.simpletoc-list a {
	color: inherit;
	text-decoration: none;
	font-size: var(--wp--preset--font-size--normal);
}
.simpletoc-list a::before {
	content: "";
	background-color: var(--wp--preset--color--secondary);
	background-image: url(./assets/images/icons.svg#arrow-right-link);
	border-radius: var(--bd-rad-medium);
	width: 1.5rem;
	height: 1.5rem;
	margin-right: 0.5em;
	display: inline-block;
	position: relative;
	top: 0.4em;
}
.simpletoc-list a:hover,
.simpletoc-list a:focus {
	text-decoration: underline;
}
.simpletoc-list a:hover::before,
.simpletoc-list a:focus::before {
	background-color: var(--wp--preset--color--base);
	filter: invert(1);
}

/* .has-global-padding {
	padding-left: 0;
	padding-right: 0;
}
 */
/* Filtres catégories */
.cat-title {
	color: var(--wp--preset--color--primary-dark);
	font-size: var(--wp--preset--font-size--huge);
	margin: 0;
}
.categories-selector {
	margin: var(--wp--preset--spacing--50) auto;
	padding: 0.75rem 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--wp--preset--spacing--30);
	list-style: none;
	width: fit-content;
	border-top: 1px solid;
	border-bottom: 1px solid;
}
.categories-selector a {
	color: inherit;
	text-decoration: none;
}
.categories-selector a:hover,
.categories-selector a:focus {
	text-decoration: underline;
}

.categories-selector a.current {
	font-weight: 700;
	color: var(--wp--preset--color--primary-dark);
}
@media screen and (min-width: 32rem) {
	.categories-selector {
		gap: var(--wp--preset--spacing--30) var(--wp--preset--spacing--70);
	}
}

a.arrow-link {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: auto;
	font-family: var(--wp--preset--font-family--heading);
	font-weight: 600;
	text-decoration: none;
	color: inherit;
}
a.arrow-link::before {
	content: "";
	display: inline-block;
	clip-path: path(
		"M9.6,14.3l-.5.5-1.1-1.1.5-.5,3.5-3.5H1v-1.5h11.1l-3.5-3.5-.5-.5,1.1-1.1.5.5,4.8,4.8.5.5-.5.5-4.8,4.8Z"
	);
	background-color: currentColor;
	width: 1em;
	height: 1em;
	transition: transform 0.3s;
}
a.arrow-link:hover::before,
a.arrow-link:focus::before {
	transform: translateX(0.5rem);
}

/* Tables */
.wp-block-table {
	border-radius: var(--bd-rad-large);
	border: 1px solid var(--wp--preset--color--primary-dark);
}
.wp-block-table thead {
	border: 0;
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	overflow: hidden;
}
.wp-block-table td,
.wp-block-table th {
	border: 0;
	border-right: 1px solid var(--wp--preset--color--primary);
	padding: var(--wp--preset--spacing--30);
}
.wp-block-table th {
	border-color: var(--wp--preset--color--base);
}
.wp-block-table td:last-child,
.wp-block-table th:last-child {
	border-right: 0;
}
.wp-block-table tr:nth-child(2n + 1) {
	background-color: var(--wp--preset--color--primary-trans);
}

/* Bugs Gutenberg */
@media (max-width: 600px) {
	.wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
		padding: 0;
	}
}

.wp-block-quote > :first-child {
	margin-top: 0;
}
cite {
	display: block;
}
.wp-block-pullquote cite {
	display: flex;
	justify-content: center;
	align-items: center;
}
.wp-block-pullquote cite::before,
.wp-block-pullquote cite::after {
	content: "";
	display: inline-block;
	margin: 0 0.75em;
	width: 0.25em;
	height: 0.25em;
	background-color: var(--wp--preset--color--primary);
	border-radius: 100%;
}

/* Titles */
.is-style-h4,
.is-style-h5,
.is-style-h6,
.wp-block-heading.is-style-h6,
p.is-style-h6,
h4,
h5,
h6 {
	font-family: var(--wp--preset--font-family--body);
}
.is-style-h5,
h5 {
	font-weight: 500;
}
