/*
Theme Name: Champ Libre
Theme URI: https://champlibre.fr
Author: Champ Libre
Description: Thème éditorial sur mesure pour Champ Libre — un regard large sur la vie. Reproduit fidèlement la maquette validée (running, gastronomie, photographie, voyage, tech, loisirs en famille).
Version: 1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: champ-libre
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#F8F5F0;--dark:#2A1F14;--muted:#8A7060;--border:#E2D9CE;--accent:#6B8C6E;
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Jost','Helvetica Neue',Arial,sans-serif;
}
body{background:var(--bg);color:var(--dark);font-family:var(--serif)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;cursor:pointer}
#reading-progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:200;width:0%;transition:width .1s linear;display:none}
header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border)}
.nav-inner{width:100%;margin:0;padding:20px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-right{display:flex;align-items:center;gap:0;margin-left:auto}
.logo{font-family:var(--serif);font-size:22px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--dark);white-space:nowrap;cursor:pointer}
.logo span{color:var(--accent)}
nav ul{display:flex;gap:26px;list-style:none}
nav a{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);transition:color .2s;cursor:pointer}
nav a:hover,nav a.active,nav .current-cat-parent>a,nav .current_page_item>a,nav .current-menu-item>a{color:var(--accent)}
.fade-in{animation:fadein .3s ease}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.hero{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:55% 45%;min-height:520px;border-bottom:1px solid var(--border)}
.hero-image{overflow:hidden}
.hero-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.hero-image:hover img{transform:scale(1.03)}
.hero-content{background:var(--bg);padding:60px 50px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--border)}
.category-label{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.category-label::before{content:'';width:18px;height:1px;background:var(--accent);flex-shrink:0}
.hero-title{font-family:var(--serif);font-size:42px;font-weight:500;line-height:1.1;margin-bottom:22px}
.hero-title em{font-style:italic;color:var(--muted)}
.hero-excerpt{font-family:var(--sans);font-size:14px;font-weight:300;line-height:1.85;color:var(--muted);margin-bottom:36px}
.btn-primary{display:inline-block;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:white;background:var(--dark);padding:13px 28px;align-self:flex-start;transition:background .25s;cursor:pointer;border:none}
.btn-primary:hover{background:var(--accent)}
.section-header{max-width:1200px;margin:56px auto 0;padding:0 40px;display:flex;align-items:center;gap:20px}
.section-title{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.section-line{flex:1;height:1px;background:var(--border)}
.grid{max-width:1200px;margin:28px auto 70px;padding:0 40px;display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.card{background:var(--bg);overflow:hidden;cursor:pointer}
.card-image{overflow:hidden;margin-bottom:18px}
.card-image img{width:100%;height:220px;object-fit:cover;transition:transform .5s}
.card:hover .card-image img{transform:scale(1.04)}
.card-featured{grid-column:span 2}
.card-featured .card-image img{height:300px}
.card-category{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.card-title{font-family:var(--serif);font-size:20px;font-weight:500;line-height:1.25;color:var(--dark);margin-bottom:10px;display:block}
.card-title:hover{color:var(--accent)}
.card-featured .card-title{font-size:27px}
.card-excerpt{font-family:var(--sans);font-size:13px;font-weight:300;line-height:1.7;color:var(--muted);margin-bottom:14px}
.card-meta{font-family:var(--sans);font-size:10px;color:#B0A090;display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--border)}
.cat-hero{max-width:1200px;margin:0 auto;padding:56px 40px 40px;border-bottom:1px solid var(--border)}
.cat-hero-label{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.cat-hero-label::before{content:'';width:18px;height:1px;background:var(--accent)}
.cat-hero h1{font-family:var(--serif);font-size:48px;font-weight:500;line-height:1.05;margin-bottom:16px}
.cat-hero h1 em{font-style:italic;color:var(--muted)}
.cat-hero p{font-family:var(--sans);font-size:14px;font-weight:300;color:var(--muted);line-height:1.8;max-width:600px}
.cat-grid{max-width:1200px;margin:40px auto 70px;padding:0 40px;display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.cat-featured{grid-column:span 3;display:grid;grid-template-columns:55% 45%;border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:40px}
.cat-featured .cf-image{overflow:hidden}
.cat-featured .cf-image img{width:100%;height:340px;object-fit:cover;transition:transform .5s}
.cat-featured:hover .cf-image img{transform:scale(1.03)}
.cat-featured .cf-content{padding:40px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--border)}
.cf-content .card-title{font-size:28px;margin-bottom:14px}
.article-cat{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.article-cat::before{content:'';width:18px;height:1px;background:var(--accent)}
.article-meta{font-family:var(--sans);font-size:11px;color:#B0A090;display:flex;gap:14px}
.article-body{max-width:820px;margin:56px auto 70px;padding:0 40px;font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.9;color:#4A3828}
.article-body p{margin-bottom:22px}
.article-body h2{font-family:var(--serif);font-size:28px;font-weight:500;color:var(--dark);margin:40px 0 16px}
.article-body h3{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--dark);margin:28px 0 12px}
.article-body strong{font-weight:500;color:var(--dark)}
.article-body ul,.article-body ol{padding-left:24px;margin-bottom:22px}
.article-body li{margin-bottom:8px}
.article-body blockquote{border-left:3px solid var(--accent);margin:32px 0;padding:4px 0 4px 28px;font-family:var(--serif);font-size:22px;font-style:italic;color:var(--muted);line-height:1.5}
.article-body img{margin:32px 0}
.article-nav{max-width:1200px;margin:0 auto;padding:32px 40px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:24px}
.article-nav a{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--muted);cursor:pointer}
.article-nav a:hover{color:var(--accent)}
.newsletter{background:var(--dark);padding:70px 40px;text-align:center}
.newsletter-title{font-family:var(--serif);font-size:38px;font-weight:400;color:white;margin-bottom:10px}
.newsletter-title em{font-style:italic;color:var(--accent)}
.newsletter-sub{font-family:var(--sans);font-size:13px;font-weight:300;color:rgba(255,255,255,.45);margin-bottom:36px}
.newsletter-form{display:flex;justify-content:center;max-width:460px;margin:0 auto 16px}
.newsletter-input{flex:1;padding:14px 20px;font-family:var(--sans);font-size:13px;border:none;background:rgba(255,255,255,.1);color:white;outline:none}
.newsletter-input::placeholder{color:rgba(255,255,255,.3)}
.newsletter-btn{padding:14px 28px;background:var(--accent);color:white;border:none;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s}
.newsletter-btn:hover{background:#557A58}
.nl-confirm{display:none;font-family:var(--sans);font-size:12px;color:var(--accent);margin-top:8px}
footer{background:#1E1610;padding:36px 40px}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-logo{font-family:var(--serif);font-size:18px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:rgba(255,255,255,.9);cursor:pointer}
.footer-logo span{color:var(--accent)}
.footer-links{display:flex;gap:24px;list-style:none}
.footer-links a{font-family:var(--sans);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3);transition:color .2s;cursor:pointer}
.footer-links a:hover{color:rgba(255,255,255,.7)}
.footer-cr{font-family:var(--sans);font-size:10px;color:rgba(255,255,255,.2)}

.nav-social { display: flex; align-items: center; gap: 16px; margin-left: 16px; padding-left: 20px; border-left: 1px solid var(--border); }
.nav-social a { display: flex; align-items: center; color: var(--muted); transition: color 0.2s; }
.nav-social a:hover { color: var(--accent); }
.footer-social { display: flex; gap: 16px; }
.footer-social a { display: flex; align-items: center; color: rgba(255,255,255,0.3); transition: color 0.2s; }
.footer-social a:hover { color: rgba(255,255,255,0.7); }

/* ── HAMBURGER & MENU MOBILE ── */
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 6px; flex-shrink: 0;
}
.hamburger span { display: block; width: 22px; height: 1.5px; background: var(--dark); transition: all 0.3s ease; }
.hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.mobile-nav {
  display: none; position: fixed; inset: 0; top: 61px;
  background: var(--bg); z-index: 99; flex-direction: column;
  padding: 40px; gap: 0; overflow-y: auto;
}
.mobile-nav.open { display: flex; }
.mobile-nav ul { flex-direction: column; gap: 0; list-style: none; }
.mobile-nav ul li { border-bottom: 1px solid var(--border); }
.mobile-nav ul li a {
  display: block; padding: 18px 0;
  font-family: var(--sans); font-size: 13px; font-weight: 500;
  letter-spacing: 2.5px; text-transform: uppercase; color: var(--dark);
}
.mobile-nav ul li a:hover { color: var(--accent); }
.mobile-social { display: flex; gap: 20px; margin-top: 36px; }
.mobile-social a { color: var(--muted); transition: color 0.2s; }
.mobile-social a:hover { color: var(--accent); }

