/*
Theme Name: Les Fermetures Françaises — Le Journal
Theme URI: https://www.lesfermeturesfrancaises.fr/
Author: Les Fermetures Françaises
Author URI: https://www.lesfermeturesfrancaises.fr/
Description: Thème de blog reprenant fidèlement l'identité du site Les Fermetures Françaises (header teal #54959b, logo, navigation, footer). Pensé pour qu'un visiteur passant du site au blog n'ait pas l'impression de changer de site. L'URL du site principal et les informations de contact se règlent dans Apparence ▸ Personnaliser ▸ « Les Fermetures Françaises ».
Version: 1.0.0
Requires at least: 5.5
Tested up to: 6.5
Requires PHP: 7.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lff-blog
Tags: blog, two-columns, right-sidebar, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* =========================================================
   Variables — la couleur header est prélevée sur la capture
   ========================================================= */
:root{
  --lff-teal:        #54959b;   /* couleur exacte du header / onglet actif */
  --lff-teal-dark:   #467c81;   /* survol */
  --lff-teal-soft:   #eef5f5;   /* fonds très légers */
  --lff-ink:         #222222;   /* titres / texte foncé */
  --lff-text:        #3a3a3a;   /* corps de texte */
  --lff-gray:        #6b6b6b;   /* liens footer / méta */
  --lff-border:      #e7e7e7;
  --lff-bg:          #ffffff;
  --lff-bg-alt:      #f7f8f8;
  --wa-green:        #25d366;
  --lff-radius:      6px;
  --lff-maxw:        1280px;
  --font-head: "Montserrat", "Segoe UI", Arial, sans-serif;
  --font-body: "Open Sans", "Segoe UI", Arial, sans-serif;
}

/* =========================================================
   Base
   ========================================================= */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  color:var(--lff-text);
  background:var(--lff-bg);
}
img{max-width:100%;height:auto;}
a{color:var(--lff-teal);text-decoration:none;}
a:hover{color:var(--lff-teal-dark);text-decoration:underline;}
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-head);
  color:var(--lff-ink);
  line-height:1.25;
  margin:0 0 .5em;
  font-weight:600;
}
p{margin:0 0 1.1em;}
hr{border:0;border-top:1px solid var(--lff-border);margin:2em 0;}
.lff-container{max-width:var(--lff-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;}
.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px 14px;z-index:1000;border:1px solid var(--lff-border);}

/* =========================================================
   Header — barre teal supérieure
   ========================================================= */
