/* ==========================================================================
   Imperial Dog & Cat — WooCommerce Mon compte (connexion / inscription)
   Scope : body.woocommerce-account
   ========================================================================== */

/* ============================================================
   PAGE WRAPPER & LAYOUT
   ============================================================ */
body.woocommerce-account .woocommerce {
	max-width: 1200px;
	margin: 60px auto;
	padding: 0 20px;
	font-family: "Nunito Sans", sans-serif;
}

/* Quand non connecté : deux colonnes (login / register) côte à côte */
body.woocommerce-account:not(.logged-in) .woocommerce .u-columns.col2-set {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	align-items: stretch;
}

body.woocommerce-account:not(.logged-in) .woocommerce .u-column1,
body.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
	width: 100% !important;
	float: none !important;
	padding: 0;
}

/* Si seul le formulaire de connexion est affiché (inscription désactivée dans WC)
   → centré et limité à une largeur compacte */
body.woocommerce-account:not(.logged-in) .woocommerce > .woocommerce-form-login {
	max-width: 440px;
	margin: 0 auto;
}

/* Header interne du formulaire de connexion */
.woocommerce-account .idc-login-header {
	text-align: center;
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 1px solid #E2EFF7;
}

.woocommerce-account .idc-login-header h2 {
	font-family: "Nunito", sans-serif;
	font-weight: 900;
	font-size: 26px;
	color: #1A1A1A;
	margin: 0 0 8px;
	letter-spacing: -0.01em;
}

.woocommerce-account .idc-login-header p {
	font-family: "Nunito Sans", sans-serif;
	font-size: 13px;
	color: #707070;
	margin: 0;
	line-height: 1.5;
}

/* Quand le header est dans le form, on cache la petite barre ::after décorative
   qui était positionnée à 86px (pertinente uniquement sans header interne) */
.woocommerce-account .woocommerce-form-login:has(.idc-login-header)::after {
	display: none;
}

/* ============================================================
   CARDS (formulaires login / register)
   ============================================================ */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register,
.woocommerce-account .woocommerce-ResetPassword.lost_reset_password {
	background: #FFFFFF;
	border: 1px solid #E2EFF7;
	border-radius: 20px;
	padding: 44px 40px 36px;
	box-shadow:
		0 2px 8px rgba(0, 0, 0, 0.03),
		0 14px 40px rgba(75, 174, 224, 0.10),
		0 30px 80px rgba(75, 174, 224, 0.06);
	position: relative;
	overflow: hidden;
	animation: idc-myaccount-fade 0.6s ease both;
}

.woocommerce-account .woocommerce-form-register { animation-delay: 0.15s; }

