/*
Theme Name: COMPUSTORE Theme
Description: Thème custom COMPUSTORE v2
Version: 2.0
*/

/* ══ RESET & GLOBALS ══════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;}
img{max-width:100%;height:auto;}
a{color:inherit;}

/* ══ ACCESSIBILITÉ ════════════════════════════════════════════════════════════ */
.screen-reader-text{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.cs-skip-link{
  position:absolute;top:-100px;left:16px;z-index:99999;
  background:var(--bl);color:#fff;
  padding:10px 20px;border-radius:0 0 8px 8px;
  font-weight:700;font-size:14px;text-decoration:none;
  transition:top .2s;
}
.cs-skip-link:focus{top:0;}
:focus-visible{
  outline:3px solid var(--or);
  outline-offset:3px;
  border-radius:4px;
}

/* ══ CSS VARIABLES ════════════════════════════════════════════════════════════ */
:root{
  --bl:#1a3080;--bl2:#142560;--bl3:#1e3a8a;--bl4:#e8edf8;
  --or:#f7941d;--or2:#e07d0a;--or3:#fff3e0;
  --tx:#1a1a2e;--tx2:#555;--bg:#f8f9fa;--wh:#fff;
  --rd:8px;--shadow:0 4px 20px rgba(26,48,128,.12);
  --container:1400px;--gap:24px;
}

/* ══ FOOTER GRID ══════════════════════════════════════════════════════════════ */
.cs-footer-cols{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.cs-footer-services{
  display:flex;flex-wrap:wrap;gap:8px;
  padding:20px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.cs-footer-copy{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 0;flex-wrap:wrap;gap:12px;
}

/* ══ SHOP LAYOUT (sidebar + grid) ════════════════════════════════════════════ */
.cs-shop-layout{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:32px;
  align-items:start;
}
.cs-sidebar{position:sticky;top:20px;}
.cs-sidebar-toggle{
  display:none;width:100%;padding:11px 16px;
  background:#fff;border:1px solid var(--bl4);border-radius:10px;
  color:var(--bl);font-weight:700;font-size:13px;cursor:pointer;
  text-align:left;font-family:inherit;
  justify-content:space-between;align-items:center;
}
.cs-sidebar-body{display:block;}

/* ══ PRODUCT GRIDS ════════════════════════════════════════════════════════════ */
.cs-product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:16px;
}
.cs-cat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:20px;
}

/* ══ PRODUCT DETAIL LAYOUT ═══════════════════════════════════════════════════ */
.cs-product-main{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
  margin-bottom:48px;
}
.cs-related-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

/* ══ PAGE HERO BREADCRUMB ════════════════════════════════════════════════════ */
.cs-hero-flex{display:flex;align-items:center;gap:20px;}
.cs-page-content{max-width:900px;margin:0 auto;padding:0 var(--gap);}
.cs-elementor-page{width:100%;}

/* ══ WC OVERRIDES ════════════════════════════════════════════════════════════ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit{
  background:var(--or);color:#fff;border-radius:var(--rd);
  font-weight:700;padding:12px 20px;border:none;
  cursor:pointer;font-family:inherit;transition:background .2s;
  font-size:14px;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover{background:var(--or2);}
.woocommerce .quantity input{
  border-radius:var(--rd);border:1px solid #e8edf8;
  padding:10px 12px;font-size:15px;width:70px;
}
.woocommerce form.cart{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.woocommerce table.shop_table{border-radius:12px;overflow:hidden;border:1px solid #e8edf8;width:100%;}
.woocommerce table.shop_table th{background:var(--bl);color:#fff;font-family:'Space Grotesk',sans-serif;}

/* ══ PAGINATION ═══════════════════════════════════════════════════════════════ */
.cs-pagination{margin-top:40px;display:flex;justify-content:center;gap:6px;flex-wrap:wrap;}
.cs-pagination .page-numbers{
  padding:8px 14px;border-radius:8px;border:1px solid #e8edf8;
  background:#fff;color:var(--bl);text-decoration:none;
  font-size:13px;font-weight:600;transition:all .2s;
}
.cs-pagination .page-numbers.current{background:var(--bl);color:#fff;border-color:var(--bl);}
.cs-pagination .page-numbers:hover{background:var(--or);color:#fff;border-color:var(--or);}

/* ══ CONTENT STYLES ══════════════════════════════════════════════════════════ */
.cs-content h2{font-family:'Space Grotesk',sans-serif;font-size:22px;color:var(--bl);border-bottom:2px solid var(--or);padding-bottom:8px;margin-top:1.5em;}
.cs-content h3{font-family:'Space Grotesk',sans-serif;font-size:18px;color:var(--bl);}
.cs-content a{color:var(--or);}
.cs-content ul{padding-left:20px;}
.cs-content li{margin-bottom:6px;}
.cs-content table{width:100%;border-collapse:collapse;margin:1em 0;}
.cs-content th,.cs-content td{padding:10px 14px;border:1px solid #e8edf8;text-align:left;}
.cs-content th{background:var(--bl4);color:var(--bl);font-weight:600;}
.cs-content img{border-radius:8px;}
.cs-content blockquote{border-left:4px solid var(--or);padding:12px 20px;margin:1.5em 0;background:var(--or3);border-radius:0 8px 8px 0;}

/* ══ TABLET — 1024px ══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .cs-footer-cols{grid-template-columns:1fr 1fr;gap:32px;}
  .cs-product-main{gap:32px;}
  .cs-related-grid{grid-template-columns:repeat(3,1fr);}
  .cs-cat-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));}
}

/* ══ TABLET PORTRAIT — 768px ═════════════════════════════════════════════════ */
@media(max-width:768px){
  :root{--gap:16px;}

  /* Shop layout: hide sidebar, full width grid */
  .cs-shop-layout{grid-template-columns:1fr;}
  .cs-sidebar{position:static;}
  .cs-sidebar-toggle{display:flex;}
  .cs-sidebar-body{display:none;}
  .cs-sidebar-body.open{display:block;}

  /* Product grids */
  .cs-product-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;}
  .cs-cat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;}

  /* Product detail: stack */
  .cs-product-main{grid-template-columns:1fr;gap:24px;}
  .cs-related-grid{grid-template-columns:repeat(2,1fr);}

  /* Footer */
  .cs-footer-cols{grid-template-columns:1fr 1fr;gap:24px;}
  .cs-footer-copy{flex-direction:column;align-items:flex-start;gap:8px;}

  /* Page content */
  .cs-page-content{padding:0 var(--gap);}
  .cs-hero-flex{flex-wrap:wrap;}
}

/* ══ MOBILE — 480px ══════════════════════════════════════════════════════════ */
@media(max-width:480px){
  /* Footer: single column */
  .cs-footer-cols{grid-template-columns:1fr;gap:28px;}
  .cs-footer-services{gap:6px;}

  /* Product grids: 2 tight columns */
  .cs-product-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .cs-cat-grid{grid-template-columns:repeat(2,1fr);gap:10px;}

  /* Related: 2 cols */
  .cs-related-grid{grid-template-columns:repeat(2,1fr);gap:10px;}

  /* WC buttons full width on mobile */
  .woocommerce form.cart{flex-direction:column;gap:10px;}
  .woocommerce form.cart .button{width:100%;text-align:center;}
  .woocommerce form.cart .quantity{width:100%;}
  .woocommerce form.cart .quantity input{width:100%;}
}

/* ══ SMALL MOBILE — 360px ═════════════════════════════════════════════════════ */
@media(max-width:360px){
  .cs-product-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .cs-cat-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
}

/* ══ GLOBAL OVERFLOW / BASE ══════════════════════════════════════════════════ */
html,body{overflow-x:hidden;}
img,video,iframe,embed,object{max-width:100%;height:auto;}

/* ══ ELEMENTOR RESPONSIVE GRIDS (override inline styles with !important) ═════ */
/* Used by the Elementor HTML widgets on the homepage */
.cs-rg{display:grid!important;}

/* 4-column → 3 → 2 → 2 */
.cs-rg-4{grid-template-columns:repeat(4,1fr)!important;}
@media(max-width:1100px){.cs-rg-4{grid-template-columns:repeat(3,1fr)!important;}}
@media(max-width:700px) {.cs-rg-4{grid-template-columns:repeat(2,1fr)!important;}}

/* 5-column → 4 → 3 → 2 */
.cs-rg-5{grid-template-columns:repeat(5,1fr)!important;}
@media(max-width:1100px){.cs-rg-5{grid-template-columns:repeat(4,1fr)!important;}}
@media(max-width:768px) {.cs-rg-5{grid-template-columns:repeat(3,1fr)!important;}}
@media(max-width:480px) {.cs-rg-5{grid-template-columns:repeat(2,1fr)!important;}}

/* 2-column (hero, dépannage) → 1 on mobile */
.cs-rg-2{grid-template-columns:1fr 1fr!important;}
@media(max-width:768px){.cs-rg-2{grid-template-columns:1fr!important;}}

/* Flex promo band — already flex-wrap:wrap, ensure gap shrinks */
@media(max-width:600px){
  .cs-promo-band-inner{gap:14px!important;}
  .cs-promo-band-item{min-width:140px;}
}

/* ══ SINGLE PRODUCT — GUARANTEES GRID ═══════════════════════════════════════ */
.cs-guarantees{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(max-width:400px){.cs-guarantees{grid-template-columns:1fr;}}

/* ══ ELEMENTOR CONTAINERS — prevent overflow ═════════════════════════════════ */
.elementor-section,.elementor-container,.elementor-row,.elementor-widget-wrap{max-width:100%;word-break:break-word;}
.elementor-column{min-width:0;}

/* ══ FOOTER EXTRA RESPONSIVE ═════════════════════════════════════════════════ */
@media(max-width:600px){
  .cs-footer-services a{font-size:11px;padding:3px 8px;}
}

/* ══ WC CART ══════════════════════════════════════════════════════════════════ */
.woocommerce-cart .woocommerce{max-width:100%;margin:0;padding:0;}
.woocommerce-cart h1,.woocommerce-cart h2{font-family:'Space Grotesk',sans-serif;color:var(--bl);margin-bottom:24px;}

/* ══ WC CHECKOUT — LAYOUT 2 COLONNES ════════════════════════════════════════ */
.woocommerce-checkout .woocommerce{max-width:100%;margin:0;padding:0;}

form.woocommerce-checkout{
  display:grid;
  grid-template-columns:1fr 380px;
  grid-template-rows:auto 1fr;
  gap:0 40px;
  align-items:start;
}
form.woocommerce-checkout #customer_details{
  grid-column:1;grid-row:1/3;
}
form.woocommerce-checkout #order_review_heading{
  grid-column:2;grid-row:1;
  font-family:'Space Grotesk',sans-serif;
  font-size:18px;color:var(--bl);
  margin:0 0 16px;padding-bottom:12px;
  border-bottom:2px solid var(--bl4);
}
form.woocommerce-checkout #order_review{
  grid-column:2;grid-row:2;
  position:sticky;top:20px;
}

