/* ==========================================================================
   Fenisol Blog — feuille de style principale
   Couleurs prélevées sur les captures du site (header slate-blue, logo doré,
   footer noir & blanc).
   ========================================================================== */

:root {
	--fen-header: #4a5c74;        /* slate-blue du header (prélevé) */
	--fen-header-dark: #41526a;
	--fen-gold: #cdab5e;          /* doré du logo */
	--fen-gold-soft: #e6cf8a;
	--fen-black: #000000;
	--fen-ink: #16181c;           /* texte principal */
	--fen-muted: #5d636e;         /* texte secondaire */
	--fen-line: #e7e8ea;
	--fen-bg: #ffffff;
	--fen-bg-alt: #f5f6f8;
	--fen-radius: 14px;
	--fen-radius-pill: 999px;
	--fen-maxw: 1180px;
	--fen-font: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	--fen-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
}

/* --- Base --- */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--fen-font);
	font-weight: 400;
	color: var(--fen-ink);
	background: var(--fen-bg);
	line-height: 1.65;
	font-size: 17px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--fen-ink); text-decoration: none; transition: color .18s ease, opacity .18s ease; }
a:hover { color: var(--fen-gold); }
h1, h2, h3, h4 { line-height: 1.18; font-weight: 700; color: var(--fen-ink); }

.container { max-width: var(--fen-maxw); margin: 0 auto; padding: 0 24px; }

.screen-reader-text {
	position: absolute !important; width: 1px; height: 1px; overflow: hidden;
	clip: rect(1px,1px,1px,1px); white-space: nowrap; border: 0; padding: 0; margin: -1px;
}
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 12px; top: 12px; background: #fff; padding: 10px 16px; z-index: 1000; border-radius: 8px; }

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header {
	position: sticky; top: 0; z-index: 200;
	background: var(--fen-header);
	transition: box-shadow .2s ease, background .2s ease;
}
.site-header.is-scrolled { box-shadow: 0 6px 24px rgba(0,0,0,.18); }
.header-inner {
	max-width: var(--fen-maxw);
	margin: 0 auto;
	padding: 14px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
.fenisol-logo { display: inline-flex; align-items: center; }
.fenisol-logo-img { height: 56px; width: auto; }

/* Navigation */
.primary-nav .menu {
	list-style: none; margin: 0; padding: 0;
	display: flex; align-items: center; gap: 30px; flex-wrap: wrap;
	justify-content: flex-end;
}
.primary-nav .menu > li > a {
	color: #fff;
	font-weight: 500;
	font-size: 16px;
	letter-spacing: .2px;
	padding: 8px 2px;
	position: relative;
	display: inline-block;
}
.primary-nav .menu > li > a:hover { color: #fff; opacity: .85; }
/* onglet actif : surlignage doré */
.primary-nav .menu > li.current > a,
.primary-nav .menu > li > a:hover {
	color: #fff;
}
.primary-nav .menu > li.current > a::after,
.primary-nav .menu > li > a:hover::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: 0;
	height: 2px; background: var(--fen-gold); border-radius: 2px;
}
.primary-nav .menu > li.current > a { font-weight: 600; }

/* Sous-menu déroulant */
.menu-item.has-children { position: relative; }
.submenu {
	list-style: none; margin: 0; padding: 8px 0;
	position: absolute; top: 100%; left: 0; min-width: 240px;
	background: #fff; border-radius: 10px;
	box-shadow: 0 16px 40px rgba(0,0,0,.16);
	opacity: 0; visibility: hidden; transform: translateY(8px);
	transition: all .18s ease; z-index: 50;
}
.menu-item.has-children:hover .submenu,
.menu-item.has-children:focus-within .submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.submenu li a { display: block; padding: 9px 18px; color: var(--fen-ink); font-size: 15px; }
.submenu li a:hover { background: var(--fen-bg-alt); color: var(--fen-gold); }
.submenu-toggle {
	display: none; background: none; border: 0; color: #fff;
	font-size: 22px; line-height: 1; cursor: pointer; padding: 0 8px;
}

/* Bouton hamburger */
.nav-toggle {
	display: none; flex-direction: column; gap: 5px;
	background: none; border: 0; cursor: pointer; padding: 8px;
}
.nav-toggle-bar { width: 26px; height: 2px; background: #fff; border-radius: 2px; transition: .2s; }

/* ==========================================================================
   ZONE DE CONTENU
   ========================================================================== */
.site-content { display: block; min-height: 50vh; }

.page-hero {
	background: var(--fen-bg-alt);
	border-bottom: 1px solid var(--fen-line);
	padding: 54px 0 48px;
	text-align: center;
}
.page-hero-title { font-size: clamp(30px, 5vw, 46px); margin: 0; }
.page-hero-title span { color: var(--fen-gold); }
.page-hero-sub { max-width: 640px; margin: 14px auto 0; color: var(--fen-muted); }

.content-with-sidebar {
	display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 48px;
	padding-top: 56px; padding-bottom: 72px; align-items: start;
}
.main-column { min-width: 0; }

/* Grille d'articles */
.post-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 32px; }
.post-card {
	background: #fff; border: 1px solid var(--fen-line); border-radius: var(--fen-radius);
	overflow: hidden; display: flex; flex-direction: column;
	transition: transform .2s ease, box-shadow .2s ease;
}
.post-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0,0,0,.10); }
.post-card-media { display: block; aspect-ratio: 16 / 10; background: var(--fen-header); overflow: hidden; }
.post-card-media img { width: 100%; height: 100%; object-fit: cover; }
.post-card-placeholder {
	display: flex; align-items: center; justify-content: center; height: 100%;
	color: var(--fen-gold-soft); font-family: var(--fen-serif); font-size: 28px; opacity: .55;
}
.post-card-body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 10px; }
.post-meta { color: var(--fen-muted); font-size: 13px; letter-spacing: .4px; text-transform: uppercase; margin: 0; }
.post-card-title { font-size: 21px; margin: 0; }
.post-card-title a { color: var(--fen-ink); }
.post-card-title a:hover { color: var(--fen-gold); }
.post-card-excerpt { color: var(--fen-muted); font-size: 15.5px; }
.read-more { margin-top: 4px; color: var(--fen-gold); font-weight: 600; font-size: 15px; }

