/*
 Theme Name:   The Mix Child
 Theme URI:    https://themix.fr
 Description:  Thème enfant Astra pour The Mix — Le média des ingés son
 Author:       The Mix
 Author URI:   https://themix.fr
 Template:     astra
 Version:      1.0.0
 Text Domain:  themix-child
*/

/* =====================================================
   THE MIX — Variables CSS Globales
   ===================================================== */
:root {
  --themix-black:        #0D0D0D;
  --themix-black2:       #111111;
  --themix-black3:       #1A1A1A;
  --themix-violet:       #6B35D4;
  --themix-violet-bright:#7B3FE4;
  --themix-violet-deep:  #3B0F8C;
  --themix-green:        #C8F135;
  --themix-white:        #FFFFFF;
  --themix-white-soft:   #E8E8E8;
}

/* =====================================================
   RESET & BASE
   ===================================================== */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
  background-color: var(--themix-black) !important;
  color: var(--themix-white) !important;
  font-family: 'Barlow', -apple-system, sans-serif !important;
}

/* =====================================================
   TYPOGRAPHIES
   ===================================================== */
h1, h2, h3, h4, h5, h6,
.entry-title,
.ast-blog-post-title {
  font-family: 'Barlow Condensed', 'Montserrat', sans-serif !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.5px !important;
  color: var(--themix-white) !important;
  line-height: 0.95 !important;
}

p, li, span, td, th {
  font-family: 'Barlow', -apple-system, sans-serif !important;
}

/* =====================================================
   HEADER / NAVIGATION
   ===================================================== */
#masthead,
.site-header,
.ast-header-break-point .ast-mobile-header-wrap {
  background-color: rgba(13, 13, 13, 0.92) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid rgba(107, 53, 212, 0.25) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
}

/* Logo */
.ast-site-identity .site-title a,
.site-title a {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  font-size: 32px !important;
  color: var(--themix-white) !important;
  text-transform: uppercase !important;
  letter-spacing: -1px !important;
  text-decoration: none !important;
}

/* Nav links */
.ast-builder-menu .menu-link,
.main-header-menu .menu-link,
.main-navigation a {
  font-family: 'Barlow', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  color: var(--themix-white-soft) !important;
  transition: color 0.2s ease !important;
}

.ast-builder-menu .menu-link:hover,
.main-header-menu .menu-link:hover {
  color: var(--themix-violet-bright) !important;
}

/* Nav CTA button */
.ast-custom-button,
.header-main-layout-1 .ast-masthead-custom-menu-items .button {
  background: var(--themix-violet-bright) !important;
  color: var(--themix-white) !important;
  border-radius: 100px !important;
  padding: 10px 22px !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

/* =====================================================
   BOUTONS GLOBAUX
   ===================================================== */
.ast-button,
button,
input[type="submit"],
input[type="button"],
.button,
.wp-block-button__link {
  background: var(--themix-violet-bright) !important;
  color: var(--themix-white) !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  padding: 14px 32px !important;
  cursor: pointer !important;
  transition: background 0.2s ease, transform 0.2s ease !important;
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.wp-block-button__link:hover {
  background: var(--themix-violet) !important;
  transform: translateY(-2px) !important;
}

/* =====================================================
   WOOCOMMERCE — BOUTIQUE
   ===================================================== */

/* Background boutique */
.woocommerce-page,
.woocommerce {
  background-color: var(--themix-black) !important;
  color: var(--themix-white) !important;
}

/* Cards produits */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--themix-black3) !important;
  border: 1px solid rgba(107, 53, 212, 0.15) !important;
  border-radius: 16px !important;
  padding: 20px !important;
  transition: transform 0.3s ease, border-color 0.3s ease !important;
  overflow: hidden !important;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(107, 53, 212, 0.5) !important;
}

/* Nom du produit */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  font-size: 22px !important;
  text-transform: uppercase !important;
  color: var(--themix-white) !important;
}

/* Prix */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce-Price-amount {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 28px !important;
  font-weight: 900 !important;
  color: var(--themix-violet-bright) !important;
}

/* Bouton Ajouter au panier */
.woocommerce ul.products li.product .button,
.woocommerce a.button.add_to_cart_button,
.woocommerce button.single_add_to_cart_button {
  background: var(--themix-violet-bright) !important;
  color: var(--themix-white) !important;
  border-radius: 100px !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  border: none !important;
  width: 100% !important;
  text-align: center !important;
  padding: 12px 20px !important;
  margin-top: 12px !important;
  transition: background 0.2s !important;
}

