/* =========================================================
   BASE — reset + layout global
   Ce fichier définit la structure commune à toutes les pages.
   Pour les couleurs/thèmes, voir themes.css
   Pour les éléments réutilisables, voir components.css
   ========================================================= */

/* --- RESET --- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* --- CORPS DE PAGE --- */
body {
  min-height: 100vh;
  background-color: var(--bg-color);
  background-image:
    radial-gradient(circle at top right, var(--theme-soft), transparent),
    radial-gradient(circle at bottom left, var(--theme-fresh), transparent);
  color: var(--text-main);
  font-family: 'Plus Jakarta Sans', sans-serif;
  display: flex;
  justify-content: center;
  padding: 20px;
}

/* --- CARTE PRINCIPALE --- */
.page {
  position: relative;
  max-width: 850px;
  width: 100%;
  min-height: 90vh;
  background: var(--card-bg);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-page);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: var(--shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: fadeIn 1.2s ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- LOGO / HEADER --- */
.logo-wrapper {
  padding: 40px 20px 20px;
  text-align: center;
}
.logo-wrapper img {
  max-width: 100%;
  width: 440px;
  height: auto;
  transform: rotate(-2deg);
  filter: drop-shadow(0 10px 15px rgba(0, 0, 0, 0.08));
}
/* L'accueil a un angle de logo légèrement différent */
.page[data-page="home"] .logo-wrapper img {
  transform: rotate(-3deg);
}

/* --- ZONE DE CONTENU --- */
.content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  padding: 0 40px 40px;
}

/* --- LIEN RETOUR ACCUEIL --- */
.back-home {
  text-align: center;
  margin-bottom: 20px;
}
.back-home a {
  text-decoration: none;
  color: var(--accent-soft);
  font-size: 0.9rem;
  font-weight: 600;
}

/* --- RESPONSIVE COMMUN --- */
@media (max-width: 500px) {
  .page { border-radius: 20px; }
  .content { padding: 0 20px 30px; }
  .logo-wrapper img { width: 280px; }
}
