:root{
  --bg:#0e1116; --bg2:#151a22; --card:#1b212b; --card2:#212a36;
  --ink:#e7e3d8; --mut:#9aa6b4; --line:#2c3543;
  --gold:#c9a24b; --gold2:#e3c074; --blood:#b3261e; --blood2:#d6443c;
  --sea:#3b82c4; --sea2:#76b4e6; --moss:#6f8f5f; --ok:#5aa469;
  --rad:12px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--ink);
  font-family:"Iowan Old Style","Palatino Linotype",Georgia,"Times New Roman",serif;line-height:1.55;font-size:15px}
a{color:var(--gold2);text-decoration:none} a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}
.muted{color:var(--mut)} .err{background:#2a1614;border:1px solid var(--blood);color:#f0c9c5;padding:9px 12px;border-radius:8px;margin:10px 0}

/* ===== Auth ===== */
body.auth{display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 100% at 50% 0%, #1a212c 0%, var(--bg) 70%)}
.authbox{width:360px;max-width:92vw;background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:28px 26px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.authbox h1{margin:0;color:var(--gold2);letter-spacing:.08em;font-size:2rem;text-align:center}
.authbox p{text-align:center;margin:6px 0 18px}
.authbox label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);margin:12px 0 4px}
.authbox input{width:100%;background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:11px 12px;font-family:inherit;font-size:1rem}
.authbox input:focus{outline:none;border-color:var(--gold)}
.authbox button{width:100%;margin-top:20px;background:var(--blood);color:#fff;border:0;border-radius:9px;padding:12px;font-size:1rem;letter-spacing:.04em}
.authbox button:hover{background:var(--blood2)}
.setup-steps{color:var(--mut);font-size:.92rem;padding-left:20px} .setup-steps code{color:var(--gold2)}

/* ===== App layout ===== */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;height:56px;padding:0 16px;background:var(--bg2);border-bottom:1px solid var(--line)}
.topbar .brand{color:var(--gold2);font-size:1.15rem;letter-spacing:.06em}
.topbar .brand span{color:var(--mut);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-left:6px}
.topbar .spacer{flex:1}
.who{color:var(--mut);font-size:.9rem}
.rolebadge{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);border-radius:999px;padding:3px 10px;color:var(--mut)}
.rolebadge.admin{color:#f0c9c5;border-color:var(--blood);background:#2a1614}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:7px 12px;font-size:.85rem}
.btn-ghost:hover{border-color:var(--gold);text-decoration:none;color:var(--gold2)}
.burger{display:none;background:transparent;border:0;color:var(--ink);font-size:1.3rem}

/* recherche globale (toolbar) */
.gsearch{position:relative;flex:1;max-width:520px;margin:0 6px}
#globalSearch{width:100%;background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 12px;font-family:inherit;font-size:.92rem}
#globalSearch::placeholder{color:var(--mut)}
#globalSearch:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.12)}
.gresults{position:absolute;top:46px;left:0;right:0;background:var(--bg2);border:1px solid var(--line);border-radius:12px;box-shadow:0 22px 54px rgba(0,0,0,.6);max-height:72vh;overflow:auto;z-index:50;padding:6px}
.gresults .gcat{color:var(--gold);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:9px 10px 4px}
.gres{display:flex;gap:10px;align-items:center;padding:8px 10px;border-radius:8px;cursor:pointer}
.gres:hover,.gres.sel{background:var(--card2)}
.gres .gic{color:var(--gold);width:16px;flex:0 0 16px;text-align:center}
.gres .gt{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gres .gt b{color:var(--gold2)}
.gres .snip{color:var(--mut);font-size:.85rem;margin-left:8px}
.gres .gtype{font-size:.64rem;color:var(--mut);border:1px solid var(--line);border-radius:999px;padding:1px 8px;flex:0 0 auto}
.gres mark{background:rgba(201,162,75,.30);color:var(--gold2);border-radius:3px;padding:0 1px}
.gempty{color:var(--mut);padding:16px;font-style:italic;text-align:center}
.gkbd{display:flex;justify-content:space-between;color:var(--mut);font-size:.72rem;padding:8px 10px 4px;border-top:1px solid var(--line);margin-top:4px}
@media(max-width:760px){ .gsearch{max-width:none} .topbar .brand span{display:none} .who{display:none} }

/* synthèse */
.tabs{display:flex;gap:8px;margin:2px 0 18px;flex-wrap:wrap}
.tab{background:var(--card);border:1px solid var(--line);color:var(--mut);border-radius:9px;padding:8px 15px;cursor:pointer;font-family:inherit;font-size:.92rem}
.tab:hover{border-color:var(--gold);color:var(--ink)}
.tab.active{border-color:var(--gold);color:var(--gold2);background:var(--card2)}
table.stable{width:100%;border-collapse:collapse;margin:6px 0 22px;font-size:.9rem}
table.stable th{position:sticky;top:56px;background:var(--bg);text-align:left;color:var(--gold);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--line);z-index:5}
table.stable td{padding:7px 10px;border-bottom:1px solid var(--line);vertical-align:top}
table.stable tr.clickable{cursor:pointer} table.stable tr.clickable:hover td{background:var(--card)}
.coltot{color:var(--mut);font-size:.8rem;font-weight:normal}
.cdot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px;vertical-align:middle}
.synthbar{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}
.figwrap{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;margin:0 0 22px}
.figwrap svg{width:100%;height:auto;display:block}
.figcap{color:var(--mut);font-size:.82rem;text-align:center;margin-top:8px;font-style:italic}

