/*
 Theme Name:   ECU Performance Child
 Theme URI:    https://www.ecuperformance.fr
 Description:  Theme enfant Astra — couleurs ECU Performance (fond sombre #070b12, accent #1f6feb)
 Author:       ECU Performance
 Template:     astra
 Version:      1.15.1
 Text Domain:  ecu-performance-child
*/

/* ==========================================================================
   ECU Performance — palette
   ========================================================================== */
:root {
	--ecu-bg-dark: #070b12;
	--ecu-bg-card: #0f1724;
	--ecu-bg-card-alt: #151f2e;
	--ecu-border: #26364d;
	--ecu-accent: #1f6feb;
	--ecu-accent-hover: #1858c7;
	--ecu-accent-light: #66a3ff;
	--ecu-text: #eef4ff;
	--ecu-text-muted: #91a4bd;
}

/* ==========================================================================
   Base & layout (Astra)
   ========================================================================== */
body,
html {
	background-color: var(--ecu-bg-dark) !important;
	color: var(--ecu-text) !important;
}

.site-content,
#content,
.ast-separate-container,
.ast-separate-container .ast-article-single,
.ast-separate-container .ast-article-post,
.ast-plain-container,
.ast-page-builder-template,
.woocommerce-page .site-content {
	background-color: var(--ecu-bg-dark) !important;
}

.ast-separate-container .ast-article-single,
.ast-separate-container .ast-article-post,
.ast-separate-container .comment-respond,
.ast-separate-container .comments-area {
	background-color: var(--ecu-bg-card) !important;
	border: 1px solid var(--ecu-border) !important;
	border-radius: 8px !important;
}

.entry-content,
.entry-summary {
	color: var(--ecu-text);
}

/* ==========================================================================
   Typographie
   ========================================================================== */
h1, h2, h3, h4, h5, h6,
.entry-title,
.entry-title a,
.page-title {
	color: var(--ecu-text) !important;
}

.entry-title a:hover {
	color: var(--ecu-accent-light) !important;
}

p, li, td, th, label {
	color: var(--ecu-text);
}

a {
	color: var(--ecu-accent-light);
}

a:hover,
a:focus {
	color: var(--ecu-accent);
}

/* ==========================================================================
   Header & menu
   ========================================================================== */
.main-header-bar,
.site-header,
.ast-primary-header-bar,
.ast-above-header-bar,
.ast-below-header-bar,
.ast-mobile-header-wrap {
	background-color: var(--ecu-bg-card) !important;
	border-bottom: 1px solid var(--ecu-border) !important;
}

.main-header-menu .menu-link,
.main-header-menu .menu-item > .menu-link,
.site-title a,
.site-title a:hover,
.site-description,
.ast-builder-menu-1 .menu-item > .menu-link {
	color: var(--ecu-text) !important;
}

.main-header-menu .menu-item:hover > .menu-link,
.main-header-menu .current-menu-item > .menu-link,
.main-header-menu .current-menu-ancestor > .menu-link {
	color: var(--ecu-accent-light) !important;
	background-color: transparent !important;
}

.main-header-menu .sub-menu,
.main-header-menu .sub-menu .menu-link {
	background-color: var(--ecu-bg-card-alt) !important;
	border-color: var(--ecu-border) !important;
	color: var(--ecu-text) !important;
}

.ast-header-break-point .main-header-bar {
	border-bottom-color: var(--ecu-border) !important;
}

/* Header Astra : logo seul — pas de menu ni titre duplique */
.main-header-bar-navigation,
.ast-primary-header-bar .ast-builder-menu,
.ast-primary-header-bar .site-header-primary-section-right,
#ast-desktop-header .main-header-menu,
.ast-header-break-point .main-header-bar-navigation,
.ast-mobile-header-wrap .main-header-bar-navigation,
.ast-header-break-point .ast-mobile-menu-buttons {
	display: none !important;
}

.site-branding .site-title,
.site-header .site-title,
.ast-site-identity .site-description {
	display: none !important;
}

.site-branding .custom-logo-link img,
.site-header .custom-logo-link img {
	max-height: 72px;
	width: auto;
}

/* ==========================================================================
   Header pro — logo + navigation
   ========================================================================== */
.ecu-site-header {
	background: linear-gradient(180deg, #0c1422 0%, var(--ecu-bg-card) 100%);
	border-bottom: 1px solid var(--ecu-border);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.35);
	position: sticky;
	top: 0;
	z-index: 999;
}

.admin-bar .ecu-site-header {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .ecu-site-header {
		top: 46px;
	}
}

.ecu-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 20px;
	max-width: 100%;
	margin: 0 auto;
	flex-wrap: nowrap;
}

.ecu-site-header__right {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex: 1;
	min-width: 0;
	flex-wrap: nowrap;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.ecu-site-header__account {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
	flex-wrap: nowrap;
}

.ecu-site-header__tokens {
	font-size: 11px;
	color: var(--ecu-accent-light);
	white-space: nowrap;
	padding: 5px 8px;
	background: rgba(31, 111, 235, 0.12);
	border-radius: 6px;
	border: 1px solid rgba(102, 163, 255, 0.25);
}

.ecu-site-header__user {
	font-size: 11px;
	color: var(--ecu-text-muted);
	max-width: 90px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.ecu-site-header__account-btn {
	font-size: 11px;
	font-weight: 700;
	padding: 7px 11px;
	border-radius: 6px;
	text-decoration: none !important;
	white-space: nowrap;
	transition: background 0.2s, border-color 0.2s;
}

.ecu-site-header__account-btn--primary {
	background: var(--ecu-accent);
	color: #fff !important;
	border: 1px solid var(--ecu-accent);
}

.ecu-site-header__account-btn--primary:hover {
	background: var(--ecu-accent-hover);
	color: #fff !important;
}

.ecu-site-header__account-btn--ghost {
	background: transparent;
	color: var(--ecu-text) !important;
	border: 1px solid var(--ecu-border);
}

.ecu-site-header__account-btn--ghost:hover {
	border-color: var(--ecu-accent-light);
	color: var(--ecu-accent-light) !important;
}

.ecu-site-header__brand {
	display: flex !important;
	align-items: center !important;
	flex-shrink: 0 !important;
	text-decoration: none !important;
}

.ecu-site-header__brand--text {
	background: transparent !important;
	box-shadow: none !important;
	padding: 0 !important;
}

.ecu-site-header__logo {
	display: block;
	height: 48px !important;
	max-height: 48px !important;
	width: auto !important;
	border-radius: 6px;
}

@media (max-width: 921px) {
	.ecu-site-header__logo {
		height: 38px !important;
		max-height: 38px !important;
	}
}

/* Panier — masque les suggestions croisées WooCommerce */
.woocommerce-cart .cross-sells {
	display: none !important;
}

/* ==========================================================================
   Panier vide — message + produits phares
   ========================================================================== */
.ecu-cart-empty {
	text-align: center;
	padding: 24px 0 40px;
}

.ecu-cart-empty__icon {
	font-size: 52px;
	margin: 0 0 8px;
	line-height: 1;
}

.ecu-cart-empty__title {
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: 28px !important;
	color: var(--ecu-text) !important;
	margin: 0 0 8px !important;
}

.ecu-cart-empty__text {
	color: var(--ecu-text-muted);
	margin: 0 0 28px;
}

.ecu-featured {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	max-width: 940px;
	margin: 0 auto 28px;
	text-align: left;
}

.ecu-featured__card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 12px;
	padding: 18px;
	transition: border-color 0.2s, transform 0.2s;
}

.ecu-featured__card:hover {
	border-color: rgba(102, 163, 255, 0.45);
	transform: translateY(-2px);
}

.ecu-featured__badge {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 2;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #fff;
	background: var(--ecu-accent);
	padding: 4px 10px;
	border-radius: 999px;
}

.ecu-featured__media {
	display: block;
	border-radius: 8px;
	overflow: hidden;
	background: var(--ecu-bg-card-alt);
	margin-bottom: 14px;
}

.ecu-featured__media img {
	display: block;
	width: 100%;
	height: 170px;
	object-fit: cover;
}

.ecu-featured__name {
	font-size: 15px !important;
	margin: 0 0 8px !important;
	line-height: 1.4 !important;
}

.ecu-featured__name a {
	color: var(--ecu-text) !important;
	text-decoration: none !important;
}

.ecu-featured__name a:hover {
	color: var(--ecu-accent-light) !important;
}

.ecu-featured__price {
	color: var(--ecu-accent-light);
	font-size: 17px;
	font-weight: 700;
	margin: 0 0 14px;
}

.ecu-featured__add {
	margin-top: auto;
	text-align: center;
	font-size: 13px !important;
	padding: 11px 16px !important;
}

.ecu-cart-empty__actions {
	margin: 0;
}

@media (max-width: 768px) {
	.ecu-featured {
		grid-template-columns: 1fr;
		max-width: 420px;
	}
}

.ecu-site-header__name {
	font-size: 18px;
	font-weight: 700;
	color: var(--ecu-text) !important;
	letter-spacing: 0.04em;
	line-height: 1;
	white-space: nowrap;
}

.ecu-site-header__name em {
	color: var(--ecu-accent-light);
	font-style: normal;
	font-weight: 700;
}

.ecu-site-header__nav {
	flex: 1;
	display: flex;
	justify-content: flex-end;
	min-width: 0;
}

.ecu-site-header__menu {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: flex-end;
	gap: 2px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.ecu-site-header__menu li {
	margin: 0;
	padding: 0;
}

.ecu-site-header__menu a {
	color: var(--ecu-text) !important;
	text-decoration: none !important;
	font-size: 12px;
	font-weight: 600;
	padding: 7px 9px;
	border-radius: 6px;
	display: block;
	white-space: nowrap;
	transition: background 0.2s, color 0.2s;
}

.ecu-site-header__menu a:hover,
.ecu-site-header__menu .current-menu-item > a,
.ecu-site-header__menu .current_page_item > a {
	background: rgba(31, 111, 235, 0.18);
	color: var(--ecu-accent-light) !important;
}

.ecu-site-header__menu .current-menu-item > a {
	box-shadow: inset 0 -2px 0 var(--ecu-accent-light);
}

@media (max-width: 921px) {
	.ecu-site-header__inner {
		padding: 10px 14px;
		gap: 10px;
	}

	.ecu-site-header__desktop-nav {
		display: none !important;
	}

	.ecu-mobile-header-tools {
		display: flex !important;
		align-items: center;
		gap: 8px;
		margin-left: auto;
		flex-shrink: 0;
	}

	.ecu-mobile-header-tools__cart {
		position: relative;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 44px;
		height: 44px;
		border-radius: 10px;
		border: 1px solid var(--ecu-border);
		background: rgba(31, 111, 235, 0.15);
		text-decoration: none !important;
	}

	.ecu-mobile-header-tools__cart-icon {
		font-size: 20px;
		line-height: 1;
	}

	.ecu-mobile-header-tools__cart-count {
		position: absolute;
		top: 4px;
		right: 4px;
		min-width: 18px;
		height: 18px;
		padding: 0 4px;
		border-radius: 999px;
		background: var(--ecu-accent);
		color: #fff;
		font-size: 11px;
		font-weight: 800;
		line-height: 18px;
		text-align: center;
	}

	.ecu-mobile-header-tools__toggle {
		display: inline-flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 5px;
		width: 44px;
		height: 44px;
		padding: 0;
		border: 1px solid var(--ecu-border);
		border-radius: 10px;
		background: var(--ecu-bg-card-alt);
		cursor: pointer;
	}

	.ecu-mobile-header-tools__toggle-bar {
		display: block;
		width: 20px;
		height: 2px;
		background: #eef4ff;
		border-radius: 2px;
	}

	body.ecu-mobile-nav-open .ecu-mobile-header-tools__toggle-bar:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
	}

	body.ecu-mobile-nav-open .ecu-mobile-header-tools__toggle-bar:nth-child(2) {
		opacity: 0;
	}

	body.ecu-mobile-nav-open .ecu-mobile-header-tools__toggle-bar:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
	}

	body.ecu-has-mobile-nav {
		padding-bottom: calc(88px + env(safe-area-inset-bottom, 0px));
	}

	body.ecu-has-mobile-nav .ecu-cart-tab {
		display: none !important;
	}

	body.ecu-has-mobile-nav .ecu-hours-float {
		right: 12px;
		bottom: calc(12px + env(safe-area-inset-bottom, 0px));
	}

	body.ecu-has-mobile-nav .ecu-whatsapp-float {
		left: 12px;
		bottom: calc(12px + env(safe-area-inset-bottom, 0px));
	}

	body.ecu-has-mobile-nav .ecu-ai-diag__btn {
		left: 12px;
		bottom: calc(72px + env(safe-area-inset-bottom, 0px));
	}

	.ecu-service-steps {
		flex-direction: column;
	}

	.ecu-service-step {
		border-right: 0;
		border-bottom: 1px solid var(--ecu-border);
		padding: 14px 12px;
	}

	.ecu-service-step:last-child {
		border-bottom: 0;
	}

	.ecu-tiktok-section__grid .ecu-tiktok-embed:nth-child(n+3) {
		display: none;
	}

	.ecu-tiktok-embed {
		min-height: 480px;
	}
}

