/*
Theme Name: Carré Homme
Theme URI: https://www.carrehomme.fr/
Author: Carré Homme
Author URI: https://www.carrehomme.fr/
Description: Thème éditorial sur-mesure pour Carré Homme — e-magazine mode & lifestyle masculin. Design sobre et clair (identité « tailleur »), JSON-LD propre et conforme schema.org (BlogPosting, BreadcrumbList, Organization, WebSite, ImageObject). Aucun microdata, source unique de données structurées.
Version: 1.0.0
Requires at least: 6.2
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: carrehomme
Tags: blog, magazine, two-columns, custom-logo, custom-menu, featured-images, translation-ready, editor-style
*/

/* ═══════════════════════════════════════════════════════════
   TOKENS
   ═══════════════════════════════════════════════════════════ */
:root{
  --paper:#FBFBF9;
  --paper-2:#F4F3EF;
  --ink:#1A1A1A;
  --graphite:#5B5B57;
  --graphite-2:#8A8A84;
  --hairline:#E3E2DD;
  --hairline-2:#D6D5CE;
  --accent:#21364F;       /* encre bleu nuit, seul accent */
  --accent-hover:#16263A;
  --max:1180px;
  --measure:40rem;        /* largeur de lecture confortable */
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;
  --step--1:clamp(.82rem,.8rem + .1vw,.9rem);
  --step-0:1.0625rem;
  --step-1:clamp(1.2rem,1.1rem + .5vw,1.45rem);
  --step-2:clamp(1.5rem,1.3rem + 1vw,2rem);
  --step-3:clamp(2rem,1.6rem + 2vw,3rem);
  --step-4:clamp(2.6rem,1.9rem + 3.4vw,4.4rem);
  --shadow:0 1px 2px rgba(26,26,26,.04),0 8px 30px rgba(26,26,26,.05);
}

/* ═══════════════════════════════════════════════════════════
   RESET / BASE
   ═══════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:var(--step-0);
  line-height:1.7;
  font-optical-sizing:auto;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-hover)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
hr{border:0;border-top:1px solid var(--hairline);margin:2.5rem 0}

/* Utility face for labels, meta, nav, buttons */
.eyebrow,.entry-meta,.site-nav,.cta,.tagline,.cap,.crumbs,.byline,.pagination,.widget-title{
  font-family:var(--sans);
}

/* ═══════════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════════ */
.wrap{max-width:var(--max);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.5rem)}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;z-index:100;background:var(--ink);color:#fff;padding:.6rem 1rem;font-family:var(--sans)}

/* ═══════════════════════════════════════════════════════════
   HEADER / MASTHEAD
   ═══════════════════════════════════════════════════════════ */
.site-header{border-bottom:1px solid var(--hairline);background:var(--paper)}
.masthead{text-align:center;padding:2.2rem 0 1.4rem}
.site-title{margin:0;font-family:var(--serif);font-weight:600;font-size:var(--step-3);letter-spacing:.01em;line-height:1}
.site-title a{color:var(--ink)}
.site-title a:hover{color:var(--ink)}
.tagline{margin:.7rem auto 0;max-width:46rem;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--graphite);font-weight:500}
.custom-logo{margin:0 auto;max-height:64px;width:auto}

.site-nav{border-top:1px solid var(--hairline)}
.site-nav .menu{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:0}
.site-nav .menu li{position:relative}
.site-nav .menu a{
  display:block;padding:.95rem 1.15rem;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;font-weight:600;color:var(--ink);
}
.site-nav .menu a:hover,.site-nav .menu .current-menu-item > a{color:var(--accent)}
/* sub-menus */
.site-nav .sub-menu{display:none;position:absolute;left:0;top:100%;background:var(--paper);
  border:1px solid var(--hairline);min-width:200px;z-index:40;padding:.3rem 0;box-shadow:var(--shadow)}
.site-nav li:hover > .sub-menu,.site-nav li:focus-within > .sub-menu{display:block}
.site-nav .sub-menu a{text-align:left;letter-spacing:.1em;padding:.6rem 1.1rem}

.nav-toggle{display:none}

/* ═══════════════════════════════════════════════════════════
   EYEBROW / LABEL SYSTEM (signature : étiquette de tailleur)
   ═══════════════════════════════════════════════════════════ */
.eyebrow{
  display:inline-block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  font-weight:600;color:var(--accent);
}
.section-head{display:flex;align-items:baseline;gap:1rem;margin:0 0 1.6rem}
.section-head h2{margin:0;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-family:var(--sans);font-weight:700;color:var(--ink)}
.section-head .rule{flex:1;height:1px;background:var(--hairline-2);transform:translateY(-3px)}

