/*
Theme Name: Astra Child
Description: Thème enfant Astra personnalisé
Author: Auto-generated
Template: astra
Version: 1.0.0
*/

:root {
  --primary-color: hsl(109, 57%, 45%);
  --link-color: hsl(119, 52%, 40%);
  --bg-color: hsl(0, 0%, 98.5%);
  --text-color: hsl(0, 0%, 10%);
  --title-color: hsl(0, 0%, 12%);
  --base-font-size: 17.1px;
  --base-font-weight: 384;
  --h2-size: 30.8px;
  --h3-size: 25.1px;
  --menu-font-size: 1.02em;
  --line-height: 1.66;
  --btn-radius: 5px;
  --section-spacing: 60px;
  --product-h1-size: 34px;
  --price-size: 24px;
  --breadcrumb-size: 15.5px;
  --header-padding: 14px;
  --footer-padding: 70px;
  --footer-bg-color: hsl(0, 0%, 99.1%);
}

body {
  font-family: Manrope, sans-serif;
  font-size: var(--base-font-size);
  font-weight: var(--base-font-weight);
  line-height: var(--line-height);
  background-color: var(--bg-color);
  color: var(--text-color);
}

h1, h2, h3, h4, h5, h6 {
  color: var(--title-color);
  margin-bottom: 0.8em;
}

h2 { font-size: var(--h2-size); }
h3 { font-size: var(--h3-size); }

/* Classe pour elements non-H2 avec style H2 (SEO) */
.h2-look {
  font-size: var(--h2-size);
  font-weight: 700;
  color: var(--title-color);
  margin-bottom: 0.4em; /* Marge réduite pour rapprocher du prix */
  display: block;
  line-height: 1.2;
}

/* Style pour la catégorie de produit */
.product-category {
    display: block;
    font-size: 0.75em;
    text-transform: uppercase;
    color: var(--text-color); /* Couleur du site */
    opacity: 0.7; /* Discret mais cohérent */
    margin-bottom: 5px;
    letter-spacing: 0.5px;
    font-weight: 600;
}

a {
  color: var(--link-color);
  text-decoration: none;
  transition: color 0.2s, opacity 0.2s;
}

a:hover {
  color: var(--primary-color) !important;
  opacity: 1 !important;
}

/* Breadcrumbs */
.woocommerce-breadcrumb {
  font-size: var(--breadcrumb-size) !important;
  margin-bottom: 20px !important;
  color: #888;
}

.woocommerce-breadcrumb a {
  color: #888;
  text-decoration: none;
}

.woocommerce-breadcrumb a:hover {
  color: var(--primary-color) !important;
}

/* Boutons */
button,
.button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
input[type="submit"] {
  background-color: var(--primary-color) !important;
  color: #fff !important;
  border-radius: var(--btn-radius) !important;
  padding: 14px 28px !important;
  font-weight: 501 !important;
  text-transform: uppercase !important;
  border: none !important;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
  transition: transform 0.2s, filter 0.2s !important;
}

button:hover,
.button:hover,
.woocommerce a.button:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
}

/* Menus (Header & Footer) */
.main-navigation a,
.ast-header-menu a,
.main-header-bar a,
.footer-menu a {
  color: var(--link-color) !important;
  transition: color 0.2s;
  text-decoration: none;
}

.main-navigation a,
.ast-header-menu a,
.main-header-bar a {
  font-size: var(--menu-font-size);
  font-weight: 500;
}

.footer-menu a {
  font-size: calc(var(--menu-font-size) * 0.95);
}

.main-navigation a:hover,
.ast-header-menu a:hover,
.main-header-bar a:hover,
.footer-menu a:hover {
  color: var(--primary-color) !important;
}

/* Footer Menu List Styles */
.footer-menu {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.footer-menu li {
  margin-bottom: 12px !important;
  padding: 0 !important;
}



.site-content,
.wrap {
  max-width: 1083px;
  margin: 0 auto;
  padding: 0 20px;
}

section,
.site-content > article,
.site-content > main > * {
  margin-bottom: var(--section-spacing);
}

/* Centrage spécifique pour la page d'accueil */
.home .content-area,
.home .site-main {
  max-width: calc(1083px + 100px);
  margin: 0 auto;
}

.product,
.woocommerce ul.products li.product {
  box-shadow: 0 16px 25px rgba(0,0,0,0.072);
  border-radius: calc(var(--btn-radius) + 4px);
  overflow: hidden;
  transition: transform 0.3s ease;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-5px);
}