@media (min-width: 922px) {
	.ecu-mobile-header-tools,
	.ecu-mobile-drawer {
		display: none !important;
	}
}

/* Legacy nav — obsolete */
.ecu-site-nav {
	display: none !important;
}

.ecu-site-footer-bar {
	background: linear-gradient(0deg, #0a1018 0%, var(--ecu-bg-card) 100%);
	border-top: 1px solid var(--ecu-border);
	padding: 32px 20px;
	text-align: center;
	color: var(--ecu-text-muted);
	font-size: 14px;
}

.ecu-site-footer-bar__inner {
	max-width: 720px;
	margin: 0 auto;
}

.ecu-site-footer-bar__logo {
	display: none;
}

.ecu-site-footer-bar__brand {
	font-size: 18px;
	font-weight: 700;
	color: var(--ecu-text);
	margin: 0 0 8px;
}

.ecu-site-footer-bar__brand em {
	color: var(--ecu-accent-light);
	font-style: normal;
}

.ecu-site-footer-bar p {
	margin: 0 0 8px;
	color: var(--ecu-text-muted);
}

.ecu-site-footer-bar a {
	color: var(--ecu-accent-light);
}

.ecu-site-footer-bar__copy {
	font-size: 12px;
	opacity: 0.85;
}

@media (max-width: 921px) {
	.ecu-site-nav__list {
		overflow-x: auto;
		flex-wrap: nowrap;
		padding-bottom: 12px;
		-webkit-overflow-scrolling: touch;
	}
}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer,
.ast-small-footer,
.ast-footer-overlay,
.site-below-footer-wrap,
.site-above-footer-wrap,
.site-primary-footer-wrap {
	background-color: var(--ecu-bg-card) !important;
	border-top: 1px solid var(--ecu-border) !important;
	color: var(--ecu-text-muted) !important;
}

.site-footer a,
.ast-small-footer a,
.site-footer .footer-widget-area a {
	color: var(--ecu-accent-light) !important;
}

.site-footer .widget-title,
.footer-widget-area .widget-title {
	color: var(--ecu-text) !important;
}

/* ==========================================================================
   Boutons
   ========================================================================== */
button,
input[type="button"],
input[type="submit"],
.button,
.ast-button,
.wp-block-button__link,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce ul.products li.product .button,
.woocommerce div.product form.cart .button,
.wpcf7 input[type="submit"] {
	background-color: var(--ecu-accent) !important;
	border-color: var(--ecu-accent) !important;
	color: #fff !important;
	border-radius: 6px !important;
	font-weight: 600 !important;
	transition: background 0.2s ease !important;
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce ul.products li.product .button:hover,
.wpcf7 input[type="submit"]:hover {
	background-color: var(--ecu-accent-hover) !important;
	border-color: var(--ecu-accent-hover) !important;
	color: #fff !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt {
	background-color: var(--ecu-accent) !important;
}

/* ==========================================================================
   Formulaires & inputs
   ========================================================================== */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
select,
textarea,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="file"],
.wpcf7 select,
.wpcf7 textarea {
	background-color: var(--ecu-bg-card) !important;
	border: 1px solid var(--ecu-border) !important;
	color: var(--ecu-text) !important;
	border-radius: 6px !important;
}

input:focus,
select:focus,
textarea:focus {
	border-color: var(--ecu-accent) !important;
	outline: none !important;
	box-shadow: 0 0 0 1px var(--ecu-accent) !important;
}

::placeholder {
	color: var(--ecu-text-muted) !important;
	opacity: 0.8;
}

/* ==========================================================================
   WooCommerce — boutique
   ========================================================================== */
.woocommerce .products .product .woocommerce-loop-product__title,
.woocommerce div.product .product_title {
	color: var(--ecu-text) !important;
}

.woocommerce .price,
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--ecu-accent-light) !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	background: var(--ecu-bg-card) !important;
	border: 1px solid var(--ecu-border) !important;
	border-radius: 8px !important;
	padding-bottom: 16px !important;
}

.woocommerce span.onsale {
	background-color: var(--ecu-accent) !important;
	color: #fff !important;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background-color: var(--ecu-bg-card-alt) !important;
	border-top-color: var(--ecu-accent) !important;
	color: var(--ecu-text) !important;
}

.woocommerce-message::before,
.woocommerce-info::before {
	color: var(--ecu-accent-light) !important;
}

.woocommerce table.shop_table,
.woocommerce table.shop_table td,
.woocommerce table.shop_table th {
	background-color: var(--ecu-bg-card) !important;
	border-color: var(--ecu-border) !important;
	color: var(--ecu-text) !important;
}

.woocommerce-cart .cart-collaterals,
.woocommerce-checkout #order_review,
.woocommerce-checkout #customer_details {
	background: var(--ecu-bg-card) !important;
	border: 1px solid var(--ecu-border) !important;
	border-radius: 8px !important;
	padding: 20px !important;
}

.woocommerce-breadcrumb a {
	color: var(--ecu-accent-light) !important;
}

.woocommerce-breadcrumb {
	color: var(--ecu-text-muted) !important;
}

/* ==========================================================================
   Contact Form 7
   ========================================================================== */
.wpcf7 form {
	color: var(--ecu-text);
}

.wpcf7 label {
	color: var(--ecu-text);
}

.wpcf7-not-valid-tip {
	color: #ff6b6b !important;
}

.wpcf7 form sent .wpcf7-response-output,
.wpcf7 form .wpcf7-response-output {
	border-color: var(--ecu-accent) !important;
	background: var(--ecu-bg-card-alt) !important;
	color: var(--ecu-text) !important;
}

/* ==========================================================================
   Divers
   ========================================================================== */
hr {
	border-color: var(--ecu-border) !important;
}

blockquote {
	border-left-color: var(--ecu-accent) !important;
	background: var(--ecu-bg-card-alt) !important;
	color: var(--ecu-text-muted) !important;
}

.ast-pagination a,
.page-numbers {
	background: var(--ecu-bg-card) !important;
	border-color: var(--ecu-border) !important;
	color: var(--ecu-text) !important;
}

.page-numbers.current {
	background: var(--ecu-accent) !important;
	border-color: var(--ecu-accent) !important;
	color: #fff !important;
}

#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment {
	background: var(--ecu-bg-card-alt) !important;
	border-radius: 8px !important;
}

#add_payment_method #payment div.payment_box,
.woocommerce-cart #payment div.payment_box,
.woocommerce-checkout #payment div.payment_box {
	background: var(--ecu-bg-card) !important;
	color: var(--ecu-text) !important;
}

/* Masquer compteur resultats + tri WooCommerce */
.woocommerce-result-count,
.woocommerce-ordering {
	display: none !important;
}

/* ==========================================================================
   Service fichier — style ECU Performance Suite Pro
   ========================================================================== */
.ecu-service-shell {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 4px 40px;
	font-family: "Segoe UI", Arial, sans-serif;
	line-height: 1.6;
}

.ecu-service-intro {
	display: grid;
	grid-template-columns: 250px minmax(0, 1fr);
	gap: 16px 20px;
	align-items: start;
	margin-bottom: 16px;
}

.ecu-service-intro__hours {
	min-width: 0;
}

.ecu-service-intro .ecu-service-header {
	margin: 0;
}

.ecu-service-intro .ecu-service-header h1 {
	margin-bottom: 8px;
}

.ecu-service-intro .ecu-service-header p {
	margin-bottom: 0;
}

@media (max-width: 768px) {
	.ecu-service-intro {
		grid-template-columns: 1fr;
	}
}

.ecu-service-header h1 {
	font-size: 24px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--ecu-text);
}

.ecu-service-header p {
	color: var(--ecu-text-muted);
	font-size: 14px;
	margin: 0 0 20px;
}

.ecu-service-notice {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	background: #1a3a5c;
	border: 1px solid var(--ecu-accent-light);
	border-radius: 8px;
	padding: 14px 16px;
	margin-bottom: 20px;
}

.ecu-service-notice__icon {
	font-size: 28px;
	line-height: 1;
	color: var(--ecu-accent-light);
	flex-shrink: 0;
}

.ecu-service-notice p {
	margin: 0;
	color: #fff;
	font-size: 13px;
}

.ecu-service-steps {
	display: flex;
	margin-bottom: 24px;
	border: 1px solid var(--ecu-border);
	border-radius: 8px;
	overflow: hidden;
}

.ecu-service-step {
	flex: 1;
	padding: 12px 10px;
	background: var(--ecu-bg-card);
	border-right: 1px solid var(--ecu-border);
	text-align: center;
}

.ecu-service-step:last-child {
	border-right: 0;
}

.ecu-service-step.is-active {
	background: var(--ecu-bg-card-alt);
	box-shadow: inset 0 -2px 0 var(--ecu-accent-light);
}

.ecu-service-step.is-done {
	background: var(--ecu-bg-card-alt);
	opacity: 0.85;
}

.ecu-service-step__num {
	color: var(--ecu-accent-light);
	font-weight: 700;
	font-size: 18px;
	line-height: 1.2;
}

.ecu-service-step__label {
	font-size: 11px;
	color: var(--ecu-text-muted);
	margin-top: 4px;
}

.ecu-service-layout {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 20px;
	align-items: start;
}

.ecu-service-layout--single {
	grid-template-columns: 1fr;
	max-width: 900px;
}

.ecu-service-sidebar {
	position: sticky;
	top: 20px;
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 8px;
	overflow: hidden;
}

.ecu-service-summary-head {
	background: #12355b;
	padding: 14px 16px;
	color: #fff;
	font-weight: 700;
	font-size: 13px;
}

.ecu-service-summary-body {
	padding: 14px 16px;
	font-size: 13px;
	color: var(--ecu-text);
}

.ecu-service-summary-body p {
	margin: 0 0 10px;
	font-size: 13px;
}

.ecu-service-summary-total {
	background: var(--ecu-border);
	padding: 12px 16px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-weight: 700;
	font-size: 13px;
	color: var(--ecu-text);
}

.ecu-service-summary-total a {
	color: var(--ecu-accent-light);
	text-decoration: none;
}

.ecu-service-pay-btn {
	display: block;
	margin: 0 14px 14px;
	padding: 14px 16px;
	background: #c0392b !important;
	color: #fff !important;
	text-align: center;
	text-decoration: none !important;
	border-radius: 6px;
	font-weight: 700;
	font-size: 14px;
	transition: background 0.2s;
}

.ecu-service-pay-btn:hover {
	background: #962d22 !important;
	color: #fff !important;
}

.ecu-service-section-title {
	margin: 20px 0 12px;
}

.ecu-service-section-title h2 {
	font-size: 16px;
	font-weight: 700;
	margin: 0;
	color: var(--ecu-text);
}

.ecu-service-section-title p {
	font-size: 13px;
	font-style: italic;
	color: var(--ecu-text-muted);
	margin: 4px 0 0;
}

.ecu-service-muted,
.ecu-service-atelier-link {
	font-size: 13px;
	color: var(--ecu-text-muted);
	margin-top: 24px;
}

.ecu-service-divider {
	border: 0;
	border-top: 1px solid var(--ecu-border);
	margin: 28px 0;
}

.ecu-paid-notice {
	padding: 14px 16px;
	background: #0d3320;
	border: 2px solid #22c55e;
	border-radius: 8px;
	margin-bottom: 20px;
	color: var(--ecu-text);
}

.ecu-paid-notice strong {
	color: #86efac;
}

.ecu-paid-notice p {
	margin: 8px 0 0;
	font-size: 14px;
}

.ecu-service-upload-box {
	background: var(--ecu-bg-card-alt);
	border: 1px solid var(--ecu-border);
	border-radius: 8px;
	padding: 28px 20px;
	text-align: center;
	margin-bottom: 24px;
}

.ecu-service-upload-box__icon {
	font-size: 42px;
	color: var(--ecu-accent-light);
	margin-bottom: 10px;
}

