/* =====================================================================
   Thème « Nuit premium » — application des tokens, composants, CSS migré.
   Foundation Sprint 0 : socle de design. Le détail par page (Theme Builder,
   layouts) arrive en Sprint 1.
   ===================================================================== */

/* --- Fond & texte globaux --- */
body,
#page-container {
	background-color: var(--ell-bg);
	color: var(--ell-text);
	font-family: var(--ell-font-body);
	font-size: var(--ell-fs-base);
	line-height: var(--ell-lh-base);
}

/* --- Titres en serif (univers « Edda ») --- */
h1, h2, h3, h4,
.et_pb_module h1, .et_pb_module h2, .et_pb_module h3,
.et_pb_slide_description .et_pb_slide_title {
	font-family: var(--ell-font-display);
	font-weight: 600;          /* poids chargé en self-hosté (évite le faux-gras) */
	color: var(--ell-text);
	line-height: 1.15;
	letter-spacing: .005em;
}
h1 { font-size: var(--ell-fs-h1); }
h2 { font-size: var(--ell-fs-h2); }
h3 { font-size: var(--ell-fs-h3); }

/* --- Liens & accents --- */
a            { color: var(--ell-accent); }
a:hover      { color: var(--ell-accent-hover); }

/* --- Accessibilité : focus visible partout --- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.et_pb_button:focus-visible {
	outline: 2px solid var(--ell-focus);
	outline-offset: 2px;
}

/* --- Boutons « Demander un devis » (or plein) — primaire --- */
.et_pb_button,
.woocommerce a.button,
.woocommerce button.button,
.button.alt,
a.wp-block-button__link {
	background-color: var(--ell-accent) !important;
	color: var(--ell-charbon) !important;
	border: 1px solid var(--ell-accent) !important;
	border-radius: var(--ell-radius);
	font-family: var(--ell-font-body);
	font-weight: 600;
	letter-spacing: .03em;
	min-height: var(--ell-tap);
	padding: .7em 1.6em;
	transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}
.et_pb_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.button.alt:hover {
	background-color: var(--ell-accent-hover) !important;
	border-color: var(--ell-accent-hover) !important;
	color: var(--ell-charbon) !important;
}

/* Variante secondaire : contour or (classe utilitaire) */
.et_pb_button.ell-btn-ghost {
	background-color: transparent !important;
	color: var(--ell-accent) !important;
}
.et_pb_button.ell-btn-ghost:hover {
	background-color: var(--ell-accent) !important;
	color: var(--ell-charbon) !important;
}

/* --- Surfaces / cartes produit --- */
.ell-card,
.woocommerce ul.products li.product {
	background-color: var(--ell-surface);
	border: 1px solid var(--ell-border);
	border-radius: var(--ell-radius);
}

/* --- Composant : bandeau USP (Suisse / Artisanal / Naturel) --- */
.ell-usp {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ell-space);
	justify-content: center;
	align-items: stretch;
	border-top: 1px solid var(--ell-border);
	border-bottom: 1px solid var(--ell-border);
	padding: var(--ell-space) 0;
}
.ell-usp__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	flex: 1 1 220px;
	padding: .25rem 1.25rem;
}
.ell-usp__item strong {
	font-family: var(--ell-font-display);
	font-weight: 600;
	font-size: 1.55rem;
	color: var(--ell-accent);
	letter-spacing: .02em;
}
.ell-usp__item span { color: var(--ell-text-muted); font-size: .95rem; margin-top: .3rem; }
.ell-usp__item + .ell-usp__item { border-left: 1px solid var(--ell-border); }
@media (max-width: 768px) { .ell-usp__item + .ell-usp__item { border-left: none; } }

/* --- Composant : bloc pédagogique --- */
.ell-pedago { max-width: 760px; margin: 0 auto; text-align: center; }
.ell-pedago h2 { margin-bottom: .6em; }
.ell-pedago p { color: var(--ell-text-muted); font-size: 1.1rem; line-height: 1.8; }
.ell-pedago strong { color: var(--ell-text); }

