/*
Theme Name: La Baule Infos
Theme URI: https://www.labaule-infos.net/
Author: La Baule Infos
Author URI: https://www.labaule-infos.net/
Description: Theme visuel pour site d'actualite locale. Mise en forme pure, sans generation de balises SEO (100% compatible Yoast / Rank Math : le theme laisse wp_head() libre). Direction artistique inspiree du logo : orange vif, blanc, gris, energie typographique condensee facon presse. La page d'accueil affiche automatiquement vos categories et vos articles, le logo, les menus et les auteurs sont recuperes dynamiquement depuis WordPress.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: labaule-infos
Tags: news, blog, custom-logo, featured-images, translation-ready, full-width-template, two-columns, right-sidebar
*/

/* ==========================================================================
   1. Variables / Design system (DA du logo)
   ========================================================================== */
:root{
  --orange:#F26522;        /* orange du logo */
  --orange-2:#FF7C36;      /* orange clair (survol/accent sombre) */
  --orange-press:#D2520F;  /* orange fonce (active) */
  --ink:#15171A;           /* presque noir : titres, header */
  --ink-2:#2C2F35;         /* texte courant */
  --muted:#6B6F77;         /* texte secondaire */
  --line:#E7E6E2;          /* filets */
  --bg:#FFFFFF;
  --bg-alt:#F5F4F1;        /* gris chaud rappelant le fond du logo */
  --taupe:#8C8A87;
  --shadow:0 8px 30px rgba(20,23,26,.10);
  --radius:5px;
  --display:"Oswald",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --wrap:1320px;
}

/* ==========================================================================
   2. Base
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink-2);
  font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--orange);text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{color:var(--ink);margin:0}
.container{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(18px,3vw,40px)}
.container--narrow{max-width:780px}
/* Bandeaux pleine largeur garantie (haut, en-tete, nav, pied : bord a bord) */
html,body{max-width:100%;overflow-x:hidden}
.site{width:100%}
.topbar,.masthead,.primary-nav,.search-panel,.site-footer{width:100%}
.site-main{padding-bottom:40px;min-height:50vh}
.empty{padding:48px 0;color:var(--muted);font-size:18px;text-align:center}

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

/* ==========================================================================
   3. Marque / Logo de secours (replique CSS du logo)
   ========================================================================== */