.ecu-service-upload-box__title {
	font-size: 15px;
	font-weight: 700;
	color: var(--ecu-text);
	margin: 0 0 8px;
}

.ecu-service-upload-box__formats {
	font-size: 12px;
	color: var(--ecu-text-muted);
	margin: 0;
}

/* Cartes produits = style Suite Pro (liste horizontale) */
.ecu-service-shell .ecu-shop-section,
.ecu-service-boutique .ecu-shop-section {
	display: block !important;
	width: 100% !important;
	margin-bottom: 28px;
}

.ecu-service-shell .ecu-shop-section .woocommerce,
.ecu-service-boutique .ecu-shop-section .woocommerce {
	width: 100% !important;
}

.ecu-service-shell ul.products,
.ecu-service-boutique ul.products,
.ecu-shop-section ul.products,
.ecu-token-packs-list ul.products,
.ecu-account-portal__shop ul.products {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.ecu-service-shell ul.products li.product,
.ecu-service-boutique ul.products li.product,
.ecu-shop-section ul.products li.product,
.ecu-token-packs-list ul.products li.product,
.ecu-account-portal__shop ul.products li.product {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	gap: 12px 16px !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 12px 16px !important;
	float: none !important;
	clear: none !important;
	background: var(--ecu-bg-card) !important;
	border: 1px solid var(--ecu-border) !important;
	border-radius: 8px !important;
	transition: border-color 0.2s, background 0.2s;
}

.ecu-service-shell ul.products li.product:hover,
.ecu-service-boutique ul.products li.product:hover,
.ecu-token-packs-list ul.products li.product:hover,
.ecu-account-portal__shop ul.products li.product:hover {
	border-color: var(--ecu-accent-light) !important;
	background: var(--ecu-bg-card-alt) !important;
}

.ecu-service-shell ul.products li.product .woocommerce-loop-product__link,
.ecu-service-boutique ul.products li.product .woocommerce-loop-product__link,
.ecu-token-packs-list ul.products li.product .woocommerce-loop-product__link,
.ecu-account-portal__shop ul.products li.product .woocommerce-loop-product__link {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	gap: 16px !important;
	flex: 1 1 200px !important;
	text-decoration: none !important;
}

.ecu-service-shell ul.products li.product a img,
.ecu-service-boutique ul.products li.product a img,
.ecu-token-packs-list ul.products li.product a img,
.ecu-account-portal__shop ul.products li.product a img {
	width: 56px !important;
	height: 56px !important;
	object-fit: contain !important;
	border-radius: 6px;
	flex-shrink: 0;
}

.ecu-service-shell ul.products li.product .woocommerce-loop-product__title,
.ecu-service-boutique ul.products li.product .woocommerce-loop-product__title,
.ecu-token-packs-list ul.products li.product .woocommerce-loop-product__title,
.ecu-account-portal__shop ul.products li.product .woocommerce-loop-product__title {
	font-size: 14px !important;
	font-weight: 700 !important;
	margin: 0 0 4px !important;
	padding: 0 !important;
}

.ecu-service-shell ul.products li.product .price,
.ecu-service-boutique ul.products li.product .price,
.ecu-token-packs-list ul.products li.product .price,
.ecu-account-portal__shop ul.products li.product .price {
	font-size: 13px !important;
	margin: 0 !important;
}

.ecu-service-shell ul.products li.product .button,
.ecu-service-boutique ul.products li.product .button,
.ecu-token-packs-list ul.products li.product .button,
.ecu-account-portal__shop ul.products li.product .button,
.ecu-token-pack-card__buy,
.ecu-token-pack-card__express {
	margin-left: 0 !important;
	flex-shrink: 0;
	padding: 10px 14px !important;
	font-size: 12px !important;
}

.ecu-token-pack-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-left: auto;
	align-items: center;
}

.ecu-token-pack-card__img {
	width: 120px !important;
	height: 120px !important;
	object-fit: cover;
	border-radius: 10px;
	border: 1px solid var(--ecu-border);
	flex-shrink: 0;
}

.ecu-express-checkout-box {
	padding: 16px 18px;
	margin: 0 0 16px;
	background: rgba(31, 111, 235, 0.08);
	border: 1px solid var(--ecu-accent);
	border-radius: 10px;
}

.ecu-express-checkout-box__title {
	margin: 0 0 6px;
	color: var(--ecu-text);
}

.ecu-express-checkout-box__hint {
	margin: 0;
	font-size: 13px;
	color: var(--ecu-text-muted);
}

@media (max-width: 921px) {
	.ecu-service-layout {
		grid-template-columns: 1fr;
	}

	.ecu-service-sidebar {
		position: static;
		order: -1;
	}
}

@media (max-width: 544px) {
	.ecu-service-shell ul.products li.product .woocommerce-loop-product__link {
		flex: 1 1 100% !important;
	}

	.ecu-service-shell ul.products li.product .button,
	.ecu-service-boutique ul.products li.product .button {
		margin-left: 0 !important;
		width: 100%;
		text-align: center;
	}
}

/* CF7 — style formulaire Suite Pro (page envoi) */
.ecu-service-upload .wpcf7 form {
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 8px;
	padding: 20px;
}

.ecu-service-upload .wpcf7 label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 14px;
}

.ecu-service-upload .wpcf7 input[type="text"],
.ecu-service-upload .wpcf7 input[type="email"],
.ecu-service-upload .wpcf7 input[type="tel"],
.ecu-service-upload .wpcf7 input[type="file"],
.ecu-service-upload .wpcf7 select,
.ecu-service-upload .wpcf7 textarea {
	width: 100%;
	margin-top: 6px;
}

.ecu-service-upload .wpcf7 input[type="submit"] {
	width: 100%;
	padding: 14px !important;
	font-size: 15px !important;
	margin-top: 8px;
}

.ecu-service-upload .wpcf7-response-output {
	margin: 16px 0 0 !important;
	border-radius: 6px;
}

/* ==========================================================================
   Page d'accueil — banniere hero
   ========================================================================== */
.ecu-home {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 0 48px;
}

.ecu-home-banner {
	position: relative;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-bottom: 36px;
	overflow: hidden;
	background: #000;
}

.ecu-home-banner__img {
	display: block;
	width: 100%;
	height: auto;
	max-height: min(520px, 55vh);
	object-fit: cover;
	object-position: center 30%;
}

.ecu-home-banner__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 28px 32px;
	background: linear-gradient(0deg, rgba(7, 11, 18, 0.92) 0%, rgba(7, 11, 18, 0.35) 45%, transparent 100%);
}

.ecu-home-banner__title {
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(28px, 5vw, 46px);
	font-weight: 700;
	color: #fff;
	margin: 0 0 8px;
	line-height: 1.1;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.85);
	letter-spacing: 0.01em;
}

.ecu-home-banner__title em {
	color: var(--ecu-accent-light);
	font-style: normal;
}

.ecu-home-banner__tagline {
	color: var(--ecu-text);
	font-size: 15px;
	font-weight: 600;
	margin: 0 0 16px;
	max-width: 560px;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8);
}

.ecu-home-banner__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

@media (max-width: 921px) {
	.ecu-home-banner__overlay {
		padding: 20px 16px;
	}

	.ecu-home-banner__title {
		font-size: 24px;
	}

	.ecu-home-banner__tagline {
		font-size: 13px;
	}
}

/* Page d'accueil — cartes */
.ecu-btn {
	display: inline-block;
	padding: 13px 24px;
	border-radius: 8px;
	font-weight: 700;
	font-size: 14px;
	text-decoration: none !important;
	transition: background 0.2s, transform 0.15s;
}

.ecu-btn--primary {
	background: var(--ecu-accent) !important;
	color: #fff !important;
	border: 1px solid var(--ecu-accent);
}

.ecu-btn--primary:hover {
	background: var(--ecu-accent-hover) !important;
	color: #fff !important;
}

.ecu-btn--ghost {
	background: transparent !important;
	color: var(--ecu-text) !important;
	border: 1px solid var(--ecu-border);
}

.ecu-btn--ghost:hover {
	border-color: var(--ecu-accent-light);
	color: var(--ecu-accent-light) !important;
}

.ecu-home-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin-bottom: 40px;
}

.ecu-home-grid--4 {
	grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1100px) {
	.ecu-home-grid,
	.ecu-home-grid--4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

.ecu-home-card {
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 10px;
	padding: 24px 22px;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.ecu-home-card:hover {
	border-color: rgba(102, 163, 255, 0.4);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}

.ecu-home-card__icon {
	font-size: 28px;
	display: block;
	margin-bottom: 12px;
}

.ecu-home-card h2 {
	font-size: 18px !important;
	font-weight: 700;
	margin: 0 0 10px !important;
	color: var(--ecu-text) !important;
}

.ecu-home-card p {
	font-size: 14px;
	color: var(--ecu-text-muted);
	margin: 0 0 16px;
	line-height: 1.6;
}

.ecu-home-card__link {
	font-size: 13px;
	font-weight: 700;
	color: var(--ecu-accent-light) !important;
	text-decoration: none !important;
}

/* Bloc SEO accueil */
.ecu-home-seo {
	max-width: 1100px;
	margin: 32px auto 24px;
	line-height: 1.7;
}

.ecu-home-seo__title {
	font-size: clamp(20px, 2.6vw, 26px);
	font-weight: 800;
	color: var(--ecu-text);
	line-height: 1.3;
	margin: 0 0 20px;
	text-align: center;
}

.ecu-home-seo__header {
	text-align: center;
	padding: 40px 32px 36px;
	background: linear-gradient(165deg, rgba(31, 111, 235, 0.14) 0%, var(--ecu-bg-card) 55%, #0a1018 100%);
	border: 1px solid var(--ecu-border);
	border-radius: 16px;
	margin-bottom: 20px;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
}

.ecu-home-seo__badge {
	display: inline-block;
	margin-bottom: 16px;
	padding: 8px 16px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ecu-accent-light);
	background: rgba(31, 111, 235, 0.12);
	border: 1px solid rgba(102, 163, 255, 0.3);
	border-radius: 999px;
}

.ecu-home-seo h1 {
	font-size: clamp(24px, 3.2vw, 34px);
	font-weight: 800;
	color: var(--ecu-text);
	line-height: 1.2;
	margin: 0 0 18px;
	max-width: 820px;
	margin-left: auto;
	margin-right: auto;
}

.ecu-home-seo__lead {
	font-size: clamp(15px, 1.7vw, 17px);
	color: var(--ecu-text-muted);
	max-width: 760px;
	margin: 0 auto 24px;
	line-height: 1.75;
}

.ecu-home-seo__lead strong {
	color: var(--ecu-text);
}

.ecu-home-seo__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
}

.ecu-home-seo__stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	margin-bottom: 20px;
}

.ecu-home-seo__stat {
	text-align: center;
	padding: 18px 12px;
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 12px;
}

.ecu-home-seo__stat strong {
	display: block;
	font-size: clamp(18px, 2vw, 22px);
	color: var(--ecu-accent-light);
	margin-bottom: 4px;
}

.ecu-home-seo__stat span {
	font-size: 12px;
	color: var(--ecu-text-muted);
}

.ecu-home-seo__cards {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-bottom: 20px;
}

.ecu-home-seo__card {
	padding: 22px 18px;
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 14px;
	transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}

.ecu-home-seo__card:hover {
	border-color: rgba(102, 163, 255, 0.45);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(31, 111, 235, 0.12);
}

.ecu-home-seo__card-icon {
	font-size: 28px;
	display: block;
	margin-bottom: 10px;
}

.ecu-home-seo__card h2 {
	font-size: 15px;
	font-weight: 700;
	color: var(--ecu-text);
	margin: 0 0 10px;
	line-height: 1.3;
}

.ecu-home-seo__card p {
	font-size: 13px;
	color: var(--ecu-text-muted);
	margin: 0 0 14px;
	line-height: 1.55;
}

.ecu-home-seo__card a {
	font-size: 13px;
	font-weight: 700;
	color: var(--ecu-accent-light);
	text-decoration: none;
}

.ecu-home-seo__card a:hover {
	color: var(--ecu-accent);
	text-decoration: underline;
}

.ecu-home-seo__block {
	padding: 28px 32px;
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 14px;
	margin-bottom: 16px;
}

.ecu-home-seo__block--alt {
	background: linear-gradient(135deg, rgba(15, 23, 36, 0.95) 0%, rgba(31, 111, 235, 0.06) 100%);
	border-color: rgba(102, 163, 255, 0.2);
}

