:root{--bg:#FFFBF5;--bg-card:#FFFFFF;--bg-soft:#FFF4E6;--ink:#2D2A26;--ink-dim:#6B5F52;--ink-muted:#9C8E7F;--accent:#FF8B3D;--accent-dark:#E5701F;--accent-soft:#FFE5D0;--green:#4CAF50;--green-soft:#E8F5E9;--yellow:#FFC107;--pink:#FF7B9C;--border:#F0E5D7;--serif:'Fraunces',Georgia,serif;--sans:'Inter',-apple-system,sans-serif}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;font-size:16px}
a{color:var(--accent-dark);text-decoration:none}
a:hover{text-decoration:underline}
.promo-banner{background:linear-gradient(90deg,var(--accent),var(--pink));color:white;text-align:center;padding:10px 16px;font-size:14px;font-weight:600}
.promo-banner a{color:white;text-decoration:underline}
header{background:white;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,0.03)}
.header-inner{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.logo{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--accent-dark);display:flex;align-items:center;gap:8px}
.logo-mark{font-size:32px}
nav ul{list-style:none;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
nav a{color:var(--ink);font-weight:500;padding:8px 14px;border-radius:100px;transition:all 0.2s;font-size:14px}
nav a:hover{background:var(--accent-soft);color:var(--accent-dark);text-decoration:none}
nav a.cta{background:var(--accent);color:white;font-weight:600}
nav a.cta:hover{background:var(--accent-dark)}
.hero{background:linear-gradient(135deg,var(--accent-soft) 0%,var(--bg-soft) 100%);padding:80px 24px;text-align:center;position:relative;overflow:hidden}
.hero-badge{display:inline-block;background:white;color:var(--accent-dark);padding:8px 18px;border-radius:100px;font-size:13px;font-weight:600;margin-bottom:24px;border:1px solid var(--border)}
.hero h1{font-family:var(--serif);font-size:clamp(36px,6vw,64px);font-weight:700;line-height:1.1;letter-spacing:-0.02em;margin-bottom:24px;max-width:900px;margin-left:auto;margin-right:auto;color:var(--ink)}
.hero h1 em{color:var(--accent-dark);font-style:normal}
.hero-subtitle{font-size:18px;color:var(--ink-dim);max-width:650px;margin:0 auto 36px;line-height:1.7}
.hero-cta-group{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.btn-primary{background:var(--accent);color:white;padding:16px 32px;border-radius:100px;font-weight:600;font-size:15px;display:inline-block;transition:all 0.2s}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);text-decoration:none}
.btn-secondary{background:white;color:var(--ink);padding:16px 32px;border-radius:100px;font-weight:600;font-size:15px;display:inline-block;border:1px solid var(--border);transition:all 0.2s}
.btn-secondary:hover{border-color:var(--accent);text-decoration:none}
.hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));max-width:800px;margin:0 auto;background:white;border-radius:24px;padding:28px 20px;border:1px solid var(--border);gap:20px}
.hero-stat{text-align:center}
.hero-stat-number{font-family:var(--serif);font-size:36px;font-weight:700;color:var(--accent-dark)}
.hero-stat-label{font-size:12px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:0.1em;margin-top:4px}
.section{padding:80px 0}
.section-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.section-tag{display:inline-block;background:var(--green-soft);color:var(--green);font-size:12px;font-weight:600;padding:6px 14px;border-radius:100px;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:12px}
.section-title{font-family:var(--serif);font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:-0.02em;margin-bottom:12px;color:var(--ink)}
.section-subtitle{font-size:17px;color:var(--ink-dim);max-width:600px;margin-bottom:40px}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}
.cat-card{background:white;border:1px solid var(--border);border-radius:20px;padding:28px 16px;text-align:center;transition:all 0.2s;display:block}
.cat-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 8px 24px rgba(255,139,61,0.12);text-decoration:none}
.cat-card-emoji{font-size:44px;display:block;margin-bottom:12px}
.cat-card h3{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink)}
.article-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.article-card{background:white;border:1px solid var(--border);border-radius:20px;padding:28px;text-decoration:none;display:block;transition:all 0.2s}
.article-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 12px 32px rgba(255,139,61,0.08)}
.article-card-icon{font-size:44px;margin-bottom:16px}
.article-card-tag{display:inline-block;background:var(--accent-soft);color:var(--accent-dark);font-size:11px;font-weight:700;padding:4px 12px;border-radius:100px;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:12px}
.article-card h3{font-family:var(--serif);font-size:20px;color:var(--ink);line-height:1.3;margin-bottom:10px}
.article-card p{font-size:14px;color:var(--ink-dim);line-height:1.6;margin-bottom:14px}
.article-card-meta{font-size:12px;color:var(--accent-dark);font-weight:600}
.about-section{background:var(--bg-soft)}
.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.about-card{background:white;border:1px solid var(--border);border-radius:20px;padding:28px;transition:all 0.2s}
.about-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.about-icon{font-size:40px;margin-bottom:12px}
.about-card h3{font-family:var(--serif);font-size:18px;margin-bottom:8px;color:var(--accent-dark)}
.about-card p{font-size:14px;color:var(--ink-dim);line-height:1.6}
footer{background:#2D2A26;color:#C5BDB1;padding:60px 24px 30px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
@media (max-width:720px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-brand .logo{color:white}
.footer-brand p{font-size:14px;line-height:1.6;margin-top:12px;max-width:300px}
.footer-col h4{font-family:var(--serif);color:white;font-size:16px;margin-bottom:14px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col a{color:#C5BDB1;font-size:14px}
.footer-col a:hover{color:var(--accent);text-decoration:none}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;display:flex;justify-content:space-between;font-size:13px;flex-wrap:wrap;gap:12px}
.pw-article{max-width:800px;margin:0 auto;padding:40px 24px 80px}
.pw-breadcrumb{font-size:13px;color:var(--ink-dim);margin-bottom:24px}
.pw-breadcrumb a{color:var(--accent-dark)}
.pw-article-header{margin-bottom:40px;padding-bottom:32px;border-bottom:1px solid var(--border)}
.pw-article-tag{display:inline-block;background:var(--accent-soft);color:var(--accent-dark);padding:6px 16px;border-radius:100px;font-size:12px;font-weight:700;margin-bottom:20px;text-transform:uppercase}
.pw-article h1{font-family:var(--serif);font-size:clamp(28px,5vw,44px);font-weight:700;line-height:1.2;margin-bottom:16px;color:var(--ink)}
.pw-article-lede{font-size:19px;line-height:1.7;color:var(--ink-dim);margin-bottom:20px}
.pw-article-meta{display:flex;gap:12px;font-size:13px;color:var(--ink-muted);flex-wrap:wrap}
.pw-article-body h2{font-family:var(--serif);font-size:28px;margin:40px 0 16px;color:var(--accent-dark);font-weight:700}
.pw-article-body h3{font-size:20px;font-weight:600;margin:24px 0 10px}
.pw-article-body p{font-size:16px;line-height:1.8;margin-bottom:16px;color:var(--ink)}
.pw-table-wrap{overflow-x:auto;margin:24px 0;border-radius:16px;border:1px solid var(--border)}
.pw-table{width:100%;border-collapse:collapse;background:white}
.pw-table th{background:var(--accent-soft);color:var(--accent-dark);padding:14px 16px;text-align:left;font-size:13px;font-weight:700;text-transform:uppercase}
.pw-table td{padding:14px 16px;border-bottom:1px solid var(--border)}
.pw-table tr:last-child td{border-bottom:none}
.pw-table tr:hover td{background:var(--bg-soft)}
.pw-table-link{background:var(--accent);color:white;padding:6px 14px;border-radius:100px;font-size:13px;font-weight:600}
.pw-table-link:hover{background:var(--accent-dark);text-decoration:none}
.pw-product-card{background:white;border:1px solid var(--border);border-radius:20px;padding:28px;margin:20px 0;transition:all 0.2s}
.pw-product-card.rank-gold{border-color:var(--yellow);box-shadow:0 8px 24px rgba(255,193,7,0.15)}
.pw-product-card.rank-silver{border-color:#C0C0C0}
.pw-product-card.rank-bronze{border-color:#CD7F32}
.pw-product-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px;flex-wrap:wrap}
.pw-product-rank{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}
.pw-rank-icon{font-size:32px}
.pw-product-name{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--ink)}
.pw-product-stats{text-align:right}
.pw-price{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--accent-dark)}
.pw-rating{font-size:14px;color:var(--green);font-weight:600}
.pw-product-subtitle{font-size:14px;color:var(--ink-dim);font-style:italic;margin-bottom:12px}
.pw-product-desc{font-size:15px;line-height:1.7;margin-bottom:16px}
.pw-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0;padding:16px;background:var(--bg-soft);border-radius:12px;font-size:13px}
@media (max-width:600px){.pw-pros-cons{grid-template-columns:1fr}}
.pw-pros{color:var(--green)}
.pw-cons{color:#C19A00}
.pw-pros strong,.pw-cons strong{display:block;font-size:11px;text-transform:uppercase;margin-bottom:6px;letter-spacing:0.05em}
.pw-btn-amazon{display:inline-flex;align-items:center;gap:8px;background:#FF9900;color:white;padding:12px 24px;border-radius:100px;font-weight:700;font-size:14px;transition:all 0.2s}
.pw-btn-amazon:hover{background:#F08800;transform:translateY(-1px);text-decoration:none}
.pw-verdict{background:linear-gradient(135deg,var(--accent-soft),var(--green-soft));border-left:4px solid var(--accent);padding:24px;border-radius:0 16px 16px 0;margin:24px 0;font-size:16px;line-height:1.7}
.pw-search-section{max-width:800px;margin:40px auto;padding:0 24px}
.pw-search-wrap{position:relative;margin-bottom:16px}
.pw-search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:20px;pointer-events:none}
.pw-search-section input{width:100%;padding:16px 24px 16px 56px;background:white;border:1px solid var(--border);border-radius:16px;color:var(--ink);font-size:16px;outline:none;transition:border-color 0.2s}
.pw-search-section input:focus{border-color:var(--accent)}
.pw-filter-tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.pw-filter-btn{background:white;border:1px solid var(--border);padding:8px 16px;border-radius:100px;font-size:13px;cursor:pointer;transition:all 0.15s;font-family:inherit}
.pw-filter-btn:hover{border-color:var(--accent)}
.pw-filter-btn.active{background:var(--accent);color:white;border-color:var(--accent)}


/* ============================================
   PetWizz - Classes complémentaires V2
   ============================================ */

/* Catégories */
.pw-cat-articles {
  max-width: 1200px;
  margin: 60px auto;
  padding: 0 24px;
}
.pw-cat-articles h2 {
  font-family: var(--serif);
  font-size: 28px;
  color: var(--ink);
  margin-bottom: 24px;
}
.pw-cat-article-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.pw-cat-article-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  text-decoration: none;
  display: block;
  transition: all 0.2s;
}
.pw-cat-article-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
  box-shadow: 0 8px 24px rgba(255, 139, 61, 0.12);
  text-decoration: none;
}
.pw-cat-article-tag {
  display: inline-block;
  background: var(--accent-soft);
  color: var(--accent-dark);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
}
.pw-cat-article-card h3 {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--ink);
  line-height: 1.3;
}
.pw-cat-intro {
  font-size: 18px;
  color: var(--ink-dim);
  line-height: 1.6;
  max-width: 700px;
  margin: 0 auto 40px;
}
.pw-cat-hero {
  text-align: center;
  padding: 80px 24px 40px;
  max-width: 900px;
  margin: 0 auto;
}
.pw-cat-emoji {
  font-size: 56px;
  display: block;
  margin-bottom: 12px;
}
.pw-cat-hero h1 {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 16px;
}