@keyframes idc-myaccount-fade {
	from { opacity: 0; transform: translateY(24px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Bandeau décoratif en haut des cartes */
.woocommerce-account .woocommerce-form-login::before,
.woocommerce-account .woocommerce-form-register::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: linear-gradient(90deg, #4BAEE0 0%, #2E96CC 50%, #4BAEE0 100%);
	background-size: 200% 100%;
	animation: idc-shine 4s linear infinite;
}

@keyframes idc-shine {
	0%   { background-position: 0% 0; }
	100% { background-position: 200% 0; }
}

/* ============================================================
   TITRES (H2 "Connexion" / "S'inscrire")
   ============================================================ */
.woocommerce-account .woocommerce h2 {
	font-family: "Nunito", sans-serif;
	font-weight: 900;
	font-size: 28px;
	color: #1A1A1A;
	margin: 0 0 8px;
	letter-spacing: -0.02em;
}

/* Sous-titre ajouté via ::after (petite baseline) */
.woocommerce-account .woocommerce-form-login::after,
.woocommerce-account .woocommerce-form-register::after {
	content: "";
	display: block;
	position: absolute;
	top: 86px;
	left: 40px;
	width: 48px;
	height: 3px;
	background: #4BAEE0;
	border-radius: 2px;
}

.woocommerce-account .woocommerce-form-login > p:first-of-type,
.woocommerce-account .woocommerce-form-register > p:first-of-type {
	font-family: "Nunito Sans", sans-serif;
	font-size: 14px;
	color: #707070;
	margin: 0 0 28px;
	line-height: 1.5;
}

/* ============================================================
   LABELS & INPUTS
   ============================================================ */
.woocommerce-account .woocommerce-form-row,
.woocommerce-account .woocommerce form .form-row {
	margin-bottom: 18px;
	padding: 0;
}

.woocommerce-account .woocommerce form .form-row label,
.woocommerce-account .woocommerce-form label {
	display: block;
	font-family: "Nunito", sans-serif;
	font-size: 13px;
	font-weight: 700;
	color: #1A1A1A;
	margin-bottom: 8px;
	letter-spacing: 0.01em;
}

.woocommerce-account .woocommerce form .form-row .required {
	color: #E63946;
	font-weight: 800;
	text-decoration: none;
}

.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"],
.woocommerce-account input[type="tel"],
.woocommerce-account .woocommerce form .form-row input.input-text {
	width: 100%;
	padding: 15px 18px;
	background: #FFFFFF;
	border: 2px solid #E2EFF7;
	border-radius: 12px;
	font-family: "Nunito Sans", sans-serif;
	font-size: 15px;
	color: #1A1A1A;
	line-height: 1.4;
	outline: none;
	box-shadow: none;
	transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.15s ease;
}

.woocommerce-account input[type="text"]:hover,
.woocommerce-account input[type="email"]:hover,
.woocommerce-account input[type="password"]:hover {
	border-color: #9BCBEB;
}

.woocommerce-account input[type="text"]:focus,
.woocommerce-account input[type="email"]:focus,
.woocommerce-account input[type="password"]:focus {
	border-color: #4BAEE0;
	box-shadow: 0 0 0 4px rgba(75, 174, 224, 0.15);
}

.woocommerce-account input::placeholder {
	color: #A8B8C4;
	opacity: 1;
}

/* Show password icon (WC le génère automatiquement) */
.woocommerce-account .password-input {
	position: relative;
	display: block;
}

.woocommerce-account .show-password-input {
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	color: #707070;
	cursor: pointer;
	transition: color 0.2s ease;
}

.woocommerce-account .show-password-input:hover,
.woocommerce-account .show-password-input.display-password {
	color: #4BAEE0;
}

/* ============================================================
   REMEMBER ME + LOST PASSWORD
   ============================================================ */
.woocommerce-account .woocommerce-form-login__rememberme {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	color: #1A1A1A;
	cursor: pointer;
	margin: 0;
}

.woocommerce-account .woocommerce-form-login__rememberme input[type="checkbox"] {
	width: 18px;
	height: 18px;
	accent-color: #4BAEE0;
	cursor: pointer;
}

.woocommerce-account .lost_password {
	margin: 0;
	text-align: right;
}

.woocommerce-account .lost_password a {
	color: #4BAEE0;
	font-weight: 700;
	font-size: 13px;
	text-decoration: none;
	border-bottom: 1px solid rgba(75, 174, 224, 0.3);
	transition: border-color 0.2s ease;
}

.woocommerce-account .lost_password a:hover {
	border-bottom-color: #4BAEE0;
}

/* Ligne remember + lost password */
.woocommerce-account .woocommerce-form-login .form-row:has(.woocommerce-form-login__rememberme) {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
}

/* ============================================================
   SUBMIT BUTTONS (Connexion / S'inscrire)
   ============================================================ */
.woocommerce-account .woocommerce-form-login__submit,
.woocommerce-account .woocommerce-form-register__submit,
.woocommerce-account .woocommerce-Button,
.woocommerce-account button[type="submit"].woocommerce-button {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	width: 100% !important;
	padding: 18px 32px !important;
	background: linear-gradient(135deg, #4BAEE0 0%, #2E96CC 100%) !important;
	color: #FFFFFF !important;
	border: none !important;
	border-radius: 50px !important;
	font-family: "Nunito", sans-serif !important;
	font-size: 16px !important;
	font-weight: 900 !important;
	letter-spacing: 0.03em !important;
	text-transform: uppercase !important;
	cursor: pointer !important;
	box-shadow: 0 8px 24px rgba(75, 174, 224, 0.40), 0 2px 8px rgba(75, 174, 224, 0.2) !important;
	transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.25s ease !important;
	margin-top: 10px !important;
	line-height: 1 !important;
	height: auto !important;
	min-height: 0 !important;
	text-shadow: none !important;
}

.woocommerce-account .woocommerce-form-login__submit::after,
.woocommerce-account .woocommerce-form-register__submit::after {
	content: "→";
	font-size: 20px;
	font-weight: 400;
	transition: transform 0.25s ease;
}

.woocommerce-account .woocommerce-form-login__submit:hover,
.woocommerce-account .woocommerce-form-register__submit:hover,
.woocommerce-account .woocommerce-Button:hover {
	transform: translateY(-3px) !important;
	box-shadow: 0 14px 34px rgba(75, 174, 224, 0.50), 0 4px 12px rgba(75, 174, 224, 0.3) !important;
	filter: brightness(1.05) !important;
}

.woocommerce-account .woocommerce-form-login__submit:hover::after,
.woocommerce-account .woocommerce-form-register__submit:hover::after {
	transform: translateX(4px);
}

/* ============================================================
   NOTICES (erreurs, infos)
   ============================================================ */
.woocommerce-account .woocommerce-notices-wrapper {
	max-width: 1200px;
	margin: 0 auto 24px;
	padding: 0 20px;
}

.woocommerce-account .woocommerce-error,
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info {
	list-style: none;
	border-radius: 12px;
	padding: 16px 24px;
	font-family: "Nunito Sans", sans-serif;
	font-size: 14px;
	color: #1A1A1A;
	margin: 0 0 20px;
	border: 1px solid transparent;
}

.woocommerce-account .woocommerce-error {
	background: #FEF2F3;
	border-color: #F5A5AE;
	border-left: 5px solid #E63946;
}

.woocommerce-account .woocommerce-error li {
	margin: 4px 0;
}

.woocommerce-account .woocommerce-error li::before {
	color: #E63946;
}

.woocommerce-account .woocommerce-message {
	background: #EAF7EE;
	border-color: #9BD7AD;
	border-left: 5px solid #5BC0A9;
}

.woocommerce-account .woocommerce-info {
	background: #EAF5FC;
	border-color: #9BCBEB;
	border-left: 5px solid #4BAEE0;
}

/* ============================================================
   PRIVACY / REGISTER NOTICE
   ============================================================ */
.woocommerce-account .woocommerce-privacy-policy-text p {
	font-size: 12px;
	color: #707070;
	line-height: 1.6;
	margin: 16px 0 0;
}

.woocommerce-account .woocommerce-privacy-policy-text a {
	color: #4BAEE0;
	font-weight: 700;
}

/* ============================================================
   LOGGED-IN DASHBOARD — Layout app-like (sidebar fixe + content)
   Full-screen : header + dashboard + footer tiennent sur 1 écran.
   Seul le contenu central scrolle si besoin.
   ============================================================ */

/* Le #page devient une colonne flex qui remplit exactement le viewport */
body.woocommerce-account.logged-in #page {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	height: 100vh;
	overflow: hidden;
}

body.woocommerce-account.logged-in .idc-header,
body.woocommerce-account.logged-in .idc-footer {
	flex: 0 0 auto;
}

body.woocommerce-account.logged-in #content.site-content {
	flex: 1 1 auto;
	min-height: 0;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

/* Cache toutes les notices (messages d'alerte WC) */
body.woocommerce-account.logged-in .woocommerce-notices-wrapper {
	display: none !important;
}

/* Edge-to-edge : neutralise le container Astra uniquement sur cette page */
body.woocommerce-account.logged-in #content.site-content > .ast-container {
	max-width: none;
	padding: 0;
	margin: 0;
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
}

body.woocommerce-account.logged-in #content {
	background: #F4F8FB;
}

/* Masque l'annonce bar pour gagner de la place */
body.woocommerce-account.logged-in .idc-announcement {
	display: none;
}

/* Footer compact : juste la barre du bas (copyright + paiements), on masque
   la newsletter et les 4 colonnes de liens pour gagner de la place verticale */
body.woocommerce-account.logged-in .idc-footer__newsletter,
body.woocommerce-account.logged-in .idc-footer__main {
	display: none;
}

body.woocommerce-account.logged-in .idc-footer__bottom {
	padding: 16px 0;
}

/* Masque la zone titre de page Astra (qui affichait le titre au-dessus
   et empêchait la sidebar de coller au haut de l'écran) */
body.woocommerce-account.logged-in .ast-page-header-wrap,
body.woocommerce-account.logged-in .ast-single-post-header,
body.woocommerce-account.logged-in .entry-header,
body.woocommerce-account.logged-in .ast-archive-description,
body.woocommerce-account.logged-in .page-header,
body.woocommerce-account.logged-in article > header.entry-header {
	display: none !important;
}

/* Force le wrapper article/main à ne pas introduire de padding top */
body.woocommerce-account.logged-in article,
body.woocommerce-account.logged-in .entry-content,
body.woocommerce-account.logged-in main#main,
body.woocommerce-account.logged-in #primary {
	padding: 0 !important;
	margin: 0 !important;
}