/* Article seul */
.single-post { background: #fff; }
.single-header { margin-bottom: 24px; }
.single-title { font-size: clamp(28px, 4.5vw, 42px); margin: 6px 0 0; }
.single-thumb { border-radius: var(--fen-radius); overflow: hidden; margin-bottom: 30px; }
.single-content { font-size: 17px; }
.single-content p { margin: 0 0 1.25em; }
.single-content h2 { font-size: 27px; margin: 1.6em 0 .5em; }
.single-content h3 { font-size: 22px; margin: 1.4em 0 .5em; }
.single-content a { color: var(--fen-gold); text-decoration: underline; text-underline-offset: 3px; }
.single-content img { border-radius: 10px; margin: 1em 0; }
.single-content blockquote {
	border-left: 4px solid var(--fen-gold); margin: 1.4em 0; padding: .4em 1.2em;
	color: var(--fen-muted); font-style: italic; background: var(--fen-bg-alt); border-radius: 0 10px 10px 0;
}
.single-content ul, .single-content ol { padding-left: 1.4em; margin: 0 0 1.25em; }
.single-tags { margin-top: 30px; color: var(--fen-muted); font-size: 14px; }
.single-tags a { color: var(--fen-muted); }
.tags-label { font-weight: 600; color: var(--fen-ink); }

.post-nav {
	display: flex; justify-content: space-between; gap: 20px;
	margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--fen-line); font-weight: 500;
}

/* Résultats de recherche */
.search-item { padding: 22px 0; border-bottom: 1px solid var(--fen-line); }
.search-item-title { font-size: 22px; margin: 6px 0 8px; }
.search-item-excerpt { color: var(--fen-muted); }

.no-posts { color: var(--fen-muted); padding: 30px 0; }