/* Table */
.pw-table-rating {
  background: var(--green-soft);
  color: var(--green);
  padding: 4px 10px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 13px;
}

/* Product link grids (dans guides) */
.pw-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  margin: 20px 0;
}
.pw-product-link-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  text-decoration: none;
  display: block;
  transition: all 0.2s;
}
.pw-product-link-card:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  text-decoration: none;
}
.pw-product-link-name {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}
.pw-product-link-cat {
  font-size: 11px;
  color: var(--ink-muted);
  margin-bottom: 10px;
  font-style: italic;
}
.pw-product-link-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.pw-product-link-price {
  font-family: var(--serif);
  font-weight: 700;
  color: var(--accent-dark);
  font-size: 15px;
}
.pw-product-link-rating {
  font-size: 12px;
  color: var(--green);
}

/* Footer fix */
.footer-col {
  /* déjà défini mais sécurité */
}
.footer-brand {
  /* déjà défini mais sécurité */
}

/* Search section pour articles.html */
.pw-search-section {
  max-width: 800px;
  margin: 40px auto;
  padding: 0 24px;
}
.pw-search-wrap {
  position: relative;
}
.pw-search-icon {
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 20px;
  pointer-events: none;
}
.pw-search-section input {
  width: 100%;
  padding: 16px 24px 16px 56px;
  background: white;
  border: 1px solid var(--border);
  border-radius: 100px;
  color: var(--ink);
  font-size: 15px;
  font-family: var(--sans);
  outline: none;
}
.pw-search-section input:focus {
  border-color: var(--accent);
}
.pw-filter-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 16px;
}
.pw-filter-btn {
  background: white;
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 8px 16px;
  border-radius: 100px;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s;
}
.pw-filter-btn:hover {
  border-color: var(--accent);
}
.pw-filter-btn.active {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}

