/* jacks.css — Jacks or Better single-hand video poker UI.
   Ported/trimmed from videopoker-web game-single.css. Scoped under
   #job-game so it can live alongside the host SEO page styles. */

#job-game *{margin:0;padding:0;box-sizing:border-box}

/* ── Game wrapper ── */
#job-game #game{width:100%;max-width:620px;margin:0 auto;padding:8px 12px;display:flex;flex-direction:column;gap:4px;background:radial-gradient(ellipse at 50% 40%,rgba(20,50,140,.3) 0%,rgba(10,30,100,.1) 50%,transparent 80%);font-family:'Arial Black',Arial,sans-serif;color:#fff}

/* Machine order: payout → msg → cards → cbar → btns */
#job-game #payout-table{order:1}
#job-game #msg{order:4}
#job-game #cards{order:5}
#job-game #cbar{order:6}
#job-game #btns{order:7}
#job-game #cel{order:8}

/* ── PAY TABLE ── */
#job-game #payout-table{display:grid;grid-template-columns:auto repeat(5,1fr);background:#002570;border:2px solid #FFD700;border-radius:3px;overflow:hidden;margin-bottom:4px;box-shadow:0 2px 12px rgba(0,0,0,.5)}
#job-game .pr{display:contents}
#job-game .pr .hn,#job-game .pr .pv{border-bottom:1px solid rgba(255,215,0,.15)}
#job-game .pr:last-child .hn,#job-game .pr:last-child .pv{border-bottom:none}
#job-game .pr .hn{white-space:nowrap;padding:2px 12px;color:#FFD700;text-transform:uppercase;letter-spacing:.3px;font-size:.78rem;font-weight:700;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;line-height:1.2;display:flex;align-items:center}
#job-game .pr .pv{position:relative;transition:all .25s ease-in-out;padding:1px 6px;color:#FFD700;font-weight:600;font-size:.78rem;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;line-height:1;display:flex;align-items:center;justify-content:flex-end}
#job-game .pr .pv::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:rgba(255,215,0,.35)}
#job-game .pr .ch{background:#E03030!important;color:#FFD700!important;font-weight:900;text-shadow:none;border-bottom-color:#E03030!important}
#job-game .pr .ch::before{background:#E03030}
#job-game .pr:last-child .ch{border-bottom:none!important}
#job-game .pr.win .hn,#job-game .pr.win .pv{background:linear-gradient(90deg,rgba(255,215,0,.25),rgba(255,215,0,.12))!important;animation:job-wp .4s ease}
#job-game .pr.win .hn{color:#fff!important;font-weight:900;text-shadow:0 0 8px rgba(255,215,0,.6)}
#job-game .pr.win .pv{color:#ffd700!important}
#job-game .pr.win .ch{background:#CC0000!important;color:#fff!important;border-bottom-color:#CC0000!important}
@keyframes job-wp{0%{background:rgba(255,215,0,0)}40%{background:rgba(255,215,0,.35)}100%{background:rgba(255,215,0,.18)}}

/* ── MESSAGE ── */
#job-game #msg{min-height:24px;text-align:center;display:flex;align-items:center;justify-content:center}
#job-game #rm{font-size:.9rem;font-weight:900;letter-spacing:1.2px;color:#4cff7c;text-transform:uppercase;text-shadow:0 0 10px rgba(76,255,124,.4)}
#job-game #rm.nw{color:rgba(255,255,255,.55);text-shadow:none;letter-spacing:1px}

/* ── CARDS ── */
#job-game #cards{display:flex;justify-content:space-between;padding:0 2.5%;perspective:1000px;align-items:flex-start;user-select:none;-webkit-user-select:none;gap:clamp(3px,1vw,8px);height:auto;margin-bottom:2px;width:100%}
#job-game .cs{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative;padding-top:22px;flex:1 1 0;min-width:0}
#job-game .card{container-type:size;width:100%;aspect-ratio:5/7;background:#fff;border-radius:6px;border:1px solid rgba(0,0,0,.08);display:flex;flex-direction:column;justify-content:space-between;padding:6px;cursor:pointer;position:relative;transition:transform .15s,box-shadow .15s;user-select:none;transform-style:preserve-3d;backface-visibility:hidden}
#job-game .card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.5)}
#job-game .card.held{border-color:#ffe033;box-shadow:0 0 18px rgba(255,224,0,.9);transform:translateY(-8px)}
#job-game .card.wc{border-color:#ffe033;box-shadow:0 0 20px rgba(255,224,51,.8);animation:job-cardWin 1.6s ease-in-out infinite;transform:translateY(-8px)}
@keyframes job-cardWin{0%,100%{box-shadow:0 0 12px rgba(255,224,51,.5)}50%{box-shadow:0 0 28px rgba(255,224,51,1),0 0 48px rgba(255,180,0,.3)}}
#job-game .card.fd{background:repeating-linear-gradient(45deg,transparent,transparent 7px,rgba(255,215,0,.1) 7px,rgba(255,215,0,.1) 8px),repeating-linear-gradient(-45deg,transparent,transparent 7px,rgba(255,215,0,.1) 7px,rgba(255,215,0,.1) 8px),linear-gradient(180deg,#001C6E 0%,#001450 50%,#000D3A 100%);border-color:#FFD700;box-shadow:inset 0 0 12px rgba(0,16,72,.4),0 2px 8px rgba(0,0,0,.3)}