/* col2-set intérieur (billing + shipping) */
.woocommerce .col2-set{display:block;}
.woocommerce .col2-set .col-1,.woocommerce .col2-set .col-2{float:none;width:100%;}

/* ══ SECTION TITRES FORMULAIRE ═══════════════════════════════════════════════ */
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3{
  font-family:'Space Grotesk',sans-serif;
  font-size:18px;color:var(--bl);
  margin:0 0 20px;padding-bottom:12px;
  border-bottom:2px solid var(--bl4);
}

/* ══ CHAMPS FORMULAIRE ═══════════════════════════════════════════════════════ */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 20px;
}

/* Champs pleine largeur */
.form-row-wide,
.form-row.notes,
p.form-row-wide{
  grid-column:1/-1;
}

/* Champs demi-largeur */
.form-row-first{grid-column:1;}
.form-row-last{grid-column:2;}

/* Wrapper champ */
.woocommerce-checkout .form-row{
  margin:0 0 16px;
  display:flex;
  flex-direction:column;
  gap:5px;
}

/* Label */
.woocommerce-checkout .form-row label{
  font-size:13px;font-weight:600;
  color:var(--bl);letter-spacing:.02em;
  display:flex;align-items:center;gap:4px;
}
.woocommerce-checkout .form-row label .required{
  color:var(--or);font-size:16px;line-height:1;
}

