@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Nunito:wght@400;600;700;800;900&family=Oswald:wght@400;500;600;700&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  /* Fond noir velours */
  --bg0:#05050d;--bg1:#0a0a18;--bg2:#0f0f20;--bg3:#161628;--bg4:#1e1e34;
  --border:rgba(255,255,255,0.05);--border2:rgba(255,255,255,0.10);
  /* Or casino */
  --gold:#f0b429;--gold2:#c8921a;--gold3:#ffd060;--gold-light:#ffe580;
  --gold-glow:rgba(240,180,41,0.35);--gold-glow2:rgba(240,180,41,0.12);
  --sidebar-border:rgba(200,146,26,0.22);
  /* Couleurs */
  --green:#1db954;--red:#e63946;--blue:#4f8ef7;--purple:#9b72f0;
  --text:#ededf5;--text2:#7a7a96;--text3:#3e3e58;
}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg0);color:var(--text);font-family:'Nunito',sans-serif;font-size:14px}

/* Lumière ambiante profonde */
body::before{
  content:'';position:fixed;inset:0;
  background:
    radial-gradient(ellipse 160% 100% at 0% 0%, rgba(100,60,200,0.06) 0%,transparent 50%),
    radial-gradient(ellipse 120% 100% at 100% 100%, rgba(240,180,41,0.05) 0%,transparent 55%),
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(30,20,60,0.4) 0%, transparent 70%);
  pointer-events:none;z-index:0
}
/* Motif de losanges subtil */
body::after{
  content:'';position:fixed;inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,.006) 0, rgba(255,255,255,.006) 1px, transparent 1px, transparent 28px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,.006) 0, rgba(255,255,255,.006) 1px, transparent 1px, transparent 28px);
  pointer-events:none;z-index:0
}
button{font-family:'Nunito',sans-serif;cursor:pointer}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-thumb{background:rgba(240,180,41,.18);border-radius:2px}

/* ─── ANIMATIONS ─── */
@keyframes goldShimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes pulseGold{
  0%,100%{box-shadow:0 0 12px rgba(240,180,41,0.25),inset 0 0 8px rgba(240,180,41,0.06)}
  50%{box-shadow:0 0 28px rgba(240,180,41,0.55),inset 0 0 18px rgba(240,180,41,0.14)}
}
@keyframes logoGlow{0%,100%{box-shadow:0 0 14px rgba(240,180,41,0.5),0 2px 10px rgba(0,0,0,0.8)}50%{box-shadow:0 0 32px rgba(240,180,41,0.85),0 2px 14px rgba(0,0,0,0.8)}}
@keyframes hslide{from{opacity:0;transform:translateX(6px)}to{opacity:1;transform:none}}
@keyframes suitFloat{0%,100%{opacity:.022;transform:translateY(0)}50%{opacity:.038;transform:translateY(-6px)}}
@keyframes navPulse{0%,100%{opacity:.5}50%{opacity:1}}

/* ── LAYOUT ── */
#app{display:flex;flex-direction:row;width:100vw;height:100vh;overflow:hidden;position:relative;z-index:1}

/* ── SIDEBAR ── */
#tpbar{
  width:170px;flex-shrink:0;
  background:linear-gradient(180deg,#080814 0%,#05050e 100%);
  border-right:1px solid var(--sidebar-border);
  display:flex;flex-direction:column;
  padding:0;gap:0;z-index:50;overflow:hidden;position:relative;
}
/* Bande dorée en haut */
#tpbar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,var(--gold2) 30%,var(--gold3) 50%,var(--gold2) 70%,transparent 100%);
  opacity:0.85;z-index:10;
}
/* Symboles de cartes flottants en fond */
#tpbar::after{
  content:'♠  ♥\A♦  ♣\A♠  ♥\A♦  ♣\A♠  ♥\A♦  ♣';
  white-space:pre;
  position:absolute;top:50px;left:0;right:0;
  font-size:32px;line-height:2;text-align:center;letter-spacing:8px;
  color:rgba(240,180,41,1);opacity:.022;pointer-events:none;
  animation:suitFloat 8s ease-in-out infinite;
}