/* hero-cta-secondary pour homepage */
.hero-cta-secondary {
  display: inline-block;
  background: white;
  color: var(--ink);
  padding: 16px 32px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 15px;
  border: 1px solid var(--border);
  text-decoration: none;
  transition: all 0.2s;
}
.hero-cta-secondary:hover {
  border-color: var(--accent);
  color: var(--accent);
  text-decoration: none;
}


/* Classes finales manquantes V3 */
.pw-products-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin: 32px 0;
}

.hero-cta-primary {
  display: inline-block;
  background: var(--accent);
  color: white;
  padding: 16px 32px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  transition: all 0.2s;
  border: 1px solid var(--accent);
}
.hero-cta-primary:hover {
  background: var(--accent-dark);
  border-color: var(--accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255, 139, 61, 0.3);
  text-decoration: none;
}


/* ============================================
   Fiches produits — Actions communes
   ============================================ */
.product-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 16px;
}
.product-actions > * {
  flex: 1;
  min-width: 140px;
}
.btn-product-detail {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 20px;
  background: transparent;
  color: inherit;
  border: 1.5px solid currentColor;
  border-radius: 100px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.2s;
  text-align: center;
}
.btn-product-detail:hover {
  background: rgba(0, 0, 0, 0.04);
  text-decoration: none;
  transform: translateY(-1px);
}
@media (max-width: 600px) {
  .product-actions { flex-direction: column; }
  .product-actions > * { width: 100%; }
}