/* Badge On Sale */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.woocommerce div.product span.onsale,
.ast-onsale-card {
  background: var(--primary-color) !important;
  color: #fff !important;
  top: 15px !important;
  left: 15px !important;
  right: auto !important;
  margin: 0 !important;
  border-radius: var(--btn-radius) !important;
  padding: 6px 12px !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  font-size: 0.8em !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  box-shadow: 0 4px 8px rgba(0,0,0,0.15) !important;
  z-index: 10 !important;
  border: none !important;
}

/* Blockquote */
blockquote {
  border-left: 5px solid var(--primary-color);
  background: rgba(0,0,0,0.02);
  padding: 25px 35px;
  margin: 40px 0;
  font-style: italic;
  font-size: 1.15em;
  color: var(--text-color);
  border-radius: 0 var(--btn-radius) var(--btn-radius) 0;
}

.site-header .main-header-bar,
.site-header .main-header-bar-wrap,
.ast-header-break-point .main-header-bar {
  padding-top: var(--header-padding);
  padding-bottom: var(--header-padding);
  border-bottom: none !important;
  box-shadow: none !important;
}

.site-header .custom-logo {
  max-height: 77px !important;
  width: auto !important;
}

.footer-logo img {
  max-height: 70px !important;
  max-width: 250px !important;
  width: auto !important;
  margin-bottom: 20px;
}

.single-product .product_title {
  font-size: var(--product-h1-size) !important;
  line-height: 1.1;
  font-weight: 700;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: var(--price-size) !important;
  color: var(--primary-color);
  font-weight: 700;
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
  font-size: 0.8em;
  opacity: 0.8;
  font-weight: 400;
}

.footer-nutra-layout {
  max-width: 1083px;
  margin: 0 auto;
  padding: var(--footer-padding) 20px 30px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
}

#colophon {
  background-color: var(--footer-bg-color) !important;
}

.footer-links-container {
  display: flex;
  gap: 60px;
}

.footer-heading {
  font-weight: 700;
  margin-bottom: 20px;
  font-size: 1.05em;
  color: #111;
  letter-spacing: 0.5px;
}

@media (max-width: 768px) {
  .footer-nutra-layout {
    flex-direction: column;
    text-align: center;
  }
  .footer-links-container {
    flex-direction: column;
    gap: 30px;
    width: 100%;
  }
}

/* Masquer le footer Astra par défaut */
.site-below-footer-wrap,
.ast-footer-copyright,
#colophon .ast-footer-copyright,
.ast-footer-builder-layout,
.ast-builder-footer-grid,
.footer-bar,
.ast-small-footer {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
}

/* ========================================= */
/* FIXES DEMANDÉS (MENU, TABS, SCROLL TOP) */
/* ========================================= */

/* 1. Menu Burger Mobile : Fond blanc, Lignes couleur random */
.main-header-menu-toggle {
    background-color: #ffffff !important;
    border-radius: 3px; 
}
.ast-header-break-point .main-header-bar .main-header-bar-navigation .page_item_has_children > .ast-menu-toggle, 
.ast-header-break-point .main-header-bar .main-header-bar-navigation .menu-item-has-children > .ast-menu-toggle, 
.ast-mobile-menu-trigger-fill {
    fill: var(--primary-color) !important;
}
.main-header-menu-toggle .ast-icon svg, 
.main-header-menu-toggle .ast-icon svg path {
    fill: var(--primary-color) !important;
    stroke: var(--primary-color) !important;
}

/* 2. Onglet Description/Avis : Barre active couleur random */
.woocommerce div.product .woocommerce-tabs ul.tabs li.active:before {
    background-color: var(--primary-color) !important;
}

/* 3. Bouton Scroll To Top : Fond couleur random */
#ast-scroll-top {
    background-color: var(--primary-color) !important;
    color: #ffffff !important;
}
#ast-scroll-top:hover {
    background-color: var(--link-color) !important;
    color: #ffffff !important;
}