.ecu-home-seo__block--particulier {
	border-color: rgba(255, 209, 102, 0.35);
	background: linear-gradient(135deg, rgba(15, 23, 36, 0.98) 0%, rgba(255, 209, 102, 0.05) 100%);
}

.ecu-home-seo__block--pro {
	border-color: rgba(102, 163, 255, 0.35);
}

.ecu-home-seo__audience {
	display: inline-block;
	margin-bottom: 12px;
	padding: 6px 14px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: #ffd166;
	background: rgba(255, 209, 102, 0.12);
	border: 1px solid rgba(255, 209, 102, 0.35);
	border-radius: 999px;
}

.ecu-home-seo__audience--pro {
	color: var(--ecu-accent-light);
	background: rgba(31, 111, 235, 0.12);
	border-color: rgba(102, 163, 255, 0.35);
}

.ecu-home-seo__note {
	margin-top: 14px !important;
	margin-bottom: 0 !important;
	padding: 12px 14px;
	font-size: 14px !important;
	background: rgba(255, 209, 102, 0.06);
	border-left: 3px solid #ffd166;
	border-radius: 0 8px 8px 0;
}

.ecu-home-seo__block h2 {
	font-size: clamp(18px, 2.2vw, 22px);
	font-weight: 700;
	color: var(--ecu-accent-light);
	margin: 0 0 14px;
}

.ecu-home-seo__block p {
	font-size: 15px;
	color: var(--ecu-text-muted);
	margin: 0 0 12px;
	line-height: 1.75;
}

.ecu-home-seo__block p strong {
	color: var(--ecu-text);
}

.ecu-home-seo__prices {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 16px;
}

.ecu-home-seo__price {
	display: inline-block;
	padding: 10px 16px;
	font-size: 13px;
	font-weight: 700;
	color: var(--ecu-text);
	background: rgba(31, 111, 235, 0.1);
	border: 1px solid rgba(102, 163, 255, 0.25);
	border-radius: 8px;
}

.ecu-home-seo__price--hot {
	color: #ffd166;
	background: rgba(255, 209, 102, 0.1);
	border-color: rgba(255, 209, 102, 0.35);
}

.ecu-home-seo__links,
.ecu-home-seo__footer {
	margin-top: 16px !important;
	margin-bottom: 0 !important;
	font-size: 14px !important;
}

.ecu-home-seo__links a,
.ecu-home-seo__footer a {
	color: var(--ecu-accent-light);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.ecu-home-seo__checks {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ecu-home-seo__checks li {
	position: relative;
	padding: 10px 0 10px 28px;
	font-size: 15px;
	color: var(--ecu-text-muted);
	border-bottom: 1px solid rgba(38, 54, 77, 0.5);
}

.ecu-home-seo__checks li:last-child {
	border-bottom: 0;
}

.ecu-home-seo__checks li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: var(--ecu-accent-light);
	font-weight: 800;
}

.ecu-home-seo__checks strong {
	color: var(--ecu-text);
}

@media (max-width: 1024px) {
	.ecu-home-seo__cards {
		grid-template-columns: repeat(2, 1fr);
	}

	.ecu-home-seo__stats {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 640px) {
	.ecu-home-seo__header {
		padding: 28px 18px;
	}

	.ecu-home-seo__block {
		padding: 22px 18px;
	}

	.ecu-home-seo__cards,
	.ecu-home-seo__stats {
		grid-template-columns: 1fr;
	}
}

.ecu-home-stats {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 48px;
	padding: 36px 24px;
	border-top: 1px solid var(--ecu-border);
	text-align: center;
}

.ecu-home-stats strong {
	display: block;
	font-size: 36px;
	font-weight: 700;
	color: var(--ecu-accent-light);
	line-height: 1.1;
}

.ecu-home-stats span {
	font-size: 13px;
	color: var(--ecu-text-muted);
}

@media (max-width: 921px) {
	.ecu-home-grid {
		grid-template-columns: 1fr;
	}

	.ecu-home-hero {
		padding: 32px 20px;
	}
}

/* Prise de RDV diagnostic */
.ecu-diag-booking {
	margin: 28px 0 0;
	padding: 28px;
	background: #151f2e;
	border: 1px solid var(--ecu-border);
	border-radius: 12px;
}

.ecu-diag-booking__errors {
	margin: 0 0 20px;
	padding: 14px 18px;
	background: rgba(220, 53, 69, 0.12);
	border: 1px solid rgba(220, 53, 69, 0.45);
	border-radius: 8px;
	color: #ffb4bc;
	font-size: 14px;
}

.ecu-diag-booking__errors p {
	margin: 0 0 6px;
}

.ecu-diag-booking__errors p:last-child {
	margin-bottom: 0;
}

.ecu-diag-booking__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px 20px;
}

.ecu-diag-booking__field label {
	display: block;
	margin-bottom: 8px;
	font-size: 14px;
	font-weight: 600;
	color: var(--ecu-text);
}

.ecu-diag-booking__field label span {
	color: var(--ecu-accent-light);
}

.ecu-diag-booking__field input,
.ecu-diag-booking__field select,
.ecu-diag-booking__field textarea {
	width: 100%;
	padding: 12px 14px;
	background: #0d1117;
	border: 1px solid var(--ecu-border);
	border-radius: 8px;
	color: var(--ecu-text);
	font-size: 15px;
	font-family: inherit;
}

.ecu-diag-booking__field input:focus,
.ecu-diag-booking__field select:focus,
.ecu-diag-booking__field textarea:focus {
	outline: none;
	border-color: var(--ecu-accent);
	box-shadow: 0 0 0 2px rgba(31, 111, 235, 0.25);
}

.ecu-diag-booking__field small {
	display: block;
	margin-top: 6px;
	font-size: 12px;
	color: var(--ecu-text-muted);
}

.ecu-diag-booking__field--full {
	grid-column: 1 / -1;
}

.ecu-diag-booking__pricing {
	margin-top: 24px;
	padding: 20px;
	background: rgba(31, 111, 235, 0.08);
	border: 1px solid rgba(31, 111, 235, 0.35);
	border-radius: 10px;
}

.ecu-diag-booking__pricing-title {
	margin: 0 0 12px;
	font-weight: 700;
	color: var(--ecu-accent-light);
}

.ecu-diag-booking__pricing ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ecu-diag-booking__pricing li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px 0;
	border-bottom: 1px solid rgba(38, 54, 77, 0.5);
	color: var(--ecu-text-muted);
	font-size: 14px;
}

.ecu-diag-booking__pricing li strong {
	color: var(--ecu-text);
}

.ecu-diag-booking__total {
	margin: 14px 0 0;
	font-size: 16px;
	color: var(--ecu-text);
}

.ecu-diag-booking__total strong {
	color: var(--ecu-accent-light);
	font-size: 20px;
}

.ecu-diag-booking__pricing-note {
	margin: 10px 0 0;
	font-size: 12px;
	color: var(--ecu-text-muted);
}

.ecu-diag-booking__submit {
	display: inline-block;
	margin-top: 22px;
	padding: 14px 28px;
	background: var(--ecu-accent);
	color: #fff;
	border: 0;
	border-radius: 8px;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.2s ease;
}

.ecu-diag-booking__submit:hover {
	background: #388bfd;
}

.ecu-diag-thankyou {
	margin: 20px 0;
	padding: 18px 22px;
	background: rgba(46, 160, 67, 0.12);
	border: 1px solid rgba(46, 160, 67, 0.45);
	border-radius: 8px;
	color: var(--ecu-text);
}

@media (max-width: 640px) {
	.ecu-diag-booking {
		padding: 20px 16px;
	}

	.ecu-diag-booking__grid {
		grid-template-columns: 1fr;
	}
}

/* Presentation globale */
.site-content .ast-container {
	max-width: 1200px;
}

.entry-content {
	padding-top: 8px;
	padding-bottom: 32px;
}

/* ==========================================================================
   Widget horaires
   ========================================================================== */
.ecu-hours-widget {
	background: var(--ecu-bg-dark);
	border: 1px solid var(--ecu-border);
	border-radius: 10px;
	overflow: hidden;
	font-family: inherit;
}

/* Bouton flottant horaires (replie par defaut, panneau au clic) */
.ecu-hours-float__btn {
	position: fixed;
	right: 20px;
	bottom: 72px;
	z-index: 99986;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 1px solid var(--ecu-border);
	background: var(--ecu-bg-card);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	line-height: 1;
	padding: 0;
	transition: border-color 0.2s, transform 0.2s;
}

.ecu-hours-float__btn:hover {
	border-color: var(--ecu-accent-light);
	transform: scale(1.06);
}

.ecu-hours-float__dot {
	position: absolute;
	top: 2px;
	right: 2px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: #e5534b;
	border: 2px solid var(--ecu-bg-dark);
}

.ecu-hours-float[data-any-open="1"] .ecu-hours-float__dot {
	background: #2ea043;
}

.ecu-hours-float .ecu-hours-widget--floating {
	display: none;
	position: fixed;
	right: 20px;
	bottom: 128px;
	z-index: 99985;
	width: min(300px, calc(100vw - 24px));
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.5);
}

.ecu-hours-float.is-open .ecu-hours-widget--floating {
	display: block;
}

.ecu-hours-widget--inline {
	position: static;
	width: 100%;
	box-shadow: none;
}

.ecu-hours-widget--compact .ecu-hours-widget__head {
	padding: 8px 10px;
}

.ecu-hours-widget--compact .ecu-hours-widget__head-text strong {
	font-size: 13px;
}

.ecu-hours-widget--compact .ecu-hours-widget__head-text span {
	font-size: 10px;
}

.ecu-hours-widget--compact .ecu-hours-box {
	padding: 8px;
}

.ecu-hours-widget--compact .ecu-hours-box__service {
	font-size: 10px;
	margin-bottom: 6px;
}

.ecu-hours-widget--compact .ecu-hours-box__schedule-card {
	padding: 8px 6px;
	margin-bottom: 8px;
}

.ecu-hours-widget--compact .ecu-hours-box__days {
	font-size: 12px;
	margin-bottom: 2px;
}

.ecu-hours-widget--compact .ecu-hours-box__hours {
	font-size: 16px;
}

.ecu-hours-widget--compact .ecu-hours-box__badge {
	padding: 4px 8px;
	font-size: 11px;
}

.ecu-hours-widget--compact .ecu-hours-widget__body {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
}

.ecu-hours-widget__head {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	background: var(--ecu-bg-card);
	border-bottom: 1px solid var(--ecu-border);
}

.ecu-hours-widget__head-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	flex-shrink: 0;
}

.ecu-hours-widget__head-dot--open {
	background: #3ecf6e;
	box-shadow: 0 0 8px rgba(62, 207, 110, 0.8);
}

.ecu-hours-widget__head-dot--closed {
	background: #e04545;
	box-shadow: 0 0 8px rgba(224, 69, 69, 0.7);
}

