/*
Theme Name: Géotop Réseaux – Actualités & Expertise
Theme URI: https://blog.geotop-reseaux.fr/
Description: Thème de blog au style identique au site geotop-reseaux.fr (header blanc, marque indigo/teal, bouton Mail noir). Pensé pour que le visiteur ne ressente aucune rupture entre le site et le blog. Header, footer, liste d'articles, article, page, archives, recherche, commentaires, 404, sidebar.
Author: Géotop Réseaux
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
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: geotop
*/

/* =========================================================
   Couleurs prélevées sur les captures + logo (ne pas deviner)
   ========================================================= */
:root{
  --brand-navy:#1A1A87;   /* indigo de la marque / liens / onglet actif */
  --brand-teal:#2E7E71;   /* vert-teal de la marque (accents)            */
  --ink:#0A0D14;          /* presque-noir : bouton Mail, titres          */
  --nav-text:#22262C;     /* texte de navigation (gris très foncé)       */
  --body:#2B2F36;         /* texte courant                                */
  --muted:#6B7280;        /* méta, légendes                               */
  --bg:#FFFFFF;           /* fond header / page                           */
  --bg-soft:#F7F8FA;      /* fonds très clairs (cartes, encarts)          */
  --border:#E6E8EC;       /* filets                                       */
  --maxw:1180px;
  --radius:14px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  --font-head: "Archivo", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--body);
  font-family:var(--font);
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--brand-navy);text-decoration:none;}
a:hover{text-decoration:underline;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

h1,h2,h3,h4{
  font-family:var(--font-head);
  color:var(--ink);
  line-height:1.15;
  font-weight:800;
  letter-spacing:-.01em;
}
h1{font-size:2.4rem;margin:.2em 0 .4em;}
h2{font-size:1.7rem;}
h3{font-size:1.3rem;}

/* =========================================================
   HEADER — blanc, logo à gauche, nav, in, bouton Mail noir
   ========================================================= */
.site-header{
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.header-inner{
  display:flex;
  align-items:center;
  gap:28px;
  padding:16px 24px;
  max-width:1320px;
  margin:0 auto;
}
.site-logo{flex:0 0 auto;}
.site-logo img{height:74px;width:auto;}

.main-nav{margin-left:auto;}
.nav-list{
  list-style:none;margin:0;padding:0;
  display:flex;align-items:center;gap:30px;
}
.nav-list > li{position:relative;}
.nav-list > li > a{
  color:var(--nav-text);
  font-size:1.02rem;
  font-weight:500;
  padding:6px 0;
  display:inline-block;
}
.nav-list > li > a:hover{color:var(--brand-navy);text-decoration:none;}

/* Onglet actif (le blog) : indigo + soulignement, comme « L'entreprise » sur le site */
.nav-list > li.is-active > a,
.nav-list > li.current-menu-item > a{
  color:var(--brand-navy);
  font-weight:600;
}
.nav-list > li.is-active > a{
  border-bottom:2px solid var(--brand-navy);
}

/* Sous-menu « Nos services » */
.has-children > .nav-toggle-caret{
  border:0;background:none;cursor:pointer;color:var(--nav-text);
  font-size:.7rem;margin-left:4px;padding:0;vertical-align:middle;
}
.sub-menu{
  list-style:none;margin:0;padding:8px 0;
  position:absolute;top:100%;left:0;
  min-width:320px;max-width:380px;
  background:#fff;border:1px solid var(--border);
  border-radius:12px;box-shadow:0 12px 32px rgba(10,13,20,.12);
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:.16s ease;z-index:50;
}
.has-children:hover .sub-menu,
.has-children:focus-within .sub-menu,
.sub-menu.open{opacity:1;visibility:visible;transform:translateY(0);}
.sub-menu li a{
  display:block;padding:9px 18px;color:var(--nav-text);
  font-size:.95rem;font-weight:400;line-height:1.35;
}
.sub-menu li a:hover{background:var(--bg-soft);color:var(--brand-navy);text-decoration:none;}

/* Icône LinkedIn + bouton Mail */
.header-actions{display:flex;align-items:center;gap:18px;}
.header-actions.desktop-only{display:flex;}
.main-nav .header-actions{display:none;} /* actions dans le menu : visibles seulement en mobile */
.ln-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;color:var(--ink);
}
.ln-icon:hover{color:var(--brand-navy);}
.ln-icon svg{width:26px;height:26px;fill:currentColor;}
.btn-mail{
  background:var(--ink);color:#fff;
  padding:14px 30px;border-radius:30px;
  font-weight:600;font-size:1.05rem;
  display:inline-block;
}
.btn-mail:hover{background:#000;color:#fff;text-decoration:none;}

/* Burger mobile */
.nav-burger{display:none;border:0;background:none;cursor:pointer;padding:8px;margin-left:auto;}
.nav-burger span{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;}

/* =========================================================
   CONTENU
   ========================================================= */
.site-main{padding:48px 0 64px;}
.layout{display:flex;gap:48px;align-items:flex-start;}
.content-col{flex:1 1 auto;min-width:0;}
.sidebar-col{flex:0 0 300px;}

.page-head{margin-bottom:32px;}
.page-head .eyebrow{
  color:var(--brand-teal);font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;font-size:.8rem;margin:0 0 6px;
}
.page-head h1{margin:0;}

/* Liste d'articles */
.post-card{
  border-bottom:1px solid var(--border);
  padding:0 0 34px;margin:0 0 34px;
}
.post-card:last-child{border-bottom:0;}
.post-card .thumb{margin-bottom:18px;border-radius:var(--radius);overflow:hidden;}
.post-card .thumb img{width:100%;height:auto;}
.post-card h2{margin:0 0 8px;font-size:1.5rem;}
.post-card h2 a{color:var(--ink);}
.post-card h2 a:hover{color:var(--brand-navy);text-decoration:none;}
.post-meta{color:var(--muted);font-size:.92rem;margin:0 0 12px;}
.post-meta a{color:var(--muted);}
.post-meta .cat{color:var(--brand-teal);font-weight:600;}
.post-excerpt{margin:0 0 14px;}
.read-more{
  display:inline-block;font-weight:600;color:var(--brand-navy);
}
.read-more:hover{text-decoration:underline;}

/* Article seul */
.single-post .entry-header{margin-bottom:24px;}
.single-post .featured{margin:0 0 28px;border-radius:var(--radius);overflow:hidden;}
.entry-content{font-size:1.08rem;}
.entry-content p{margin:0 0 1.25em;}
.entry-content h2{margin:1.6em 0 .5em;}
.entry-content h3{margin:1.4em 0 .4em;}
.entry-content img{border-radius:10px;margin:1.2em 0;}
.entry-content blockquote{
  border-left:4px solid var(--brand-teal);
  margin:1.4em 0;padding:.4em 0 .4em 22px;color:var(--body);
  background:var(--bg-soft);border-radius:0 8px 8px 0;
}
.entry-content a{text-decoration:underline;}
.entry-footer{margin-top:28px;padding-top:20px;border-top:1px solid var(--border);
  color:var(--muted);font-size:.95rem;}
.tags a{display:inline-block;background:var(--bg-soft);border:1px solid var(--border);
  padding:4px 12px;border-radius:30px;margin:0 6px 6px 0;color:var(--nav-text);font-size:.85rem;}
.tags a:hover{border-color:var(--brand-navy);color:var(--brand-navy);text-decoration:none;}

/* Navigation entre articles / pagination */
.post-nav{display:flex;justify-content:space-between;gap:18px;margin-top:36px;}
.post-nav a{font-weight:600;}
.pagination{margin:40px 0 0;}
.pagination .nav-links{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 12px;border:1px solid var(--border);
  border-radius:10px;color:var(--nav-text);font-weight:600;
}
.pagination .page-numbers:hover{border-color:var(--brand-navy);color:var(--brand-navy);text-decoration:none;}
.pagination .page-numbers.current{background:var(--brand-navy);border-color:var(--brand-navy);color:#fff;}

/* =========================================================
   SIDEBAR / WIDGETS
   ========================================================= */
.widget{margin:0 0 34px;}
.widget-title{
  font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--ink);
  margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid var(--brand-teal);
  display:inline-block;
}
.widget ul{list-style:none;margin:0;padding:0;}
.widget ul li{padding:7px 0;border-bottom:1px solid var(--border);}
.widget ul li:last-child{border-bottom:0;}
.widget a{color:var(--nav-text);}
.widget a:hover{color:var(--brand-navy);}

/* Formulaire de recherche */
.search-form{display:flex;gap:8px;}
.search-form input[type=search]{
  flex:1;border:1px solid var(--border);border-radius:10px;
  padding:11px 14px;font-size:1rem;font-family:var(--font);color:var(--ink);
}
.search-form input[type=search]:focus{outline:2px solid var(--brand-navy);border-color:var(--brand-navy);}
.search-form button{
  background:var(--ink);color:#fff;border:0;border-radius:10px;
  padding:0 18px;font-weight:600;cursor:pointer;
}
.search-form button:hover{background:#000;}

/* =========================================================
   COMMENTAIRES
   ========================================================= */
.comments-area{margin-top:48px;padding-top:32px;border-top:1px solid var(--border);}
.comments-title,.comment-reply-title{font-family:var(--font-head);font-size:1.4rem;}
.comment-list{list-style:none;margin:0;padding:0;}
.comment-list ol.children{list-style:none;margin:0 0 0 36px;padding:0;}
.comment-body{padding:18px 0;border-bottom:1px solid var(--border);}
.comment-meta{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.comment-meta img{border-radius:50%;}
.comment-author{font-weight:700;color:var(--ink);}
.comment-date{color:var(--muted);font-size:.85rem;display:block;}
.comment-reply a{font-weight:600;font-size:.9rem;}
.comment-respond{margin-top:24px;}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea{
  width:100%;border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;font-size:1rem;font-family:var(--font);margin-top:6px;color:var(--ink);
}
.comment-form textarea:focus,
.comment-form input:focus{outline:2px solid var(--brand-navy);border-color:var(--brand-navy);}
.comment-form p{margin:0 0 16px;}
.form-submit input,
.comment-form .submit{
  background:var(--ink);color:#fff;border:0;border-radius:30px;
  padding:13px 30px;font-weight:600;cursor:pointer;font-size:1rem;
}
.form-submit input:hover{background:#000;}

/* =========================================================
   404 & messages
   ========================================================= */
.not-found{text-align:center;padding:40px 0 20px;}
.not-found h1{font-size:4rem;color:var(--brand-navy);margin-bottom:0;}
.not-found .lead{font-size:1.3rem;color:var(--ink);margin:0 0 24px;}
.btn{
  display:inline-block;background:var(--ink);color:#fff;
  padding:13px 28px;border-radius:30px;font-weight:600;
}
.btn:hover{background:#000;color:#fff;text-decoration:none;}

/* =========================================================
   FOOTER — sobre, identique à l'esprit du site
   ========================================================= */
.site-footer{
  background:var(--bg);
  border-top:1px solid var(--border);
  padding:48px 0 32px;
  margin-top:40px;
}
.footer-inner{display:flex;flex-wrap:wrap;gap:32px;align-items:center;justify-content:space-between;}
.footer-brand{display:flex;align-items:center;gap:18px;}
.footer-brand img{height:84px;width:auto;}
.footer-follow{text-align:center;}
.footer-follow .h{font-family:var(--font-head);font-weight:700;color:var(--ink);font-size:1.05rem;margin:0 0 10px;}
.footer-follow .ln-icon{color:var(--ink);width:34px;height:34px;}
.footer-follow .ln-icon svg{width:30px;height:30px;}
.footer-contact a{color:var(--nav-text);font-weight:600;}
.footer-bottom{
  margin-top:32px;padding-top:20px;border-top:1px solid var(--border);
  display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;
  color:var(--muted);font-size:.9rem;
}
.footer-bottom a{color:var(--muted);}
.footer-bottom a:hover{color:var(--brand-navy);}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1024px){
  .layout{flex-direction:column;}
  .sidebar-col{flex:1 1 auto;width:100%;}
}
@media (max-width:900px){
  .site-logo img{height:58px;}
  .nav-burger{display:block;}
  .main-nav{
    position:absolute;left:0;right:0;top:100%;background:#fff;
    border-bottom:1px solid var(--border);box-shadow:0 16px 30px rgba(10,13,20,.08);
    display:none;z-index:60;margin-left:0;
  }
  .site-header{position:relative;}
  .main-nav.open{display:block;}
  .nav-list{flex-direction:column;align-items:stretch;gap:0;padding:8px 0;}
  .nav-list > li{border-bottom:1px solid var(--border);}
  .nav-list > li > a{padding:14px 24px;}
  .nav-list > li.is-active > a{border-bottom:0;background:var(--bg-soft);}
  .sub-menu{position:static;opacity:1;visibility:visible;transform:none;border:0;box-shadow:none;
    border-radius:0;min-width:0;max-width:none;display:none;padding:0 0 8px;}
  .sub-menu.open{display:block;}
  .sub-menu li a{padding:10px 38px;}
  .header-actions{display:none;}
  .header-actions.desktop-only{display:none;}
  .header-actions.mobile-show{display:flex;padding:14px 24px;}
  .main-nav.open .header-actions.mobile-show{display:flex;}
}
@media (max-width:560px){
  body{font-size:17px;}
  h1{font-size:1.9rem;}
  .header-inner{padding:12px 16px;}
  .container{padding:0 16px;}
}
