/* Bot vs Player — AAA battlefield UI */

html, body.bot-page{ height:100%; }
body.bot-page{
  display:flex; flex-direction:column; overflow:hidden;
  background:
    radial-gradient(ellipse 90% 55% at 50% 4%, rgba(123,58,160,0.32), transparent 60%),
    radial-gradient(ellipse 90% 55% at 50% 98%, rgba(196,35,63,0.30), transparent 60%),
    radial-gradient(ellipse 140% 100% at 50% 50%, rgba(0,0,0,0) 35%, rgba(0,0,0,0.7) 100%),
    var(--bg);
  background-attachment:fixed;
}
body.bot-page > header{ flex-shrink:0; position:relative; z-index:1; }
body.bot-page > #board.bot-board{ flex:1 1 auto; min-height:0; position:relative; z-index:1; }
body.bot-page > #setup.setup-wrap,
body.bot-page > #modeSelect.setup-wrap,
body.bot-page > #tutorialMenu.setup-wrap{ flex:1 1 auto; position:relative; z-index:1; }

/* ===================================================================
   FX layers — particle background, arrows, popups, turn banner
   =================================================================== */
.fx-particles{ position:fixed; inset:0; z-index:0; pointer-events:none; }
.fx-particles canvas{ display:block; width:100% !important; height:100% !important; }

