/*!
 * Copyright (c) 2024-2026 Entreprises Miron & Co. All rights reserved.
 * Mon Académie — Dashboard élève AcadémieCo
 * Palette pop art / neon (alignée Arène)
 * Principes Calm UX 2026 appliqués hors contexte de jeu
 */

.ma-root {
	/* ─── Tokens (pop art / neon) ─── */
	--aca-bg-deep:     #0f0f1e;
	--aca-bg-1:        #1a1a2e;
	--aca-bg-2:        #22223e;
	--aca-border:      rgba(255, 255, 255, 0.08);

	--aca-pink:        #e94560;
	--aca-pink-glow:   rgba(233, 69, 96, 0.4);
	--aca-blue:        #0f3460;
	--aca-blue-2:      #2a5298;
	--aca-yellow:      #f5c518;
	--aca-yellow-glow: rgba(245, 197, 24, 0.5);
	--aca-cyan:        #00d2ff;
	--aca-cyan-glow:   rgba(0, 210, 255, 0.4);
	--aca-purple:      #b44aff;
	--aca-purple-glow: rgba(180, 74, 255, 0.4);
	--aca-green:       #52d060;
	--aca-green-glow:  rgba(82, 208, 96, 0.4);

	--aca-text:        #ffffff;
	--aca-text-dim:    #b0bace;
	--aca-text-muted:  #6a7490;

	--aca-radius:      16px;
	--aca-radius-sm:   10px;
	--aca-font:        'Nunito', 'Segoe UI', system-ui, sans-serif;
	--aca-motion-fast: 120ms;
	--aca-motion-base: 220ms;

	background: var(--aca-bg-1);
	color: var(--aca-text);
	font-family: var(--aca-font);
	border-radius: var(--aca-radius);
	overflow: hidden;
	max-width: 1100px;
	margin: 0 auto;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
}

.ma-root *, .ma-root *::before, .ma-root *::after {
	box-sizing: border-box;
}

.ma-root :focus-visible {
	outline: 2px solid var(--aca-cyan);
	outline-offset: 2px;
	border-radius: var(--aca-radius-sm);
}

/* ─── Login gate ─── */
.ma-login-gate {
	padding: 40px 20px;
	text-align: center;
}
.ma-login-gate p { margin: 0 0 16px; color: var(--aca-text-dim); }

/* ─── Hero banner ─── */
.ma-hero {
	position: relative;
	padding: 32px 24px 40px;
	background: linear-gradient(135deg, #2a1a4e 0%, #1a1a2e 50%, #0f3460 100%);
	overflow: hidden;
}
.ma-hero::before {
	content: '';
	position: absolute;
	top: -50%; right: -20%;
	width: 500px; height: 500px;
	background: radial-gradient(circle, var(--aca-pink-glow) 0%, transparent 60%);
	pointer-events: none;
}
.ma-hero::after {
	content: '';
	position: absolute;
	bottom: -40%; left: -10%;
	width: 400px; height: 400px;
	background: radial-gradient(circle, var(--aca-cyan-glow) 0%, transparent 60%);
	pointer-events: none;
}
.ma-hero-inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	gap: 20px;
}
.ma-avatar {
	width: 96px; height: 96px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--aca-pink), var(--aca-purple));
	border: 4px solid var(--aca-yellow);
	box-shadow: 0 0 30px var(--aca-yellow-glow), inset 0 0 20px rgba(255, 255, 255, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.5rem;
	font-weight: 900;
	color: #fff;
	flex-shrink: 0;
	overflow: hidden;
}
.ma-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ma-avatar-fallback { text-transform: uppercase; }
.ma-hero-name {
	font-size: 1.6rem;
	font-weight: 900;
	letter-spacing: -0.01em;
	margin: 0 0 4px;
	color: #fff;
}
.ma-hero-title {
	font-size: 0.82rem;
	color: var(--aca-yellow);
	font-weight: 700;
	font-style: italic;
	text-shadow: 0 0 12px var(--aca-yellow-glow);
}

