/*
 * TapisInfo — main.css
 * Chargé en async après le critical CSS inline.
 * Toute la styleguide est ici.
 */

/* --- Reset léger --- */
figure, blockquote { margin: 0 0 1.5em; }
hr { border: 0; border-top: 1px solid var(--ti-border); margin: 3em 0; }
input, textarea, button, select { font: inherit; }
button { cursor: pointer; }

/* --- Screen reader --- */
.screen-reader-text { position: absolute; left: -10000px; top: auto; width: 1px; height: 1px; overflow: hidden; }

/* --- Boutons --- */
.ti-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	border-radius: var(--ti-radius);
	font-weight: 600;
	text-decoration: none;
	font-size: 15px;
	transition: transform .15s, background .15s;
	border: 1px solid transparent;
}
.ti-btn:hover { transform: translateY(-1px); }
.ti-btn-primary { background: var(--ti-accent); color: #fff; }
.ti-btn-primary:hover { background: #9d6330; color: #fff; }
.ti-btn-ghost { background: transparent; color: var(--ti-text); border-color: var(--ti-border); }
.ti-btn-ghost:hover { background: var(--ti-soft); color: var(--ti-text); }

/* --- Hero homepage --- */
.ti-hero {
	padding: 64px 20px 48px;
	background: linear-gradient(180deg, var(--ti-soft) 0%, #fff 100%);
	text-align: center;
}
.ti-hero h1 { max-width: 800px; margin: 0 auto .5em; }
.ti-hero .ti-lede {
	max-width: 680px;
	margin: 0 auto 1.8em;
	font-size: 18px;
	color: var(--ti-muted);
}
.ti-hero-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* --- Silos accueil --- */
.ti-silos { padding: 48px 20px; }
.ti-silo-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 20px;
}
.ti-silo-card {
	display: block;
	padding: 32px;
	border: 1px solid var(--ti-border);
	border-radius: var(--ti-radius);
	background: #fff;
	text-decoration: none;
	color: var(--ti-text);
	transition: border-color .15s, transform .15s, box-shadow .15s;
	position: relative;
}
.ti-silo-card:hover {
	border-color: var(--ti-accent);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px -12px rgba(0,0,0,.12);
}
.ti-silo-card h2 { margin: 0 0 .4em; font-size: 1.5rem; }
.ti-silo-card p { color: var(--ti-muted); margin: 0 0 1em; font-size: 15px; }
.ti-silo-arrow { color: var(--ti-accent); font-weight: 700; }

/* --- Latest homepage --- */
.ti-latest { padding: 48px 20px 80px; }
.ti-latest > h2 { margin-bottom: 1.5em; }

/* --- Card grid --- */
.ti-card-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 28px;
}
.ti-card {
	background: #fff;
	border: 1px solid var(--ti-border);
	border-radius: var(--ti-radius);
	overflow: hidden;
	transition: transform .15s, box-shadow .15s;
	display: flex;
	flex-direction: column;
}
.ti-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px -12px rgba(0,0,0,.12);
}
.ti-card-media { display: block; aspect-ratio: 3/2; overflow: hidden; background: var(--ti-soft); }
.ti-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.ti-card:hover .ti-card-media img { transform: scale(1.03); }
.ti-card-body { padding: 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.ti-card-cat {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--ti-accent);
}
.ti-card-title { margin: 0; font-size: 1.1rem; line-height: 1.35; }
.ti-card-title a { color: var(--ti-text); text-decoration: none; }
.ti-card-title a:hover { color: var(--ti-accent); }
.ti-card-excerpt { margin: 0; color: var(--ti-muted); font-size: 14px; line-height: 1.5; }

/* --- Archive / Category --- */
.ti-archive { padding: 32px 20px 80px; }
.ti-archive-header { margin-bottom: 40px; }
.ti-archive-desc { color: var(--ti-muted); font-size: 17px; max-width: 780px; line-height: 1.7; }
.ti-archive-desc p:first-child::first-letter { font-size: 1.4em; font-weight: 700; color: var(--ti-accent); }
.ti-archive-posts-title { margin-top: 2em; margin-bottom: 1em; font-size: 1.3rem; color: var(--ti-muted); }

