/*
 * Theme Name:  Corbo Boutique
 * Theme URI:   https://boutique.corbocourse.fr
 * Description: Thème enfant WooCommerce — épuré, fond clair, goodies Corbo
 * Author:      Coopérative Corbo
 * Template:    storefront
 * Version:     2.0.0
 * Text Domain: corbo-boutique
 */

/* ═══════════════════════════════════════
   FONTS
═══════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Racing+Sans+One&family=Karla:ital,wght@0,400;0,500;0,600;1,400&display=swap');

/* ═══════════════════════════════════════
   VARIABLES — MODE CLAIR
═══════════════════════════════════════ */
:root {
  --rouge:       #d84116;
  --rouge-dk:    #bf3712;
  --rouge-lt:    #f4c4b3;
  --brun:        #3c1c14;
  --brun-mid:    #5a3525;
  --brun-lt:     #9e7e6e;
  --bg:          #faf7f2;
  --bg-card:     #ffffff;
  --bg-alt:      #f2ede5;
  --border:      #e0d5c5;
  --txt:         #3c1c14;
  --txt-mid:     #6b4535;
  --txt-lt:      #9e7e6e;
  --title-font:  'Racing Sans One', sans-serif;
  --body-font:   'Karla', sans-serif;
}

/* ═══════════════════════════════════════
   VARIABLES — MODE SOMBRE
═══════════════════════════════════════ */
@media (prefers-color-scheme: dark) {
  :root {
    --bg:       #100804;
    --bg-card:  #1e0d08;
    --bg-alt:   #180a05;
    --border:   #3a1a0e;
    --txt:      #eee4d2;
    --txt-mid:  #c8a98a;
    --txt-lt:   #8a6050;
  }
}

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

body {
  font-family: var(--body-font);
  background: var(--bg);
  color: var(--txt);
  font-size: 1rem;
  line-height: 1.65;
  margin: 0;
}

h1, h2, h3, h4, h5 {
  font-family: var(--title-font);
  font-weight: 400;
  color: var(--txt);
  line-height: 1.1;
}

a { color: var(--rouge); text-decoration: none; }
a:hover { color: var(--rouge-dk); }

img { max-width: 100%; height: auto; display: block; }

/* ═══════════════════════════════════════
   STOREFRONT OVERRIDES — cacher l'inutile
═══════════════════════════════════════ */
/* ── Cacher les éléments Storefront indésirables ── */
.main-navigation,
.storefront-sorting,
.woocommerce-breadcrumb,
.storefront-product-section,
.site-header .col-full > .site-branding,
.widget_shopping_cart_content .buttons .button.wc-forward,
.related.products h2,
.upsells.products h2,
.woocommerce-products-header,
.woocommerce-products-header__title,
.page-title,
.entry-header,
h1.entry-title,
.site-search,
.site-header-cart,
.widget_product_search,
.storefront-handheld-footer-bar { display: none !important; }

.site-header { padding: 0 !important; background: transparent !important; box-shadow: none !important; border: none !important; }
.site-content .col-full { padding: 0 !important; }
.woocommerce-page .site-main { margin: 0 !important; }
.widget-area,
.sidebar-widget-area { display: none !important; }

/* ═══════════════════════════════════════
   HEADER CORBO
═══════════════════════════════════════ */
.corbo-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--bg);
  border-bottom: 2px solid var(--border);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: .9rem 2.5rem;
  gap: 1rem;
}

.corbo-header-back {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: var(--title-font);
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--txt-lt);
  text-decoration: none;
  transition: color .2s;
}
.corbo-header-back:hover { color: var(--rouge); }
.corbo-header-back svg { width: 14px; height: 14px; fill: currentColor; }

.corbo-header-logo {
  display: flex;
  justify-content: center;
}
.corbo-header-logo img {
  height: 36px;
  width: auto;
}