/* Pagination */
.pagination { margin-top: 44px; }
.pagination .nav-links { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 42px; height: 42px; padding: 0 12px;
	border: 1px solid var(--fen-line); border-radius: 10px; color: var(--fen-ink); font-weight: 500;
}
.pagination .page-numbers.current { background: var(--fen-black); color: #fff; border-color: var(--fen-black); }
.pagination .page-numbers:hover { border-color: var(--fen-black); color: var(--fen-black); }
.pagination .page-numbers.current:hover { color: #fff; }

/* ==========================================================================
   SIDEBAR
   ========================================================================== */
.sidebar { display: flex; flex-direction: column; gap: 26px; position: sticky; top: 100px; }
.widget {
	background: #fff; border: 1px solid var(--fen-line);
	border-radius: var(--fen-radius); padding: 22px 22px 24px;
}
.widget-title { font-size: 16px; text-transform: uppercase; letter-spacing: .6px; margin: 0 0 14px; }
.widget ul { list-style: none; margin: 0; padding: 0; }
.widget-recent li, .widget-categories li { padding: 8px 0; border-bottom: 1px solid var(--fen-line); }
.widget-recent li:last-child, .widget-categories li:last-child { border-bottom: 0; }
.widget-recent a { display: block; font-weight: 500; }
.widget-date { display: block; color: var(--fen-muted); font-size: 12.5px; margin-top: 2px; }
.widget-categories a { color: var(--fen-ink); }
.widget-categories a:hover { color: var(--fen-gold); }

/* Formulaire de recherche */
.search-form { display: flex; gap: 8px; }
.search-field {
	flex: 1; padding: 11px 14px; border: 1px solid var(--fen-line);
	border-radius: 10px; font: inherit; font-size: 15px; outline: none;
}
.search-field:focus { border-color: var(--fen-header); }
.search-submit {
	background: var(--fen-black); color: #fff; border: 0; border-radius: 10px;
	padding: 0 18px; font: inherit; font-weight: 600; cursor: pointer;
}
.search-submit:hover { opacity: .88; }

/* ==========================================================================
   BOUTONS
   ========================================================================== */
.btn-outline, .btn-dark, .btn-dark-outline {
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--fen-radius-pill); font-weight: 600; font-size: 16px;
	padding: 14px 30px; cursor: pointer; transition: all .18s ease; border: 2px solid transparent;
}
.btn-outline { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.btn-outline:hover { background: #fff; color: var(--fen-black); border-color: #fff; }
.btn-dark { background: var(--fen-black); color: #fff; }
.btn-dark:hover { color: #fff; opacity: .88; }
.btn-dark-outline { background: transparent; color: var(--fen-black); border-color: var(--fen-black); }
.btn-dark-outline:hover { background: var(--fen-black); color: #fff; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer-cta { background: var(--fen-black); color: #fff; }
.footer-cta-inner {
	max-width: var(--fen-maxw); margin: 0 auto; padding: 40px 24px;
	display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap;
}
.footer-cta-title { color: #fff; font-size: clamp(28px, 4vw, 44px); margin: 0; font-weight: 700; }

.site-footer { background: #fff; color: var(--fen-ink); }
.footer-inner {
	max-width: var(--fen-maxw); margin: 0 auto; padding: 64px 24px 40px;
	display: grid; grid-template-columns: 1.3fr 1fr 1fr 1.2fr; gap: 40px;
}
.footer-about p { color: var(--fen-ink); margin: 0; max-width: 320px; }
.footer-title { font-size: 24px; margin: 0 0 22px; font-weight: 700; }
.footer-links { list-style: none; margin: 0; padding: 0; }
.footer-links li { margin-bottom: 14px; }
.footer-links a { color: var(--fen-ink); font-size: 17px; }
.footer-links a:hover { color: var(--fen-gold); }
.contact-list { list-style: none; margin: 0; padding: 0; }
.contact-list li { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 18px; font-size: 17px; }
.contact-list .ci {
	flex: none; width: 40px; height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
}
.contact-list .ci svg { width: 100%; height: 100%; display: block; }
.contact-list a { color: var(--fen-ink); }
.contact-list a:hover { color: var(--fen-gold); }
.footer-social { margin-top: 16px; display: flex; gap: 16px; }
.footer-social a { color: var(--fen-muted); font-weight: 500; }

.footer-bottom { border-top: 1px solid var(--fen-line); }
.footer-copy {
	max-width: var(--fen-maxw); margin: 0 auto; padding: 24px; text-align: center;
	color: var(--fen-muted); font-size: 15px;
}

/* Bouton flottant "Appelez-moi 24h/24" */
.floating-call {
	position: fixed; right: 22px; bottom: 22px; z-index: 300;
	background: var(--fen-black); color: #fff;
	padding: 15px 26px; border-radius: var(--fen-radius-pill);
	font-weight: 600; font-size: 15.5px; box-shadow: 0 12px 30px rgba(0,0,0,.28);
}
.floating-call:hover { color: #fff; transform: translateY(-2px); }

/* ==========================================================================
   404
   ========================================================================== */
.error-404 { text-align: center; padding: 90px 24px 110px; }
.error-404-code { font-size: clamp(70px, 14vw, 130px); margin: 0; color: var(--fen-header); line-height: 1; }
.error-404-text { color: var(--fen-muted); font-size: 19px; margin: 12px 0 30px; }
.error-404-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.error-404-search { max-width: 420px; margin: 36px auto 0; }

/* ==========================================================================
   COMMENTAIRES
   ========================================================================== */
.comments-area { margin-top: 56px; padding-top: 32px; border-top: 1px solid var(--fen-line); }
.comments-title { font-size: 24px; margin: 0 0 24px; }
.comment-list { list-style: none; margin: 0 0 36px; padding: 0; }
.comment-list .children { list-style: none; margin: 0 0 0 28px; padding: 0; }
.comment-body { padding: 18px 0; border-bottom: 1px solid var(--fen-line); }
.comment-author { font-weight: 600; }
.comment-meta { font-size: 13px; color: var(--fen-muted); margin-bottom: 8px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%; padding: 12px 14px; border: 1px solid var(--fen-line);
	border-radius: 10px; font: inherit; margin-top: 6px;
}
.comment-form label { font-weight: 500; font-size: 14px; }
.comment-form p { margin: 0 0 16px; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
	.footer-inner { grid-template-columns: 1fr 1fr; gap: 36px; }
	.content-with-sidebar { grid-template-columns: 1fr; }
	.sidebar { position: static; flex-direction: row; flex-wrap: wrap; }
	.sidebar .widget { flex: 1 1 280px; }
}

@media (max-width: 880px) {
	.nav-toggle { display: flex; }
	.primary-nav {
		position: fixed; inset: 0 0 0 auto; width: min(86vw, 360px);
		background: var(--fen-header-dark); padding: 88px 26px 30px;
		transform: translateX(100%); transition: transform .25s ease;
		overflow-y: auto; box-shadow: -10px 0 40px rgba(0,0,0,.3);
	}
	.primary-nav.is-open { transform: translateX(0); }
	.primary-nav .menu { flex-direction: column; align-items: stretch; gap: 4px; }
	.primary-nav .menu > li { border-bottom: 1px solid rgba(255,255,255,.12); }
	.primary-nav .menu > li > a { display: block; padding: 14px 4px; }
	.primary-nav .menu > li.current > a::after,
	.primary-nav .menu > li > a:hover::after { display: none; }
	.submenu-toggle { display: inline-block; position: absolute; right: 0; top: 8px; }
	.menu-item.has-children { position: relative; }
	.submenu {
		position: static; opacity: 1; visibility: visible; transform: none;
		box-shadow: none; background: transparent; padding: 0 0 8px 14px;
		max-height: 0; overflow: hidden; transition: max-height .2s ease;
	}
	.menu-item.submenu-open .submenu { max-height: 600px; }
	.submenu li a { color: rgba(255,255,255,.85); padding: 9px 6px; }
	.submenu li a:hover { background: transparent; color: #fff; }
	body.nav-open { overflow: hidden; }
}

@media (max-width: 620px) {
	.post-grid { grid-template-columns: 1fr; }
	.footer-inner { grid-template-columns: 1fr; }
	.footer-cta-inner { flex-direction: column; align-items: flex-start; }
	.floating-call { right: 14px; bottom: 14px; padding: 13px 20px; font-size: 14px; }
	.fenisol-logo-img { height: 46px; }
}