/* --- Composant : légende « Edda » --- */
.ell-edda {
	font-family: var(--ell-font-display);
	font-style: italic;
	color: var(--ell-text-muted);
	border-left: 2px solid var(--ell-vin-clair);
	padding-left: var(--ell-space);
}

/* --- Composant : mention +18 --- */
.ell-mention-18 {
	color: var(--ell-text-muted);
	font-size: .85em;
	letter-spacing: .02em;
}

/* =====================================================================
   CSS migré du Customizer de la prod (Apparence → CSS additionnel).
   Migré le 2026-06-23 vers le child theme pour qu'il survive aux réglages.
   ===================================================================== */
#main-header {
	background: transparent;
	background-color: rgba(0, 0, 0, .25);
}
.et-cart-info {
	display: none !important; /* site en devis uniquement : pas de panier */
}

/* =====================================================================
   Sprint 1 — passe de polish (v0.2)
   ===================================================================== */

/* --- Sélection de texte --- */
::selection { background: var(--ell-or); color: var(--ell-charbon); }

/* --- Contrôles de formulaire (thème sombre) --- */
input[type="text"], input[type="email"], input[type="tel"], input[type="search"],
input[type="number"], input[type="password"], input[type="url"], textarea, select,
.woocommerce-ordering select {
	background-color: var(--ell-surface);
	color: var(--ell-text);
	border: 1px solid var(--ell-border);
	border-radius: var(--ell-radius);
	padding: .55em .8em;
	min-height: var(--ell-tap);
	font-family: var(--ell-font-body);
}
select option { background-color: var(--ell-surface); color: var(--ell-text); }
::placeholder { color: var(--ell-text-muted); opacity: 1; }

/* Champs de formulaire Divi (contact, newsletter) — spécificité forte → !important ciblé */
.et_pb_contact_field input.input,
.et_pb_contact_field textarea,
.et_pb_contact_field select.et_pb_contact_select,
.et_pb_contact_message,
.et_pb_contact_form .input,
.et_pb_newsletter_field input {
	background-color: var(--ell-surface) !important;
	color: var(--ell-text) !important;
	border: 1px solid var(--ell-border) !important;
}
.et_pb_contact_field input.input::placeholder,
.et_pb_contact_field textarea::placeholder { color: var(--ell-text-muted) !important; }

/* --- En-tête / navigation --- */
#main-header { border-bottom: 1px solid var(--ell-border); }
#main-header .et-menu > li > a,
#et-top-navigation .et-menu li a { color: var(--ell-text); letter-spacing: .04em; }
#main-header .et-menu > li > a:hover { color: var(--ell-accent); }

/* Barre supérieure dorée : texte SOMBRE (charbon) pour la lisibilité sur le doré */
#top-header, #top-header a, #top-header span, #top-header li,
#top-header .et-social-icon a { color: var(--ell-charbon) !important; }
#top-header a:hover { color: var(--ell-vin) !important; }
#main-header #top-menu li a,
#et-top-navigation #top-menu li a { color: var(--ell-text) !important; }
#main-header #top-menu li a:hover { color: var(--ell-accent) !important; }

/* Bouton CTA dans le menu (Demander un Devis) — contenu dans sa case */
#top-menu li.ell-menu-cta > a,
#et-top-navigation #top-menu li.ell-menu-cta > a {
	display: inline-block;
	background-color: var(--ell-accent) !important;
	color: var(--ell-charbon) !important;
	border-radius: var(--ell-radius);
	padding: 8px 15px !important;
	line-height: 1 !important;
	white-space: nowrap;
}
#top-menu li.ell-menu-cta > a:hover {
	background-color: var(--ell-accent-hover) !important;
	color: var(--ell-charbon) !important;
}