.corbo-header-cart {
  display: flex;
  justify-content: flex-end;
}
/* Panier WooCommerce dans le header */
.corbo-header-cart .cart-contents {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--title-font);
  font-size: .72rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--txt);
  text-decoration: none;
  border: 1px solid var(--border);
  padding: .38rem .9rem;
  transition: border-color .2s, color .2s;
}
.corbo-header-cart .cart-contents:hover { border-color: var(--rouge); color: var(--rouge); }
.corbo-header-cart .cart-contents .count {
  background: var(--rouge);
  color: #fff;
  font-size: .6rem;
  padding: .1rem .35rem;
  line-height: 1.4;
  min-width: 18px;
  text-align: center;
}
.corbo-header-cart .cart-contents svg,
.corbo-header-cart .cart-contents .amount { display: none; }

/* Icône panier SVG */
.corbo-cart-icon { width: 16px; height: 16px; fill: currentColor; }

@media (max-width: 600px) {
  .corbo-header { padding: .75rem 1.2rem; }
  .corbo-header-back span { display: none; }
  .corbo-header-logo img { height: 28px; }
}

/* ═══════════════════════════════════════
   INTRO BOUTIQUE
═══════════════════════════════════════ */
.corbo-shop-intro {
  text-align: center;
  padding: 2.5rem 2rem 1.5rem;
  max-width: 520px;
  margin: 0 auto;
}
.corbo-shop-intro h1 {
  font-family: var(--title-font);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 400;
  color: var(--txt);
  margin-bottom: .4rem;
}
.corbo-shop-intro p {
  font-size: .92rem;
  color: var(--txt-mid);
  line-height: 1.7;
  margin: 0;
}

/* ═══════════════════════════════════════
   GRILLE PRODUITS
═══════════════════════════════════════ */
.woocommerce-page .site-main,
.woocommerce-page .entry-content,
.woocommerce .entry-content { display: block !important; }

/* Reset colonnes Storefront */
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none !important; }

.woocommerce ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.5rem !important;
  list-style: none !important;
  margin: 2rem 2rem 4rem !important;
  padding: 0 !important;
  max-width: 1140px !important;
  float: none !important;
  clear: both !important;
}

/* Annuler les styles float de Storefront sur chaque produit */
li.product,
.woocommerce ul.products li.product {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  clear: none !important;
  background: var(--bg-card) !important;
  border: 1px solid var(--border) !important;
  display: flex !important;
  flex-direction: column !important;
  transition: border-color .25s, box-shadow .25s !important;
}
li.product:hover {
  border-color: var(--rouge) !important;
  box-shadow: 0 4px 20px rgba(216,65,22,.08) !important;
}

/* Image carré */
.woocommerce ul.products li.product img,
li.product img {
  width: 100% !important;
  height: 240px !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--border) !important;
  transition: opacity .25s !important;
}
li.product:hover img { opacity: .9 !important; }

.woocommerce-loop-product__title {
  font-family: var(--title-font) !important;
  font-size: .95rem !important;
  font-weight: 400 !important;
  color: var(--txt) !important;
  margin: .8rem 1rem .3rem !important;
  padding: 0 !important;
  line-height: 1.2 !important;
}

.woocommerce ul.products li.product .price {
  font-family: var(--title-font) !important;
  font-size: .9rem !important;
  color: var(--rouge) !important;
  display: block !important;
  margin: 0 1rem .8rem !important;
  padding: 0 !important;
}

.woocommerce ul.products li.product .button {
  display: block !important;
  width: calc(100% - 2rem) !important;
  margin: auto 1rem 1rem !important;
  background: var(--txt) !important;
  color: var(--bg) !important;
  font-family: var(--title-font) !important;
  font-size: .68rem !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  border: none !important;
  border-radius: 0 !important;
  padding: .65rem 1rem !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: background .2s !important;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--rouge) !important;
  color: #fff !important;
}

.onsale {
  background: var(--rouge) !important;
  color: #fff !important;
  font-family: var(--title-font) !important;
  font-size: .62rem !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  padding: .2rem .6rem !important;
  top: .7rem !important;
  left: .7rem !important;
  min-height: auto !important;
  line-height: 1.6 !important;
}

