/* ============================================================
   Cartons — feuille de style
   Palette : nuit de stade + couleurs officielles des cartons
   ============================================================ */
:root{
  --ink:#0F1115;        /* fond nuit */
  --panel:#1B1F27;      /* panneau */
  --panel-2:#232833;
  --line:#2C333F;
  --chalk:#E8E6E1;      /* texte clair (craie) */
  --muted:#8A93A2;
  --bg-glow:#1a2130;    /* halo du fond */
  --on-chalk:#0b0d10;   /* texte posé sur une surface --chalk */

  --vert:#2FBF71;
  --jaune:#F0A020;
  --rouge:#E23636;
  --violet:#7B3FF2;

  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.45);
  font-synthesis:none;
}

/* Thème clair : redéfinit les mêmes variables. Les couleurs de cartons
   restent identiques (elles sont l'identité du produit) mais sont
   légèrement assombries pour rester lisibles sur fond clair. */
:root[data-theme="light"]{
  --ink:#F3F1EC;
  --panel:#FFFFFF;
  --panel-2:#F0EEE8;
  --line:#DED9CF;
  --chalk:#1E2229;
  --muted:#6B7280;
  --bg-glow:#E7E3D8;
  --on-chalk:#FFFFFF;

  --vert:#1FA85F;
  --jaune:#D98A00;
  --rouge:#D12C2C;
  --violet:#6A2FE0;

  --shadow:0 8px 24px rgba(30,34,41,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(1200px 600px at 50% -10%, var(--bg-glow) 0%, var(--ink) 60%) fixed,
    var(--ink);
  color:var(--chalk);
  transition:background-color .2s ease, color .2s ease;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}

/* Type d'affichage : condensé, "tableau officiel" */
.display{
  font-family:"Archivo",system-ui,sans-serif;
  font-weight:800;
  letter-spacing:.01em;
  text-transform:uppercase;
}

.app{max-width:520px;margin:0 auto;padding:20px 16px 96px;min-height:100%}

/* ---------- En-tête ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:8px;
}
.brand{display:flex;align-items:center;gap:10px}
.logo-heart{display:block;flex:0 0 auto}
.logo-lg{display:flex;justify-content:center;margin-bottom:14px}
.brand h1{font-family:"Archivo";font-weight:800;font-size:20px;letter-spacing:.06em;text-transform:uppercase}
.who{font-size:13px;color:var(--muted)}
.who b{color:var(--chalk)}
.linkbtn{background:none;border:none;color:var(--muted);font:inherit;text-decoration:underline;cursor:pointer;padding:0}
.linkbtn:hover{color:var(--chalk)}
.theme-switch-row{display:flex;align-items:center;gap:10px;margin:2px 0 4px}
.theme-switch-row.center{justify-content:center;margin-top:18px}
.theme-lbl{font-family:"Archivo";text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700;color:var(--muted)}
.switch{
  position:relative;width:46px;height:26px;border-radius:20px;flex:0 0 auto;
  background:var(--panel-2);border:1px solid var(--line);cursor:pointer;padding:0;
  transition:background-color .18s ease, border-color .18s ease;
}
.switch-knob{
  position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;
  background:var(--chalk);transition:transform .18s ease;
}
.switch.on{background:var(--vert);border-color:var(--vert)}
.switch.on .switch-knob{transform:translateX(20px)}
.switch:focus-visible{outline:2px solid var(--chalk);outline-offset:2px}

.date-line{
  font-family:"Archivo";text-transform:uppercase;letter-spacing:.08em;
  font-size:12px;color:var(--muted);margin:2px 0 18px;
}

/* ---------- Cartes/panneaux ---------- */
.card{
  background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);
  margin-bottom:16px;
}
.card h2{font-family:"Archivo";font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:700}

