/*
Theme Name: AssurvVente Child Theme
Description: Thème enfant personnalisé pour assurvente.shop - E-commerce d'électroménagers avec système de crédit et contrôle à distance
Version: 1.1.8
Author: AssurvVente Team
*/

/* Import Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&family=Roboto:wght@300;400;500;700&family=Poppins:wght@300;400;500;600;700&display=swap');

/* CSS Variables - Palette de couleurs AssurvVente */
:root {
  /* Couleurs principales */
  --primary-blue: #0066ff;
  --electric-blue: #00ccff;
  --dark-blue: #003d99;
  
  /* Couleurs neutres */
  --neutral-gray: #f8f9fa;
  --medium-gray: #6c757d;
  --dark-gray: #343a40;
  --light-gray: #e9ecef;
  
  /* Accents métalliques */
  --metallic-silver: #c0c0c0;
  --metallic-gold: #ffd700;
  --neon-green: #00ff88;
  
  /* Typographie */
  --font-primary: 'Montserrat', sans-serif;
  --font-secondary: 'Roboto', sans-serif;
  --font-accent: 'Poppins', sans-serif;
  
  /* Espacements */
  --spacing-xs: 0.5rem;
  --spacing-sm: 1rem;
  --spacing-md: 1.5rem;
  --spacing-lg: 2rem;
  --spacing-xl: 3rem;
  
  /* Transitions */
  --transition-fast: 0.2s ease-in-out;
  --transition-normal: 0.3s ease-in-out;
  --transition-slow: 0.5s ease-in-out;
}

/* Reset et base */
* {
  box-sizing: border-box;
}

body {
  font-family: var(--font-secondary);
  line-height: 1.6;
  color: var(--dark-gray);
  background-color: var(--neutral-gray);
}

/* Typographie */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-primary);
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: var(--spacing-sm);
}

h1 {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--primary-blue);
}

h2 {
  font-size: 2rem;
  font-weight: 700;
}

h3 {
  font-size: 1.5rem;
  font-weight: 600;
}

p {
  margin-bottom: var(--spacing-sm);
}

/* Boutons */
.btn-primary {
  background: linear-gradient(135deg, var(--primary-blue), var(--electric-blue));
  border: none;
  color: white;
  padding: var(--spacing-sm) var(--spacing-lg);
  border-radius: 8px;
  font-family: var(--font-accent);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: all var(--transition-normal);
  cursor: pointer;
  box-shadow: 0 4px 15px rgba(0, 102, 255, 0.3);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 102, 255, 0.4);
  background: linear-gradient(135deg, var(--dark-blue), var(--primary-blue));
}

.btn-secondary {
  background: transparent;
  border: 2px solid var(--primary-blue);
  color: var(--primary-blue);
  padding: var(--spacing-sm) var(--spacing-lg);
  border-radius: 8px;
  font-family: var(--font-accent);
  font-weight: 500;
  transition: all var(--transition-normal);
  cursor: pointer;
}

.btn-secondary:hover {
  background: var(--primary-blue);
  color: white;
  transform: translateY(-1px);
}