/* --- Grille boutique : cartes produit --- */
.et_pb_shop ul.products li.product,
.woocommerce ul.products li.product {
	padding: .75rem;
	border: 1px solid transparent;
	border-radius: var(--ell-radius);
	transition: border-color .2s ease, transform .2s ease, background-color .2s ease;
}
.et_pb_shop ul.products li.product:hover,
.woocommerce ul.products li.product:hover {
	border-color: var(--ell-border);
	background-color: var(--ell-surface);
	transform: translateY(-3px);
}
.et_pb_shop ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--ell-font-display);
	color: var(--ell-text);
}
.et_pb_shop ul.products li.product:hover .woocommerce-loop-product__title,
.woocommerce ul.products li.product:hover .woocommerce-loop-product__title { color: var(--ell-accent); }

/* prix + compteur WooCommerce */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price { color: var(--ell-accent); }
.woocommerce-result-count { color: var(--ell-text-muted); }

/* --- Pied de page --- */
#main-footer { background-color: #16151A; border-top: 1px solid var(--ell-border); }
#main-footer, #footer-bottom { color: var(--ell-text-muted); }
#main-footer a { color: var(--ell-text); }
#main-footer a:hover { color: var(--ell-accent); }

/* Réseaux sociaux du pied de page (Facebook / X / RSS) non utilisés → masqués */
#footer-bottom .et-social-icons,
#et-footer-nav .et-social-icons,
.bottom-nav .et-social-icons { display: none !important; }

/* --- Section partenaires : couleur homogène (fin du blanc/gris incohérent) --- */
.ell-partners h3 { color: var(--ell-text-muted) !important; }
.ell-partners h3:hover { color: var(--ell-accent) !important; }

/* --- Vitrine image (drakkar Gullveig) : halo doré + profondeur --- */
.ell-showcase .et_pb_image img {
	box-shadow: 0 12px 40px rgba(0,0,0,.55), 0 0 55px rgba(201,162,39,.18);
}

/* --- Barre de défilement (discrète) --- */
* { scrollbar-color: var(--ell-vin-clair) var(--ell-charbon); }

/* =====================================================================
   Fond sombre sur TOUTES les pages (v0.2.2)
   L'accueil était sombre via ses sections Divi Builder ; les pages au
   template par défaut (fiche produit, boutique, panier, compte, blog)
   restaient claires. On force le sombre + un texte lisible partout.
   ===================================================================== */
#page-container,
#main-content,
#et-main-area,
.et_pb_pagebuilder_layout #main-content,
body.woocommerce-page #main-content {
	background-color: var(--ell-bg) !important;
}
#left-area, #sidebar,
#main-content .entry-content,
.woocommerce, .woocommerce-page {
	color: var(--ell-text);
}

/* Fil d'Ariane + méta produit */
.woocommerce-breadcrumb,
.woocommerce .product_meta { color: var(--ell-text-muted); }
.woocommerce-breadcrumb a,
.woocommerce .product_meta a { color: var(--ell-accent); }

/* Fiche produit : titre, prix, stock */
.woocommerce div.product .product_title { color: var(--ell-text); }
.woocommerce div.product p.price,
.woocommerce div.product span.price { color: var(--ell-accent); }
.woocommerce .stock { color: var(--ell-text-muted); }

/* Onglets (Description / Informations complémentaires) */
.woocommerce div.product .woocommerce-tabs ul.tabs { border-bottom: 1px solid var(--ell-border); }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: var(--ell-border); }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background-color: var(--ell-surface);
	border: 1px solid var(--ell-border);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: var(--ell-text-muted); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { background-color: var(--ell-bg); border-bottom-color: var(--ell-bg); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--ell-accent); }
.woocommerce div.product .woocommerce-tabs .panel {
	background-color: var(--ell-surface);
	border: 1px solid var(--ell-border);
	border-radius: var(--ell-radius);
	padding: 1.5rem;
}

/* Sidebar filtres (widgets) */
#sidebar .widgettitle, #left-area .widgettitle,
.et_pb_widget h4, .widget h4 {
	font-family: var(--ell-font-display);
	color: var(--ell-text);
}
#sidebar, #sidebar a, #sidebar label,
.et_pb_widget, .et_pb_widget a, .et_pb_widget label { color: var(--ell-text-muted); }
#sidebar a:hover, .et_pb_widget a:hover { color: var(--ell-accent); }
