/* ============================================================
   UN SOURIRE POUR TOUS — Feuille de style commune
   Version 1.0 — Mode Sourire (jour) + Mode Doudou (nuit)
   ============================================================ */

/* ---- Variables globales ---- */
:root {
  /* Mode Sourire */
  --c-bg:       #e8f5e2;
  --c-surface:  rgba(255,255,255,0.65);
  --c-border:   rgba(255,255,255,0.75);
  --c-primary:  #4a9e50;
  --c-primary2: #2d7a30;
  --c-accent:   #f5c030;
  --c-text:     #1a3a1a;
  --c-text2:    #1e4a1e;
  --c-text3:    #4a7a4a;
  --c-shadow:   rgba(60,120,60,0.12);
  --c-glow:     rgba(74,158,80,0.3);
  --c-notif-border: #5ab85a;

  /* Typographie */
  --font-ui:    'Comfortaa', sans-serif;
  --font-body:  'Lora', serif;

  /* Layout */
  --radius:     1.4rem;
  --radius-sm:  0.85rem;
  --max-width:  440px;
  --transition: 0.4s cubic-bezier(0.34,1.56,0.64,1);
}

body.doudou {
  --c-bg:       #0a0a28;
  --c-surface:  rgba(18,18,60,0.72);
  --c-border:   rgba(100,90,200,0.3);
  --c-primary:  #7060c0;
  --c-primary2: #4840a0;
  --c-accent:   #f0c060;
  --c-text:     #d8e0ff;
  --c-text2:    #b0b8e8;
  --c-text3:    #7878b8;
  --c-shadow:   rgba(80,60,180,0.2);
  --c-glow:     rgba(112,96,192,0.35);
  --c-notif-border: #7060c0;
}

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

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--c-bg);
  color: var(--c-text);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background 1.2s ease, color 0.6s ease;
  -webkit-font-smoothing: antialiased;
}

/* ---- Layout page ---- */
.page {
  position: relative;
  z-index: 10;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 1rem 1rem 5rem;
  min-height: 100vh;
}

/* ---- Header ---- */
header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 1rem 0 0.8rem;
  gap: 0.5rem;
}

.logo-circle {
  width: 46px; height: 46px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
  background: radial-gradient(circle at 35% 35%, #fff8d0, #f5c030);
  box-shadow: 0 0 18px 6px rgba(245,192,48,0.4), 0 3px 10px rgba(0,0,0,0.1);
  animation: logoGlow 3s ease-in-out infinite;
  transition: background 1.2s, box-shadow 1.2s;
}
body.doudou .logo-circle {
  background: radial-gradient(circle at 35% 35%, #d0d8ff, #7060c0);
  box-shadow: 0 0 18px 6px rgba(112,96,192,0.5);
}
@keyframes logoGlow {
  0%,100% { box-shadow: 0 0 18px 6px rgba(245,192,48,0.35), 0 3px 10px rgba(0,0,0,0.1); }
  50%      { box-shadow: 0 0 28px 10px rgba(245,192,48,0.55), 0 3px 10px rgba(0,0,0,0.1); }
}

.site-name {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-text);
  line-height: 1.3;
  transition: color 1.2s;
}
.site-tagline {
  font-size: 0.68rem;
  color: var(--c-text3);
  font-style: italic;
  transition: color 1.2s;
}

.header-btns { display: flex; gap: 0.4rem; flex-wrap: wrap; justify-content: flex-end; }

/* ---- Boutons pill ---- */
.btn-pill {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.45rem 0.85rem;
  border-radius: 2rem;
  border: 1.5px solid var(--c-border);
  background: var(--c-surface);
  color: var(--c-text2);
  cursor: pointer;
  backdrop-filter: blur(8px);
  transition: all 0.3s;
  box-shadow: 0 2px 8px var(--c-shadow);
  white-space: nowrap;
}
.btn-pill:hover {
  background: var(--c-primary);
  color: white;
  border-color: transparent;
  transform: scale(1.05);
}

/* ---- Status bar ---- */
.status {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.5rem 0 1rem;
  padding: 0.55rem 0.9rem;
  border-radius: 2rem;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 600;
  background: var(--c-surface);
  backdrop-filter: blur(8px);
  border: 1px solid var(--c-border);
  box-shadow: 0 2px 10px var(--c-shadow);
  color: var(--c-text2);
  transition: all 1.2s;
}
.status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: blink 2s ease-in-out infinite;
}
.status.open .status-dot  { background: #4aaa50; box-shadow: 0 0 6px 2px rgba(74,170,80,0.5); }
.status.closed .status-dot { background: var(--c-primary); box-shadow: 0 0 6px 2px var(--c-glow); }
@keyframes blink {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:0.5; transform:scale(1.5); }
}