/* ============================================
   PetWizz — Pages produits
   ============================================ */
.pw-product-page {
  max-width: 880px;
  margin: 0 auto;
  padding: 40px 24px 80px;
}
.pw-product-page .pw-breadcrumb {
  font-size: 13px;
  color: var(--ink-muted);
  margin-bottom: 24px;
}
.pw-product-page .pw-breadcrumb a {
  color: var(--accent);
  text-decoration: none;
}
.pw-product-header {
  text-align: center;
  padding-bottom: 32px;
}
.pw-product-header h1 {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 48px);
  color: var(--ink);
  margin: 12px 0;
}
.pw-product-tagline {
  font-size: 18px;
  color: var(--ink-dim);
  font-style: italic;
  margin-bottom: 16px;
}
.pw-product-hero-box {
  background: linear-gradient(135deg, var(--accent-soft), white);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 32px;
  margin: 32px 0;
  display: flex;
  gap: 32px;
  align-items: center;
}
@media (max-width: 600px) {
  .pw-product-hero-box { flex-direction: column; text-align: center; }
}
.pw-product-hero-emoji {
  font-size: 80px;
  flex-shrink: 0;
}
.pw-product-hero-info {
  flex: 1;
}
.pw-product-hero-info h2 {
  font-family: var(--serif);
  font-size: 24px;
  color: var(--ink);
  margin-bottom: 12px;
}
.pw-product-hero-info p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink);
  margin-bottom: 20px;
}
.pw-product-hero-cta {
  display: flex;
  gap: 20px;
  align-items: center;
  flex-wrap: wrap;
}
.pw-product-hero-price {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 700;
  color: var(--accent-dark);
}
.pw-product-cta-btn {
  display: inline-block;
  background: var(--accent);
  color: white;
  padding: 14px 28px;
  border-radius: 100px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
  font-size: 15px;
}
.pw-product-cta-btn:hover {
  background: var(--accent-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255, 139, 61, 0.3);
  text-decoration: none;
}
.pw-affiliate-disclosure {
  font-size: 12px;
  color: var(--ink-muted);
  text-align: center;
  font-style: italic;
  margin: 16px 0 40px;
}
.pw-features-list {
  list-style: none;
  padding: 0;
  margin: 16px 0;
}
.pw-features-list li {
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: 15px;
}
.pw-related-articles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
  margin: 24px 0;
}
.pw-related-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  text-decoration: none;
  transition: all 0.2s;
  display: block;
}
.pw-related-card:hover {
  transform: translateY(-3px);
  border-color: var(--accent);
  text-decoration: none;
}
.pw-related-tag {
  font-size: 11px;
  color: var(--accent);
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}
.pw-related-card h3 {
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
  line-height: 1.4;
}
.pw-faq {
  background: var(--cream);
  border-radius: 16px;
  padding: 24px;
  margin: 24px 0;
}
.pw-faq h3 {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--ink);
  margin: 16px 0 8px;
}
.pw-faq h3:first-child { margin-top: 0; }
.pw-final-cta {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: white;
  border-radius: 24px;
  padding: 40px;
  text-align: center;
  margin: 40px 0;
}
.pw-final-cta h2 {
  font-family: var(--serif);
  color: white;
  font-size: 28px;
  margin-bottom: 12px;
}
.pw-final-cta p {
  color: rgba(255, 255, 255, 0.95);
  font-size: 16px;
  margin-bottom: 24px;
}
.pw-product-cta-btn-large {
  display: inline-block;
  background: white;
  color: var(--accent-dark);
  padding: 18px 36px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  transition: all 0.2s;
}
.pw-product-cta-btn-large:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
  text-decoration: none;
}