/* Logo zone */
.tb-logo{
  font-family:'Cinzel',serif;font-weight:700;font-size:13.5px;
  display:flex;align-items:center;gap:8px;padding:13px 10px 14px;
  border-bottom:1px solid rgba(200,146,26,0.18);
  flex-shrink:0;position:relative;
}
.tb-logo::after{
  content:'';position:absolute;bottom:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,180,41,0.3),transparent);
}
.tb-logo-icon{
  width:32px;height:32px;
  background:linear-gradient(135deg,var(--gold3),var(--gold),var(--gold2));
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:16px;color:#0a0a0a;flex-shrink:0;
  box-shadow:0 0 18px rgba(240,180,41,0.55),0 3px 12px rgba(0,0,0,0.7);
  animation:logoGlow 3.5s ease-in-out infinite;
}
.tb-logo b{
  background:linear-gradient(90deg,var(--gold2),var(--gold3),var(--gold-light),var(--gold3),var(--gold2));
  background-size:300% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:goldShimmer 5s ease-in-out infinite;letter-spacing:.3px;
}

/* Séparateur de section */
.tb-section-lbl{
  font-family:'Cinzel',serif;font-size:7px;font-weight:700;
  letter-spacing:2.5px;color:rgba(240,180,41,0.35);text-transform:uppercase;
  padding:8px 12px 3px;position:relative;
}
.tb-section-lbl::before{
  content:'';position:absolute;left:10px;right:10px;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,180,41,0.15),transparent);
}

/* Nav links */
.tb-nav{display:flex;flex-direction:column;gap:1px;flex:1;padding:6px 7px}
.tb-nav a{
  display:flex;align-items:center;gap:9px;
  padding:8px 10px;border-radius:7px;
  background:transparent;color:var(--text2);
  font-size:11.5px;font-weight:700;
  transition:all .18s;text-decoration:none;white-space:nowrap;
  border:1px solid transparent;position:relative;overflow:hidden;
}
.tb-nav a::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:linear-gradient(90deg,rgba(240,180,41,0.12),transparent);
  transition:width .22s;border-radius:7px;
}
.tb-nav a:hover{background:rgba(240,180,41,0.06);color:var(--text);border-color:rgba(240,180,41,0.12)}
.tb-nav a:hover::after{width:100%}
.tb-nav a.active{
  background:linear-gradient(135deg,rgba(240,180,41,0.14),rgba(240,180,41,0.05));
  color:var(--gold);border-color:rgba(240,180,41,0.28);
  text-shadow:0 0 16px rgba(240,180,41,0.4);
}
.tb-nav a.active::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;width:2px;
  background:linear-gradient(180deg,transparent,var(--gold),transparent);
  border-radius:0 2px 2px 0;
}
.tb-nav a .nav-icon{font-size:15px;width:18px;text-align:center;flex-shrink:0;filter:drop-shadow(0 0 4px rgba(240,180,41,0.2))}

/* Divider */
.tb-divider{height:1px;margin:4px 10px;background:linear-gradient(90deg,transparent,rgba(240,180,41,0.1),transparent)}

/* User section en bas */
.tb-bottom{
  flex-shrink:0;padding:8px 7px 10px;
  border-top:1px solid rgba(200,146,26,0.15);
  position:relative;display:flex;flex-direction:column;gap:5px;
}
.tb-bottom::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,180,41,0.25),transparent);
}
.tb-user-wrap{
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,0.025);border:1px solid rgba(240,180,41,0.1);
  border-radius:8px;padding:7px 9px;cursor:pointer;transition:all .18s;
}
.tb-user-wrap:hover{background:rgba(240,180,41,0.07);border-color:rgba(240,180,41,0.25)}
#tb-avatar-img{width:26px;height:26px;border-radius:50%;border:1.5px solid rgba(240,180,41,0.4);object-fit:cover;background:var(--bg3);flex-shrink:0;box-shadow:0 0 8px rgba(240,180,41,0.15)}
#tb-username{font-size:11px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:95px}
.tb-balance{
  background:linear-gradient(135deg,rgba(240,180,41,0.12),rgba(240,180,41,0.04));
  border:1px solid rgba(240,180,41,0.35);border-radius:7px;
  padding:9px 10px;font-family:'Oswald',sans-serif;font-size:16px;
  font-weight:600;color:var(--gold);text-align:center;
  animation:pulseGold 3.5s ease-in-out infinite;letter-spacing:0.5px;
  text-shadow:0 0 14px rgba(240,180,41,0.4);position:relative;
}
.tb-balance::before{
  content:'SOLDE';position:absolute;top:-5px;left:50%;transform:translateX(-50%);
  background:var(--bg0);padding:0 5px;
  font-family:'Cinzel',serif;font-size:6px;font-weight:700;
  letter-spacing:2px;color:rgba(240,180,41,0.45);white-space:nowrap;
}
.tb-daily{
  background:linear-gradient(135deg,#1db954,#158f40,#0f6b30);color:#fff;
  border:1px solid rgba(29,185,84,0.35);border-radius:7px;padding:8px;font-size:10.5px;
  font-weight:800;transition:all .2s;width:100%;text-align:center;
  box-shadow:0 4px 16px rgba(29,185,84,0.22);letter-spacing:0.3px;
  position:relative;overflow:hidden;
}
.tb-daily::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.1),transparent);pointer-events:none}
.tb-daily:hover{filter:brightness(1.15);box-shadow:0 6px 22px rgba(29,185,84,0.4);transform:translateY(-1px)}
.tb-daily:disabled{opacity:.3;cursor:not-allowed;transform:none!important}