/* ---- Cards ---- */
.card {
  background: var(--c-surface);
  backdrop-filter: blur(14px);
  border-radius: var(--radius);
  border: 1.5px solid var(--c-border);
  padding: 1.3rem 1.2rem;
  margin-bottom: 0.9rem;
  box-shadow: 0 6px 28px var(--c-shadow), 0 1px 4px rgba(255,255,255,0.3) inset;
  transition: background 1.2s, border-color 1.2s, box-shadow 1.2s;
  animation: slideUp 0.5s cubic-bezier(.34,1.56,.64,1) both;
}
.card:nth-child(3) { animation-delay:0.1s; }
.card:nth-child(4) { animation-delay:0.2s; }
@keyframes slideUp {
  from { opacity:0; transform:translateY(20px) scale(0.97); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}

.card-head { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.2rem; }
.card-icon { font-size:1.1rem; }
.card-title {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-text);
  transition: color 1.2s;
}
.card-sub {
  font-size: 0.77rem;
  color: var(--c-text3);
  font-style: italic;
  margin-bottom: 0.9rem;
  transition: color 1.2s;
}

/* ---- Catégories ---- */
.cats { display:flex; gap:0.45rem; margin-bottom:0.9rem; flex-wrap:wrap; }
.cat {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.38rem 0.85rem;
  border-radius: 2rem;
  border: 1.5px solid var(--c-border);
  background: transparent;
  color: var(--c-text2);
  cursor: pointer;
  transition: all var(--transition);
}
.cat:hover, .cat.on {
  background: linear-gradient(135deg, var(--c-primary), var(--c-primary2));
  color: white;
  border-color: transparent;
  transform: scale(1.08);
  box-shadow: 0 4px 14px var(--c-glow);
}

/* ---- Textarea ---- */
textarea {
  width: 100%;
  min-height: 96px;
  padding: 0.8rem 0.9rem;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--c-border);
  background: rgba(255,255,255,0.3);
  color: var(--c-text);
  font-family: var(--font-body);
  font-size: 0.88rem;
  line-height: 1.65;
  resize: none;
  transition: all 0.3s;
}
textarea:focus {
  outline: none;
  border-color: var(--c-primary);
  background: rgba(255,255,255,0.55);
  box-shadow: 0 0 0 3px var(--c-glow);
}
textarea::placeholder { color: var(--c-text3); font-style:italic; }

.char-row {
  text-align: right;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  color: var(--c-text3);
  margin: 0.3rem 0 0.7rem;
}

/* ---- Boutons action ---- */
.actions { display:flex; align-items:center; justify-content:space-between; gap:0.6rem; }

.btn-main {
  font-family: var(--font-ui);
  font-size: 0.88rem;
  font-weight: 700;
  padding: 0.7rem 1.6rem;
  border-radius: 2rem;
  border: none;
  background: linear-gradient(135deg, var(--c-primary), var(--c-primary2));
  color: white;
  cursor: pointer;
  box-shadow: 0 4px 18px var(--c-glow), 0 1px 3px rgba(0,0,0,0.1);
  transition: all var(--transition);
  letter-spacing: 0.02em;
}
.btn-main:hover {
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 8px 24px var(--c-glow);
}
.btn-main:active { transform: scale(0.97); }

.btn-sec {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0.65rem 1.1rem;
  border-radius: 2rem;
  border: 1.5px solid var(--c-border);
  background: transparent;
  color: var(--c-text3);
  cursor: pointer;
  transition: all 0.25s;
}
.btn-sec:hover { border-color: var(--c-primary); color: var(--c-primary); }

