/* SHIPPED! — Web layout global
   =============================================================================
   Palette inspirée d'Atlassian design system (mode sombre), reprise de
   l'extension pour cohérence visuelle. */

:root {
	--bg-base:    #0D1117;
	--bg-panel:   #1D2125;
	--bg-elev:   #22272B;
	--bg-elev-2: #2C333A;
	--border:     #2C333A;
	--border-2:   #3B444C;
	--text:       #DEE4EA;
	--text-muted: #8C9BAB;
	--text-dim:   #6B7680;
	--primary:    #579DFF;
	--primary-dark: #0C66E4;
	--accent:     #6E40C9;
	--warn:       #FF7452;
	--good:       #7EE2B8;
	--radius:     10px;
}

* { box-sizing: border-box; }

html, body {
	margin: 0; padding: 0;
	background: var(--bg-base);
	color: var(--text);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	font-size: 14px;
	line-height: 1.5;
	min-height: 100vh;
}

button { font-family: inherit; }

#jcg-app {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

/* ─── Écran de boot ─────────────────────────────────────────────────────── */
.jcg-boot {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	gap: 16px;
}
.jcg-boot-logo {
	font-size: 64px;
	animation: jcg-pulse 1.5s ease-in-out infinite;
}
.jcg-boot-text {
	color: var(--text-muted);
	font-size: 14px;
}
@keyframes jcg-pulse {
	0%, 100% { opacity: 0.6; transform: scale(1); }
	50%      { opacity: 1;   transform: scale(1.08); }
}