/* ═══════════════════════════════════════════════════════════
   HOME / ARCHIVE
   ═══════════════════════════════════════════════════════════ */
.lead{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center;
  padding:2.6rem 0;border-bottom:1px solid var(--hairline)}
.lead .thumb{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2)}
.lead .thumb img{width:100%;height:100%;object-fit:cover}
.lead h1,.lead h2{font-family:var(--serif);font-weight:600;line-height:1.08;margin:.5rem 0 .6rem;font-size:var(--step-3)}
.lead h1 a,.lead h2 a{color:var(--ink)}
.lead h1 a:hover,.lead h2 a:hover{color:var(--accent)}
.lead .dek{color:var(--graphite);font-size:var(--step-1);line-height:1.5;margin:0 0 1rem}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.4rem);padding:2.6rem 0}
.card{display:flex;flex-direction:column}
.card .thumb{aspect-ratio:3/2;overflow:hidden;background:var(--paper-2);margin-bottom:.95rem}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card a.thumb-link:hover img{transform:scale(1.03)}
.card h3{font-family:var(--serif);font-weight:600;line-height:1.18;font-size:var(--step-1);margin:.5rem 0 .4rem}
.card h3 a{color:var(--ink)}
.card h3 a:hover{color:var(--accent)}
.card .dek{color:var(--graphite);font-size:.95rem;line-height:1.55;margin:0}

.entry-meta{font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--graphite-2);font-weight:500}
.entry-meta a{color:var(--graphite-2)}
.entry-meta a:hover{color:var(--accent)}
.entry-meta .sep{margin:0 .5rem;color:var(--hairline-2)}

.archive-head{padding:2.6rem 0 1.4rem;border-bottom:1px solid var(--hairline);text-align:center}
.archive-head h1{font-family:var(--serif);font-weight:600;font-size:var(--step-3);margin:.4rem 0 .3rem}
.archive-head .desc{color:var(--graphite);max-width:var(--measure);margin:.4rem auto 0}

/* ═══════════════════════════════════════════════════════════
   SINGLE / PAGE (lecture)
   ═══════════════════════════════════════════════════════════ */
.crumbs{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite-2);
  padding:1.4rem 0 0;font-weight:500}
.crumbs a{color:var(--graphite)}
.crumbs a:hover{color:var(--accent)}
.crumbs .sep{margin:0 .45rem;color:var(--hairline-2)}

.article-header{max-width:var(--measure);margin:1.6rem auto 0;text-align:center}
.article-header h1{font-family:var(--serif);font-weight:600;line-height:1.08;font-size:var(--step-4);margin:.7rem 0 .8rem}
.article-header .dek{color:var(--graphite);font-size:var(--step-1);line-height:1.5;margin:0 auto 1.2rem;max-width:34rem}
.byline{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);font-weight:500}
.byline a{color:var(--ink)}
.byline .sep{margin:0 .5rem;color:var(--hairline-2)}

.featured{margin:2rem auto 0;max-width:980px}
.featured img{width:100%}
.featured figcaption,.wp-caption-text{font-family:var(--sans);font-size:.72rem;color:var(--graphite-2);
  text-align:center;margin-top:.6rem;letter-spacing:.02em}

.entry-content{max-width:var(--measure);margin:2.4rem auto 0;font-size:1.125rem;line-height:1.78}
.entry-content > *{margin-top:0;margin-bottom:1.4rem}
.entry-content h2{font-family:var(--serif);font-weight:600;font-size:var(--step-2);line-height:1.2;margin-top:2.6rem}
.entry-content h3{font-family:var(--serif);font-weight:600;font-size:var(--step-1);margin-top:2rem}
.entry-content p{margin-bottom:1.4rem}
/* Liens in-article : nets et intentionnels (le site vend des liens) */
.entry-content a{
  color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:3px;text-decoration-color:var(--hairline-2);
  transition:text-decoration-color .2s ease;
}
.entry-content a:hover{text-decoration-color:var(--accent)}
.entry-content blockquote{
  border-left:2px solid var(--accent);margin-inline:0;padding:.2rem 0 .2rem 1.5rem;
  font-style:italic;color:var(--graphite)
}
.entry-content ul,.entry-content ol{padding-left:1.4rem}
.entry-content li{margin-bottom:.5rem}
.entry-content img{margin-inline:auto}
.entry-content figure{margin:2rem 0}
.entry-content code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:var(--paper-2);padding:.1em .35em;border-radius:3px}
.entry-content table{width:100%;border-collapse:collapse;font-size:.95rem}
.entry-content th,.entry-content td{border-bottom:1px solid var(--hairline);padding:.7rem .5rem;text-align:left}

