/* ===== Les Quêtes du Tavergiste — charte VERT dragon ===== */
:root{
  --dragon:#226b63;       /* corps du dragon (exact) */
  --dragon-dark:#14534b;
  --green:#2a8174;         /* vert vif d'accent */
  --gold:#eed089;          /* reflets du dragon (exact) */
  --gold2:#f4e0a6;
  --tan:#80695c;
  --crimson:#b6294f;
  --bg:#08231f;
  --bg2:#0c2f2a;
  --panel:#103a34;
  --panel2:#154a42;
  --line:#22675b;
  --cream:#eaf5f0;
  --muted:#8fbcae;
  --answer:#86e3b6;
  --radius:18px;
  --shadow:0 12px 34px rgba(0,0,0,.5);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(1100px 560px at 50% -8%,#0e4d4455,#0000),var(--bg);
  color:var(--cream);
  display:flex;flex-direction:column;min-height:100dvh;
  user-select:none;
}
svg{width:1.1em;height:1.1em;flex:none}

/* ---------- Topbar ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 18px;padding-top:max(10px,env(safe-area-inset-top));
  background:linear-gradient(180deg,var(--bg2),#04221fcc);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;
}
/* logo dragon seul (SVG vectoriel) */
.brand-logo-box{display:flex;align-items:center}
.brand-logo{height:48px;width:auto;display:block;filter:drop-shadow(0 2px 6px #0007)}
.tabs{display:flex;gap:6px;background:#0004;padding:4px;border-radius:12px}
.tab{
  border:0;background:transparent;color:var(--muted);font-weight:700;font-size:15px;
  padding:9px 16px;border-radius:9px;cursor:pointer;transition:.15s;
}
.tab.active{background:var(--green);color:#fff;box-shadow:0 1px 0 #0006}

/* ---------- Views ---------- */
.view{display:none;flex:1;flex-direction:column;padding:16px;gap:16px;max-width:820px;width:100%;margin:0 auto}
.view.active{display:flex}

/* ---------- Filtres ---------- */
.filters{display:flex;flex-direction:column;gap:14px}
.filter-group{display:flex;flex-direction:column;gap:8px}
.filter-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:700}
.seg{display:inline-flex;background:#0003;border:1px solid var(--line);border-radius:12px;padding:4px;gap:4px;flex-wrap:wrap}
.seg-btn{
  border:0;background:transparent;color:var(--cream);font-weight:700;font-size:14px;
  padding:9px 16px;border-radius:9px;cursor:pointer;transition:.12s;
}
.seg-btn.active{background:var(--gold);color:#23200a}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  border:1px solid var(--line);background:var(--panel);color:var(--cream);
  font-weight:700;font-size:14px;padding:10px 16px;border-radius:999px;cursor:pointer;transition:.12s;
}
.chip.active{background:var(--gold);border-color:var(--gold);color:#23200a}

/* ---------- Carte ---------- */
.stage{flex:1;display:flex;align-items:stretch}
.card{
  flex:1;display:flex;flex-direction:column;gap:14px;
  background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);min-height:230px;
  animation:pop .25s ease;position:relative;overflow:hidden;
}
.card::after{content:"";position:absolute;inset:0;border-radius:var(--radius);
  background:radial-gradient(420px 200px at 100% 0,#2a817422,#0000);pointer-events:none}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}
.card.empty{align-items:center;justify-content:center;border-style:dashed;box-shadow:none;background:#0002}
.card-empty-msg{text-align:center;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
.card-empty-msg svg{width:42px;height:42px;opacity:.6}

.card-badges{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
.badge{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:5px 11px;border-radius:999px;border:1px solid #ffffff22}
.badge.type{background:#eed08922;color:var(--gold2)}
.badge.mode{background:#2a817433;color:#bfeede}
.badge.univers{background:#0e3a33;color:#9fe0c8;border-color:#1c6657}
.badge.facile{background:#0e4a3a;color:#8be9bf}
.badge.moyen{background:#4a3b0e;color:var(--gold2)}
.badge.difficile{background:#4a1426;color:#f3a9bd}

.card-title{font-size:21px;font-weight:800;color:var(--gold2);margin:0;position:relative;z-index:1}
.card-body{font-size:22px;line-height:1.45;font-weight:600;color:var(--cream);margin:0;position:relative;z-index:1}
.card-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:14px;font-weight:600;margin-top:auto;padding-top:6px;border-top:1px dashed var(--line);position:relative;z-index:1}
.card-meta b{color:var(--cream)}

.answer{
  background:#04221f99;border:1px solid var(--line);border-radius:12px;padding:16px;
  font-size:19px;line-height:1.45;color:var(--answer);font-weight:700;
  animation:pop .2s ease;position:relative;z-index:1;
}
.answer .answer-lbl{display:block;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px}

/* ---------- Actions ---------- */
.actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border:0;border-radius:14px;padding:16px 22px;font-size:17px;font-weight:800;
  cursor:pointer;transition:.12s;flex:1;min-width:160px;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:linear-gradient(180deg,var(--gold2),var(--gold));color:#23200a;box-shadow:0 6px 18px #eed08933}
.btn-ghost{background:var(--panel2);color:var(--gold2);border:1px solid var(--line)}
.btn-big{font-size:22px;padding:22px;min-width:220px}

/* ---------- Statusbar ---------- */
.statusbar{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-size:13px;font-weight:600}
.link-btn{display:inline-flex;align-items:center;gap:7px;background:none;border:0;color:var(--muted);font-weight:700;cursor:pointer;font-size:13px}
.link-btn:active{color:var(--gold)}

/* ---------- Morpion ---------- */
.mp-wrap{display:flex;flex-direction:column;align-items:center;gap:18px;margin:auto 0}
.mp-status{font-size:20px;font-weight:700;color:var(--muted)}
.mp-status strong{color:var(--gold2)}
.mp-board{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:min(86vw,360px);aspect-ratio:1}
.mp-cell{
  background:var(--panel);border:1px solid var(--line);border-radius:16px;
  font-size:54px;font-weight:900;cursor:pointer;color:var(--cream);transition:.1s;
  display:flex;align-items:center;justify-content:center;
}
.mp-cell:active{background:var(--panel2)}
.mp-cell.x{color:var(--gold2)}
.mp-cell.o{color:#79d9b6}
.mp-cell.win{background:#0e4a3a;border-color:var(--gold)}
.mp-score{display:flex;gap:24px;font-size:15px;color:var(--muted);font-weight:600}
.mp-score strong{color:var(--cream);font-size:18px}

/* ---------- Dé ---------- */
.de-wrap{display:flex;flex-direction:column;align-items:center;gap:22px;margin:auto 0}
.de-config{display:flex;flex-direction:column;align-items:center;gap:12px}
.de-result{
  font-size:96px;font-weight:900;color:var(--gold2);line-height:1;
  min-width:160px;text-align:center;text-shadow:0 4px 24px #eed08955;
}
.de-result.roll{animation:shake .4s ease}
@keyframes shake{0%,100%{transform:none}25%{transform:translateX(-6px) rotate(-3deg)}75%{transform:translateX(6px) rotate(3deg)}}
.de-detail{color:var(--muted);font-size:15px;font-weight:600;min-height:20px}

/* ---------- Bouton Jouer (carte mini-jeu) ---------- */
.btn-jouer{
  display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;
  background:linear-gradient(180deg,var(--gold2),var(--gold));color:#23200a;
  font-weight:800;font-size:15px;padding:11px 18px;border-radius:12px;
}
.btn-jouer:active{transform:scale(.97)}

/* ---------- Overlay mini-jeux ---------- */
.game-modal{position:fixed;inset:0;z-index:50;background:var(--bg);
  display:flex;flex-direction:column;gap:14px;padding:16px;
  padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom))}
.game-modal[hidden]{display:none}
.game-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.game-title{font-weight:800;color:var(--gold2);font-size:18px}
.game-status{color:var(--cream);font-weight:800;font-size:16px;margin-left:auto}
.game-close{background:var(--panel2);color:var(--gold2);border:1px solid var(--line);
  font-weight:700;padding:10px 16px;border-radius:12px;cursor:pointer}
.game-area{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}
#game-replay{flex:0 0 auto}

/* memory */
.mem-grid{display:grid;gap:10px}
.mem-card{aspect-ratio:1;border-radius:14px;border:1px solid var(--line);background:var(--panel);
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s;padding:0}
.mem-card svg{width:58%;height:58%;opacity:0;transition:.15s}
.mem-card img{width:100%;height:100%;object-fit:cover;border-radius:13px;opacity:0;transition:.15s;background:#fff}
.mem-card.up{background:var(--panel2)}
.mem-card.up svg,.mem-card.done svg,.mem-card.up img,.mem-card.done img{opacity:1}
.mem-card.done{background:#0e4a3a;border-color:var(--gold)}

/* taquin */
.taq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:min(82vw,360px);aspect-ratio:1}
.taq-cell{border-radius:10px;background-size:300% 300%;background-color:#fff;
  background-repeat:no-repeat;cursor:pointer;border:1px solid var(--line);padding:0}
.taq-cell.empty{background:#0002;border:1px dashed var(--line);cursor:default}

/* simon */
.simon{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:min(78vw,340px);aspect-ratio:1}
.simon-pad{border-radius:18px;cursor:pointer;opacity:.5;transition:.08s;border:0}
.simon-pad.lit{opacity:1;transform:scale(.96)}
.simon-g{background:#3bbf7a}.simon-r{background:#d8593f}.simon-y{background:#e6c34a}.simon-b{background:#46a7d0}

/* morpion (overlay) */
.mp2-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:min(80vw,340px);aspect-ratio:1}
.mp2-cell{background:var(--panel);border:1px solid var(--line);border-radius:14px;font-size:48px;font-weight:900;
  color:var(--cream);display:flex;align-items:center;justify-content:center;cursor:pointer}
.mp2-cell.x{color:var(--gold2)}.mp2-cell.o{color:#79d9b6}.mp2-cell.win{background:#0e4a3a;border-color:var(--gold)}

/* puissance 4 */
.p4-board{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;background:var(--panel2);
  border:1px solid var(--line);border-radius:14px;padding:8px;width:min(94vw,460px)}
.p4-cell{aspect-ratio:1;border-radius:50%;background:var(--bg);border:0;cursor:pointer;padding:0}
.p4-cell.r{background:#d8593f}.p4-cell.y{background:#eed089}
.p4-cell.win{box-shadow:0 0 0 4px #fff inset}

/* menu des duels du tavergiste */
.duel-intro{color:var(--muted);font-weight:600;font-size:14px;margin:0 2px}
.duel-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;align-content:start;overflow:auto}
.duel-tile{display:flex;flex-direction:column;gap:6px;text-align:left;cursor:pointer;color:var(--cream);
  background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:16px;padding:16px;min-height:108px}
.duel-tile:active{transform:scale(.98)}
.dt-title{font-weight:800;color:var(--gold2);font-size:16px}
.dt-sub{font-size:12px;color:var(--muted);font-weight:600;line-height:1.35}
.dt-badge{margin-top:auto;align-self:flex-start;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
  color:#23200a;background:var(--gold);padding:4px 10px;border-radius:999px}
.duel-tile.rules .dt-badge{background:var(--panel);color:var(--gold2);border:1px solid var(--line)}

/* boîte de règles (overlay) */
.rules-box{max-width:680px;font-size:20px;line-height:1.5;color:var(--cream);
  background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:16px;padding:24px}

/* jeu des bâtonnets (Nim) */
.nim-wrap{display:flex;flex-direction:column;gap:24px;align-items:center;width:min(92vw,460px)}
.nim-scores{display:flex;gap:12px;width:100%}
.nim-side{flex:1;display:flex;flex-direction:column;gap:4px;text-align:center;padding:14px 10px;
  border-radius:16px;border:2px solid var(--line);background:var(--panel);transition:.15s}
.nim-side.active{border-color:var(--gold);background:var(--panel2);box-shadow:0 0 0 3px #eed08933}
.nim-side.win{border-color:var(--answer);background:#0e4a3a}
.nim-side.lose{opacity:.45}
.ns-name{font-weight:800;color:var(--gold2);font-size:17px}
.nim-side.win .ns-name{color:var(--answer)}
.ns-count{font-size:13px;color:var(--muted);font-weight:700}
.nim-side.active .ns-count{color:var(--gold2)}
.nim-side.win .ns-count{color:var(--answer);font-weight:800;font-size:15px}
.nim-sticks{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:flex-end;min-height:90px}
.nim-stick{width:14px;height:84px;border-radius:7px;background:#d9c188;box-shadow:0 4px 8px #0006;position:relative;animation:pop .2s ease}
.nim-stick::before{content:"";position:absolute;top:-3px;left:0;right:0;height:18px;border-radius:7px;background:var(--crimson)}
.nim-controls{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.nim-btn{background:linear-gradient(180deg,var(--gold2),var(--gold));color:#23200a;font-weight:800;font-size:16px;padding:14px 22px;border:0;border-radius:12px;cursor:pointer}
.nim-btn:disabled{opacity:.4;cursor:default}
.nim-btn:active:not(:disabled){transform:scale(.96)}

/* vrais dés qui roulent */
.de-dice{display:flex;gap:16px;align-items:center;justify-content:center;flex-wrap:wrap;min-height:150px}
.die{width:140px;height:140px;border-radius:24px;background:linear-gradient(145deg,#f6ecd2,#e6cf94);
  box-shadow:0 12px 26px #0008, inset 0 -7px 0 #00000022, inset 0 4px 0 #ffffff55;
  display:flex;align-items:center;justify-content:center;color:#23200a;font-weight:900;font-size:68px}
.die.num{font-size:68px}
/* formes + couleurs par type de dé */
.die.d10,.die.d20,.die.d100{border-radius:0;box-shadow:0 10px 22px #0007}
.die.d10{background:linear-gradient(145deg,#3aa088,#1c5f51);color:#eef7f2;clip-path:polygon(50% 0,100% 38%,50% 100%,0 38%)}
.die.d20{background:linear-gradient(145deg,#d8657f,#9c1f3c);color:#fff;clip-path:polygon(50% 0,93% 25%,93% 75%,50% 100%,7% 75%,7% 25%)}
.die.d100{background:linear-gradient(145deg,#f4e0a6,#d8b24e);color:#23200a;clip-path:polygon(50% 0,79% 10%,98% 35%,98% 65%,79% 90%,50% 100%,21% 90%,2% 65%,2% 35%,21% 10%)}
.die.rolling{animation:diceroll .14s linear infinite}
.die.pop{animation:dicepop .32s ease}
@keyframes diceroll{0%{transform:rotate(-10deg) translateY(0)}50%{transform:rotate(10deg) translateY(-8px)}100%{transform:rotate(-10deg) translateY(0)}}
@keyframes dicepop{0%{transform:scale(1.18)}60%{transform:scale(.94)}100%{transform:scale(1)}}
.die-pips{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:74%;height:74%;gap:8%}
.pip{align-self:center;justify-self:center;width:100%;height:100%;border-radius:50%;background:#23200a;visibility:hidden}
.pip.on{visibility:visible}

@media (max-width:520px){
  .brand-logo{height:40px}
  .card-body{font-size:19px}
  .de-result{font-size:76px}
}
