:root {
  --bg: #0f0e0d;
  --bg-soft: #1a1817;
  --bg-card: #211e1c;
  --text: #f2ede9;
  --text-dim: #a59d96;
  --accent: #E8A0BF;
  --danger: #d96459;
  --radius: 16px;
  --border: #322d2a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}

body { display: flex; flex-direction: column; min-height: 100vh; }
a { color: var(--accent); }

.container { width: 100%; max-width: 640px; margin: 0 auto; padding: 20px; }

/* --- Splash / sélection --- */
.splash { text-align: center; padding: 48px 20px 24px; }
.splash h1 { font-size: 2.4rem; letter-spacing: 0.5px; }
.splash p { color: var(--text-dim); margin-top: 8px; }

.persona-grid { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media (min-width: 520px) { .persona-grid { grid-template-columns: 1fr 1fr; } }

.persona-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease;
  text-align: left;
}
.persona-card:hover { transform: translateY(-2px); }
.persona-card .emoji { font-size: 1.8rem; }
.persona-card h3 { margin-top: 8px; font-size: 1.15rem; }
.persona-card .meta { color: var(--text-dim); font-size: .82rem; margin-top: 2px; }
.persona-card .tagline { margin-top: 8px; font-size: .9rem; color: var(--text); }
.persona-card .tags { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font-size: .72rem; padding: 3px 8px; border-radius: 999px; background: var(--bg-soft); color: var(--text-dim); }

/* --- Boutons --- */
.btn {
  display: inline-block; border: none; cursor: pointer;
  background: var(--accent); color: #1a0f15;
  font-weight: 600; padding: 12px 18px; border-radius: 12px; font-size: .95rem;
}
.btn:disabled { opacity: .5; cursor: default; }
.btn-ghost { background: transparent; color: var(--text); border: 1px solid var(--border); }

/* --- Chat --- */
.chat-page { display: flex; flex-direction: column; height: 100vh; }
.chat-header {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; border-bottom: 1px solid var(--border); background: var(--bg-soft);
}
.chat-header .back { background: none; border: none; color: var(--text); font-size: 1.3rem; cursor: pointer; }
.chat-header .who { flex: 1; }
.chat-header .who h2 { font-size: 1rem; }
.chat-header .who .meta { font-size: .76rem; color: var(--text-dim); }

/* Badge IA permanent (garde-fou éthique) */
.ia-badge {
  font-size: .68rem; font-weight: 700; letter-spacing: .5px;
  background: var(--bg-card); color: var(--text-dim);
  border: 1px solid var(--border); padding: 4px 8px; border-radius: 999px;
}

/* Bandeau 3114 (détresse) */
.banner-3114 {
  display: none; background: #2a1714; color: #ffd9d2;
  border-bottom: 1px solid #4a2820; padding: 10px 16px; font-size: .85rem; line-height: 1.4;
}
.banner-3114.show { display: block; }
.banner-3114 strong { color: #ff9b8e; }

.messages { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.msg { max-width: 80%; padding: 10px 14px; border-radius: 14px; font-size: .95rem; line-height: 1.4; white-space: pre-wrap; word-wrap: break-word; }
.msg.user { align-self: flex-end; background: var(--accent); color: #1a0f15; border-bottom-right-radius: 4px; }
.msg.assistant { align-self: flex-start; background: var(--bg-card); border: 1px solid var(--border); border-bottom-left-radius: 4px; }
.msg.system { align-self: center; background: transparent; color: var(--text-dim); font-size: .8rem; font-style: italic; }
.typing { align-self: flex-start; color: var(--text-dim); font-size: .85rem; padding: 4px 14px; }

/* Bulle portrait révélé en chat (photo imprimée qui se développe) */
.photoMsg { align-self: flex-start; background: #fbf7ec; padding: 10px 10px 12px; border-radius: 3px; box-shadow: 0 14px 34px rgba(0,0,0,.5); width: 200px; transform: rotate(-2deg); }
.photoMsg .photoImg { border-radius: 2px; overflow: hidden; filter: blur(9px) grayscale(1) brightness(1.25); opacity: .4; transition: filter 1.8s ease, opacity 1.3s; min-height: 120px; background: #2a2522; }
.photoMsg.dev .photoImg { filter: none; opacity: 1; }
.photoMsg .photoImg img { width: 100%; display: block; }
.photoMsg .photoCap { margin-top: 8px; text-align: center; font-family: Georgia, serif; font-style: italic; font-size: .95rem; color: #3a3128; }
.photoMsg .photoCap .gen { display: block; font-style: normal; font-size: .56rem; letter-spacing: .5px; color: #9a8c78; margin-top: 3px; text-transform: uppercase; }

.composer { display: flex; gap: 8px; padding: 12px; border-top: 1px solid var(--border); background: var(--bg-soft); align-items: flex-end; }
.composer textarea {
  flex: 1; resize: none; background: var(--bg-card); color: var(--text);
  border: 1px solid var(--border); border-radius: 12px; padding: 10px 12px; font-size: .95rem; max-height: 120px;
}
.composer .icon-btn { background: var(--bg-card); border: 1px solid var(--border); color: var(--text); border-radius: 12px; padding: 10px 12px; cursor: pointer; font-size: 1.1rem; }

/* Limite quota */
.quota-note { display: none; text-align: center; padding: 12px; color: var(--text-dim); font-size: .85rem; border-top: 1px solid var(--border); }
.quota-note.show { display: block; }

/* Formulaires (age-verify) */
.form-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; margin-top: 24px; }
.form-card h2 { margin-bottom: 12px; }
.form-card label { display: block; margin: 14px 0 6px; font-size: .9rem; color: var(--text-dim); }
.form-card input[type="date"], .form-card input[type="email"], .form-card input[type="password"] {
  width: 100%; background: var(--bg-soft); color: var(--text); border: 1px solid var(--border); border-radius: 10px; padding: 10px;
}
.checkbox-row { display: flex; gap: 10px; align-items: flex-start; margin-top: 16px; font-size: .9rem; }
.error { color: var(--danger); font-size: .85rem; margin-top: 10px; min-height: 1em; }
.muted { color: var(--text-dim); font-size: .82rem; }
.center { text-align: center; }

/* --- Admin modération --- */
.admin-bar { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-bottom: 1px solid var(--border); background: var(--bg-soft); position: sticky; top: 0; z-index: 5; }
.admin-bar h1 { font-size: 1.1rem; flex: 1; }
.admin-bar .count { font-size: .8rem; color: var(--text-dim); }
.mod-grid { display: grid; gap: 16px; grid-template-columns: 1fr; padding: 16px; }
@media (min-width: 560px) { .mod-grid { grid-template-columns: 1fr 1fr; } }
.mod-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; display: flex; flex-direction: column; }
.mod-card .thumb { width: 100%; aspect-ratio: 4/3; object-fit: cover; background: #000; display: block; }
.mod-card .info { padding: 12px 14px; font-size: .82rem; color: var(--text-dim); flex: 1; }
.mod-card .info b { color: var(--text); }
.mod-card .actions { display: flex; gap: 8px; padding: 0 14px 14px; }
.mod-card .actions .btn { flex: 1; padding: 10px; font-size: .9rem; }
.btn-danger { background: var(--danger); color: #fff; }
.mod-card .result { padding: 10px 14px; font-size: .85rem; border-top: 1px solid var(--border); white-space: pre-wrap; }
.empty-state { text-align: center; color: var(--text-dim); padding: 60px 20px; }
.login-box { max-width: 360px; margin: 60px auto; }
.spinner { display: inline-block; width: 14px; height: 14px; border: 2px solid var(--text-dim); border-top-color: transparent; border-radius: 50%; animation: spin .7s linear infinite; vertical-align: middle; }
@keyframes spin { to { transform: rotate(360deg); } }