.brand{display:flex;align-items:center}
.custom-logo{max-height:62px;width:auto}
.custom-logo-link{display:inline-block;line-height:0}
.brand__fallback{display:inline-flex;align-items:center;gap:3px;line-height:1;font-family:var(--display);font-weight:700;text-transform:lowercase}
.brand__a{background:var(--orange);color:#fff;padding:.16em .40em .20em;transform:skewX(-8deg);font-size:30px;letter-spacing:.005em;border-radius:3px}
.brand__b{color:var(--orange);font-style:italic;font-weight:600;font-size:25px;letter-spacing:-.01em}

/* ==========================================================================
   4. Top bar + Masthead + Navigation
   ========================================================================== */
.topbar{background:var(--ink);color:#fff}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;height:38px}
.topbar__date{font-size:12.5px;letter-spacing:.02em;color:rgba(255,255,255,.82);text-transform:capitalize}
.topbar__tagline{font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:500;color:var(--orange-2)}

.masthead{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .2s}
.masthead.is-stuck{box-shadow:var(--shadow)}
.masthead__inner{display:flex;align-items:center;gap:16px;min-height:80px}
.masthead .brand{flex:1 1 auto;justify-content:flex-start}
.search-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:0;background:none;color:var(--ink);border-radius:50%}
.search-toggle:hover{background:var(--bg-alt);color:var(--orange)}

/* hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:40px;align-items:center;justify-content:center;border:0;background:none}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);transition:transform .25s,opacity .2s}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.primary-nav{border-top:3px solid var(--orange);background:#fff}
.primary-nav .menu{display:flex;flex-wrap:wrap;gap:2px;list-style:none;margin:0;padding:0}
.primary-nav .menu li{position:relative}
.primary-nav .menu a{display:block;padding:13px 15px;font-family:var(--display);text-transform:uppercase;font-weight:500;font-size:15px;letter-spacing:.03em;color:var(--ink)}
.primary-nav .menu a::after{content:"";position:absolute;left:15px;right:15px;bottom:8px;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .22s}
.primary-nav .menu a:hover::after,.primary-nav .menu .current-menu-item>a::after,.primary-nav .menu .current-cat>a::after{transform:scaleX(1)}
.primary-nav .menu a:hover,.primary-nav .menu .current-menu-item>a,.primary-nav .menu .current-cat>a{color:var(--orange)}

.search-panel{background:var(--bg-alt);border-top:1px solid var(--line)}
.search-panel .container{padding-top:14px;padding-bottom:14px}

/* ==========================================================================
   5. Badge categorie (rappel du bloc incline du logo) + kicker
   ========================================================================== */
.badge{display:inline-block;background:var(--orange);color:#fff;font-family:var(--display);text-transform:uppercase;font-weight:600;font-size:12px;line-height:1;letter-spacing:.04em;padding:.42em .62em .38em;transform:skewX(-8deg);border-radius:2px}
.badge span{display:inline-block;transform:skewX(8deg)}
.badge:hover{background:var(--orange-press);color:#fff}
.badge--media{position:absolute;left:12px;bottom:12px;box-shadow:0 4px 14px rgba(0,0,0,.25)}

/* ==========================================================================
   6. Grilles + Cartes
   ========================================================================== */
.grid{display:grid;gap:28px}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}

.card{display:flex;flex-direction:column}
.card__media{position:relative;display:block;aspect-ratio:16/10;background:var(--bg-alt);overflow:hidden;border-radius:var(--radius)}
.card__img-link{display:block;width:100%;height:100%}
.card__img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.card:hover .card__img{transform:scale(1.045)}
.card__ph{display:flex;align-items:center;justify-content:center;height:100%;font-family:var(--display);font-weight:700;font-size:120px;line-height:0;color:var(--orange);opacity:.45}
.card__body{padding-top:13px}
.card__title{font-family:var(--display);font-weight:600;line-height:1.14;font-size:19px;margin:9px 0 9px}
.card__title a{color:var(--ink)}
.card__title a:hover{color:var(--orange)}
.card__excerpt{color:var(--muted);font-size:14.5px;line-height:1.55;margin:0 0 11px}

/* carte large (une) */
.card--large .card__title{font-size:clamp(27px,3.6vw,42px);line-height:1.06;margin:14px 0 10px}
.card--large .card__excerpt{font-size:17px;line-height:1.6}

/* mini carte (liste de la une) */
.card--mini{display:grid;grid-template-columns:108px 1fr;gap:15px;align-items:start;padding:15px 0;border-top:1px solid var(--line)}
.hero__list .card--mini:first-child{border-top:0;padding-top:4px}
.card--mini .card__media{aspect-ratio:1/1;border-radius:4px}
.card--mini .card__body{padding-top:0}
.card--mini .card__title{font-size:16px;margin:0 0 7px}
.card--mini .card__ph{font-size:54px}

/* meta auteur/date/lecture */
.meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.meta__author{display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);font-weight:600}
.meta__author:hover{color:var(--orange)}
.meta__avatar{border-radius:50%}
.meta__name{font-weight:600}
.meta__sep{opacity:.5}
.meta__read{font-variant-numeric:tabular-nums}

/* ==========================================================================
   7. Une (hero) + entetes de section
   ========================================================================== */
.hero{display:grid;grid-template-columns:1.6fr 1fr;gap:34px;padding:26px 0 30px;border-bottom:4px solid var(--ink);margin-bottom:6px}
.hero__list{display:flex;flex-direction:column}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:38px 0 20px;border-bottom:2px solid var(--line)}
.section-head__title{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(20px,2.5vw,27px);line-height:1;letter-spacing:.01em;margin:0}
.section-head__title a{color:var(--ink)}
.section-head__title span{display:inline-block;padding:0 2px 11px;border-bottom:3px solid var(--orange);margin-bottom:-2px}
.section-head__title a:hover span{color:var(--orange)}
.section-head__all{flex:0 0 auto;font-family:var(--display);text-transform:uppercase;font-size:13px;font-weight:500;letter-spacing:.03em;color:var(--muted);padding-bottom:11px}
.section-head__all:hover{color:var(--orange)}
.cat-block{margin:0 0 8px}

/* ==========================================================================
   8. Archives (categorie / auteur / recherche)
   ========================================================================== */
.archive-head{padding:34px 0 20px;border-bottom:3px solid var(--ink);margin-bottom:28px}
.archive-head .badge{margin-bottom:14px}
.archive-head__title{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(30px,5.2vw,54px);line-height:1;margin:0 0 .18em}
.archive-head__desc{color:var(--muted);max-width:680px;font-size:16px}

