/* ============================================================
   EL RAMON MUSIC CLUB — Styles communs des sous-pages
   Chargé en complément de styles.css sur les pages /pages/*.html
   ============================================================ */

/* --- Hero des sous-pages --- */
.page-hero {
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 120px var(--space-md) var(--space-3xl);
  background: var(--grad-hero);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% 40%, rgba(255,107,107,0.15) 0%, transparent 55%),
              radial-gradient(ellipse at 30% 60%, rgba(255,215,0,0.12) 0%, transparent 50%);
  pointer-events: none;
}
.page-hero-emoji {
  font-size: 4rem;
  margin-bottom: var(--space-md);
  display: block;
  animation: float-parrot 4s ease-in-out infinite;
}
.page-hero h1 {
  font-size: clamp(2.2rem, 6vw, 4rem);
  font-weight: 900;
  margin-bottom: var(--space-sm);
}
.page-hero p {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.75);
  max-width: 600px;
  margin: 0 auto;
}

/* --- Carte d'intro (icône + texte) --- */
.intro-card {
  background: linear-gradient(135deg, rgba(255,215,0,0.08) 0%, rgba(255,140,0,0.06) 100%);
  border: 1px solid rgba(255,215,0,0.2);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  display: flex;
  gap: var(--space-xl);
  align-items: flex-start;
}
.intro-icon { font-size: 3rem; flex-shrink: 0; }
.intro-text h2 { font-size: 1.6rem; color: var(--yellow-sun); margin-bottom: var(--space-sm); }
.intro-text p { color: rgba(255,255,255,0.8); line-height: 1.8; }

/* --- Section alternée --- */
.section-alt { background: rgba(22,33,62,0.5); }

/* --- Grille de ressources générique --- */
.resource-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-xl);
}
.resource-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
  transition: all var(--transition-mid);
}
.resource-card:hover {
  border-color: rgba(255,215,0,0.25);
  transform: translateY(-4px);
}
.resource-icon { font-size: 2.2rem; margin-bottom: 0.5rem; display:block; }
.resource-title { font-size: 0.95rem; font-weight: 700; color: var(--white-light); margin-bottom: 0.3rem; }
.resource-desc { font-size: 0.82rem; color: rgba(255,255,255,0.55); line-height: 1.5; }
.resource-badge {
  display: inline-block; font-size: 0.72rem; font-weight: 600;
  color: var(--orange-tropical); background: rgba(255,140,0,0.1);
  border: 1px solid rgba(255,140,0,0.3); border-radius: var(--radius-full);
  padding: 0.2rem 0.8rem; margin-top: 0.6rem;
}
.resource-badge-live {
  display: inline-block; font-size: 0.72rem; font-weight: 600;
  color: var(--palm-green); background: rgba(46,204,113,0.1);
  border: 1px solid rgba(46,204,113,0.3); border-radius: var(--radius-full);
  padding: 0.2rem 0.8rem; margin-top: 0.6rem;
}

/* --- Placeholder "en préparation" --- */
.tab-placeholder {
  background: rgba(255,255,255,0.04);
  border: 2px dashed rgba(255,255,255,0.15);
  border-radius: var(--radius-xl);
  padding: var(--space-3xl) var(--space-xl);
  text-align: center;
}
.tab-placeholder-icon { font-size: 4rem; margin-bottom: var(--space-lg); display:block; }

/* --- Étapes numérotées --- */
.steps-card {
  background: rgba(15,52,96,0.4);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
}
.steps-card h2 { font-size: 1.8rem; margin-bottom: var(--space-xl); color: var(--yellow-sun); }
.steps-list { display: flex; flex-direction: column; gap: var(--space-md); }
.step-item {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
  background: rgba(255,255,255,0.04);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  border: 1px solid rgba(255,255,255,0.07);
  transition: all var(--transition-mid);
}
.step-item:hover { border-color: rgba(255,215,0,0.25); transform: translateX(6px); }
.step-number {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--grad-warm);
  color: var(--night-blue);
  font-weight: 900; font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.step-content h3 { font-size: 1rem; font-weight: 700; margin-bottom: 0.3rem; color: var(--white-light); }
.step-content p { font-size: 0.9rem; color: rgba(255,255,255,0.65); line-height: 1.6; }

/* --- Grille de pratiques (guides) --- */
.practices-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-xl);
}
.practice-card {
  background: rgba(0,206,209,0.06);
  border: 1px solid rgba(0,206,209,0.2);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  transition: all var(--transition-mid);
}
.practice-card:hover { background: rgba(0,206,209,0.12); transform: translateY(-4px); }
.practice-card .practice-icon { font-size: 1.8rem; margin-bottom: 0.6rem; }
.practice-card h3 { font-size: 1rem; font-weight: 700; color: var(--turquoise); margin-bottom: 0.4rem; }
.practice-card p { font-size: 0.88rem; color: rgba(255,255,255,0.7); line-height: 1.6; }

