/* =====================================================
   JEUX DE DAMES ROYAL — style.css
   © 2026 LeJojoVirtuel — VirtuelStudio — Bruxelles
===================================================== */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0a0a0f;--panel:#12121a;--card:#1a1a26;--border:#2a2a3e;
  --gold:#d4a843;--gold2:#f0c860;--cyan:#3dd6c8;--red:#e05555;--green:#4ac77a;--purple:#9b6ef5;
  --txt:#e8e8f0;--muted:#6b6b8a;
}
html,body{height:100%;font-family:'Inter',sans-serif;background:var(--bg);color:var(--txt);overflow-x:hidden}
#app{display:flex;flex-direction:column;min-height:100vh}

/* ── HEADER ── */
header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;background:rgba(10,10,15,.96);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;
}
.logo{font-family:'Cinzel',serif;font-size:clamp(.85rem,2.2vw,1.05rem);color:var(--gold);letter-spacing:2px}
.hbtns{display:flex;gap:6px}
.hbtn{padding:5px 11px;border-radius:20px;border:1px solid;font-size:.63rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;background:transparent;transition:.15s;text-decoration:none;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;color:inherit}
.hbtn-arc{border-color:var(--cyan);color:var(--cyan)}.hbtn-arc:hover{background:rgba(61,214,200,.1)}
.hbtn-rul{border-color:var(--gold);color:var(--gold)}.hbtn-rul:hover{background:rgba(212,168,67,.1)}
.hbtn-set{border-color:var(--purple);color:var(--purple)}.hbtn-set:hover{background:rgba(155,110,245,.1)}

main{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;padding:16px;flex:1}