@media (max-width: 900px) {
  .woocommerce ul.products, ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    margin: 1.5rem 1.2rem 3rem !important;
  }
}
@media (max-width: 520px) {
  .woocommerce ul.products, ul.products {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
  li.product img { height: 220px !important; }
}

/* ═══════════════════════════════════════
   PAGE PRODUIT
═══════════════════════════════════════ */

/* Cacher boutons paiement express (Apple Pay, Google Pay, Link, PayPal) */
.wc-block-components-express-payment,
.wc-block-components-express-payment-continue-rule,
[class*="express-payment"],
[class*="payment-request"],
.payment_request_button,
.woocommerce div.product .woocommerce-product-payment-request { display: none !important; }

.woocommerce div.product {
  max-width: 960px;
  margin: 3rem auto;
  padding: 0 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items: start;
}

/* Images */
.woocommerce div.product div.images {
  position: sticky;
  top: 80px;
}
.woocommerce div.product div.images img {
  width: 100% !important;
  height: auto !important;
  border: 1px solid var(--border);
  object-fit: contain !important;
}
.woocommerce div.product div.images .flex-control-thumbs {
  display: flex;
  gap: .5rem;
  margin-top: .5rem;
}
.woocommerce div.product div.images .flex-control-thumbs li {
  flex: 0 0 60px;
}
.woocommerce div.product div.images .flex-control-thumbs img {
  border: 1px solid var(--border);
  opacity: .6;
  cursor: pointer;
  height: 60px;
  object-fit: cover;
  transition: opacity .2s, border-color .2s;
}
.woocommerce div.product div.images .flex-control-thumbs img:hover,
.woocommerce div.product div.images .flex-control-thumbs .flex-active {
  opacity: 1;
  border-color: var(--rouge);
}

/* Infos */
.woocommerce div.product div.summary {
  padding-top: .5rem;
}
.woocommerce div.product .product_title {
  font-family: var(--title-font) !important;
  font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
  font-weight: 400 !important;
  color: var(--txt) !important;
  margin-bottom: .6rem !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--title-font) !important;
  font-size: 1.3rem !important;
  color: var(--rouge) !important;
  display: block;
  margin-bottom: 1.2rem;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: .92rem;
  line-height: 1.75;
  color: var(--txt-mid);
  margin-bottom: 1.5rem;
  border-top: 1px solid var(--border);
  padding-top: 1.2rem;
}

/* Bouton principal */
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
  background: var(--rouge) !important;
  color: #fff !important;
  font-family: var(--title-font) !important;
  font-size: .75rem !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  border: none !important;
  padding: .9rem 2rem !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background .2s !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  background: var(--rouge-dk) !important;
}

/* Quantité */
.woocommerce div.product form.cart {
  display: flex;
  gap: .8rem;
  align-items: center;
  flex-wrap: wrap;
}
.woocommerce div.product form.cart .qty {
  width: 64px !important;
  border: 1px solid var(--border) !important;
  background: var(--bg) !important;
  color: var(--txt) !important;
  font-family: var(--body-font) !important;
  font-size: 1rem !important;
  padding: .7rem !important;
  border-radius: 0 !important;
  text-align: center;
}
.woocommerce div.product form.cart .single_add_to_cart_button {
  flex: 1;
}

/* Méta (catégorie, SKU) */
.product_meta {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
  font-size: .8rem;
  color: var(--txt-lt);
}
.product_meta a { color: var(--txt-lt); }
.product_meta a:hover { color: var(--rouge); }

/* Description complète */
.woocommerce-tabs {
  grid-column: 1 / -1;
  margin-top: 2rem;
  border-top: 1px solid var(--border);
  padding-top: 2rem;
}
.woocommerce-tabs ul.tabs { display: none; }
.woocommerce-tabs .panel {
  font-size: .92rem;
  line-height: 1.8;
  color: var(--txt-mid);
  max-width: 640px;
}
.woocommerce-tabs .panel h2 {
  font-family: var(--title-font);
  font-size: 1.1rem;
  font-weight: 400;
  margin-bottom: .8rem;
}