/* Card face content */
#job-game .cc{font-family:'Fredoka One',cursive;position:absolute;top:2%;left:8%;width:25%;display:flex;flex-direction:column;align-items:center}
#job-game .cc .cr{font-size:40cqi;line-height:.9;margin-bottom:1cqi}
#job-game .cc .csuit{font-size:28cqi;line-height:1;font-variant-emoji:text;font-family:sans-serif}
#job-game .cm{position:absolute;bottom:1%;left:50%;transform:translateX(-50%);font-family:'Fredoka One',cursive;font-size:75cqi;line-height:1;filter:drop-shadow(0 1px 0 rgba(0,0,0,.15));display:flex;justify-content:center;align-items:center;font-variant-emoji:text;font-family:sans-serif}
#job-game .cp{position:absolute;top:4%;right:4%;width:64cqi;height:64cqi;border-radius:3cqi;pointer-events:none;object-fit:contain}
#job-game .red{color:#FF0000}
#job-game .black{color:#000}

/* HOLD label */
#job-game .hl{position:absolute;top:0;left:0;width:100%;text-align:center;font-size:.85rem;font-weight:900;color:#ffe033;letter-spacing:3px;text-transform:uppercase;height:22px;line-height:22px;text-shadow:0 0 10px rgba(255,224,0,.8)}

/* ── CREDITS BAR (BET | WIN | CREDITS) ── */
#job-game #cbar{display:flex;background:transparent;padding:10px 0 6px}
#job-game .ci{flex:1;text-align:center;padding:6px 8px}
#job-game .ci:nth-child(1){order:3}
#job-game .ci:nth-child(2){order:1}
#job-game .ci:nth-child(3){order:2}
#job-game .cl{font-size:.7rem;color:#FFD700;text-transform:uppercase;letter-spacing:2px;margin-bottom:2px;font-weight:900}
#job-game .cv{font-size:1.6rem;font-weight:900;color:#fff;line-height:1;font-variant-numeric:tabular-nums;transition:color .3s}
#job-game #wv{color:#fff;font-size:1.8rem;font-weight:900}
#job-game #wv.active{color:#4cff7c}