body.woocommerce-account.logged-in .woocommerce {
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	align-items: stretch;
	flex: 1 1 auto;
	min-height: 0;
	height: 100%;
	overflow: hidden;
}

/* -------- SIDEBAR (menu gauche, pleine hauteur du flex parent) -------- */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
	width: 280px !important;
	min-width: 280px;
	flex-shrink: 0;
	background: #FFFFFF;
	border-right: 1px solid #E2EFF7;
	box-shadow: 4px 0 24px rgba(75, 174, 224, 0.06);
	padding: 32px 20px;
	overflow-y: auto;
	height: 100%;
	float: none !important;
	margin: 0 !important;
	border-radius: 0;
	display: flex;
	flex-direction: column;
}

/* Titre / logo de sidebar (optionnel, ajouté via pseudo) */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation::before {
	content: "Espace client";
	display: block;
	font-family: "Nunito", sans-serif;
	font-weight: 900;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #707070;
	padding: 0 12px 18px;
	margin-bottom: 12px;
	border-bottom: 1px solid #E2EFF7;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li {
	margin: 0;
	padding: 0;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 13px 16px;
	font-family: "Nunito", sans-serif;
	font-size: 14px;
	font-weight: 700;
	color: #1A1A1A;
	text-decoration: none;
	border-radius: 12px;
	transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	position: relative;
}