.ecu-hours-widget__head-text {
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.ecu-hours-widget__head-text strong {
	font-size: 14px;
	color: var(--ecu-text);
	line-height: 1.2;
}

.ecu-hours-widget__head-text span {
	font-size: 11px;
	color: var(--ecu-text-muted);
	font-weight: 600;
}

.ecu-hours-box {
	padding: 12px;
	color: #fff;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.ecu-hours-box:last-child {
	border-right: none;
}

.ecu-hours-box--open {
	background: linear-gradient(135deg, #145028 0%, #1d6b38 100%);
}

.ecu-hours-box--closed {
	background: linear-gradient(135deg, #6b1528 0%, #8b1e32 100%);
}

.ecu-hours-box__service {
	margin: 0 0 8px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ecu-hours-box__schedule-card {
	background: rgba(255, 255, 255, 0.97);
	color: #0a1018;
	border-radius: 8px;
	padding: 10px 8px;
	margin-bottom: 8px;
	text-align: center;
}

.ecu-hours-box__days {
	margin: 0 0 2px;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	color: #0a1018;
}

.ecu-hours-box__hours {
	margin: 0;
	font-size: 20px;
	font-weight: 800;
	line-height: 1.1;
	color: #1f6feb;
}

.ecu-hours-box__status {
	margin: 0;
}

.ecu-hours-box__badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 5px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
}

.ecu-hours-box__badge--open {
	background: rgba(255, 255, 255, 0.2);
	border: 1px solid rgba(255, 255, 255, 0.35);
}

.ecu-hours-box__badge--closed {
	background: rgba(0, 0, 0, 0.25);
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.ecu-hours-box__dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #5dff8a;
	box-shadow: 0 0 8px rgba(93, 255, 138, 0.9);
	flex-shrink: 0;
}

.ecu-hours-box__clock {
	font-variant-numeric: tabular-nums;
	font-weight: 800;
	font-size: 11px;
}

/* Onglet panier */
.ecu-cart-tab {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 99990;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--ecu-accent);
	color: #fff !important;
	text-decoration: none !important;
	font-size: 14px;
	font-weight: 700;
	padding: 12px 18px;
	border-radius: 999px;
	box-shadow: 0 8px 28px rgba(31, 111, 235, 0.45);
	transition: background 0.2s, transform 0.2s;
}

.ecu-cart-tab:hover {
	background: var(--ecu-accent-hover);
	color: #fff !important;
	transform: translateY(-2px);
}

.ecu-cart-tab__icon {
	font-size: 18px;
	line-height: 1;
}

.ecu-cart-tab__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 6px;
	border-radius: 999px;
	background: #fff;
	color: var(--ecu-accent);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.ecu-menu-item-cart > a {
	background: rgba(31, 111, 235, 0.2) !important;
	border: 1px solid rgba(102, 163, 255, 0.35);
}

@media (max-width: 480px) {
	.ecu-hours-float__btn {
		right: 10px;
		bottom: 64px;
		width: 44px;
		height: 44px;
		font-size: 20px;
	}

	.ecu-hours-float .ecu-hours-widget--floating {
		right: 10px;
		bottom: 116px;
		width: calc(100vw - 20px);
	}

	.ecu-cart-tab {
		right: 10px;
		bottom: 10px;
		padding: 10px 14px;
		font-size: 13px;
	}
}

/* Tokens ECU */
.ecu-token-price {
	margin-top: 6px;
	font-size: 14px;
	color: var(--ecu-accent-light);
}

.ecu-token-price__discount {
	font-size: 12px;
	color: var(--ecu-text-muted);
	font-weight: 600;
}

.ecu-token-balance {
	background: rgba(31, 111, 235, 0.12);
	border: 1px solid rgba(102, 163, 255, 0.35);
	border-radius: 8px;
	padding: 12px 14px;
	margin-bottom: 14px;
	font-size: 13px;
}

.ecu-token-balance p {
	margin: 0 0 6px;
}

.ecu-token-balance__tier {
	color: var(--ecu-accent-light);
	font-size: 12px;
}

.ecu-token-notice {
	padding: 14px 16px;
	margin: 0 0 20px;
	background: #151f2e;
	border: 1px solid #1f6feb;
	border-radius: 8px;
	color: #eef4ff;
	font-size: 14px;
}

.ecu-token-notice__tier {
	color: #66a3ff;
	font-size: 13px;
}

.ecu-token-notice__warn {
	color: #ffb4b4;
}

.ecu-token-packs {
	background: rgba(31, 111, 235, 0.08);
	border: 1px solid var(--ecu-border);
	border-radius: 10px;
	padding: 16px 18px;
	margin-bottom: 24px;
}

.ecu-token-packs__offers {
	color: var(--ecu-accent-light) !important;
	font-size: 13px;
}

.ecu-token-packs__delay {
	color: var(--ecu-text-muted) !important;
	font-size: 12px;
	margin-top: 8px;
}

.ecu-token-price__hint {
	font-size: 11px;
	color: var(--ecu-text-muted);
	font-weight: 600;
}

.ecu-token-packs__empty {
	color: var(--ecu-text-muted);
	font-size: 14px;
}

.ecu-token-pack-card__meta {
	display: block;
	font-size: 12px;
	color: var(--ecu-accent-light);
	margin-top: 4px;
}

.ecu-account-portal__pay-note {
	font-size: 13px;
	color: var(--ecu-text-muted);
	margin-bottom: 16px;
}

.ecu-cf7-missing {
	color: #ffb4b4;
	padding: 16px;
	border: 1px solid #ff6b6b;
	border-radius: 8px;
}

.ecu-checkout-version {
	margin: 0 0 12px;
	font-size: 11px;
	color: #4a6078;
	opacity: 0.85;
}

.ecu-token-notice--login {
	border-color: #1f6feb;
	background: rgba(31, 111, 235, 0.1);
}

.ecu-token-notice--login p {
	margin: 8px 0 0;
	font-size: 14px;
}

.ecu-token-notice__link {
	color: #66a3ff;
	font-weight: 600;
	text-decoration: underline;
}

#payment .payment_method_ecu_tokens {
	border: 1px solid #1f6feb !important;
	border-radius: 8px;
	background: rgba(31, 111, 235, 0.08) !important;
}

#payment .payment_method_ecu_tokens label {
	font-weight: 700;
	color: #66a3ff !important;
}

.ecu-token-blocks-balance {
	font-size: 13px;
	color: #66a3ff;
	margin: 8px 0 0;
}

.ecu-token-blocks-warn {
	font-size: 13px;
	color: #ffb4b4;
	margin: 6px 0 0;
}

.ecu-stripe-notice,
.ecu-token-purchase-notice {
	padding: 14px 16px;
	margin: 0 0 20px;
	background: rgba(31, 111, 235, 0.12);
	border: 1px solid var(--ecu-accent);
	border-radius: 8px;
	color: var(--ecu-text);
	font-size: 14px;
}
	padding: 14px 16px;
	margin: 0 0 20px;
	background: rgba(31, 111, 235, 0.12);
	border: 1px solid var(--ecu-accent);
	border-radius: 8px;
	color: var(--ecu-text);
	font-size: 14px;
}

.ecu-token-packs ul.products li.product img {
	width: 120px !important;
	height: 120px !important;
	object-fit: cover;
	border-radius: 10px;
	border: 1px solid var(--ecu-border);
}

.ecu-token-packs ul.products li.product .woocommerce-loop-product__link {
	align-items: center;
}

.ecu-token-account__tier {
	color: var(--ecu-accent-light);
}

body:not(.ecu-service-boutique):not(.ecu-service-upload) .entry-content > .ecu-home,
body:not(.ecu-service-boutique):not(.ecu-service-upload) .entry-content > .ecu-service-shell {
	margin-top: 8px;
}

/* Portail compte + tokens */
.ecu-account-portal {
	max-width: 960px;
	margin: 0 auto;
}

.ecu-account-portal__guest,
.ecu-account-portal__member {
	background: var(--ecu-bg-card);
	border: 1px solid var(--ecu-border);
	border-radius: 12px;
	padding: 28px 32px;
}

.ecu-account-portal__benefits {
	margin: 16px 0 24px;
	padding-left: 20px;
	color: var(--ecu-text-muted);
}

.ecu-account-portal__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 16px;
}

.ecu-account-portal__hint {
	font-size: 13px;
	color: var(--ecu-text-muted);
	margin: 0;
}

.ecu-account-portal__welcome {
	margin-bottom: 28px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--ecu-border);
}

.ecu-account-portal__balance {
	font-size: 22px;
	margin: 12px 0;
}

.ecu-account-portal__tier {
	color: var(--ecu-accent-light);
	font-size: 14px;
}

.ecu-account-portal__rules {
	color: var(--ecu-text-muted);
	font-size: 13px;
	line-height: 1.5;
}

.ecu-account-portal__shop h3 {
	margin-bottom: 8px;
}

.ecu-account-portal__delay {
	font-size: 13px;
	color: var(--ecu-text-muted);
	margin-bottom: 16px;
}

.ecu-account-portal__links {
	margin-top: 24px;
	font-size: 13px;
	color: var(--ecu-text-muted);
}

.ecu-account-portal__links a {
	color: var(--ecu-accent-light);
}

.ecu-account-portal__forms {
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid var(--ecu-border);
}

.ecu-account-portal__forms h3 {
	margin-bottom: 16px;
}

.ecu-account-portal__forms .woocommerce-form-login,
.ecu-account-portal__forms .woocommerce-form-register {
	background: #0f1724;
	border: 1px solid var(--ecu-border);
	border-radius: 10px;
	padding: 20px;
	margin-bottom: 16px;
}

.ecu-account-portal__forms label {
	color: var(--ecu-text);
}

.ecu-account-portal__forms input[type="text"],
.ecu-account-portal__forms input[type="email"],
.ecu-account-portal__forms input[type="password"] {
	background: #070b12;
	border: 1px solid var(--ecu-border);
	color: var(--ecu-text);
	border-radius: 6px;
	padding: 10px 12px;
	width: 100%;
}

.ecu-account-portal__forms .woocommerce-button,
.ecu-account-portal__forms button[type="submit"] {
	background: var(--ecu-accent) !important;
	color: #fff !important;
	border: none !important;
	border-radius: 6px !important;
	padding: 10px 18px !important;
	font-weight: 700 !important;
}

/* ==========================================================================
   Bannieres pro en haut des pages (titre en surimpression)
   ========================================================================== */
.ecu-page-banner {
	position: relative;
	margin: 0 0 28px;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid var(--ecu-border);
	box-shadow: 0 16px 36px rgba(0, 0, 0, 0.4);
	line-height: 0;
}

.ecu-page-banner img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 21 / 9;
	object-fit: cover;
}

.ecu-page-banner__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 24px 28px;
	margin: 0;
	background: linear-gradient(0deg, rgba(7, 11, 18, 0.9) 0%, rgba(7, 11, 18, 0.3) 50%, transparent 100%);
	line-height: 1.2;
}

.ecu-page-banner__title {
	font-family: Georgia, "Times New Roman", serif !important;
	font-size: clamp(24px, 4vw, 38px) !important;
	font-weight: 700 !important;
	color: #fff !important;
	margin: 0 !important;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.85);
	letter-spacing: 0.01em;
}

/* Masque le titre duplique dans le contenu (le titre est sur la banniere) */
.ecu-has-banner .entry-content > div > h1:first-child,
.ecu-has-banner .ecu-service-header h1,
.ecu-has-banner .entry-header,
.ecu-has-banner h1.entry-title,
.ecu-has-banner .page-title {
	display: none !important;
}

/* Boutique : banniere integree au shell, plus compacte */
.ecu-page-banner--boutique {
	grid-column: 1 / -1;
	width: 100%;
}

.ecu-page-banner--boutique img {
	aspect-ratio: 4 / 1;
}

@media (max-width: 544px) {
	.ecu-page-banner {
		border-radius: 8px;
		margin-bottom: 20px;
	}

	.ecu-page-banner img,
	.ecu-page-banner--boutique img {
		aspect-ratio: 16 / 9;
	}

	.ecu-page-banner__overlay {
		padding: 16px 18px;
	}
}

/* =========================================================
   Simulateur de gains
   ========================================================= */
.ecu-simulator {
	margin: 24px 0;
}

.ecu-simulator__form {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 22px;
}

.ecu-simulator__field label {
	display: block;
	color: #91a4bd;
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 6px;
}

.ecu-simulator__field select {
	width: 100%;
	background: #0a1220;
	color: #eef4ff;
	border: 1px solid #2b3c58;
	border-radius: 8px;
	padding: 10px 12px;
	font-size: 15px;
}

.ecu-simulator__field select:disabled {
	opacity: 0.45;
}

.ecu-simulator__result {
	margin-top: 22px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 26px;
}

.ecu-simulator__result-title {
	color: #eef4ff;
	font-size: 20px;
	margin: 0 0 20px;
}