/* --- CTA encadré --- */
.cta-suno {
  background: linear-gradient(135deg, rgba(255,215,0,0.12) 0%, rgba(255,140,0,0.08) 100%);
  border: 2px solid rgba(255,215,0,0.3);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  text-align: center;
}
.cta-suno h2 { font-size: 2rem; margin-bottom: var(--space-sm); }
.cta-suno p { color: rgba(255,255,255,0.75); margin-bottom: var(--space-xl); font-size: 1.05rem; }

/* --- Cartes PDF --- */
.pdf-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-xl);
}
.pdf-card {
  background: rgba(255,255,255,0.04);
  border: 1px dashed rgba(255,255,255,0.2);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  text-align: center;
  transition: all var(--transition-mid);
}
.pdf-card:hover { border-style: solid; border-color: rgba(255,215,0,0.3); }
.pdf-card .pdf-icon { font-size: 2.2rem; margin-bottom: 0.6rem; }
.pdf-card h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 0.4rem; }
.pdf-card .badge-soon {
  display: inline-block; font-size: 0.75rem; font-weight: 600;
  color: var(--orange-tropical); background: rgba(255,140,0,0.1);
  border: 1px solid rgba(255,140,0,0.3); border-radius: var(--radius-full);
  padding: 0.2rem 0.8rem; margin-top: 0.6rem;
}

/* --- Exemple de prompt --- */
.prompt-example {
  background: rgba(26,26,46,0.8);
  border: 1px solid rgba(46,204,113,0.25);
  border-left: 4px solid var(--palm-green);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
  font-family: 'Courier New', monospace;
  font-size: 0.9rem;
  color: var(--palm-green);
}
.prompt-example::before {
  content: 'PROMPT EXEMPLE';
  display: block;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
  color: var(--palm-green); margin-bottom: 0.5rem; opacity: 0.7;
}

/* ============================================================
   DISCOGRAPHIE — Styles spécifiques
   ============================================================ */

/* --- Grille des albums --- */
.discog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

/* --- Carte album --- */
.album-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition-mid);
  display: flex;
  flex-direction: column;
}
.album-card:hover {
  border-color: rgba(255,215,0,0.3);
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(255,140,0,0.15);
}
.album-cover {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  transition: transform var(--transition-mid);
}
.album-card:hover .album-cover {
  transform: scale(1.05);
}
.album-info {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  flex: 1;
}
.album-info h3 {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--white-light);
  margin-bottom: 0.4rem;
}
.album-meta {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.6rem;
}
.album-type {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--night-blue);
  background: var(--yellow-sun);
  padding: 0.15rem 0.6rem;
  border-radius: var(--radius-full);
}
.album-style {
  font-size: 0.75rem;
  color: var(--turquoise);
}
.album-desc {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.6;
  margin-bottom: var(--space-sm);
  flex: 1;
}
.album-links {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: auto;
}
.album-links a {
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
  padding: 0.35rem 0.7rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  transition: all var(--transition-fast);
}
.album-links a:hover {
  background: rgba(255,215,0,0.15);
  border-color: rgba(255,215,0,0.3);
}

/* --- Plateformes (réseaux + outils) --- */
.discog-platforms {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: center;
}
.platform-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: var(--space-md);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--white-light);
  font-size: 0.85rem;
  font-weight: 600;
  min-width: 110px;
  transition: all var(--transition-mid);
}
.platform-link:hover {
  transform: translateY(-4px);
  border-color: rgba(255,215,0,0.3);
  background: rgba(255,215,0,0.06);
}
.platform-icon {
  font-size: 1.8rem;
}

/* ============================================================
   BIBLIOTHÈQUE DE PROMPTS — 3 niveaux
   ============================================================ */

/* --- Onglets de niveau --- */
.level-tabs {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
}
.level-tab {
  padding: 0.7rem 1.4rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.7);
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-mid);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.level-tab:hover {
  border-color: rgba(255,215,0,0.3);
  color: var(--white-light);
}
.level-tab.active {
  background: var(--grad-warm);
  color: var(--night-blue);
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(255,140,0,0.25);
}
.level-tab .level-count {
  font-size: 0.7rem;
  background: rgba(0,0,0,0.2);
  padding: 0.1rem 0.5rem;
  border-radius: var(--radius-full);
}
.level-tab.active .level-count {
  background: rgba(26,26,46,0.2);
}

/* --- Section niveau (panneau) --- */
.level-panel { display: none; }
.level-panel.active { display: block; animation: fadeInUp 0.4s ease; }

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

/* --- Bandeau d'info niveau --- */
.level-banner {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}
.level-banner-discover {
  background: rgba(46,204,113,0.08);
  border: 1px solid rgba(46,204,113,0.2);
}
.level-banner-studio {
  background: rgba(0,206,209,0.08);
  border: 1px solid rgba(0,206,209,0.2);
}
.level-banner-pro {
  background: rgba(255,215,0,0.08);
  border: 1px solid rgba(255,215,0,0.2);
}
.level-banner-icon { font-size: 2rem; flex-shrink: 0; }
.level-banner-text h3 { font-size: 1rem; font-weight: 800; margin-bottom: 0.2rem; }
.level-banner-text p { font-size: 0.85rem; color: rgba(255,255,255,0.65); margin: 0; }