/* ── GAME AREA ── */
#game-area{flex:1;display:flex;overflow:hidden;min-width:0}

/* ── BET PANEL ── */
.bet-panel{
  width:212px;flex-shrink:0;
  background:linear-gradient(180deg,#080814,#05050e);
  border-left:1px solid var(--sidebar-border);
  display:flex;flex-direction:column;overflow-y:auto;position:relative;
}
.bet-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0.5}
.bp{padding:9px 10px 7px;border-bottom:1px solid rgba(255,255,255,0.04)}
.bp:last-child{border-bottom:none}
.bp-title{font-family:'Cinzel',serif;font-size:7px;font-weight:700;letter-spacing:2.5px;color:rgba(240,180,41,0.45);text-transform:uppercase;margin-bottom:6px}
.bet-row{
  background:linear-gradient(135deg,rgba(255,255,255,0.03),rgba(255,255,255,0.008));
  border:1px solid rgba(255,255,255,0.06);border-radius:7px;padding:6px 10px;
  display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;
}
.bet-lbl{font-size:9px;color:var(--text3);font-weight:700;letter-spacing:.5px}
.bet-val{font-family:'Oswald',sans-serif;font-size:19px;font-weight:500;color:var(--gold);text-shadow:0 0 12px rgba(240,180,41,0.3)}
input.bet-val{background:none;border:none;outline:none;width:80px;text-align:right;-moz-appearance:textfield;cursor:text;}
input.bet-val::-webkit-inner-spin-button,input.bet-val::-webkit-outer-spin-button{-webkit-appearance:none;}
.bet-sym{font-size:9px;color:var(--text3);margin-right:2px}