/* Input / Select */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea{
  width:100%;
  padding:14px 16px;
  border:2px solid #b8c6e8;
  border-radius:var(--rd);
  font-family:inherit;font-size:15px;
  color:var(--tx);
  background:#f4f7ff;
  transition:border-color .2s,box-shadow .2s,background .2s;
  appearance:none;-webkit-appearance:none;
  outline:none;
  box-shadow:inset 0 2px 4px rgba(26,48,128,.06);
}
.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus{
  border-color:var(--bl);
  background:#fff;
  box-shadow:0 0 0 4px rgba(26,48,128,.12),inset 0 2px 4px rgba(26,48,128,.04);
}
.woocommerce-checkout .form-row input.input-text:not(:placeholder-shown),
.woocommerce-checkout .form-row select:not([value=""]):valid{
  background:#fff;
  border-color:#8fa8d8;
}
.woocommerce-checkout .form-row input.input-text::placeholder{
  color:#8fa0c0;font-size:13px;font-style:italic;
}

/* Sélect avec flèche custom */
.woocommerce-checkout .form-row select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231a3080' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
  cursor:pointer;
}

/* Champ invalide */
.woocommerce-checkout .form-row.woocommerce-invalid input.input-text,
.woocommerce-checkout .form-row.woocommerce-invalid select{
  border-color:#ef4444;
  box-shadow:0 0 0 3px rgba(239,68,68,.1);
}
.woocommerce-checkout .form-row.woocommerce-invalid label{color:#ef4444;}

/* Champ valide */
.woocommerce-checkout .form-row.woocommerce-validated input.input-text{
  border-color:#22c55e;
}

/* Message d'erreur inline */
.woocommerce-checkout .form-row .woocommerce-error{
  font-size:12px;color:#ef4444;margin-top:4px;
}

/* Notice login */
.woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-checkout .woocommerce-info{
  background:var(--bl4);border-left:3px solid var(--bl);
  padding:12px 16px;border-radius:0 var(--rd) var(--rd) 0;
  font-size:13px;color:var(--bl);margin-bottom:20px;
}
.woocommerce-checkout .woocommerce-info a{color:var(--or);font-weight:600;}

/* Coupon */
.woocommerce-checkout .checkout_coupon{
  background:var(--bg);border:1px solid var(--bl4);
  border-radius:var(--rd);padding:20px;margin-bottom:24px;
  display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;
}
.woocommerce-checkout .checkout_coupon p{margin:0;font-size:13px;color:var(--tx2);}
.woocommerce-checkout .checkout_coupon .form-row{margin:0;flex:1 1 200px;}
.woocommerce-checkout .checkout_coupon .form-row-last{flex:0 0 auto;}
.woocommerce-checkout .checkout_coupon input{margin-bottom:0;}

/* ══ RÉCAPITULATIF COMMANDE ══════════════════════════════════════════════════ */
#order_review{
  background:#fff;
  border:1.5px solid var(--bl4);
  border-radius:12px;
  overflow:hidden;
}

