/*!
Theme Name: Annuaire-lien.fr
Theme URI: https://www.annuaire-lien.fr/
Author: Eagle Rocket
Description: Annuaire web généraliste — design catalogue structuré, clair et premium. SEO/Schema/E-E-A-T intégrés au thème.
Version: 2.0.1
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: annuaire-lien-fr
*/

/* =========================================================
   ANNUAIRE-LIEN.FR — Design system « index / catalogue »
   Direction : annuaire suisse moderne. Clair, dense mais aéré,
   ultra-scannable. Une grotesque géométrique + un body lisible.
   Un seul accent confiant (indigo).
   ========================================================= */

:root{
  /* Couleurs */
  --ink:#15171c;          /* texte principal, presque noir */
  --ink-soft:#3d424d;     /* texte secondaire */
  --muted:#6b7280;        /* labels, méta */
  --line:#e4e6ec;         /* filets, séparateurs */
  --line-strong:#cfd2db;
  --paper:#ffffff;        /* cartes */
  --bg:#f6f7f9;           /* fond de page */
  --bg-2:#eef0f4;         /* fond alterné */
  --accent:#2f3bd6;       /* indigo confiant */
  --accent-ink:#1f2aa8;   /* accent foncé (hover/texte) */
  --accent-wash:#eceefe;  /* fond accent très clair */
  --accent-line:#c8cdfb;
  --gold:#b07b2c;         /* signal éditorial discret */
  --ok:#157347;

  /* Typo */
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --display:'Space Grotesk','Inter',system-ui,sans-serif;

  /* Rayons & ombres */
  --r:10px;
  --r-lg:16px;
  --shadow:0 1px 2px rgba(21,23,28,.04), 0 4px 16px rgba(21,23,28,.05);
  --shadow-lg:0 8px 30px rgba(21,23,28,.10);

  /* Layout */
  --wrap:1200px;
  --gap:clamp(1rem,2.5vw,1.75rem);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-ink);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,h4{font-family:var(--display);line-height:1.12;letter-spacing:-.02em;color:var(--ink);margin:0 0 .5em;font-weight:600}
h1{font-size:clamp(2rem,4.5vw,3.1rem);letter-spacing:-.03em}
h2{font-size:clamp(1.5rem,3vw,2.1rem)}
h3{font-size:1.18rem}
p{margin:0 0 1rem}

.container{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.section{padding-block:clamp(2.5rem,6vw,4.5rem)}
.eyebrow{font-family:var(--display);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink)}

/* ---- Accessibilité ---- */
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--r) 0;z-index:2000}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* =======================  HEADER  ======================= */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line)}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:68px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;font-size:1.25rem;letter-spacing:-.02em;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mark{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--accent);color:#fff;font-weight:700;font-size:1.05rem}
.brand b{color:var(--accent-ink)}
.brand .tld{color:var(--muted);font-weight:500}

.primary-nav{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0}
.primary-nav li{list-style:none;margin:0}
.primary-nav a{color:var(--ink-soft);font-weight:500;font-size:.97rem;padding:.5rem .8rem;border-radius:8px;transition:background .15s,color .15s;display:inline-block}
.primary-nav .current-menu-item>a{color:var(--accent-ink)}
.primary-nav a:hover{background:var(--bg-2);color:var(--ink);text-decoration:none}
.primary-nav a.current{color:var(--accent-ink)}
.btn-submit{background:var(--accent)!important;color:#fff!important;border-radius:9px;padding:.55rem 1rem!important;box-shadow:0 1px 0 rgba(0,0,0,.08)}
.btn-submit:hover{background:var(--accent-ink)!important}

.nav-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:9px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@media(max-width:880px){
  .nav-toggle{display:flex}
  .primary-nav{position:absolute;top:68px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:.5rem;box-shadow:var(--shadow-lg);display:none}
  .primary-nav.open{display:flex}
  .primary-nav a{padding:.85rem 1rem}
  .btn-submit{margin-top:.4rem;text-align:center}
}

/* =======================  HERO / RECHERCHE  ======================= */
.hero{background:
   radial-gradient(120% 90% at 100% -10%, var(--accent-wash) 0%, transparent 55%),
   linear-gradient(#fff,#fbfbfd);
  border-bottom:1px solid var(--line)}
.hero-inner{padding-block:clamp(2.5rem,6vw,4rem);max-width:760px}
.hero h1{margin-bottom:.4em}
.hero .lead{font-size:1.15rem;color:var(--ink-soft);max-width:60ch;margin-bottom:1.6rem}
.searchbox{display:flex;background:#fff;border:1px solid var(--line-strong);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;max-width:600px}
.searchbox:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-wash)}
.searchbox input[type=search]{flex:1;border:0;outline:0;font:inherit;padding:.95rem 1.1rem;background:transparent;color:var(--ink)}
.searchbox button{border:0;background:var(--accent);color:#fff;font-family:var(--display);font-weight:600;padding:0 1.4rem;cursor:pointer;font-size:.98rem}
.searchbox button:hover{background:var(--accent-ink)}
.hero-meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1.6rem;color:var(--muted);font-size:.92rem}
.hero-meta b{font-family:var(--display);color:var(--ink);font-size:1.15rem;display:block;line-height:1}
.hero-meta .stat{display:flex;flex-direction:column;gap:.15rem}

/* =======================  GRILLE CATÉGORIES  ======================= */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.8rem}
.section-head p{color:var(--ink-soft);margin:.3rem 0 0;max-width:60ch}