.fx-arrows{ position:fixed; inset:0; width:100%; height:100%; z-index:150; pointer-events:none; }
.fx-arrow-line{ stroke:var(--accent2); stroke-width:4; stroke-linecap:round; filter:drop-shadow(0 0 6px var(--accent2)); }
.fx-arrow-dot{ fill:#fff8; filter:drop-shadow(0 0 8px var(--accent2)); }

.fx-layer{ position:fixed; inset:0; z-index:160; pointer-events:none; overflow:hidden; }
.fx-pop{
  position:absolute; transform:translateX(-50%);
  font-family:var(--display); font-weight:800;
  font-size:clamp(15px, 2.4vh, 28px);
  color:#ff5c6c; text-shadow:0 0 10px #ff0000aa, 0 2px 4px #000;
  white-space:nowrap; pointer-events:none;
}
.fx-pop.heal{ color:#7cffb2; text-shadow:0 0 10px #00ff8866, 0 2px 4px #000; }
.fx-pop.gain{ color:#ffd76e; text-shadow:0 0 10px #ffae0066, 0 2px 4px #000; }

@keyframes fxHit{
  0%,100%{ transform:translateX(0); filter:brightness(1); }
  20%{ transform:translateX(-6px); filter:brightness(2.2); }
  40%{ transform:translateX(6px); }
  60%{ transform:translateX(-4px); }
  80%{ transform:translateX(4px); }
}
.fx-hit{ animation:fxHit .35s ease; }

.turn-banner{
  position:fixed; left:50%; top:40%; transform:translate(-50%,-50%) scale(.7);
  font-family:var(--display); font-weight:900; text-transform:uppercase;
  font-size:clamp(26px, 6vw, 64px); letter-spacing:.3em;
  color:#fff; text-shadow:0 0 24px var(--accent2), 0 0 70px var(--accent), 0 4px 14px #000;
  opacity:0; pointer-events:none; z-index:170; white-space:nowrap;
}
.turn-banner.show{ opacity:1; }
.turn-banner.opp{ text-shadow:0 0 24px #b48bff, 0 0 70px #5b2a8a, 0 4px 14px #000; }

@keyframes summonIn{
  0%{ box-shadow:0 0 0 0 #fff0, inset 0 0 0 0 #fff0; }
  35%{ box-shadow:0 0 30px 10px var(--accent2); }
  100%{ box-shadow:0 2px 8px #0008; }
}
.slot.summon-in{ animation:summonIn .55s ease-out; }

/* ===================================================================
   Setup screen
   =================================================================== */
.setup-wrap{
  max-width:760px; margin:40px auto; padding:24px;
  background:linear-gradient(180deg, var(--surface) 0%, var(--surface2) 100%);
  border:1px solid var(--border); border-radius:12px;
  text-align:center; box-shadow:0 12px 40px #000a;
}
.setup-wrap h2{ font-family:var(--display); color:var(--accent2); margin-top:0; text-shadow:0 0 18px #e8657f55; }
.setup-note{ color:var(--muted); font-size:.9em; line-height:1.6; margin-bottom:20px; }
.deck-pick{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.deckbtn{
  flex:1 1 240px; max-width:300px; padding:18px; cursor:pointer;
  background:var(--surface2); border:1px solid var(--border); border-radius:10px;
  color:var(--text); text-align:left; transition:.15s;
}
.deckbtn:hover{ border-color:var(--accent2); background:#33202a; box-shadow:0 0 22px -4px var(--accent2); transform:translateY(-2px); }
.deckbtn-name{ font-family:var(--display); font-weight:700; color:var(--accent2); margin-bottom:6px; }
.deckbtn-desc{ font-size:.85em; color:var(--muted); }
.mode-grid{ display:flex; gap:20px; justify-content:center; flex-wrap:wrap; margin-top:8px; }
.mode-card{
  flex:1 1 200px; max-width:240px; padding:28px 20px; cursor:pointer;
  background:var(--surface2); border:1px solid var(--border); border-radius:12px;
  color:var(--text); text-align:center; transition:.15s;
}
a.mode-card{ display:block; text-decoration:none; }
.mode-card:hover{ border-color:var(--accent2); background:#33202a; box-shadow:0 0 22px -4px var(--accent2); transform:translateY(-2px); }
.mode-card-icon{ font-size:2.6em; margin-bottom:10px; }
.mode-card-name{ font-family:var(--display); font-weight:700; font-size:1.2em; color:var(--accent2); margin-bottom:8px; }
.mode-card-desc{ font-size:.85em; color:var(--muted); line-height:1.5; }

.part-grid{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.part-card{
  flex:1 1 240px; max-width:300px; padding:18px; cursor:pointer;
  background:var(--surface2); border:1px solid var(--border); border-radius:10px;
  color:var(--text); text-align:left; transition:.15s;
}
.part-card:hover{ border-color:var(--accent2); background:#33202a; box-shadow:0 0 22px -4px var(--accent2); transform:translateY(-2px); }
.part-card-title{ font-family:var(--display); font-weight:700; color:var(--accent2); margin-bottom:6px; }
.part-card-desc{ font-size:.85em; color:var(--muted); }
.part-reward{ margin-top:10px; font-size:.85em; font-weight:700; color:#ffd76e; }
.part-card.soon{ cursor:not-allowed; opacity:.5; }
.part-card.soon:hover{ border-color:var(--border); background:var(--surface2); box-shadow:none; transform:none; }
.part-card-soon{
  display:inline-block; margin-top:10px; padding:3px 10px; font-size:.75em; font-weight:700;
  color:var(--muted); border:1px solid var(--border); border-radius:999px;
}

.back-btn{
  position:absolute; top:16px; left:16px; padding:6px 14px; cursor:pointer;
  background:transparent; border:1px solid var(--border); border-radius:8px;
  color:var(--text); font-family:var(--display); font-weight:700; font-size:.85em;
  transition:.15s;
}
.back-btn:hover{ border-color:var(--accent2); color:var(--accent2); }

/* ===================================================================
   Battlefield shell
   =================================================================== */
.bot-board{
  max-width:1480px; width:100%; margin:0 auto; padding:6px 10px;
  display:flex; flex-direction:column; gap:4px; overflow:hidden;
}

.parea{
  position:relative; display:flex; flex-direction:column; gap:6px; justify-content:space-around;
  background:linear-gradient(180deg, var(--surface) 0%, var(--surface2) 100%);
  border:1px solid var(--border); border-radius:10px; padding:8px 14px;
  flex:1 0 auto; overflow:visible;
  box-shadow:inset 0 0 40px -20px #000c;
  transition:box-shadow .3s ease, border-color .3s ease;
}
.parea::before, .parea::after{
  content:''; position:absolute; width:16px; height:16px; pointer-events:none; opacity:.5;
  border:2px solid var(--accent2);
}
.parea::before{ top:-1px; left:-1px; border-right:none; border-bottom:none; border-radius:8px 0 0 0; }
.parea::after{ bottom:-1px; right:-1px; border-left:none; border-top:none; border-radius:0 0 8px 0; }
.parea.active-turn{ border-color:var(--accent2); box-shadow:inset 0 0 40px -20px #000c, 0 0 28px -6px var(--accent2); }
.parea.opp{ order:1; }
.parea.opp::before, .parea.opp::after{ border-color:#b48bff; }
.midbar{ order:2; display:flex; align-items:center; gap:14px; justify-content:center; padding:4px; flex-shrink:0; }
.parea.me{ order:3; }
.log-panel{ order:4; flex-shrink:0; }

/* ===================================================================
   Hero plate (portrait + HP) and resource crystal
   =================================================================== */
.hero-row{ display:flex; align-items:center; gap:10px; flex-shrink:0; }
.hero-plate{
  display:flex; align-items:center; gap:10px; flex-shrink:0; min-width:0;
  padding:4px 14px 4px 4px; border-radius:999px;
  background:linear-gradient(135deg, var(--surface2), var(--surface));
  border:1px solid var(--border);
  box-shadow:0 4px 18px #0008, inset 0 0 0 1px #ffffff0c;
}
.hero-portrait{
  width:clamp(38px, 6vh, 70px); height:clamp(38px, 6vh, 70px); border-radius:50%;
  background-color:var(--surface2); background-size:cover; background-position:center top;
  border:2px solid var(--accent2); box-shadow:0 0 0 3px #00000080, 0 0 16px -2px var(--accent2);
  flex-shrink:0;
}
.parea.opp .hero-portrait{ border-color:#b48bff; box-shadow:0 0 0 3px #00000080, 0 0 16px -2px #b48bff; }
.active-glow{ animation:heroPulse 1.6s ease-in-out infinite; }
@keyframes heroPulse{
  0%,100%{ box-shadow:0 4px 18px #0008, inset 0 0 0 1px #ffffff0c, 0 0 0 2px var(--accent2)33; }
  50%{ box-shadow:0 4px 24px #0008, inset 0 0 0 1px #ffffff18, 0 0 0 2px var(--accent2); }
}
.parea.opp .active-glow{
  animation-name:heroPulseOpp;
}
@keyframes heroPulseOpp{
  0%,100%{ box-shadow:0 4px 18px #0008, inset 0 0 0 1px #ffffff0c, 0 0 0 2px #b48bff33; }
  50%{ box-shadow:0 4px 24px #0008, inset 0 0 0 1px #ffffff18, 0 0 0 2px #b48bff; }
}
.hero-meta{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.hero-meta .pname{
  font-family:var(--display); font-weight:700; color:var(--accent2); font-size:.92em;
  letter-spacing:.02em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:32vw;
}
.parea.opp .hero-meta .pname{ color:#c9a8ff; }
.hero-hp{
  position:relative; height:14px; min-width:120px; width:18vw; max-width:240px;
  border-radius:7px; background:#1a0d12; border:1px solid #00000080; overflow:hidden;
  box-shadow:inset 0 1px 4px #000a;
}
.hero-hp .hpfill{
  height:100%; background:linear-gradient(90deg,#ff4d6d,#ffd76e);
  box-shadow:0 0 10px #ff4d6daa; transition:width .4s ease;
}
.hero-hp .hptext{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:.68em; font-weight:700; color:#fff; text-shadow:0 1px 2px #000; letter-spacing:.04em;
}
.hand-count{ font-size:.7em; color:var(--muted); }

.orb-row{ margin-left:auto; flex-shrink:0; display:flex; align-items:center; gap:6px; }
.resource-orb{
  flex-shrink:0; display:flex; align-items:center; justify-content:center;
  width:clamp(34px, 5.2vh, 58px); height:clamp(34px, 5.2vh, 58px);
  background:radial-gradient(circle at 35% 30%, #8be9ff, #1c5d8c 60%, #0a2740 100%);
  border-radius:14px; transform:rotate(45deg);
  box-shadow:0 0 16px -2px #4fd1ff99, inset 0 0 10px #ffffff40;
}
.resource-orb .rv{
  transform:rotate(-45deg); display:flex; flex-direction:column; align-items:center; justify-content:center;
  line-height:1.05;
}
.resource-orb .rv b{ font-size:1.05em; color:#fff; text-shadow:0 1px 3px #000; font-family:var(--display); }
.resource-orb .rv small{ font-size:.5em; color:#bfeaff; letter-spacing:.12em; }
.resource-orb.growth-orb{
  background:radial-gradient(circle at 35% 30%, #c4ff9b, #2e7d32 60%, #0a2f12 100%);
  box-shadow:0 0 16px -2px #7CFC0099, inset 0 0 10px #ffffff40;
}
.resource-orb.growth-orb .rv small{ color:#e6ffd0; }

/* ===================================================================
   Field row — battlefield lanes
   =================================================================== */
.field-row{
  display:flex; align-items:flex-end; justify-content:center; gap:14px; flex-wrap:nowrap;
  overflow:visible; flex-shrink:0; padding:4px 0;
  border-radius:8px;
}
.fgroup{ display:flex; flex-direction:column; align-items:center; gap:6px; flex-shrink:0; }
.fgroup .flabel{ font-size:.7em; color:var(--muted); letter-spacing:.08em; text-transform:uppercase; }
.slot-pair{ display:flex; gap:8px; }
.pile-group{ flex-direction:row; gap:10px; align-items:flex-end; }

.slot{
  width:90px; height:130px;
  border:2px solid var(--border); border-radius:10px;
  background:var(--surface2); box-shadow:inset 0 0 6px #0006;
  display:flex; align-items:center; justify-content:center;
  font-size:.78em; color:var(--muted); position:relative; flex-shrink:0; text-align:center; padding:5px;
  cursor:default;
}
.slot.filled{
  border-color:var(--accent2); cursor:pointer; color:var(--text); box-shadow:0 2px 8px #0008;
  background-size:cover; background-position:center; transition:transform .15s, box-shadow .15s;
}
.slot.filled:hover{ transform:translateY(-6px) scale(1.08); z-index:3; box-shadow:0 10px 22px #000c, 0 0 0 2px var(--accent2), 0 0 18px var(--accent2); }
.slot.filled::before{
  content:''; position:absolute; inset:0; border-radius:6px;
  background:linear-gradient(to top, #000d 0%, #0006 38%, transparent 72%);
}
.slot.character{ width:120px; height:180px; font-size:.92em; border-width:3px; border-radius:12px; }
.slot.character.filled{ box-shadow:0 10px 24px #000b, 0 0 28px -6px var(--accent2); }
.parea.opp .slot.character.filled{ border-color:#b48bff; box-shadow:0 10px 24px #000b, 0 0 28px -6px #b48bff; }
.slot.character .sname{ -webkit-line-clamp:3; max-height:3.6em; }

.pile-stack{ display:flex; flex-direction:column; align-items:center; gap:4px; }
.pile-stack .stackface{
  width:90px; height:130px;
  border:2px solid var(--border); border-radius:8px;
  background:repeating-linear-gradient(135deg,var(--surface2),var(--surface2) 6px,var(--bg) 6px,var(--bg) 12px);
  display:flex; align-items:center; justify-content:center; font-size:2em; color:var(--muted);
  position:relative; box-shadow:inset 0 0 6px #0006;
}
.pile-stack .stackcount{
  position:absolute; bottom:4px; right:4px; font-size:1em; font-weight:700;
  background:#000a; border-radius:4px; padding:1px 6px; color:var(--text);
}
.has-sleeve-img{ background-size:cover !important; background-position:center !important; color:transparent !important; }
.pile-stack .stacklabel{ font-size:.75em; color:var(--muted); }
.pile-stack.grave .stackface{ color:#7a5560; }
.slot .sname{
  font-weight:700; line-height:1.2; position:relative; z-index:1; text-shadow:0 1px 2px #000;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  max-height:2.4em; width:100%;
}
.slot .shp{ position:absolute; bottom:4px; left:4px; right:4px; font-size:1em; color:#ff9b9b; background:#0008; border-radius:4px; z-index:1; padding:1px 0; }
.slot .scd{ position:absolute; top:4px; right:4px; font-size:1em; background:#000a; border-radius:4px; padding:1px 5px; color:#ffd76e; z-index:1; }
.slot .sell-btn{
  position:absolute; top:4px; left:4px; font-size:1em; z-index:2;
  background:#000a; border:1px solid var(--border); border-radius:4px; padding:1px 5px;
  color:#ffd76e; font-family:var(--display); font-weight:700; cursor:pointer; line-height:1.4;
}
.slot .sell-btn:hover{ background:var(--accent); color:#fff; border-color:var(--accent2); }
.slot.ready{ outline:3px solid var(--accent2); outline-offset:1px; animation:slotReady 1.3s ease-in-out infinite; z-index:2; }
@keyframes slotReady{
  0%,100%{ box-shadow:0 0 10px var(--accent2); }
  50%{ box-shadow:0 0 24px 5px var(--accent2); }
}
.slot.tapped{ opacity:.45; }

/* ===================================================================
   Hand dock — fanned cards with hover zoom + drag/drop
   =================================================================== */
.handrow{
  display:flex; gap:8px; flex-wrap:nowrap; align-items:flex-end; justify-content:center;
  overflow:visible; flex-shrink:0; padding:6px 4px 2px;
}
.handcard{
  height:130px; aspect-ratio:0.72; width:auto;
  border:1px solid var(--border); border-radius:8px;
  background:var(--surface2); background-size:cover; background-position:center;
  font-size:.78em; padding:6px; cursor:pointer; text-align:center; flex-shrink:0;
  display:flex; flex-direction:column; justify-content:space-between; position:relative;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  box-shadow:0 2px 8px #0008;
  transform:rotate(var(--rot, 0deg));
  transform-origin:bottom center;
}
.handcard::before{
  content:''; position:absolute; inset:0; border-radius:7px;
  background:linear-gradient(to top, #000d 0%, #0006 38%, transparent 72%);
}
.handcard > div{ position:relative; z-index:1; text-shadow:0 1px 2px #000; }
.handcard:hover{
  border-color:var(--accent2); transform:translateY(-22px) scale(1.18) rotate(0deg);
  z-index:10; box-shadow:0 16px 30px #000d, 0 0 0 2px var(--accent2), 0 0 22px var(--accent2);
}
.handcard.unaffordable{ opacity:.4; cursor:not-allowed; }
.handcard.unaffordable:hover{ transform:rotate(var(--rot, 0deg)); box-shadow:0 2px 8px #0008; border-color:var(--border); z-index:1; }
.handcard.dragging{ opacity:.3; }
.handcard .hname{
  font-weight:700; line-height:1.1; font-size:.85em;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.handcard .hcost{ color:#ffd76e; font-weight:700; font-size:.85em; line-height:1.1; }
.handcard.facedown{ height:56px; display:flex; align-items:center; justify-content:center; font-size:1.6em; color:var(--muted); }
.handcard.facedown:hover{ transform:rotate(var(--rot, 0deg)); box-shadow:0 2px 8px #0008; border-color:var(--border); z-index:1; }

.field-row.drop-ready{ outline:2px dashed var(--accent2); outline-offset:-4px; box-shadow:0 0 24px -6px var(--accent2) inset; }

/* ===================================================================
   Turn controls
   =================================================================== */
.phase-info{
  font-family:var(--display); font-weight:700; color:var(--accent2); min-width:220px; text-align:center;
  text-shadow:0 0 12px #e8657f44; letter-spacing:.03em;
}
.next-btn, .restart-btn{
  background:var(--accent); color:#fff; border:none; border-radius:999px; padding:8px 16px;
  font-weight:700; cursor:pointer; font-family:var(--display);
}
.next-btn{
  padding:11px 34px; font-size:1.05em; letter-spacing:.08em; text-transform:uppercase;
  background:linear-gradient(135deg, var(--accent), #8a1830);
  border:2px solid var(--accent2);
  box-shadow:0 4px 16px #c4233f55, inset 0 1px 0 #ffffff30;
  transition:transform .12s ease, box-shadow .2s ease, opacity .2s ease;
}
.next-btn:not(:disabled){ animation:btnPulse 1.8s ease-in-out infinite; }
@keyframes btnPulse{
  0%,100%{ box-shadow:0 4px 16px #c4233f55, inset 0 1px 0 #ffffff30; }
  50%{ box-shadow:0 4px 30px #e8657fbb, inset 0 1px 0 #ffffff55; }
}
.next-btn:hover:not(:disabled){ transform:translateY(-2px); }
.next-btn:disabled{ animation:none; opacity:.4; box-shadow:none; cursor:default; }
.restart-btn{ background:var(--surface2); color:var(--muted); border:1px solid var(--border); }
.restart-btn:hover{ background:var(--accent2); color:#fff; }

/* ===================================================================
   Activity log
   =================================================================== */
.log-panel{
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  padding:6px 12px; height:7vh; min-height:46px; max-height:72px; overflow-y:auto; font-size:.8em; color:var(--muted);
  display:flex; flex-direction:column-reverse;
}
.log-panel .logline{ padding:2px 0; border-bottom:1px solid #ffffff0a; }
.log-panel .logline:first-child{ color:var(--text); }

/* ===================================================================
   Modals
   =================================================================== */
.bot-modal{
  display:none; position:fixed; inset:0; background:#000c; z-index:200;
  align-items:center; justify-content:center;
}
.bot-modal.show{ display:flex; }
.bot-modal-box{
  background:var(--surface); border:1px solid var(--border); border-radius:12px;
  padding:20px; max-width:460px; width:90%; text-align:center;
  box-shadow:0 0 60px -10px var(--accent2);
}
.bot-modal-title{ font-family:var(--display); color:var(--accent2); font-weight:700; margin-bottom:10px; }
.bot-modal-body{ color:var(--text); margin-bottom:14px; font-size:.9em; line-height:1.6; }
.bot-modal-actions{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }
.bot-modal-actions button{
  background:var(--accent); color:#fff; border:none; border-radius:6px; padding:8px 14px;
  font-weight:700; cursor:pointer;
}
.bot-modal-actions button.secondary{ background:var(--surface2); color:var(--text); }
.bot-modal-actions button:hover{ background:var(--accent2); }

.card-preview-modal{
  display:none; position:fixed; inset:0; background:#000c; z-index:300;
  align-items:center; justify-content:center;
}
.card-preview-modal.show{ display:flex; }
.card-preview-box{
  background:var(--surface); border:1px solid var(--border); border-radius:12px;
  padding:20px; max-width:520px; width:90%; max-height:90vh; overflow-y:auto;
  text-align:center; display:flex; flex-direction:column; gap:12px; align-items:center;
}
.card-preview-box .cp-image{ max-width:100%; max-height:60vh; border-radius:8px; border:1px solid var(--border); }
.cp-info{ width:100%; }
.cp-info .cp-name{ font-family:var(--display); font-weight:700; color:var(--accent2); font-size:1.1em; margin-bottom:4px; }
.cp-info .cp-meta{ color:#ffd76e; font-size:.85em; margin-bottom:8px; }
.cp-info .cp-effect{ color:var(--text); font-size:.9em; line-height:1.6; text-align:left; }

/* ===================================================================
   Mulligan overlay
   =================================================================== */
.mulligan-overlay{
  display:none; position:fixed; inset:0; background:#000c; z-index:250;
  align-items:center; justify-content:center;
}
.mulligan-overlay.show{ display:flex; }
.mulligan-box{
  background:var(--surface); border:1px solid var(--border); border-radius:12px;
  padding:24px; max-width:680px; width:92%; text-align:center;
  box-shadow:0 0 60px -10px var(--accent2);
}
.mulligan-box h2{ font-family:var(--display); color:var(--accent2); margin:0 0 8px; text-shadow:0 0 18px #e8657f55; }
.mulligan-note{ color:var(--muted); font-size:.85em; line-height:1.5; margin:0 0 18px; }
.mulligan-hand{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:20px; }
.mulligan-hand .handcard.marked{ opacity:.4; border-color:var(--accent); box-shadow:0 0 0 2px var(--accent), 0 0 18px var(--accent); }
.mulligan-hand .handcard.marked::after{
  content:'ทิ้ง'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:900; font-size:1.2em; color:#fff;
  text-shadow:0 0 10px #000, 0 0 8px var(--accent); z-index:2; letter-spacing:.15em;
  border-radius:7px; background:#0006;
}
.mulligan-card-wrap{ display:flex; flex-direction:column; align-items:center; gap:6px; }
.tutorial-note{ color:var(--accent2); }
.mulligan-hand .tip-badge{
  font-size:.68em; font-weight:700; padding:3px 6px; border-radius:5px;
  max-width:100px; line-height:1.25; text-align:center;
}
.mulligan-hand .tip-badge.keep{ background:#2e7d4f33; color:#7cffa3; border:1px solid #2e7d4f; }
.mulligan-hand .tip-badge.neutral{ background:#55555533; color:var(--muted); border:1px solid var(--border); }
.mulligan-hand .tip-badge.consider{ background:#a3402b33; color:#ffb199; border:1px solid #a3402b; }

@media (max-width:760px){
  .hero-meta .pname{ max-width:24vw; }
  .hero-hp{ min-width:80px; }
  .field-row{ gap:6px; }
}