table.woocommerce-checkout-review-order-table{
  width:100%;border-collapse:collapse;
  font-size:14px;
}
table.woocommerce-checkout-review-order-table th{
  background:var(--bl);color:#fff;
  padding:12px 16px;font-family:'Space Grotesk',sans-serif;
  font-size:13px;letter-spacing:.03em;
}
table.woocommerce-checkout-review-order-table td{
  padding:12px 16px;
  border-bottom:1px solid var(--bl4);
  vertical-align:middle;
}
table.woocommerce-checkout-review-order-table .product-name{
  color:var(--tx);font-weight:500;
}
table.woocommerce-checkout-review-order-table .product-name .product-quantity{
  color:var(--tx2);font-size:12px;font-weight:400;
}
table.woocommerce-checkout-review-order-table .product-total{
  font-weight:700;color:var(--bl);text-align:right;white-space:nowrap;
}
table.woocommerce-checkout-review-order-table tfoot tr:last-child td,
table.woocommerce-checkout-review-order-table tfoot tr:last-child th{
  font-size:16px;font-weight:700;color:var(--or);
  background:var(--or3);border-bottom:none;
}
table.woocommerce-checkout-review-order-table tfoot th{
  background:transparent;color:var(--tx);padding:10px 16px;
  font-family:inherit;font-size:13px;
}
table.woocommerce-checkout-review-order-table tfoot td{
  text-align:right;padding:10px 16px;
}