/* ---------- Le carton (signature) ---------- */
.reveal-card{
  position:relative;border-radius:14px;padding:22px;color:#0b0d10;
  min-height:150px;display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.15), var(--shadow);
  overflow:hidden;
}
.reveal-card::after{ /* reflet oblique façon carton plastifié */
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,rgba(255,255,255,.22),transparent 40%);
  pointer-events:none;
}
.reveal-card .rc-label{font-family:"Archivo";text-transform:uppercase;letter-spacing:.1em;font-size:12px;opacity:.7}
.reveal-card .rc-title{font-family:"Archivo";text-transform:uppercase;font-weight:800;font-size:26px;line-height:1.05;margin-top:4px}
.reveal-card .rc-comment{font-size:15px;margin-top:14px;color:rgba(0,0,0,.78)}
.reveal-card.vert{background:var(--vert)}
.reveal-card.jaune{background:var(--jaune);color:#fff}
.reveal-card.jaune .rc-comment{color:rgba(255,255,255,.9)}
.reveal-card.rouge{background:var(--rouge);color:#fff}
.reveal-card.rouge .rc-comment{color:rgba(255,255,255,.9)}
.reveal-card.violet{background:var(--violet);color:#fff}
.reveal-card.violet .rc-comment{color:rgba(255,255,255,.9)}

/* Carte grisée "en attente" */
.reveal-card.pending{
  background:repeating-linear-gradient(45deg,var(--panel),var(--panel) 12px,var(--panel-2) 12px,var(--panel-2) 24px);
  color:var(--muted);box-shadow:inset 0 0 0 1px var(--line);
  align-items:center;justify-content:center;text-align:center;
}
.reveal-card.pending::after{display:none}
.reveal-card.pending .rc-title{color:var(--chalk);font-size:20px}
.reveal-card.pending .rc-sub{font-size:13px;margin-top:8px;max-width:34ch}
.reveal-card.pending .lock{font-size:26px;margin-bottom:6px}

/* ---------- Choix de carton ---------- */
.picker{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pick{
  border:2px solid transparent;border-radius:14px;padding:14px;cursor:pointer;
  color:#0b0d10;text-align:left;font-family:inherit;
  transition:transform .08s ease, box-shadow .15s ease, outline-color .15s;
  outline:3px solid transparent;outline-offset:2px;
}
.pick:active{transform:scale(.97)}
.pick .pk-t{font-family:"Archivo";text-transform:uppercase;font-weight:800;font-size:15px}
.pick .pk-d{font-size:12px;margin-top:4px;color:rgba(0,0,0,.7);line-height:1.35}
.pick.vert{background:var(--vert)}
.pick.jaune{background:var(--jaune);color:#fff}
.pick.jaune .pk-d{color:rgba(255,255,255,.85)}
.pick.rouge{background:var(--rouge);color:#fff}
.pick.rouge .pk-d{color:rgba(255,255,255,.85)}
.pick.violet{background:var(--violet);color:#fff}
.pick.violet .pk-d{color:rgba(255,255,255,.85)}
.pick[aria-pressed="true"]{outline-color:var(--chalk);box-shadow:0 0 0 2px var(--ink), 0 0 0 5px currentColor}

textarea{
  width:100%;margin-top:14px;background:var(--panel-2);color:var(--chalk);
  border:1px solid var(--line);border-radius:12px;padding:12px;font:inherit;resize:vertical;min-height:74px;
}
textarea::placeholder{color:var(--muted)}

/* ---------- Boutons ---------- */
.btn{
  width:100%;border:none;border-radius:12px;padding:14px 16px;cursor:pointer;
  font-family:"Archivo";text-transform:uppercase;letter-spacing:.06em;font-weight:800;font-size:15px;
  background:var(--chalk);color:var(--on-chalk);transition:opacity .15s, transform .08s;
}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.secondary{background:var(--panel-2);color:var(--chalk);border:1px solid var(--line)}
.btn.danger{background:var(--rouge);color:#fff}
.btn.small{width:auto;padding:9px 14px;font-size:13px}
.btn-row{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}

/* ---------- Onglets ---------- */
.tabs{display:flex;gap:8px;margin-bottom:16px}
.tab{
  flex:1;text-align:center;padding:11px;border-radius:12px;cursor:pointer;
  font-family:"Archivo";text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:700;
  background:var(--panel);border:1px solid var(--line);color:var(--muted);
}
.tab.active{background:var(--chalk);color:var(--on-chalk);border-color:var(--chalk)}

/* ---------- Historique ---------- */
.hist-item{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.hist-item:last-child{border-bottom:none}
.chip{width:14px;height:20px;border-radius:3px;flex:0 0 auto;margin-top:2px;transform:skewX(-8deg)}
.chip.vert{background:var(--vert)}.chip.jaune{background:var(--jaune)}.chip.rouge{background:var(--rouge)}.chip.violet{background:var(--violet)}
.hist-meta{font-family:"Archivo";text-transform:uppercase;letter-spacing:.05em;font-size:12px;color:var(--muted)}
.hist-c{font-size:14px;margin-top:2px}
.empty{color:var(--muted);font-size:14px;text-align:center;padding:18px 0}

/* ---------- Login ---------- */
.login-wrap{max-width:400px;margin:8vh auto 0;padding:0 16px}
.login-wrap .hero{text-align:center;margin-bottom:26px}
.login-wrap .hero .big{font-family:"Archivo";font-weight:800;font-size:34px;text-transform:uppercase;letter-spacing:.04em}
.login-wrap .hero .sub{color:var(--muted);font-size:14px;margin-top:6px}
input[type=text],input[type=password]{
  width:100%;background:var(--panel-2);color:var(--chalk);border:1px solid var(--line);
  border-radius:12px;padding:14px;font:inherit;margin-bottom:12px;
}
input::placeholder{color:var(--muted)}

/* ---------- Admin ---------- */
.user-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.user-row:last-child{border-bottom:none}
.badge{font-family:"Archivo";font-size:10px;letter-spacing:.08em;text-transform:uppercase;background:var(--panel-2);border:1px solid var(--line);color:var(--muted);padding:2px 7px;border-radius:20px}

/* ---------- Réglages (select) ---------- */
.fld-label{display:block;font-family:"Archivo";text-transform:uppercase;letter-spacing:.05em;font-size:11px;color:var(--muted);margin:12px 0 6px}
.select{
  width:100%;background:var(--panel-2);color:var(--chalk);border:1px solid var(--line);
  border-radius:12px;padding:13px;font:inherit;
  appearance:none;-webkit-appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 20px) 20px,calc(100% - 14px) 20px;background-size:6px 6px,6px 6px;background-repeat:no-repeat;
}
.set-preview{color:var(--muted);font-size:13px;margin-top:14px;line-height:1.5}
.notif-desc{color:var(--muted);font-size:14px;margin-bottom:12px;line-height:1.5}

/* ---------- Notices ---------- */
.notice{border-radius:12px;padding:11px 14px;font-size:14px;margin-bottom:12px}
.notice.err{background:rgba(226,54,54,.12);border:1px solid rgba(226,54,54,.4);color:#ffb0b0}
.notice.ok{background:rgba(47,191,113,.12);border:1px solid rgba(47,191,113,.4);color:#a6f0c6}

.foot{color:var(--muted);font-size:12px;text-align:center;margin-top:20px;line-height:1.6}

@media (prefers-reduced-motion:reduce){*{transition:none!important}}