/* ─── Stats ─── */
.ma-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	padding: 20px 24px;
	background: var(--aca-bg-deep);
	border-bottom: 1px solid var(--aca-border);
}
.ma-stat {
	background: var(--aca-bg-2);
	border: 1px solid var(--aca-border);
	border-radius: var(--aca-radius-sm);
	padding: 14px 16px;
	position: relative;
	overflow: hidden;
}
.ma-stat::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
}
.ma-stat-xp::before { background: linear-gradient(90deg, var(--aca-cyan), var(--aca-blue-2)); }
.ma-stat-pierres::before { background: linear-gradient(90deg, var(--aca-yellow), var(--aca-pink)); }
.ma-stat-label {
	font-size: 0.72rem;
	color: var(--aca-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 700;
	margin-bottom: 4px;
}
.ma-stat-value {
	font-size: 1.6rem;
	font-weight: 900;
	letter-spacing: -0.02em;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

/* Icône Pierres (remplace l'emoji 💎) */
.ma-pierres-icon {
	width: 1.4em;
	height: 1.4em;
	object-fit: contain;
	display: inline-block;
	vertical-align: middle;
}
.ma-pierres-icon-fallback {
	font-size: 1em;
}
.ma-stat-sub {
	font-size: 0.75rem;
	color: var(--aca-text-dim);
	margin-top: 4px;
}
.ma-xp-bar {
	height: 6px;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 3px;
	overflow: hidden;
	margin-top: 8px;
}
.ma-xp-bar-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--aca-cyan), var(--aca-blue-2));
	box-shadow: 0 0 8px var(--aca-cyan-glow);
	border-radius: 3px;
	transition: width var(--aca-motion-base) ease-out;
}