@media (max-width: 900px) {
  .hamburger { display: flex; }
  nav, .nav-social { display: none; }
  .nav-inner { padding: 18px 24px; }
}

@media (max-width: 900px) {
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-image img{height:320px}
  .hero-content{padding:40px 24px;border-left:none;border-top:1px solid var(--border)}
  .hero-title{font-size:32px}
  .grid{grid-template-columns:1fr;padding:0 24px}
  .card-featured{grid-column:span 1}
  .cat-grid{grid-template-columns:1fr;padding:0 24px}
  .cat-featured{grid-column:span 1;grid-template-columns:1fr}
  .cat-featured .cf-content{border-left:none;border-top:1px solid var(--border);padding:28px 0 0;margin-top:24px}
  .cat-hero{padding:40px 24px 32px}
  .cat-hero h1{font-size:34px}
  .section-header,.article-nav{padding:0 24px}
  .article-body{padding:0 24px}
  .newsletter{padding:50px 24px}
  .footer-inner{flex-direction:column;text-align:center}
}

/* ── Pages statiques : À propos / Contact ── */
.static-wrap{max-width:900px;margin:0 auto;padding:70px 40px 0}
.static-wrap h1{font-family:var(--serif);font-size:52px;font-weight:500;line-height:1.05;margin-bottom:40px}
.static-wrap h1 em{font-style:italic;color:var(--muted)}
.about-grid{max-width:900px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;margin-bottom:70px}
.about-portrait{width:100%;height:420px;overflow:hidden}
.about-portrait img{width:100%;height:100%;object-fit:cover}
.about-quote{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.5;color:var(--dark);margin-bottom:28px;font-style:italic}
.about-text{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.9;color:#4A3828}
.about-text p{margin-bottom:18px}
.about-cats-wrap{max-width:900px;margin:0 auto 70px;padding:0 40px}
.about-cats-intro{border-top:1px solid var(--border);padding-top:50px;margin-bottom:50px}
.about-cats-label{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:32px}
.about-cats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.about-cat-item{border-left:2px solid var(--accent);padding-left:20px}
.about-cat-item .t{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--dark);margin-bottom:8px}
.about-cat-item .d{font-family:var(--sans);font-size:13px;font-weight:300;color:var(--muted);line-height:1.7}
.about-cta{background:var(--dark);padding:50px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.about-cta-title{font-family:var(--serif);font-size:30px;font-weight:400;color:white;margin-bottom:12px;line-height:1.3}
.about-cta-title em{font-style:italic;color:var(--accent)}
.about-cta-sub{font-family:var(--sans);font-size:13px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.7}

.contact-wrap{max-width:580px;margin:70px auto 90px;padding:0 40px}
.contact-wrap h1{font-family:var(--serif);font-size:44px;font-weight:500;line-height:1.08;margin-bottom:16px}
.contact-wrap h1 em{font-style:italic;color:var(--muted)}
.contact-wrap>p{font-family:var(--sans);font-size:14px;font-weight:300;color:var(--muted);margin-bottom:40px;line-height:1.7}
.contact-form{display:flex;flex-direction:column;gap:20px}
.contact-form label{font-family:var(--sans);font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
.contact-form input,.contact-form textarea{width:100%;padding:13px 16px;font-family:var(--sans);font-size:14px;border:1px solid var(--border);background:white;color:var(--dark);outline:none}
.contact-form textarea{resize:vertical}
.contact-form .btn-primary{text-align:center;align-self:stretch}

.simple-page .static-wrap{padding-bottom:70px}
.simple-page .article-body{margin-top:0}

@media (max-width: 900px) {
  .static-wrap,.contact-wrap,.about-cats-wrap,.about-grid{padding-left:24px;padding-right:24px}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-cats-grid{grid-template-columns:1fr;gap:32px}
  .about-cta{grid-template-columns:1fr;padding:36px 24px;text-align:center}
  .static-wrap h1{font-size:38px}
}