/* ---- Vote items ---- */
.vote-list { display:flex; flex-direction:column; gap:0.5rem; }
.vote-item {
  display:flex; align-items:center; gap:0.7rem;
  padding: 0.72rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--c-border);
  background: rgba(255,255,255,0.25);
  cursor: pointer;
  transition: all var(--transition);
}
.vote-item:hover {
  background: rgba(255,255,255,0.55);
  border-color: var(--c-primary);
  transform: translateX(4px);
  box-shadow: 0 3px 14px var(--c-shadow);
}
.vote-item.on {
  background: rgba(74,158,80,0.1);
  border-color: var(--c-primary);
  transform: translateX(4px);
  box-shadow: 0 3px 14px var(--c-glow);
}
body.doudou .vote-item.on { background: rgba(112,96,192,0.12); }

.vote-orb {
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 2px solid var(--c-border);
  flex-shrink: 0;
  display:flex; align-items:center; justify-content:center;
  transition: all 0.3s;
}
.vote-item.on .vote-orb {
  background: linear-gradient(135deg, var(--c-primary), var(--c-primary2));
  border-color: transparent;
  box-shadow: 0 0 8px var(--c-glow);
}
.vote-item.on .vote-orb::after {
  content:''; width:7px; height:7px;
  border-radius:50%; background:white;
}
.vote-txt {
  font-size: 0.84rem;
  font-style: italic;
  color: var(--c-text);
  line-height: 1.4;
  flex:1;
  transition: color 1.2s;
}
.vote-foot {
  display:flex; align-items:center;
  justify-content:space-between;
  margin-top: 0.75rem;
}
.vote-hint {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  color: var(--c-text3);
}

/* ---- Principe ---- */
.principe {
  text-align: center;
  font-size: 0.7rem;
  font-style: italic;
  color: var(--c-text3);
  padding: 0.5rem 0.5rem 0;
  line-height: 1.7;
  transition: color 1.2s;
}

/* ---- Barre basse ---- */
.bar-bottom {
  position: fixed;
  bottom:0; left:0; right:0;
  z-index: 20;
  background: var(--c-surface);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--c-border);
  padding: 0.55rem 1rem;
  display: flex; align-items:center; justify-content:center; gap:1.2rem;
  transition: background 1.2s, border-color 1.2s;
}
.bar-link {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--c-text3);
  text-decoration: none;
  transition: color 0.25s;
}
.bar-link:hover { color: var(--c-primary); }
.bar-sep { color: var(--c-border); }

/* ---- Notification ---- */
.notif {
  position: fixed;
  top: 1rem; left:50%;
  transform: translateX(-50%) translateY(-120px);
  background: var(--c-surface);
  backdrop-filter: blur(12px);
  border: 1px solid var(--c-border);
  border-left: 3px solid var(--c-notif-border);
  border-radius: var(--radius-sm);
  padding: 0.75rem 1.2rem;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--c-text);
  box-shadow: 0 8px 28px var(--c-shadow);
  z-index: 200;
  transition: transform 0.45s cubic-bezier(.34,1.56,.64,1);
  max-width: 300px;
  text-align: center;
  white-space: nowrap;
}
.notif.show { transform: translateX(-50%) translateY(0); }

/* ---- Filtre message doux ---- */
.filtre-msg {
  display: none;
  background: rgba(245,192,48,0.12);
  border: 1.5px solid rgba(245,192,48,0.4);
  border-radius: var(--radius-sm);
  padding: 0.8rem 1rem;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--c-text);
  margin-top: 0.6rem;
  line-height: 1.6;
  text-align: center;
  animation: slideUp 0.4s ease both;
}
.filtre-msg.show { display: block; }

/* ---- Doudou section ---- */
.doudou-section { display:none; }
body.doudou .doudou-section { display:block; }
body.doudou .write-section,
body.doudou .vote-section { display:none; }