/* Chips redesignées */
.chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px;justify-content:center}
.chip{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  font-family:'Oswald',sans-serif;font-size:10.5px;font-weight:900;
  color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.95);
  border:3px solid rgba(255,255,255,.22);
  box-shadow:0 4px 12px rgba(0,0,0,.7),inset 0 2px 0 rgba(255,255,255,.22),inset 0 -2px 0 rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.5);
  transition:transform .12s,box-shadow .14s,border-color .12s;
  user-select:none;position:relative;flex-shrink:0;
}
/* Anneau intérieur (style jeton de casino) */
.chip::before{content:'';position:absolute;inset:4px;border-radius:50%;border:2px dashed rgba(255,255,255,.28);pointer-events:none}
/* Reflet de lumière */
.chip::after{
  content:'';position:absolute;top:3px;left:8px;width:55%;height:35%;
  background:linear-gradient(135deg,rgba(255,255,255,.22),transparent);
  border-radius:50%;pointer-events:none;
}
.chip:hover{transform:translateY(-4px) scale(1.12);box-shadow:0 8px 22px rgba(0,0,0,.75),inset 0 2px 0 rgba(255,255,255,.3),inset 0 -2px 0 rgba(0,0,0,.4)}
.chip:active{transform:scale(.91)}
.chip.active{border-color:rgba(255,255,255,.9);box-shadow:0 0 0 3px rgba(255,255,255,.35),0 6px 20px rgba(0,0,0,.7)}
.chip[data-c=r]{background:radial-gradient(circle at 40% 35%,#f05252,#c0392b 60%,#922b21)}
.chip[data-c=b]{background:radial-gradient(circle at 40% 35%,#5b9df5,#2563eb 60%,#1a4bb5)}
.chip[data-c=g]{background:radial-gradient(circle at 40% 35%,#26d668,#159b45 60%,#0e7234)}
.chip[data-c=y]{background:radial-gradient(circle at 40% 35%,#ffd060,#d4a017 60%,#9a7010)}
.chip[data-c=p]{background:radial-gradient(circle at 40% 35%,#a87cf8,#7c3aed 60%,#5b25b5)}
.chip[data-c=o]{background:radial-gradient(circle at 40% 35%,#fb923c,#d05a14 60%,#9a3f08)}
.chip[data-c=m]{background:radial-gradient(circle at 40% 35%,#c0375d,#861433 60%,#5e0a21)}
.chip[data-c=t]{background:radial-gradient(circle at 40% 35%,#22b8d4,#0878a0 60%,#04556e)}
.chip[data-c=h]{background:radial-gradient(circle at 40% 35%,#f472b6,#c0185e 60%,#87094a)}
.chip[data-c=s]{background:radial-gradient(circle at 40% 35%,#b0bec5,#546e7a 60%,#37474f)}
.chip-lbl{display:none}
.qrow{display:flex;gap:3px}
.qbtn{flex:1;background:var(--bg3);border:1px solid rgba(255,255,255,.06);border-radius:5px;padding:4px 2px;color:var(--text2);font-size:10px;font-weight:800;transition:all .13s;text-align:center}
.qbtn:hover{background:var(--bg4);color:var(--gold);border-color:rgba(240,180,41,0.25)}
.clr-btn{width:100%;background:transparent;border:1px solid rgba(255,255,255,.06);border-radius:5px;padding:5px;color:var(--text3);font-size:10px;font-weight:700;transition:all .13s;margin-top:4px}
.clr-btn:hover{border-color:rgba(230,57,70,.4);color:var(--red);background:rgba(230,57,70,.06)}

/* Action buttons */
.abtn{
  padding:10px 6px;border-radius:7px;
  font-family:'Oswald',sans-serif;font-weight:500;font-size:13px;
  letter-spacing:.5px;border:none;transition:all .2s;
  position:relative;overflow:hidden;user-select:none;width:100%;display:block;
}
.abtn::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.11),transparent 60%);pointer-events:none}
.abtn:not(:disabled):hover{transform:translateY(-2px);filter:brightness(1.14)}
.abtn:not(:disabled):active{transform:scale(.96)}
.abtn:disabled{opacity:.18;cursor:not-allowed;transform:none!important;filter:saturate(.3)!important}
.abtn-sub{font-size:7px;font-family:'Nunito',sans-serif;font-weight:600;display:block;opacity:.6;margin-top:1px;letter-spacing:0}
.a-green{background:linear-gradient(135deg,#1db954,#138c3a,#0d6929);color:#fff;box-shadow:0 4px 18px rgba(29,185,84,0.28);margin-bottom:4px;font-size:14px;padding:12px}
.a-green:not(:disabled):hover{box-shadow:0 6px 26px rgba(29,185,84,0.5)}
.a-blue{background:linear-gradient(135deg,#4f8ef7,#2563eb,#1a4bb5);color:#fff;box-shadow:0 4px 14px rgba(79,142,247,0.25)}
.a-blue:not(:disabled):hover{box-shadow:0 6px 22px rgba(79,142,247,0.44)}
.a-gray{background:linear-gradient(135deg,var(--bg3),var(--bg2));color:var(--text);border:1px solid var(--border2)}
.a-gold{background:linear-gradient(135deg,#c8921a,#a0700e,#7a5208);color:#fff;box-shadow:0 4px 14px rgba(200,146,26,0.28)}
.a-gold:not(:disabled):hover{box-shadow:0 6px 22px rgba(200,146,26,0.48)}
.acts2{display:grid;grid-template-columns:1fr 1fr;gap:4px}

/* Stats */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.stat-tile{
  background:linear-gradient(135deg,rgba(255,255,255,0.035),rgba(255,255,255,0.012));
  border:1px solid rgba(255,255,255,0.05);border-radius:7px;padding:6px 7px;text-align:center;position:relative;overflow:hidden;
}
.stat-tile::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1.5px}
.st-w::after{background:linear-gradient(90deg,transparent,var(--green),transparent)}
.st-l::after{background:linear-gradient(90deg,transparent,var(--red),transparent)}
.st-p::after{background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.st-s::after{background:linear-gradient(90deg,transparent,var(--blue),transparent)}
.sval{font-family:'Oswald',sans-serif;font-size:17px;font-weight:600;line-height:1}
.st-w .sval{color:var(--green)}.st-l .sval{color:var(--red)}.st-p .sval{color:var(--gold)}.st-s .sval{color:var(--blue)}
.slbl{font-family:'Cinzel',serif;font-size:6.5px;color:var(--text3);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-top:2px}

/* History */
.hist{max-height:100px;overflow-y:auto}
.hrow{display:flex;align-items:center;gap:3px;padding:3px 5px;border-radius:5px;margin-bottom:2px;background:linear-gradient(135deg,rgba(255,255,255,0.025),transparent);animation:hslide .22s ease}
.hbadge{font-size:7px;font-weight:800;padding:1px 4px;border-radius:3px;flex-shrink:0}
.hbadge.win{background:rgba(29,185,84,.16);color:var(--green)}
.hbadge.lose{background:rgba(230,57,70,.16);color:var(--red)}
.hbadge.push{background:rgba(79,142,247,.12);color:var(--blue)}
.hinfo{font-size:8px;color:var(--text3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hamt{font-size:9.5px;font-weight:800;font-family:'Oswald',sans-serif}
.hamt.win{color:var(--green)}.hamt.lose{color:var(--red)}.hamt.push{color:var(--blue)}

/* Particles */
.particles{position:absolute;inset:0;pointer-events:none;z-index:25;overflow:hidden}
.particle{position:absolute;animation:pfall 1.2s ease-out forwards}
@keyframes pfall{0%{transform:translateY(-5px) rotate(0);opacity:1}100%{transform:translateY(300px) rotate(720deg);opacity:0}}

/* Result overlay */
.res-ov{
  position:absolute;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;
  pointer-events:none;opacity:0;transition:opacity .2s;
  background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(0,0,0,0.78),transparent);
}
.res-ov.show{opacity:1}
.res-card{text-align:center;animation:resPop .45s cubic-bezier(.34,1.56,.64,1) both}
@keyframes resPop{from{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}
.res-main{
  font-family:'Cinzel',serif;font-size:60px;font-weight:900;line-height:1;letter-spacing:4px;
  text-shadow:0 0 70px currentColor,0 0 35px currentColor,0 4px 24px rgba(0,0,0,.95);
}
.res-ov.win .res-main{color:var(--gold)}.res-ov.lose .res-main{color:var(--red)}.res-ov.push .res-main{color:var(--blue)}
.res-sub{font-family:'Cinzel',serif;font-size:15px;font-weight:700;margin-top:7px;letter-spacing:2px}
.res-ov.win .res-sub{color:var(--green)}.res-ov.lose .res-sub{color:rgba(230,57,70,.85)}.res-ov.push .res-sub{color:rgba(100,160,255,.85)}
/* Ornements en coins du résultat */
.res-card::before,.res-card::after{
  content:'♠ ♥ ♦ ♣';
  display:block;font-size:10px;letter-spacing:6px;
  color:rgba(240,180,41,0.3);margin:6px 0;font-family:'Nunito',sans-serif;
}
.wm{position:absolute;bottom:5px;left:50%;transform:translateX(-50%);font-family:'Cinzel',serif;font-size:7px;color:rgba(255,255,255,.04);letter-spacing:3px;text-transform:uppercase;pointer-events:none;white-space:nowrap;z-index:1}

/* Toast */
.toast-wrap{position:fixed;bottom:14px;right:14px;z-index:300;display:flex;flex-direction:column;gap:5px;align-items:flex-end}
.toast{
  background:linear-gradient(135deg,rgba(15,15,30,0.97),rgba(8,8,20,0.97));
  border:1px solid rgba(240,180,41,0.22);
  backdrop-filter:blur(14px);
  border-radius:9px;padding:10px 15px;font-size:12px;font-weight:700;color:var(--text);
  box-shadow:0 8px 36px rgba(0,0,0,0.75),0 0 0 1px rgba(255,255,255,0.03);
  animation:tin .28s cubic-bezier(.34,1.56,.64,1);
}
@keyframes tin{from{transform:translateX(20px) scale(.88);opacity:0}to{transform:none;opacity:1}}
.toast.out{animation:tout .22s ease forwards}
@keyframes tout{to{transform:translateX(20px) scale(.88);opacity:0}}
.empty-hist{text-align:center;padding:10px;color:var(--text3);font-size:10px;font-family:'Cinzel',serif;letter-spacing:1px}