/* --- Filtres par catégorie --- */
.category-filter {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: var(--space-xl);
}
.filter-btn {
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.7);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.filter-btn:hover {
  border-color: rgba(255,215,0,0.3);
  color: var(--white-light);
}
.filter-btn.active {
  background: rgba(255,215,0,0.15);
  border-color: rgba(255,215,0,0.4);
  color: var(--yellow-sun);
}

/* --- Grille de prompts --- */
.prompts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-md);
}

/* --- Carte prompt (Découverte & Studio) --- */
.prompt-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  transition: all var(--transition-mid);
}
.prompt-card:hover {
  border-color: rgba(255,215,0,0.25);
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(0,0,0,0.2);
}
.prompt-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}
.prompt-card-title {
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--white-light);
}
.prompt-card-tag {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.15rem 0.6rem;
  border-radius: var(--radius-full);
  white-space: nowrap;
}
.tag-afrobeat { background: rgba(255,107,107,0.15); color: var(--coral-red); }
.tag-zouk { background: rgba(255,107,157,0.15); color: #FF6B9D; }
.tag-compas { background: rgba(255,140,0,0.15); color: var(--orange-sun); }
.tag-tropical { background: rgba(46,204,113,0.15); color: var(--palm-green); }
.tag-reggaeton { background: rgba(255,215,0,0.15); color: var(--yellow-sun); }
.tag-instrumental { background: rgba(0,206,209,0.15); color: var(--turquoise); }
.tag-studio { background: rgba(141,110,99,0.2); color: #B39DDB; }

.prompt-card-text {
  font-family: 'Courier New', monospace;
  font-size: 0.82rem;
  line-height: 1.6;
  color: var(--palm-green);
  background: rgba(26,26,46,0.6);
  border-left: 3px solid var(--palm-green);
  padding: 0.7rem;
  border-radius: var(--radius-sm);
}
.prompt-card-desc {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
  flex: 1;
}
.prompt-card-meta {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}
.prompt-meta-chip {
  font-size: 0.7rem;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.6);
}
.prompt-card-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin-top: 0.3rem;
}
.btn-copy {
  padding: 0.45rem 1rem;
  border: none;
  border-radius: var(--radius-full);
  background: var(--grad-warm);
  color: var(--night-blue);
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}
.btn-copy:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 16px rgba(255,140,0,0.3);
}
.btn-copy.copied {
  background: linear-gradient(135deg, #2ECC71 0%, #00CED1 100%);
  color: var(--white-light);
}
.btn-copy-lg {
  padding: 0.55rem 1.3rem;
  font-size: 0.85rem;
}

/* --- Carte Pro (verrouillée) --- */
.prompt-card-locked {
  background: rgba(255,255,255,0.02);
  border: 1px dashed rgba(255,215,0,0.25);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  position: relative;
  overflow: hidden;
}
.prompt-card-locked::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 20px,
    rgba(255,215,0,0.02) 20px,
    rgba(255,215,0,0.02) 40px
  );
  pointer-events: none;
}
.prompt-card-locked > * { position: relative; z-index: 1; }
.prompt-locked-title {
  font-size: 0.95rem;
  font-weight: 800;
  color: rgba(255,255,255,0.5);
}
.prompt-locked-desc {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.4);
  line-height: 1.6;
  flex: 1;
}
.prompt-locked-blur {
  font-family: 'Courier New', monospace;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.3);
  background: rgba(26,26,46,0.4);
  border-left: 3px solid rgba(255,215,0,0.3);
  padding: 0.7rem;
  border-radius: var(--radius-sm);
  filter: blur(3px);
  user-select: none;
}
.prompt-locked-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--yellow-sun);
  background: rgba(255,215,0,0.1);
  border: 1px solid rgba(255,215,0,0.3);
  padding: 0.3rem 0.8rem;
  border-radius: var(--radius-full);
  align-self: flex-start;
}

/* --- Bloc de déblocage Pro --- */
.pro-unlock-cta {
  text-align: center;
  padding: var(--space-2xl);
  background: linear-gradient(135deg, rgba(255,215,0,0.06) 0%, rgba(255,140,0,0.04) 100%);
  border: 2px solid rgba(255,215,0,0.2);
  border-radius: var(--radius-xl);
  margin-top: var(--space-xl);
}
.pro-unlock-cta h3 {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--yellow-sun);
  margin-bottom: var(--space-sm);
}
.pro-unlock-cta p {
  color: rgba(255,255,255,0.7);
  margin-bottom: var(--space-lg);
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .intro-card { flex-direction: column; gap: var(--space-md); }
  .discog-grid { grid-template-columns: 1fr; }
  .prompts-grid { grid-template-columns: 1fr; }
  .level-banner { flex-direction: column; text-align: center; }
}
