/*
Theme Name: Codex Alter
Theme URI: https://codexalter.example
Author: Julien Bigot
Description: Thème moderne et vibrant pour site d'art — gros titres en dégradé néon (magenta→violet), accents cyan, mise en page épurée et 100% responsive.
Version: 1.6.0
License: GNU General Public License v2 or later
Text Domain: codex-alter
*/

/* ---------- Variables ---------- */
:root {
	/* Palette Néon Pop */
	--ca-magenta: #ff2d95;
	--ca-violet:  #7a2cff;
	--ca-cyan:    #00e0ff;

	/* Dégradé signature (titres, boutons, traits) */
	--ca-degrade: linear-gradient(100deg, var(--ca-magenta) 0%, var(--ca-violet) 60%, var(--ca-cyan) 130%);

	/* Fond nuit (thème unique) */
	--ca-encre:  #f4f2ff; /* texte clair */
	--ca-texte:  #cbc7e0;
	--ca-gris:   #8d88ad;
	--ca-fond:   #0a0a14; /* nuit profonde légèrement violacée */
	--ca-accent: var(--ca-violet);

	--ca-largeur: 760px;          /* largeur de lecture confortable */
	--ca-marge: clamp(20px, 5vw, 24px); /* marge latérale fluide */
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

html, body {
	margin: 0;
	padding: 0;
	color: var(--ca-texte);
	font-family: "Inter", "Archivo", "Helvetica Neue", Arial, sans-serif;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden; /* évite tout débordement horizontal sur mobile */

	/* Fond nuit avec halos néon */
	background-color: var(--ca-fond);
	background-image:
		radial-gradient(60% 50% at 12% -5%, rgba(255, 45, 149, .22), transparent 70%),
		radial-gradient(55% 48% at 96% 0%,  rgba(0, 224, 255, .20), transparent 70%),
		radial-gradient(50% 45% at 80% 100%, rgba(122, 44, 255, .18), transparent 70%);
	background-repeat: no-repeat;
	background-attachment: fixed;
}

/* Les médias ne dépassent jamais de leur colonne */
img, video, iframe, embed, object {
	max-width: 100%;
	height: auto;
}

/* Les mots/URL très longs passent à la ligne au lieu de pousser la page */
.ca-content { overflow-wrap: break-word; word-wrap: break-word; }

a { color: inherit; }
img { max-width: 100%; height: auto; }

/* ---------- En-tête du site ---------- */
.ca-site-header {
	max-width: var(--ca-largeur);
	margin: 0 auto;
	padding: 40px var(--ca-marge) 0;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	align-items: center;
}

.ca-site-nav a {
	text-decoration: none;
	font-weight: 600;
	font-size: .9rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--ca-gris);
	margin-left: 22px;
}

.ca-site-nav a:hover { color: var(--ca-encre); }

/* ---------- Page ---------- */
.ca-page {
	max-width: var(--ca-largeur);
	margin: 0 auto;
	padding: clamp(56px, 9vw, 80px) var(--ca-marge) clamp(80px, 14vw, 120px);
}

/* Variante large : page du blog (grille masonry) */
.ca-page--wide { max-width: 1100px; }

.ca-header { margin-bottom: 56px; }

/* En-tête centré (page du blog) : on retire le trait de gauche */
.ca-header--center { text-align: center; }
.ca-header--center::after { margin-left: auto; margin-right: auto; }

.ca-title {
	font-size: clamp(2.8rem, 7vw, 4.8rem);
	font-weight: 900;
	letter-spacing: -0.03em;
	line-height: 1.0;
	text-transform: uppercase;
	margin: 0;

	/* Dégradé néon appliqué au texte */
	background: var(--ca-degrade);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: var(--ca-cyan); /* repli si le navigateur ne gère pas le clip */
}

/* Titre de l'article (single) : sous le grand CODEX ALTER, plus discret */
.ca-post-title {
	font-size: clamp(1.6rem, 4vw, 2.2rem);
	font-weight: 800;
	letter-spacing: -0.01em;
	line-height: 1.2;
	color: var(--ca-encre);
	margin: 0 0 28px;
}

.ca-post-title::after {
	content: "";
	display: block;
	width: 56px;
	height: 4px;
	border-radius: 999px;
	margin-top: 14px;
	background: var(--ca-degrade);
}

.ca-subtitle {
	margin: 20px 0 0;
	font-size: clamp(1rem, 2.2vw, 1.35rem);
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: #b89bff;
}

.ca-header::after {
	content: "";
	display: block;
	width: 88px;
	height: 5px;
	border-radius: 999px;
	margin-top: 32px;
	background: var(--ca-degrade);
}

/* ---------- Contenu ---------- */
.ca-content { font-size: 1.08rem; }
.ca-content > * + * { margin-top: 1.4em; }

.ca-content h2 {
	font-size: 1.8rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	margin-top: 2.4em;
	color: var(--ca-encre);
	position: relative;
	padding-left: 18px;
}

/* Petite barre néon devant les titres de section */
.ca-content h2::before {
	content: "";
	position: absolute;
	left: 0;
	top: .15em;
	bottom: .15em;
	width: 5px;
	border-radius: 999px;
	background: var(--ca-degrade);
}

.ca-content h3 {
	font-size: 1.3rem;
	font-weight: 700;
	margin-top: 2em;
	color: #b89bff;
}