.ecu-simulator__bars {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

.ecu-simulator__metric-name {
	color: #91a4bd;
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 10px;
}

.ecu-simulator__bar-row {
	display: grid;
	grid-template-columns: 60px 1fr 70px;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}

.ecu-simulator__bar-label {
	color: #91a4bd;
	font-size: 13px;
}

.ecu-simulator__bar {
	background: #0a1220;
	border-radius: 6px;
	height: 14px;
	overflow: hidden;
}

.ecu-simulator__bar-fill {
	height: 100%;
	border-radius: 6px;
	width: 0;
	transition: width 0.6s ease;
}

.ecu-simulator__bar-fill--orig {
	background: #44546d;
}

.ecu-simulator__bar-fill--stage {
	background: linear-gradient(90deg, #1f6feb, #66a3ff);
}

.ecu-simulator__bar-value {
	color: #eef4ff;
	font-size: 14px;
	font-weight: 600;
	text-align: right;
}

.ecu-simulator__bar-value--stage {
	color: #66a3ff;
}

.ecu-simulator__gains {
	display: flex;
	gap: 12px;
	margin: 18px 0 0;
}

.ecu-simulator__gain {
	background: rgba(31, 111, 235, 0.16);
	color: #66a3ff;
	border: 1px solid rgba(102, 163, 255, 0.4);
	border-radius: 999px;
	padding: 6px 16px;
	font-weight: 700;
	font-size: 16px;
}

.ecu-simulator__pricing {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 22px;
}

.ecu-simulator__price-card {
	background: #0a1220;
	border: 1px solid #21304a;
	border-radius: 10px;
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ecu-simulator__price-card strong {
	color: #eef4ff;
}

.ecu-simulator__price-card span {
	color: #91a4bd;
	font-size: 14px;
}

.ecu-simulator__price-card span b {
	color: #66a3ff;
	font-size: 16px;
}

.ecu-simulator__price-card .ecu-btn {
	margin-top: 6px;
	align-self: flex-start;
}

.ecu-simulator__disclaimer {
	color: #5c7089;
	font-size: 12.5px;
	margin: 18px 0 0;
}

.ecu-simulator__missing {
	color: #91a4bd;
	font-size: 14px;
	margin-top: 16px;
}

.ecu-btn {
	display: inline-block;
	border-radius: 8px;
	padding: 9px 18px;
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	cursor: pointer;
	border: 1px solid transparent;
}

.ecu-btn--primary {
	background: #1f6feb;
	color: #ffffff !important;
}

.ecu-btn--primary:hover {
	background: #3b82f6;
	color: #ffffff !important;
}

.ecu-btn--ghost {
	background: transparent;
	border-color: #2b3c58;
	color: #66a3ff !important;
}

.ecu-btn--ghost:hover {
	border-color: #66a3ff;
}

@media (max-width: 768px) {
	.ecu-simulator__form,
	.ecu-simulator__bars,
	.ecu-simulator__pricing {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
   Suivi de commande
   ========================================================= */
.ecu-tracking {
	margin: 24px 0;
}

.ecu-tracking__form {
	display: grid;
	grid-template-columns: 1fr 1.4fr auto;
	gap: 14px;
	align-items: end;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 22px;
}

.ecu-tracking__field label {
	display: block;
	color: #91a4bd;
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 6px;
}

.ecu-tracking__field input {
	width: 100%;
	background: #0a1220;
	color: #eef4ff;
	border: 1px solid #2b3c58;
	border-radius: 8px;
	padding: 10px 12px;
	font-size: 15px;
}

.ecu-tracking__form .ecu-btn {
	white-space: nowrap;
}

.ecu-tracking__error {
	margin-top: 16px;
	background: rgba(220, 80, 80, 0.12);
	border: 1px solid rgba(220, 80, 80, 0.4);
	color: #ff9b9b;
	border-radius: 10px;
	padding: 12px 16px;
	font-size: 14px;
}

.ecu-tracking__result {
	margin-top: 22px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 26px;
}

.ecu-tracking__result h3 {
	color: #eef4ff;
	font-size: 19px;
	margin: 0 0 22px;
}

.ecu-tracking__timeline {
	display: flex;
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
	gap: 8px;
}

.ecu-tracking__step {
	flex: 1;
	text-align: center;
	padding: 14px 8px;
	background: #0a1220;
	border: 1px solid #21304a;
	border-radius: 10px;
	opacity: 0.45;
}

.ecu-tracking__step.is-done {
	opacity: 1;
	border-color: rgba(102, 163, 255, 0.5);
}

.ecu-tracking__step.is-current {
	background: rgba(31, 111, 235, 0.14);
	border-color: #1f6feb;
}

.ecu-tracking__step-icon {
	display: block;
	font-size: 22px;
	margin-bottom: 6px;
}

.ecu-tracking__step-label {
	color: #eef4ff;
	font-size: 13px;
	font-weight: 600;
}

.ecu-tracking__message {
	color: #eef4ff;
	font-size: 15px;
	margin: 0 0 14px;
}

.ecu-tracking__result--cancel .ecu-tracking__message {
	color: #ff9b9b;
}

.ecu-tracking__items {
	list-style: disc;
	color: #91a4bd;
	font-size: 14px;
	margin: 0;
	padding-left: 22px;
}

.ecu-tracking__help {
	color: #91a4bd;
	font-size: 14px;
	margin-top: 18px;
}

@media (max-width: 768px) {
	.ecu-tracking__form {
		grid-template-columns: 1fr;
	}

	.ecu-tracking__timeline {
		flex-direction: column;
	}

	.ecu-tracking__step {
		text-align: left;
		display: flex;
		align-items: center;
		gap: 12px;
	}

	.ecu-tracking__step-icon {
		margin-bottom: 0;
	}
}

/* =========================================================
   Garanties
   ========================================================= */
.ecu-guarantees {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin: 34px 0;
}

.ecu-guarantees__item {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.ecu-guarantees__icon {
	font-size: 24px;
}

.ecu-guarantees__title {
	color: #eef4ff;
	font-size: 15px;
}

.ecu-guarantees__text {
	color: #91a4bd;
	font-size: 13px;
	line-height: 1.5;
}

@media (max-width: 900px) {
	.ecu-guarantees {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 520px) {
	.ecu-guarantees {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
   Bandeau avis Google
   ========================================================= */
.ecu-greviews {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin: 18px 0 6px;
	padding: 12px 18px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 999px;
	text-decoration: none;
	transition: border-color 0.2s ease;
}

.ecu-greviews:hover {
	border-color: #66a3ff;
}

.ecu-greviews__stars {
	color: #f5b942;
	font-size: 16px;
	letter-spacing: 2px;
}

.ecu-greviews__text {
	color: #eef4ff;
	font-size: 14px;
}

.ecu-greviews__g {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #ffffff;
	color: #4285f4;
	font-weight: 800;
	font-size: 15px;
	font-family: Arial, sans-serif;
}

@media (max-width: 600px) {
	.ecu-greviews {
		flex-wrap: wrap;
		border-radius: 14px;
		text-align: center;
	}
}

/* =========================================================
   Avis Google — badge dans la banniere d'accueil
   ========================================================= */
.ecu-hero-greviews {
	position: absolute;
	top: 16%;
	right: 6%;
	z-index: 3;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 22px 30px;
	background: rgba(7, 11, 18, 0.72);
	border: 1px solid rgba(102, 163, 255, 0.35);
	border-radius: 16px;
	text-decoration: none !important;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.45);
	transition: transform 0.15s ease, border-color 0.15s ease;
}

.ecu-hero-greviews:hover {
	transform: scale(1.03);
	border-color: #66a3ff;
}

.ecu-hero-greviews__stars {
	color: #f5b942;
	font-size: 32px;
	line-height: 1;
	letter-spacing: 5px;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.6);
}

.ecu-hero-greviews__text {
	color: #eef4ff;
	font-size: 15px;
	font-weight: 600;
}

.ecu-hero-greviews__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: #66a3ff;
	font-size: 13.5px;
	text-decoration: underline;
}

.ecu-hero-greviews__g {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #ffffff;
	color: #4285f4;
	font-weight: 800;
	font-size: 14px;
	font-family: Arial, sans-serif;
}

@media (max-width: 900px) {
	.ecu-hero-greviews {
		top: 10px;
		right: 50%;
		transform: translateX(50%);
		flex-direction: row;
		gap: 10px;
		padding: 8px 14px;
		border-radius: 999px;
	}

	.ecu-hero-greviews:hover {
		transform: translateX(50%);
	}

	.ecu-hero-greviews__stars {
		font-size: 18px;
		letter-spacing: 2px;
	}

	.ecu-hero-greviews__text {
		display: none;
	}

	.ecu-hero-greviews__link {
		font-size: 12.5px;
	}
}

/* =========================================================
   Réalisations
   ========================================================= */
.ecu-realisations {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
	margin: 28px 0;
}

.ecu-realisation {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 22px;
}

.ecu-realisation__tag {
	display: inline-block;
	background: rgba(31, 111, 235, 0.16);
	color: #66a3ff;
	border: 1px solid rgba(102, 163, 255, 0.4);
	border-radius: 999px;
	padding: 3px 12px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 12px;
}

.ecu-realisation h3 {
	color: #eef4ff;
	font-size: 17px;
	margin: 0 0 8px;
}

.ecu-realisation__gain {
	color: #66a3ff;
	font-size: 15px;
	margin: 0 0 10px;
}

.ecu-realisation__gain strong {
	color: #66a3ff;
}

.ecu-realisation p:last-child {
	color: #91a4bd;
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
}

@media (max-width: 768px) {
	.ecu-realisations {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
   Bouton WhatsApp flottant
   ========================================================= */
.ecu-whatsapp-float {
	position: fixed;
	left: 18px;
	bottom: 18px;
	z-index: 9998;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: #25d366;
	color: #ffffff !important;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.4);
	transition: transform 0.15s ease;
}

.ecu-whatsapp-float:hover {
	transform: scale(1.08);
	color: #ffffff !important;
}

@media (max-width: 600px) {
	.ecu-whatsapp-float {
		width: 48px;
		height: 48px;
		left: 12px;
		bottom: 12px;
	}
}

/* =========================================================
   Assistant diagnostic IA
   ========================================================= */
.ecu-ai-diag__btn {
	position: fixed;
	left: 18px;
	bottom: 84px;
	z-index: 99987;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11px 16px;
	border-radius: 999px;
	border: 1px solid var(--ecu-border, #26364d);
	background: linear-gradient(135deg, #1f6feb, #1857c4);
	color: #ffffff;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
	transition: transform 0.15s ease;
}

.ecu-ai-diag__btn:hover {
	transform: scale(1.04);
}

.ecu-ai-diag__btn-icon {
	font-size: 17px;
}

.ecu-ai-diag__panel[hidden] {
	display: none !important;
}

.ecu-ai-diag__panel {
	position: fixed;
	left: 18px;
	bottom: 140px;
	z-index: 99995;
	width: 360px;
	max-width: calc(100vw - 36px);
	max-height: min(560px, calc(100vh - 170px));
	display: flex;
	flex-direction: column;
	background: #0f1724;
	border: 1px solid #26364d;
	border-radius: 14px;
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.6);
	overflow: hidden;
}

.ecu-ai-diag__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 16px;
	background: #101b2d;
	border-bottom: 1px solid #21304a;
}

.ecu-ai-diag__header strong {
	display: block;
	color: #eef4ff;
	font-size: 15px;
}

.ecu-ai-diag__sub {
	color: #66a3ff;
	font-size: 12px;
}

.ecu-ai-diag__close {
	background: transparent;
	border: none;
	color: #91a4bd;
	font-size: 16px;
	cursor: pointer;
	padding: 4px 8px;
}

.ecu-ai-diag__close:hover {
	color: #eef4ff;
}

.ecu-ai-diag__messages {
	flex: 1;
	overflow-y: auto;
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-height: 180px;
}

.ecu-ai-diag__msg {
	max-width: 85%;
	padding: 10px 14px;
	border-radius: 12px;
	font-size: 14px;
	line-height: 1.55;
	white-space: pre-wrap;
	word-wrap: break-word;
}

.ecu-ai-diag__msg--bot {
	align-self: flex-start;
	background: #16243a;
	border: 1px solid #21304a;
	color: #eef4ff;
	border-bottom-left-radius: 4px;
}

.ecu-ai-diag__msg--user {
	align-self: flex-end;
	background: #1f6feb;
	color: #ffffff;
	border-bottom-right-radius: 4px;
}

.ecu-ai-diag__msg--typing {
	display: inline-flex;
	gap: 5px;
	align-items: center;
	padding: 14px 16px;
}

.ecu-ai-diag__msg--typing span {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #66a3ff;
	animation: ecu-ai-bounce 1.2s infinite;
}

.ecu-ai-diag__msg--typing span:nth-child(2) {
	animation-delay: 0.15s;
}

.ecu-ai-diag__msg--typing span:nth-child(3) {
	animation-delay: 0.3s;
}

@keyframes ecu-ai-bounce {
	0%, 60%, 100% { transform: translateY(0); opacity: 0.5; }
	30% { transform: translateY(-5px); opacity: 1; }
}

.ecu-ai-diag__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.ecu-ai-diag__chip {
	background: transparent;
	border: 1px solid #2b3c58;
	color: #66a3ff;
	border-radius: 999px;
	padding: 6px 13px;
	font-size: 13px;
	cursor: pointer;
	transition: border-color 0.15s ease;
}

.ecu-ai-diag__chip:hover {
	border-color: #66a3ff;
}

.ecu-ai-diag__form {
	display: flex;
	gap: 8px;
	padding: 12px 14px;
	border-top: 1px solid #21304a;
	background: #101b2d;
}

.ecu-ai-diag__form input {
	flex: 1;
	background: #0a1220;
	color: #eef4ff;
	border: 1px solid #2b3c58;
	border-radius: 999px;
	padding: 10px 16px;
	font-size: 14px;
}

.ecu-ai-diag__form input:focus {
	outline: none;
	border-color: #1f6feb;
}

.ecu-ai-diag__form button {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: none;
	background: #1f6feb;
	color: #ffffff;
	font-size: 16px;
	cursor: pointer;
	flex-shrink: 0;
}

.ecu-ai-diag__form button:hover {
	background: #3b82f6;
}

.ecu-ai-diag__disclaimer {
	margin: 0;
	padding: 8px 14px 12px;
	background: #101b2d;
	color: #5c7089;
	font-size: 11.5px;
	line-height: 1.4;
}

.ecu-ai-diag__disclaimer a {
	color: #66a3ff;
}

@media (max-width: 600px) {
	.ecu-ai-diag__btn {
		left: 12px;
		bottom: 72px;
		padding: 10px 14px;
		font-size: 13px;
	}

	.ecu-ai-diag__btn-label {
		display: none;
	}

	.ecu-ai-diag__panel {
		left: 12px;
		right: 12px;
		width: auto;
		max-width: none;
		bottom: 126px;
		max-height: calc(100vh - 150px);
	}
}

/* =========================================================
   Base de calculateurs supportés
   ========================================================= */
.ecu-ecudb {
	margin: 24px 0;
}

.ecu-ecudb__controls {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
	margin-bottom: 10px;
}

.ecu-ecudb__search {
	flex: 1;
	min-width: 260px;
	background: #0a1220;
	color: #eef4ff;
	border: 1px solid #2b3c58;
	border-radius: 999px;
	padding: 12px 20px;
	font-size: 15px;
}

.ecu-ecudb__search:focus {
	outline: none;
	border-color: #1f6feb;
}

.ecu-ecudb__filters {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.ecu-ecudb__filter {
	background: transparent;
	border: 1px solid #2b3c58;
	color: #91a4bd;
	border-radius: 999px;
	padding: 8px 16px;
	font-size: 13.5px;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease;
}

.ecu-ecudb__filter:hover {
	border-color: #66a3ff;
	color: #eef4ff;
}

.ecu-ecudb__filter.is-active {
	background: #1f6feb;
	border-color: #1f6feb;
	color: #ffffff;
}

.ecu-ecudb__count {
	color: #91a4bd;
	font-size: 13.5px;
	margin: 0 0 14px;
}

.ecu-ecudb__count strong {
	color: #66a3ff;
}

.ecu-ecudb__list {
	display: flex;
	flex-direction: column;
	gap: 8px;
	max-height: 640px;
	overflow-y: auto;
	padding-right: 6px;
}

.ecu-ecudb__row {
	display: grid;
	grid-template-columns: 180px 220px 1fr;
	gap: 14px;
	align-items: center;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 10px;
	padding: 12px 16px;
}

.ecu-ecudb__row[hidden] {
	display: none;
}

.ecu-ecudb__ref strong {
	display: block;
	color: #eef4ff;
	font-size: 15px;
}

.ecu-ecudb__ref span {
	color: #5c7089;
	font-size: 12px;
}

.ecu-ecudb__vehicles {
	color: #91a4bd;
	font-size: 13.5px;
}

.ecu-ecudb__ops {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: flex-end;
}

.ecu-ecudb__op {
	background: rgba(31, 111, 235, 0.14);
	border: 1px solid rgba(102, 163, 255, 0.3);
	color: #66a3ff;
	border-radius: 999px;
	padding: 2px 10px;
	font-size: 11.5px;
	white-space: nowrap;
}

.ecu-ecudb__empty {
	color: #91a4bd;
	text-align: center;
	padding: 24px 0;
}

.ecu-ecudb__missing {
	margin-top: 22px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 20px 24px;
	text-align: center;
}

.ecu-ecudb__missing p {
	color: #91a4bd;
	margin: 0 0 14px;
}

.ecu-ecudb__missing p strong {
	color: #eef4ff;
}

@media (max-width: 860px) {
	.ecu-ecudb__row {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.ecu-ecudb__ops {
		justify-content: flex-start;
	}
}

/* =========================================================
   FAQ (accordéon)
   ========================================================= */
.ecu-faq {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 24px 0;
}

.ecu-faq__item {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	overflow: hidden;
}

.ecu-faq__item[open] {
	border-color: #2b3c58;
}

.ecu-faq__question {
	cursor: pointer;
	padding: 16px 20px;
	color: #eef4ff;
	font-size: 15.5px;
	font-weight: 600;
	list-style: none;
	position: relative;
	padding-right: 44px;
}

.ecu-faq__question::-webkit-details-marker {
	display: none;
}

.ecu-faq__question::after {
	content: '+';
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
	color: #66a3ff;
	font-size: 20px;
	font-weight: 400;
}

.ecu-faq__item[open] .ecu-faq__question::after {
	content: '−';
}

.ecu-faq__question:hover {
	color: #66a3ff;
}

.ecu-faq__answer {
	padding: 0 20px 18px;
}

.ecu-faq__answer p {
	color: #91a4bd;
	font-size: 14.5px;
	line-height: 1.65;
	margin: 0;
}

/* =========================================================
   Comment ça marche (étapes)
   ========================================================= */
.ecu-how {
	display: flex;
	align-items: stretch;
	gap: 10px;
	margin: 24px 0;
}

.ecu-how__step {
	flex: 1;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 22px 20px;
	position: relative;
}

.ecu-how__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: #1f6feb;
	color: #ffffff;
	font-weight: 800;
	font-size: 16px;
	margin-bottom: 12px;
}

.ecu-how__step h3 {
	color: #eef4ff;
	font-size: 16.5px;
	margin: 0 0 8px;
}

.ecu-how__step p {
	color: #91a4bd;
	font-size: 13.5px;
	line-height: 1.6;
	margin: 0;
}

.ecu-how__step a {
	color: #66a3ff;
}

.ecu-how__arrow {
	align-self: center;
	color: #2b3c58;
	font-size: 26px;
	flex-shrink: 0;
}

@media (max-width: 860px) {
	.ecu-how {
		flex-direction: column;
	}

	.ecu-how__arrow {
		transform: rotate(90deg);
		text-align: center;
		margin: -2px 0;
	}
}

/* =========================================================
   Newsletter — capture e-mail + code promo
   ========================================================= */
.ecu-newsletter {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin: 34px 0;
	padding: 24px 28px;
	background: linear-gradient(135deg, #101b2d, #16243a);
	border: 1px solid rgba(102, 163, 255, 0.35);
	border-radius: 14px;
}

.ecu-newsletter__text {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 240px;
	flex: 1;
}

.ecu-newsletter__text strong {
	color: #eef4ff;
	font-size: 17px;
}

.ecu-newsletter__text span {
	color: #91a4bd;
	font-size: 13.5px;
}

.ecu-newsletter__form {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	position: relative;
}

.ecu-newsletter__form input[type='email'] {
	background: #0a1220;
	color: #eef4ff;
	border: 1px solid #2b3c58;
	border-radius: 999px;
	padding: 11px 18px;
	font-size: 14px;
	min-width: 220px;
}

.ecu-newsletter__form input[type='email']:focus {
	outline: none;
	border-color: #1f6feb;
}

.ecu-newsletter__feedback {
	width: 100%;
	margin: 0;
	color: #f5b942;
	font-size: 14px;
	font-weight: 600;
}

.ecu-newsletter__feedback.is-success {
	color: #4ade80;
}

@media (max-width: 700px) {
	.ecu-newsletter {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}

	.ecu-newsletter__form {
		flex-direction: column;
	}

	.ecu-newsletter__form input[type='email'] {
		min-width: 0;
	}
}

/* =========================================================
   Lien version anglaise (boutique)
   ========================================================= */
.ecu-lang-link {
	margin-top: 8px !important;
	font-size: 13.5px;
	color: #91a4bd;
}

.ecu-lang-link a {
	color: #66a3ff;
}

/* =========================================================
   Blog technique — liste des articles
   ========================================================= */
body.home:not(.front-page) .ast-article-post,
body.blog .ast-article-post,
.blog .ast-article-post,
.archive .ast-article-post,
.archive.category-videos-tiktok .ast-article-post {
	background: #101b2d !important;
	border: 1px solid #21304a !important;
	border-radius: 12px !important;
}

body.home:not(.front-page) .ast-article-post .inside-article,
body.home:not(.front-page) .ast-article-post > div,
body.blog .ast-article-post .inside-article,
.blog .ast-article-post .inside-article,
.archive .ast-article-post .inside-article,
.archive .ast-article-post > div {
	background: transparent !important;
}

body.home:not(.front-page) .ast-article-post .entry-title,
body.home:not(.front-page) .ast-article-post .entry-title a,
body.blog .ast-article-post .entry-title,
body.blog .ast-article-post .entry-title a,
.blog .ast-article-post .entry-title,
.blog .ast-article-post .entry-title a,
.archive .ast-article-post .entry-title,
.archive .ast-article-post .entry-title a {
	color: #eef4ff !important;
}

body.home:not(.front-page) .ast-article-post .entry-title a:hover,
body.blog .ast-article-post .entry-title a:hover,
.blog .ast-article-post .entry-title a:hover,
.archive .ast-article-post .entry-title a:hover {
	color: #66a3ff !important;
}

body.home:not(.front-page) .ast-article-post .entry-summary,
body.home:not(.front-page) .ast-article-post .entry-summary p,
body.home:not(.front-page) .ast-article-post .entry-content,
body.home:not(.front-page) .ast-article-post .entry-content p,
body.blog .ast-article-post .entry-summary,
body.blog .ast-article-post .entry-summary p,
body.blog .ast-article-post .entry-content,
body.blog .ast-article-post .entry-content p,
.blog .ast-article-post .entry-summary,
.blog .ast-article-post .entry-summary p,
.blog .ast-article-post .entry-content,
.blog .ast-article-post .entry-content p,
.archive .ast-article-post .entry-summary,
.archive .ast-article-post .entry-summary p,
.archive .ast-article-post .entry-content,
.archive .ast-article-post .entry-content p {
	color: #c5d4e8 !important;
}

body.home:not(.front-page) .ast-article-post .entry-meta,
body.home:not(.front-page) .ast-article-post .entry-meta a,
body.home:not(.front-page) .ast-article-post .posted-by,
body.home:not(.front-page) .ast-article-post .posted-on,
body.blog .ast-article-post .entry-meta,
body.blog .ast-article-post .entry-meta a,
.blog .ast-article-post .entry-meta,
.blog .ast-article-post .entry-meta a,
.archive .ast-article-post .entry-meta,
.archive .ast-article-post .entry-meta a {
	color: #91a4bd !important;
}

body.home:not(.front-page) .ast-article-post .cat-links a,
body.home:not(.front-page) .ast-article-post .tags-links a,
body.blog .ast-article-post .cat-links a,
.blog .ast-article-post .cat-links a,
.archive .ast-article-post .cat-links a {
	color: #66a3ff !important;
}

body.home:not(.front-page) .ast-article-post .read-more a,
body.blog .ast-article-post .read-more a,
.blog .ast-article-post .read-more a,
.archive .ast-article-post .read-more a {
	color: #66a3ff !important;
}

.single-post .entry-content h2 {
	color: #66a3ff;
	font-size: 22px;
	margin-top: 32px;
}

.single-post .entry-content h3 {
	color: #eef4ff;
	font-size: 17.5px;
	margin-top: 22px;
}

/* =========================================================
   Espace pro — historique fichiers
   ========================================================= */
.ecu-pro-files__intro {
	color: #91a4bd;
	margin-bottom: 18px;
}

.ecu-pro-files__empty {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 24px;
	color: #91a4bd;
}

.ecu-pro-files__table-wrap {
	overflow-x: auto;
	margin-top: 20px;
}

.ecu-pro-files__table {
	width: 100%;
	font-size: 14px;
}

.ecu-pro-files__status {
	color: #66a3ff;
	font-weight: 600;
}

.ecu-pro-files__dl a {
	color: #66a3ff;
	font-weight: 600;
}

/* =========================================================
   Calculateur de prix
   ========================================================= */
.ecu-price-calc {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 14px;
	padding: 20px 22px;
	margin: 0 0 28px;
}

.ecu-price-calc__header {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: baseline;
	margin-bottom: 16px;
}

.ecu-price-calc__header strong {
	color: #eef4ff;
	font-size: 17px;
}

.ecu-price-calc__header span {
	color: #91a4bd;
	font-size: 13.5px;
}

.ecu-price-calc__cat {
	grid-column: 1 / -1;
	color: #66a3ff;
	font-weight: 700;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: 12px 0 4px;
}

.ecu-price-calc__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 8px;
}

.ecu-price-calc__item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	background: #0a1220;
	border: 1px solid #2b3c58;
	border-radius: 10px;
	cursor: pointer;
}

.ecu-price-calc__item:has(input:checked) {
	border-color: #1f6feb;
	background: rgba(31, 111, 235, 0.12);
}

.ecu-price-calc__name {
	flex: 1;
	color: #eef4ff;
	font-size: 13.5px;
}

.ecu-price-calc__price {
	color: #66a3ff;
	font-weight: 700;
	font-size: 14px;
}

.ecu-price-calc__total {
	margin-top: 18px;
	padding-top: 16px;
	border-top: 1px solid #21304a;
}

.ecu-price-calc__line {
	display: flex;
	justify-content: space-between;
	color: #91a4bd;
	margin-bottom: 8px;
}

.ecu-price-calc__line--final strong {
	color: #eef4ff;
	font-size: 18px;
}

.ecu-price-calc__hint {
	color: #5c7089;
	font-size: 13px;
	margin: 8px 0 14px;
}

/* =========================================================
   Comparateur sur mesure vs generique
   ========================================================= */
.ecu-compare {
	margin: 28px 0;
	overflow-x: auto;
}

.ecu-compare__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.ecu-compare__table th,
.ecu-compare__table td {
	padding: 12px 14px;
	border: 1px solid #21304a;
	text-align: left;
}

.ecu-compare__table thead th {
	background: #101b2d;
	color: #eef4ff;
}

.ecu-compare__table tbody td {
	background: #0a1220;
	color: #91a4bd;
}

.ecu-compare__us {
	background: rgba(31, 111, 235, 0.1) !important;
	color: #eef4ff !important;
}

/* =========================================================
   Parrainage pro
   ========================================================= */
.ecu-referral {
	margin-top: 28px;
	padding: 22px;
	background: #101b2d;
	border: 1px solid rgba(102, 163, 255, 0.35);
	border-radius: 12px;
}

.ecu-referral h3 {
	color: #eef4ff;
	margin: 0 0 10px;
}

.ecu-referral p {
	color: #91a4bd;
	margin: 0 0 10px;
}

.ecu-referral__code {
	color: #eef4ff !important;
	font-size: 16px;
}

.ecu-referral__code strong {
	color: #66a3ff;
	font-size: 20px;
	letter-spacing: 0.06em;
}

.ecu-referral--guest {
	margin: 20px 0;
	padding: 16px 20px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
}

/* =========================================================
   Temoignages
   ========================================================= */
.ecu-testimonials {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	margin: 24px 0 32px;
}

.ecu-testimonial {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 22px;
}

.ecu-testimonial__video iframe {
	width: 100%;
	aspect-ratio: 16/9;
	border: 0;
	border-radius: 8px;
	margin-bottom: 12px;
}

.ecu-testimonial__avatar {
	color: #f5b942;
	font-size: 22px;
	letter-spacing: 3px;
	margin-bottom: 12px;
}

.ecu-testimonial__quote {
	color: #eef4ff;
	font-style: italic;
	margin: 0 0 12px;
	line-height: 1.6;
}

.ecu-testimonial__author {
	color: #91a4bd;
	font-size: 13px;
	margin: 0;
}

@media (max-width: 900px) {
	.ecu-testimonials {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
   Support humain
   ========================================================= */
.ecu-human-support {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	margin: 28px 0;
	padding: 18px 22px;
	background: linear-gradient(135deg, #101b2d, #16243a);
	border: 1px solid #21304a;
	border-radius: 12px;
}

.ecu-human-support__icon {
	font-size: 28px;
}

.ecu-human-support__text {
	flex: 1;
	min-width: 200px;
}

.ecu-human-support__text strong {
	display: block;
	color: #eef4ff;
	margin-bottom: 4px;
}

.ecu-human-support__text span {
	color: #91a4bd;
	font-size: 13.5px;
}

/* =========================================================
   Realisations — photo
   ========================================================= */
.ecu-realisation__photo {
	margin: -22px -22px 16px;
	border-radius: 12px 12px 0 0;
	overflow: hidden;
}

.ecu-realisation__photo img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	display: block;
}

/* =========================================================
   Blog — intro page articles
   ========================================================= */
.ecu-blog-page-intro,
.ecu-blog-intro {
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 12px;
	padding: 20px 24px;
	margin: 0 0 28px;
	color: #91a4bd;
	line-height: 1.65;
}

.ecu-blog-page-intro p,
.ecu-blog-intro p {
	margin: 0;
	color: #eef4ff;
}

.ecu-blog-page-intro strong,
.ecu-blog-intro strong {
	color: #66a3ff;
}

.ecu-blog-intro__tiktok {
	margin-top: 10px !important;
	font-size: 14px;
}

.ecu-blog-intro__tiktok a {
	color: #66a3ff;
}

/* =========================================================
   TikTok — blog
   ========================================================= */
.ecu-tiktok-section {
	margin: 0 0 36px;
	padding: 24px;
	background: #101b2d;
	border: 1px solid #21304a;
	border-radius: 14px;
}

.ecu-tiktok-section__head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 20px;
}

.ecu-tiktok-section__head h2 {
	margin: 0;
	color: #eef4ff;
	font-size: 22px;
}

.ecu-tiktok-section__profile {
	color: #66a3ff;
	font-size: 14px;
	text-decoration: none;
}

.ecu-tiktok-section__profile:hover {
	text-decoration: underline;
}

.ecu-tiktok-section__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 18px;
}

.ecu-tiktok-embed {
	min-height: 580px;
	display: flex;
	align-items: flex-start;
	justify-content: center;
}

.ecu-tiktok-embed blockquote {
	margin: 0 !important;
}

.ecu-tiktok-profile-embed {
	max-width: 780px;
	margin: 0 auto;
}

.ecu-tiktok-profile-embed blockquote {
	margin: 0 auto !important;
}

.ecu-tiktok-section__more {
	margin: 18px 0 0;
	text-align: center;
}

.ecu-tiktok-section__more a {
	color: #66a3ff;
}

.ecu-tiktok-post__cta,
.ecu-tiktok-post__follow {
	color: #91a4bd;
	margin-top: 16px;
}

.ecu-tiktok-post__cta a,
.ecu-tiktok-post__follow a {
	color: #66a3ff;
}

.ecu-tiktok-fallback a {
	color: #66a3ff;
}

@media (max-width: 640px) {
	.ecu-tiktok-embed {
		min-height: 520px;
	}
}

/* =========================================================
   Blog — cartes liste (priorite max, corrige fond blanc Astra)
   ========================================================= */
body.home:not(.front-page),
body.archive,
body.blog {
	--ast-global-color-4: #0f1724;
	--ast-global-color-5: #101b2d;
	--ast-global-color-6: #eef4ff;
	--ast-global-color-7: #91a4bd;
}

#primary article.ecu-blog-list-card,
#primary article.ecu-blog-list-card .ast-post-format-,
#primary article.ecu-blog-list-card .inside-article,
#primary article.ecu-blog-list-card .entry-header,
#primary article.ecu-blog-list-card .entry-content,
#primary article.ecu-blog-list-card .entry-summary,
.ast-separate-container #primary article.ecu-blog-list-card {
	background-color: #101b2d !important;
	border: 1px solid #21304a !important;
	border-radius: 12px !important;
	color: #c5d4e8 !important;
}

#primary article.ecu-blog-list-card .entry-title,
#primary article.ecu-blog-list-card .entry-title a,
#primary article.ecu-blog-list-card h2.entry-title a {
	color: #eef4ff !important;
}

#primary article.ecu-blog-list-card .entry-title a:hover,
#primary article.ecu-blog-list-card h2.entry-title a:hover {
	color: #66a3ff !important;
}

#primary article.ecu-blog-list-card .entry-summary,
#primary article.ecu-blog-list-card .entry-summary p,
#primary article.ecu-blog-list-card .entry-content,
#primary article.ecu-blog-list-card .entry-content p,
#primary article.ecu-blog-list-card .ast-excerpt-container,
#primary article.ecu-blog-list-card .ast-excerpt-container p {
	color: #c5d4e8 !important;
}

#primary article.ecu-blog-list-card .entry-meta,
#primary article.ecu-blog-list-card .entry-meta *,
#primary article.ecu-blog-list-card .posted-by,
#primary article.ecu-blog-list-card .posted-on,
#primary article.ecu-blog-list-card .posted-by a,
#primary article.ecu-blog-list-card .posted-on a {
	color: #91a4bd !important;
}

#primary article.ecu-blog-list-card .cat-links a,
#primary article.ecu-blog-list-card .tags-links a,
#primary article.ecu-blog-list-card .ast-terms-link {
	color: #66a3ff !important;
}

#primary article.ecu-blog-list-card .read-more a {
	color: #66a3ff !important;
	font-weight: 600;
}

/* =========================================================
   Navigation mobile — menu hamburger + tiroir
   ========================================================= */
.ecu-mobile-drawer[hidden] {
	display: none !important;
}

.ecu-mobile-drawer {
	position: fixed;
	inset: 0;
	z-index: 100000;
}

.ecu-mobile-drawer__backdrop {
	position: absolute;
	inset: 0;
	border: 0;
	padding: 0;
	margin: 0;
	background: rgba(0, 0, 0, 0.65);
	cursor: pointer;
}

.ecu-mobile-drawer__panel {
	position: absolute;
	top: 0;
	right: 0;
	width: min(100%, 360px);
	height: 100%;
	display: flex;
	flex-direction: column;
	background: #0c1422;
	border-left: 1px solid #26364d;
	box-shadow: -12px 0 40px rgba(0, 0, 0, 0.5);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: env(safe-area-inset-bottom, 0px);
}

.ecu-mobile-drawer__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 18px;
	border-bottom: 1px solid #26364d;
	flex-shrink: 0;
}