/* --- Subcategories grid --- */
.ti-subcats { margin-bottom: 48px; }
.ti-subcats > h2 { font-size: 1.2rem; color: var(--ti-muted); margin-bottom: 1em; }
.ti-subcat-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 12px;
}
.ti-subcat {
	display: flex;
	flex-direction: column;
	padding: 16px 18px;
	background: var(--ti-soft);
	border-radius: var(--ti-radius);
	text-decoration: none;
	color: var(--ti-text);
	transition: background .15s;
}
.ti-subcat:hover { background: #ede5d7; color: var(--ti-text); }
.ti-subcat-name { font-weight: 600; }
.ti-subcat-count { font-size: 13px; color: var(--ti-muted); margin-top: 2px; }

/* --- Breadcrumbs --- */
.ti-breadcrumbs { margin: 0 0 28px; font-size: 14px; color: var(--ti-muted); }
.ti-breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.ti-breadcrumbs li:not(:last-child)::after { content: "›"; margin-left: 6px; opacity: .5; }
.ti-breadcrumbs a { color: var(--ti-muted); text-decoration: none; }
.ti-breadcrumbs a:hover { color: var(--ti-accent); }
.ti-breadcrumbs li[aria-current] { color: var(--ti-text); }

/* --- Single post --- */
.ti-single-inner { padding: 28px 20px 80px; }
.ti-single-header { max-width: 780px; margin: 0 auto 32px; }
.ti-single-cat {
	display: inline-block;
	margin-bottom: 14px;
	color: var(--ti-accent);
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
	text-decoration: none;
}
.ti-post-meta { color: var(--ti-muted); font-size: 14px; margin-top: 12px; }
.ti-single-featured { max-width: 1200px; margin: 0 auto 48px; }
.ti-single-featured img { width: 100%; border-radius: var(--ti-radius); }
.ti-single-featured figcaption { text-align: center; font-size: 13px; color: var(--ti-muted); margin-top: 8px; }

/* --- Prose (contenu éditorial) --- */
.ti-prose { max-width: 720px; margin: 0 auto; font-size: 18px; line-height: 1.75; }
.ti-prose h2 { margin-top: 2em; font-size: 1.6rem; }
.ti-prose h3 { margin-top: 1.6em; font-size: 1.25rem; }
.ti-prose p, .ti-prose ul, .ti-prose ol, .ti-prose blockquote { margin-bottom: 1.3em; }
.ti-prose ul, .ti-prose ol { padding-left: 1.5em; }
.ti-prose li { margin-bottom: .5em; }
.ti-prose img { border-radius: var(--ti-radius); margin: 1.5em 0; }
.ti-prose blockquote {
	padding: 8px 24px;
	border-left: 3px solid var(--ti-accent);
	background: var(--ti-soft);
	font-style: italic;
	color: var(--ti-muted);
	border-radius: 0 var(--ti-radius) var(--ti-radius) 0;
}
.ti-prose code {
	background: var(--ti-soft);
	padding: 2px 6px;
	border-radius: 3px;
	font-size: .9em;
}
.ti-prose pre {
	background: #1a1a1a;
	color: #f0f0f0;
	padding: 16px;
	border-radius: var(--ti-radius);
	overflow-x: auto;
	font-size: 14px;
}
.ti-prose pre code { background: none; padding: 0; }
.ti-prose table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.5em 0;
	font-size: 15px;
}
.ti-prose th, .ti-prose td {
	padding: 10px 12px;
	border: 1px solid var(--ti-border);
	text-align: left;
}
.ti-prose th { background: var(--ti-soft); font-weight: 600; }

