<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Club du Livre | Communauté Littéraire, Critiques & Fiches de Lecture 2026</title>
<meta name="description" content="Découvrez le Club du Livre 2026 : fiches de lecture détaillées, critiques littéraires, chroniques des meilleurs livres récents (Foenkinos, Le Clézio, Houellebecq), clubs de lecture en ligne et recommandations personnalisées. Rejoignez notre communauté de passionnés.">
<meta property="og:locale" content="fr_FR">
<meta property="og:type" content="website">
<meta property="og:title" content="Club du Livre 2026 | Fiches de Lecture & Critiques Littéraires">
<meta property="og:description" content="Explorez nos fiches de lecture 2026, critiques détaillées des meilleurs livres récents, chroniques littéraires et recommandations personnalisées.">
<meta property="og:url" content="https://clubdulivre.fr/">
<meta property="og:image" content="https://clubdulivre.fr/images/og/club-livre-2026.jpg">
<meta name="twitter:card" content="summary_large_image">
<meta name="twitter:title" content="Club du Livre 2026 | Fiches de Lecture & Critiques Littéraires">
<meta name="twitter:description" content="Découvrez nos analyses littéraires 2026, fiches de lecture détaillées et recommandations de livres récents.">
<meta name="twitter:image" content="https://clubdulivre.fr/images/twitter/club-livre-2026.jpg">
<link rel="canonical" href="https://clubdulivre.fr/">
<link rel="preload" href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Inter:wght@300;400;500;600&display=swap" as="style" onload="this.onload=null;this.rel='stylesheet'">
<noscript><link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Inter:wght@300;400;500;600&display=swap"></noscript>
<link rel="preload" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css" as="style" onload="this.onload=null;this.rel='stylesheet'">
<noscript><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"></noscript>
<link rel="icon" type="image/svg+xml" href="/favicon.svg">
<link rel="alternate icon" href="/favicon.ico" type="image/x-icon">
<meta name="theme-color" content="#2c3e50">
<script type="application/ld+json">
{
"@context": "https://schema.org",
"@graph": [
{
"@type": "Organization",
"@id": "https://clubdulivre.fr/#organization",
"name": "Club du Livre",
"url": "https://clubdulivre.fr/",
"logo": {"@type": "ImageObject", "url": "https://clubdulivre.fr/images/logo.svg", "width": 200, "height": 200},
"description": "Communauté française dédiée à la lecture, aux échanges littéraires et aux recommandations de livres."
},
{
"@type": "WebSite",
"@id": "https://clubdulivre.fr/#website",
"url": "https://clubdulivre.fr/",
"name": "Club du Livre",
"description": "Site officiel du Club du Livre - Fiches de lecture, critiques littéraires et communauté de lecteurs",
"publisher": {"@id": "https://clubdulivre.fr/#organization"},
"inLanguage": "fr-FR"
}
]
}
</script>
<style>
:root {
/* Colors */
--color-primary-50: #eff6ff;
--color-primary-100: #dbeafe;
--color-primary-200: #bfdbfe;
--color-primary-300: #93c5fd;
--color-primary-400: #60a5fa;
--color-primary-500: #3b82f6;
--color-primary-600: #2563eb;
--color-primary-700: #1d4ed8;
--color-primary-800: #1e40af;
--color-primary-900: #1e3a8a;
--color-secondary-50: #f0fdf4;
--color-secondary-100: #dcfce7;
--color-secondary-200: #bbf7d0;
--color-secondary-300: #86efac;
--color-secondary-400: #4ade80;
--color-secondary-500: #22c55e;
--color-secondary-600: #16a34a;
--color-neutral-50: #fafafa;
--color-neutral-100: #f5f5f5;
--color-neutral-200: #e5e5e5;
--color-neutral-300: #d4d4d4;
--color-neutral-400: #a3a3a3;
--color-neutral-500: #737373;
--color-neutral-600: #525252;
--color-neutral-700: #404040;
--color-neutral-800: #262626;
--color-neutral-900: #171717;
--color-accent-500: #f59e0b;
--color-accent-600: #d97706;
/* Typography */
--font-primary: 'Playfair Display', Georgia, serif;
--font-secondary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
/* Spacing */
--space-xs: 0.25rem;
--space-sm: 0.5rem;
--space-md: 1rem;
--space-lg: 1.5rem;
--space-xl: 2rem;
--space-2xl: 3rem;
--space-3xl: 4rem;
/* Border Radius */
--radius-sm: 0.25rem;
--radius-md: 0.5rem;
--radius-lg: 0.75rem;
--radius-xl: 1rem;
--radius-full: 9999px;
/* Shadows */
--shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
--shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1);
--shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1);
/* Transitions */
--transition-fast: 150ms cubic-bezier(0.4,0,0.2,1);
--transition-base: 250ms cubic-bezier(0.4,0,0.2,1);
--transition-slow: 350ms cubic-bezier(0.4,0,0.2,1);
/* Layout */
--header-height: 60px;
--nav-width-desktop: 280px;
--nav-width-collapsed: 60px;
--main-max-width: 1200px;
--container-padding: 1rem;
/* Z-Index */
--z-dropdown: 100;
--z-sticky: 200;
--z-fixed: 300;
--z-modal: 400;
--z-tooltip: 500;
}
/* Reset & Base */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
scroll-behavior: smooth;
-webkit-text-size-adjust: 100%;
}
body {
min-height: 100vh;
font-family: var(--font-secondary);
font-size: 1rem;
line-height: 1.6;
color: var(--color-neutral-800);
background-color: var(--color-neutral-50);
display: flex;
flex-direction: column;
overflow-x: hidden;
}
/* Typography */
h1, h2, h3, h4, h5, h6 {
font-family: var(--font-primary);
font-weight: 700;
line-height: 1.2;
color: var(--color-neutral-900);
}
h1 { font-size: clamp(2rem, 5vw, 3rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2.25rem); }
h3 { font-size: clamp(1.25rem, 3vw, 1.75rem); }
h4 { font-size: 1.25rem; }
p { margin-bottom: var(--space-md); color: var(--color-neutral-700); }
a { color: var(--color-primary-600); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--color-primary-700); }
strong { font-weight: 600; color: var(--color-neutral-900); }
em { font-style: italic; color: var(--color-neutral-600); }
/* ===== HEADER ===== */
header {
position: sticky;
top: 0;
z-index: var(--z-sticky);
background-color: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border-bottom: 1px solid var(--color-neutral-200);
padding: 0 var(--container-padding);
height: var(--header-height);
display: flex;
align-items: center;
justify-content: space-between;
}
.header-content {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
max-width: var(--main-max-width);
margin: 0 auto;
}
.header-left {
display: flex;
align-items: center;
gap: var(--space-md);
}
/* Mobile Menu Toggle - Only visible on mobile */
.mobile-menu-toggle {
display: none;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
background: var(--color-primary-600);
color: white;
border: none;
border-radius: var(--radius-md);
cursor: pointer;
font-size: 1.25rem;
transition: background-color var(--transition-fast);
}
.mobile-menu-toggle:hover { background: var(--color-primary-700); }
.mobile-menu-toggle:focus { outline: 2px solid var(--color-primary-500); outline-offset: 2px; }
/* Logo */
.logo {
display: flex;
align-items: center;
gap: var(--space-sm);
}
.logo-icon {
width: 40px;
height: 40px;
background: linear-gradient(135deg, var(--color-primary-500), var(--color-secondary-500));
border-radius: var(--radius-md);
display: flex;
align-items: center;
justify-content: center;
color: white;
font-weight: 700;
font-size: 1.25rem;
}
.logo-text {
font-family: var(--font-primary);
font-size: 1.25rem;
font-weight: 700;
color: var(--color-neutral-900);
}
.header-actions {
display: flex;
align-items: center;
gap: var(--space-md);
}
.cta-button { display: none; }
/* ===== NAVIGATION - DESKTOP ===== */
.nav-container {
position: fixed;
top: var(--header-height);
left: 0;
width: var(--nav-width-desktop);
height: calc(100vh - var(--header-height));
z-index: var(--z-fixed);
transition: width var(--transition-base);
}
.nav-container.collapsed {
width: var(--nav-width-collapsed);
}
nav {
width: 100%;
height: 100%;
background-color: var(--color-neutral-100);
display: flex;
flex-direction: column;
overflow: hidden;
}
.nav-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: var(--space-lg);
border-bottom: 1px solid var(--color-neutral-200);
min-height: 60px;
}
.nav-title {
font-family: var(--font-primary);
font-size: 1.125rem;
font-weight: 600;
color: var(--color-neutral-800);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* Toggle Button for Desktop Navigation */
.nav-toggle {
display: none;
background: none;
border: none;
cursor: pointer;
color: var(--color-neutral-600);
font-size: 1.25rem;
padding: var(--space-xs);
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
border-radius: var(--radius-md);
transition: all var(--transition-fast);
}
.nav-toggle:hover {
background-color: var(--color-neutral-200);
color: var(--color-primary-600);
}
.nav-menu {
list-style: none;
padding: var(--space-md) 0;
flex: 1;
overflow-y: auto;
}
.nav-menu li { margin: 0; }
.nav-menu a {
display: flex;
align-items: center;
gap: var(--space-md);
padding: var(--space-md) var(--space-lg);
color: var(--color-neutral-700);
border-radius: 0;
transition: all var(--transition-fast);
font-weight: 500;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.nav-menu a:hover {
background-color: var(--color-neutral-200);
color: var(--color-primary-600);
}
.nav-menu a.active {
background-color: var(--color-primary-100);
color: var(--color-primary-700);
}
.nav-menu i {
width: 20px;
text-align: center;
color: var(--color-neutral-500);
transition: color var(--transition-fast);
}
.nav-menu a:hover i,
.nav-menu a.active i {
color: var(--color-primary-600);
}
/* Collapsed Navigation - Icons Only */
.nav-container.collapsed .nav-title,
.nav-container.collapsed .nav-menu span {
display: none;
}
.nav-container.collapsed .nav-menu i {
margin: 0 auto;
}
.nav-container.collapsed .nav-menu a {
justify-content: center;
padding: var(--space-md);
}
.nav-container.collapsed .nav-toggle i.fa-chevron-left {
display: none;
}
.nav-container.collapsed .nav-toggle i.fa-chevron-right {
display: block;
}
/* ===== MAIN CONTENT ===== */
.page-container {
display: flex;
flex: 1;
min-height: 100vh;
}
main {
padding: var(--space-xl) var(--container-padding);
flex: 1;
transition: margin-left var(--transition-base);
}
/* Adjust main margin based on nav state */
.nav-container:not(.collapsed) ~ .page-container main {
margin-left: var(--nav-width-desktop);
}
.nav-container.collapsed ~ .page-container main {
margin-left: var(--nav-width-collapsed);
}
/* ===== MOBILE NAVIGATION ===== */
.mobile-nav-overlay {
display: none;
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: rgba(0, 0, 0, 0.5);
z-index: var(--z-modal);
opacity: 0;
transition: opacity var(--transition-base);
}
.mobile-nav-overlay.active {
display: block;
opacity: 1;
}
.mobile-nav {
display: none;
position: fixed;
top: 0;
left: 0;
width: 85%;
max-width: 320px;
height: 100vh;
background-color: white;
padding: var(--space-xl);
z-index: calc(var(--z-modal) + 1);
transform: translateX(-100%);
transition: transform var(--transition-base);
box-shadow: var(--shadow-lg);
overflow-y: auto;
}
.mobile-nav.active {
display: block;
transform: translateX(0);
}
.mobile-nav-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--space-xl);
padding-bottom: var(--space-md);
border-bottom: 1px solid var(--color-neutral-200);
}
.mobile-nav-close {
cursor: pointer;
background: none;
border: none;
font-size: 1.5rem;
color: var(--color-neutral-700);
padding: var(--space-xs);
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
}
.mobile-nav-menu {
list-style: none;
}
.mobile-nav-menu li {
margin-bottom: var(--space-sm);
}
.mobile-nav-menu a {
display: flex;
align-items: center;
gap: var(--space-md);
padding: var(--space-md) var(--space-lg);
color: var(--color-neutral-800);
font-size: 1.125rem;
border-radius: var(--radius-md);
transition: all var(--transition-fast);
font-weight: 500;
}
.mobile-nav-menu a:hover {
background-color: var(--color-neutral-100);
color: var(--color-primary-600);
}
.mobile-nav-menu i {
width: 24px;
text-align: center;
color: var(--color-neutral-500);
}
/* ===== CARD COMPONENTS ===== */
.section-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--space-lg);
flex-wrap: wrap;
gap: var(--space-md);
}
.section-title {
font-size: clamp(1.5rem, 4vw, 2rem);
}
.section-link {
color: var(--color-primary-600);
font-weight: 600;
display: flex;
align-items: center;
gap: var(--space-xs);
}
.section-link:hover {
color: var(--color-primary-700);
gap: var(--space-sm);
}
.section-link i {
transition: transform var(--transition-fast);
}
.section-link:hover i {
transform: translateX(4px);
}
.card-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
gap: var(--space-lg);
}
.featured-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: var(--space-lg);
}
.card {
background: white;
border-radius: var(--radius-lg);
overflow: hidden;
box-shadow: var(--shadow-md);
transition: all var(--transition-base);
display: flex;
flex-direction: column;
}
.card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
}
.card-image {
position: relative;
aspect-ratio: 2/3;
overflow: hidden;
}
.card-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform var(--transition-slow);
}
.card:hover .card-image img {
transform: scale(1.05);
}
.card-badge {
position: absolute;
top: var(--space-sm);
right: var(--space-sm);
background: var(--color-accent-500);
color: white;
padding: var(--space-xs) var(--space-sm);
border-radius: var(--radius-full);
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.card-content {
padding: var(--space-lg);
flex: 1;
display: flex;
flex-direction: column;
}
.card-header {
display: flex;
align-items: flex-start;
justify-content: space-between;
margin-bottom: var(--space-sm);
}
.card-title {
font-size: 1.125rem;
margin-bottom: var(--space-xs);
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
.card-author {
color: var(--color-neutral-600);
font-size: 0.875rem;
}
.card-meta {
display: flex;
align-items: center;
gap: var(--space-md);
margin-bottom: var(--space-sm);
font-size: 0.875rem;
color: var(--color-neutral-500);
}
.card-meta span {
display: flex;
align-items: center;
gap: var(--space-xs);
}
.card-meta i {
font-size: 0.75rem;
}
.card-description {
color: var(--color-neutral-600);
font-size: 0.9375rem;
margin-bottom: var(--space-md);
flex: 1;
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
}
.card-footer {
display: flex;
align-items: center;
justify-content: space-between;
padding-top: var(--space-md);
border-top: 1px solid var(--color-neutral-100);
}
.rating {
display: flex;
align-items: center;
gap: var(--space-xs);
color: var(--color-accent-500);
}
.stars {
color: var(--color-accent-400);
}
.rating-count {
font-size: 0.75rem;
color: var(--color-neutral-500);
}
.card-action {
color: var(--color-primary-600);
font-weight: 600;
font-size: 0.875rem;
display: flex;
align-items: center;
gap: var(--space-xs);
transition: all var(--transition-fast);
}
.card-action:hover {
color: var(--color-primary-700);
gap: var(--space-sm);
}
/* Buttons */
.btn {
display: inline-flex;
align-items: center;
gap: var(--space-sm);
padding: var(--space-sm) var(--space-md);
border-radius: var(--radius-md);
font-weight: 600;
font-size: 0.875rem;
transition: all var(--transition-fast);
cursor: pointer;
border: none;
text-decoration: none;
}
.btn-primary {
background-color: var(--color-primary-600);
color: white;
}
.btn-primary:hover {
background-color: var(--color-primary-700);
transform: translateY(-1px);
}
.btn-secondary {
background-color: rgba(255, 255, 255, 0.2);
color: white;
backdrop-filter: blur(10px);
}
.btn-secondary:hover {
background-color: rgba(255, 255, 255, 0.3);
}
.btn-outline {
background-color: transparent;
border: 1px solid var(--color-neutral-300);
color: var(--color-neutral-700);
}
.btn-outline:hover {
background-color: var(--color-neutral-100);
border-color: var(--color-neutral-400);
}
/* Hero Section */
.hero {
background: linear-gradient(135deg, var(--color-primary-600), var(--color-secondary-500));
color: white;
padding: var(--space-3xl) var(--space-xl);
border-radius: var(--radius-xl);
margin-bottom: var(--space-2xl);
position: relative;
overflow: hidden;
}
.hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');
opacity: 0.3;
}
.hero-content {
position: relative;
z-index: 1;
max-width: 600px;
}
.hero h1 {
color: white;
margin-bottom: var(--space-md);
line-height: 1.1;
}
.hero p {
color: rgba(255, 255, 255, 0.95);
font-size: 1.125rem;
margin-bottom: var(--space-lg);
}
.hero-actions {
display: flex;
gap: var(--space-md);
flex-wrap: wrap;
}
/* Newsletter */
.newsletter {
background: linear-gradient(135deg, var(--color-neutral-800), var(--color-neutral-900));
color: white;
padding: var(--space-3xl);
border-radius: var(--radius-xl);
text-align: center;
}
.newsletter h2 {
color: white;
margin-bottom: var(--space-sm);
}
.newsletter p {
color: rgba(255, 255, 255, 0.8);
max-width: 600px;
margin: 0 auto var(--space-lg);
}
.newsletter-form {
display: flex;
gap: var(--space-md);
max-width: 400px;
margin: 0 auto;
flex-wrap: wrap;
justify-content: center;
}
.newsletter-input {
flex: 1;
min-width: 200px;
padding: var(--space-md);
border: 1px solid var(--color-neutral-600);
border-radius: var(--radius-md);
background-color: var(--color-neutral-800);
color: white;
font-family: var(--font-secondary);
}
.newsletter-input::placeholder {
color: var(--color-neutral-500);
}
.newsletter-input:focus {
outline: none;
border-color: var(--color-primary-500);
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}
/* Footer */
footer {
background-color: var(--color-neutral-900);
color: white;
padding: var(--space-3xl) var(--container-padding) var(--space-xl);
margin-top: auto;
}
.footer-content {
max-width: var(--main-max-width);
margin: 0 auto;
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: var(--space-2xl);
}
.footer-section h3 {
color: white;
font-size: 1.125rem;
margin-bottom: var(--space-lg);
position: relative;
padding-bottom: var(--space-sm);
}
.footer-section h3::after {
content: '';
position: absolute;
left: 0;
bottom: 0;
width: 40px;
height: 2px;
background: var(--color-primary-500);
}
.footer-section ul {
list-style: none;
}
.footer-section li {
margin-bottom: var(--space-sm);
}
.footer-section a {
color: var(--color-neutral-400);
transition: color var(--transition-fast);
}
.footer-section a:hover {
color: var(--color-primary-400);
}
.social-icons {
display: flex;
gap: var(--space-md);
justify-content: center;
margin-top: var(--space-lg);
}
.social-icons a {
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
background-color: var(--color-neutral-800);
border-radius: var(--radius-full);
color: var(--color-neutral-400);
transition: all var(--transition-fast);
}
.social-icons a:hover {
background-color: var(--color-primary-500);
color: white;
transform: translateY(-2px);
}
.footer-bottom {
text-align: center;
padding-top: var(--space-xl);
margin-top: var(--space-xl);
border-top: 1px solid var(--color-neutral-800);
color: var(--color-neutral-500);
font-size: 0.875rem;
}
/* Animations */
@keyframes fadeIn {
from { opacity: 0; transform: translateY(20px); }
to { opacity: 1; transform: translateY(0); }
}
@keyframes slideIn {
from { transform: translateX(-20px); opacity: 0; }
to { transform: translateX(0); opacity: 1; }
}
.animate-fade-in {
animation: fadeIn 0.5s ease-out forwards;
}
.animate-slide-in {
animation: slideIn 0.5s ease-out forwards;
}
/* Scrollbar */
::-webkit-scrollbar {
width: 8px;
height: 8px;
}
::-webkit-scrollbar-track {
background: var(--color-neutral-100);
}
::-webkit-scrollbar-thumb {
background: var(--color-neutral-300);
border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover {
background: var(--color-neutral-400);
}
/* Selection */
::selection {
background-color: var(--color-primary-200);
color: var(--color-primary-900);
}
/* Focus */
:focus-visible {
outline: 2px solid var(--color-primary-500);
outline-offset: 2px;
}
/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 0.01ms !important;
transition-duration: 0.01ms !important;
}
html {
scroll-behavior: auto;
}
}
/* ===== RESPONSIVE DESIGN ===== */
/* MOBILE FIRST - Default (up to 767px) */
:root {
--container-padding: 1rem;
}
header {
padding: 0 var(--container-padding);
}
.mobile-menu-toggle {
display: flex;
}
.cta-button {
display: none;
}
.nav-container {
display: none;
}
main {
padding: var(--space-lg) var(--container-padding);
max-width: 100%;
}
.hero {
padding: var(--space-xl);
}
.hero h1 {
font-size: 1.75rem;
}
.hero-actions {
flex-direction: column;
align-items: flex-start;
}
.hero-actions .btn {
width: 100%;
justify-content: center;
}
.card-grid,
.featured-grid {
grid-template-columns: 1fr;
}
.newsletter-form {
flex-direction: column;
}
.newsletter-input {
width: 100%;
}
.footer-content {
grid-template-columns: 1fr;
gap: var(--space-xl);
}
/* TABLET - 768px and up */
@media (min-width: 768px) {
:root {
--container-padding: 1.5rem;
}
.mobile-menu-toggle {
display: none;
}
.cta-button {
display: block;
}
.nav-container {
display: block;
}
.nav-toggle {
display: flex;
}
header {
padding: 0;
}
.header-content {
padding: 0 var(--container-padding);
}
main {
padding: var(--space-2xl) var(--container-padding);
}
.hero {
padding: var(--space-3xl) var(--space-xl);
}
.hero h1 {
font-size: 2.25rem;
}
.hero-actions {
flex-direction: row;
}
.hero-actions .btn {
width: auto;
}
.card-grid {
grid-template-columns: repeat(2, 1fr);
}
.featured-grid {
grid-template-columns: repeat(2, 1fr);
}
.newsletter-form {
flex-direction: row;
}
.newsletter-input {
width: auto;
}
.footer-content {
grid-template-columns: repeat(2, 1fr);
}
}
/* DESKTOP - 1024px and up */
@media (min-width: 1024px) {
.header-content {
padding: 0;
}
.logo-text {
font-size: 1.5rem;
}
main {
padding: var(--space-3xl) var(--container-padding);
}
.hero {
padding: var(--space-3xl) var(--space-2xl);
}
.hero h1 {
font-size: 2.5rem;
}
.card-grid {
grid-template-columns: repeat(3, 1fr);
}
.featured-grid {
grid-template-columns: repeat(3, 1fr);
}
.footer-content {
grid-template-columns: repeat(4, 1fr);
}
}
/* LARGE DESKTOP - 1280px and up */
@media (min-width: 1280px) {
.hero {
padding: var(--space-3xl);
}
.hero-actions {
gap: var(--space-lg);
}
}
/* PRINT */
@media print {
body {
background: white;
color: black;
}
header,
nav,
.nav-container,
.mobile-menu-toggle,
.mobile-nav,
.mobile-nav-overlay,
footer,
.hero,
.newsletter {
display: none !important;
}
main {
margin-left: 0;
padding: 0;
max-width: 100%;
}
section {
page-break-inside: avoid;
}
a {
text-decoration: underline;
}
}
</style>
</head>
<body>
<!-- Skip to main content -->
<a href="#accueil" class="skip-link" style="position: absolute; top: -40px; left: 0; background: var(--color-primary-600); color: white; padding: 8px 16px; z-index: 1000; transition: top 0.3s;" onfocus="this.style.top='0'" onblur="this.style.top='-40px'">Aller au contenu principal</a>
<!-- Mobile Navigation Overlay -->
<div class="mobile-nav-overlay" id="mobile-nav-overlay"></div>
<!-- Mobile Navigation -->
<nav class="mobile-nav" id="mobile-nav">
<div class="mobile-nav-header">
<div class="logo">
<div class="logo-icon" aria-label="Club du Livre">L</div>
<span class="logo-text">Club du Livre</span>
</div>
<button class="mobile-nav-close" id="mobile-nav-close" aria-label="Fermer le menu">
<i class="fas fa-times"></i>
</button>
</div>
<ul class="mobile-nav-menu">
<li><a href="#accueil" class="active"><i class="fas fa-home"></i> Accueil</a></li>
<li><a href="#a-la-une"><i class="fas fa-fire"></i> À la une</a></li>
<li><a href="#fiches-lecture"><i class="fas fa-book-open"></i> Fiches de lecture</a></li>
<li><a href="#critiques"><i class="fas fa-star"></i> Critiques littéraires</a></li>
<li><a href="#chroniques"><i class="fas fa-newspaper"></i> Chroniques</a></li>
<li><a href="#club-lecture"><i class="fas fa-users"></i> Club de lecture</a></li>
<li><a href="#livre-du-mois"><i class="fas fa-award"></i> Livre du mois</a></li>
<li><a href="#evenements"><i class="fas fa-calendar-alt"></i> Événements</a></li>
<li><a href="#a-propos"><i class="fas fa-info-circle"></i> À propos</a></li>
<li><a href="#contact"><i class="fas fa-envelope"></i> Contact</a></li>
<li>
<a href="#inscription" class="btn btn-outline" style="margin-top: 1rem; justify-content: center;">
<i class="fas fa-user-plus"></i>
<span>S'inscrire gratuitement</span>
</a>
</li>
</ul>
</nav>
<div class="page-container">
<!-- Desktop Navigation Container -->
<div class="nav-container" id="nav-container">
<nav>
<div class="nav-header">
<span class="nav-title">Menu</span>
<button class="nav-toggle" id="nav-toggle" aria-label="Plier/Déplier le menu" aria-expanded="true">
<i class="fas fa-chevron-left" id="nav-toggle-icon"></i>
</button>
</div>
<ul class="nav-menu">
<li><a href="#accueil" class="active"><i class="fas fa-home"></i> <span>Accueil</span></a></li>
<li><a href="#a-la-une"><i class="fas fa-fire"></i> <span>À la une</span></a></li>
<li><a href="#fiches-lecture"><i class="fas fa-book-open"></i> <span>Fiches de lecture</span></a></li>
<li><a href="#critiques"><i class="fas fa-star"></i> <span>Critiques littéraires</span></a></li>
<li><a href="#chroniques"><i class="fas fa-newspaper"></i> <span>Chroniques</span></a></li>
<li><a href="#club-lecture"><i class="fas fa-users"></i> <span>Club de lecture</span></a></li>
<li><a href="#livre-du-mois"><i class="fas fa-award"></i> <span>Livre du mois</span></a></li>
<li><a href="#evenements"><i class="fas fa-calendar-alt"></i> <span>Événements</span></a></li>
<li><a href="#a-propos"><i class="fas fa-info-circle"></i> <span>À propos</span></a></li>
<li><a href="#contact"><i class="fas fa-envelope"></i> <span>Contact</span></a></li>
</ul>
<div style="padding: var(--space-md) var(--space-lg); border-top: 1px solid var(--color-neutral-200);">
<a href="#inscription" class="btn btn-outline" style="width: 100%;">
<i class="fas fa-user-plus"></i>
<span>S'inscrire gratuitement</span>
</a>
</div>
</nav>
</div>
<!-- Header -->
<header>
<div class="header-content">
<div class="header-left">
<!-- Mobile Menu Toggle -->
<button class="mobile-menu-toggle" id="mobile-menu-toggle" aria-label="Ouvrir le menu" aria-expanded="false" aria-controls="mobile-nav">
<i class="fas fa-bars"></i>
</button>
<div class="logo">
<div class="logo-icon" aria-label="Club du Livre">L</div>
<span class="logo-text">Club du Livre</span>
</div>
</div>
<div class="header-actions">
<a href="#inscription" class="btn btn-primary cta-button">
<i class="fas fa-user-plus"></i>
<span>Rejoindre</span>
</a>
</div>
</div>
</header>
<!-- Main Content -->
<main id="accueil">
<!-- Hero Section -->
<section class="hero animate-fade-in">
<div class="hero-content">
<h1>Découvrez l'univers <br><em>littéraire</em> avec nous</h1>
<p>Rejoignez notre communauté de plus de 50 000 passionnés de lecture. Accédez à des fiches de lecture détaillées, des critiques exclusives, et participez à nos clubs de discussion mensuels.</p>
<div class="hero-actions">
<a href="#fiches-lecture" class="btn btn-secondary">
<i class="fas fa-book"></i>
<span>Explorer les fiches</span>
</a>
<a href="#inscription" class="btn btn-primary">
<i class="fas fa-rocket"></i>
<span>Devenir membre</span>
</a>
</div>
</div>
</section>
<!-- À la une Section -->
<section id="a-la-une">
<div class="section-header">
<h2 class="section-title">À la une <span style="color: var(--color-primary-600);">Mai 2026</span></h2>
<a href="#tous-les-livres" class="section-link">
Voir tous les livres
<i class="fas fa-arrow-right"></i>
</a>
</div>
<div class="featured-grid">
<article class="card animate-slide-in" style="--delay: 0.1s">
<div class="card-image">
<img src="https://images.unsplash.com/photo-1544947950-fa07a98d237f?w=600&h=400&fit=crop" alt="La Vie heureuse - David Foenkinos" loading="lazy">
<span class="card-badge">Nouveau</span>
</div>
<div class="card-content">
<div class="card-header">
<h3 class="card-title">La Vie heureuse</h3>
<span style="color: var(--color-accent-500);">4.7★</span>
</div>
<p class="card-author">David Foenkinos</p>
<div class="card-meta">
<span><i class="fas fa-book"></i> Roman</span>
<span><i class="fas fa-calendar"></i> 2025</span>
</div>
<p class="card-description">Un cadre parisien en burn-out découvre le rituel coréen du "Madang", une pratique de partage qui lui permet de se reconstruire.</p>
<div class="card-footer">
<div class="rating">
<div class="stars">
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star-half-alt"></i>
</div>
<span class="rating-count">(1284 avis)</span>
</div>
<a href="#fiche-la-vie-heureuse" class="card-action">Lire la fiche</a>
</div>
</div>
</article>
<article class="card animate-slide-in" style="--delay: 0.2s">
<div class="card-image">
<img src="https://images.unsplash.com/photo-1481627834876-b7833e8f5570?w=600&h=400&fit=crop" alt="Les Impudiques - Emmanuelle Bayamack-Tam" loading="lazy">
<span class="card-badge">Coup de cœur</span>
</div>
<div class="card-content">
<div class="card-header">
<h3 class="card-title">Les Impudiques</h3>
<span style="color: var(--color-accent-500);">4.5★</span>
</div>
<p class="card-author">Emmanuelle Bayamack-Tam</p>
<div class="card-meta">
<span><i class="fas fa-book"></i> Roman</span>
<span><i class="fas fa-calendar"></i> 2026</span>
</div>
<p class="card-description">Une exploration audacieuse des dynamiques familiales et des secrets inavouables, avec une ironie mordante.</p>
<div class="card-footer">
<div class="rating">
<div class="stars">
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="far fa-star"></i>
</div>
<span class="rating-count">(892 avis)</span>
</div>
<a href="#fiche-les-impudiques" class="card-action">Lire la fiche</a>
</div>
</div>
</article>
<article class="card animate-slide-in" style="--delay: 0.3s">
<div class="card-image">
<img src="https://images.unsplash.com/photo-1512820790803-83ca734da794?w=600&h=400&fit=crop" alt="La Plus Secrète Mémoire des hommes" loading="lazy">
<span class="card-badge">Prix Goncourt</span>
</div>
<div class="card-content">
<div class="card-header">
<h3 class="card-title">La Plus Secrète Mémoire des hommes</h3>
<span style="color: var(--color-accent-500);">4.8★</span>
</div>
<p class="card-author">Mohamed Mbougar Sarr</p>
<div class="card-meta">
<span><i class="fas fa-book"></i> Roman</span>
<span><i class="fas fa-calendar"></i> 2021</span>
</div>
<p class="card-description">Une réflexion profonde sur l'héritage littéraire africain, la mémoire et l'identité.</p>
<div class="card-footer">
<div class="rating">
<div class="stars">
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
</div>
<span class="rating-count">(2456 avis)</span>
</div>
<a href="#fiche-memoire-hommes" class="card-action">Lire la fiche</a>
</div>
</div>
</article>
</div>
</section>
<!-- Fiches de Lecture Section -->
<section id="fiches-lecture">
<div class="section-header">
<h2 class="section-title">Fiches de lecture <span style="color: var(--color-secondary-500);">détaillées</span></h2>
<a href="#toutes-fiches" class="section-link">Toutes les fiches <i class="fas fa-arrow-right"></i></a>
</div>
<div class="card-grid">
<article class="card animate-fade-in" style="--delay: 0.1s">
<div class="card-image">
<img src="https://images.unsplash.com/photo-1544947950-fa07a98d237f?w=400&h=600&fit=crop" alt="La Vie heureuse" loading="lazy">
<span class="card-badge">Nouveau</span>
</div>
<div class="card-content">
<div class="card-header">
<h3 class="card-title">La Vie heureuse</h3>
<span style="color: var(--color-primary-600);">4.7★</span>
</div>
<p class="card-author">David Foenkinos</p>
<div class="card-meta">
<span><i class="fas fa-book"></i> Roman</span>
<span><i class="fas fa-calendar"></i> 2025</span>
<span><i class="fas fa-clock"></i> 8 min</span>
</div>
<p class="card-description"><strong>Résumé :</strong> Un cadre parisien en burn-out découvre le rituel coréen du "Madang". Thèmes : résilience, reconstruction, partage.</p>
<div class="card-footer">
<div class="rating">
<div class="stars"><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star-half-alt"></i></div>
<span class="rating-count">(1284)</span>
</div>
<a href="#fiche-la-vie-heureuse" class="card-action">Lire <i class="fas fa-arrow-right"></i></a>
</div>
</div>
</article>
<article class="card animate-fade-in" style="--delay: 0.2s">
<div class="card-image">
<img src="https://images.unsplash.com/photo-1481627834876-b7833e8f5570?w=400&h=600&fit=crop" alt="Les Impudiques" loading="lazy">
<span class="card-badge">Coup de cœur</span>
</div>
<div class="card-content">
<div class="card-header">
<h3 class="card-title">Les Impudiques</h3>
<span style="color: var(--color-primary-600);">4.5★</span>
</div>
<p class="card-author">Emmanuelle Bayamack-Tam</p>
<div class="card-meta">
<span><i class="fas fa-book"></i> Roman</span>
<span><i class="fas fa-calendar"></i> 2026</span>
<span><i class="fas fa-clock"></i> 12 min</span>
</div>
<p class="card-description"><strong>Résumé :</strong> Exploration des dynamiques familiales et secrets inavouables. Thèmes : famille, sexualité, hypocrisie.</p>
<div class="card-footer">
<div class="rating">
<div class="stars"><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="far fa-star"></i></div>
<span class="rating-count">(892)</span>
</div>
<a href="#fiche-les-impudiques" class="card-action">Lire <i class="fas fa-arrow-right"></i></a>
</div>
</div>
</article>
<article class="card animate-fade-in" style="--delay: 0.3s">
<div class="card-image">
<img src="https://images.unsplash.com/photo-1512820790803-83ca734da794?w=400&h=600&fit=crop" alt="La Plus Secrète Mémoire des hommes" loading="lazy">
<span class="card-badge">Prix Goncourt</span>
</div>
<div class="card-content">
<div class="card-header">
<h3 class="card-title">La Plus Secrète Mémoire des hommes</h3>
<span style="color: var(--color-primary-600);">4.8★</span>
</div>
<p class="card-author">Mohamed Mbougar Sarr</p>
<div class="card-meta">
<span><i class="fas fa-book"></i> Roman</span>
<span><i class="fas fa-calendar"></i> 2021</span>
<span><i class="fas fa-clock"></i> 15 min</span>
</div>
<p class="card-description"><strong>Résumé :</strong> Réflexion sur l'héritage littéraire africain. Thèmes : mémoire, identité, transmission.</p>
<div class="card-footer">
<div class="rating">
<div class="stars"><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i><i class="fas fa-star"></i></div>
<span class="rating-count">(2456)</span>
</div>
<a href="#fiche-memoire-hommes" class="card-action">Lire <i class="fas fa-arrow-right"></i></a>
</div>
</div>
</article>
</div>
</section>
<!-- Newsletter Section -->
<section class="newsletter animate-fade-in">
<h2>Restez informé des <span style="color: var(--color-primary-500);">nouvelles parutions</span></h2>
<p>Inscrivez-vous à notre newsletter pour recevoir chaque semaine nos recommandations et les actualités littéraires.</p>
<form class="newsletter-form" id="newsletter-form">
<input type="email" class="newsletter-input" placeholder="Votre adresse email" required aria-label="Adresse email">
<button type="submit" class="btn btn-primary">
<i class="fas fa-paper-plane"></i>
<span>S'inscrire</span>
</button>
</form>
<p style="margin-top: 1rem; font-size: 0.875rem; opacity: 0.8;">
<i class="fas fa-check-circle"></i> Pas de spam, désabonnement en un clic
</p>
</section>
<!-- Inscription Section -->
<aside id="inscription" class="animate-fade-in" style="margin-top: 2rem;">
<div style="background: white; padding: 2rem; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); text-align: center;">
<h2 style="margin-bottom: 1rem;">Rejoignez notre communauté</h2>
<p style="color: var(--color-neutral-600); margin-bottom: 1.5rem; max-width: 500px; margin-left: auto; margin-right: auto;">
L'adhésion au Club du Livre est <strong>totalement gratuite</strong>. En devenant membre, vous accédez à des avantages exclusifs.
</p>
<div style="display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap;">
<a href="#formulaire-inscription" class="btn btn-primary">
<i class="fas fa-user-plus"></i>
S'inscrire gratuitement
</a>
<a href="#avantages" class="btn btn-outline">
<i class="fas fa-gift"></i>
Découvrir les avantages
</a>
</div>
<p style="margin-top: 1.5rem; font-size: 0.875rem; color: var(--color-neutral-500);">
<i class="fas fa-users"></i> Déjà 52 847 membres satisfaits
</p>
</div>
</aside>
</main>
</div>
<!-- Footer -->
<footer>
<div class="footer-content">
<div class="footer-section">
<h3>Club du Livre</h3>
<ul>
<li><a href="#a-propos">À propos de nous</a></li>
<li><a href="#equipe">Notre équipe</a></li>
<li><a href="#partenaires">Partenaires</a></li>
<li><a href="#contact">Contact</a></li>
</ul>
</div>
<div class="footer-section">
<h3>Ressources</h3>
<ul>
<li><a href="#fiches-lecture">Fiches de lecture</a></li>
<li><a href="#critiques">Critiques littéraires</a></li>
<li><a href="#chroniques">Chroniques</a></li>
<li><a href="#auteurs">Index des auteurs</a></li>
</ul>
</div>
<div class="footer-section">
<h3>Communauté</h3>
<ul>
<li><a href="#club-lecture">Clubs de lecture</a></li>
<li><a href="#evenements">Événements</a></li>
<li><a href="#forum">Forum</a></li>
<li><a href="#concours">Concours</a></li>
</ul>
</div>
<div class="footer-section">
<h3>Support</h3>
<ul>
<li><a href="#faq">FAQ</a></li>
<li><a href="#mentions-legales">Mentions légales</a></li>
<li><a href="#politique-confidentialite">Politique de confidentialité</a></li>
</ul>
</div>
</div>
<div style="text-align: center; margin-top: 2rem; padding-top: 2rem; border-top: 1px solid var(--color-neutral-800);">
<div class="social-icons">
<a href="https://www.facebook.com/clubdulivrefr" aria-label="Facebook"><i class="fab fa-facebook-f"></i></a>
<a href="https://twitter.com/ClubDuLivreFR" aria-label="Twitter"><i class="fab fa-twitter"></i></a>
<a href="https://www.instagram.com/clubdulivre.fr/" aria-label="Instagram"><i class="fab fa-instagram"></i></a>
<a href="https://www.goodreads.com/group/club_du_livre_france" aria-label="Goodreads"><i class="fab fa-goodreads-g"></i></a>
</div>
</div>
<div class="footer-bottom">
<p>© 2026 Club du Livre. Tous droits réservés.</p>
</div>
</footer>
<!-- Back to Top Button -->
<button class="back-to-top" id="back-to-top" aria-label="Retour en haut" style="position: fixed; bottom: 20px; right: 20px; width: 50px; height: 50px; border-radius: 50%; background: var(--color-primary-600); color: white; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; box-shadow: var(--shadow-lg); opacity: 0; visibility: hidden; transition: all var(--transition-base); z-index: 999;">
<i class="fas fa-arrow-up"></i>
</button>
<script>
// DOM Elements
const mobileMenuToggle = document.getElementById('mobile-menu-toggle');
const mobileNav = document.getElementById('mobile-nav');
const mobileNavClose = document.getElementById('mobile-nav-close');
const mobileNavOverlay = document.getElementById('mobile-nav-overlay');
const backToTopBtn = document.getElementById('back-to-top');
const newsletterForm = document.getElementById('newsletter-form');
const navContainer = document.getElementById('nav-container');
const navToggle = document.getElementById('nav-toggle');
const navToggleIcon = document.getElementById('nav-toggle-icon');
// Mobile Navigation Toggle
function toggleMobileMenu() {
const isOpen = mobileNav.classList.contains('active');
if (isOpen) {
mobileNav.classList.remove('active');
mobileNavOverlay.classList.remove('active');
mobileMenuToggle.setAttribute('aria-expanded', 'false');
document.body.style.overflow = '';
} else {
mobileNav.classList.add('active');
mobileNavOverlay.classList.add('active');
mobileMenuToggle.setAttribute('aria-expanded', 'true');
document.body.style.overflow = 'hidden';
}
}
mobileMenuToggle.addEventListener('click', toggleMobileMenu);
mobileNavClose.addEventListener('click', toggleMobileMenu);
mobileNavOverlay.addEventListener('click', toggleMobileMenu);
// Close mobile menu on link click
document.querySelectorAll('.mobile-nav-menu a').forEach(link => {
link.addEventListener('click', () => {
if (mobileNav.classList.contains('active')) {
toggleMobileMenu();
}
});
});
// Close mobile menu on escape key
document.addEventListener('keydown', (e) => {
if (e.key === 'Escape' && mobileNav.classList.contains('active')) {
toggleMobileMenu();
}
});
// Desktop Navigation Toggle (Collapse/Expand)
function toggleNav() {
const isCollapsed = navContainer.classList.contains('collapsed');
if (isCollapsed) {
// Expand navigation
navContainer.classList.remove('collapsed');
navToggle.setAttribute('aria-expanded', 'true');
navToggleIcon.classList.remove('fa-chevron-right');
navToggleIcon.classList.add('fa-chevron-left');
// Store preference in localStorage
localStorage.setItem('navCollapsed', 'false');
} else {
// Collapse navigation
navContainer.classList.add('collapsed');
navToggle.setAttribute('aria-expanded', 'false');
navToggleIcon.classList.remove('fa-chevron-left');
navToggleIcon.classList.add('fa-chevron-right');
// Store preference in localStorage
localStorage.setItem('navCollapsed', 'true');
}
}
navToggle.addEventListener('click', toggleNav);
// Restore navigation state from localStorage
if (localStorage.getItem('navCollapsed') === 'true') {
navContainer.classList.add('collapsed');
navToggle.setAttribute('aria-expanded', 'false');
navToggleIcon.classList.remove('fa-chevron-left');
navToggleIcon.classList.add('fa-chevron-right');
}
// Smooth Scrolling for all anchor links
document.querySelectorAll('a[href^="#"]').forEach(anchor => {
anchor.addEventListener('click', function(e) {
const href = this.getAttribute('href');
if (href === '#') return;
const target = document.querySelector(href);
if (target) {
e.preventDefault();
// Close mobile menu if open
if (mobileNav.classList.contains('active')) {
toggleMobileMenu();
}
// Scroll to target with offset
const headerOffset = 80;
const elementPosition = target.getBoundingClientRect().top;
const offsetPosition = elementPosition + window.pageYOffset - headerOffset;
window.scrollTo({
top: offsetPosition,
behavior: 'smooth'
});
// Update URL without jumping
history.pushState(null, null, href);
}
});
});
// Back to Top Button
window.addEventListener('scroll', () => {
if (window.pageYOffset > 300) {
backToTopBtn.style.opacity = '1';
backToTopBtn.style.visibility = 'visible';
} else {
backToTopBtn.style.opacity = '0';
backToTopBtn.style.visibility = 'hidden';
}
});
backToTopBtn.addEventListener('click', () => {
window.scrollTo({
top: 0,
behavior: 'smooth'
});
});
// Newsletter Form
newsletterForm.addEventListener('submit', function(e) {
e.preventDefault();
const emailInput = this.querySelector('input[type="email"]');
const email = emailInput.value.trim();
if (email) {
const submitBtn = this.querySelector('button[type="submit"]');
const originalText = submitBtn.innerHTML;
submitBtn.innerHTML = '<i class="fas fa-spinner fa-spin"></i> Envoi...';
submitBtn.disabled = true;
setTimeout(() => {
submitBtn.innerHTML = '<i class="fas fa-check"></i> Merci !';
submitBtn.style.backgroundColor = 'var(--color-secondary-500)';
setTimeout(() => {
submitBtn.innerHTML = originalText;
submitBtn.style.backgroundColor = '';
submitBtn.disabled = false;
emailInput.value = '';
}, 3000);
}, 2000);
}
});
// Scroll Animations with Intersection Observer
const observerOptions = {
root: null,
rootMargin: '0px',
threshold: 0.1
};
const observer = new IntersectionObserver((entries) => {
entries.forEach(entry => {
if (entry.isIntersecting) {
entry.target.classList.add('animate-visible');
if (entry.target.classList.contains('card') ||
entry.target.classList.contains('featured-card')) {
const delay = entry.target.style.getPropertyValue('--delay') || '0s';
entry.target.style.animationDelay = delay;
}
}
});
}, observerOptions);
document.querySelectorAll('.animate-fade-in, .animate-slide-in, .card').forEach(el => {
observer.observe(el);
});
// Lazy Loading Images
if ('loading' in HTMLImageElement.prototype) {
const lazyImages = document.querySelectorAll('img[loading="lazy"]');
lazyImages.forEach(img => {
img.addEventListener('load', () => {
img.classList.add('loaded');
});
});
}
// Accessibility - Focus visible for keyboard navigation
document.addEventListener('keydown', (e) => {
if (e.key === 'Tab') {
document.body.classList.add('keyboard-navigation');
}
});
document.addEventListener('mousedown', () => {
document.body.classList.remove('keyboard-navigation');
});
// Console Message
console.log('%c�� Club du Livre 2026', 'font-size: 24px; color: #3b82f6; font-weight: bold;');
console.log('%cNavigation optimisée Desktop & Mobile', 'font-size: 14px; color: #737373;');
</script>
</body>
</html>