.ecu-mobile-drawer__title {
	color: #eef4ff;
	font-size: 18px;
	font-weight: 700;
}

.ecu-mobile-drawer__close {
	width: 44px;
	height: 44px;
	border: 1px solid #26364d;
	border-radius: 10px;
	background: #151f2e;
	color: #eef4ff;
	font-size: 18px;
	cursor: pointer;
}

.ecu-mobile-drawer__nav {
	flex: 1;
	padding: 8px 0;
}

.ecu-mobile-drawer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ecu-mobile-drawer__menu li {
	margin: 0;
	border-bottom: 1px solid rgba(38, 54, 77, 0.65);
}

.ecu-mobile-drawer__menu a {
	display: flex;
	align-items: center;
	min-height: 48px;
	padding: 12px 18px;
	color: #eef4ff !important;
	text-decoration: none !important;
	font-size: 16px;
	font-weight: 600;
}

.ecu-mobile-drawer__menu a:hover,
.ecu-mobile-drawer__menu .current-menu-item > a,
.ecu-mobile-drawer__menu .current_page_item > a {
	background: rgba(31, 111, 235, 0.15);
	color: #66a3ff !important;
}

.ecu-mobile-drawer__account {
	padding: 16px 18px;
	border-top: 1px solid #26364d;
	border-bottom: 1px solid #26364d;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex-shrink: 0;
}