/* --- Tags --- */
.ti-tags-wrap { max-width: 720px; margin: 40px auto 0; padding: 24px 0; border-top: 1px solid var(--ti-border); font-size: 14px; }
.ti-tags-label { color: var(--ti-muted); margin-right: 8px; }
.ti-tags { display: inline-flex; flex-wrap: wrap; gap: 6px; list-style: none; padding: 0; margin: 0; }
.ti-tags a {
	display: inline-block;
	padding: 4px 10px;
	background: var(--ti-soft);
	border-radius: 999px;
	text-decoration: none;
	color: var(--ti-muted);
	font-size: 13px;
}
.ti-tags a:hover { background: var(--ti-accent); color: #fff; }

/* --- Related --- */
.ti-related { max-width: 1200px; margin: 64px auto 0; padding-top: 32px; border-top: 1px solid var(--ti-border); }
.ti-related > h2 { margin-bottom: 1em; }

/* --- Pagination --- */
.ti-pagination { margin-top: 48px; display: flex; justify-content: center; }
.ti-pagination ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 6px; }
.ti-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border: 1px solid var(--ti-border);
	border-radius: var(--ti-radius);
	text-decoration: none;
	color: var(--ti-text);
	font-size: 14px;
}
.ti-pagination .page-numbers:hover,
.ti-pagination .page-numbers.current {
	background: var(--ti-accent);
	color: #fff;
	border-color: var(--ti-accent);
}

/* --- Search form --- */
.ti-search-form {
	display: flex;
	gap: 8px;
	max-width: 560px;
	margin: 16px 0;
}
.ti-search-input {
	flex: 1;
	padding: 10px 14px;
	border: 1px solid var(--ti-border);
	border-radius: var(--ti-radius);
	font-size: 15px;
}
.ti-search-input:focus { outline: 2px solid var(--ti-accent); outline-offset: -1px; }
.ti-search-submit {
	padding: 10px 20px;
	background: var(--ti-text);
	color: #fff;
	border: 0;
	border-radius: var(--ti-radius);
	font-weight: 600;
}

/* --- 404 / suggest --- */
.ti-404 { max-width: 720px; margin: 32px auto 0; }
.ti-suggest { list-style: none; padding: 0; margin: 0 0 2em; display: flex; flex-direction: column; gap: 8px; }
.ti-suggest a {
	display: block;
	padding: 14px 18px;
	background: var(--ti-soft);
	border-radius: var(--ti-radius);
	text-decoration: none;
	color: var(--ti-text);
	font-weight: 500;
}
.ti-suggest a:hover { background: var(--ti-accent); color: #fff; }

/* --- Footer --- */
.ti-site-footer {
	margin-top: 80px;
	background: #1a1a1a;
	color: #d9d9d9;
}
.ti-footer-inner {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 40px;
	padding: 56px 20px 32px;
}
.ti-footer-title { color: #fff; font-size: 1rem; margin: 0 0 1em; text-transform: uppercase; letter-spacing: .04em; }
.ti-site-footer ul { list-style: none; padding: 0; margin: 0; }
.ti-site-footer li { margin-bottom: .5em; }
.ti-site-footer a { color: #d9d9d9; text-decoration: none; }
.ti-site-footer a:hover { color: #fff; }
.ti-footer-bottom {
	border-top: 1px solid #333;
	padding: 20px 0;
	font-size: 13px;
	color: #888;
}
.ti-footer-bottom .ti-container { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.ti-footer-bottom p { margin: 0; }
.ti-footer-bottom ul { display: flex; gap: 16px; }

/* --- Mobile nav --- */
@media (max-width: 859px) {
	.ti-nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: #fff;
		border-bottom: 1px solid var(--ti-border);
		padding: 16px 20px;
	}
	.ti-nav.is-open { display: block; }
	.ti-nav ul { flex-direction: column; gap: 12px; }
}

/* --- Print --- */
@media print {
	.ti-site-header, .ti-site-footer, .ti-related, .ti-tags-wrap, .ti-breadcrumbs, .ti-hero-cta { display: none; }
	.ti-prose { max-width: 100%; font-size: 12pt; }
}

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* --- Dark mode preference (basique, optionnel) --- */
@media (prefers-color-scheme: dark) {
	/* Laissé désactivé volontairement : on veut un look cohérent éditorial.
	   Activer via un DfDarkMode plugin dédié si souhaité. */
}