.woocommerce ul.products li.product .button:hover {
  background: var(--themix-violet) !important;
}

/* Badge "En vente" */
.woocommerce span.onsale {
  background: var(--themix-green) !important;
  color: var(--themix-black) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  border-radius: 100px !important;
  font-size: 14px !important;
}

/* Page produit unique */
.woocommerce div.product .product_title {
  font-size: clamp(36px, 5vw, 64px) !important;
  line-height: 0.9 !important;
  margin-bottom: 16px !important;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--themix-white-soft) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
}

/* Panier */
.woocommerce-cart .cart_totals,
.woocommerce-checkout #order_review {
  background: var(--themix-black3) !important;
  border: 1px solid rgba(107, 53, 212, 0.2) !important;
  border-radius: 16px !important;
  padding: 24px !important;
}

/* Formulaire checkout */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  border-radius: 8px !important;
  color: var(--themix-white) !important;
  padding: 12px 16px !important;
  transition: border-color 0.2s !important;
}

.woocommerce form .form-row input.input-text:focus {
  border-color: var(--themix-violet-bright) !important;
  outline: none !important;
}

/* =====================================================
   ARTICLES / BLOG
   ===================================================== */
.site-content,
#primary,
.content-area {
  background-color: var(--themix-black) !important;
}

/* Card article dans la liste */
article.post {
  background: var(--themix-black3) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: 12px !important;
  padding: 24px !important;
  margin-bottom: 24px !important;
  transition: border-color 0.3s !important;
}

article.post:hover {
  border-color: rgba(107, 53, 212, 0.4) !important;
}

article.post .entry-title a {
  color: var(--themix-white) !important;
  text-decoration: none !important;
}

/* Catégorie badge */
.ast-post-categories a,
.cat-links a {
  background: var(--themix-violet-bright) !important;
  color: var(--themix-white) !important;
  border-radius: 100px !important;
  padding: 3px 12px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  text-decoration: none !important;
}

/* =====================================================
   FORMULAIRES NEWSLETTER
   ===================================================== */
input[type="email"],
input[type="text"],
textarea {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  border-radius: 100px !important;
  color: var(--themix-white) !important;
  padding: 14px 24px !important;
  font-family: 'Barlow', sans-serif !important;
  font-size: 15px !important;
  transition: border-color 0.2s !important;
}

input[type="email"]:focus,
input[type="text"]:focus {
  border-color: var(--themix-violet-bright) !important;
  outline: none !important;
}

input[type="email"]::placeholder {
  color: rgba(255, 255, 255, 0.3) !important;
}

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer,
#colophon {
  background: var(--themix-black3) !important;
  border-top: 1px solid rgba(107, 53, 212, 0.2) !important;
  color: rgba(255, 255, 255, 0.4) !important;
  padding: 60px 0 30px !important;
}

.site-footer a {
  color: rgba(255, 255, 255, 0.4) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}

.site-footer a:hover {
  color: var(--themix-violet-bright) !important;
}

/* =====================================================
   SIDEBAR & WIDGETS
   ===================================================== */
.widget-area .widget {
  background: var(--themix-black3) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: 12px !important;
  padding: 24px !important;
  margin-bottom: 20px !important;
}

.widget-area .widget-title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  color: var(--themix-white) !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid var(--themix-violet) !important;
  margin-bottom: 16px !important;
}

/* =====================================================
   LIENS GLOBAUX
   ===================================================== */
a {
  color: var(--themix-violet-bright) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}

a:hover {
  color: var(--themix-white) !important;
}

/* =====================================================
   SEPARATEURS & UTILITAIRES
   ===================================================== */
hr {
  border: none !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(107, 53, 212, 0.4), transparent) !important;
  margin: 40px 0 !important;
}

/* Pill violette — classe utilitaire */
.themix-pill {
  display: inline-block;
  background: var(--themix-violet-bright);
  border-radius: 12px;
  padding: 4px 18px 6px;
  color: var(--themix-white);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Bullet ✦ vert — classe utilitaire */
.themix-bullet {
  color: var(--themix-green);
  margin-right: 6px;
}

/* Badge "LIVE" animé */
.themix-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 50, 50, 0.15);
  border: 1px solid rgba(255, 50, 50, 0.3);
  border-radius: 100px;
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #ff6b6b;
}

.themix-live-badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ff4444;
  animation: pulse-red 1.5s infinite;
}

@keyframes pulse-red {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