/* ============================================
   Catalogue produits — Grid pour chaque site
   ============================================ */
.pw-prod-catalog-grid,
.ss-prod-catalog-grid,
.gn-prod-catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
.pw-prod-catalog-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  text-decoration: none;
  display: block;
  transition: all 0.2s;
}
.pw-prod-catalog-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
  box-shadow: 0 8px 24px rgba(255, 139, 61, 0.15);
  text-decoration: none;
}
.pw-prod-catalog-emoji { font-size: 40px; margin-bottom: 12px; }
.pw-prod-catalog-card h3 { font-family: var(--serif); font-size: 18px; color: var(--ink); margin-bottom: 10px; }
.pw-prod-catalog-desc { font-size: 13px; color: var(--ink-dim); margin-bottom: 14px; line-height: 1.5; }
.pw-prod-catalog-meta { display: flex; justify-content: space-between; align-items: center; padding-top: 14px; border-top: 1px solid var(--border); }
.pw-prod-catalog-price { font-family: var(--serif); font-weight: 700; color: var(--accent-dark); font-size: 16px; }
.pw-prod-catalog-rating { font-size: 13px; color: var(--green); }

.ss-prod-catalog-card {
  background: white;
  border: 1px solid #EAE5DD;
  border-radius: 20px;
  padding: 28px;
  text-decoration: none;
  display: block;
  transition: all 0.2s;
}
.ss-prod-catalog-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
  text-decoration: none;
}
.ss-prod-catalog-emoji { font-size: 44px; margin-bottom: 16px; }
.ss-prod-catalog-card h3 { font-family: var(--display); font-size: 19px; color: var(--ink); margin-bottom: 10px; font-weight: 400; }
.ss-prod-catalog-desc { font-size: 13px; color: var(--ink-dim); margin-bottom: 16px; line-height: 1.6; font-style: italic; }
.ss-prod-catalog-meta { display: flex; justify-content: space-between; padding-top: 16px; border-top: 1px solid #EAE5DD; }
.ss-prod-catalog-price { font-family: var(--display); font-weight: 600; color: var(--accent); font-size: 16px; }
.ss-prod-catalog-rating { font-size: 13px; color: var(--ink-dim); }

.gn-prod-catalog-card {
  background: var(--bg-card);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 24px;
  text-decoration: none;
  display: block;
  transition: all 0.25s;
}
.gn-prod-catalog-card:hover {
  transform: translateY(-4px);
  border-color: var(--neon-cyan);
  box-shadow: 0 10px 30px rgba(0, 229, 255, 0.15);
  text-decoration: none;
}
.gn-prod-catalog-emoji { font-size: 40px; margin-bottom: 12px; }
.gn-prod-catalog-card h3 { font-family: 'Orbitron', sans-serif; font-size: 16px; color: var(--ink); margin-bottom: 10px; }
.gn-prod-catalog-desc { font-size: 12px; color: var(--ink-dim); margin-bottom: 14px; line-height: 1.5; }
.gn-prod-catalog-meta { display: flex; justify-content: space-between; padding-top: 14px; border-top: 1px solid rgba(255, 255, 255, 0.06); }
.gn-prod-catalog-price { font-family: 'Orbitron', sans-serif; font-weight: 800; background: linear-gradient(135deg, var(--neon-cyan), var(--neon-green)); -webkit-background-clip: text; background-clip: text; color: transparent; font-size: 14px; }
.gn-prod-catalog-rating { font-size: 12px; color: var(--ink-dim); font-family: 'JetBrains Mono', monospace; }

/* SkinSavvy cat hero */
.ss-cat-hero { text-align: center; padding: 80px 24px 40px; max-width: 900px; margin: 0 auto; }
.ss-cat-hero h1 { font-family: var(--display); font-size: clamp(36px, 5vw, 56px); color: var(--ink); margin-bottom: 16px; font-weight: 400; }
.ss-cat-hero p { font-size: 18px; color: var(--ink-dim); line-height: 1.7; }

.ss-cat-articles { max-width: 1200px; margin: 40px auto 80px; padding: 0 24px; }

.gn-cat-hero { text-align: center; padding: 80px 24px 40px; max-width: 900px; margin: 0 auto; }
.gn-cat-hero h1 { font-family: 'Orbitron', sans-serif; font-size: clamp(36px, 5vw, 56px); color: var(--ink); margin-bottom: 16px; text-transform: uppercase; font-weight: 800; }
.gn-cat-hero p { font-size: 17px; color: var(--ink-dim); line-height: 1.7; }

.gn-cat-articles { max-width: 1200px; margin: 40px auto 80px; padding: 0 24px; }


/* ============================================
   Maillage interne — Liens contextuels
   ============================================ */
.related-inline {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 139, 61, 0.3);
  padding-bottom: 1px;
  transition: all 0.15s;
}
.related-inline:hover {
  color: var(--accent-dark);
  border-bottom-color: var(--accent-dark);
}
.related-articles-section {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
  margin: 20px 0 32px;
}
.related-article-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px;
  text-decoration: none;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  transition: all 0.2s;
}
.related-article-card:hover {
  transform: translateY(-3px);
  border-color: var(--accent);
  box-shadow: 0 6px 18px rgba(255, 139, 61, 0.12);
  text-decoration: none;
}
.related-emoji {
  font-size: 22px;
  flex-shrink: 0;
}
.related-article-card h4 {
  font-family: var(--serif);
  font-size: 15px;
  color: var(--ink);
  line-height: 1.4;
  margin: 0;
}