.doudou-card { text-align:center; padding:2rem 1.2rem 1.8rem; }
.doudou-eyebrow {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-text3);
  margin-bottom: 1.4rem;
}
.doudou-sparkles { font-size:1rem; letter-spacing:0.3rem; margin-bottom:1.2rem; display:block; }
.doudou-quote {
  font-family: var(--font-body);
  font-size: 1.3rem;
  font-style: italic;
  font-weight: 600;
  color: var(--c-text);
  line-height: 1.75;
  margin-bottom: 1rem;
  position: relative;
  padding: 0.5rem 1rem;
}
.doudou-quote::before {
  content:'\201C';
  position:absolute; top:-0.8rem; left:0.2rem;
  font-size:5rem;
  color: var(--c-primary);
  opacity:0.2;
  font-family:Georgia,serif;
  line-height:1;
}
.doudou-cat-tag {
  display:inline-block;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-accent);
  border: 1px solid rgba(240,192,96,0.35);
  padding: 0.3rem 0.8rem;
  border-radius: 2rem;
  margin-bottom: 1.5rem;
  background: rgba(240,192,96,0.08);
}
.doudou-close-msg {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--c-text3);
  line-height: 1.7;
}

/* ---- Mode Voyager (plein écran) ---- */
.voyager-overlay {
  position: fixed;
  inset: 0;
  z-index: 500;
  background: transparent;
  display: none;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 2rem;
}
.voyager-overlay.actif { display: flex; }
.voyager-overlay .page { display:none; }
.btn-voyager-retour {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 700;
  padding: 0.7rem 1.6rem;
  border-radius: 2rem;
  border: 1.5px solid rgba(255,255,255,0.5);
  background: rgba(0,0,0,0.35);
  color: white;
  cursor: pointer;
  backdrop-filter: blur(8px);
  transition: all 0.3s;
}
.btn-voyager-retour:hover { background: rgba(0,0,0,0.6); }

/* ---- QR / Share ---- */
.share-zone {
  text-align:center;
  margin: 0.8rem 0;
}
.btn-share {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 700;
  padding: 0.6rem 1.4rem;
  border-radius: 2rem;
  border: 1.5px solid var(--c-border);
  background: var(--c-surface);
  color: var(--c-text2);
  cursor: pointer;
  transition: all 0.3s;
  backdrop-filter: blur(8px);
}
.btn-share:hover { background: var(--c-primary); color:white; border-color:transparent; }

/* ---- Admin ---- */
.admin-section { margin-bottom: 1.2rem; }
.admin-row {
  display:flex; align-items:center;
  justify-content:space-between;
  gap:0.8rem;
  padding: 0.7rem 0;
  border-bottom: 1px solid var(--c-border);
}
.admin-label {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--c-text);
}
.admin-hint {
  font-size: 0.7rem;
  color: var(--c-text3);
  font-style: italic;
}
.toggle {
  width: 44px; height: 24px;
  border-radius: 12px;
  background: var(--c-border);
  cursor: pointer;
  position:relative;
  transition: background 0.3s;
  flex-shrink:0;
  border:none;
}
.toggle.on { background: var(--c-primary); }
.toggle::after {
  content:'';
  position:absolute;
  width:18px; height:18px;
  border-radius:50%;
  background:white;
  top:3px; left:3px;
  transition: transform 0.3s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
.toggle.on::after { transform:translateX(20px); }

.input-field {
  width:100%;
  padding: 0.65rem 0.9rem;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--c-border);
  background: rgba(255,255,255,0.3);
  color: var(--c-text);
  font-family: var(--font-ui);
  font-size: 0.85rem;
  transition: all 0.3s;
}
.input-field:focus {
  outline:none;
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px var(--c-glow);
  background: rgba(255,255,255,0.5);
}

/* ---- Fancy fair ---- */
.fancy-wrap {
  position:fixed; inset:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2rem;
}
.fancy-msg {
  text-align:center;
  animation: fancyIn 1.2s ease both;
}
@keyframes fancyIn {
  from { opacity:0; transform:translateY(30px) scale(0.95); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.fancy-quote {
  font-family: var(--font-body);
  font-size: clamp(1.4rem, 4vw, 2.8rem);
  font-style:italic;
  font-weight:600;
  color:white;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
  line-height:1.6;
  margin-bottom:1rem;
}
.fancy-theme {
  font-family: var(--font-ui);
  font-size:0.85rem;
  font-weight:700;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color: var(--c-accent);
  text-shadow: 0 1px 8px rgba(0,0,0,0.4);
}