.ecu-mobile-drawer__user {
	margin: 0;
	color: #eef4ff;
	font-size: 15px;
	font-weight: 700;
}

.ecu-mobile-drawer__tokens {
	margin: 0;
	color: #91a4bd;
	font-size: 14px;
}

.ecu-mobile-drawer__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 16px;
	border-radius: 10px;
	text-decoration: none !important;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
}

.ecu-mobile-drawer__btn--primary {
	background: #1f6feb;
	color: #fff !important;
	border: 1px solid #1f6feb;
}

.ecu-mobile-drawer__btn--ghost {
	background: transparent;
	color: #eef4ff !important;
	border: 1px solid #26364d;
}

.ecu-mobile-drawer__quick {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	padding: 16px 18px 20px;
	flex-shrink: 0;
}

.ecu-mobile-drawer__quick a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 10px 12px;
	border-radius: 10px;
	border: 1px solid #26364d;
	background: #151f2e;
	color: #66a3ff !important;
	text-decoration: none !important;
	font-size: 14px;
	font-weight: 600;
	text-align: center;
}

body.ecu-mobile-nav-open {
	overflow: hidden;
}

body.ecu-mobile-nav-open .ecu-mobile-header-tools__toggle-bar {
	transition: transform 0.2s ease, opacity 0.2s ease;
}

@media (max-width: 921px) {
	.ecu-mobile-drawer__quick a:last-child:nth-child(odd) {
		grid-column: 1 / -1;
	}
}