/* ── BOARD ── */
#board-wrap{position:relative}
#board{
  display:grid;grid-template-columns:repeat(8,1fr);
  width:min(94vw,520px);aspect-ratio:1;
  border:3px solid rgba(212,168,67,.35);border-radius:6px;overflow:hidden;
  box-shadow:0 0 50px rgba(0,0,0,.8),0 0 90px rgba(212,168,67,.06);
}
.sq{aspect-ratio:1;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}
.sq.light{background:#d4c89a}
.sq.dark{background:#3a2a1a}
.sq.sel{background:#b8860b !important}
.sq.move{background:#1a6b1a !important}
.sq.capt{background:#6b1a1a !important}

/* ── PIECE ── */
.piece{
  width:75%;height:75%;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:clamp(.9rem,3.5vw,1.8rem);
  line-height:1;pointer-events:none;user-select:none;
  box-shadow:0 3px 8px rgba(0,0,0,.5),inset 0 -2px 4px rgba(0,0,0,.3);
  transition:transform .1s;position:relative;z-index:2;
}
.sq.sel .piece{transform:scale(1.12)}
.piece.white{background:radial-gradient(circle at 35% 30%,#fff,#d8c880);border:3px solid #c8a030;color:#5a3a00}
.piece.black{background:radial-gradient(circle at 35% 30%,#884444,#1a0808);border:3px solid #662222;color:#ffd700}

/* ── AI OVERLAY ── */
#ai-over{
  display:none;position:absolute;inset:0;z-index:20;
  background:rgba(5,5,12,.55);border-radius:4px;
  align-items:center;justify-content:center;flex-direction:column;gap:8px;
}
#ai-over.show{display:flex}
.dots{display:flex;gap:6px}
.dots i{width:9px;height:9px;border-radius:50%;background:var(--gold);display:block;animation:dp 1.1s ease-in-out infinite}
.dots i:nth-child(2){animation-delay:.2s}.dots i:nth-child(3){animation-delay:.4s}
@keyframes dp{0%,80%,100%{transform:scale(.4);opacity:.3}40%{transform:scale(1);opacity:1}}
.aitxt{font-size:.62rem;letter-spacing:2px;color:var(--gold2);text-transform:uppercase}

/* ── SIDE PANEL ── */
#side{width:min(94vw,260px);display:flex;flex-direction:column;gap:10px}
.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.clbl{font-size:.53rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-weight:600}

#turn-row{display:flex;align-items:center;gap:9px}
.tdot{width:16px;height:16px;border-radius:50%;flex-shrink:0}
.tdot.W{background:#fff;box-shadow:0 0 7px rgba(255,255,255,.5)}
.tdot.B{background:#4a1010;box-shadow:0 0 7px rgba(100,20,20,.8),0 0 0 1.5px #882222}
#turn-txt{font-family:'Cinzel',serif;font-size:.9rem}
#status{font-size:.63rem;color:var(--cyan);margin-top:2px;min-height:12px}

#score-row{display:flex;gap:8px}
.sbox{flex:1;background:var(--panel);border-radius:8px;padding:8px;text-align:center}
.slbl{font-size:.53rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.sval{font-family:'Cinzel',serif;font-size:1.7rem;font-weight:700}
.sval.W{color:#e8e0d0}.sval.B{color:#cc8888}

/* ── TIMERS ── */
#timers{display:none;gap:8px}
#timers.show{display:flex}
.tmbox{flex:1;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:8px;text-align:center;transition:.2s}
.tmbox.active{border-color:var(--gold);box-shadow:0 0 10px rgba(212,168,67,.2)}
.tmbox.low{border-color:var(--red)}
.tmlbl{font-size:.53rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.tmval{font-family:'Cinzel',serif;font-size:1.3rem;color:var(--gold2)}
.tmbox.low .tmval{color:var(--red);animation:blk .5s infinite}
@keyframes blk{50%{opacity:.4}}

.cap-row{display:flex;align-items:center;gap:5px;margin-bottom:4px}
.cap-row:last-child{margin-bottom:0}
.caplbl{font-size:.6rem;color:var(--muted);min-width:16px}
#cap-w,#cap-b{font-size:.85rem;flex:1}

#hist{display:flex;flex-wrap:wrap;gap:3px;max-height:68px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.hmv{font-size:.57rem;padding:2px 5px;border-radius:3px;background:var(--panel);color:var(--muted);border:1px solid var(--border)}
.hmv.cur{color:var(--gold);border-color:rgba(212,168,67,.35)}

/* ── ACTION BUTTONS ── */
#actions{display:flex;gap:6px;flex-wrap:wrap;width:min(94vw,260px)}
.abtn{flex:1;min-width:52px;padding:9px 3px;border-radius:20px;font-size:.6rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;border:1px solid;background:transparent;transition:.15s;display:flex;align-items:center;justify-content:center;gap:3px}
.abtn-new{border-color:var(--gold);color:var(--gold)}.abtn-new:hover{background:rgba(212,168,67,.1)}
.abtn-undo{border-color:var(--purple);color:var(--purple)}.abtn-undo:hover{background:rgba(155,110,245,.1)}
.abtn-ai{border-color:var(--green);color:var(--green)}.abtn-ai:hover,.abtn-ai.on{background:rgba(74,199,122,.12)}
.abtn-ai.on{box-shadow:0 0 9px rgba(74,199,122,.2)}

/* ── SETTINGS DRAWER ── */
#ov{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;display:none;backdrop-filter:blur(4px)}
#ov.show{display:block}
#drawer{position:fixed;top:0;right:-330px;width:300px;max-width:96vw;height:100vh;background:var(--panel);border-left:1px solid var(--border);z-index:201;transition:right .28s ease;overflow-y:auto;padding-bottom:40px}
#drawer.open{right:0}
.dh{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--panel);z-index:5}
.dt{font-family:'Cinzel',serif;font-size:.95rem;color:var(--gold);letter-spacing:2px}
.dc{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer}
.dc:hover{color:var(--txt)}
.ds{padding:13px 16px;border-bottom:1px solid var(--border)}
.ds:last-child{border-bottom:none}
.dst{font-size:.53rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:9px;font-weight:600}
.trow{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.trlbl{font-size:.76rem;font-weight:500}
.trsub{font-size:.59rem;color:var(--muted);margin-top:1px}
.tog{position:relative;width:38px;height:20px;flex-shrink:0}
.tog input{opacity:0;width:0;height:0}
.togtr{position:absolute;inset:0;border-radius:20px;background:var(--card);border:1px solid var(--border);cursor:pointer;transition:.2s}
.togtr::before{content:'';position:absolute;left:3px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--muted);transition:.2s}
.tog input:checked~.togtr{background:rgba(212,168,67,.25);border-color:var(--gold)}
.tog input:checked~.togtr::before{transform:translateX(18px);background:var(--gold)}
.nrow{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.nlbl{font-size:.7rem;color:var(--muted);min-width:66px}
.ninp{width:66px;padding:4px 7px;border-radius:6px;background:var(--card);border:1px solid var(--border);color:var(--txt);font-size:.78rem;text-align:center}
.ninp:focus{outline:none;border-color:var(--gold)}
.swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-top:5px}
.sw{height:30px;border-radius:5px;cursor:pointer;border:2px solid transparent;transition:.15s;display:flex;align-items:center;justify-content:center;font-size:.68rem;color:transparent}
.sw:hover{transform:scale(1.07)}.sw.on{border-color:var(--gold);color:rgba(255,255,255,.8)}
.dapply{width:100%;padding:9px;border-radius:18px;margin-top:9px;border:none;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0a0f;font-weight:700;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:.15s}
.dapply:hover{opacity:.88}
.ubtns{display:flex;gap:6px;margin-top:4px}
.ubtn{flex:1;padding:7px;border-radius:18px;font-size:.62rem;font-weight:600;letter-spacing:.7px;text-transform:uppercase;cursor:pointer;border:1px solid;background:transparent;transition:.15s}
.ubtn1{border-color:var(--purple);color:var(--purple)}.ubtn1:hover{background:rgba(155,110,245,.1)}
.ubtn2{border-color:var(--gold);color:var(--gold)}.ubtn2:hover{background:rgba(212,168,67,.1)}

/* ── Bouton Soutien Ko-fi dans les réglages ── */
.kofi-drawer-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:11px 14px;border-radius:18px;
  border:none;cursor:pointer;text-decoration:none;
  font-weight:700;font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;
  background:linear-gradient(135deg,#22d3ee,#4ade80);
  color:#0a0a0f;
  box-shadow:0 0 18px rgba(34,197,94,.35);
  transition:.15s;
}
.kofi-drawer-btn:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 0 26px rgba(34,197,94,.55)}
.kofi-drawer-sub{
  font-size:.62rem;color:var(--muted);text-align:center;
  margin-top:7px;line-height:1.5;
}
.kofi-drawer-sub span{color:var(--cyan)}

/* ── MODALS ── */
.mbg{position:fixed;inset:0;background:rgba(0,0,0,.86);z-index:300;display:none;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(5px)}
.mbg.show{display:flex}
.modal{background:linear-gradient(160deg,#11111e,#0c0c16);border:1px solid rgba(212,168,67,.35);border-radius:12px;padding:20px 18px;max-width:400px;width:100%;max-height:88vh;overflow-y:auto;position:relative}
.mcls{position:absolute;top:11px;right:12px;background:none;border:none;color:var(--muted);font-size:1.15rem;cursor:pointer}
.mcls:hover{color:var(--txt)}
.modal h2{font-family:'Cinzel',serif;font-size:1.15rem;color:var(--gold);text-align:center;margin-bottom:12px;letter-spacing:2px}
.modal h3{font-family:'Cinzel',serif;font-size:.8rem;color:var(--cyan);margin:10px 0 3px;letter-spacing:1px}
.modal p,.modal li{font-size:.73rem;line-height:1.7;color:#9090b0;margin-bottom:3px}
.modal ul{padding-left:13px}
.wcrown{font-size:3.2rem;display:block;text-align:center;animation:fl 2s ease-in-out infinite}
@keyframes fl{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.wtitle{font-family:'Cinzel',serif;font-size:1.7rem;color:var(--gold);text-align:center;letter-spacing:3px;text-transform:uppercase}
.wsub{color:var(--muted);font-size:.74rem;text-align:center;margin-top:4px}
.wdiv{height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,67,.35),transparent);margin:12px 0}
.wbtns{display:flex;flex-direction:column;gap:7px}
.wbtn{width:100%;padding:10px;border-radius:25px;font-weight:700;font-size:.7rem;letter-spacing:1.8px;text-transform:uppercase;cursor:pointer;border:none;transition:.15s;display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none}
.wbtn-p{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0a0f}.wbtn-p:hover{opacity:.88}
.wbtn-s{background:rgba(61,214,200,.1);color:var(--cyan);border:1px solid var(--cyan)}.wbtn-s:hover{background:rgba(61,214,200,.18)}
.wbtn-img{background:rgba(74,199,122,.1);color:var(--green);border:1px solid var(--green)}.wbtn-img:hover{background:rgba(74,199,122,.18)}
.wbtn-c{background:rgba(74,199,122,.1);color:var(--green);border:1px solid var(--green)}

/* ── TOAST / CONFETTI ── */
#toast{position:fixed;top:58px;left:50%;transform:translateX(-50%) translateY(-8px);background:var(--card);border:1px solid rgba(212,168,67,.35);border-radius:18px;padding:5px 15px;font-size:.64rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gold);z-index:400;opacity:0;transition:.22s;pointer-events:none;white-space:nowrap}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#confetti{position:fixed;inset:0;pointer-events:none;z-index:500}

/* ── FOOTER / SIGNATURE ── */
footer{text-align:center;padding:12px;color:var(--muted);font-size:.56rem;letter-spacing:.8px;border-top:1px solid var(--border)}
#vsig{position:fixed;bottom:7px;right:11px;font-size:.56rem;color:rgba(255,255,255,.18);pointer-events:none;user-select:none;letter-spacing:.7px;z-index:9999}

/* ── KO-FI WIDGET FLOTTANT ── */
#kofi{position:fixed;right:.9rem;bottom:1.7rem;z-index:9998;max-width:240px;font-family:'Inter',sans-serif}
.kfc{background:radial-gradient(circle at top left,rgba(61,214,200,.2),rgba(10,10,20,.96));border-radius:.85rem;padding:.65rem .76rem;border:1px solid rgba(61,214,200,.32);box-shadow:0 9px 24px rgba(0,0,0,.8);font-size:.7rem;line-height:1.4;position:relative}
.kft{font-weight:600;font-size:.73rem;margin-bottom:.18rem}
.kfs{color:#b0b8d0;margin-bottom:.4rem}.kfs span{color:var(--cyan)}
.kfb{display:inline-flex;align-items:center;justify-content:center;padding:.28rem .7rem;border-radius:999px;background:linear-gradient(135deg,#22d3ee,#4ade80);color:#0a0a0f;font-weight:700;font-size:.68rem;text-decoration:none;white-space:nowrap}
.kfx{position:absolute;top:-.26rem;right:-.26rem;width:17px;height:17px;border-radius:50%;background:rgba(10,10,20,.9);border:1px solid rgba(100,100,120,.55);color:#777;font-size:.58rem;display:flex;align-items:center;justify-content:center;cursor:pointer}
.kfx:hover{color:var(--txt)}
@media(max-width:580px){#kofi{right:.55rem;left:.55rem;bottom:.55rem;max-width:none}.kfc{text-align:center}}