/* ── BUTTONS ── */
#job-game #btns{display:flex;justify-content:space-between;align-items:center;gap:8px}
#job-game #btns-left,#job-game #btns-right{display:flex;gap:8px}
#job-game .btn{border-radius:8px;padding:12px 0;height:50px;font-weight:900;cursor:pointer;text-transform:uppercase;font-family:'Arial Black',Arial,sans-serif;font-size:.85rem;display:inline-flex;align-items:center;justify-content:center;transition:all .12s ease;letter-spacing:1px;background:linear-gradient(180deg,#FFE44D 0%,#F0C800 35%,#D4A800 65%,#B89000 100%);color:#111;border:3px solid #A07800;box-shadow:0 4px 0 #705000,inset 0 2px 0 rgba(255,255,255,.35);text-shadow:0 1px 0 rgba(255,255,255,.15)}
#job-game .btn:active{transform:translateY(4px);box-shadow:0 0 0 #705000,inset 0 2px 4px rgba(0,0,0,.3);filter:brightness(.85)}
#job-game .btn:hover:not(:disabled){background:linear-gradient(180deg,#FFEA66 0%,#F8D400 35%,#DDBB00 65%,#C49800 100%);box-shadow:0 4px 0 #705000,inset 0 2px 0 rgba(255,255,255,.4),0 0 12px rgba(255,215,0,.3)}
#job-game .btn:disabled{opacity:.3;filter:grayscale(.6) brightness(.5);box-shadow:none;cursor:not-allowed;transform:none}
@keyframes job-btnAppear{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
#job-game .dealbtn,#job-game .drawbtn{animation:job-btnAppear .25s ease-out}

@media (min-width:769px){
  #job-game #btns{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
  #job-game #btns-left,#job-game #btns-right{display:contents}
  #job-game .btn{width:100%;min-width:0}
}

/* ── Confetti ── */
#job-game #cel{display:none;position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:100;overflow:hidden}
#job-game .cf{position:absolute;width:10px;height:10px;border-radius:2px;animation:job-fall linear forwards}
@keyframes job-fall{to{transform:translateY(110vh) rotate(720deg);opacity:0}}

/* ══ RESPONSIVE ══ */
@media (max-width:768px){
  #job-game #game{max-width:100%;padding:6px;gap:4px}
  #job-game .pr .hn{font-size:.60rem;letter-spacing:.2px}
  #job-game .pr .pv{font-size:.66rem}
  #job-game .pr .ch{font-size:.72rem}
  #job-game .ci{padding:5px 4px}
  #job-game .cl{font-size:.6rem;letter-spacing:1.5px}
  #job-game .cv,#job-game #wv{font-size:1.4rem}
  #job-game .cs{padding-top:22px}
  #job-game .card{padding:3px}
  #job-game .hl{font-size:.6rem;letter-spacing:1.5px;height:20px;line-height:20px}
  #job-game #rm{font-size:.78rem;letter-spacing:1.2px}
  #job-game #rm.nw{font-size:.68rem}
  #job-game #btns{display:grid;grid-template-columns:1fr 1fr;gap:5px}
  #job-game #btns-left,#job-game #btns-right{display:contents}
  #job-game .btn{height:44px;width:100%;padding:0 8px;font-size:.72rem;letter-spacing:.5px;border-radius:6px}
  #job-game .clearbtn{grid-column:1;grid-row:1}
  #job-game .holdallbtn{grid-column:2;grid-row:1}
  #job-game .b1btn{grid-column:1;grid-row:2}
  #job-game .dealbtn,#job-game .drawbtn{grid-column:2;grid-row:2;font-size:.78rem;letter-spacing:.8px}
}
@media (max-width:430px){
  #job-game #game{padding:5px}
  #job-game .pr .hn{font-size:.56rem}
  #job-game .pr .pv{font-size:.62rem}
  #job-game .pr .ch{font-size:.68rem}
  #job-game .card{padding:2px}
  #job-game .btn{height:40px;font-size:.64rem}
  #job-game .cl{font-size:.55rem}
  #job-game .cv,#job-game #wv{font-size:1.3rem}
  #job-game #rm{font-size:.7rem}
}

/* ══ SOUND: settings modal (ported from rps, job- prefix) ══
   The speaker button lives in the page header (see index.html); only the
   modal styles live here. Modal mounts on document.body, so it is NOT scoped. */
.job-ss-mask{
  position:fixed;inset:0;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;padding:20px;animation:job-ss-mask-in 180ms ease;
  font-family:'Inter',system-ui,sans-serif}
@keyframes job-ss-mask-in{from{opacity:0}to{opacity:1}}
.job-ss-dialog{
  width:340px;max-width:100%;background:#1A2332;
  border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;color:#fff;
  animation:job-ss-dialog-in 220ms cubic-bezier(.2,.9,.3,1.1)}
@keyframes job-ss-dialog-in{
  from{opacity:0;transform:scale(.94) translateY(6px)}
  to{opacity:1;transform:scale(1) translateY(0)}}
.job-ss-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.job-ss-title{color:rgba(255,255,255,.75);font-size:14px;font-weight:700;letter-spacing:1.5px}
.job-ss-close{
  background:transparent;border:0;color:rgba(255,255,255,.4);
  cursor:pointer;padding:4px;display:inline-flex;border-radius:4px;
  transition:color .15s,background .15s}
.job-ss-close:hover{color:#fff;background:rgba(255,255,255,.08)}
.job-ss-row{
  display:flex;align-items:center;padding:14px 20px;gap:14px;
  border-bottom:1px solid rgba(255,255,255,.06)}
.job-ss-row:last-child{border-bottom:none}
.job-ss-label{flex:0 0 40%;color:rgba(255,255,255,.6);font-size:15px}
.job-ss-switch{position:relative;display:inline-block;margin-left:auto;cursor:pointer}
.job-ss-switch input{appearance:none;position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.job-ss-switch-track{
  display:inline-block;width:44px;height:24px;border-radius:12px;
  background:rgba(255,255,255,.12);transition:background .2s;position:relative}
.job-ss-switch-thumb{
  position:absolute;top:3px;left:3px;width:18px;height:18px;
  border-radius:50%;background:rgba(255,255,255,.7);transition:transform .2s,background .2s}
.job-ss-switch input:checked + .job-ss-switch-track{background:rgba(255,215,0,.4)}
.job-ss-switch input:checked + .job-ss-switch-track .job-ss-switch-thumb{transform:translateX(20px);background:#FFD700}
input.job-ss-slider{
  flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;
  background:linear-gradient(to right,#FFD700 0%,#FFD700 var(--fill,100%),
    rgba(255,255,255,.12) var(--fill,100%),rgba(255,255,255,.12) 100%);
  outline:none;cursor:pointer}
input.job-ss-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:16px;height:16px;
  border-radius:50%;background:#fff;border:0;box-shadow:0 1px 4px rgba(0,0,0,.5);cursor:pointer}
input.job-ss-slider::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;background:#fff;border:0;
  box-shadow:0 1px 4px rgba(0,0,0,.5);cursor:pointer}