/* Cards et conteneurs */
.card {
  background: white;
  border-radius: 12px;
  padding: var(--spacing-lg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  transition: all var(--transition-normal);
  border: 1px solid var(--light-gray);
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

/* Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    transform: scale(1);
  }
}

.animate-fade-in {
  animation: fadeInUp 0.6s ease-out;
}

.animate-pulse {
  animation: pulse 2s infinite;
}

/* Header personnalisé */
.site-header {
  background: linear-gradient(135deg, var(--primary-blue), var(--dark-blue));
  padding: var(--spacing-sm) 0;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.site-header .site-title {
  font-family: var(--font-primary);
  font-weight: 800;
  font-size: 1.8rem;
  color: white;
  text-decoration: none;
}

/* Navigation */
.main-navigation ul {
  list-style: none;
  display: flex;
  gap: var(--spacing-lg);
  margin: 0;
  padding: 0;
}

.main-navigation a {
  color: white;
  text-decoration: none;
  font-family: var(--font-accent);
  font-weight: 500;
  transition: all var(--transition-fast);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: 6px;
}

.main-navigation a:hover {
  background: rgba(255, 255, 255, 0.1);
  transform: translateY(-1px);
}

/* Produits WooCommerce */
.woocommerce .products .product {
  background: white;
  border-radius: 12px;
  overflow: hidden;
  transition: all var(--transition-normal);
  border: 1px solid var(--light-gray);
}

.woocommerce .products .product:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.woocommerce .products .product img {
  transition: all var(--transition-normal);
}

.woocommerce .products .product:hover img {
  transform: scale(1.05);
}

/* Calculateur de crédit */
.credit-calculator {
  background: linear-gradient(135deg, var(--neutral-gray), white);
  border-radius: 12px;
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border: 2px solid var(--electric-blue);
}

.credit-calculator h3 {
  color: var(--primary-blue);
  font-family: var(--font-primary);
  margin-bottom: var(--spacing-md);
}

.credit-result {
  background: white;
  border-radius: 8px;
  padding: var(--spacing-md);
  margin-top: var(--spacing-md);
  border-left: 4px solid var(--neon-green);
}

/* Formulaires */
.form-group {
  margin-bottom: var(--spacing-md);
}

.form-group label {
  display: block;
  font-family: var(--font-accent);
  font-weight: 500;
  margin-bottom: var(--spacing-xs);
  color: var(--dark-gray);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: var(--spacing-sm);
  border: 2px solid var(--light-gray);
  border-radius: 8px;
  font-family: var(--font-secondary);
  transition: all var(--transition-fast);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary-blue);
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.1);
}

/* Checkbox T&C obligatoire */
.terms-checkbox {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin: var(--spacing-lg) 0;
  padding: var(--spacing-md);
  background: var(--neutral-gray);
  border-radius: 8px;
  border: 2px solid var(--electric-blue);
}

.terms-checkbox input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.terms-checkbox label {
  margin: 0;
  font-weight: 500;
  color: var(--dark-gray);
}

/* Dashboard admin */
.admin-dashboard {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
}

.admin-widget {
  background: white;
  border-radius: 12px;
  padding: var(--spacing-lg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  border-top: 4px solid var(--primary-blue);
}

.admin-widget h3 {
  color: var(--primary-blue);
  margin-bottom: var(--spacing-md);
}

/* Responsive Design */
@media (max-width: 768px) {
  :root {
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.75rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
  }
  
  h1 {
    font-size: 2rem;
  }
  
  h2 {
    font-size: 1.5rem;
  }
  
  .main-navigation ul {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .admin-dashboard {
    grid-template-columns: 1fr;
  }
  
  .btn-primary,
  .btn-secondary {
    width: 100%;
    text-align: center;
  }
}

/* Utilitaires */
.text-center { text-align: center; }
.text-primary { color: var(--primary-blue); }
.text-muted { color: var(--medium-gray); }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--spacing-xs); }
.mb-2 { margin-bottom: var(--spacing-sm); }
.mb-3 { margin-bottom: var(--spacing-md); }
.mb-4 { margin-bottom: var(--spacing-lg); }
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--spacing-xs); }
.mt-2 { margin-top: var(--spacing-sm); }
.mt-3 { margin-top: var(--spacing-md); }
.mt-4 { margin-top: var(--spacing-lg); }

/* Styles spécifiques ShopLentor */
.shoplentor-product-grid .product-item {
  transition: all var(--transition-normal);
}

.shoplentor-product-grid .product-item:hover {
  transform: translateY(-5px);
}

.shoplentor-checkout-progress {
  background: linear-gradient(135deg, var(--primary-blue), var(--electric-blue));
  color: white;
  border-radius: 8px;
  padding: var(--spacing-md);
}

