/*
Theme Name: Serial Grimpeur
Theme URI: https://www.serial-grimpeur.com
Author: La Forcl'Up
Description: Thème de blocs (FSE) pour Serial Grimpeur — esprit maillot à pois, cycliste montagnard. Enfant de Twenty Twenty-Five. Sans Elementor ni Revolution Slider.
Template: twentytwentyfive
Version: 1.0.0
Requires at least: 6.6
Requires PHP: 7.4
Text Domain: serial-grimpeur
*/

/* =========================================================
   Composants éditoriaux partagés (pages refondues)
   Préfixe .sg-  — réutilisables dans les blocs HTML
   ========================================================= */

.sg-page{--ink:var(--wp--preset--color--contrast,#1C2530);--red:var(--wp--preset--color--primary,#D8232A);--red2:var(--wp--preset--color--primary-dark,#B01D23);--paper:var(--wp--preset--color--base,#FAF8F3)}
.sg-page *{box-sizing:border-box}
.sg-wrap{max-width:1100px;margin:0 auto;padding:0 1.25rem}
.sg-kicker{font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:.82rem;font-weight:600;color:var(--red)}
.sg-btn{display:inline-block;font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:1rem;padding:.8rem 1.5rem;border-radius:4px;text-decoration:none;transition:.2s;cursor:pointer;border:0}
.sg-btn--red{background:var(--red);color:#fff}
.sg-btn--red:hover{background:var(--red2)}
.sg-btn--dark{background:var(--ink);color:#fff}
.sg-btn--dark:hover{background:#000}

/* En-tête de page */
.sg-pagehero{position:relative;background:var(--wp--preset--color--contrast,#1C2530);color:#fff;padding:3.5rem 0 3rem;overflow:hidden}
.sg-pagehero--img{background-size:cover;background-position:center}
.sg-pagehero--img::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,28,38,.45),rgba(20,28,38,.85))}
.sg-pagehero>.sg-wrap{position:relative}
.sg-pagehero h1{font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;color:#fff;font-weight:700;font-size:clamp(2rem,5vw,3.2rem);line-height:1.05;margin:.4rem 0 0}
.sg-pagehero p{color:#C9CFD6;font-size:1.1rem;margin:.8rem 0 0;max-width:60ch}
.sg-pagehero__dots{position:absolute;left:0;bottom:0;width:100%;height:10px;background-image:radial-gradient(var(--red) 2.6px,transparent 2.8px);background-size:18px 18px}

/* Corps de page / prose */
.sg-prose{padding:3.5rem 0 4.5rem}
.sg-prose .sg-wrap{max-width:820px}
.sg-prose h2{font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;color:var(--ink);font-weight:600;font-size:1.7rem;margin:2.4rem 0 .9rem;line-height:1.15}
.sg-prose h3{font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;color:var(--ink);font-weight:600;font-size:1.25rem;margin:1.8rem 0 .6rem}
.sg-prose p,.sg-prose li{font-size:1.05rem;line-height:1.8;color:#3a424d}
.sg-prose ul,.sg-prose ol{padding-left:1.3rem;margin:.6rem 0 1.2rem}
.sg-prose li{margin:.3rem 0}
.sg-prose a:not(.sg-btn){color:var(--red);font-weight:500}
.sg-prose a.sg-btn--red,.sg-prose a.sg-btn--dark{color:#fff}
.sg-prose strong{color:var(--ink)}
.sg-prose hr{border:0;border-top:1px solid #E4DECE;margin:2.5rem 0}
.sg-prose .sg-lead{font-size:1.2rem;color:var(--ink);line-height:1.7;border-left:4px solid var(--red);padding-left:1.2rem;margin:0 0 2rem}

/* Cartes / grilles */
.sg-section{padding:3.8rem 0}
.sg-section--surface{background:var(--wp--preset--color--surface,#EFEBE3)}
.sg-grid{display:grid;gap:1.5rem}
.sg-grid--2{grid-template-columns:1fr 1fr}
.sg-grid--3{grid-template-columns:repeat(3,1fr)}
.sg-card{background:#fff;border:1px solid #E7E1D5;border-radius:8px;padding:1.8rem}
.sg-card h3{font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;color:var(--ink);font-size:1.2rem;margin:0 0 .5rem}
.sg-card p{color:#5A626C;line-height:1.6;margin:.3rem 0}
.sg-card a{color:var(--red);font-weight:500;text-decoration:none}

/* Bloc d'infos contact */
.sg-info{display:flex;gap:.9rem;align-items:flex-start;margin:0 0 1.4rem}
.sg-info__ic{flex:0 0 42px;height:42px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center}
.sg-info__ic svg{width:20px;height:20px;stroke:var(--red);fill:none;stroke-width:1.8}
.sg-info b{display:block;font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;font-size:.95rem;color:var(--ink)}
.sg-info span,.sg-info a{color:#5A626C;text-decoration:none}

/* FAQ accordéon (sans JS) */
.sg-faq details{background:#fff;border:1px solid #E7E1D5;border-radius:8px;margin:0 0 .8rem;overflow:hidden}
.sg-faq summary{cursor:pointer;list-style:none;padding:1.1rem 1.3rem;font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;font-size:1.05rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.sg-faq summary::-webkit-details-marker{display:none}
.sg-faq summary::after{content:"+";color:var(--red);font-size:1.5rem;line-height:1}
.sg-faq details[open] summary::after{content:"\2013"}
.sg-faq details[open] summary{border-bottom:1px solid #EFEBE3}
.sg-faq .sg-faq__a{padding:1rem 1.3rem 1.3rem;color:#3a424d;line-height:1.75}

/* Formulaire (Contact Form 7) dans une carte */
.sg-formcard{background:#fff;border:1px solid #E7E1D5;border-radius:8px;padding:1.8rem}
.sg-formcard input[type=text],.sg-formcard input[type=email],.sg-formcard input[type=tel],.sg-formcard input[type=url],.sg-formcard input[type=number],.sg-formcard select,.sg-formcard textarea{width:100%;padding:.7rem .9rem;border:1px solid #D8D2C5;border-radius:5px;font-family:inherit;font-size:1rem;margin:.3rem 0 1rem;background:var(--paper);box-sizing:border-box}
.sg-formcard textarea{min-height:140px}
.sg-formcard input[type=submit]{background:var(--red);color:#fff;border:0;padding:.8rem 1.6rem;border-radius:4px;font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;letter-spacing:.04em;font-weight:600;cursor:pointer}
.sg-formcard input[type=submit]:hover{background:var(--red2)}

@media(max-width:820px){
 .sg-grid--2,.sg-grid--3{grid-template-columns:1fr}
}

/* =========================================================
   Finitions WooCommerce (cohérence charte)
   ========================================================= */
.woocommerce-page .wp-block-group,
.woocommerce .wp-block-group{--ink:var(--wp--preset--color--contrast,#1C2530);--red:var(--wp--preset--color--primary,#D8232A)}

/* Titre de fiche produit : un cran plus raisonnable */
.woocommerce div.product .product_title{font-size:clamp(1.8rem,3.5vw,2.6rem)!important;line-height:1.08}

/* Prix en rouge KOM */
.woocommerce .price,.woocommerce span.price,.woocommerce ins{color:var(--wp--preset--color--primary,#D8232A)!important;font-weight:600}
.woocommerce ins{text-decoration:none}
.woocommerce del{opacity:.6}

/* Boutons WooCommerce -> rouge KOM, typo display */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce #respond input#submit{
  background:var(--wp--preset--color--primary,#D8232A);color:#fff;border:0;border-radius:4px;
  font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase;
  letter-spacing:.04em;font-weight:600;padding:.7rem 1.4rem}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{background:var(--wp--preset--color--primary-dark,#B01D23)}

/* Liens (fil d'Ariane, catégories) en rouge */
.woocommerce-breadcrumb a,.woocommerce a.added_to_cart{color:var(--wp--preset--color--primary,#D8232A)}

/* Champs select (tri, variations) */
.woocommerce select,.woocommerce .woocommerce-ordering select{
  padding:.5rem .8rem;border:1px solid #D8D2C5;border-radius:5px;background:var(--wp--preset--color--base,#FAF8F3);font-family:inherit}

/* Badge promo */
.woocommerce span.onsale{background:var(--wp--preset--color--contrast,#1C2530);color:#fff;border-radius:4px;font-family:var(--wp--preset--font-family--display,Oswald),sans-serif;text-transform:uppercase}

/* Notices */
.woocommerce-message,.woocommerce-info{border-top-color:var(--wp--preset--color--primary,#D8232A)}
.woocommerce-message::before,.woocommerce-info::before{color:var(--wp--preset--color--primary,#D8232A)}