.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:1rem}
.cat-card{position:relative;display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.15rem 1.2rem;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;overflow:hidden}
.cat-card::after{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .2s ease}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent-line);text-decoration:none}
.cat-card:hover::after{transform:scaleY(1)}
.cat-card .ico{font-size:1.5rem;line-height:1;margin-bottom:.6rem}
.cat-card h3{font-size:1.08rem;margin:0 0 .35rem;color:var(--ink)}
.cat-card .cat-count{font-size:.82rem;color:var(--muted);font-family:var(--display);font-weight:500}
.cat-card .cat-subs{margin:.55rem 0 0;font-size:.86rem;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* =======================  LISTING (catégorie)  ======================= */
.page-head{background:linear-gradient(#fff,#fbfbfd);border-bottom:1px solid var(--line);padding-block:clamp(1.8rem,4vw,2.8rem)}
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:.8rem}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent-ink)}
.breadcrumb [aria-current]{color:var(--ink-soft)}
.page-head h1{margin-bottom:.3em}
.page-head .desc{color:var(--ink-soft);max-width:65ch}

.subnav{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.1rem}
.chip{display:inline-flex;align-items:center;gap:.35rem;background:#fff;border:1px solid var(--line-strong);color:var(--ink-soft);padding:.4rem .8rem;border-radius:999px;font-size:.88rem;font-weight:500}
.chip:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-wash);text-decoration:none}
.chip .n{color:var(--muted);font-size:.8rem}

.listing-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap}
.listing-count{color:var(--muted);font-size:.92rem}
.listing-count b{color:var(--ink);font-family:var(--display)}