/* === Layout & Header/Nav === */
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:24px}
.brand{font-size:22px; font-weight:700; color:#fff; text-decoration:none}
.site-nav .menu{list-style:none; padding:0; margin:0; display:flex; gap:18px}
.site-nav .menu li a{color:#fff; text-decoration:none; font-weight:500}
.site-nav .menu li a:hover{text-decoration:underline}

/* === Hero === */
.av-hero{background:linear-gradient(90deg,var(--av-primary),var(--av-accent)); color:#fff; padding:56px 0; margin:0 0 28px}
.av-hero h1{margin:0 0 10px; font-size:32px}
.av-hero p{opacity:.95; margin:0 0 18px}
.actions{display:flex; gap:12px}
.btn{display:inline-block; padding:10px 16px; border-radius:8px; border:1px solid #fff}
.btn-primary{background:#fff; color:var(--av-primary); border-color:#fff; font-weight:600}
.btn-outline{background:transparent; color:#fff}

/* === Features === */
.av-features{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin:24px auto}
.av-features .feature{border:1px solid var(--av-border); border-radius:12px; padding:16px; background:#fff}

/* === Latest posts === */
.av-latest h2{margin:0 0 12px}
.av-latest .posts{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.card{border:1px solid var(--av-border); border-radius:12px; padding:16px; background:#fff}
/* === NAV HEADER: structure + dropdowns (AssurVente) === */
.site-nav .menu{list-style:none; margin:0; padding:0; display:flex; gap:22px; align-items:center; flex-wrap:wrap}
.site-nav .menu > li{position:relative}
.site-nav .menu > li > a{color:#fff; text-decoration:none; font-weight:600; padding:8px 4px; display:inline-block}
.site-nav .menu > li > a:hover{opacity:.9}

/* Sous-menus */
.site-nav .menu li .sub-menu{list-style:none; margin:0; padding:8px 0; display:none; position:absolute; left:0; top:calc(100% + 8px); background:#fff; color:#111827; border:1px solid #e5e7eb; border-radius:10px; min-width:220px; box-shadow:0 8px 20px rgba(0,0,0,.06); z-index:30}
.site-nav .menu li:hover > .sub-menu{display:block}
.site-nav .menu li .sub-menu li a{color:#111827; display:block; padding:8px 12px; text-decoration:none; white-space:nowrap}
.site-nav .menu li .sub-menu li a:hover{background:#f8fafc}

/* HEADER layout */
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:24px}
.brand{font-size:22px; font-weight:700; color:#fff; text-decoration:none}

/* --- Fallback si pas d'image catégorie --- */
.av-cat-fallback{
  height:140px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(90deg,#f0f4ff,#e9eefc);
  color:#334155; font-weight:600; padding:8px; text-align:center;
}

/* Catégories */
.av-cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.av-cat-card{border:1px solid var(--av-border);border-radius:12px;background:#fff;overflow:hidden;text-align:center;display:block;transition: transform .15s ease}
.av-cat-card:hover{transform:translateY(-2px)}
.av-cat-card img{width:100%;height:140px;object-fit:cover;display:block}
.av-cat-card .cat-name{padding:12px;font-weight:600;color:var(--av-text)}

/* Footer menu */
.footer-nav .menu{list-style:none; margin:8px 0 0; padding:0; display:flex; gap:16px; flex-wrap:wrap}
.footer-nav .menu a{color:#4b5563; text-decoration:none}
.footer-nav .menu a:hover{text-decoration:underline}
/* === Header sticky + shadow (AssurVente) === */
.site-header{
  position: sticky; top: 0; z-index: 1000;
  background: linear-gradient(90deg, var(--av-primary), var(--av-accent));
  box-shadow: 0 6px 20px rgba(17,24,39,.12);
}
.site-header .container{ padding: 10px 0; }

/* Dropdown déjà stylé; renfort lisibilité */
.site-nav .menu li .sub-menu{
  background:#fff; color:#111827; border:1px solid #e5e7eb;
  border-radius:10px; box-shadow:0 8px 20px rgba(0,0,0,.06);
}

/* Petites adaptations responsive */
@media (max-width: 820px){
  .site-nav .menu{ gap: 12px; }
  .brand{ font-size: 20px; }
}

/* Espace d'ancrage (si liens #ancres) avec header sticky */
:target::before{ content:; display:block; height:64px; margin-top:-64px; }
/* ===== Header blanc, sticky + ombre ===== */
.site-header{
  position: sticky; top: 0; z-index: 1000;
  background:#fff; border-bottom:1px solid #e5e7eb;
  box-shadow: 0 6px 20px rgba(17,24,39,.06);
}
.brand{ color:#0f172a; }
.site-nav .menu > li > a{ color:#111827; }
.site-nav .menu > li > a:hover{ color:#1d4ed8; }
/* Dropdown lisible */
.site-nav .menu li .sub-menu{
  background:#fff; color:#111827; border:1px solid #e5e7eb;
  border-radius:10px; box-shadow:0 8px 20px rgba(0,0,0,.06);
}
/* Hero garde le dégradé bleu */
.av-hero{background:linear-gradient(90deg,var(--av-primary),var(--av-accent)); color:#fff; padding:56px 0; margin:0 0 28px}
/* ===== Cartes catégories compactes ===== */
.av-cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}
.av-cat-card{border:1px solid var(--av-border);border-radius:12px;background:#fff;overflow:hidden;text-align:center;display:block;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.av-cat-card img,.av-cat-fallback{width:100%;height:160px;object-fit:cover;display:block}
.av-cat-card .cat-name{padding:12px 10px;font-weight:600;color:#0f172a}
/* ===== Cartes catégories compactes ===== */
.av-cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}
.av-cat-card{border:1px solid var(--av-border);border-radius:12px;background:#fff;overflow:hidden;text-align:center;display:block;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.av-cat-card img,.av-cat-fallback{width:100%;height:160px;object-fit:cover;display:block}
.av-cat-card .cat-name{padding:12px 10px;font-weight:600;color:#0f172a}
/* Patch boutique */
ul.products li.product .button:hover{filter:brightness(0.95)}
@media (max-width: 920px){ ul.products{grid-template-columns:repeat(2,1fr) !important} }
@media (max-width: 560px){ ul.products{grid-template-columns:1fr !important} }
/* Header propre */
.site-header{position:sticky; top:0; background:#fff; z-index:1000; box-shadow:0 8px 24px rgba(2,6,23,.08)}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:24px; min-height:68px}
.site-nav .menu{display:flex; gap:18px; list-style:none; margin:0; padding:0}
.site-nav a{color:#334155; text-decoration:none; font-weight:600}
.site-nav a:hover{color:#1e40af}
.site-nav .menu > li{position:relative}
.site-nav .menu > li > .sub-menu{display:none; position:absolute; left:0; top:100%; background:#fff; border:1px solid #e5e7eb; border-radius:10px; padding:8px; min-width:220px; box-shadow:0 18px 40px rgba(2,6,23,.12)}
.site-nav .menu > li:hover > .sub-menu{display:block}
.site-nav .menu .sub-menu a{display:block; padding:8px 10px; color:#111827; white-space:nowrap}
.av-hero{padding-top:24px} /* espace sous header */
@media (max-width: 980px){
  .site-nav .menu{gap:12px; flex-wrap:wrap}
  .site-nav .menu > li > .sub-menu{position:static; display:none; box-shadow:none; border:none; padding:0}
  .site-nav .menu > li.open > .sub-menu{display:block}
}
/* Cartes produit plus claires */
ul.products li.product{border:1px solid #e5e7eb; border-radius:14px; padding:14px; background:#fff}
ul.products li.product .price{display:block; font-size:20px; font-weight:800; color:#1e40af; margin-top:6px; margin-bottom:10px}
ul.products li.product .button{display:inline-flex; align-items:center; justify-content:center; padding:10px 14px; border-radius:10px; background:#1e40af; color:#fff !important; font-weight:700; border:0; transition:transform .12s ease, box-shadow .12s ease}
ul.products li.product .button:hover{transform:translateY(-1px); box-shadow:0 10px 24px rgba(30,64,175,.2)}
/* responsive */
@media (max-width: 920px){ ul.products{grid-template-columns:repeat(2,1fr) !important} }
@media (max-width: 560px){ ul.products{grid-template-columns:1fr !important} }
.site-footer{background:#0f172a;color:#cbd5e1;margin-top:40px}
.site-footer a{color:#93c5fd;text-decoration:none}
.site-footer a:hover{text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:2fr 2fr 2fr;gap:24px;padding:32px 0}
.footer-grid h4{color:#fff;margin:0 0 12px;font-size:16px}
.footer-grid .menu{list-style:none;margin:0;padding:0;display:grid;gap:7px}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;border-top:1px solid rgba(255,255,255,.08);padding:14px 0;font-size:13px}
@media (max-width:900px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
}
/* --- Logo AssurVente --- */
.brand{
  background:url("../assets/img/logo.png") no-repeat left center / contain;
  min-width:200px; height:56px; display:block;
  text-indent:-9999px; overflow:hidden;
}
/* --- Override logo <img> --- */
.brand{background:none !important; text-indent:0 !important; min-width:auto !important; height:auto !important; padding:0 !important; display:inline-flex; align-items:center}
.brand img{height:56px; width:auto; display:block}
@media (max-width:640px){ .brand img{height:44px} }
/* === AV override: header & logo size === */
.site-header .header-top{min-height:84px; padding:12px 16px}
.brand{background:none; text-indent:0; min-width:auto; height:auto; padding:0; display:inline-flex; align-items:center}
.brand img{height:72px; width:auto; display:block}
@media (max-width: 640px){ .brand img{height:56px} }
/* === AV footer clean === */
.site-footer{background:#0b1220; color:#cbd5e1; margin-top:32px}
.site-footer a{color:#e2e8f0; text-decoration:none}
.site-footer a:hover{text-decoration:underline}
.footer-grid{display:grid; grid-template-columns:2fr 1.5fr 1.5fr 2fr; gap:24px; padding:28px 0}
.footer-grid h4{margin:0 0 10px; color:#fff}
.footer-grid .menu{list-style:none; margin:0; padding:0; display:grid; gap:8px}
.footer-grid .contact{list-style:none; margin:0; padding:0; display:grid; gap:6px}
.copyright{border-top:1px solid #111827; padding:12px 0; color:#94a3b8; font-size:14px}
.container{max-width:1180px; margin:0 auto; padding:0 16px}
@media (max-width: 980px){
  .footer-grid{grid-template-columns:1fr 1fr; gap:16px}
}
@media (max-width: 600px){
  .footer-grid{grid-template-columns:1fr}
}
/* Logo plus grand */
.brand{ min-width: 300px; }
.brand-img{ height: 88px; width: auto; display: block; }
@media (max-width: 992px){ .brand-img{ height: 64px; } }

/* Barre de navigation en une seule ligne, scroll horizontal si trop longue */
.site-nav .menu{ display:flex; flex-wrap:nowrap; overflow-x:auto; gap:18px; white-space:nowrap; scrollbar-width:thin; }
.site-nav .menu > li{ flex:0 0 auto; }

/* Bandeau header lisible (fond + ombre) */
.site-header{ background:#ffffffcc; backdrop-filter:blur(6px); box-shadow:0 2px 12px rgba(0,0,0,.06); }

/* Boutons produits plus clairs */
ul.products li.product .button{ font-weight:600; border-radius:10px; padding:.6rem .9rem; }
ul.products li.product .price{ font-size:1.1rem; font-weight:700; color:#0f172a; }

/* Cacher le bloc "Catégories" en bas si présent dans le front-page */
.home .widget_product_categories{ display:none; }
/* override taille logo */
.brand-img{height:110px; width:auto; display:block}
@media (max-width: 992px){ .brand-img{height:80px} }
/* Menu header sur une seule ligne (scroll horizontal si trop) */
.site-nav .menu{ display:flex; flex-wrap:nowrap; overflow-x:auto; gap:18px; white-space:nowrap; scrollbar-width:thin; }
.site-nav .menu > li{ flex:0 0 auto; }

.home-block{margin:30px 0}
.home-block h2{margin:0 0 12px; font-size:26px; color:#111827}
/* === AV HEADER v2 === */
.header-top{display:grid;grid-template-columns:240px 1fr 170px;gap:16px;align-items:center;padding:12px 18px;background:#ffffff;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.brand-img{height:72px;width:auto;display:block}

.header-search form{display:flex;gap:10px;justify-content:center}
.header-search input[type="search"]{width:100%;max-width:720px;padding:12px 14px;border:1px solid #d1d5db;border-radius:12px}
.header-search button,.header-search input[type="submit"]{padding:12px 16px;border-radius:12px;border:0;background:#2563eb;color:#fff;cursor:pointer}

.header-cart{justify-self:end;display:flex;align-items:center;gap:8px;text-decoration:none;color:#111827}
.header-cart .count{background:#2563eb;color:#fff;min-width:26px;height:26px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;padding:0 7px}

/* Barre catégories : sur 1 ligne (défilement horizontal si trop long) */
.site-nav{border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;background:#fff}
.site-nav .menu{margin:0;padding:8px 16px;list-style:none;display:flex;gap:16px;flex-wrap:nowrap;overflow-x:auto;white-space:nowrap;scrollbar-width:thin}
.site-nav .menu>li{display:inline-block}
.site-nav .menu a{text-decoration:none;color:#374151;padding:8px 6px;display:inline-block;font-weight:700}
.site-nav .menu a:hover{color:#2563eb}

/* Cacher une éventuelle liste de catégories en footer injectée par widget */
.site-footer .widget_product_categories{display:none !important}
/* === Lisibilité HERO + structure header =================================== */
.header-inner{display:grid;grid-template-columns:220px 1fr auto;align-items:center;gap:20px}
.brand-img{height:56px;width:auto;display:block}
.header-search{justify-self:center;max-width:680px;width:100%}
.header-cart{justify-self:end;display:flex;align-items:center;gap:8px;text-decoration:none;color:#111827;font-weight:600}
.header-cart .count{background:#1a56db;color:#fff;border-radius:999px;padding:2px 8px;font-size:12px}

/* Hero */
.hero{padding:18px 0 8px}
.hero h1{color:#1e3a8a;margin:0 0 8px;font-weight:800}
.hero-subtitle{color:#1f2937;font-weight:600;line-height:1.5;max-width:900px}
.hero-cta{display:flex;gap:16px;margin-top:18px;flex-wrap:wrap}
.btn,.btn:link,.btn:visited{background:#1a56db;color:#fff;border:0;padding:12px 20px;border-radius:12px;text-decoration:none;box-shadow:0 8px 24px rgba(26,86,219,.18);font-weight:700}
.btn:hover{filter:brightness(0.95)}
.btn--ghost{background:#f3f4f6;color:#1f2937}

/* Fix : supprimer soulignement global sur liens du hero */
.hero a{ text-decoration:none }
/* Hero lisible (contrasté) */
.hero-subtitle{
  color:#0f172a !important;
  font-weight:700; letter-spacing:.1px;
  text-shadow:0 1px 0 rgba(255,255,255,.25);
}
.hero-cta a{ text-decoration:none !important }
/* AV: vignettes catégories (ratio stable) */
.av-cat-card img{width:100%;height:180px;object-fit:cover;border-bottom:1px solid var(--av-border)}
@media (max-width:640px){ .av-cat-card img{height:150px} }
/* AV: vignettes catégories */
.av-cat-card img{width:100%;height:180px;object-fit:cover;border-bottom:1px solid var(--av-border);display:block}
@media (max-width:640px){ .av-cat-card img{height:150px} }