/* Icône SVG inline pour chaque endpoint (via ::before) */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a::before {
	content: "";
	display: inline-block;
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	opacity: 0.75;
	transition: opacity 0.2s ease, filter 0.2s ease;
}

/* Dashboard */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--dashboard a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='7' height='7'/><rect x='14' y='3' width='7' height='7'/><rect x='14' y='14' width='7' height='7'/><rect x='3' y='14' width='7' height='7'/></svg>");
}

/* Orders */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--orders a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 2L3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4z'/><line x1='3' y1='6' x2='21' y2='6'/><path d='M16 10a4 4 0 0 1-8 0'/></svg>");
}

/* Downloads */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--downloads a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/><polyline points='7 10 12 15 17 10'/><line x1='12' y1='15' x2='12' y2='3'/></svg>");
}

/* Addresses */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--edit-address a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>");
}

/* Payment methods */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--payment-methods a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='5' width='20' height='14' rx='2'/><line x1='2' y1='10' x2='22' y2='10'/></svg>");
}

/* Edit account */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--edit-account a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/><circle cx='12' cy='7' r='4'/></svg>");
}

/* Logout */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--customer-logout a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E63946' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/><polyline points='16 17 21 12 16 7'/><line x1='21' y1='12' x2='9' y2='12'/></svg>");
	opacity: 1;
}