.entry-footer{max-width:var(--measure);margin:2.6rem auto 0;padding-top:1.6rem;border-top:1px solid var(--hairline)}
.tags{display:flex;flex-wrap:wrap;gap:.5rem;font-family:var(--sans)}
.tags a{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite);
  border:1px solid var(--hairline-2);padding:.35rem .7rem;border-radius:2px}
.tags a:hover{border-color:var(--accent);color:var(--accent)}

/* Related */
.related{padding:3rem 0;border-top:1px solid var(--hairline);margin-top:3rem}

/* ═══════════════════════════════════════════════════════════
   SIDEBAR / WIDGETS
   ═══════════════════════════════════════════════════════════ */
.has-sidebar{display:grid;grid-template-columns:1fr 300px;gap:clamp(2rem,5vw,4rem);align-items:start}
.widget{margin-bottom:2.4rem;font-size:.95rem}
.widget-title{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
  margin:0 0 1rem;padding-bottom:.7rem;border-bottom:1px solid var(--hairline)}
.widget ul{list-style:none;margin:0;padding:0}
.widget li{padding:.55rem 0;border-bottom:1px solid var(--hairline);font-family:var(--sans);font-size:.86rem;line-height:1.4}
.widget li a{color:var(--ink)}
.widget li a:hover{color:var(--accent)}

/* ═══════════════════════════════════════════════════════════
   BUTTONS / FORMS
   ═══════════════════════════════════════════════════════════ */
.cta,button,input[type=submit]{
  display:inline-block;font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;font-weight:600;color:#fff;background:var(--accent);
  padding:.8rem 1.5rem;border:0;border-radius:2px;cursor:pointer;transition:background .2s ease
}
.cta:hover,button:hover,input[type=submit]:hover{background:var(--accent-hover);color:#fff}
input[type=text],input[type=search],input[type=email],textarea{
  font-family:var(--sans);font-size:.95rem;padding:.65rem .8rem;border:1px solid var(--hairline-2);
  border-radius:2px;background:#fff;width:100%;color:var(--ink)
}
.search-form{display:flex;gap:.5rem;max-width:420px;margin:1.5rem auto 0}

/* ═══════════════════════════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════════════════════════ */
.pagination{display:flex;justify-content:center;gap:.4rem;padding:3rem 0;font-family:var(--sans)}
.pagination .page-numbers{padding:.55rem .85rem;border:1px solid var(--hairline-2);
  font-size:.8rem;color:var(--ink);border-radius:2px}
.pagination .current{background:var(--ink);color:#fff;border-color:var(--ink)}
.pagination a.page-numbers:hover{border-color:var(--accent);color:var(--accent)}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
.site-footer{border-top:1px solid var(--hairline);margin-top:4rem;padding:3rem 0 2.4rem;background:var(--paper-2)}
.footer-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:2rem;align-items:flex-start}
.footer-brand .site-title{font-size:var(--step-2)}
.footer-nav .menu{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:1.4rem}
.footer-nav a{font-family:var(--sans);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:500}
.footer-nav a:hover{color:var(--accent)}
.colophon{margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--hairline-2);
  font-family:var(--sans);font-size:.72rem;color:var(--graphite-2);letter-spacing:.04em;text-align:center}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width:880px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .lead{grid-template-columns:1fr}
  .lead .thumb{order:-1}
  .has-sidebar{grid-template-columns:1fr}
}
@media (max-width:560px){
  .grid{grid-template-columns:1fr}
  .nav-toggle{display:inline-flex;align-items:center;gap:.5rem;margin:0 auto;background:none;color:var(--ink);
    border:1px solid var(--hairline-2);font-size:.7rem;letter-spacing:.14em;padding:.55rem 1rem}
  .nav-toggle:hover{background:none;color:var(--accent)}
  .site-nav .menu{display:none;flex-direction:column}
  .site-nav.is-open .menu{display:flex}
  .site-nav .menu a{padding:.85rem 1rem;border-bottom:1px solid var(--hairline)}
  .site-nav .sub-menu{position:static;border:0;box-shadow:none;padding-left:1rem}
}