.ca-content a {
	color: #7ce7ff;
	font-weight: 600;
	text-decoration: underline;
	text-decoration-color: var(--ca-magenta);
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
	transition: color .15s ease;
}

.ca-content a:hover { color: var(--ca-magenta); }

.ca-content img { border-radius: 6px; }

/* ---------- Boutons ---------- */
.ca-content .wp-block-button__link,
.ca-bouton {
	display: inline-block;
	background: var(--ca-degrade);
	background-size: 160% 160%;
	background-position: 0% 50%;
	color: #fff;
	padding: 15px 32px;
	border-radius: 999px;
	font-weight: 800;
	letter-spacing: 0.02em;
	text-decoration: none;
	box-shadow: 0 10px 24px -10px rgba(122, 44, 255, .55);
	transition: transform .18s ease, background-position .4s ease, box-shadow .18s ease;
}

.ca-content .wp-block-button__link:hover,
.ca-bouton:hover {
	transform: translateY(-2px);
	background-position: 100% 50%;
	box-shadow: 0 14px 30px -10px rgba(255, 45, 149, .6);
}

/* ---------- Blog : grille masonry (titres seuls) ---------- */
.ca-masonry {
	columns: 3;
	column-gap: 22px;
}

.ca-card {
	display: block;
	break-inside: avoid;
	margin: 0 0 22px;
	padding: 30px 26px;
	border-radius: 16px;
	background: rgba(255, 255, 255, .035);
	border: 1px solid rgba(255, 255, 255, .09);
	text-decoration: none;
	transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.ca-card:hover {
	transform: translateY(-3px);
	border-color: transparent;
	background: rgba(122, 44, 255, .12);
	box-shadow: 0 16px 40px -16px rgba(122, 44, 255, .65);
}

.ca-card-title {
	font-size: 1.35rem;
	font-weight: 800;
	line-height: 1.25;
	letter-spacing: -0.01em;
	color: var(--ca-encre);
}

.ca-card:hover .ca-card-title {
	background: var(--ca-degrade);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* Pagination */
.ca-page .pagination,
.navigation.pagination {
	margin-top: 48px;
	display: flex;
	justify-content: center;
}

.ca-page .nav-links {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: center;
}

.ca-page .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 12px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .12);
	color: var(--ca-encre);
	text-decoration: none;
	font-weight: 700;
	transition: border-color .15s ease, color .15s ease;
}

.ca-page .page-numbers:hover { border-color: var(--ca-violet); color: #fff; }
.ca-page .page-numbers.current {
	border-color: transparent;
	background: var(--ca-degrade);
	color: #fff;
}

/* ---------- Pied de page ---------- */
.ca-site-footer {
	max-width: var(--ca-largeur);
	margin: 0 auto;
	padding: 40px var(--ca-marge) 64px;
	border-top: 1px solid rgba(255, 255, 255, .12);
	text-align: center;
	color: var(--ca-gris);
	font-size: .82rem;
}

.ca-social {
	margin-bottom: 16px;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 18px;
}

.ca-social-icone {
	display: inline-flex;
	color: var(--ca-violet); /* teinte néon au repos */
	transition: transform .15s ease, color .15s ease;
}

.ca-social-icone svg {
	width: 26px;
	height: 26px;
	display: block;
}

.ca-social-icone:hover { transform: translateY(-2px) scale(1.12); }

/* Couleurs officielles des marques au survol */
.ca-social-bluesky:hover   { color: #0285FF; }
.ca-social-instagram:hover { color: #E1306C; }
.ca-social-patreon:hover   { color: #FF424D; }

/* ===================================================================
   RESPONSIVE — adapté du grand écran au mobile
   La typo et les marges sont déjà fluides (clamp). Les paliers ci-dessous
   ajustent la mise en page là où c'est nécessaire.
   =================================================================== */

/* --- Très grand écran : on laisse un peu plus de respiration --- */
@media (min-width: 1400px) {
	:root { --ca-largeur: 820px; }
}

/* --- Tablette (paysage / petit portable) --- */
@media (max-width: 900px) {
	.ca-content h2 { margin-top: 2em; }
	.ca-masonry { columns: 2; }
}

/* --- Masonry sur une colonne (petit écran) --- */
@media (max-width: 600px) {
	.ca-masonry { columns: 1; }
}

/* --- Tablette portrait / grand mobile --- */
@media (max-width: 700px) {
	.ca-site-header {
		justify-content: center;
		text-align: center;
	}
	.ca-site-nav {
		width: 100%;
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
	}
	.ca-site-nav a:first-child { margin-left: 0; }
}

/* --- Mobile --- */
@media (max-width: 480px) {
	.ca-site-nav a { margin: 4px 10px; }
	.ca-content { font-size: 1rem; }
	/* Boutons pleine largeur, plus faciles à toucher */
	.ca-content .wp-block-button__link,
	.ca-bouton {
		display: block;
		width: 100%;
		text-align: center;
		padding: 16px 24px;
	}
}

/* --- Très petit mobile --- */
@media (max-width: 360px) {
	.ca-subtitle { letter-spacing: 0.12em; }
}

/* --- Cibles tactiles : marge confortable sur écrans sans souris --- */
@media (hover: none) and (pointer: coarse) {
	.ca-site-nav a,
	.ca-social a { padding: 6px 4px; }
}

/* --- Respect de la préférence « animations réduites » --- */
@media (prefers-reduced-motion: reduce) {
	* {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
	}
}