.author-head{display:flex;gap:22px;align-items:center;padding:34px 0 24px;border-bottom:3px solid var(--ink);margin-bottom:28px}
.author-head__avatar{border-radius:50%;flex:0 0 auto;box-shadow:var(--shadow)}
.author-head__name{font-family:var(--display);font-weight:600;font-size:clamp(26px,4vw,40px);text-transform:uppercase;line-height:1;margin:.18em 0 .2em}
.author-head__bio{color:var(--muted);max-width:60ch;margin:0}

/* ==========================================================================
   9. Article (single)
   ========================================================================== */
/* Article en deux colonnes : zone de lecture + colonne laterale */
.single-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:54px;align-items:start;max-width:1140px;margin:0 auto;padding-top:30px}
.single-main{min-width:0}
.single{max-width:none;margin:0}
.single-main .single__tags,.single-main .author-box,.single-main .comments-area,.single-main #comments{max-width:none;margin-left:0;margin-right:0}
.single-sidebar{position:sticky;top:100px;display:flex;flex-direction:column;gap:32px}
.widget__title{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:16px;letter-spacing:.03em;line-height:1;margin:0 0 16px;border-bottom:2px solid var(--line)}
.widget__title span{display:inline-block;padding:0 2px 9px;border-bottom:3px solid var(--orange);margin-bottom:-2px}
.widget__list .card--mini{padding:14px 0}
.widget__list .card--mini:first-child{border-top:0;padding-top:0}
.widget__cats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.widget__cats a{color:var(--ink-2);font-family:var(--display);text-transform:uppercase;font-size:14px;letter-spacing:.02em}
.widget__cats a:hover{color:var(--orange)}
@media(max-width:980px){
  .single-layout{grid-template-columns:1fr;gap:36px;max-width:780px}
  .single-sidebar{position:static}
}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:16px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--orange)}
.crumbs span{margin:0 7px;opacity:.6}
.single__head .badge{margin-bottom:16px}
.single__title{font-family:var(--display);font-weight:700;font-size:clamp(32px,5.2vw,55px);line-height:1.04;margin:.1em 0 .35em}
.single__standfirst{font-size:21px;line-height:1.5;color:var(--ink-2);font-weight:500;margin:0 0 20px}
.single__head .meta{padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.single__media{margin:30px 0}
.single__media img{width:100%;border-radius:var(--radius)}
.single__media figcaption{font-size:13px;color:var(--muted);padding-top:9px}

/* contenu redactionnel */
.prose{font-size:18px;line-height:1.78;color:var(--ink-2)}
.prose>*{margin:0 0 1.3em}
.prose>*:last-child{margin-bottom:0}
.prose p{margin:0 0 1.3em}
.prose h2{font-family:var(--display);font-weight:600;font-size:1.7em;line-height:1.15;margin:1.7em 0 .5em;color:var(--ink)}
.prose h3{font-family:var(--display);font-weight:600;font-size:1.36em;line-height:1.2;margin:1.5em 0 .45em;color:var(--ink)}
.prose a{color:var(--orange);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.prose a:hover{text-decoration-thickness:2px}
.prose img,.prose figure img{border-radius:var(--radius)}
.prose figure{margin:1.7em 0}
.prose figcaption{font-size:13px;color:var(--muted);padding-top:8px;text-align:center}
.prose blockquote{margin:1.6em 0;padding:.2em 0 .2em 1.2em;border-left:4px solid var(--orange);font-family:var(--display);font-weight:500;font-size:1.32em;line-height:1.3;color:var(--ink)}
.prose blockquote p{margin:0}
.prose ul,.prose ol{margin:0 0 1.3em;padding-left:1.3em}
.prose li{margin:.4em 0}
.prose code{background:var(--bg-alt);padding:.12em .38em;border-radius:3px;font-size:.88em}
.prose hr{border:0;border-top:2px solid var(--line);margin:2em 0}
.prose .wp-caption,.prose figure.wp-block-image{max-width:100%}

.single__tags{max-width:780px;margin:26px auto 0}
.tags-label{font-family:var(--display);text-transform:uppercase;font-size:12px;letter-spacing:.04em;color:var(--muted);margin-right:8px}
.single__tags a{display:inline-block;background:var(--bg-alt);color:var(--ink-2);padding:6px 12px;border-radius:30px;font-size:13px;margin:0 6px 7px 0}
.single__tags a:hover{background:var(--orange);color:#fff}

.author-box{max-width:780px;margin:34px auto 0;display:flex;gap:18px;align-items:flex-start;background:var(--bg-alt);padding:24px;border-radius:8px;border-left:4px solid var(--orange)}
.author-box__avatar{border-radius:50%;flex:0 0 auto}
.author-box__label{display:block;font-family:var(--display);text-transform:uppercase;font-size:11.5px;letter-spacing:.06em;color:var(--muted);margin-bottom:2px}
.author-box__name{font-family:var(--display);font-weight:600;font-size:20px;color:var(--ink)}
.author-box__name:hover{color:var(--orange)}
.author-box__bio{margin:.5em 0 0;color:var(--muted);font-size:15px;line-height:1.6}

.related{margin-top:54px}

/* ==========================================================================
   10. Page (mentions legales, etc.)
   ========================================================================== */
.page-head{padding:36px 0 12px;border-bottom:3px solid var(--ink);margin-bottom:28px}
.page-head__title{font-family:var(--display);font-weight:700;font-size:clamp(30px,5vw,48px);line-height:1.05;margin:0}
.page-media{margin:0 0 28px}
.page-media img{width:100%;border-radius:var(--radius)}

/* ==========================================================================
   11. Boutons / formulaire de recherche / pagination
   ========================================================================== */
.btn{display:inline-block;background:var(--orange);color:#fff;font-family:var(--display);text-transform:uppercase;font-weight:600;letter-spacing:.03em;padding:13px 24px;border-radius:var(--radius);border:0}
.btn:hover{background:var(--orange-press);color:#fff}

.search-form{display:flex;gap:10px;align-items:stretch}
.search-form label{flex:1 1 auto;margin:0}
.search-field{width:100%;padding:12px 15px;border:1px solid var(--line);border-radius:var(--radius);font:inherit;background:#fff;color:var(--ink)}
.search-field:focus{outline:2px solid var(--orange);outline-offset:1px}
.search-submit{background:var(--orange);color:#fff;font-family:var(--display);text-transform:uppercase;font-weight:600;letter-spacing:.03em;padding:0 22px;border:0;border-radius:var(--radius)}
.search-submit:hover{background:var(--orange-press)}

.pagination{margin:44px 0 0}
.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:44px;height:44px;padding:0 13px;border:1px solid var(--line);border-radius:var(--radius);font-family:var(--display);font-weight:500;color:var(--ink)}
.pagination .page-numbers.current{background:var(--orange);color:#fff;border-color:var(--orange)}
.pagination a.page-numbers:hover{border-color:var(--orange);color:var(--orange)}
.pagination .dots{border:0}

/* ==========================================================================
   12. 404
   ========================================================================== */
.error404{text-align:center;padding:72px 0}
.error404__code{display:block;font-family:var(--display);font-weight:700;font-size:96px;line-height:1;color:var(--orange)}
.error404__title{font-family:var(--display);font-weight:600;font-size:clamp(26px,4vw,38px);margin:.15em 0 .35em}
.error404 p{color:var(--muted);max-width:50ch;margin:0 auto 26px}
.error404 .btn{margin-bottom:30px}
.error404 .search-form{max-width:460px;margin:0 auto}

/* ==========================================================================
   13. Footer
   ========================================================================== */
.site-footer{background:var(--ink);color:#cbcfd4;margin-top:64px}
.site-footer a{color:#cbcfd4}
.site-footer a:hover{color:var(--orange-2)}
.site-footer__inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding:50px 0 38px}
.site-footer__brand .brand__a{font-size:26px}
.site-footer__brand .brand__b{font-size:22px}
.site-footer__about{color:#9398a0;font-size:14px;line-height:1.65;max-width:44ch;margin:16px 0 0}
.site-footer__title{font-family:var(--display);text-transform:uppercase;color:#fff;font-size:14px;letter-spacing:.06em;margin:0 0 16px;padding-bottom:11px;border-bottom:2px solid rgba(255,255,255,.12)}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;font-size:14px}
.site-footer__bar{border-top:1px solid rgba(255,255,255,.1)}
.site-footer__bar-inner{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:17px 0;font-size:13px;color:#868c95}
.site-footer__sig{font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;color:var(--orange-2)}

/* ==========================================================================
   14. Responsive
   ========================================================================== */
@media (max-width:980px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .site-footer__inner{grid-template-columns:1fr 1fr;gap:30px}
  .site-footer__brand{grid-column:1 / -1}
}
@media (max-width:860px){
  .nav-toggle{display:flex}
  .primary-nav{display:n