/* Produits liés */
.related.products,
.upsells.products {
  grid-column: 1 / -1;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
  margin-top: 1rem;
}
.related.products > h2,
.upsells.products > h2 {
  display: block !important;
  font-family: var(--title-font);
  font-size: 1.2rem;
  font-weight: 400;
  margin-bottom: 1.5rem;
  color: var(--txt);
}

@media (max-width: 720px) {
  .woocommerce div.product {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 0 1.2rem;
    margin: 1.5rem auto;
  }
  .woocommerce div.product div.images { position: static; }
}

/* ═══════════════════════════════════════
   PANIER & CHECKOUT
═══════════════════════════════════════ */
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content {
  max-width: 860px;
  margin: 2.5rem auto;
  padding: 0 2rem;
}

.woocommerce table.cart,
.woocommerce .shop_table {
  border: 1px solid var(--border) !important;
  border-collapse: collapse !important;
}
.woocommerce table.cart th,
.woocommerce table.cart td,
.woocommerce .shop_table th,
.woocommerce .shop_table td {
  border-bottom: 1px solid var(--border) !important;
  padding: .8rem 1rem !important;
  color: var(--txt) !important;
  font-family: var(--body-font) !important;
}
.woocommerce table.cart th {
  font-family: var(--title-font) !important;
  font-weight: 400 !important;
  font-size: .75rem !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  background: var(--bg-alt) !important;
}

/* Formulaires checkout */
.woocommerce form .form-row label {
  font-size: .8rem;
  color: var(--txt-mid);
  margin-bottom: .25rem;
  display: block;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1px solid var(--border) !important;
  border-radius: 0 !important;
  background: var(--bg) !important;
  color: var(--txt) !important;
  font-family: var(--body-font) !important;
  font-size: .92rem !important;
  padding: .7rem !important;
  width: 100% !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--rouge) !important;
  outline: none !important;
  box-shadow: none !important;
}

.woocommerce #payment {
  background: var(--bg-alt) !important;
  border-radius: 0 !important;
}
.woocommerce #payment div.payment_box {
  background: var(--bg) !important;
}

/* Boutons panier/checkout */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--txt) !important;
  color: var(--bg) !important;
  font-family: var(--title-font) !important;
  font-size: .72rem !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  border: none !important;
  padding: .75rem 1.5rem !important;
  cursor: pointer !important;
  transition: background .2s !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--rouge) !important;
  color: #fff !important;
}

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: 0 !important;
  border-top: 3px solid var(--rouge) !important;
  background: var(--bg-alt) !important;
  color: var(--txt) !important;
}
.woocommerce-message::before,
.woocommerce-info::before { color: var(--rouge) !important; }

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
.site-footer {
  background: var(--bg-alt) !important;
  border-top: 1px solid var(--border) !important;
  padding: 0 !important;
}
/* Cacher le footer Storefront par défaut */
.site-footer .col-full { display: none !important; }

.corbo-footer {
  max-width: 1140px;
  margin: 0 auto;
  padding: 1.8rem 2.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.corbo-footer-logo img {
  height: 24px;
  width: auto;
}

.corbo-footer-legal {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.corbo-footer-legal a {
  font-size: .76rem;
  color: var(--txt-lt);
  text-decoration: none;
  transition: color .2s;
}
.corbo-footer-legal a:hover { color: var(--rouge); }
.corbo-footer-legal span {
  color: var(--border);
  font-size: .7rem;
}
.corbo-footer-copy {
  font-size: .72rem;
  color: var(--txt-lt);
}

.corbo-footer-social {
  display: flex;
  gap: .5rem;
}
.corbo-footer-social a {
  width: 30px;
  height: 30px;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--txt-lt);
  text-decoration: none;
  transition: border-color .2s, color .2s;
}
.corbo-footer-social a:hover { border-color: var(--rouge); color: var(--rouge); }
.corbo-footer-social svg { width: 14px; height: 14px; fill: currentColor; }

@media (max-width: 600px) {
  .corbo-footer {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.5rem 1.2rem;
    gap: 1rem;
  }
}