.site-list{display:grid;gap:.9rem}
.site-row{display:flex;align-items:flex-start;gap:1rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.1rem 1.2rem;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s}
.site-row:hover{border-color:var(--accent-line);box-shadow:var(--shadow-lg)}
.site-row .favicon{flex:0 0 auto;width:40px;height:40px;border-radius:9px;border:1px solid var(--line);background:#fff;object-fit:contain;padding:4px}
.site-row .body{flex:1;min-width:0}
.site-row h3{font-size:1.1rem;margin:0 0 .2rem}
.site-row h3 a{color:var(--ink)}
.site-row h3 a:hover{color:var(--accent-ink)}
.site-row .host{font-size:.82rem;color:var(--accent-ink);font-family:var(--display);font-weight:500;word-break:break-all}
.site-row .snippet{margin:.4rem 0 0;color:var(--ink-soft);font-size:.95rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.site-row .go{flex:0 0 auto;align-self:center;color:var(--accent-ink);font-family:var(--display);font-weight:600;font-size:.9rem;white-space:nowrap}

.empty-state{background:var(--paper);border:1px dashed var(--line-strong);border-radius:var(--r-lg);padding:2.5rem 1.5rem;text-align:center;color:var(--muted)}
.empty-state h3{color:var(--ink)}

/* =======================  SINGLE FICHE  ======================= */
.fiche-wrap{max-width:760px}
.fiche-head{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}
.fiche-head .favicon{width:56px;height:56px;border-radius:12px;border:1px solid var(--line);padding:6px;background:#fff}
.fiche-visit{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:#fff;font-family:var(--display);font-weight:600;padding:.8rem 1.4rem;border-radius:var(--r);box-shadow:var(--shadow)}
.fiche-visit:hover{background:var(--accent-ink);color:#fff;text-decoration:none;transform:translateY(-1px)}
.fiche-body{font-size:1.05rem;line-height:1.75}
.fiche-body h2{margin-top:1.6em}
.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin:1.5rem 0}
.meta-grid div{background:#fff;padding:.85rem 1rem}
.meta-grid dt{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.2rem}
.meta-grid dd{margin:0;font-weight:500;color:var(--ink)}

/* =======================  PAGES / PROSE  ======================= */
.prose{max-width:720px}
.prose h2{margin-top:1.8em}
.prose ul,.prose ol{padding-left:1.3em;margin-bottom:1rem}
.prose li{margin-bottom:.4rem}
.prose a{text-decoration:underline}
.prose blockquote{border-left:3px solid var(--accent);margin:1.5rem 0;padding:.3rem 0 .3rem 1.2rem;color:var(--ink-soft);font-style:italic}
.card-soft{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.3rem,3vw,2rem);box-shadow:var(--shadow)}

/* Formulaires (soumission / contact) — habille le shortcode eagle-contact */
.eagle-contact-form input,.eagle-contact-form textarea{border:1px solid var(--line-strong);border-radius:9px;padding:.7rem .9rem;background:#fff}
.eagle-contact-form input:focus,.eagle-contact-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-wash)}
.eagle-contact-form label{font-size:.9rem;font-weight:500;color:var(--ink-soft)}
.eagle-contact-form button{background:var(--accent);color:#fff;border:0;border-radius:9px;padding:.75rem 1.5rem;font-family:var(--display);font-weight:600;font-size:1rem}
.eagle-contact-form button:hover{background:var(--accent-ink)}
.ecf-status{font-size:.92rem;color:var(--ink-soft)}

/* Liste A-Z des catégories (footer de home) */
.az-grid{columns:4 180px;column-gap:2rem}
.az-grid a{display:block;padding:.25rem 0;color:var(--ink-soft);font-size:.93rem;border-bottom:1px solid transparent}
.az-grid a:hover{color:var(--accent-ink);text-decoration:none}

/* =======================  FOOTER  ======================= */
.site-footer{background:var(--ink);color:#c9ccd6;margin-top:clamp(3rem,7vw,5rem)}
.site-footer a{color:#c9ccd6}
.site-footer a:hover{color:#fff}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding-block:clamp(2.5rem,5vw,3.5rem);border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .brand{color:#fff}
.footer-brand .brand b{color:#aeb8ff}
.footer-brand p{margin-top:.9rem;color:#9aa0ad;font-size:.95rem;max-width:36ch}
.footer-col h4{font-family:var(--display);color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:.55rem}
.footer-col a{font-size:.95rem}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-block:1.4rem;font-size:.85rem;color:#888f9c}
.footer-bottom .legal a{margin-left:1.2rem}
@media(max-width:880px){.footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}.az-grid{columns:2 140px}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}.az-grid{columns:1}}

/* Pagination WP */
.pagination{margin-top:2rem;display:flex;justify-content:center}
.pagination .nav-links{display:flex;gap:.4rem;flex-wrap:wrap}
.pagination a,.pagination span{display:grid;place-items:center;min-width:42px;height:42px;padding:0 .6rem;border:1px solid var(--line-strong);border-radius:9px;background:#fff;color:var(--ink-soft);font-family:var(--display);font-weight:500}
.pagination a:hover{border-color:var(--accent);color:var(--accent-ink);text-decoration:none}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Reveal au chargement (finit visible, respecte reduced-motion) */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(14px);animation:reveal .6s cubic-bezier(.22,.61,.36,1) forwards}
  .reveal-2{animation-delay:.08s}
  .reveal-3{animation-delay:.16s}
  @keyframes reveal{to{opacity:1;transform:none}}
}