/* inventaire de départ (start) */
.startcat{margin:16px 0 4px;color:var(--gold);font-size:.92rem;letter-spacing:.03em}
.startrow{display:flex;gap:8px;align-items:center;margin:6px 0;flex-wrap:wrap}
.startrow input{background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:.92rem}
.startrow input:focus{outline:none;border-color:var(--gold)}
.startrow input.nom{flex:1;min-width:130px}
.startrow input.val{flex:1.4;min-width:150px}
.startrow input.qte{width:72px}

/* étiquettes multi-personnages */
.taglist{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 12px}
.tagchip{background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:5px 12px;cursor:pointer;font-size:.9rem;color:var(--ink)}
.tagchip:hover{border-color:var(--gold);color:var(--gold2)}
.tagchip .x{color:var(--blood2);margin-left:2px;font-weight:bold;cursor:pointer}
.tagchip .x:hover{color:#fff}

.layout{display:flex;min-height:calc(100vh - 56px)}
.side{width:220px;flex:0 0 220px;background:var(--bg2);border-right:1px solid var(--line);padding:14px 10px;position:sticky;top:56px;height:calc(100vh - 56px);overflow:auto}
.side a{display:flex;align-items:center;gap:10px;color:var(--mut);padding:9px 12px;border-radius:9px;font-size:.95rem;cursor:pointer}
.side a:hover{background:var(--card);color:var(--ink);text-decoration:none}
.side a.active{background:var(--card2);color:var(--gold2)}
.side a .ic{width:18px;text-align:center;opacity:.9}
.side .cnt{margin-left:auto;font-size:.72rem;color:var(--mut);background:var(--card);border:1px solid var(--line);border-radius:999px;padding:0 7px}

.view{flex:1;min-width:0;padding:22px 26px 80px}
.viewhead{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.viewhead h1{margin:0;font-size:1.7rem;color:var(--gold2);letter-spacing:.02em}
.viewhead .spacer{flex:1}
.search{background:var(--bg2);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 12px;font-family:inherit;font-size:.92rem;min-width:220px}
.search:focus{outline:none;border-color:var(--gold)}
.btn{background:var(--blood);color:#fff;border:0;border-radius:9px;padding:9px 14px;font-size:.9rem}
.btn:hover{background:var(--blood2)}
.btn.sec{background:var(--card2);color:var(--ink);border:1px solid var(--line)} .btn.sec:hover{border-color:var(--gold)}

/* ===== Listes / cartes ===== */
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.itemcard{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);padding:14px 16px;cursor:pointer;transition:border-color .15s,transform .05s}
.itemcard:hover{border-color:var(--gold)} .itemcard:active{transform:translateY(1px)}
.itemcard h3{margin:0 0 4px;color:var(--gold2);font-size:1.05rem}
.itemcard .sub{color:var(--mut);font-size:.83rem}
.itemcard .tags{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.chip{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--line);color:var(--mut);border-radius:999px;padding:2px 8px}
.chip.gold{color:var(--gold2);border-color:var(--gold)}
.chip.blood{color:#f0c9c5;border-color:var(--blood);background:#2a1614}
.chip.sea{color:var(--sea2);border-color:var(--sea)}
.chip.ok{color:#cfe8d3;border-color:var(--ok)}
.grouphead{margin:22px 0 8px;color:var(--mut);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--line);padding-bottom:6px}
.subhead{margin:14px 0 6px;color:var(--gold);font-size:.92rem;letter-spacing:.05em}

/* ===== Détail / formulaire ===== */
.detail{max-width:860px}
.back{color:var(--mut);font-size:.9rem;cursor:pointer;display:inline-block;margin-bottom:12px}
.field{margin:14px 0}
.field label{display:block;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.editable{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:11px 13px;min-height:42px;white-space:pre-wrap;transition:border-color .15s,box-shadow .15s}
.editable:hover{border-color:#3a4658}
.editable:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.12)}
.editable.long{min-height:120px;line-height:1.65}
.editable.saving{border-color:var(--sea)} .editable.saved{border-color:var(--ok)}
select.editable,input.editable{font-family:inherit;font-size:1rem;color:var(--ink);width:100%}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px} @media(max-width:680px){.row2{grid-template-columns:1fr}}
.mjzone{border-left:3px solid var(--blood);background:#1a1413;border-radius:0 10px 10px 0;padding:6px 14px 14px;margin:18px 0}
.mjzone .mjlabel{color:var(--blood2);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-top:12px}
.detail .danger{margin-top:24px}
.btn-del{background:transparent;border:1px solid var(--blood);color:var(--blood2);border-radius:8px;padding:8px 13px;font-size:.85rem}
.btn-del:hover{background:var(--blood);color:#fff}

.objlist{margin:6px 0} .objrow{display:flex;gap:8px;align-items:flex-start;margin:6px 0}
.objrow .editable{flex:1}
.objrow .mini{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:7px;padding:4px 8px;font-size:.8rem}
.objrow .mini:hover{border-color:var(--blood);color:var(--blood2)}
.addline{color:var(--gold2);cursor:pointer;font-size:.9rem;display:inline-block;margin-top:6px}

/* tableau quetes */
table.q{width:100%;border-collapse:collapse;margin-top:8px}
table.q th{text-align:left;color:var(--gold);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--line)}
table.q td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.statut{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 9px;border:1px solid var(--line)}
.statut.a_faire{color:var(--mut)} .statut.en_cours{color:var(--sea2);border-color:var(--sea)}
.statut.terminee{color:#cfe8d3;border-color:var(--ok)} .statut.echouee{color:#f0c9c5;border-color:var(--blood);background:#2a1614}

.empty{color:var(--mut);font-style:italic;padding:30px 0}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(40px);background:var(--card2);border:1px solid var(--line);color:var(--ink);
  padding:10px 18px;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.5);opacity:0;transition:.2s;z-index:60;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:var(--ok)} .toast.bad{border-color:var(--blood)}

/* dashboard */
.stats{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);padding:18px}
.stat .n{font-size:2rem;color:var(--gold2)} .stat .l{color:var(--mut);font-size:.85rem;letter-spacing:.04em}

@media(max-width:760px){
  .side{position:fixed;left:-240px;z-index:40;transition:.2s} .side.open{left:0}
  .burger{display:block}
}