/* ─── Sections ─── */
.ma-section {
	padding: 20px 24px;
	border-bottom: 1px solid var(--aca-border);
}
.ma-section:last-child { border-bottom: none; }
.ma-section-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 16px;
	gap: 12px;
}
.ma-section-title {
	font-size: 1.1rem;
	font-weight: 800;
	letter-spacing: -0.01em;
	margin: 0;
}
.ma-section-title span {
	background: linear-gradient(90deg, var(--aca-pink), var(--aca-yellow));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.ma-link {
	font-size: 0.8rem;
	color: var(--aca-cyan);
	text-decoration: none;
	font-weight: 700;
	letter-spacing: 0.02em;
	transition: opacity var(--aca-motion-fast);
}
.ma-link:hover { opacity: 0.8; text-decoration: underline; }

.ma-empty {
	padding: 20px 10px;
	text-align: center;
	color: var(--aca-text-muted);
	font-size: 0.9rem;
}

/* ─── Daily shop ─── */
.ma-shop-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}
.ma-shop-card {
	aspect-ratio: 1;
	background: var(--aca-bg-2);
	border: 2px solid var(--aca-border);
	border-radius: var(--aca-radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	position: relative;
	overflow: hidden;
	transition: transform var(--aca-motion-fast);
}
.ma-shop-card img {
	width: 80%;
	height: 80%;
	object-fit: cover;
	border-radius: 8px;
}
.ma-shop-placeholder {
	font-weight: 900;
	color: var(--aca-text-dim);
}

/* Carte de titre — le nom est écrit dans le carré et s'auto-ajuste */
.ma-shop-card-title {
	padding: 10px;
	align-items: stretch;
}
.ma-shop-title-text {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-style: italic;
	font-weight: 700;
	line-height: 1.15;
	color: var(--aca-text);
	word-break: break-word;
	hyphens: auto;
	padding: 4px 6px 24px;
	/* La taille de police est ajustée dynamiquement par JS (data-autofit) */
	font-size: 1rem;
}

/* Couleur du texte selon la rareté de la carte */
.ma-shop-card-title.ma-rarity-common    .ma-shop-title-text { color: #d0d5e0; }
.ma-shop-card-title.ma-rarity-rare      .ma-shop-title-text { color: var(--aca-cyan); }
.ma-shop-card-title.ma-rarity-epic      .ma-shop-title-text { color: #cc88ff; }
.ma-shop-card-title.ma-rarity-legendary .ma-shop-title-text { color: var(--aca-yellow); }

.ma-shop-cost {
	position: absolute;
	bottom: 4px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--aca-yellow);
	color: #000;
	font-size: 0.65rem;
	font-weight: 900;
	padding: 2px 8px;
	border-radius: 10px;
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	gap: 3px;
	z-index: 2;
}
.ma-shop-cost .ma-pierres-icon {
	width: 11px;
	height: 11px;
}
.ma-shop-card:hover { transform: translateY(-3px); }

/* ─── Rarity ─── */
.ma-rarity-rare      { border-color: var(--aca-cyan);   box-shadow: 0 0 12px var(--aca-cyan-glow); }
.ma-rarity-epic      { border-color: var(--aca-purple); box-shadow: 0 0 12px var(--aca-purple-glow); }
.ma-rarity-legendary { border-color: var(--aca-yellow); box-shadow: 0 0 15px var(--aca-yellow-glow); }

/* ─── Collection tabs ─── */
.ma-collection-tabs {
	display: flex;
	gap: 6px;
	margin-bottom: 12px;
}
.ma-tab {
	flex: 1;
	padding: 10px 12px;
	background: var(--aca-bg-2);
	border: 1px solid var(--aca-border);
	border-radius: var(--aca-radius-sm);
	color: var(--aca-text-dim);
	font-size: 0.85rem;
	font-weight: 700;
	text-align: center;
	cursor: pointer;
	font-family: inherit;
	transition: all var(--aca-motion-fast);
}
.ma-tab:hover { background: rgba(255, 255, 255, 0.06); }
.ma-tab.active {
	background: var(--aca-pink);
	color: #fff;
	border-color: var(--aca-pink);
	box-shadow: 0 0 15px var(--aca-pink-glow);
}

/* ─── Avatar collection grid ─── */
.ma-collection-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}
.ma-col-item {
	aspect-ratio: 1;
	background: var(--aca-bg-2);
	border: 2px solid var(--aca-border);
	border-radius: var(--aca-radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.6rem;
	position: relative;
	overflow: hidden;
	cursor: pointer;
	padding: 0;
	font-family: inherit;
	color: inherit;
	transition: transform var(--aca-motion-fast), border-color var(--aca-motion-fast), box-shadow var(--aca-motion-fast);
}
.ma-col-item:hover:not(.equipped):not(:disabled) {
	transform: translateY(-2px);
	border-color: var(--aca-cyan);
	box-shadow: 0 0 10px var(--aca-cyan-glow);
}
.ma-col-item:disabled {
	opacity: 0.55;
	cursor: wait;
}
.ma-col-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ma-col-item.equipped {
	border-color: var(--aca-green) !important;
	box-shadow: 0 0 12px var(--aca-green-glow) !important;
}
.ma-col-item.equipped::after {
	content: '✓';
	position: absolute;
	top: 3px;
	right: 3px;
	background: var(--aca-green);
	color: #000;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	font-size: 0.7rem;
	font-weight: 900;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ─── Titles list ─── */
.ma-titles-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.ma-title-chip {
	padding: 8px 14px;
	background: var(--aca-bg-2);
	border: 1.5px solid var(--aca-border);
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 600;
	font-style: italic;
	color: var(--aca-text-dim);
	position: relative;
	cursor: pointer;
	font-family: inherit;
	transition: background var(--aca-motion-fast), border-color var(--aca-motion-fast), color var(--aca-motion-fast);
}
.ma-title-chip:disabled {
	opacity: 0.55;
	cursor: wait;
}

/* ─── Couleur de texte par rareté (titres) ─── */
.ma-title-chip.ma-rarity-common    { color: #d0d5e0; }
.ma-title-chip.ma-rarity-rare      { color: var(--aca-cyan); }
.ma-title-chip.ma-rarity-epic      { color: #cc88ff; }
.ma-title-chip.ma-rarity-legendary { color: var(--aca-yellow); }

.ma-title-chip:hover:not(.equipped):not(:disabled) {
	background: rgba(255, 255, 255, 0.06);
	filter: brightness(1.2);
}
.ma-title-chip.equipped {
	background: linear-gradient(135deg, rgba(82, 208, 96, 0.1), rgba(0, 210, 255, 0.1));
	border-color: var(--aca-green) !important;
	color: #fff;
	box-shadow: 0 0 10px var(--aca-green-glow);
}
.ma-title-equipped-badge {
	margin-left: 6px;
	color: var(--aca-green);
	font-weight: 900;
}

/* ─── Arena CTA ─── */
.ma-arena-cta {
	display: block;
	position: relative;
	padding: 24px;
	text-align: center;
	border-radius: var(--aca-radius);
	overflow: hidden;
	text-decoration: none;
	color: #fff;
	background: linear-gradient(135deg, var(--aca-pink) 0%, #7b2c8a 100%);
	box-shadow: 0 10px 40px var(--aca-pink-glow);
	transition: transform var(--aca-motion-base);
}
.ma-arena-cta::before {
	content: '⚔️';
	position: absolute;
	top: -20px;
	right: -10px;
	font-size: 6rem;
	opacity: 0.15;
	transform: rotate(15deg);
	pointer-events: none;
}
.ma-arena-cta:hover { transform: translateY(-2px); }
.ma-arena-content { position: relative; z-index: 1; }
.ma-arena-title {
	font-size: 1.3rem;
	font-weight: 900;
	margin: 0 0 6px;
	letter-spacing: -0.01em;
}
.ma-arena-desc {
	font-size: 0.88rem;
	color: rgba(255, 255, 255, 0.9);
	margin: 0 0 16px;
}
.ma-arena-btn {
	display: inline-block;
	padding: 12px 24px;
	background: #fff;
	color: var(--aca-pink);
	border-radius: 10px;
	font-weight: 900;
	font-size: 0.95rem;
	text-decoration: none;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* ─── Parent link ─── */
.ma-parent-link {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px;
	background: var(--aca-bg-2);
	border-radius: var(--aca-radius-sm);
	border: 1px solid var(--aca-border);
	text-decoration: none;
	color: inherit;
	transition: background var(--aca-motion-fast), border-color var(--aca-motion-fast);
}
.ma-parent-link:hover {
	background: rgba(255, 255, 255, 0.04);
	border-color: var(--aca-yellow);
}
.ma-parent-icon {
	width: 44px; height: 44px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--aca-yellow), var(--aca-pink));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
	flex-shrink: 0;
}
.ma-parent-label { flex: 1; }
.ma-parent-label strong { display: block; font-size: 0.95rem; color: var(--aca-text); }
.ma-parent-label span { font-size: 0.78rem; color: var(--aca-text-muted); }
.ma-parent-arrow { color: var(--aca-text-muted); font-size: 1.2rem; }

/* ─── Activity ─── */
.ma-activity {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.ma-activity-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	background: var(--aca-bg-2);
	border-radius: var(--aca-radius-sm);
	border-left: 3px solid var(--aca-cyan);
	font-size: 0.85rem;
	flex-wrap: wrap;
}
.ma-activity-xp       { border-left-color: var(--aca-cyan); }
.ma-activity-arena    { border-left-color: var(--aca-pink); }
.ma-activity-pierres  { border-left-color: var(--aca-yellow); }
.ma-activity-purchase { border-left-color: var(--aca-purple); }
.ma-activity-item strong { font-weight: 800; color: var(--aca-text); }
.ma-activity-desc { color: var(--aca-text-dim); flex: 1; }
.ma-activity-time {
	margin-left: auto;
	color: var(--aca-text-muted);
	font-size: 0.72rem;
}

/* ─── Responsive desktop ─── */
@media (min-width: 768px) {
	.ma-hero { padding: 48px 40px 56px; }
	.ma-hero-name { font-size: 2.2rem; }
	.ma-stats { padding: 24px 40px; }
	.ma-section { padding: 32px 40px; }
	.ma-shop-grid { grid-template-columns: repeat(6, 1fr); }
	.ma-collection-grid { grid-template-columns: repeat(8, 1fr); }
}

/* ─── Equip feedback ─── */
.ma-equip-flash {
	animation: ma-flash 0.7s ease-out;
}
@keyframes ma-flash {
	0%   { box-shadow: 0 0 0 0 var(--aca-green-glow); }
	40%  { box-shadow: 0 0 20px 8px var(--aca-green-glow); }
	100% { box-shadow: 0 0 0 0 rgba(82, 208, 96, 0); }
}

.ma-equip-error {
	animation: ma-error 0.4s ease-out;
	border-color: var(--aca-pink) !important;
}
@keyframes ma-error {
	0%, 100% { transform: translateX(0); }
	25%      { transform: translateX(-4px); }
	75%      { transform: translateX(4px); }
}

/* ─── Reduced motion ─── */
@media (prefers-reduced-motion: reduce) {
	.ma-shop-card, .ma-arena-cta, .ma-parent-link, .ma-xp-bar-fill,
	.ma-col-item, .ma-title-chip {
		transition: none !important;
	}
	.ma-equip-flash, .ma-equip-error {
		animation: none !important;
	}
}