/* ─── Header ────────────────────────────────────────────────────────────── */
.jcg-header {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 10px 24px;
	background: var(--bg-panel);
	border-bottom: 1px solid var(--border);
	position: sticky;
	top: 0;
	z-index: 100;
}
.jcg-header-brand {
	display: flex;
	align-items: center;
	gap: 8px;
}
.jcg-brand-logo { font-size: 22px; }
.jcg-brand-name {
	font-weight: 900;
	font-size: 16px;
	letter-spacing: 0.04em;
	background: linear-gradient(135deg, var(--primary-dark), var(--accent));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.jcg-nav {
	display: flex;
	gap: 4px;
	flex: 1;
}
.jcg-tab {
	background: transparent;
	border: none;
	color: var(--text-muted);
	font-size: 13px;
	font-weight: 600;
	padding: 8px 14px;
	border-radius: 8px;
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}
.jcg-tab:hover { background: var(--bg-elev); color: var(--text); }
.jcg-tab.active { background: var(--bg-elev); color: var(--primary); }

.jcg-header-user {
	display: flex;
	align-items: center;
	gap: 10px;
}
.jcg-booster-badge {
	background: var(--bg-elev);
	border: 1px solid var(--border);
	border-radius: 20px;
	padding: 5px 10px;
	font-size: 12px;
	font-weight: 700;
}
.jcg-user-name {
	font-size: 13px;
	font-weight: 600;
	color: var(--text);
	max-width: 180px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.jcg-header-btn {
	background: var(--bg-elev);
	border: 1px solid var(--border-2);
	color: var(--text);
	padding: 6px 12px;
	border-radius: 6px;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}
.jcg-header-btn:hover { background: var(--bg-elev-2); border-color: var(--primary); }

/* ─── Main content ──────────────────────────────────────────────────────── */
.jcg-main {
	flex: 1;
	max-width: 1400px;
	width: 100%;
	margin: 0 auto;
	padding: 24px;
}
.jcg-page {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.jcg-page-title {
	font-size: 20px;
	font-weight: 800;
	color: var(--text);
	margin: 0;
}
.jcg-page-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

/* ─── Boutons globaux ───────────────────────────────────────────────────── */
.jcg-btn-primary {
	background: linear-gradient(135deg, var(--primary-dark), var(--accent));
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 10px 18px;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity 0.15s, transform 0.1s;
}
.jcg-btn-primary:hover:not(:disabled)  { opacity: 0.9; }
.jcg-btn-primary:active:not(:disabled) { transform: translateY(1px); }
.jcg-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }

.jcg-btn-secondary {
	background: var(--bg-elev);
	color: var(--text);
	border: 1px solid var(--border-2);
	border-radius: 8px;
	padding: 10px 18px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
}
.jcg-btn-secondary:hover { background: var(--bg-elev-2); }

/* ─── Collection (grid de cartes) ───────────────────────────────────────── */
.jcg-cards-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 12px;
}
.jcg-empty {
	text-align: center;
	color: var(--text-muted);
	padding: 40px 20px;
	background: var(--bg-panel);
	border: 1px dashed var(--border-2);
	border-radius: var(--radius);
}
.jcg-card-fallback {
	background: var(--bg-elev);
	padding: 16px;
	border-radius: 8px;
}

/* ─── Overlay modale générique ──────────────────────────────────────────── */
.jcg-modal-overlay {
	position: fixed; inset: 0;
	background: rgba(0, 0, 0, 0.75);
	z-index: 1000;
	display: flex; align-items: center; justify-content: center;
	padding: 20px;
	backdrop-filter: blur(4px);
}
.jcg-modal {
	background: var(--bg-panel);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 24px;
	max-width: 440px; width: 100%;
	display: flex; flex-direction: column; gap: 14px;
}
.jcg-modal h3 {
	margin: 0;
	font-size: 16px;
	font-weight: 700;
}
.jcg-modal p {
	margin: 0;
	color: var(--text-muted);
	line-height: 1.5;
}

/* ─── Booster reveal ────────────────────────────────────────────────────── */
.jcg-reveal-overlay {
	position: fixed; inset: 0;
	background: rgba(0, 0, 0, 0.92);
	z-index: 2000;
	display: flex; flex-direction: column; align-items: center;
	justify-content: flex-start;       /* content en haut → bouton toujours atteignable par scroll */
	gap: 24px;
	padding: 40px 20px 120px;          /* padding-bottom = place pour bouton sticky */
	overflow-y: auto;
}
/* Bouton "Voir ma collection" toujours visible en bas (sticky) */
.jcg-reveal-overlay .jcg-btn-primary {
	position: sticky;
	bottom: 16px;
	z-index: 1;
	box-shadow: 0 4px 16px rgba(0,0,0,0.5);
}
/* Croix de fermeture backup en haut à droite */
.jcg-reveal-close-x {
	position: fixed;
	top: 16px; right: 20px;
	background: rgba(44, 51, 58, 0.85);
	color: #DEE4EA;
	border: 1px solid #3B444C;
	width: 36px; height: 36px;
	border-radius: 50%;
	font-size: 18px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	z-index: 2001;
}
.jcg-reveal-close-x:hover { background: rgba(59, 68, 76, 0.95); }
.jcg-reveal-overlay h2 {
	color: #fff;
	font-size: 26px;
	font-weight: 800;
	margin: 0;
}
.jcg-reveal-grid {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 1200px;
}

/* ─── Ban / Erreur full-screen ──────────────────────────────────────────── */
.jcg-banned-screen, .jcg-error-screen {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	padding: 40px 20px;
	text-align: center;
	gap: 14px;
}
.jcg-banned-screen .jcg-banned-icon,
.jcg-error-screen > div:first-child {
	font-size: 56px;
}
.jcg-banned-screen h1, .jcg-error-screen h2 {
	color: var(--warn);
	font-size: 22px;
	margin: 0;
}
.jcg-banned-screen p, .jcg-error-screen p {
	color: var(--text-muted);
	max-width: 480px;
	margin: 0;
}

/* ─── Adapter les styles de modules hérités du panel extension ───────────── */
/* Les modules portés (DeckBuilder, Matchmaking, AdminPanel, GameBoard) injectent
   leurs propres styles scopés via class selectors. Ils s'intègrent naturellement
   dans le layout web grâce à la structure identique. */

/* Responsive : header compact sur mobile */
@media (max-width: 720px) {
	.jcg-header {
		flex-wrap: wrap;
		padding: 10px 14px;
		gap: 10px;
	}
	.jcg-nav {
		order: 3;
		width: 100%;
		overflow-x: auto;
	}
	.jcg-tab { white-space: nowrap; }
	.jcg-main { padding: 16px; }
	.jcg-user-name { max-width: 100px; }
}