.lff-topbar{
  background:var(--lff-teal);
  color:#fff;
  font-family:var(--font-head);
  font-size:14px;
}
.lff-topbar a{color:#fff;text-decoration:none;}
.lff-topbar a:hover{text-decoration:underline;color:#fff;}
.lff-topbar .lff-container{
  display:flex;align-items:center;justify-content:space-between;
  min-height:42px;gap:16px;flex-wrap:wrap;
}
.lff-topbar__left{font-weight:500;}
.lff-topbar__right{display:flex;align-items:center;gap:8px;font-weight:600;}
.lff-topbar__right svg{flex:0 0 auto;}

/* Header principal (fond blanc) */
.lff-header{background:#fff;border-bottom:1px solid #f0f0f0;}
.lff-header__main{
  display:flex;align-items:center;gap:28px;padding:18px 0;flex-wrap:wrap;
}
.lff-logo{flex:0 0 auto;display:inline-block;line-height:0;}
.lff-logo img{height:74px;width:auto;display:block;}
.lff-search{flex:1 1 320px;min-width:240px;}
.lff-search form{position:relative;display:flex;}
.lff-search input[type="search"]{
  width:100%;padding:14px 52px 14px 20px;
  border:1px solid #d9d9d9;border-radius:var(--lff-radius);
  font-family:var(--font-body);font-size:15px;color:var(--lff-ink);
  background:#fff;outline:none;
}
.lff-search input[type="search"]:focus{border-color:var(--lff-teal);box-shadow:0 0 0 2px rgba(84,149,155,.15);}
.lff-search button{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  border:0;background:transparent;cursor:pointer;color:#333;
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
}
.lff-search button:hover{color:var(--lff-teal);}

.lff-experts{display:flex;align-items:center;gap:14px;flex:0 0 auto;}
.lff-experts__icon{
  width:54px;height:54px;border-radius:50%;border:2px solid #e3e3e3;
  display:flex;align-items:center;justify-content:center;color:var(--lff-teal);flex:0 0 auto;
}
.lff-experts__txt{font-size:13px;color:var(--lff-gray);line-height:1.35;}
.lff-experts__txt .lff-phone{
  display:block;font-family:var(--font-head);font-weight:700;
  font-size:22px;color:var(--lff-teal);letter-spacing:.5px;
}
.lff-experts__txt .lff-phone:hover{color:var(--lff-teal-dark);text-decoration:none;}

.lff-account{display:flex;align-items:flex-end;gap:22px;flex:0 0 auto;}
.lff-account a{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  color:var(--lff-teal);font-size:13px;font-family:var(--font-head);
}
.lff-account a:hover{color:var(--lff-teal-dark);text-decoration:none;}

/* =========================================================
   Navigation principale
   ========================================================= */
.lff-nav{background:#fff;border-bottom:1px solid #ededed;}
.lff-nav .lff-container{display:flex;align-items:stretch;gap:0;flex-wrap:wrap;}
.lff-nav__home{
  display:flex;align-items:center;justify-content:center;
  padding:0 22px;color:var(--lff-ink);
}
.lff-nav__home:hover{color:var(--lff-teal);text-decoration:none;}
.lff-menu{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:stretch;}
.lff-menu li{display:flex;}
.lff-menu a{
  display:flex;align-items:center;
  padding:20px 16px;
  font-family:var(--font-head);font-weight:600;font-size:14px;
  color:var(--lff-ink);text-decoration:none;line-height:1.2;
  border-bottom:3px solid transparent;
  transition:color .15s ease,background .15s ease;
}
.lff-menu a:hover{color:var(--lff-teal);text-decoration:none;}
/* onglet actif : reproduit le rectangle teal « Devis sur mesure » */
.lff-menu li.lff-active a,
.lff-menu li.current-menu-item > a,
.lff-menu li.current_page_item > a{
  background:var(--lff-teal);color:#fff;border-bottom-color:var(--lff-teal);
}
.lff-menu li.lff-active a:hover,
.lff-menu li.current-menu-item > a:hover{background:var(--lff-teal-dark);color:#fff;}
.lff-menu .sub-menu{display:none;}

.lff-nav__toggle{display:none;}

/* =========================================================
   Layout contenu + sidebar
   ========================================================= */
.lff-site-main{padding:42px 0 56px;}
.lff-layout{display:flex;gap:42px;align-items:flex-start;}
.lff-content{flex:1 1 auto;min-width:0;}
.lff-sidebar{flex:0 0 300px;}

.lff-page-head{margin:0 0 30px;}
.lff-page-head h1{font-size:30px;margin:0;}
.lff-page-head .lff-page-sub{color:var(--lff-gray);font-size:15px;margin-top:6px;}
.lff-page-head::after{content:"";display:block;width:60px;height:3px;background:var(--lff-teal);margin-top:14px;border-radius:2px;}

/* =========================================================
   Articles (liste)
   ========================================================= */
.lff-post-card{
  border:1px solid var(--lff-border);border-radius:var(--lff-radius);
  overflow:hidden;background:#fff;margin-bottom:30px;
}
.lff-post-card__thumb{display:block;line-height:0;}
.lff-post-card__thumb img{width:100%;height:auto;object-fit:cover;display:block;}
.lff-post-card__body{padding:24px 26px 26px;}
.lff-post-card__title{font-size:22px;margin:0 0 8px;}
.lff-post-card__title a{color:var(--lff-ink);}
.lff-post-card__title a:hover{color:var(--lff-teal);text-decoration:none;}
.lff-meta{font-size:13px;color:var(--lff-gray);margin-bottom:14px;font-family:var(--font-head);}
.lff-meta a{color:var(--lff-gray);}
.lff-meta a:hover{color:var(--lff-teal);}
.lff-meta span+span::before{content:"·";margin:0 8px;color:#c8c8c8;}
.lff-excerpt{color:var(--lff-text);}

.lff-btn{
  display:inline-block;background:var(--lff-teal);color:#fff;
  font-family:var(--font-head);font-weight:600;font-size:14px;
  padding:11px 22px;border-radius:var(--lff-radius);border:0;cursor:pointer;
  transition:background .15s ease;
}
.lff-btn:hover{background:var(--lff-teal-dark);color:#fff;text-decoration:none;}
.lff-btn--ghost{background:transparent;color:var(--lff-teal);border:1px solid var(--lff-teal);}
.lff-btn--ghost:hover{background:var(--lff-teal);color:#fff;}

/* Article seul */
.lff-single__header h1{font-size:32px;margin-bottom:10px;}
.lff-single__thumb{margin:22px 0;border-radius:var(--lff-radius);overflow:hidden;}
.lff-entry{font-size:16.5px;}
.lff-entry img{border-radius:var(--lff-radius);}
.lff-entry h2{font-size:24px;margin-top:1.4em;}
.lff-entry h3{font-size:20px;margin-top:1.3em;}
.lff-entry blockquote{
  border-left:4px solid var(--lff-teal);margin:1.4em 0;padding:.4em 1.2em;
  background:var(--lff-teal-soft);color:var(--lff-ink);border-radius:0 var(--lff-radius) var(--lff-radius) 0;
}
.lff-entry ul,.lff-entry ol{padding-left:1.4em;}
.lff-entry li{margin:.3em 0;}
.lff-entry a{text-decoration:underline;}
.lff-entry table{border-collapse:collapse;width:100%;margin:1.2em 0;}
.lff-entry th,.lff-entry td{border:1px solid var(--lff-border);padding:10px 12px;text-align:left;}
.lff-entry th{background:var(--lff-bg-alt);}

.lff-tags{margin-top:26px;font-size:13px;font-family:var(--font-head);}
.lff-tags a{
  display:inline-block;background:var(--lff-bg-alt);border:1px solid var(--lff-border);
  color:var(--lff-gray);padding:5px 12px;border-radius:20px;margin:0 6px 8px 0;text-decoration:none;
}
.lff-tags a:hover{border-color:var(--lff-teal);color:var(--lff-teal);}

.lff-postnav{display:flex;justify-content:space-between;gap:20px;margin:36px 0;font-family:var(--font-head);}
.lff-postnav a{font-weight:600;}

/* Pagination */
.lff-pagination{margin:36px 0 0;font-family:var(--font-head);}
.lff-pagination .page-numbers{
  display:inline-block;padding:9px 15px;margin:0 4px 6px 0;border:1px solid var(--lff-border);
  border-radius:var(--lff-radius);color:var(--lff-ink);text-decoration:none;font-weight:600;
}
.lff-pagination .page-numbers.current{background:var(--lff-teal);color:#fff;border-color:var(--lff-teal);}
.lff-pagination a.page-numbers:hover{border-color:var(--lff-teal);color:var(--lff-teal);}

/* =========================================================
   Sidebar / widgets
   ========================================================= */
.lff-widget{margin-bottom:34px;}
.lff-widget .widget-title,
.lff-widget h2.wp-block-heading{
  font-family:var(--font-head);font-size:15px;text-transform:uppercase;letter-spacing:.6px;
  color:var(--lff-ink);margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid var(--lff-teal);
}
.lff-widget ul{list-style:none;margin:0;padding:0;}
.lff-widget li{padding:7px 0;border-bottom:1px solid #f0f0f0;font-size:15px;}
.lff-widget li a{color:var(--lff-text);}
.lff-widget li a:hover{color:var(--lff-teal);}

/* =========================================================
   Commentaires
   ========================================================= */
.lff-comments{margin-top:46px;border-top:1px solid var(--lff-border);padding-top:30px;}
.lff-comments h2{font-size:22px;}
.commentlist{list-style:none;margin:0;padding:0;}
.commentlist .comment{margin:0 0 22px;}
.commentlist .children{list-style:none;margin:18px 0 0 30px;padding-left:18px;border-left:2px solid var(--lff-border);}
.comment-body{background:var(--lff-bg-alt);border:1px solid var(--lff-border);border-radius:var(--lff-radius);padding:16px 18px;}
.comment-author{font-family:var(--font-head);font-weight:600;color:var(--lff-ink);}
.comment-meta{font-size:12px;color:var(--lff-gray);margin-bottom:8px;}
.comment-respond{margin-top:26px;}
.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 #d9d9d9;border-radius:var(--lff-radius);
  font-family:var(--font-body);font-size:15px;margin:4px 0 14px;
}
.comment-form label{font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--lff-ink);}

/* =========================================================
   404 / recherche vide
   ========================================================= */
.lff-empty{text-align:center;padding:50px 0;}
.lff-empty h1{font-size:64px;color:var(--lff-teal);margin:0;}
.lff-empty p{color:var(--lff-gray);font-size:18px;}

/* =========================================================
   Footer
   ========================================================= */
.lff-footer{background:#fff;border-top:1px solid #ededed;padding:54px 0 0;color:var(--lff-text);}
.lff-footer__grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr 1fr;gap:36px;align-items:start;
}
.lff-footer h3{
  font-family:var(--font-head);font-size:20px;color:var(--lff-ink);font-weight:600;
  margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--lff-teal);
}
.lff-footer__logo img{height:64px;width:auto;margin-bottom:14px;}
.lff-footer__tag{font-family:var(--font-head);font-weight:700;color:var(--lff-ink);margin:0 0 14px;}
.lff-checklist{list-style:none;margin:0;padding:0;}
.lff-checklist li{position:relative;padding:0 0 12px 26px;font-size:15px;line-height:1.4;}
.lff-checklist li::before{
  content:"";position:absolute;left:0;top:3px;width:16px;height:16px;
  background:var(--lff-ink);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z'/></svg>") no-repeat center/contain;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z'/></svg>") no-repeat center/contain;
}
.lff-footer__list{list-style:none;margin:0;padding:0;}
.lff-footer__list li{position:relative;padding:0 0 12px 18px;font-size:15px;line-height:1.4;}
.lff-footer__list li::before{
  content:"›";position:absolute;left:0;top:-1px;color:var(--lff-teal);font-weight:700;font-size:18px;
}
.lff-footer__list a{color:var(--lff-gray);}
.lff-footer__list a:hover{color:var(--lff-teal);}
.lff-contact-line{display:flex;gap:10px;align-items:flex-start;margin:0 0 16px;font-size:15px;color:var(--lff-gray);}
.lff-contact-line svg{flex:0 0 auto;color:var(--lff-teal);margin-top:3px;}
.lff-contact-line strong{color:var(--lff-ink);font-family:var(--font-head);}
.lff-contact-line a{color:var(--lff-teal);}

.lff-social{display:flex;gap:12px;margin-bottom:24px;}
.lff-social a{
  width:42px;height:42px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  color:var(--lff-teal);border:1px solid var(--lff-border);
}
.lff-social a:hover{background:var(--lff-teal);color:#fff;text-decoration:none;}

.lff-pay{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.lff-pay span{
  font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:.3px;
  border:1px solid var(--lff-border);border-radius:4px;padding:6px 9px;color:#555;background:#fff;line-height:1;
}

.lff-footer__bottom{
  border-top:1px solid #ededed;margin-top:44px;padding:20px 0;font-size:14px;color:var(--lff-gray);
}

/* Bouton WhatsApp flottant (présent sur le site) */
.lff-whatsapp{
  position:fixed;right:22px;bottom:22px;z-index:900;
  width:58px;height:58px;border-radius:50%;background:var(--wa-green);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.22);
}
.lff-whatsapp:hover{color:#fff;text-decoration:none;transform:translateY(-2px);transition:transform .15s ease;}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1080px){
  .lff-footer__grid{grid-template-columns:1fr 1fr;gap:30px;}
}
@media (max-width:900px){
  .lff-layout{flex-direction:column;}
  .lff-sidebar{flex:1 1 auto;width:100%;}
  .lff-header__main{gap:18px;}
  .lff-search{order:3;flex:1 1 100%;}
  .lff-account{margin-left:auto;}
}
@media (max-width:768px){
  .lff-nav__toggle{
    display:inline-flex;align-items:center;gap:8px;margin:0;border:0;background:transparent;
    font-family:var(--font-head);font-weight:600;color:var(--lff-ink);padding:14px 0;cursor:pointer;width:100%;
  }
  .lff-nav .lff-container{flex-direction:column;align-items:stretch;}
  .lff-nav__home{justify-content:flex-start;padding:14px 0;}
  .lff-menu{flex-direction:column;display:none;width:100%;}
  .lff-menu.is-open{display:flex;}
  .lff-menu a{padding:13px 0;border-bottom:1px solid #f0f0f0;}
  .lff-menu li.lff-active a,.lff-menu li.current-menu-item>a{padding-left:12px;padding-right:12px;}
  .lff-experts__txt{display:none;}
}
@media (max-width:600px){
  .lff-footer__grid{grid-template-columns:1fr;}
  .lff-topbar .lff-container{justify-content:center;text-align:center;}
  .lff-logo img{height:60px;}
}