/* ══ SECTION PAIEMENT ════════════════════════════════════════════════════════ */
#payment{
  border-top:2px solid var(--bl4);
}

#payment .woocommerce-checkout-payment-header{
  padding:16px;font-weight:700;font-size:14px;color:var(--bl);
  background:var(--bg);
}

ul.woocommerce_payment_methods{
  list-style:none;padding:0;margin:0;
}

ul.woocommerce_payment_methods li.payment_method_cod,
ul.woocommerce_payment_methods li.payment_method_bacs,
ul.woocommerce_payment_methods li[class*="payment_method_"]{
  border-bottom:1px solid var(--bl4);
}

ul.woocommerce_payment_methods li label{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;cursor:pointer;
  font-weight:600;font-size:14px;color:var(--tx);
  transition:background .15s;
}
ul.woocommerce_payment_methods li label:hover{background:var(--bg);}

ul.woocommerce_payment_methods li input[type=radio]{
  accent-color:var(--bl);
  width:16px;height:16px;flex-shrink:0;cursor:pointer;
}

ul.woocommerce_payment_methods li img{
  max-height:22px;width:auto;margin-left:auto;opacity:.7;
}

.payment_box{
  padding:12px 16px 16px;
  font-size:13px;color:var(--tx2);
  background:var(--bl4);
  border-top:1px solid #dde5f5;
  line-height:1.6;
  white-space:pre-line;
}

/* Bouton place order */
.place-order{padding:20px 16px;}

#place_order,
.woocommerce .place-order button{
  width:100%;
  padding:16px 24px;
  background:var(--or);color:#fff;
  border:none;border-radius:var(--rd);
  font-size:16px;font-weight:700;
  font-family:'Space Grotesk',sans-serif;
  cursor:pointer;
  transition:background .2s,transform .1s;
  letter-spacing:.02em;
}
#place_order:hover,.woocommerce .place-order button:hover{background:var(--or2);}
#place_order:active{transform:scale(.98);}

/* ══ RESPONSIVE CHECKOUT ═════════════════════════════════════════════════════ */
@media(max-width:900px){
  form.woocommerce-checkout{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
  form.woocommerce-checkout #customer_details{grid-column:1;grid-row:1;}
  form.woocommerce-checkout #order_review_heading{grid-column:1;grid-row:2;}
  form.woocommerce-checkout #order_review{grid-column:1;grid-row:3;position:static;}
}

@media(max-width:600px){
  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper{
    grid-template-columns:1fr;
  }
  .form-row-first,.form-row-last{grid-column:1;}

  .woocommerce-cart .woocommerce,
  .woocommerce-checkout .woocommerce{padding:0 16px;}
  .woocommerce table.shop_table{font-size:13px;}
  .woocommerce table.shop_table td,
  .woocommerce table.shop_table th{padding:8px 10px;}
  .woocommerce-cart-form .product-thumbnail{display:none;}
}
