/* ════════════════════════════════════════════════════════════════════
   SydePlay — Styles PARTAGÉS : grille, cartes de réaction, popup
   ════════════════════════════════════════════════════════════════════
   Utilisé partout où l'on affiche des réactions (feed, découverte,
   abonnements). Inclure avec :
     <link rel="stylesheet" href="/shared/reaction-ui.css" />
   ════════════════════════════════════════════════════════════════════ */

/* ── Grille responsive ── */
.reaction-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}

/* ── Carte de réaction ── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden; cursor: pointer;
  transition: transform .15s, border-color .15s;
}
.card:hover { transform: translateY(-2px); border-color: var(--border-2); }

.card-cover {
  position: relative; aspect-ratio: 16/9;
  background: linear-gradient(135deg, #2a3a4a, #1a2230);
  display: flex; align-items: center; justify-content: center;
}
.card-cover img { width: 100%; height: 100%; object-fit: cover; }
.card-cover .cover-letter { font-size: 32px; font-weight: 800; color: rgba(255,255,255,.18); }

/* badges sur la jaquette */
.card-badges { position: absolute; top: 8px; left: 8px; right: 8px;
  display: flex; gap: 6px; align-items: center; }
.badge {
  font-size: 10px; font-weight: 700; padding: 3px 7px; border-radius: 6px;
  background: rgba(0,0,0,.6); color: #fff; backdrop-filter: blur(4px);
}
.badge-platform { text-transform: capitalize; }
.badge-free { background: var(--accent); color: #4A2721; }
.badge-price { background: rgba(0,0,0,.6); color: var(--accent); }
.badge-lock { margin-left: auto; background: rgba(0,0,0,.6); }
.card-duration { position: absolute; bottom: 8px; right: 8px;
  font-size: 10px; padding: 2px 6px; border-radius: 5px;
  background: rgba(0,0,0,.7); color: #fff; }

/* étiquette Nouveau / Tendance */
.tag { position: absolute; bottom: 8px; left: 8px;
  font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 6px; }
.tag-new { background: var(--accent); color: #4A2721; }
.tag-trend { background: rgba(0,0,0,.7); color: #ffb347; }

/* bouton favori */
.fav-btn { position: absolute; bottom: 8px; right: 8px;
  background: rgba(0,0,0,.55); border: none; border-radius: 50%;
  width: 30px; height: 30px; cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center; }
.card-cover:has(.card-duration) .fav-btn { right: 64px; }
.fav-btn:hover { background: rgba(0,0,0,.8); }

/* étoiles */
.card-stars { display: flex; align-items: center; gap: 6px; margin-top: 8px; }
.card-stars .st { color: #ffc24b; font-size: 12px; letter-spacing: 1px; }
.card-stars .st-num { font-size: 11px; color: var(--text-dim); }

.card-body { padding: 11px 13px; }
.card-show { font-size: 13px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-ep { font-size: 11px; color: var(--text-dim); margin: 2px 0 9px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-creator-row { display: flex; align-items: center; gap: 8px; }
.card-avatar { width: 22px; height: 22px; border-radius: 50%;
  background: var(--purple); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700; flex-shrink: 0; }
.avatar-img { object-fit: cover; }
.card-creator { font-size: 12px; color: var(--text); }
.card-views { margin-left: auto; font-size: 11px; color: var(--text-mut); }

.card-footer { display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin-top: 9px; padding-top: 9px; border-top: 1px solid var(--border); }
.card-price { font-size: 12px; font-weight: 700; color: var(--text); }
.card-price .sep { color: var(--text-mut); margin: 0 2px; }
.card-date { font-size: 11px; color: var(--text-mut); white-space: nowrap; }

/* ── États (chargement / vide / erreur) d'une grille ── */
.grid-state { text-align: center; color: var(--text-dim); padding: 60px 20px; }
.grid-state .big { font-size: 40px; margin-bottom: 12px; }

/* ── Popup de lancement ── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,.6); backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.modal-overlay[hidden] { display: none; }
.modal {
  position: relative; width: 100%; max-width: 440px;
  background: var(--surface); border: 1px solid var(--border-2);
  border-radius: var(--radius-lg); padding: 22px; }
.modal-close { position: absolute; top: 14px; right: 14px;
  background: none; border: none; color: var(--text-dim);
  font-size: 16px; cursor: pointer; }
.modal-cover { position: relative; aspect-ratio: 16/9; border-radius: var(--radius);
  overflow: hidden; margin-bottom: 14px;
  display: flex; align-items: center; justify-content: center; }
.modal-cover img { width: 100%; height: 100%; object-fit: cover; }
.modal-cover .cover-letter { font-size: 44px; font-weight: 800; color: rgba(255,255,255,.18); }
.modal-cover-dur { position: absolute; bottom: 8px; right: 8px;
  font-size: 11px; padding: 2px 7px; border-radius: 5px;
  background: rgba(0,0,0,.7); color: #fff; }

.modal-show { font-size: 18px; font-weight: 700; }
.modal-ep { color: var(--text-dim); font-size: 13px; margin: 2px 0 12px; }

.modal-creator { display: flex; align-items: center; gap: 10px;
  padding: 8px; margin: 12px 0 14px; border-radius: var(--radius);
  background: var(--surface-2); text-decoration: none; }
.modal-creator:hover { filter: brightness(1.1); }
.modal-creator .card-avatar { width: 30px; height: 30px; font-size: 11px; }
.mc-name { display: block; font-size: 13px; font-weight: 600; color: var(--text); }
.mc-view { display: block; font-size: 11px; color: var(--accent); }

.modal-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.modal-meta .badge { background: var(--surface-2); color: var(--text); }

.modal-access { font-size: 13px; margin-bottom: 12px; }
.modal-access.ok { color: var(--accent); font-weight: 600; }
.modal-access.pay { color: var(--text-dim); }

.btn-launch {
  width: 100%; padding: 12px; border: none; border-radius: var(--radius);
  background: var(--accent); color: #4A2721; font-size: 14px; font-weight: 700;
  cursor: pointer; font-family: inherit; }
.btn-launch:hover { filter: brightness(1.05); }

.pay-options { display: flex; flex-direction: column; gap: 8px; }
.btn-pay { display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-radius: var(--radius); cursor: pointer;
  font-family: inherit; font-size: 13px; text-align: left;
  background: var(--surface-2); border: 1px solid var(--border-2); color: var(--text); }
.btn-pay:hover { border-color: var(--accent); }
.btn-pay .amt { font-weight: 700; color: var(--accent); }
.btn-pay.sub { background: var(--accent-bg); border-color: var(--accent); }

.btn-share { width: 100%; margin-top: 10px; padding: 10px;
  border: 1px solid var(--border-2); border-radius: var(--radius);
  background: var(--surface-2); color: var(--text-dim);
  font-family: inherit; font-size: 13px; cursor: pointer; }
.btn-share:hover { color: var(--text); border-color: var(--accent); }