/* Wishlist (liste d'envies) */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--wishlist a::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/></svg>");
}

/* Hover state */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a:hover {
	background: #F4F8FB;
	color: #4BAEE0;
	transform: translateX(2px);
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a:hover::before {
	opacity: 1;
	filter: hue-rotate(180deg) saturate(2);
}

/* Active state */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li.is-active a {
	background: linear-gradient(135deg, #4BAEE0 0%, #2E96CC 100%);
	color: #FFFFFF;
	box-shadow: 0 6px 18px rgba(75, 174, 224, 0.35);
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li.is-active a::before {
	filter: brightness(0) invert(1);
	opacity: 1;
}

/* Logout : texte rouge */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--customer-logout {
	margin-top: auto;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--customer-logout a {
	color: #E63946;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--customer-logout a:hover {
	background: #FEF2F3;
	color: #E63946;
}

/* Force une liste flex-column pour pouvoir pousser le logout en bas */
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
	min-height: calc(100vh - 200px);
}

/* -------- MAIN CONTENT AREA -------- */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content {
	flex: 1 1 auto;
	background: transparent;
	border: none;
	border-radius: 0;
	padding: 32px 40px;
	box-shadow: none;
	max-width: none;
	min-width: 0;
	height: 100%;
	overflow-y: auto;
	animation: idc-myaccount-fade 0.4s ease both;
}

/* Formulaire edit-account / edit-address : compacter et centrer
   Flexbox avec wrap → 2 par ligne, tolérant aux .clear divs de WC */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm,
body.woocommerce-account.logged-in form.edit-account,
body.woocommerce-account.logged-in form.woocommerce-address-fields,
body.woocommerce-account.logged-in .woocommerce-Address form {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 16px 20px;
	align-items: flex-start;
}

/* Cache les .clear divs que WC insère entre les rows pour les floats */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm .clear,
body.woocommerce-account.logged-in form.woocommerce-address-fields .clear {
	display: none !important;
}

/* Toutes les rows prennent 50% - gap → 2 par ligne */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .form-row,
body.woocommerce-account.logged-in form.woocommerce-address-fields > .form-row,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .woocommerce-form-row {
	flex: 0 0 calc(50% - 10px);
	max-width: calc(50% - 10px);
	width: calc(50% - 10px) !important;
	margin: 0 !important;
	padding: 0;
	float: none !important;
	display: block;
	box-sizing: border-box;
}

/* Fieldset + bouton submit : pleine largeur */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > fieldset,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > p:has(button[type="submit"]),
body.woocommerce-account.logged-in form.woocommerce-address-fields > p:has(button[type="submit"]) {
	flex: 1 1 100%;
	max-width: 100%;
	width: 100%;
}

/* Fieldset "Changer le mot de passe" : flex wrap 2 par ligne aussi */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset {
	display: flex;
	flex-wrap: wrap;
	gap: 16px 20px;
	align-items: stretch;
}

/* Chaque .form-row devient une colonne flex pour que les inputs
   s'alignent en bas quel que soit le nombre de lignes du label */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .form-row,
body.woocommerce-account.logged-in form.woocommerce-address-fields > .form-row {
	display: flex;
	flex-direction: column;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row label,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .form-row label,
body.woocommerce-account.logged-in form.woocommerce-address-fields > .form-row label {
	flex: 1 0 auto;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row .input-text,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row input,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row .password-input,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .form-row .input-text,
body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .form-row input,
body.woocommerce-account.logged-in form.woocommerce-address-fields > .form-row .input-text,
body.woocommerce-account.logged-in form.woocommerce-address-fields > .form-row input {
	margin-top: auto;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .clear {
	display: none !important;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset legend {
	flex: 1 1 100%;
	max-width: 100%;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row {
	flex: 0 0 calc(50% - 10px);
	max-width: calc(50% - 10px);
	width: calc(50% - 10px) !important;
	margin: 0 !important;
}

/* Le mot de passe actuel seul sur une ligne (plus intuitif) */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row:first-of-type {
	flex: 1 1 100%;
	max-width: 100%;
	width: 100% !important;
}

/* Page orders : "Aucune commande" + bouton "Parcourir les produits"
   → conteneur plus compact et centré */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-info,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-Message,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-notice--info {
	max-width: 520px;
	margin: 40px auto;
	text-align: center;
	padding: 32px 28px;
	border-radius: 16px;
	background: #FFFFFF;
	border: 1px solid #E2EFF7;
	border-left: 5px solid #4BAEE0;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03), 0 10px 30px rgba(75, 174, 224, 0.08);
	font-family: "Nunito Sans", sans-serif;
	font-size: 15px;
	color: #1A1A1A;
	line-height: 1.6;
}

/* Bouton "Parcourir les produits" dans la notice */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-info .button,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-info a.wc-forward {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 16px;
	padding: 14px 32px;
	background: linear-gradient(135deg, #4BAEE0 0%, #2E96CC 100%);
	color: #FFFFFF !important;
	border: none;
	border-radius: 50px;
	font-family: "Nunito", sans-serif;
	font-size: 14px;
	font-weight: 800;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	text-decoration: none;
	box-shadow: 0 6px 18px rgba(75, 174, 224, 0.35);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	float: none !important;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-info .button:hover,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .woocommerce-info a.wc-forward:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 26px rgba(75, 174, 224, 0.45);
}

/* Section "Changer le mot de passe" avec un espacement plus généreux */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset {
	border: 1px solid #E2EFF7;
	border-radius: 12px;
	padding: 20px 24px;
	margin: 24px 0 16px;
	background: #F8FBFD;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset legend {
	font-family: "Nunito", sans-serif;
	font-weight: 800;
	font-size: 14px;
	color: #1A1A1A;
	padding: 0 12px;
	background: #FFFFFF;
	border-radius: 20px;
	border: 1px solid #E2EFF7;
	margin-left: -4px;
}

/* Bouton submit centré */
body.woocommerce-account.logged-in .woocommerce-EditAccountForm p:has(button[type="submit"]),
body.woocommerce-account.logged-in form.woocommerce-address-fields p:has(button[type="submit"]) {
	text-align: center;
	margin-top: 24px;
}

body.woocommerce-account.logged-in .woocommerce-EditAccountForm button[type="submit"],
body.woocommerce-account.logged-in form.woocommerce-address-fields button[type="submit"] {
	width: auto !important;
	max-width: 360px;
	padding: 16px 48px !important;
}

/* Sur mobile, une seule colonne */
@media (max-width: 640px) {
	body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .form-row,
	body.woocommerce-account.logged-in .woocommerce-EditAccountForm > .woocommerce-form-row,
	body.woocommerce-account.logged-in form.woocommerce-address-fields > .form-row,
	body.woocommerce-account.logged-in .woocommerce-EditAccountForm fieldset .form-row {
		flex: 1 1 100% !important;
		max-width: 100% !important;
		width: 100% !important;
	}
}

/* Card wrapper pour le contenu */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content > * {
	background: #FFFFFF;
	border: 1px solid #E2EFF7;
	border-radius: 16px;
	padding: 32px 36px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03), 0 10px 30px rgba(75, 174, 224, 0.06);
	margin-bottom: 20px;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content > h2,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content > h3,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content > p:first-child {
	background: transparent;
	border: none;
	padding: 0;
	box-shadow: none;
	margin-bottom: 20px;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content h2,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content h3:first-child,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content > h2:first-child {
	font-family: "Nunito", sans-serif;
	font-weight: 900;
	font-size: 30px;
	color: #1A1A1A;
	margin: 0 0 24px;
	letter-spacing: -0.02em;
	text-align: center;
	padding-bottom: 18px;
	border-bottom: 2px solid #E2EFF7;
	position: relative;
}

/* Petite barre terra décorative sous le titre centré */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content h2::after,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content > h2:first-child::after {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 2px;
	background: linear-gradient(90deg, #4BAEE0, #2E96CC);
	border-radius: 2px;
}

/* Tables orders + downloads */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-family: "Nunito Sans", sans-serif;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content table thead th {
	background: #F4F8FB;
	font-family: "Nunito", sans-serif;
	font-weight: 800;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #1A1A1A;
	padding: 14px 16px;
	text-align: left;
	border-bottom: 2px solid #E2EFF7;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content table tbody td {
	padding: 16px;
	border-bottom: 1px solid #E2EFF7;
	font-size: 14px;
	color: #1A1A1A;
	vertical-align: middle;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content table tbody tr:hover {
	background: #F8FBFD;
}

/* Boutons dans les tables */
body.woocommerce-account.logged-in .woocommerce-MyAccount-content table .button,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .button {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background: #4BAEE0;
	color: #FFFFFF !important;
	border: none;
	border-radius: 50px;
	font-family: "Nunito", sans-serif;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
	transition: background 0.2s ease, transform 0.2s ease;
}

body.woocommerce-account.logged-in .woocommerce-MyAccount-content table .button:hover,
body.woocommerce-account.logged-in .woocommerce-MyAccount-content .button:hover {
	background: #2E96CC;
	transform: translateY(-1px);
}

/* ============================================================
   RESPONSIVE dashboard — Sidebar → Fixed bottom bar (tablet/mobile)
   Icônes seules + tooltip au survol avec le nom du menu.
   ============================================================ */
@media (max-width: 900px) {
	/* Libère le lock full-screen desktop : la page scrolle normalement */
	body.woocommerce-account.logged-in #page {
		height: auto !important;
		min-height: 100vh;
		overflow: visible !important;
	}
	body.woocommerce-account.logged-in #content.site-content {
		overflow: visible !important;
		min-height: 0;
	}
	body.woocommerce-account.logged-in #content.site-content > .ast-container {
		min-height: 0;
	}

	/* Layout container : colonne, nav flottante hors flux */
	body.woocommerce-account.logged-in .woocommerce {
		flex-direction: column;
		min-height: auto;
		overflow: visible;
		height: auto;
	}

	/* Empêche le contenu d'être caché derrière la bottom bar */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-content {
		padding: 24px 16px 100px;
		flex: 1 1 auto;
	}

	/* -------- BOTTOM BAR -------- */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
		position: fixed !important;
		bottom: 0;
		left: 0;
		right: 0;
		width: 100% !important;
		min-width: 0;
		height: 72px;
		padding: 0;
		margin: 0;
		background: #FFFFFF;
		border-right: none;
		border-top: 1px solid #E2EFF7;
		box-shadow: 0 -6px 24px rgba(75, 174, 224, 0.12);
		z-index: 100;
		overflow: visible;
		display: flex;
		flex-direction: row;
		align-items: center;
	}

	/* Masquer le titre "Espace client" */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation::before {
		display: none;
	}

	/* UL : row, items équi-répartis */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
		display: flex;
		flex-direction: row;
		align-items: stretch;
		justify-content: space-around;
		width: 100%;
		min-height: 0;
		height: 100%;
		gap: 0;
		padding: 0 8px;
		margin: 0;
	}

	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li {
		flex: 1 1 0;
		min-width: 0;
		display: flex;
		align-items: center;
		justify-content: center;
	}

	/* Logout : plus d'alignement bas, reste dans la row */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--customer-logout {
		margin-top: 0;
	}

	/* -------- Lien : icône seule, texte masqué via font-size 0 -------- */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 0;
		width: 48px;
		height: 48px;
		padding: 0;
		border-radius: 14px;
		font-size: 0;  /* masque le texte de l'endpoint */
		line-height: 0;
		position: relative;
		transform: none !important;
	}

	/* Icône SVG : on force la taille car le parent est en font-size 0 */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a::before {
		width: 22px;
		height: 22px;
		opacity: 0.75;
	}

	/* État actif : carré arrondi terra, icône blanche */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li.is-active a {
		background: linear-gradient(135deg, #4BAEE0 0%, #2E96CC 100%);
		color: #fff;
		box-shadow: 0 6px 16px rgba(75, 174, 224, 0.35);
		transform: translateY(-2px) !important;
	}

	/* Hover : fond cream clair */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a:hover {
		background: #F4F8FB;
		transform: none !important;
	}
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li.is-active a:hover {
		background: linear-gradient(135deg, #2E96CC 0%, #1F7FB3 100%);
		transform: translateY(-2px) !important;
	}

	/* -------- TOOLTIP au survol -------- */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a::after {
		position: absolute;
		bottom: calc(100% + 10px);
		left: 50%;
		transform: translateX(-50%) translateY(4px);
		padding: 6px 12px;
		background: #1A1A1A;
		color: #fff;
		font-family: "Nunito", sans-serif;
		font-size: 12px;
		font-weight: 700;
		line-height: 1;
		letter-spacing: 0.01em;
		border-radius: 8px;
		white-space: nowrap;
		opacity: 0;
		pointer-events: none;
		transition: opacity 0.2s ease, transform 0.2s ease;
		z-index: 110;
		box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
	}

	/* Flèche du tooltip */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a:hover::after,
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a:focus::after {
		opacity: 1;
		transform: translateX(-50%) translateY(0);
	}

	/* Contenu des tooltips par endpoint */
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--dashboard a::after { content: "Tableau de bord"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--orders a::after { content: "Commandes"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--downloads a::after { content: "Téléchargements"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--edit-address a::after { content: "Adresses"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--payment-methods a::after { content: "Paiement"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--edit-account a::after { content: "Mon compte"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--wishlist a::after { content: "Favoris"; }
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation-link--customer-logout a::after { content: "Déconnexion"; }

	/* Padding bottom du body pour que la bottom bar ne masque pas le footer */
	body.woocommerce-account.logged-in {
		padding-bottom: 72px;
	}

	/* Masquer le mini footer (copyright + paiements) sur la page mon-compte
	   en tablette/mobile — évite la redondance avec la bottom bar fixée */
	body.woocommerce-account.logged-in .idc-footer__bottom,
	body.woocommerce-account.logged-in .idc-footer__newsletter {
		display: none;
	}
}

/* Petits écrans : réduire tooltip et tailles pour tenir */
@media (max-width: 420px) {
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
		height: 64px;
	}
	body.woocommerce-account.logged-in {
		padding-bottom: 64px;
	}
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a {
		width: 42px;
		height: 42px;
		border-radius: 12px;
	}
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation li a::before {
		width: 20px;
		height: 20px;
	}
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
		padding: 0 4px;
	}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
	body.woocommerce-account:not(.logged-in) .woocommerce .u-columns.col2-set {
		grid-template-columns: 1fr;
	}

	body.woocommerce-account.logged-in .woocommerce-account .woocommerce {
		grid-template-columns: 1fr;
	}

	.woocommerce-account .woocommerce-form-login,
	.woocommerce-account .woocommerce-form-register {
		padding: 32px 24px;
	}

	.woocommerce-account .woocommerce h2 {
		font-size: 24px;
	}
}

/* ============================================================
   ACCESSIBILITÉ
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
	.woocommerce-account .woocommerce-form-login,
	.woocommerce-account .woocommerce-form-register,
	.woocommerce-account .woocommerce-form-login::before,
	.woocommerce-account .woocommerce-form-register::before {
		animation: none !important;
	}
	.woocommerce-account .woocommerce-form-login__submit,
	.woocommerce-account .woocommerce-form-register__submit {
		transition: none !important;
	}
}