/* ============================================
   FAQ Section (pour articles)
   ============================================ */
.pw-faq-section {
  background: var(--cream);
  border-radius: 16px;
  padding: 28px;
  margin: 24px 0;
}
.pw-faq-item { margin-bottom: 20px; }
.pw-faq-item:last-child { margin-bottom: 0; }
.pw-faq-item h3 {
  font-family: var(--serif);
  font-size: 17px;
  color: var(--accent-dark);
  margin: 0 0 8px;
}
.pw-faq-item p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink);
  margin: 0;
}


/* ============================================
   Author boxes — E-E-A-T compliance
   ============================================ */
.author-box {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 16px 0 24px;
  padding: 14px 18px;
  background: rgba(0,0,0,0.03);
  border-radius: 12px;
  max-width: fit-content;
}
.author-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 700;
  font-size: 16px;
  flex-shrink: 0;
}
.author-info { line-height: 1.4; }
.author-name { font-size: 14px; color: inherit; }
.author-title { font-size: 12px; opacity: 0.75; }

.author-full-section {
  margin: 48px 0;
  padding: 32px;
  background: rgba(0,0,0,0.03);
  border-radius: 16px;
  border-left: 4px solid currentColor;
}
.author-full-section h3 {
  margin-bottom: 20px;
  font-size: 18px;
  opacity: 0.7;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.author-full-content {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}
@media (max-width: 600px) {
  .author-full-content { flex-direction: column; }
}
.author-avatar-large {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 700;
  font-size: 28px;
  flex-shrink: 0;
}
.author-full-name {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 4px;
}
.author-full-title {
  font-size: 14px;
  margin-bottom: 12px;
  opacity: 0.75;
  font-style: italic;
}
.author-credentials {
  font-size: 13px;
  margin-bottom: 10px;
  opacity: 0.85;
}
.author-bio {
  font-size: 14px;
  line-height: 1.7;
  margin: 0;
}

/* Catégorie : intro éditoriale */
.cat-intro {
  max-width: 800px;
  margin: 32px auto;
  padding: 0 24px;
}
.cat-intro p {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 18px;
}

.cat-intro-editorial {
  max-width: 800px;
  margin: 32px auto;
  padding: 24px;
}
.cat-intro-editorial p {
  font-size: 16px;
  line-height: 1.85;
  margin-bottom: 18px;
}
