:root {
  --bg: #090411;
  --panel: rgba(14, 7, 29, 0.86);
  --panel-2: rgba(25, 12, 52, 0.88);
  --line: rgba(197, 169, 255, 0.38);
  --text: #f5ecff;
  --muted: #c8b4ef;
  --accent: #9a6bff;
  --accent-2: #ddc16d;
  --success: #7fe97f;
  --danger: #ff7373;
  --shadow: 0 20px 40px rgba(0, 0, 0, 0.45);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  color: var(--text);
  font-family: Verdana, Arial, sans-serif;
  background: var(--bg);
  min-height: 100vh;
}
button, input, select {
  font: inherit;
}
.page-bg {
  position: fixed;
  inset: 0;
  background:
    linear-gradient(rgba(6,2,15,0.65), rgba(6,2,15,0.9)),
    url('/static/assets/gui_bg.webp') center/cover no-repeat;
  z-index: -2;
}
.page-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url('/static/assets/pattern.webp') center/cover repeat;
  opacity: 0.22;
  mix-blend-mode: screen;
}
.hero {
  padding: 1rem;
}
.hero-inner {
  max-width: 1280px;
  margin: 0 auto;
}
.hero-title-wrap {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.dragonfly-badge {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12) url('/static/assets/dragonfly.webp') center/70% no-repeat;
  border: 2px solid rgba(255,255,255,0.5);
  box-shadow: 0 0 24px rgba(190, 132, 255, 0.5);
}
.hero h1 {
  margin: 0;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(2rem, 5vw, 4rem);
  letter-spacing: 0.06em;
}
.subtitle {
  margin: 0.25rem 0;
  color: var(--muted);
  font-size: 1.15rem;
}
.small { font-size: 0.95rem; color: var(--muted); }
.glow { text-shadow: 0 0 16px rgba(170,124,255,0.45); }
.hero-actions { margin-top: 0.75rem; }
.cta-link {
  display: inline-flex;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  color: #1b1029;
  background: linear-gradient(180deg, #f8e797, #d9b85b);
  text-decoration: none;
  font-weight: 700;
}
.app-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1rem 2rem;
}
.panel {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
  padding: 1rem;
}
.hidden { display: none !important; }
.narrow-panel { max-width: 540px; margin: 1rem auto; }
.auth-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}
.auth-card {
  background: rgba(17, 7, 39, 0.66);
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.1);
}
.single-wide { grid-column: 1 / -1; max-width: 680px; margin: 0 auto; }
label {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 0.75rem;
}
input, select {
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(255,255,255,0.24);
  border-radius: 12px;
  padding: 0.72rem 0.85rem;
  color: #2d2142;
}
button {
  border: 0;
  cursor: pointer;
  border-radius: 14px;
  padding: 0.72rem 1rem;
  transition: transform 160ms ease, box-shadow 160ms ease, opacity 160ms ease;
}
button:hover { transform: translateY(-1px); }
button:disabled { opacity: 0.55; cursor: default; transform: none; }
.primary {
  background: linear-gradient(180deg, #b080ff, #7b4fe4);
  color: white;
  box-shadow: 0 12px 30px rgba(122, 71, 228, 0.4);
}
.ghost {
  background: rgba(255,255,255,0.08);
  color: var(--text);
  border: 1px solid rgba(255,255,255,0.15);
}
.check {
  flex-direction: row;
  align-items: center;
}
.topbar, .tabs { margin-bottom: 1rem; }
.topbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
}
.topline { font-size: 1.3rem; font-weight: 700; }
.top-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.admin-badge {
  background: linear-gradient(180deg, #f4d989, #c89a2b);
  color: #2b1a00;
  border-radius: 999px;
  padding: 0.2rem 0.55rem;
  font-size: 0.8rem;
  vertical-align: middle;
}
.tabs { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.tab {
  background: rgba(255,255,255,0.06);
  color: var(--muted);
}
.tab.active {
  background: rgba(154, 107, 255, 0.32);
  color: white;
  border: 1px solid rgba(255,255,255,0.18);
}
.tab-panel { display: none; }
.tab-panel.active { display: block; }
.two-col {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}
.wide-right { grid-template-columns: minmax(250px, 340px) 1fr; }
.sticky-panel { position: sticky; top: 1rem; align-self: start; }
.list { display: grid; gap: 0.75rem; }
.notice {
  margin-top: 0.75rem;
  padding: 0.8rem 0.9rem;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  color: var(--muted);
}
.collection-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fill, minmax(165px, 1fr));
}
.collection-grid.compact {
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  max-height: 72vh;
  overflow: auto;
}
.card-tile {
  position: relative;
  background: rgba(255,255,255,0.03);
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.1);
}
.card-tile img {
  width: 100%;
  display: block;
  aspect-ratio: 0.724;
  object-fit: cover;
  cursor: zoom-in;
}
.card-meta {
  padding: 0.65rem;
  display: grid;
  gap: 0.35rem;
}
.card-meta h4 { margin: 0; font-size: 0.92rem; }
.card-meta p { margin: 0; font-size: 0.78rem; color: var(--muted); }
.card-qty {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  padding: 0.25rem 0.5rem;
  border-radius: 999px;
  background: rgba(10, 8, 18, 0.88);
  color: white;
  font-size: 0.82rem;
}
.foil::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,0) 32%,
    rgba(255,255,255,0.14) 42%,
    rgba(255,255,255,0.32) 50%,
    rgba(163,230,255,0.18) 57%,
    rgba(255,163,255,0.18) 64%,
    rgba(255,255,255,0) 78%,
    rgba(255,255,255,0) 100%);
  background-size: 220% 100%;
  background-position: 0% 0%;
  animation: shimmerBg 2.8s linear infinite;
  mix-blend-mode: screen;
  pointer-events: none;
}
.founding::before { display: none !important; content: none !important; }
@keyframes shimmerBg { from { background-position: 0% 0%; } to { background-position: 100% 0%; } }
.deck-slots { display: grid; gap: 0.6rem; }
.deck-slot {
  display: flex; justify-content: space-between; align-items: center; gap: 0.5rem;
  background: rgba(255,255,255,0.06); padding: 0.8rem; border-radius: 14px;
}
.deck-slot.active { outline: 2px solid rgba(200, 180, 239, 0.65); }

.deck-slot-pill {
  display: grid;
  justify-items: start;
  align-items: center;
  gap: 0.15rem;
  min-width: 0;
}
.deck-slot-title-line {
  display: flex;
  align-items: baseline;
  gap: 0.45rem;
  flex-wrap: wrap;
}
.deck-slot-meta-line {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}
.deck-slot-power {
  color: var(--accent-2);
  font-weight: 700;
}
.deck-stats-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: center;
  margin-bottom: 1rem;
}
.deck-power {
  color: var(--accent-2);
  font-weight: 700;
}
.deck-power.subtle {
  margin-top: -0.3rem;
  margin-bottom: 0.45rem;
}
.deck-section-head {
  display: grid;
  gap: 0.45rem;
}
.deck-section-head h3 { margin-bottom: 0; }
.deck-sort-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: end;
  margin-bottom: 0.4rem;
}
.deck-sort-row input { flex: 1 1 240px; }
.deck-sort-row label {
  display: grid;
  gap: 0.22rem;
  color: var(--muted);
  font-size: 0.95rem;
}
.deck-header-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: end;
  justify-content: space-between;
}
.deck-stats { margin-bottom: 1rem; color: var(--accent-2); font-weight: 700; }
.builder-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1rem;
}
.deck-entry {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  background: rgba(255,255,255,0.06);
  padding: 0.65rem;
  border-radius: 14px;
}

.recent-match-actions {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.remove-recent-match-btn {
  border-color: rgba(255, 115, 115, 0.45);
  color: #ffd5d5;
}
.counter-controls { display: flex; align-items: center; gap: 0.4rem; }
.counter-controls button { padding: 0.35rem 0.6rem; }
.match-shell {
  display: grid;
  gap: 1rem;
}
.match-top {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0.75rem;
  align-items: center;
}
.boss-panel {
  display: grid;
  justify-items: center;
  gap: 0.4rem;
}
.boss-card {
  width: min(22vw, 160px);
  min-width: 110px;
  position: relative;
}
.boss-card img { width: 100%; display: block; border-radius: 14px; }
.match-mid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 220px;
  gap: 0.75rem;
  align-items: stretch;
}
.side-panel {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 0.75rem;
}
.board-panel {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.1);
  min-height: 780px;
  background: rgba(0,0,0,0.2);
}
.board-backdrop {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  filter: saturate(1.05) brightness(0.72);
}
.board-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(20,9,38,0.22), rgba(20,9,38,0.42));
}
.grid-board {
  position: absolute;
  inset: 6% 8%;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-template-rows: repeat(5, 1fr);
  gap: 0.7%;
}
.board-cell {
  position: relative;
  border-radius: 10px;
  border: 2px solid rgba(248, 221, 109, 0.28);
  min-height: 88px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  overflow: hidden;
  background: rgba(7, 4, 14, 0.3);
}
.board-cell.attack-lane {
  border-color: rgba(255, 110, 110, 0.58);
}
.board-cell.legal-play {
  box-shadow: inset 0 0 0 3px rgba(119, 237, 148, 0.58);
}
.board-cell.legal-replace {
  box-shadow: inset 0 0 0 3px rgba(221, 193, 109, 0.58);
}
.board-cell img {
  width: 100%; height: 100%; object-fit: cover;
}
.hand-panel {
  display: grid;
  gap: 0.8rem;
}
.hand-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(82px, 96px));
  gap: 0.55rem;
  justify-content: flex-start;
}
.hand-card {
  position: relative;
  max-width: 96px;
  width: 100%;
  margin: 0 auto;
  border-radius: 14px;
  overflow: hidden;
  border: 2px solid transparent;
  background: rgba(255,255,255,0.05);
}
.hand-card.selected {
  border-color: rgba(127, 233, 127, 0.9);
  transform: translateY(-3px) scale(1.01);
}
.hand-card img { width: 100%; display: block; cursor: pointer; }
.hand-card .hand-actions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.24rem;
  padding: 0.28rem;
}
.hand-card .hand-actions button {
  padding: 0.28rem 0.2rem;
  font-size: 0.69rem;
}
.zoom-modal {
  position: fixed; inset: 0; z-index: 40;
  background: rgba(0,0,0,0.85);
  display: grid; place-items: center;
}
.zoom-card-wrap {
  max-width: min(80vw, 620px);
  max-height: 90vh;
}
.zoom-card-wrap img { width: 100%; border-radius: 24px; box-shadow: 0 20px 55px rgba(0,0,0,0.65); }
.toast {
  position: fixed; bottom: 1rem; right: 1rem; z-index: 50;
  background: rgba(10,10,20,0.94); border: 1px solid rgba(255,255,255,0.18); padding: 0.9rem 1rem; border-radius: 14px;
  max-width: 360px;
}
.pass-screen {
  position: fixed; inset: 0; z-index: 60;
  display: grid; place-items: center;
  background: rgba(0,0,0,0.84);
}
.center-text { text-align: center; }
.card-fly {
  position: fixed;
  z-index: 55;
  width: 160px;
  pointer-events: none;
  transition: transform 520ms cubic-bezier(.22,.87,.3,1), left 520ms ease, top 520ms ease, opacity 520ms ease;
}
.pack-display {
  display: grid;
  gap: 1rem;
  justify-items: center;
}
.pack-cards {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.pack-card {
  width: min(26vw, 190px);
  perspective: 1000px;
}
.pack-card-inner {
  position: relative;
  transform-style: preserve-3d;
  transition: transform 700ms ease;
}
.pack-card.revealed .pack-card-inner { transform: rotateY(180deg) scale(1.03); }
.pack-face, .pack-back {
  backface-visibility: hidden;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 14px 38px rgba(0,0,0,0.5);
}
.pack-back { background: url('/static/assets/back.webp') center/cover no-repeat; aspect-ratio: 0.724; }
.pack-face { position: absolute; inset: 0; transform: rotateY(180deg); }
.pack-face img { width: 100%; display: block; }
.admin-user-row {
  display: grid;
  grid-template-columns: 1.2fr 1.6fr auto auto auto;
  gap: 0.6rem;
  align-items: center;
  background: rgba(255,255,255,0.05);
  padding: 0.7rem;
  border-radius: 14px;
}
.match-log {
  max-height: 240px;
  overflow: auto;
  display: grid; gap: 0.35rem;
}
.match-log .line {
  font-size: 0.85rem; color: var(--muted);
  padding-bottom: 0.35rem; border-bottom: 1px solid rgba(255,255,255,0.06);
}
@media (max-width: 1050px) {
  .builder-layout { grid-template-columns: 1fr; }
  .match-mid { grid-template-columns: 1fr; }
  .board-panel { min-height: 620px; }
}
@media (max-width: 760px) {
  .topbar { flex-direction: column; align-items: stretch; }
  .wide-right { grid-template-columns: 1fr; }
  .match-top { grid-template-columns: 1fr; }
  .board-panel { min-height: 500px; }
  .grid-board { inset: 7% 6%; }
  .board-cell { min-height: 70px; }
  .hand-row { grid-template-columns: repeat(auto-fit, minmax(70px, 84px)); gap: 0.4rem; }
  .hand-card { max-width: 84px; border-radius: 12px; }
  .hand-card .hand-actions button { font-size: 0.62rem; }
  .admin-user-row { grid-template-columns: 1fr; }
}

body.in-match { overflow: hidden; }
.match-screen {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: linear-gradient(rgba(6,2,15,0.92), rgba(6,2,15,0.96)), url('/static/assets/gui_bg.webp') center/cover no-repeat;
  overflow: auto;
}
.match-screen-inner {
  min-height: 100vh;
  padding: 0.55rem;
}
.match-screen-shell {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 0.45rem;
}
.match-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 0.8rem;
}
.match-toolbar-left { display: grid; gap: 0.15rem; }
.match-toolbar-actions { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.dangerish { background: linear-gradient(180deg, #bb4c5f, #893447); }
.match-log-panel { padding: 0.5rem 0.7rem; }
.board-wrap-panel { padding: 0.35rem 0.45rem 0.55rem; }
.match-status-line {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 0.35rem;
}
.status-chip {
  padding: 0.16rem 0.55rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.09);
  font-size: 0.8rem;
  color: var(--muted);
}
.board-stage {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 0.1rem;
}
.match-screen .board-panel {
  min-height: 0;
  width: min(92vw, 56vh);
  aspect-ratio: 0.724 / 1;
  height: auto;
  max-height: calc(100vh - 250px);
  overflow: visible;
  background: transparent;
}
.grid-board {
  inset: 0.2%;
  gap: 0.1%;
}
.board-cell {
  border-radius: 4px;
  border: 1px solid rgba(248, 221, 109, 0.14);
  min-height: 0;
  background: rgba(7, 4, 14, 0.08);
  overflow: visible;
  padding: 0.01rem;
  aspect-ratio: 0.724 / 1;
}
.board-cell.attack-lane { border-color: rgba(255,110,110,0.18); }
.board-cell.legal-play { box-shadow: inset 0 0 0 2px rgba(119, 237, 148, 0.82); }
.board-cell.legal-replace { box-shadow: inset 0 0 0 2px rgba(221, 193, 109, 0.82); }
.board-card {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 7px;
  overflow: visible;
  transition: transform 0.12s ease;
  z-index: 1;
}
.board-card img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  border-radius: 7px;
}
.board-card:hover {
  transform: scale(1.18);
  z-index: 6;
}
.compact-hand-panel { padding-top: 0.45rem; }
.clean-hand {
  grid-template-columns: repeat(auto-fit, minmax(78px, 94px));
  gap: 0.28rem;
}
.clean-hand-card {
  border-radius: 10px;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.clean-hand-card:hover {
  transform: translateY(-4px) scale(1.16);
  z-index: 8;
  box-shadow: 0 14px 28px rgba(0,0,0,0.45);
}
.clean-hand-card .hand-actions {
  gap: 0.16rem;
  padding: 0.2rem;
}
.clean-hand-card .hand-actions button {
  padding: 0.16rem 0.12rem;
  font-size: 0.63rem;
  border-radius: 999px;
}
.clean-card {
  background: transparent;
  border: none;
  overflow: visible;
}
.clean-card img {
  border-radius: 10px;
  object-fit: contain;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.clean-card:hover img {
  transform: scale(1.1);
  box-shadow: 0 14px 30px rgba(0,0,0,0.45);
}
.card-clean-footer {
  padding-top: 0.18rem;
  display: flex;
  justify-content: flex-start;
}
.deck-line-controls {
  display: inline-flex;
  align-items: center;
  gap: 0.18rem;
  padding: 0.1rem 0.2rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
}
.deck-line-controls button {
  min-width: 1.4rem;
  padding: 0.1rem 0.2rem;
  border-radius: 999px;
}
.deck-line-count, .deck-line-unused {
  min-width: 0.9rem;
  text-align: center;
  font-size: 0.82rem;
}
.deck-line-unused { color: var(--accent-2); }
#currentDeckList.current-deck-grid, #deckCardLibrary.collection-grid.compact {
  gap: 0.55rem;
  grid-template-columns: repeat(auto-fill, minmax(112px, 1fr));
}
.card-meta, .card-clean-footer:empty { display: none; }
.match-log { max-height: 180px; }
@media (max-width: 900px) {
  .match-screen .board-panel { width: min(94vw, 50vh); }
}
@media (max-width: 760px) {
  .match-toolbar { flex-direction: column; align-items: stretch; }
  .match-toolbar-actions { justify-content: flex-start; }
  .match-screen .board-panel { width: min(94vw, 46vh); max-height: calc(100vh - 260px); }
  .clean-hand { grid-template-columns: repeat(auto-fit, minmax(68px, 82px)); gap: 0.2rem; }
  .clean-hand-card:hover { transform: translateY(-3px) scale(1.1); }
}


/* v5 layout tuning */
#tab-decks { gap: 0.75rem; }
#tab-decks.active { display: grid; }
#tab-decks:not(.active) { display: none; }
.deck-slot-bar-panel { padding: 0.55rem 0.75rem; }
.deck-slots-bar { display:flex; gap:0.55rem; flex-wrap:wrap; }
.deck-slot-pill { border:none; cursor:pointer; padding:0.65rem 0.95rem; border-radius:16px; min-width:130px; display:grid; justify-items:start; background:rgba(255,255,255,0.06); color:var(--text); }
.deck-slot-pill.active { outline:2px solid rgba(200, 180, 239, 0.72); background:rgba(143,94,255,0.18); }
.deck-builder-panel { padding: 0.8rem; }
.builder-layout-wide { grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.95fr); }
.collection-grid.compact { max-height: 68vh; }
#currentDeckList.current-deck-grid, #deckCardLibrary.collection-grid.compact { gap: 0.12rem; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); }
.clean-card img, .clean-hand-card img { object-fit: contain; }
.clean-card:hover img { transform: scale(1.18); }
.match-screen-inner { padding: 0.28rem 0.4rem 0.5rem; }
.match-screen-shell { max-width: 1400px; gap: 0.28rem; }
.match-toolbar, .board-wrap-panel, .hand-panel { padding-left: 0.45rem; padding-right: 0.45rem; }
.match-log-panel { padding: 0.35rem 0.45rem; }
.player-strip { display:flex; justify-content:space-between; align-items:center; gap:0.5rem; padding:0.15rem 0.2rem 0.25rem; color:var(--muted); }
.player-strip strong { color: var(--text); }
.player-strip-bottom { padding-top: 0.28rem; }
.thin-line { margin-bottom: 0.18rem; }
.thin-line .status-chip { width:100%; text-align:center; border-radius:10px; padding:0.1rem 0.4rem; font-size:0.74rem; }
.board-stage { padding: 0; }
.match-screen .board-panel.vertical { width: min(82vw, 62vh); aspect-ratio: 886 / 1536; max-height: calc(100vh - 245px); }
.match-screen .board-panel.horizontal { width: min(96vw, 128vh); aspect-ratio: 909 / 511; max-height: calc(100vh - 245px); }
.grid-board.vertical { inset: 28.5% 19.5% 18.7% 19.5%; gap: 0.12%; }
.grid-board.horizontal { inset: 18.8% 28.2% 18.8% 28.2%; gap: 0.12%; }
.board-cell { border: 1px solid rgba(248,221,109,0.12); background: transparent; padding:0.01rem; overflow: visible; }
.board-card { overflow: visible; border-radius: 4px; --card-rot: 0deg; transform: rotate(var(--card-rot)) scale(1.1); transform-origin: center center; }
.board-card.opponent-facing { --card-rot: 180deg; }
.board-card img { object-fit: contain; border-radius:4px; }
.board-card:hover { transform: rotate(var(--card-rot)) scale(2.05); z-index: 20; }
.clean-hand { grid-template-columns: repeat(auto-fit, minmax(68px, 80px)); gap: 0.12rem; }
.clean-hand-card { max-width: 80px; }
.clean-hand-card:hover { transform: translateY(-2px) scale(2); z-index: 25; }
.clean-hand-card .hand-actions { gap:0.08rem; padding:0.12rem; }
.clean-hand-card .hand-actions button { padding:0.12rem 0.06rem; font-size:0.6rem; }
.hand-panel strong { display:block; margin-bottom:0.15rem; }
.battle-burst { position:absolute; inset:50% auto auto 50%; transform:translate(-50%,-50%); min-width:48px; text-align:center; padding:0.32rem 0.42rem; border-radius:999px; font-weight:900; font-size:1.45rem; color:#fff; background:rgba(10,10,18,0.8); border:2px solid rgba(255,255,255,0.25); box-shadow:0 8px 28px rgba(0,0,0,0.5); z-index:30; pointer-events:none; }
.battle-burst.winner { background: rgba(22,124,44,0.88); border-color: rgba(114,255,142,0.9); }
.battle-burst.loser { background: rgba(146,26,32,0.88); border-color: rgba(255,136,136,0.9); }
.battle-burst.tie { background: rgba(92,92,112,0.88); border-color: rgba(240,240,240,0.7); }
.explode-fx { position:absolute; inset:50% auto auto 50%; width:72%; aspect-ratio:1; transform:translate(-50%,-50%); border-radius:50%; background: radial-gradient(circle, rgba(255,248,160,0.98) 0%, rgba(255,156,31,0.92) 22%, rgba(255,63,24,0.74) 46%, rgba(255,63,24,0.16) 68%, transparent 72%); z-index:35; pointer-events:none; animation: explodePulse 420ms ease-out forwards; }
@keyframes explodePulse { from { opacity:0; transform:translate(-50%,-50%) scale(0.3);} 30% { opacity:1; } to { opacity:0; transform:translate(-50%,-50%) scale(1.35);} }
@media (max-width: 1000px) {
  .builder-layout-wide { grid-template-columns: 1fr; }
  #currentDeckList.current-deck-grid, #deckCardLibrary.collection-grid.compact { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
}
@media (max-width: 760px) {
  .match-screen .board-panel.vertical { width:min(96vw, 56vh); }
  .match-screen .board-panel.horizontal { width:min(98vw, 92vh); }
  .player-strip { flex-direction:column; align-items:center; }
  .clean-hand { grid-template-columns: repeat(auto-fit, minmax(58px, 72px)); gap:0.08rem; }
  .clean-hand-card { max-width:72px; }
}

#tab-decks .clean-card:hover img { transform: none; box-shadow: none; }
#tab-decks .clean-card img { transition: none; }


/* v6f3 playfield cleanup */
.match-screen .board-panel.vertical { width: min(90vw, 76vh); aspect-ratio: 886 / 1536; max-height: calc(100vh - 185px); }
.match-screen .board-panel.horizontal { width: min(98vw, 154vh); aspect-ratio: 909 / 511; max-height: calc(100vh - 185px); }
.grid-board.vertical { inset: 27.7% 18.8% 18.1% 18.8%; gap: 0.05%; }
.grid-board.horizontal { inset: 17.9% 27.4% 17.9% 27.4%; gap: 0.05%; }
.board-cell { aspect-ratio: auto !important; padding: 0 !important; display: flex; align-items: stretch; justify-content: stretch; overflow: visible; }
.board-card {
  width: 100%;
  height: 100%;
  --card-rot: 0deg;
  transform: rotate(var(--card-rot));
  transform-origin: center center;
  transition: transform 0.14s ease, box-shadow 0.14s ease;
  overflow: visible;
  z-index: 1;
}
.board-card.opponent-facing { --card-rot: 180deg; }
.board-card img {
  width: 100%;
  height: 100%;
  object-fit: fill;
  display: block;
  border-radius: 4px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.24);
}
.board-card:hover { transform: rotate(var(--card-rot)) scale(1.42); z-index: 24; }
.board-card.foil::after,
.clean-hand-card.foil::after,
.card-tile.foil::after { border-radius: inherit; clip-path: inset(0 round 4px); }
.board-card.opponent-facing .battle-burst { transform: translate(-50%, -50%) rotate(180deg); }
.clean-hand { grid-template-columns: repeat(auto-fit, minmax(64px, 76px)); gap: 0.1rem; }
.clean-hand-card { max-width: 76px; }
.clean-hand-card:hover { transform: translateY(-2px) scale(1.7); z-index: 25; }
#tab-decks .clean-card:hover,
#tab-decks .clean-card:hover img,
#tab-collection .clean-card:hover img { transform: none !important; box-shadow: none !important; }
@media (max-width: 760px) {
  .match-screen .board-panel.vertical { width: min(97vw, 62vh); max-height: calc(100vh - 170px); }
  .match-screen .board-panel.horizontal { width: min(99vw, 108vh); max-height: calc(100vh - 170px); }
  .clean-hand { grid-template-columns: repeat(auto-fit, minmax(56px, 68px)); gap: 0.08rem; }
  .clean-hand-card { max-width: 68px; }
}


/* v6_fixed4 board proportion and animation tuning */
.match-screen .board-panel.vertical {
  width: min(96vw, 86vh);
  aspect-ratio: 886 / 1536;
  max-height: calc(100vh - 175px);
}
.match-screen .board-panel.horizontal {
  width: min(98vw, 168vh);
  aspect-ratio: 909 / 511;
  max-height: calc(100vh - 175px);
}
.grid-board.vertical { inset: 27.7% 16.5% 18.1% 16.5%; gap: 0.12%; }
.grid-board.horizontal { inset: 17.9% 36.5% 17.9% 36.5%; gap: 0.12%; }
.board-cell {
  aspect-ratio: 5 / 7 !important;
  padding: 0 !important;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  overflow: visible;
  background: transparent;
}
.board-card {
  width: 100%;
  aspect-ratio: 5 / 7;
  height: auto;
  overflow: visible;
  transform: rotate(var(--card-rot));
  transform-origin: center center;
}
.board-card img {
  width: 100%;
  height: 100%;
  aspect-ratio: 5 / 7;
  object-fit: contain !important;
  display: block;
  border-radius: 4px;
}
.board-card:hover { transform: rotate(var(--card-rot)) scale(1.34); z-index: 24; }
.clean-hand { grid-template-columns: repeat(auto-fit, minmax(60px, 72px)); gap: 0.08rem; }
.clean-hand-card { max-width: 72px; }
.clean-hand-card:hover { transform: translateY(-2px) scale(1.62); z-index: 25; }
.board-card.opponent-facing .battle-burst { transform: translate(-50%, -50%) !important; }
@media (max-width: 760px) {
  .match-screen .board-panel.vertical { width: min(98vw, 70vh); max-height: calc(100vh - 160px); }
  .match-screen .board-panel.horizontal { width: min(99vw, 118vh); max-height: calc(100vh - 160px); }
  .clean-hand { grid-template-columns: repeat(auto-fit, minmax(52px, 64px)); gap: 0.08rem; }
  .clean-hand-card { max-width: 64px; }
}


/* v6_fixed5 overlap and playfield click tuning */
.board-card {
  cursor: zoom-in;
}
.board-card img {
  cursor: zoom-in;
}
.board-card:hover {
  transform: rotate(var(--card-rot)) scale(1.16);
  z-index: 16;
}
.board-card:active {
  transform: rotate(var(--card-rot)) scale(1.08);
}
.clean-hand-card:hover {
  transform: translateY(-2px) scale(1.52);
  z-index: 25;
}
@media (max-width: 760px) {
  .board-card:hover {
    transform: rotate(var(--card-rot)) scale(1.1);
  }
}


/* v6_fixed6 board spacing and click zoom fixes */
.zoom-modal { z-index: 220 !important; }
.zoom-card-wrap { max-width: min(90vw, 720px); max-height: 92vh; }
.match-screen { z-index: 80; }
.board-stage { padding: 0.08rem 0.16rem; }
.match-screen .board-panel.vertical {
  width: min(98vw, 90vh);
  max-height: calc(100vh - 168px);
}
.match-screen .board-panel.horizontal {
  width: min(99vw, 176vh);
  max-height: calc(100vh - 168px);
}
.grid-board.vertical {
  inset: 27.7% 15.6% 18.1% 15.6%;
  gap: 0.46% 0.58%;
}
.grid-board.horizontal {
  inset: 17.9% 35.5% 17.9% 35.5%;
  gap: 0.46% 0.58%;
}
.board-cell {
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
  border-width: 1px;
}
.board-card {
  width: 94%;
  max-width: 94%;
  height: auto;
  aspect-ratio: 5 / 7;
  cursor: zoom-in;
  margin: 0 auto;
  transform: rotate(var(--card-rot));
  z-index: 1;
}
.board-card img {
  width: 100%;
  height: auto !important;
  aspect-ratio: 5 / 7;
  object-fit: contain !important;
  cursor: zoom-in;
}
.board-card:hover {
  transform: rotate(var(--card-rot)) scale(1.1);
  z-index: 14;
}
.board-card:active {
  transform: rotate(var(--card-rot)) scale(1.04);
}
.board-card .battle-burst {
  z-index: 30;
}
@media (max-width: 760px) {
  .match-screen .board-panel.vertical {
    width: min(99vw, 72vh);
    max-height: calc(100vh - 156px);
  }
  .match-screen .board-panel.horizontal {
    width: min(99vw, 122vh);
    max-height: calc(100vh - 156px);
  }
  .grid-board.vertical,
  .grid-board.horizontal {
    gap: 0.38% 0.48%;
  }
  .board-card:hover {
    transform: rotate(var(--card-rot)) scale(1.06);
  }
}


/* v6_fixed7 zero-overlap board alignment and click reliability */
.board-backdrop, .board-overlay { pointer-events: none; }
.board-backdrop { background-size: contain !important; background-repeat: no-repeat; background-position: center center; }
.grid-board { z-index: 3; }
.match-screen .board-panel.vertical { width: min(98vw, 88vh) !important; max-height: calc(100vh - 168px) !important; }
.match-screen .board-panel.horizontal { width: min(99vw, 168vh) !important; max-height: calc(100vh - 168px) !important; }
.grid-board.vertical { inset: 27.85% 16.35% 18.15% 16.35% !important; gap: 0.95% 1.15% !important; }
.grid-board.horizontal { inset: 18.2% 35.9% 18.2% 35.9% !important; gap: 0.95% 1.15% !important; }
.board-cell { overflow: hidden !important; background: transparent !important; border-width: 0 !important; padding: 0 !important; }
.board-card { width: 100% !important; max-width: 100% !important; height: 100% !important; aspect-ratio: 5 / 7 !important; margin: 0 !important; transform: rotate(var(--card-rot)) !important; transition: box-shadow 0.12s ease, filter 0.12s ease !important; }
.board-card img { width: 100% !important; height: 100% !important; object-fit: contain !important; aspect-ratio: 5 / 7 !important; display: block; }
.board-card:hover { transform: rotate(var(--card-rot)) !important; box-shadow: 0 0 0 2px rgba(255,255,255,0.18); filter: brightness(1.06); z-index: 6 !important; }
.board-card:active { transform: rotate(var(--card-rot)) !important; }
.board-card .battle-burst { transform: translate(-50%, -50%) !important; }
.zoom-modal.hidden { display: none !important; }
.zoom-modal { display: flex; align-items: center; justify-content: flex-start; }
.zoom-card-wrap { pointer-events: none; }


/* v6_fixed8a board grid / piles / hud alignment */
.match-screen .board-panel.vertical { width: min(98vw, 88vh) !important; aspect-ratio: 587 / 916 !important; max-height: calc(100vh - 168px) !important; }
.board-stage { padding: 0 !important; }
.board-wrap-panel { padding: 0.25rem 0.35rem !important; }
.board-backdrop { background-size: contain !important; background-repeat: no-repeat !important; background-position: center !important; }
.board-overlay { display: none !important; }
.grid-board.vertical { inset: 16.81% 13.80% 17.47% 14.48% !important; gap: 0.58% 0.72% !important; }
.grid-board.horizontal { inset: 18.2% 31.6% 18.2% 31.6% !important; gap: 0.58% 0.72% !important; }
.board-cell { aspect-ratio: 5 / 7 !important; overflow: hidden !important; background: transparent !important; border: 0 !important; }
.board-card, .board-card img { width: 100% !important; height: 100% !important; aspect-ratio: 5 / 7 !important; }
.board-card { margin: 0 !important; transform: rotate(var(--card-rot)) !important; transition: filter 0.12s ease, box-shadow 0.12s ease !important; cursor: zoom-in !important; }
.board-card:hover { filter: brightness(1.08); box-shadow: 0 0 0 2px rgba(255,255,255,0.16); z-index: 8 !important; }
.board-card img { object-fit: contain !important; display: block; }
.board-hud { position: absolute; left: 0.8%; right: 0.8%; height: 4.55%; display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; z-index: 5; }
.top-hud { top: 0.55%; }
.bottom-hud { bottom: 0.55%; }
.yellow-info { flex: 1 1 auto; min-height: 100%; border: 2px solid rgba(245, 221, 54, 0.92); border-radius: 8px; background: rgba(18, 9, 34, 0.78); color: #f2e58a; font-weight: 700; display: flex; align-items: center; justify-content: flex-start; padding: 0 0.7rem; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08); }
.hud-hand { flex: 0 0 40%; min-width: 0; display: flex; align-items: center; gap: 0.14rem; overflow: visible; }
.opponent-hand-tray { justify-content: flex-start; }
.player-hand-tray { justify-content: flex-end; }
.opponent-hand-card { width: clamp(20px, 3.1vw, 30px); aspect-ratio: 5 / 7; margin-left: calc(var(--stack, 0) * -6px); filter: drop-shadow(0 2px 4px rgba(0,0,0,0.35)); }
.opponent-hand-card:first-child { margin-left: 0; }
.opponent-hand-card img { width: 100%; height: 100%; object-fit: contain; display: block; }
.opponent-hand-count { margin-left: 0.35rem; color: var(--text); }
.pile-slot { position: absolute; z-index: 5; display: flex; align-items: center; justify-content: flex-start; pointer-events: none; }
.top-deck-slot { left: 19.9%; top: 5.8%; width: 19.1%; height: 10.0%; }
.top-boss-slot { left: 42.1%; top: 4.8%; width: 15.7%; height: 11.5%; }
.top-discard-slot { left: 61.0%; top: 5.8%; width: 19.1%; height: 10.0%; }
.bottom-deck-slot { left: 19.9%; top: 82.5%; width: 19.1%; height: 10.0%; }
.bottom-boss-slot { left: 42.1%; top: 82.4%; width: 15.7%; height: 11.6%; }
.bottom-discard-slot { left: 61.0%; top: 82.5%; width: 19.1%; height: 10.0%; }
.pile-back, .pile-card, .pile-empty { width: 100%; height: 100%; display: flex; align-items: center; justify-content: flex-start; }
.pile-back img, .pile-card img { width: 100%; height: 100%; object-fit: contain; display: block; }
.pile-card.opponent-facing { transform: rotate(180deg); }
.pile-empty { border-radius: 6px; }
#playerHand.clean-hand { display: flex !important; flex-wrap: nowrap; gap: 0.12rem; overflow: visible; }
#playerHand .clean-hand-card { width: clamp(40px, 5.8vw, 58px); max-width: none !important; flex: 0 0 auto; transform: none !important; }
#playerHand .clean-hand-card img { width: 100%; height: auto; aspect-ratio: 5 / 7; object-fit: contain; }
#playerHand .clean-hand-card:hover { transform: translateY(-2px) scale(1.08) !important; z-index: 18; }
#playerHand .hand-actions { gap: 0.08rem; padding: 0.08rem; }
#playerHand .hand-actions button { padding: 0.09rem 0.06rem; font-size: 0.56rem; }
.match-status-line.thin-line { margin-bottom: 0.12rem !important; }
.thin-line .status-chip { padding: 0.06rem 0.35rem !important; font-size: 0.72rem !important; }
.player-strip, .player-strip-bottom, .hand-panel.compact-hand-panel { display: none !important; }
@media (max-width: 760px) {
  .match-screen .board-panel.vertical { width: min(99vw, 78vh) !important; }
  .board-hud { gap: 0.2rem; }
  .yellow-info { font-size: 0.72rem; padding: 0 0.25rem; }
  .hud-hand { flex-basis: 38%; }
  #playerHand .clean-hand-card { width: clamp(34px, 7vw, 46px); }
  #playerHand .hand-actions button { font-size: 0.48rem; }
}

/* v6_fixed8b vertical board alignment + hands + deck save polish */
.match-screen .board-panel.vertical {
  width: min(96vw, 86vh) !important;
  aspect-ratio: 587 / 916 !important;
  max-height: calc(100vh - 166px) !important;
}
.grid-board.vertical {
  inset: 16.70% 13.35% 17.35% 13.35% !important;
  gap: 0.18% !important;
}
.grid-board.vertical .board-cell {
  aspect-ratio: 5 / 7 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
  align-items: center !important;
  justify-content: center !important;
}
.grid-board.vertical .board-card,
.grid-board.vertical .board-card img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 5 / 7 !important;
}
.grid-board.vertical .board-card {
  margin: 0 !important;
  transform: rotate(var(--card-rot)) !important;
  transition: filter 0.12s ease, box-shadow 0.12s ease !important;
  cursor: zoom-in !important;
}
.grid-board.vertical .board-card img {
  object-fit: contain !important;
  display: block !important;
}
.grid-board.vertical .board-card:hover,
.grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) !important;
  filter: brightness(1.05);
  box-shadow: 0 0 0 2px rgba(255,255,255,0.12);
  z-index: 8 !important;
}
.board-hud {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 8;
  pointer-events: none;
}
.board-hud > * { pointer-events: auto; }
.top-hud,
.bottom-hud {
  height: 0 !important;
  min-height: 0 !important;
}
.top-hud .yellow-info,
.bottom-hud .yellow-info {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 44%;
  min-width: 260px;
  height: 4.35%;
  min-height: 34px;
  border: 2px solid rgba(245, 221, 54, 0.92);
  border-radius: 12px;
  background: rgba(18, 9, 34, 0.84);
  color: #f2e58a;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 0.8rem;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
}
.top-hud .yellow-info { top: 0.7%; }
.bottom-hud .yellow-info { bottom: 0.7%; }
#opponentHand {
  position: absolute;
  top: 0.75%;
  left: 3.1%;
  width: 22%;
  display: flex !important;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0;
  overflow: visible;
}
#playerHand.clean-hand {
  position: absolute;
  right: 3.1%;
  bottom: 0.65%;
  width: 31%;
  display: flex !important;
  justify-content: flex-end;
  align-items: flex-end;
  flex-wrap: nowrap;
  gap: 0.12rem;
  overflow: visible;
}
.opponent-hand-card {
  width: clamp(34px, 4.2vw, 46px);
  aspect-ratio: 5 / 7;
  margin-left: calc(var(--stack, 0) * -10px);
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.35));
}
.opponent-hand-card:first-child { margin-left: 0; }
.opponent-hand-card img { width: 100%; height: 100%; object-fit: contain; display: block; }
.opponent-hand-count {
  margin-left: 0.4rem;
  align-self: center;
  color: var(--text);
  font-weight: 800;
}
#playerHand .clean-hand-card {
  width: clamp(58px, 7.1vw, 76px);
  max-width: none !important;
  flex: 0 0 auto;
  transform: none !important;
}
#playerHand .clean-hand-card img {
  width: 100%;
  height: auto;
  aspect-ratio: 5 / 7;
  object-fit: contain;
}
#playerHand .clean-hand-card:hover {
  transform: translateY(-2px) scale(1.04) !important;
  z-index: 18;
}
#playerHand .hand-actions {
  gap: 0.08rem;
  padding: 0.08rem;
}
#playerHand .hand-actions button {
  padding: 0.1rem 0.06rem;
  font-size: 0.56rem;
}
.top-deck-slot,
.top-discard-slot,
.bottom-deck-slot,
.bottom-discard-slot {
  width: 20.45% !important;
  height: 9.35% !important;
}
.top-deck-slot { left: 20.3% !important; top: 5.65% !important; }
.top-boss-slot { left: 42.15% !important; top: 4.25% !important; width: 15.7% !important; height: 11.9% !important; }
.top-discard-slot { left: 59.25% !important; top: 5.65% !important; }
.bottom-deck-slot { left: 20.3% !important; top: 82.55% !important; }
.bottom-boss-slot { left: 42.15% !important; top: 82.1% !important; width: 15.7% !important; height: 11.9% !important; }
.bottom-discard-slot { left: 59.25% !important; top: 82.55% !important; }
#topDeckSlot .pile-back img,
#bottomDeckSlot .pile-back img,
#topDiscardSlot .pile-card img,
#bottomDiscardSlot .pile-card img {
  transform: rotate(90deg);
  transform-origin: center center;
}
#topBossSlot .pile-card.opponent-facing {
  transform: rotate(180deg);
}
#topDiscardSlot .pile-card,
#bottomDiscardSlot .pile-card,
#topDeckSlot .pile-back,
#bottomDeckSlot .pile-back {
  overflow: visible;
}
#topDiscardSlot .pile-card.opponent-facing { transform: none; }
.board-backdrop {
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
}
@media (max-width: 760px) {
  .top-hud .yellow-info,
  .bottom-hud .yellow-info {
    width: 48%;
    min-width: 0;
    font-size: 0.74rem;
    padding: 0 0.25rem;
  }
  #opponentHand { width: 24%; }
  .opponent-hand-card { width: clamp(28px, 5vw, 38px); margin-left: calc(var(--stack, 0) * -8px); }
  #playerHand.clean-hand { width: 35%; }
  #playerHand .clean-hand-card { width: clamp(48px, 8vw, 62px); }
}


/* v6_fixed8c exact vertical grid + same-size cards + side hands */

.board-wrap-panel { overflow: visible !important; }
.board-stage { overflow: visible !important; }
.match-screen .board-panel.vertical {
  width: min(94vw, 86vh) !important;
  aspect-ratio: 587 / 916 !important;
  max-height: calc(100vh - 166px) !important;
  overflow: visible !important;
  --field-card-w: 14.17%;
}
.grid-board.vertical {
  inset: 16.92% 14.31% 17.58% 14.82% !important;
  gap: 0 !important;
}
.grid-board.vertical .board-cell {
  aspect-ratio: 5 / 7 !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.grid-board.vertical .board-card,
.grid-board.vertical .board-card img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 5 / 7 !important;
}
.grid-board.vertical .board-card {
  transform: rotate(var(--card-rot)) !important;
  box-shadow: none !important;
}
.grid-board.vertical .board-card img { object-fit: contain !important; }
.grid-board.vertical .board-card:hover,
.grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) !important;
  filter: brightness(1.06);
  box-shadow: 0 0 0 2px rgba(255,255,255,0.12) !important;
  z-index: 10 !important;
}
.top-hud .yellow-info,
.bottom-hud .yellow-info {
  width: 44% !important;
  min-width: 280px !important;
  height: 4.45% !important;
  min-height: 34px !important;
}
.top-hud .yellow-info { top: 0.65% !important; }
.bottom-hud .yellow-info { bottom: 0.65% !important; }
#opponentHand {
  position: absolute !important;
  top: 0.65% !important;
  left: -29.2% !important;
  width: auto !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  gap: 0.35% !important;
  overflow: visible !important;
}
#playerHand.clean-hand {
  position: absolute !important;
  right: -45.0% !important;
  bottom: 0.65% !important;
  width: auto !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: flex-end !important;
  flex-wrap: nowrap !important;
  gap: 0.35% !important;
  overflow: visible !important;
}
.opponent-hand-card,
#playerHand .clean-hand-card {
  width: var(--field-card-w) !important;
  max-width: none !important;
  flex: 0 0 auto !important;
  aspect-ratio: 5 / 7 !important;
}
.opponent-hand-card {
  margin-left: 0 !important;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.35));
}
.opponent-hand-card img,
#playerHand .clean-hand-card img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 5 / 7 !important;
  object-fit: contain !important;
  display: block !important;
}
#playerHand .clean-hand-card:hover {
  transform: translateY(-2px) !important;
  z-index: 18 !important;
}
#playerHand .hand-actions {
  gap: 0.08rem !important;
  padding: 0.08rem !important;
}
#playerHand .hand-actions button {
  padding: 0.1rem 0.08rem !important;
  font-size: 0.56rem !important;
}
.opponent-hand-count {
  margin-left: 0.35rem !important;
  align-self: center !important;
  font-weight: 800 !important;
}
.top-deck-slot,
.top-discard-slot,
.bottom-deck-slot,
.bottom-discard-slot {
  width: 20.42% !important;
  height: 14.17% !important;
}
.top-deck-slot { left: 12.27% !important; top: 4.69% !important; }
.top-boss-slot { left: 44.29% !important; top: 3.49% !important; width: 11.58% !important; height: 14.52% !important; }
.top-discard-slot { left: 67.12% !important; top: 4.69% !important; }
.bottom-deck-slot { left: 12.27% !important; top: 81.66% !important; }
.bottom-boss-slot { left: 44.29% !important; top: 80.57% !important; width: 11.58% !important; height: 14.52% !important; }
.bottom-discard-slot { left: 67.12% !important; top: 81.66% !important; }
#topDeckSlot .pile-back img,
#bottomDeckSlot .pile-back img,
#topDiscardSlot .pile-card img,
#bottomDiscardSlot .pile-card img {
  transform: rotate(90deg) !important;
  transform-origin: center center !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}
.pile-back img, .pile-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}
@media (max-width: 1200px) {
  .match-screen .board-panel.vertical { width: min(96vw, 80vh) !important; }
  #opponentHand { left: -24% !important; }
  #playerHand.clean-hand { right: -38% !important; }
}
@media (max-width: 980px) {
  .match-screen .board-panel.vertical { width: min(98vw, 76vh) !important; --field-card-w: 12.8%; }
  #opponentHand { left: -18% !important; }
  #playerHand.clean-hand { right: -30% !important; }
  .top-hud .yellow-info, .bottom-hud .yellow-info { width: 48% !important; min-width: 220px !important; }
}

/* v6_fixed8d law layout from grid playmat layout.png @ 105% center-focused */
.cardplay-law-layout.vertical {
  display: grid !important;
  grid-template-columns: minmax(270px, 1fr) auto minmax(270px, 1fr) !important;
  align-items: stretch !important;
  justify-content: center !important;
  gap: 1.25rem !important;
  width: 100% !important;
  min-height: calc(100vh - 250px) !important;
  overflow: visible !important;
  --match-card-width: clamp(72px, 4.2vw, 82px);
  --match-card-height: calc(var(--match-card-width) * 1.4);
  --match-pile-width: var(--match-card-height);
  --match-pile-height: var(--match-card-width);
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  position: relative !important;
  height: min(calc(100vh - 250px), 962px) !important;
  width: auto !important;
  aspect-ratio: 587 / 916 !important;
  max-width: none !important;
  min-height: 760px !important;
  overflow: visible !important;
  margin: 0 auto !important;
}
.cardplay-law-layout.vertical .board-backdrop {
  inset: 0 !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 13.92% 9.46% 14.58% 9.97% !important;
  gap: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  aspect-ratio: 5 / 7 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 5 / 7 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card {
  transform: rotate(var(--card-rot)) !important;
  margin: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) !important;
  filter: brightness(1.06) !important;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.16) !important;
  z-index: 8 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  object-fit: contain !important;
  display: block !important;
}
.cardplay-law-layout.vertical .board-hud {
  left: 0.7% !important;
  right: 0.7% !important;
  height: 4.3% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
}
.cardplay-law-layout.vertical .board-hud > * { pointer-events: auto !important; }
.cardplay-law-layout.vertical .top-hud { top: 0.25% !important; }
.cardplay-law-layout.vertical .bottom-hud { bottom: 0.25% !important; }
.cardplay-law-layout.vertical .yellow-info {
  width: 98.4% !important;
  min-width: 0 !important;
  min-height: 100% !important;
  border: 2px solid rgba(245,221,54,0.95) !important;
  border-radius: 8px !important;
  background: rgba(18,9,34,0.82) !important;
  color: #f2e58a !important;
  font-size: clamp(0.95rem, 1.25vw, 1.2rem) !important;
}
.cardplay-law-layout.vertical .side-table {
  align-self: stretch !important;
  min-height: min(calc(100vh - 250px), 962px) !important;
  background: rgba(88, 88, 88, 0.28) !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  display: flex !important;
  padding: 0.9rem !important;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.2) !important;
}
.cardplay-law-layout.vertical .opponent-side-table {
  justify-content: flex-start !important;
  align-items: flex-start !important;
}
.cardplay-law-layout.vertical .player-side-table {
  justify-content: flex-end !important;
  align-items: flex-end !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  width: 100% !important;
  min-height: 118px !important;
  background: rgba(0,0,0,0.72) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 8px !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
  padding: 0.6rem 0.7rem !important;
}
.cardplay-law-layout.vertical .opponent-hand-slot {
  margin-top: 0.2rem !important;
}
.cardplay-law-layout.vertical .player-hand-slot {
  margin-bottom: 0.2rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  position: static !important;
  width: 100% !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  gap: 0.35rem !important;
  overflow: hidden !important;
}
.cardplay-law-layout.vertical #playerHand.clean-hand {
  align-items: flex-end !important;
  justify-content: flex-start !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  max-width: none !important;
  aspect-ratio: 5 / 7 !important;
  flex: 0 0 auto !important;
}
.cardplay-law-layout.vertical .opponent-hand-card {
  margin-left: 0 !important;
}
.cardplay-law-layout.vertical .opponent-hand-card img,
.cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 5 / 7 !important;
  object-fit: contain !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card:hover {
  transform: translateY(-2px) !important;
  z-index: 18 !important;
}
.cardplay-law-layout.vertical #playerHand .hand-actions {
  gap: 0.08rem !important;
  padding: 0.08rem !important;
}
.cardplay-law-layout.vertical #playerHand .hand-actions button {
  padding: 0.1rem 0.08rem !important;
  font-size: 0.56rem !important;
}
.cardplay-law-layout.vertical .opponent-hand-count {
  align-self: center !important;
  margin-left: 0.15rem !important;
}
.cardplay-law-layout.vertical .pile-slot {
  position: absolute !important;
  z-index: 6 !important;
  pointer-events: none !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 15.15% !important; top: 5.1% !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 42.08% !important; top: 4.38% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 68.65% !important; top: 5.1% !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 15.15% !important; top: 82.2% !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 42.08% !important; top: 81.45% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 68.65% !important; top: 82.2% !important; }
.cardplay-law-layout.vertical #topDeckSlot .pile-back img,
.cardplay-law-layout.vertical #bottomDeckSlot .pile-back img,
.cardplay-law-layout.vertical #topDiscardSlot .pile-card img,
.cardplay-law-layout.vertical #bottomDiscardSlot .pile-card img {
  transform: rotate(90deg) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .pile-back,
.cardplay-law-layout.vertical .pile-card,
.cardplay-law-layout.vertical .pile-empty {
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.cardplay-law-layout.vertical .pile-card.opponent-facing { transform: rotate(180deg) !important; }
.cardplay-law-layout.vertical .pile-back img,
.cardplay-law-layout.vertical .pile-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}
@media (max-width: 1600px) {
  .cardplay-law-layout.vertical {
    grid-template-columns: minmax(230px, 0.9fr) auto minmax(230px, 0.9fr) !important;
    gap: 0.9rem !important;
  }
}
@media (max-width: 1280px) {
  .cardplay-law-layout.vertical {
    grid-template-columns: minmax(180px, 0.7fr) auto minmax(180px, 0.7fr) !important;
    --match-card-width: clamp(60px, 4.8vw, 74px);
  }
  .cardplay-law-layout.vertical > .board-panel.vertical {
    height: min(calc(100vh - 235px), 860px) !important;
  }
}


/* v6_fixed8f based on 8d - law layout side tables, side info, larger piles, full hands */
.cardplay-law-layout.vertical {
  grid-template-columns: minmax(360px, 430px) auto minmax(360px, 430px) !important;
  align-items: stretch !important;
  justify-content: center !important;
  gap: 1.35rem !important;
  width: 100% !important;
  min-height: calc(100vh - 235px) !important;
  overflow: visible !important;
  --match-card-width: clamp(74px, 4.55vw, 84px);
  --match-card-height: calc(var(--match-card-width) * 1.4);
  --match-pile-width: calc(var(--match-card-height) * 1.12);
  --match-pile-height: calc(var(--match-card-width) * 1.12);
}

.cardplay-law-layout.vertical > .board-panel.vertical {
  position: relative !important;
  height: min(calc(100vh - 235px), 972px) !important;
  aspect-ratio: 587 / 916 !important;
  overflow: visible !important;
}

.cardplay-law-layout.vertical .board-backdrop {
  inset: 0 !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
}

.cardplay-law-layout.vertical .board-overlay { pointer-events: none !important; }
.cardplay-law-layout.vertical .board-hud { display: none !important; }

.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 16.78% 14.05% 17.42% 14.05% !important;
  gap: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  aspect-ratio: 5 / 7 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 5 / 7 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card {
  margin: 0 !important;
  overflow: hidden !important;
  box-shadow: none !important;
  transition: filter 0.12s ease !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
  transform: none !important;
  filter: brightness(1.06) !important;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.16) !important;
  z-index: 8 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  object-fit: contain !important;
  display: block !important;
}

.cardplay-law-layout.vertical .side-table {
  align-self: stretch !important;
  min-height: min(calc(100vh - 235px), 972px) !important;
  background: rgba(88, 88, 88, 0.28) !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0.95rem !important;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.2) !important;
}
.cardplay-law-layout.vertical .opponent-side-table {
  justify-content: flex-start !important;
  align-items: stretch !important;
}
.cardplay-law-layout.vertical .player-side-table {
  justify-content: flex-end !important;
  align-items: stretch !important;
}

.cardplay-law-layout.vertical .side-hand-slot {
  width: 100% !important;
  min-height: calc(var(--match-card-height) + 26px) !important;
  background: rgba(0,0,0,0.82) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 8px !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
  padding: 0.55rem !important;
}
.cardplay-law-layout.vertical .opponent-hand-slot {
  margin-top: 0.15rem !important;
}
.cardplay-law-layout.vertical .player-hand-slot {
  margin-top: auto !important;
  margin-bottom: 0.15rem !important;
}

.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  position: static !important;
  width: 100% !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  gap: 0.18rem !important;
  overflow: hidden !important;
}
.cardplay-law-layout.vertical #playerHand.clean-hand {
  align-items: flex-end !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  max-width: none !important;
  aspect-ratio: 5 / 7 !important;
  flex: 0 0 auto !important;
}
.cardplay-law-layout.vertical .opponent-hand-card img,
.cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 5 / 7 !important;
  object-fit: contain !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card:hover {
  transform: translateY(-2px) !important;
  z-index: 18 !important;
}
.cardplay-law-layout.vertical #playerHand .hand-actions {
  gap: 0.08rem !important;
  padding: 0.08rem !important;
}
.cardplay-law-layout.vertical #playerHand .hand-actions button {
  padding: 0.1rem 0.08rem !important;
  font-size: 0.56rem !important;
}

.cardplay-law-layout.vertical .side-info-box {
  margin-top: 0.7rem !important;
  border: 2px solid rgba(245,221,54,0.95) !important;
  border-radius: 8px !important;
  background: rgba(18,9,34,0.82) !important;
  color: #f2e58a !important;
  padding: 0.65rem 0.8rem !important;
  display: grid !important;
  gap: 0.22rem !important;
}
.cardplay-law-layout.vertical .player-info-box {
  margin-top: 0 !important;
  margin-bottom: 0.75rem !important;
}
.cardplay-law-layout.vertical .side-player-label {
  font-weight: 800 !important;
  color: #fff6c2 !important;
  font-size: 0.98rem !important;
}
.cardplay-law-layout.vertical .side-die-roll {
  font-size: 0.92rem !important;
  color: #d7d4ff !important;
}
.cardplay-law-layout.vertical .side-stat-line {
  font-size: 1.08rem !important;
  font-weight: 800 !important;
}

.cardplay-law-layout.vertical .pile-slot {
  position: absolute !important;
  z-index: 6 !important;
  pointer-events: none !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 14.75% !important; top: 5.05% !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 42.16% !important; top: 4.35% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 68.25% !important; top: 5.05% !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 14.75% !important; top: 82.15% !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 42.16% !important; top: 81.42% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 68.25% !important; top: 82.15% !important; }
.cardplay-law-layout.vertical #topDeckSlot .pile-back img,
.cardplay-law-layout.vertical #bottomDeckSlot .pile-back img,
.cardplay-law-layout.vertical #topDiscardSlot .pile-card img,
.cardplay-law-layout.vertical #bottomDiscardSlot .pile-card img {
  transform: rotate(90deg) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .pile-back,
.cardplay-law-layout.vertical .pile-card,
.cardplay-law-layout.vertical .pile-empty {
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.cardplay-law-layout.vertical .pile-card.opponent-facing { transform: rotate(180deg) !important; }
.cardplay-law-layout.vertical .pile-back img,
.cardplay-law-layout.vertical .pile-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.card-fly {
  position: fixed;
  z-index: 55;
  width: 160px;
  pointer-events: none;
  transition-property: transform, left, top, width, opacity;
  transition-timing-function: cubic-bezier(.22,.87,.3,1), ease, ease, ease, ease;
}

@media (max-width: 1700px) {
  .cardplay-law-layout.vertical {
    grid-template-columns: minmax(300px, 360px) auto minmax(300px, 360px) !important;
    --match-card-width: clamp(66px, 4.1vw, 78px);
  }
}


/* v6_fixed8g based on 8f - keep 8d geometry feel, visible full hands, side info, bigger piles, law nudges */
.cardplay-law-layout.vertical {
  grid-template-columns: minmax(320px, 390px) auto minmax(320px, 390px) !important;
  --match-card-width: clamp(66px, 4.0vw, 76px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.22) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.22) !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  height: min(calc(100vh - 220px), 980px) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 16.35% 12.9% 16.95% 12.9% !important;
  gap: 0 !important;
}
.cardplay-law-layout.vertical .side-table {
  min-height: min(calc(100vh - 220px), 980px) !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--match-card-height) + 18px) !important;
  overflow: visible !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  overflow: visible !important;
  gap: 0.14rem !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  min-width: 0 !important;
  max-width: var(--match-card-width) !important;
  flex: 0 0 var(--match-card-width) !important;
  background: transparent !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  border: 2px solid transparent !important;
  border-radius: 8px !important;
  overflow: visible !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.selected {
  border-color: rgba(127,233,127,0.9) !important;
  box-shadow: 0 0 0 1px rgba(127,233,127,0.5) !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card img,
.cardplay-law-layout.vertical .opponent-hand-card img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
}
.cardplay-law-layout.vertical .side-action-strip {
  margin-top: auto !important;
  margin-bottom: 0.5rem !important;
  display: grid !important;
  gap: 0.25rem !important;
}
.cardplay-law-layout.vertical .selected-card-title {
  color: var(--muted) !important;
  font-size: 0.86rem !important;
  min-height: 1.1rem !important;
}
.cardplay-law-layout.vertical .muted-hint { color: #c8b4ef !important; opacity: 0.9 !important; }
.cardplay-law-layout.vertical .selected-card-actions {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0.3rem !important;
}
.cardplay-law-layout.vertical .selected-card-actions button {
  min-width: 0 !important;
  padding: 0.34rem 0.18rem !important;
  font-size: 0.66rem !important;
  white-space: nowrap !important;
}
.cardplay-law-layout.vertical .selected-card-actions .active-mode {
  background: rgba(154,107,255,0.32) !important;
  color: #fff !important;
}
.cardplay-law-layout.vertical .side-info-box {
  padding: 0.75rem 0.9rem !important;
}
.cardplay-law-layout.vertical .side-die-roll {
  font-size: 1.15rem !important;
  font-weight: 800 !important;
  color: #fff7bf !important;
}
.cardplay-law-layout.vertical .side-stat-line {
  font-size: 1.1rem !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 12.8% !important; top: 4.2% !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 43.1% !important; top: 3.65% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 71.0% !important; top: 4.2% !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 12.8% !important; top: 83.05% !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 43.1% !important; top: 83.7% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 71.0% !important; top: 83.05% !important; }
.cardplay-law-layout.vertical .pile-slot, .cardplay-law-layout.vertical .pile-back, .cardplay-law-layout.vertical .pile-card, .cardplay-law-layout.vertical .pile-empty {
  pointer-events: auto !important;
}
.cardplay-law-layout.vertical .board-stage .pile-card img,
.cardplay-law-layout.vertical .board-stage .pile-back img {
  filter: drop-shadow(0 3px 6px rgba(0,0,0,0.35));
}
.card-fly { z-index: 9999 !important; will-change: left, top, transform, width !important; }


/* v6_fixed8h from 8g - layout nudges, visible full hands, drag targets, bigger board spacing */
.cardplay-law-layout.vertical {
  grid-template-columns: minmax(360px, 420px) auto minmax(360px, 420px) !important;
  --match-card-width: clamp(62px, 3.35vw, 72px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.34) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.34) !important;
}
.match-screen-shell { max-width: 1710px !important; }
.cardplay-law-layout.vertical > .board-panel.vertical {
  height: min(calc(100vh - 220px), 960px) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 16.2% 11.45% 17.25% 11.45% !important;
  gap: 0.72% 0.9% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: visible !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  border-radius: 4px !important;
}
.cardplay-law-layout.vertical .side-table {
  min-height: min(calc(100vh - 220px), 960px) !important;
  padding: 0.9rem 1rem !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--match-card-height) + 24px) !important;
  overflow: hidden !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  overflow: visible !important;
  gap: 0 !important;
  justify-content: flex-start !important;
}
.cardplay-law-layout.vertical #opponentHand > *,
.cardplay-law-layout.vertical #playerHand.clean-hand > * {
  margin-left: -12px !important;
}
.cardplay-law-layout.vertical #opponentHand > *:first-child,
.cardplay-law-layout.vertical #playerHand.clean-hand > *:first-child {
  margin-left: 0 !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  flex: 0 0 var(--match-card-width) !important;
  position: relative;
  z-index: 1;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card:hover,
.cardplay-law-layout.vertical .opponent-hand-card:hover {
  z-index: 15 !important;
}
.cardplay-law-layout.vertical .side-action-strip {
  margin-top: 0.45rem !important;
  margin-bottom: 0.45rem !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 11.65% !important; top: 3.6% !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 44.1% !important; top: 3.2% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 73.2% !important; top: 3.6% !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 11.65% !important; top: 83.9% !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 44.1% !important; top: 84.55% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 73.2% !important; top: 83.9% !important; }
.cardplay-law-layout.vertical .drop-hover {
  box-shadow: inset 0 0 0 3px rgba(221,193,109,0.92) !important;
  border-radius: 6px !important;
}
.cardplay-law-layout.vertical .side-die-roll {
  font-size: 1.35rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.02em;
  min-height: 1.6em;
}
.cardplay-law-layout.vertical .side-die-roll.rolling {
  color: #fff !important;
  text-shadow: 0 0 18px rgba(255,229,104,0.85);
}
.hand-card.dragging { opacity: 0.55 !important; }
.card-fly { z-index: 99999 !important; }
@media (max-width: 1500px) {
  .cardplay-law-layout.vertical {
    grid-template-columns: minmax(310px, 360px) auto minmax(310px, 360px) !important;
    --match-card-width: clamp(56px, 3.6vw, 66px) !important;
  }
  .cardplay-law-layout.vertical #opponentHand > *,
  .cardplay-law-layout.vertical #playerHand.clean-hand > * { margin-left: -10px !important; }
}



/* v6_fixed8i from 8h - aggressive geometry nudge, full hands, true drop targets */
.match-screen-shell { max-width: 1840px !important; }

.cardplay-law-layout.vertical {
  grid-template-columns: minmax(420px, 500px) auto minmax(420px, 500px) !important;
  gap: 1.75rem !important;
  --match-card-width: clamp(72px, 3.95vw, 84px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.18) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.18) !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  height: min(calc(100vh - 210px), 990px) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 15.45% 9.85% 16.85% 9.85% !important;
  gap: 1.05% 1.15% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: visible !important;
  border-radius: 6px !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  border-radius: 6px !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 8.9% !important; top: 4.1% !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 44.95% !important; top: 3.45% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 76.2% !important; top: 4.1% !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 8.9% !important; top: 84.35% !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 44.95% !important; top: 84.9% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 76.2% !important; top: 84.35% !important; }

.cardplay-law-layout.vertical .side-table {
  padding: 1rem 1.05rem !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  width: 100% !important;
  min-height: calc(var(--match-card-height) + 18px) !important;
  overflow: visible !important;
  padding: 0.35rem 0.4rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  display: grid !important;
  grid-template-columns: repeat(5, var(--match-card-width)) !important;
  grid-auto-rows: var(--match-card-height) !important;
  justify-content: start !important;
  align-content: center !important;
  gap: 0.1rem !important;
  width: max-content !important;
  min-width: 100% !important;
  overflow: visible !important;
}
.cardplay-law-layout.vertical #opponentHand > *,
.cardplay-law-layout.vertical #playerHand.clean-hand > * {
  margin-left: 0 !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
  max-width: var(--match-card-width) !important;
  flex: none !important;
  overflow: visible !important;
}
.cardplay-law-layout.vertical .opponent-hand-card img,
.cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}
.cardplay-law-layout.vertical .side-action-strip {
  margin-top: 0.55rem !important;
  margin-bottom: 0.55rem !important;
}
body.dragging-card .board-card,
body.dragging-card .board-card img,
body.dragging-card .board-backdrop,
body.dragging-card .board-overlay,
body.dragging-card .pile-slot > *,
body.dragging-card .side-hand-slot img {
  pointer-events: none !important;
}
body.dragging-card .board-cell,
body.dragging-card .pile-slot {
  pointer-events: auto !important;
}
.cardplay-law-layout.vertical .drop-hover {
  box-shadow: inset 0 0 0 3px rgba(119,237,148,0.95) !important;
  border-radius: 8px !important;
}
.cardplay-law-layout.vertical .drop-hover.discard-target,
.cardplay-law-layout.vertical .drop-hover.boss-target {
  box-shadow: 0 0 0 3px rgba(221,193,109,0.95) !important;
}


/* v6_fixed8j overrides - much wider side tables, smaller board, visible hands, custom drag */
.match-screen-shell { max-width: 1860px !important; }
.cardplay-law-layout.vertical {
  grid-template-columns: minmax(560px, 620px) minmax(430px, 520px) minmax(560px, 620px) !important;
  gap: 1rem !important;
  --match-card-width: clamp(62px, 3.2vw, 72px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.18) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.18) !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(94vw, 63vh) !important;
  height: min(calc(100vh - 205px), 930px) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 14.6% 10.7% 16.1% 10.7% !important;
  gap: 1.65% 1.8% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: visible !important;
}
.cardplay-law-layout.vertical .side-table {
  min-height: min(calc(100vh - 205px), 930px) !important;
  padding: 0.85rem 1.1rem !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--match-card-height) * 2 + 1.1rem) !important;
  overflow: visible !important;
  padding: 0.5rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, var(--match-card-width)) !important;
  grid-auto-rows: var(--match-card-height) !important;
  gap: 0.28rem !important;
  justify-content: start !important;
  align-content: start !important;
  overflow: visible !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
  max-width: none !important;
  margin: 0 !important;
}
.cardplay-law-layout.vertical .opponent-hand-card img,
.cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 7.9% !important; top: 3.9% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 45.8% !important; top: 3.3% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 78.4% !important; top: 3.9% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 7.9% !important; top: 84.2% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 45.8% !important; top: 84.8% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 78.4% !important; top: 84.2% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.pointer-drag-ghost {
  position: fixed !important;
  z-index: 100000 !important;
  pointer-events: none !important;
  transform: rotate(-3deg);
  filter: drop-shadow(0 8px 20px rgba(0,0,0,0.45));
}
body.dragging-card { cursor: grabbing !important; }
body.dragging-card .board-backdrop, body.dragging-card .board-overlay { pointer-events: none !important; }
.cardplay-law-layout.vertical .drop-hover {
  outline: 3px solid rgba(118, 255, 155, 0.95) !important;
  outline-offset: 1px !important;
  box-shadow: inset 0 0 0 2px rgba(118,255,155,0.65) !important;
}


/* v6_fixed8k final layout and board-zoom pass */
.cardplay-law-layout.vertical {
  --match-card-width: clamp(68px, 3.45vw, 82px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-width) * 1.26) !important;
  --match-pile-height: calc(var(--match-card-height) * 0.74) !important;
  grid-template-columns: minmax(360px, 0.78fr) minmax(520px, 0.98fr) minmax(360px, 0.78fr) !important;
  gap: 0.8rem !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(92vw, 69vh) !important;
  height: min(calc(100vh - 200px), 950px) !important;
}
.cardplay-law-layout.vertical .board-backdrop {
  background-size: 108% 100% !important;
  background-position: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 14.35% 9.1% 15.55% 9.1% !important;
  gap: 1.05% 1.25% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: visible !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  cursor: zoom-in !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) scale(1.12) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:active {
  transform: rotate(180deg) scale(1.12) !important;
}
.cardplay-law-layout.vertical .side-table {
  min-height: min(calc(100vh - 200px), 950px) !important;
  padding: 0.8rem 0.95rem !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--match-card-height) * 2 + 1.2rem) !important;
  overflow: visible !important;
  padding: 0.4rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  display: grid !important;
  grid-template-columns: repeat(3, var(--match-card-width)) !important;
  grid-auto-rows: var(--match-card-height) !important;
  gap: 0.32rem !important;
  justify-content: start !important;
  align-content: start !important;
  width: 100% !important;
  overflow: visible !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
  max-width: none !important;
  margin: 0 !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 4.8% !important; top: 2.8% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 47.2% !important; top: 2.15% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 82.0% !important; top: 2.8% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 4.8% !important; top: 86.0% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 47.2% !important; top: 86.35% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 82.0% !important; top: 86.0% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .side-action-strip {
  margin-top: 0.45rem !important;
  margin-bottom: 0.5rem !important;
}
.cardplay-law-layout.vertical .selected-card-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 0.28rem !important;
}
.cardplay-law-layout.vertical .selected-card-actions button {
  font-size: 0.64rem !important;
  padding: 0.28rem 0.12rem !important;
  white-space: nowrap !important;
}
.cardplay-law-layout.vertical .side-stat-line {
  line-height: 1.25 !important;
}
.cardplay-law-layout.vertical .side-die-roll {
  min-height: 1.45rem !important;
}
.cardplay-law-layout.vertical .pile-slot,
.cardplay-law-layout.vertical .pile-back,
.cardplay-law-layout.vertical .pile-card,
.cardplay-law-layout.vertical .pile-empty {
  pointer-events: auto !important;
}


/* v6_fixed8l targeted patch from 8k */
.cardplay-law-layout.vertical {
  --match-card-width: clamp(76px, 3.8vw, 90px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-width) * 1.52) !important;
  --match-pile-height: calc(var(--match-card-height) * 0.92) !important;
  grid-template-columns: minmax(400px, 0.84fr) minmax(520px, 0.94fr) minmax(400px, 0.84fr) !important;
  gap: 0.7rem !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(92vw, 68vh) !important;
  height: min(calc(100vh - 205px), 955px) !important;
}
.cardplay-law-layout.vertical .board-backdrop {
  background-size: 104.5% 100% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 14.55% 9.45% 15.95% 9.45% !important;
  gap: 1.22% 1.38% !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--match-card-height) * 3 + 1.3rem) !important;
  align-items: flex-start !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 0.5rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  grid-template-columns: repeat(2, var(--match-card-width)) !important;
  grid-auto-rows: var(--match-card-height) !important;
  gap: 0.36rem !important;
  width: max-content !important;
  min-width: 100% !important;
  align-content: start !important;
  justify-content: start !important;
}
.cardplay-law-layout.vertical .top-deck-slot { left: 26.2% !important; top: 5.05% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .top-boss-slot { left: 43.15% !important; top: 4.2% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 59.85% !important; top: 5.05% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 26.2% !important; top: 83.8% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 43.15% !important; top: 82.95% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 59.85% !important; top: 83.8% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .selected-card-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
.cardplay-law-layout.vertical .selected-card-actions button {
  font-size: 0.62rem !important;
  padding: 0.26rem 0.12rem !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) scale(1.05) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:active {
  transform: rotate(180deg) scale(1.05) !important;
}


/* v6_fixed8m patch from 8l */
.cardplay-law-layout.vertical {
  --match-card-width: clamp(76px, 3.8vw, 90px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: var(--match-card-height) !important;
  --match-pile-height: var(--match-card-width) !important;
  --side-hand-card-width: calc(var(--match-card-width) * 1.48) !important;
  --side-hand-card-height: calc(var(--side-hand-card-width) * 1.4) !important;
  grid-template-columns: minmax(420px, 0.9fr) minmax(500px, 0.9fr) minmax(420px, 0.9fr) !important;
  gap: 0.7rem !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(90vw, 67vh) !important;
  height: min(calc(100vh - 205px), 955px) !important;
}
.cardplay-law-layout.vertical .board-backdrop {
  background-size: 102.2% 100% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 14.95% 10.25% 16.45% 10.25% !important;
  gap: 1.45% 1.62% !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--side-hand-card-height) * 3 + 1.35rem) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  grid-template-columns: repeat(2, var(--side-hand-card-width)) !important;
  grid-auto-rows: var(--side-hand-card-height) !important;
  gap: 0.42rem !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--side-hand-card-width) !important;
  aspect-ratio: 5 / 7 !important;
}
.cardplay-law-layout.vertical .opponent-hand-card img,
.cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 5 / 7 !important;
  object-fit: contain !important;
}
.cardplay-law-layout.vertical .top-boss-slot { left: 43.15% !important; top: 2.95% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 43.15% !important; top: 84.35% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-deck-slot { left: 17.55% !important; top: 4.8% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 68.65% !important; top: 4.8% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 17.55% !important; top: 84.7% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 68.65% !important; top: 84.7% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .side-info-actions {
  margin-top: 0.6rem !important;
  display: flex !important;
  justify-content: flex-start !important;
}
.cardplay-law-layout.vertical .side-info-actions .ghost {
  width: auto !important;
  padding: 0.5rem 0.75rem !important;
}
.cardplay-law-layout.vertical .match-toolbar-actions {
  justify-content: flex-end !important;
}


/* v6_fixed8m_logicfix layout patch */
.cardplay-law-layout.vertical {
  --match-card-width: clamp(78px, 3.95vw, 94px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.02) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.02) !important;
  --side-hand-card-width: calc(var(--match-card-width) * 1.52) !important;
  --side-hand-card-height: calc(var(--side-hand-card-width) * 1.4) !important;
  grid-template-columns: minmax(405px, 0.84fr) minmax(560px, 1.04fr) minmax(405px, 0.84fr) !important;
  gap: 0.72rem !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(91vw, 70vh) !important;
  height: min(calc(100vh - 205px), 980px) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 14.45% 8.95% 16.55% 8.95% !important;
  gap: 1.62% 1.9% !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--side-hand-card-height) * 3 + 1.45rem) !important;
  padding: 0.55rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  grid-template-columns: repeat(2, var(--side-hand-card-width)) !important;
  grid-auto-rows: var(--side-hand-card-height) !important;
  gap: 0.46rem !important;
  width: max-content !important;
  min-width: 100% !important;
}
.cardplay-law-layout.vertical #playerHand.clean-hand {
  margin-left: auto !important;
  justify-content: end !important;
}
.cardplay-law-layout.vertical .player-hand-slot {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: flex-start !important;
}
.cardplay-law-layout.vertical .player-side-table {
  align-items: stretch !important;
}
.cardplay-law-layout.vertical .player-side-table .side-info-box,
.cardplay-law-layout.vertical .player-side-table .side-action-strip {
  text-align: right !important;
  margin-left: auto !important;
}
.cardplay-law-layout.vertical .player-side-table .side-info-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
}
.cardplay-law-layout.vertical .player-side-table .side-info-box .side-info-actions {
  justify-content: flex-end !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  left: 43.15% !important;
  top: 1.7% !important;
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: 43.15% !important;
  top: 85.55% !important;
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
}
.cardplay-law-layout.vertical .top-deck-slot {
  left: 14.2% !important;
  top: 6.25% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: 72.65% !important;
  top: 6.25% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: 14.2% !important;
  top: 86.75% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: 72.65% !important;
  top: 86.75% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}


/* v6_fixed8m_logicfix2 layout cleanup patch */
.match-screen-inner {
  padding: 0.12rem 0.28rem 0.35rem !important;
}
.match-screen-shell {
  max-width: 1880px !important;
  gap: 0.18rem !important;
}
.match-toolbar {
  padding: 0.22rem 0.55rem !important;
  gap: 0.35rem !important;
  min-height: 44px !important;
  border-radius: 22px !important;
}
.match-toolbar-left {
  gap: 0.05rem !important;
}
.match-toolbar-left strong {
  font-size: 0.92rem !important;
  line-height: 1.0 !important;
}
.match-toolbar-left .small {
  font-size: 0.80rem !important;
  line-height: 1.0 !important;
}
.match-toolbar-actions {
  gap: 0.32rem !important;
}
.match-toolbar-actions button {
  padding: 0.38rem 0.72rem !important;
  font-size: 0.88rem !important;
}
.board-wrap-panel {
  padding: 0.18rem 0.28rem 0.38rem !important;
}
.match-status-line,
.thin-line {
  display: none !important;
}
.cardplay-law-layout.vertical {
  --match-card-width: clamp(70px, 3.45vw, 84px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.02) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.02) !important;
  grid-template-columns: minmax(390px, 0.82fr) minmax(620px, 1.08fr) minmax(390px, 0.82fr) !important;
  gap: 0.6rem !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(95vw, 73vh) !important;
  height: min(calc(100vh - 118px), 1020px) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 14.6% 8.55% 16.25% 8.55% !important;
  gap: 1.95% 2.15% !important;
}
.cardplay-law-layout.vertical .board-cell {
  overflow: hidden !important;
}
.cardplay-law-layout.vertical .board-card,
.cardplay-law-layout.vertical .board-card.opponent-facing {
  transform: rotate(var(--card-rot)) scale(1) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) scale(1.0) !important;
  z-index: 2 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:active {
  transform: rotate(180deg) scale(1.0) !important;
  z-index: 2 !important;
}
.cardplay-law-layout.vertical .board-card img {
  object-fit: contain !important;
}


/* v6_fixed8m_logicfix4 - centered board, no top toolbar, no overlap, classic mat only */

.match-screen-inner { padding: 0.18rem 0.22rem 0.35rem !important; }
.match-screen-shell {
  max-width: 1880px !important;
  margin: 0 auto !important;
  gap: 0.24rem !important;
  justify-items: center !important;
}
.match-toolbar { display: none !important; }
.board-wrap-panel {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: flex-start !important;
  padding: 0.18rem 0.24rem 0.42rem !important;
}
.cardplay-law-layout.vertical {
  width: 100% !important;
  max-width: 1820px !important;
  margin: 0 auto !important;
  grid-template-columns: minmax(355px, 0.72fr) minmax(540px, 0.96fr) minmax(355px, 0.72fr) !important;
  gap: 0.9rem !important;
  --match-card-width: clamp(64px, 3.15vw, 78px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 0.98) !important;
  --match-pile-height: calc(var(--match-card-width) * 0.98) !important;
  --side-hand-card-width: calc(var(--match-card-width) * 1.28) !important;
  --side-hand-card-height: calc(var(--side-hand-card-width) * 1.4) !important;
  align-items: stretch !important;
  justify-content: center !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(88vw, 66vh) !important;
  height: min(calc(100vh - 72px), 920px) !important;
  justify-self: center !important;
}
.cardplay-law-layout.vertical .board-backdrop {
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  inset: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 15.35% 11.55% 17.15% 11.55% !important;
  gap: 2.55% 2.75% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: hidden !important;
  border-radius: 4px !important;
  background: transparent !important;
  border: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 5 / 7 !important;
  object-fit: contain !important;
  display: block !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card {
  margin: 0 auto !important;
  transform: rotate(var(--card-rot)) scale(0.94) !important;
  transform-origin: center center !important;
  overflow: hidden !important;
  box-shadow: none !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing {
  transform: rotate(180deg) scale(0.94) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
  transform: rotate(var(--card-rot)) scale(0.94) !important;
  z-index: 3 !important;
  filter: brightness(1.04) !important;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.14) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:active {
  transform: rotate(180deg) scale(0.94) !important;
}
.cardplay-law-layout.vertical .side-table {
  min-height: min(calc(100vh - 72px), 920px) !important;
  padding: 0.7rem 0.8rem !important;
}
.cardplay-law-layout.vertical .side-info-actions {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0.35rem !important;
  justify-content: stretch !important;
  margin-top: 0.7rem !important;
}
.cardplay-law-layout.vertical .side-info-actions .ghost,
.cardplay-law-layout.vertical .side-info-actions .primary {
  width: 100% !important;
  justify-content: center !important;
  padding: 0.45rem 0.65rem !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--side-hand-card-height) * 3 + 1.1rem) !important;
  padding: 0.45rem !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  grid-template-columns: repeat(2, var(--side-hand-card-width)) !important;
  grid-auto-rows: var(--side-hand-card-height) !important;
  gap: 0.36rem !important;
  width: max-content !important;
  min-width: 100% !important;
}
.cardplay-law-layout.vertical .player-hand-slot { display:flex !important; justify-content:flex-end !important; }
.cardplay-law-layout.vertical #playerHand.clean-hand { margin-left: auto !important; justify-content: end !important; }
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--side-hand-card-width) !important;
  height: var(--side-hand-card-height) !important;
  max-width: var(--side-hand-card-width) !important;
  margin: 0 !important;
}
.cardplay-law-layout.vertical .top-boss-slot { left: 45.35% !important; top: 1.95% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .bottom-boss-slot { left: 45.35% !important; top: 85.25% !important; width: var(--match-card-width) !important; height: var(--match-card-height) !important; }
.cardplay-law-layout.vertical .top-deck-slot { left: 10.1% !important; top: 5.45% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .top-discard-slot { left: 75.25% !important; top: 5.45% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-deck-slot { left: 10.1% !important; top: 86.65% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .bottom-discard-slot { left: 75.25% !important; top: 86.65% !important; width: var(--match-pile-width) !important; height: var(--match-pile-height) !important; }
.cardplay-law-layout.vertical .top-boss-slot,
.cardplay-law-layout.vertical .bottom-boss-slot,
.cardplay-law-layout.vertical .top-deck-slot,
.cardplay-law-layout.vertical .top-discard-slot,
.cardplay-law-layout.vertical .bottom-deck-slot,
.cardplay-law-layout.vertical .bottom-discard-slot {
  pointer-events: auto !important;
}
.cardplay-law-layout.vertical .pile-back img,
.cardplay-law-layout.vertical .pile-card img {
  object-fit: contain !important;
}
.playmat-setting, .layout-setting, #matChoiceSelect, #settingsMatChoice, #matchLayoutSelect, #settingsLayoutChoice { display:none !important; }


/* v6_fixed8m_logicfix5 - current html cleanup pass */
.cardplay-law-layout.vertical {
  grid-template-columns: minmax(345px, 0.72fr) minmax(560px, 0.90fr) minmax(395px, 0.82fr) !important;
  gap: 0.72rem !important;
  --match-card-width: clamp(60px, 2.95vw, 72px) !important;
  --match-card-height: calc(var(--match-card-width) * 1.4) !important;
  --match-pile-width: calc(var(--match-card-height) * 1.02) !important;
  --match-pile-height: calc(var(--match-card-width) * 1.02) !important;
  --side-hand-card-width: calc(var(--match-card-width) * 1.22) !important;
  --side-hand-card-height: calc(var(--side-hand-card-width) * 1.4) !important;
}
.cardplay-law-layout.vertical > .board-panel.vertical {
  width: min(84vw, 62vh) !important;
  height: min(calc(100vh - 66px), 900px) !important;
}
.cardplay-law-layout.vertical .board-backdrop {
  background-size: contain !important;
  background-position: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical {
  inset: 15.2% 12.2% 17.2% 12.2% !important;
  gap: 1.2% 3.2% !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: hidden !important;
  border-radius: 3px !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card {
  transform: rotate(var(--card-rot)) scale(0.88) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing {
  transform: rotate(180deg) scale(0.88) !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card:active,
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:hover,
.cardplay-law-layout.vertical .grid-board.vertical .board-card.opponent-facing:active {
  transform: none !important;
  filter: none !important;
  box-shadow: none !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  padding: 0 !important;
}
.cardplay-law-layout.vertical .side-table {
  min-height: min(calc(100vh - 66px), 900px) !important;
}
.cardplay-law-layout.vertical .side-hand-slot {
  min-height: calc(var(--side-hand-card-height) * 3 + 0.9rem) !important;
  padding: 0.4rem !important;
}
.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  grid-template-columns: repeat(2, var(--side-hand-card-width)) !important;
  grid-auto-rows: var(--side-hand-card-height) !important;
  gap: 0.28rem !important;
}
.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: var(--side-hand-card-width) !important;
  height: var(--side-hand-card-height) !important;
}
.cardplay-law-layout.vertical .player-side-table .side-info-box,
.cardplay-law-layout.vertical .player-side-table .side-action-strip {
  text-align: right !important;
  align-items: flex-end !important;
}
.cardplay-law-layout.vertical .side-info-actions {
  gap: 0.26rem !important;
}
.cardplay-law-layout.vertical .side-info-actions .ghost,
.cardplay-law-layout.vertical .side-info-actions .primary {
  padding: 0.42rem 0.62rem !important;
}
.cardplay-law-layout.vertical .side-action-strip { margin-top: 0.35rem !important; }
.cardplay-law-layout.vertical .selected-card-title.muted-hint { display: none !important; }
.cardplay-law-layout.vertical .side-action-strip:empty { display: none !important; }
.cardplay-law-layout.vertical .top-boss-slot {
  left: 43.55% !important;
  top: 1.35% !important;
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: 43.55% !important;
  top: 86.0% !important;
  width: var(--match-card-width) !important;
  height: var(--match-card-height) !important;
}
.cardplay-law-layout.vertical .top-deck-slot {
  left: 17.0% !important;
  top: 5.35% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: 69.4% !important;
  top: 5.35% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: 17.0% !important;
  top: 87.1% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: 69.4% !important;
  top: 87.1% !important;
  width: var(--match-pile-width) !important;
  height: var(--match-pile-height) !important;
}


/* === Layout foundation cleanup: single-source vertical match geometry === */
/* Baseline: ATAC_TCG_Online_Local_Build_v6_fixed8m_logicfix5.zip
   Scope: layout only. No logic / timing / animation changes.
   Card play layout.png is law for the vertical board.
*/
.cardplay-law-layout.vertical {
  --law-grid-left-right: 13.35%;
  --law-grid-top: 16.70%;
  --law-grid-bottom: 17.35%;
  --law-grid-gap: 0.18%;
  --law-pile-width: calc(var(--match-card-height) * 1.02);
  --law-pile-height: calc(var(--match-card-width) * 1.02);
  --law-boss-width: var(--match-card-width);
  --law-boss-height: var(--match-card-height);
  --law-left-pile-center-x: 29.45%;
  --law-right-pile-center-x: 70.55%;
  --law-boss-center-x: 49.95%;
  --law-top-pile-center-y: 10.80%;
  --law-top-boss-center-y: 10.55%;
  --law-bottom-pile-center-y: 87.50%;
  --law-bottom-boss-center-y: 88.20%;
}

.cardplay-law-layout.vertical .grid-board.vertical {
  inset: var(--law-grid-top) var(--law-grid-left-right) var(--law-grid-bottom) var(--law-grid-left-right) !important;
  gap: var(--law-grid-gap) !important;
}

.cardplay-law-layout.vertical .pile-slot {
  width: var(--law-pile-width) !important;
  height: var(--law-pile-height) !important;
}

.cardplay-law-layout.vertical .top-boss-slot,
.cardplay-law-layout.vertical .bottom-boss-slot {
  width: var(--law-boss-width) !important;
  height: var(--law-boss-height) !important;
}

.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2)) !important;
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2)) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}

.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2)) !important;
  top: calc(var(--law-bottom-boss-center-y) - (var(--law-boss-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}

/* === 1920x1080 play map refinement ===
   Baseline: ATAC_TCG_Online_Local_Build_v6_fixed8m_logicfix5_layoutfoundation.zip
   Scope: layout only. 1920x1080_Play_Map.png is law.
*/
.cardplay-law-layout.vertical {
  /* single-source geometry for 1920x1080 testing */
  --law-board-width: clamp(560px, 30.6vw, 602px);
  --law-board-height: calc(var(--law-board-width) * 1.5604770017); /* 916 / 587 */
  --law-side-width: clamp(410px, 23.2vw, 470px);

  --law-grid-left-right: 13.58%;
  --law-grid-top: 15.92%;
  --law-grid-bottom: 16.42%;
  --law-grid-gap: 0.62% 1.04%;

  --law-pile-width: calc(var(--match-card-height) * 1.06);
  --law-pile-height: calc(var(--match-card-width) * 1.06);
  --law-boss-width: var(--match-card-width);
  --law-boss-height: var(--match-card-height);

  --law-left-pile-center-x: 29.25%;
  --law-right-pile-center-x: 70.75%;
  --law-boss-center-x: 50.00%;
  --law-top-pile-center-y: 8.78%;
  --law-top-boss-center-y: 8.72%;
  --law-bottom-pile-center-y: 90.18%;
  --law-bottom-boss-center-y: 90.06%;

  grid-template-columns: var(--law-side-width) var(--law-board-width) var(--law-side-width) !important;
  gap: 1.15rem !important;
  justify-content: center !important;
  align-items: stretch !important;
}

.cardplay-law-layout.vertical > .board-panel.vertical {
  width: var(--law-board-width) !important;
  height: var(--law-board-height) !important;
  max-width: none !important;
  max-height: none !important;
  aspect-ratio: 587 / 916 !important;
  margin: 0 auto !important;
}

.cardplay-law-layout.vertical .grid-board.vertical {
  inset: var(--law-grid-top) var(--law-grid-left-right) var(--law-grid-bottom) var(--law-grid-left-right) !important;
  gap: var(--law-grid-gap) !important;
}

.cardplay-law-layout.vertical .side-table {
  width: 100% !important;
  min-height: var(--law-board-height) !important;
}

.cardplay-law-layout.vertical .pile-slot {
  width: var(--law-pile-width) !important;
  height: var(--law-pile-height) !important;
}

.cardplay-law-layout.vertical .top-boss-slot,
.cardplay-law-layout.vertical .bottom-boss-slot {
  width: var(--law-boss-width) !important;
  height: var(--law-boss-height) !important;
}

.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2)) !important;
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2)) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2)) !important;
  top: calc(var(--law-bottom-boss-center-y) - (var(--law-boss-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}

@media (max-width: 1720px) {
  .cardplay-law-layout.vertical {
    --law-board-width: clamp(520px, 31vw, 580px);
    --law-side-width: clamp(340px, 22vw, 420px);
  }
}

@media (max-width: 1480px) {
  .cardplay-law-layout.vertical {
    --law-board-width: clamp(470px, 33vw, 540px);
    --law-side-width: clamp(280px, 20vw, 340px);
    --law-grid-gap: 0.48% 0.88%;
  }
}

/* === layout tweak pass: center cards in annotated zones and maximize hand readability === */
.cardplay-law-layout.vertical {
  --law-grid-left-right: 13.95%;
  --law-grid-top: 16.05%;
  --law-grid-bottom: 16.55%;
  --law-grid-gap: 0.44% 0.82%;
  --law-board-width: clamp(575px, 31.4vw, 620px);
  --law-side-width: clamp(430px, 24.2vw, 500px);
  --law-pile-width: calc(var(--match-card-height) * 1.08);
  --law-pile-height: calc(var(--match-card-width) * 1.08);
}

.cardplay-law-layout.vertical .grid-board.vertical {
  inset: var(--law-grid-top) var(--law-grid-left-right) var(--law-grid-bottom) var(--law-grid-left-right) !important;
  gap: var(--law-grid-gap) !important;
}

/* opponent side is head-to-head: top-left is discard, top-right is deck */
.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
}

.cardplay-law-layout.vertical .side-table {
  min-height: var(--law-board-height) !important;
}

.cardplay-law-layout.vertical .side-hand-slot {
  min-height: 41.5% !important;
  height: 41.5% !important;
  padding: 0.65rem !important;
  overflow: hidden !important;
}

.cardplay-law-layout.vertical .opponent-hand-slot {
  margin-top: 0.25rem !important;
}
.cardplay-law-layout.vertical .player-hand-slot {
  margin-bottom: 0.25rem !important;
}

.cardplay-law-layout.vertical #opponentHand,
.cardplay-law-layout.vertical #playerHand.clean-hand {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  grid-auto-rows: auto !important;
  justify-items: center !important;
  align-content: start !important;
  align-items: start !important;
  gap: 0.4rem 0.4rem !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
}
.cardplay-law-layout.vertical #playerHand.clean-hand {
  align-content: end !important;
}

.cardplay-law-layout.vertical .opponent-hand-card,
.cardplay-law-layout.vertical #playerHand .clean-hand-card {
  width: min(100%, 112px) !important;
  max-width: 112px !important;
  aspect-ratio: 5 / 7 !important;
  height: auto !important;
  justify-self: center !important;
}
.cardplay-law-layout.vertical .opponent-hand-card img,
.cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  width: 100% !important;
  height: auto !important;
}

@media (max-width: 1720px) {
  .cardplay-law-layout.vertical {
    --law-board-width: clamp(540px, 31vw, 590px);
    --law-side-width: clamp(380px, 23vw, 450px);
  }
  .cardplay-law-layout.vertical .opponent-hand-card,
  .cardplay-law-layout.vertical #playerHand .clean-hand-card {
    max-width: 98px !important;
  }
}

@media (max-width: 1480px) {
  .cardplay-law-layout.vertical {
    --law-board-width: clamp(500px, 32vw, 550px);
    --law-side-width: clamp(320px, 22vw, 390px);
  }
  .cardplay-law-layout.vertical .side-hand-slot {
    min-height: 38% !important;
    height: 38% !important;
  }
  .cardplay-law-layout.vertical .opponent-hand-card,
  .cardplay-law-layout.vertical #playerHand .clean-hand-card {
    max-width: 88px !important;
  }
}


/* layout-only patch from game.zip baseline: opponent deck up 1/4 inch + 100x125 */
.cardplay-law-layout.vertical .top-deck-slot {
  width: 100px !important;
  height: 125px !important;
  top: calc(var(--law-top-pile-center-y) - 62.5px - 24px) !important;
}


/* layout-only patch from game1.zip baseline: opponent discard up 1/4 inch + 100x125, player deck down 1/4 inch */
.cardplay-law-layout.vertical .top-discard-slot {
  width: 100px !important;
  height: 125px !important;
  top: calc(var(--law-top-pile-center-y) - 62.5px - 24px) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2) + 24px) !important;
}


/* layout-only patch from game2.zip baseline: opponent boss up 1/4 inch + 100x125, player discard down 1/4 inch */
.cardplay-law-layout.vertical .top-boss-slot {
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px) !important;
  width: 100px !important;
  height: 125px !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  top: calc(var(--law-bottom-discard-center-y) - (var(--law-pile-height) / 2) + 24px) !important;
}



/* Game7.13 layout-only patch: remove specified 5x5 grid spacing */
.cardplay-law-layout.vertical {
  --law-grid-gap: 0px !important;
}
.cardplay-law-layout.vertical .grid-board,
.cardplay-law-layout.vertical .grid-board.vertical {
  gap: 0 !important;
  column-gap: 0 !important;
  row-gap: 0 !important;
}


/* layout-only patch: 5x5 grid zones and legal-play zones set to 100x125, cards centered at 100x125 */
.cardplay-law-layout.vertical .grid-board.vertical {
  grid-template-columns: repeat(5, 100px) !important;
  grid-template-rows: repeat(5, 125px) !important;
  justify-content: center !important;
  align-content: center !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  width: 100px !important;
  height: 125px !important;
  min-width: 100px !important;
  min-height: 125px !important;
  max-width: 100px !important;
  max-height: 125px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-card img {
  width: 100px !important;
  height: 125px !important;
  min-width: 100px !important;
  min-height: 125px !important;
  max-width: 100px !important;
  max-height: 125px !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-card {
  margin: 0 auto !important;
  align-self: center !important;
  justify-self: center !important;
}

.cardplay-law-layout.vertical .board-cell.legal-play,
.cardplay-law-layout.vertical .board-cell.legal-replace {
  width: 100px !important;
  height: 125px !important;
  min-width: 100px !important;
  min-height: 125px !important;
  max-width: 100px !important;
  max-height: 125px !important;
}


/* coordinate-based slot system for board cells (1,1) through (5,5) */
.cardplay-law-layout.vertical {
  --slot-1-1-x: 0px;
  --slot-1-1-y: 0px;
  --slot-1-1-w: 100px;
  --slot-1-1-h: 125px;
  --slot-1-2-x: 0px;
  --slot-1-2-y: 0px;
  --slot-1-2-w: 100px;
  --slot-1-2-h: 125px;
  --slot-1-3-x: 0px;
  --slot-1-3-y: 0px;
  --slot-1-3-w: 100px;
  --slot-1-3-h: 125px;
  --slot-1-4-x: 0px;
  --slot-1-4-y: 0px;
  --slot-1-4-w: 100px;
  --slot-1-4-h: 125px;
  --slot-1-5-x: 0px;
  --slot-1-5-y: 0px;
  --slot-1-5-w: 100px;
  --slot-1-5-h: 125px;
  --slot-2-1-x: 0px;
  --slot-2-1-y: 0px;
  --slot-2-1-w: 100px;
  --slot-2-1-h: 125px;
  --slot-2-2-x: 0px;
  --slot-2-2-y: 0px;
  --slot-2-2-w: 100px;
  --slot-2-2-h: 125px;
  --slot-2-3-x: 0px;
  --slot-2-3-y: 0px;
  --slot-2-3-w: 100px;
  --slot-2-3-h: 125px;
  --slot-2-4-x: 0px;
  --slot-2-4-y: 0px;
  --slot-2-4-w: 100px;
  --slot-2-4-h: 125px;
  --slot-2-5-x: 0px;
  --slot-2-5-y: 0px;
  --slot-2-5-w: 100px;
  --slot-2-5-h: 125px;
  --slot-3-1-x: 0px;
  --slot-3-1-y: 0px;
  --slot-3-1-w: 100px;
  --slot-3-1-h: 125px;
  --slot-3-2-x: 0px;
  --slot-3-2-y: 0px;
  --slot-3-2-w: 100px;
  --slot-3-2-h: 125px;
  --slot-3-3-x: 0px;
  --slot-3-3-y: 0px;
  --slot-3-3-w: 100px;
  --slot-3-3-h: 125px;
  --slot-3-4-x: 0px;
  --slot-3-4-y: 0px;
  --slot-3-4-w: 100px;
  --slot-3-4-h: 125px;
  --slot-3-5-x: 0px;
  --slot-3-5-y: 0px;
  --slot-3-5-w: 100px;
  --slot-3-5-h: 125px;
  --slot-4-1-x: 0px;
  --slot-4-1-y: 0px;
  --slot-4-1-w: 100px;
  --slot-4-1-h: 125px;
  --slot-4-2-x: 0px;
  --slot-4-2-y: 0px;
  --slot-4-2-w: 100px;
  --slot-4-2-h: 125px;
  --slot-4-3-x: 0px;
  --slot-4-3-y: 0px;
  --slot-4-3-w: 100px;
  --slot-4-3-h: 125px;
  --slot-4-4-x: 0px;
  --slot-4-4-y: 0px;
  --slot-4-4-w: 100px;
  --slot-4-4-h: 125px;
  --slot-4-5-x: 0px;
  --slot-4-5-y: 0px;
  --slot-4-5-w: 100px;
  --slot-4-5-h: 125px;
  --slot-5-1-x: 0px;
  --slot-5-1-y: 0px;
  --slot-5-1-w: 100px;
  --slot-5-1-h: 125px;
  --slot-5-2-x: 0px;
  --slot-5-2-y: 0px;
  --slot-5-2-w: 100px;
  --slot-5-2-h: 125px;
  --slot-5-3-x: 0px;
  --slot-5-3-y: 0px;
  --slot-5-3-w: 100px;
  --slot-5-3-h: 125px;
  --slot-5-4-x: 0px;
  --slot-5-4-y: 0px;
  --slot-5-4-w: 100px;
  --slot-5-4-h: 125px;
  --slot-5-5-x: 0px;
  --slot-5-5-y: 0px;
  --slot-5-5-w: 100px;
  --slot-5-5-h: 125px;
}

.cardplay-law-layout.vertical .grid-board.vertical {
  overflow: visible !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  overflow: visible !important;
  position: relative !important;
  z-index: 1;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell .board-card {
  margin: 0 auto !important;
  align-self: center !important;
  justify-self: center !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,1"] {
  width: var(--slot-1-1-w) !important;
  height: var(--slot-1-1-h) !important;
  min-width: var(--slot-1-1-w) !important;
  min-height: var(--slot-1-1-h) !important;
  max-width: var(--slot-1-1-w) !important;
  max-height: var(--slot-1-1-h) !important;
  transform: translate(var(--slot-1-1-x), var(--slot-1-1-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,1"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,1"] .board-card img {
  width: var(--slot-1-1-w) !important;
  height: var(--slot-1-1-h) !important;
  min-width: var(--slot-1-1-w) !important;
  min-height: var(--slot-1-1-h) !important;
  max-width: var(--slot-1-1-w) !important;
  max-height: var(--slot-1-1-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,2"] {
  width: var(--slot-1-2-w) !important;
  height: var(--slot-1-2-h) !important;
  min-width: var(--slot-1-2-w) !important;
  min-height: var(--slot-1-2-h) !important;
  max-width: var(--slot-1-2-w) !important;
  max-height: var(--slot-1-2-h) !important;
  transform: translate(var(--slot-1-2-x), var(--slot-1-2-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,2"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,2"] .board-card img {
  width: var(--slot-1-2-w) !important;
  height: var(--slot-1-2-h) !important;
  min-width: var(--slot-1-2-w) !important;
  min-height: var(--slot-1-2-h) !important;
  max-width: var(--slot-1-2-w) !important;
  max-height: var(--slot-1-2-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,3"] {
  width: var(--slot-1-3-w) !important;
  height: var(--slot-1-3-h) !important;
  min-width: var(--slot-1-3-w) !important;
  min-height: var(--slot-1-3-h) !important;
  max-width: var(--slot-1-3-w) !important;
  max-height: var(--slot-1-3-h) !important;
  transform: translate(var(--slot-1-3-x), var(--slot-1-3-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,3"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,3"] .board-card img {
  width: var(--slot-1-3-w) !important;
  height: var(--slot-1-3-h) !important;
  min-width: var(--slot-1-3-w) !important;
  min-height: var(--slot-1-3-h) !important;
  max-width: var(--slot-1-3-w) !important;
  max-height: var(--slot-1-3-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,4"] {
  width: var(--slot-1-4-w) !important;
  height: var(--slot-1-4-h) !important;
  min-width: var(--slot-1-4-w) !important;
  min-height: var(--slot-1-4-h) !important;
  max-width: var(--slot-1-4-w) !important;
  max-height: var(--slot-1-4-h) !important;
  transform: translate(var(--slot-1-4-x), var(--slot-1-4-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,4"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,4"] .board-card img {
  width: var(--slot-1-4-w) !important;
  height: var(--slot-1-4-h) !important;
  min-width: var(--slot-1-4-w) !important;
  min-height: var(--slot-1-4-h) !important;
  max-width: var(--slot-1-4-w) !important;
  max-height: var(--slot-1-4-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,5"] {
  width: var(--slot-1-5-w) !important;
  height: var(--slot-1-5-h) !important;
  min-width: var(--slot-1-5-w) !important;
  min-height: var(--slot-1-5-h) !important;
  max-width: var(--slot-1-5-w) !important;
  max-height: var(--slot-1-5-h) !important;
  transform: translate(var(--slot-1-5-x), var(--slot-1-5-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,5"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="1,5"] .board-card img {
  width: var(--slot-1-5-w) !important;
  height: var(--slot-1-5-h) !important;
  min-width: var(--slot-1-5-w) !important;
  min-height: var(--slot-1-5-h) !important;
  max-width: var(--slot-1-5-w) !important;
  max-height: var(--slot-1-5-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,1"] {
  width: var(--slot-2-1-w) !important;
  height: var(--slot-2-1-h) !important;
  min-width: var(--slot-2-1-w) !important;
  min-height: var(--slot-2-1-h) !important;
  max-width: var(--slot-2-1-w) !important;
  max-height: var(--slot-2-1-h) !important;
  transform: translate(var(--slot-2-1-x), var(--slot-2-1-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,1"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,1"] .board-card img {
  width: var(--slot-2-1-w) !important;
  height: var(--slot-2-1-h) !important;
  min-width: var(--slot-2-1-w) !important;
  min-height: var(--slot-2-1-h) !important;
  max-width: var(--slot-2-1-w) !important;
  max-height: var(--slot-2-1-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,2"] {
  width: var(--slot-2-2-w) !important;
  height: var(--slot-2-2-h) !important;
  min-width: var(--slot-2-2-w) !important;
  min-height: var(--slot-2-2-h) !important;
  max-width: var(--slot-2-2-w) !important;
  max-height: var(--slot-2-2-h) !important;
  transform: translate(var(--slot-2-2-x), var(--slot-2-2-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,2"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,2"] .board-card img {
  width: var(--slot-2-2-w) !important;
  height: var(--slot-2-2-h) !important;
  min-width: var(--slot-2-2-w) !important;
  min-height: var(--slot-2-2-h) !important;
  max-width: var(--slot-2-2-w) !important;
  max-height: var(--slot-2-2-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,3"] {
  width: var(--slot-2-3-w) !important;
  height: var(--slot-2-3-h) !important;
  min-width: var(--slot-2-3-w) !important;
  min-height: var(--slot-2-3-h) !important;
  max-width: var(--slot-2-3-w) !important;
  max-height: var(--slot-2-3-h) !important;
  transform: translate(var(--slot-2-3-x), var(--slot-2-3-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,3"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,3"] .board-card img {
  width: var(--slot-2-3-w) !important;
  height: var(--slot-2-3-h) !important;
  min-width: var(--slot-2-3-w) !important;
  min-height: var(--slot-2-3-h) !important;
  max-width: var(--slot-2-3-w) !important;
  max-height: var(--slot-2-3-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,4"] {
  width: var(--slot-2-4-w) !important;
  height: var(--slot-2-4-h) !important;
  min-width: var(--slot-2-4-w) !important;
  min-height: var(--slot-2-4-h) !important;
  max-width: var(--slot-2-4-w) !important;
  max-height: var(--slot-2-4-h) !important;
  transform: translate(var(--slot-2-4-x), var(--slot-2-4-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,4"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,4"] .board-card img {
  width: var(--slot-2-4-w) !important;
  height: var(--slot-2-4-h) !important;
  min-width: var(--slot-2-4-w) !important;
  min-height: var(--slot-2-4-h) !important;
  max-width: var(--slot-2-4-w) !important;
  max-height: var(--slot-2-4-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,5"] {
  width: var(--slot-2-5-w) !important;
  height: var(--slot-2-5-h) !important;
  min-width: var(--slot-2-5-w) !important;
  min-height: var(--slot-2-5-h) !important;
  max-width: var(--slot-2-5-w) !important;
  max-height: var(--slot-2-5-h) !important;
  transform: translate(var(--slot-2-5-x), var(--slot-2-5-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,5"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="2,5"] .board-card img {
  width: var(--slot-2-5-w) !important;
  height: var(--slot-2-5-h) !important;
  min-width: var(--slot-2-5-w) !important;
  min-height: var(--slot-2-5-h) !important;
  max-width: var(--slot-2-5-w) !important;
  max-height: var(--slot-2-5-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,1"] {
  width: var(--slot-3-1-w) !important;
  height: var(--slot-3-1-h) !important;
  min-width: var(--slot-3-1-w) !important;
  min-height: var(--slot-3-1-h) !important;
  max-width: var(--slot-3-1-w) !important;
  max-height: var(--slot-3-1-h) !important;
  transform: translate(var(--slot-3-1-x), var(--slot-3-1-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,1"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,1"] .board-card img {
  width: var(--slot-3-1-w) !important;
  height: var(--slot-3-1-h) !important;
  min-width: var(--slot-3-1-w) !important;
  min-height: var(--slot-3-1-h) !important;
  max-width: var(--slot-3-1-w) !important;
  max-height: var(--slot-3-1-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,2"] {
  width: var(--slot-3-2-w) !important;
  height: var(--slot-3-2-h) !important;
  min-width: var(--slot-3-2-w) !important;
  min-height: var(--slot-3-2-h) !important;
  max-width: var(--slot-3-2-w) !important;
  max-height: var(--slot-3-2-h) !important;
  transform: translate(var(--slot-3-2-x), var(--slot-3-2-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,2"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,2"] .board-card img {
  width: var(--slot-3-2-w) !important;
  height: var(--slot-3-2-h) !important;
  min-width: var(--slot-3-2-w) !important;
  min-height: var(--slot-3-2-h) !important;
  max-width: var(--slot-3-2-w) !important;
  max-height: var(--slot-3-2-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,3"] {
  width: var(--slot-3-3-w) !important;
  height: var(--slot-3-3-h) !important;
  min-width: var(--slot-3-3-w) !important;
  min-height: var(--slot-3-3-h) !important;
  max-width: var(--slot-3-3-w) !important;
  max-height: var(--slot-3-3-h) !important;
  transform: translate(var(--slot-3-3-x), var(--slot-3-3-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,3"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,3"] .board-card img {
  width: var(--slot-3-3-w) !important;
  height: var(--slot-3-3-h) !important;
  min-width: var(--slot-3-3-w) !important;
  min-height: var(--slot-3-3-h) !important;
  max-width: var(--slot-3-3-w) !important;
  max-height: var(--slot-3-3-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,4"] {
  width: var(--slot-3-4-w) !important;
  height: var(--slot-3-4-h) !important;
  min-width: var(--slot-3-4-w) !important;
  min-height: var(--slot-3-4-h) !important;
  max-width: var(--slot-3-4-w) !important;
  max-height: var(--slot-3-4-h) !important;
  transform: translate(var(--slot-3-4-x), var(--slot-3-4-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,4"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,4"] .board-card img {
  width: var(--slot-3-4-w) !important;
  height: var(--slot-3-4-h) !important;
  min-width: var(--slot-3-4-w) !important;
  min-height: var(--slot-3-4-h) !important;
  max-width: var(--slot-3-4-w) !important;
  max-height: var(--slot-3-4-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,5"] {
  width: var(--slot-3-5-w) !important;
  height: var(--slot-3-5-h) !important;
  min-width: var(--slot-3-5-w) !important;
  min-height: var(--slot-3-5-h) !important;
  max-width: var(--slot-3-5-w) !important;
  max-height: var(--slot-3-5-h) !important;
  transform: translate(var(--slot-3-5-x), var(--slot-3-5-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,5"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="3,5"] .board-card img {
  width: var(--slot-3-5-w) !important;
  height: var(--slot-3-5-h) !important;
  min-width: var(--slot-3-5-w) !important;
  min-height: var(--slot-3-5-h) !important;
  max-width: var(--slot-3-5-w) !important;
  max-height: var(--slot-3-5-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,1"] {
  width: var(--slot-4-1-w) !important;
  height: var(--slot-4-1-h) !important;
  min-width: var(--slot-4-1-w) !important;
  min-height: var(--slot-4-1-h) !important;
  max-width: var(--slot-4-1-w) !important;
  max-height: var(--slot-4-1-h) !important;
  transform: translate(var(--slot-4-1-x), var(--slot-4-1-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,1"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,1"] .board-card img {
  width: var(--slot-4-1-w) !important;
  height: var(--slot-4-1-h) !important;
  min-width: var(--slot-4-1-w) !important;
  min-height: var(--slot-4-1-h) !important;
  max-width: var(--slot-4-1-w) !important;
  max-height: var(--slot-4-1-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,2"] {
  width: var(--slot-4-2-w) !important;
  height: var(--slot-4-2-h) !important;
  min-width: var(--slot-4-2-w) !important;
  min-height: var(--slot-4-2-h) !important;
  max-width: var(--slot-4-2-w) !important;
  max-height: var(--slot-4-2-h) !important;
  transform: translate(var(--slot-4-2-x), var(--slot-4-2-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,2"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,2"] .board-card img {
  width: var(--slot-4-2-w) !important;
  height: var(--slot-4-2-h) !important;
  min-width: var(--slot-4-2-w) !important;
  min-height: var(--slot-4-2-h) !important;
  max-width: var(--slot-4-2-w) !important;
  max-height: var(--slot-4-2-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,3"] {
  width: var(--slot-4-3-w) !important;
  height: var(--slot-4-3-h) !important;
  min-width: var(--slot-4-3-w) !important;
  min-height: var(--slot-4-3-h) !important;
  max-width: var(--slot-4-3-w) !important;
  max-height: var(--slot-4-3-h) !important;
  transform: translate(var(--slot-4-3-x), var(--slot-4-3-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,3"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,3"] .board-card img {
  width: var(--slot-4-3-w) !important;
  height: var(--slot-4-3-h) !important;
  min-width: var(--slot-4-3-w) !important;
  min-height: var(--slot-4-3-h) !important;
  max-width: var(--slot-4-3-w) !important;
  max-height: var(--slot-4-3-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,4"] {
  width: var(--slot-4-4-w) !important;
  height: var(--slot-4-4-h) !important;
  min-width: var(--slot-4-4-w) !important;
  min-height: var(--slot-4-4-h) !important;
  max-width: var(--slot-4-4-w) !important;
  max-height: var(--slot-4-4-h) !important;
  transform: translate(var(--slot-4-4-x), var(--slot-4-4-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,4"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,4"] .board-card img {
  width: var(--slot-4-4-w) !important;
  height: var(--slot-4-4-h) !important;
  min-width: var(--slot-4-4-w) !important;
  min-height: var(--slot-4-4-h) !important;
  max-width: var(--slot-4-4-w) !important;
  max-height: var(--slot-4-4-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,5"] {
  width: var(--slot-4-5-w) !important;
  height: var(--slot-4-5-h) !important;
  min-width: var(--slot-4-5-w) !important;
  min-height: var(--slot-4-5-h) !important;
  max-width: var(--slot-4-5-w) !important;
  max-height: var(--slot-4-5-h) !important;
  transform: translate(var(--slot-4-5-x), var(--slot-4-5-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,5"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="4,5"] .board-card img {
  width: var(--slot-4-5-w) !important;
  height: var(--slot-4-5-h) !important;
  min-width: var(--slot-4-5-w) !important;
  min-height: var(--slot-4-5-h) !important;
  max-width: var(--slot-4-5-w) !important;
  max-height: var(--slot-4-5-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,1"] {
  width: var(--slot-5-1-w) !important;
  height: var(--slot-5-1-h) !important;
  min-width: var(--slot-5-1-w) !important;
  min-height: var(--slot-5-1-h) !important;
  max-width: var(--slot-5-1-w) !important;
  max-height: var(--slot-5-1-h) !important;
  transform: translate(var(--slot-5-1-x), var(--slot-5-1-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,1"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,1"] .board-card img {
  width: var(--slot-5-1-w) !important;
  height: var(--slot-5-1-h) !important;
  min-width: var(--slot-5-1-w) !important;
  min-height: var(--slot-5-1-h) !important;
  max-width: var(--slot-5-1-w) !important;
  max-height: var(--slot-5-1-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,2"] {
  width: var(--slot-5-2-w) !important;
  height: var(--slot-5-2-h) !important;
  min-width: var(--slot-5-2-w) !important;
  min-height: var(--slot-5-2-h) !important;
  max-width: var(--slot-5-2-w) !important;
  max-height: var(--slot-5-2-h) !important;
  transform: translate(var(--slot-5-2-x), var(--slot-5-2-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,2"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,2"] .board-card img {
  width: var(--slot-5-2-w) !important;
  height: var(--slot-5-2-h) !important;
  min-width: var(--slot-5-2-w) !important;
  min-height: var(--slot-5-2-h) !important;
  max-width: var(--slot-5-2-w) !important;
  max-height: var(--slot-5-2-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,3"] {
  width: var(--slot-5-3-w) !important;
  height: var(--slot-5-3-h) !important;
  min-width: var(--slot-5-3-w) !important;
  min-height: var(--slot-5-3-h) !important;
  max-width: var(--slot-5-3-w) !important;
  max-height: var(--slot-5-3-h) !important;
  transform: translate(var(--slot-5-3-x), var(--slot-5-3-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,3"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,3"] .board-card img {
  width: var(--slot-5-3-w) !important;
  height: var(--slot-5-3-h) !important;
  min-width: var(--slot-5-3-w) !important;
  min-height: var(--slot-5-3-h) !important;
  max-width: var(--slot-5-3-w) !important;
  max-height: var(--slot-5-3-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,4"] {
  width: var(--slot-5-4-w) !important;
  height: var(--slot-5-4-h) !important;
  min-width: var(--slot-5-4-w) !important;
  min-height: var(--slot-5-4-h) !important;
  max-width: var(--slot-5-4-w) !important;
  max-height: var(--slot-5-4-h) !important;
  transform: translate(var(--slot-5-4-x), var(--slot-5-4-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,4"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,4"] .board-card img {
  width: var(--slot-5-4-w) !important;
  height: var(--slot-5-4-h) !important;
  min-width: var(--slot-5-4-w) !important;
  min-height: var(--slot-5-4-h) !important;
  max-width: var(--slot-5-4-w) !important;
  max-height: var(--slot-5-4-h) !important;
}

.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,5"] {
  width: var(--slot-5-5-w) !important;
  height: var(--slot-5-5-h) !important;
  min-width: var(--slot-5-5-w) !important;
  min-height: var(--slot-5-5-h) !important;
  max-width: var(--slot-5-5-w) !important;
  max-height: var(--slot-5-5-h) !important;
  transform: translate(var(--slot-5-5-x), var(--slot-5-5-y)) !important;
  transform-origin: center center !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,5"] .board-card,
.cardplay-law-layout.vertical .grid-board.vertical .board-cell[data-slot="5,5"] .board-card img {
  width: var(--slot-5-5-w) !important;
  height: var(--slot-5-5-h) !important;
  min-width: var(--slot-5-5-w) !important;
  min-height: var(--slot-5-5-h) !important;
  max-width: var(--slot-5-5-w) !important;
  max-height: var(--slot-5-5-h) !important;
}



/* layout-only patch: move row 1 down 25px, move row 5 up 25px */
.cardplay-law-layout.vertical {
  --slot-1-1-y: 25px !important;
  --slot-1-2-y: 25px !important;
  --slot-1-3-y: 25px !important;
  --slot-1-4-y: 25px !important;
  --slot-1-5-y: 25px !important;

  --slot-5-1-y: -25px !important;
  --slot-5-2-y: -25px !important;
  --slot-5-3-y: -25px !important;
  --slot-5-4-y: -25px !important;
  --slot-5-5-y: -25px !important;
}



/* layout-only patch from Game7.1 baseline:
   move player discard to the player discard zone at the bottom */
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}



/* layout-only patch from Game7.2 baseline:
   explicit pile zone correction so player discard renders in the bottom discard zone
   and opponent deck remains in the top deck zone */
.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2)) !important;
  top: calc(var(--law-bottom-pile-center-y) - (var(--law-pile-height) / 2)) !important;
}



/* layout-only patch from Game7.3 baseline:
   move opponent deck/discard up 30px;
   make player deck/discard 100px x 125px and move them down 30px */
.cardplay-law-layout.vertical .top-deck-slot {
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  width: 100px !important;
  height: 125px !important;
  top: calc(var(--law-bottom-pile-center-y) - 62.5px + 30px) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  width: 100px !important;
  height: 125px !important;
  top: calc(var(--law-bottom-pile-center-y) - 62.5px + 30px) !important;
}



/* layout-only patch from Game7.4 baseline:
   move player deck left 10px;
   move player discard right 5px;
   move player boss down 30px;
   set player boss to 100px x 125px */
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) - 10px) !important;
}
.cardplay-law-layout.vertical .bottom-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2) + 5px) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  width: 100px !important;
  height: 125px !important;
  top: calc(var(--law-bottom-boss-center-y) - 62.5px + 30px) !important;
}



/* layout-only patch from Game7.5 baseline:
   move player boss left 12px;
   move player deck left 3px;
   move opponent boss up 5px;
   move opponent deck up 10px;
   move opponent discard up 10px */
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - 50px - 12px) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) - 10px - 3px) !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px - 5px) !important;
}
.cardplay-law-layout.vertical .top-deck-slot {
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px) !important;
}



/* layout-only patch from Game7.6 baseline:
   move player deck right 1px;
   move player boss right 3px;
   move opponent boss up 1px and left 5px;
   move opponent deck up 3px and right 2px;
   move opponent discard up 3px and left 4px */
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) - 10px - 3px + 1px) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - 50px - 12px + 3px) !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2) - 5px) !important;
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px - 5px - 1px) !important;
}
.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) + 2px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2) - 4px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px) !important;
}



/* layout-only patch from Game7.7 baseline:
   swap opponent deck and opponent discard current positions */
.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2) - 4px) !important;
}
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) + 2px) !important;
}



/* layout-only patch from Game7.8 baseline:
   move opponent discard left 11px and up 3px;
   move opponent boss left 10px and up 1px;
   move opponent deck right 6px and up 3px */
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) + 2px - 11px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px - 3px) !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2) - 5px - 10px) !important;
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px - 5px - 1px - 1px) !important;
}
.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2) - 4px + 6px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px - 3px) !important;
}



/* layout-only patch from Game7.9 baseline:
   move opponent discard up 3px and left 3px;
   move opponent boss up 3px and left 3px;
   move opponent deck up 3px and right 3px;
   move player deck left 1px;
   move player boss right 4px */
.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) + 2px - 11px - 3px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px - 3px - 3px) !important;
}
.cardplay-law-layout.vertical .top-boss-slot {
  left: calc(var(--law-boss-center-x) - (var(--law-boss-width) / 2) - 5px - 10px - 3px) !important;
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px - 5px - 1px - 1px - 3px) !important;
}
.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2) - 4px + 6px + 3px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px - 3px - 3px) !important;
}
.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) - 10px - 3px + 1px - 1px) !important;
}
.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - 50px - 12px + 3px + 4px) !important;
}



/* layout-only patch from Game7.10 baseline:
   move row 1 up 12px;
   move row 5 down 15px;
   move row 2 down 4px;
   move row 4 up 5px */
.cardplay-law-layout.vertical {
  --slot-1-1-y: -12px !important;
  --slot-1-2-y: -12px !important;
  --slot-1-3-y: -12px !important;
  --slot-1-4-y: -12px !important;
  --slot-1-5-y: -12px !important;

  --slot-2-1-y: 4px !important;
  --slot-2-2-y: 4px !important;
  --slot-2-3-y: 4px !important;
  --slot-2-4-y: 4px !important;
  --slot-2-5-y: 4px !important;

  --slot-4-1-y: -5px !important;
  --slot-4-2-y: -5px !important;
  --slot-4-3-y: -5px !important;
  --slot-4-4-y: -5px !important;
  --slot-4-5-y: -5px !important;

  --slot-5-1-y: 15px !important;
  --slot-5-2-y: 15px !important;
  --slot-5-3-y: 15px !important;
  --slot-5-4-y: 15px !important;
  --slot-5-5-y: 15px !important;
}



/* layout-only patch from Game7.11 baseline:
   row/column nudges */
.cardplay-law-layout.vertical {
  /* rows */
  --slot-1-1-y: -2px !important;
  --slot-1-2-y: -2px !important;
  --slot-1-3-y: -2px !important;
  --slot-1-4-y: -2px !important;
  --slot-1-5-y: -2px !important;

  --slot-2-1-y: 6px !important;
  --slot-2-2-y: 6px !important;
  --slot-2-3-y: 6px !important;
  --slot-2-4-y: 6px !important;
  --slot-2-5-y: 6px !important;

  --slot-3-1-y: 1px !important;
  --slot-3-2-y: 1px !important;
  --slot-3-3-y: 1px !important;
  --slot-3-4-y: 1px !important;
  --slot-3-5-y: 1px !important;

  --slot-4-1-y: -3px !important;
  --slot-4-2-y: -3px !important;
  --slot-4-3-y: -3px !important;
  --slot-4-4-y: -3px !important;
  --slot-4-5-y: -3px !important;

  --slot-5-1-y: 5px !important;
  --slot-5-2-y: 5px !important;
  --slot-5-3-y: 5px !important;
  --slot-5-4-y: 5px !important;
  --slot-5-5-y: 5px !important;

  /* columns */
  --slot-1-1-x: 10px !important;
  --slot-2-1-x: 10px !important;
  --slot-3-1-x: 10px !important;
  --slot-4-1-x: 10px !important;
  --slot-5-1-x: 10px !important;

  --slot-1-2-x: 5px !important;
  --slot-2-2-x: 5px !important;
  --slot-3-2-x: 5px !important;
  --slot-4-2-x: 5px !important;
  --slot-5-2-x: 5px !important;

  --slot-1-4-x: -4px !important;
  --slot-2-4-x: -4px !important;
  --slot-3-4-x: -4px !important;
  --slot-4-4-x: -4px !important;
  --slot-5-4-x: -4px !important;

  --slot-1-5-x: -13px !important;
  --slot-2-5-x: -13px !important;
  --slot-3-5-x: -13px !important;
  --slot-4-5-x: -13px !important;
  --slot-5-5-x: -13px !important;
}

/* Game7.13 final guard: keep all 5x5 grid card spacing at zero. */
.cardplay-law-layout.vertical {
  --law-grid-gap: 0px !important;
}
.cardplay-law-layout.vertical .grid-board,
.cardplay-law-layout.vertical .grid-board.vertical {
  gap: 0 !important;
  column-gap: 0 !important;
  row-gap: 0 !important;
}
.cardplay-law-layout.vertical .grid-board.vertical .board-cell {
  padding: 0 !important;
  margin: 0 !important;
}


/* Game7.14 layout-only patch from Game7.13 baseline:
   row 1 down 5px; row 5 up 5px; row 4 down 2px; row 2 up 2px */
.cardplay-law-layout.vertical {
  /* row 1: Game7.13 -2px + 5px = 3px */
  --slot-1-1-y: 3px !important;
  --slot-1-2-y: 3px !important;
  --slot-1-3-y: 3px !important;
  --slot-1-4-y: 3px !important;
  --slot-1-5-y: 3px !important;

  /* row 2: Game7.13 6px - 2px = 4px */
  --slot-2-1-y: 4px !important;
  --slot-2-2-y: 4px !important;
  --slot-2-3-y: 4px !important;
  --slot-2-4-y: 4px !important;
  --slot-2-5-y: 4px !important;

  /* row 4: Game7.13 -3px + 2px = -1px */
  --slot-4-1-y: -1px !important;
  --slot-4-2-y: -1px !important;
  --slot-4-3-y: -1px !important;
  --slot-4-4-y: -1px !important;
  --slot-4-5-y: -1px !important;

  /* row 5: Game7.13 5px - 5px = 0px */
  --slot-5-1-y: 0px !important;
  --slot-5-2-y: 0px !important;
  --slot-5-3-y: 0px !important;
  --slot-5-4-y: 0px !important;
  --slot-5-5-y: 0px !important;
}

/* Game7.15 bug fix from Game7.14 baseline:
   keep the digital hologram/shimmer overlay rotated with horizontal discard cards. */
.cardplay-law-layout.vertical #topDiscardSlot .pile-card.foil,
.cardplay-law-layout.vertical #bottomDiscardSlot .pile-card.foil {
  position: relative !important;
  overflow: visible !important;
}

.cardplay-law-layout.vertical #topDiscardSlot .pile-card.foil::after,
.cardplay-law-layout.vertical #bottomDiscardSlot .pile-card.foil::after {
  transform: rotate(90deg) !important;
  transform-origin: center center !important;
}

/* Game7.16 layout-only patch from Game7.15 baseline:
   row 1 down 2px; row 5 up 2px; row 4 down 2px; row 2 up 1px;
   player boss right 2px; player deck right 1px;
   opponent discard left 1px/up 1px; opponent boss up 3px;
   opponent deck up 1px/right 1px. */
.cardplay-law-layout.vertical {
  /* row 1: Game7.15 3px + 2px = 5px */
  --slot-1-1-y: 5px !important;
  --slot-1-2-y: 5px !important;
  --slot-1-3-y: 5px !important;
  --slot-1-4-y: 5px !important;
  --slot-1-5-y: 5px !important;

  /* row 2: Game7.15 4px - 1px = 3px */
  --slot-2-1-y: 3px !important;
  --slot-2-2-y: 3px !important;
  --slot-2-3-y: 3px !important;
  --slot-2-4-y: 3px !important;
  --slot-2-5-y: 3px !important;

  /* row 4: Game7.15 -1px + 2px = 1px */
  --slot-4-1-y: 1px !important;
  --slot-4-2-y: 1px !important;
  --slot-4-3-y: 1px !important;
  --slot-4-4-y: 1px !important;
  --slot-4-5-y: 1px !important;

  /* row 5: Game7.15 0px - 2px = -2px */
  --slot-5-1-y: -2px !important;
  --slot-5-2-y: -2px !important;
  --slot-5-3-y: -2px !important;
  --slot-5-4-y: -2px !important;
  --slot-5-5-y: -2px !important;
}

.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - 50px - 12px + 3px + 4px + 2px) !important;
}

.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) - 10px - 3px + 1px - 1px + 1px) !important;
}

.cardplay-law-layout.vertical .top-discard-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) + 2px - 11px - 3px - 1px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px - 3px - 3px - 1px) !important;
}

.cardplay-law-layout.vertical .top-boss-slot {
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px - 5px - 1px - 1px - 3px - 3px) !important;
}

.cardplay-law-layout.vertical .top-deck-slot {
  left: calc(var(--law-right-pile-center-x) - (var(--law-pile-width) / 2) - 4px + 6px + 3px + 1px) !important;
  top: calc(var(--law-top-pile-center-y) - (var(--law-pile-height) / 2) - 30px - 10px - 3px - 3px - 3px - 1px) !important;
}


/* Game7.17 layout-only patch from Game7.16 baseline:
   column 1 right 6px; column 2 right 3px; column 4 left 4px; column 5 left 6px;
   player boss right 1px; player deck left 1px. */
.cardplay-law-layout.vertical {
  /* column 1: Game7.16 10px + 6px = 16px */
  --slot-1-1-x: 16px !important;
  --slot-2-1-x: 16px !important;
  --slot-3-1-x: 16px !important;
  --slot-4-1-x: 16px !important;
  --slot-5-1-x: 16px !important;

  /* column 2: Game7.16 5px + 3px = 8px */
  --slot-1-2-x: 8px !important;
  --slot-2-2-x: 8px !important;
  --slot-3-2-x: 8px !important;
  --slot-4-2-x: 8px !important;
  --slot-5-2-x: 8px !important;

  /* column 4: Game7.16 -4px - 4px = -8px */
  --slot-1-4-x: -8px !important;
  --slot-2-4-x: -8px !important;
  --slot-3-4-x: -8px !important;
  --slot-4-4-x: -8px !important;
  --slot-5-4-x: -8px !important;

  /* column 5: Game7.16 -13px - 6px = -19px */
  --slot-1-5-x: -19px !important;
  --slot-2-5-x: -19px !important;
  --slot-3-5-x: -19px !important;
  --slot-4-5-x: -19px !important;
  --slot-5-5-x: -19px !important;
}

.cardplay-law-layout.vertical .bottom-boss-slot {
  left: calc(var(--law-boss-center-x) - 50px - 12px + 3px + 4px + 2px + 1px) !important;
}

.cardplay-law-layout.vertical .bottom-deck-slot {
  left: calc(var(--law-left-pile-center-x) - (var(--law-pile-width) / 2) - 10px - 3px + 1px - 1px + 1px - 1px) !important;
}

/* Game7.18 layout-only patch from Game7.17 baseline:
   stretch board background 2px left and 2px right without moving cards or slots. */
.cardplay-law-layout.vertical .board-backdrop {
  left: -2px !important;
  right: -2px !important;
  width: auto !important;
}

/* Game7.19 layout-only patch from Game7.18 baseline:
   column 1 right 2px; column 2 right 1px; column 4 left 1px; column 5 left 2px;
   row 1 down 1px; row 5 up 1px. */
.cardplay-law-layout.vertical {
  /* row 1: Game7.18 5px + 1px = 6px */
  --slot-1-1-y: 6px !important;
  --slot-1-2-y: 6px !important;
  --slot-1-3-y: 6px !important;
  --slot-1-4-y: 6px !important;
  --slot-1-5-y: 6px !important;

  /* row 5: Game7.18 -2px - 1px = -3px */
  --slot-5-1-y: -3px !important;
  --slot-5-2-y: -3px !important;
  --slot-5-3-y: -3px !important;
  --slot-5-4-y: -3px !important;
  --slot-5-5-y: -3px !important;

  /* column 1: Game7.18 16px + 2px = 18px */
  --slot-1-1-x: 18px !important;
  --slot-2-1-x: 18px !important;
  --slot-3-1-x: 18px !important;
  --slot-4-1-x: 18px !important;
  --slot-5-1-x: 18px !important;

  /* column 2: Game7.18 8px + 1px = 9px */
  --slot-1-2-x: 9px !important;
  --slot-2-2-x: 9px !important;
  --slot-3-2-x: 9px !important;
  --slot-4-2-x: 9px !important;
  --slot-5-2-x: 9px !important;

  /* column 4: Game7.18 -8px - 1px = -9px */
  --slot-1-4-x: -9px !important;
  --slot-2-4-x: -9px !important;
  --slot-3-4-x: -9px !important;
  --slot-4-4-x: -9px !important;
  --slot-5-4-x: -9px !important;

  /* column 5: Game7.18 -19px - 2px = -21px */
  --slot-1-5-x: -21px !important;
  --slot-2-5-x: -21px !important;
  --slot-3-5-x: -21px !important;
  --slot-4-5-x: -21px !important;
  --slot-5-5-x: -21px !important;
}

/* Game7.20 layout-only patch from Game7.19 baseline:
   column 1 right 2px; column 2 right 1px; column 4 left 1px; column 5 left 2px;
   player boss down 1px; opponent boss up 1px. */
.cardplay-law-layout.vertical {
  /* column 1: Game7.19 18px + 2px = 20px */
  --slot-1-1-x: 20px !important;
  --slot-2-1-x: 20px !important;
  --slot-3-1-x: 20px !important;
  --slot-4-1-x: 20px !important;
  --slot-5-1-x: 20px !important;

  /* column 2: Game7.19 9px + 1px = 10px */
  --slot-1-2-x: 10px !important;
  --slot-2-2-x: 10px !important;
  --slot-3-2-x: 10px !important;
  --slot-4-2-x: 10px !important;
  --slot-5-2-x: 10px !important;

  /* column 4: Game7.19 -9px - 1px = -10px */
  --slot-1-4-x: -10px !important;
  --slot-2-4-x: -10px !important;
  --slot-3-4-x: -10px !important;
  --slot-4-4-x: -10px !important;
  --slot-5-4-x: -10px !important;

  /* column 5: Game7.19 -21px - 2px = -23px */
  --slot-1-5-x: -23px !important;
  --slot-2-5-x: -23px !important;
  --slot-3-5-x: -23px !important;
  --slot-4-5-x: -23px !important;
  --slot-5-5-x: -23px !important;
}

.cardplay-law-layout.vertical .bottom-boss-slot {
  top: calc(var(--law-bottom-boss-center-y) - 62.5px + 30px + 1px) !important;
}

.cardplay-law-layout.vertical .top-boss-slot {
  top: calc(var(--law-top-boss-center-y) - (var(--law-boss-height) / 2) - 24px - 5px - 1px - 1px - 3px - 3px - 1px) !important;
}


/* Game7.22 floating gameplay magnifier lens cursor-lock fix */
.match-magnifier-lens {
  position: fixed;
  width: clamp(190px, 15vw, 260px);
  height: clamp(190px, 15vw, 260px);
  z-index: 190;
  border-radius: 50%;
  overflow: hidden;
  pointer-events: none;
  background: rgba(8, 7, 15, 0.96);
  border: 3px solid rgba(255, 242, 163, 0.95);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.72), 0 0 0 1px rgba(255, 255, 255, 0.24) inset, 0 0 28px rgba(255, 221, 95, 0.28);
  contain: strict;
  transform: translate(-50%, -50%);
  will-change: left, top;
}

.match-magnifier-lens.hidden { display: none !important; }
.match-magnifier-lens::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  box-shadow: inset 0 0 26px rgba(255,255,255,0.18), inset 0 0 65px rgba(0,0,0,0.42);
  pointer-events: none;
}
.match-magnifier-content {
  position: absolute;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  transform-origin: 0 0;
  will-change: transform;
}
.match-magnifier-clone {
  position: absolute !important;
  pointer-events: none !important;
  user-select: none !important;
  max-width: none !important;
  margin: 0 !important;
  transform: none !important;
}
.match-magnifier-clone * {
  pointer-events: none !important;
}


/* Game7.22: cloned lens content uses IDs stripped for safety, so preserve the
   same class-based visible orientation for deck/discard piles inside the lens. */
.match-magnifier-clone .top-deck-slot .pile-back img,
.match-magnifier-clone .bottom-deck-slot .pile-back img,
.match-magnifier-clone .top-discard-slot .pile-card img,
.match-magnifier-clone .bottom-discard-slot .pile-card img {
  transform: rotate(90deg) !important;
  transform-origin: center center !important;
}
.match-magnifier-clone .top-discard-slot .pile-card.foil::after,
.match-magnifier-clone .bottom-discard-slot .pile-card.foil::after {
  transform: rotate(90deg) !important;
  transform-origin: center center !important;
}


/* Game7.25: stabilize the floating lens at the top/bottom gameplay edges. */
.match-magnifier-lens,
.match-magnifier-lens * {
  pointer-events: none !important;
}
.match-screen {
  overscroll-behavior: contain;
}

/* Game7.28 audio controls and battle-number orientation fixes */
.audio-top-actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}
.audio-slider-label {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.55rem;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  background: rgba(0,0,0,0.22);
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1;
  white-space: nowrap;
}
.audio-slider-label input[type="range"] {
  width: 92px;
  accent-color: var(--accent);
}
.audio-slider-label span {
  min-width: 3.2em;
  text-align: right;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.board-cell .board-card.opponent-facing .battle-burst {
  transform: translate(-50%, -50%) rotate(180deg) !important;
}


/* Game7.29 interaction/audio/AI animation fixes */
.audio-slider-label,
#toggleMusicBtn,
#musicVolumeSlider,
#sfxVolumeSlider,
#musicVolumeValue,
#sfxVolumeValue {
  display: none !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle {
  cursor: grab !important;
  touch-action: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-user-drag: none !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:active {
  cursor: grabbing !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle img {
  pointer-events: auto !important;
  -webkit-user-drag: none !important;
  user-select: none !important;
}
.board-card.opponent-facing .battle-burst,
.board-cell .board-card.opponent-facing .battle-burst,
.board-card .battle-burst {
  transform: translate(-50%, -50%) !important;
}

/* Game7.30: make player hand cards fully clickable/draggable again. */
.cardplay-law-layout.vertical #playerHand.clean-hand {
  pointer-events: auto !important;
  position: relative !important;
  z-index: 30 !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle,
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle img {
  display: block !important;
  pointer-events: auto !important;
  cursor: grab !important;
  touch-action: none !important;
  -webkit-user-drag: none !important;
  user-select: none !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle {
  z-index: 31 !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:hover {
  z-index: 40 !important;
}

/* Game7.31: player hand alignment + full-card hit target repair.
   Keep the visible card image and the clickable/draggable box locked together. */
.cardplay-law-layout.vertical .player-hand-slot {
  display: flex !important;
  justify-content: center !important;
  align-items: flex-end !important;
  overflow: visible !important;
  padding-left: 0.55rem !important;
  padding-right: 0.55rem !important;
}
.cardplay-law-layout.vertical #playerHand.clean-hand {
  --player-hand-card-w: min(112px, calc((100% - 0.55rem) / 2));
  display: grid !important;
  grid-template-columns: repeat(2, var(--player-hand-card-w)) !important;
  grid-auto-rows: calc(var(--player-hand-card-w) * 1.4) !important;
  gap: 0.55rem !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  height: auto !important;
  margin: 0 auto !important;
  justify-content: center !important;
  justify-items: center !important;
  align-content: end !important;
  align-items: center !important;
  overflow: visible !important;
  position: relative !important;
  z-index: 80 !important;
  pointer-events: auto !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle,
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:hover,
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:active,
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle.selected {
  width: var(--player-hand-card-w) !important;
  height: calc(var(--player-hand-card-w) * 1.4) !important;
  min-width: var(--player-hand-card-w) !important;
  min-height: calc(var(--player-hand-card-w) * 1.4) !important;
  max-width: var(--player-hand-card-w) !important;
  max-height: calc(var(--player-hand-card-w) * 1.4) !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  position: relative !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  transform: none !important;
  cursor: grab !important;
  pointer-events: auto !important;
  touch-action: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-user-drag: none !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:active {
  cursor: grabbing !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  object-fit: contain !important;
  border-radius: 6px !important;
  pointer-events: auto !important;
  touch-action: none !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}
.cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle.foil::after {
  inset: 0 !important;
  border-radius: 6px !important;
  pointer-events: none !important;
}

/* Game7.32: final player-hand centering guard.
   This keeps the right-side hand cards centered in their black panel and keeps
   the visible image locked to the click/drag rectangle. */
#matchScreen .cardplay-law-layout.vertical .player-hand-slot {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  overflow: visible !important;
}
#matchScreen .cardplay-law-layout.vertical #playerHand.clean-hand {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  margin: 0 auto !important;
  padding: 0 !important;
  transform: none !important;
  justify-content: center !important;
  justify-items: center !important;
  align-content: center !important;
  align-items: center !important;
  overflow: visible !important;
}
#matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card,
#matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  box-sizing: border-box !important;
  transform: none !important;
}

/* Game7.33: make the player's card zone fill the available right-side space
   and keep the hand centered inside that taller zone. */
#matchScreen .cardplay-law-layout.vertical .player-side-table {
  display: flex !important;
  flex-direction: column !important;
  justify-content: stretch !important;
  align-items: stretch !important;
  height: var(--law-board-height) !important;
  min-height: var(--law-board-height) !important;
  box-sizing: border-box !important;
}
#matchScreen .cardplay-law-layout.vertical .player-side-table .player-info-box,
#matchScreen .cardplay-law-layout.vertical .player-side-table .side-action-strip {
  flex: 0 0 auto !important;
}
#matchScreen .cardplay-law-layout.vertical .player-hand-slot {
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: calc(var(--side-hand-card-height) * 3 + 2.2rem) !important;
  width: 100% !important;
  margin: 0.65rem 0 0 0 !important;
  padding: 0.75rem !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  align-content: center !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}
#matchScreen .cardplay-law-layout.vertical #playerHand.clean-hand {
  align-self: center !important;
  justify-self: center !important;
  margin: auto !important;
  place-content: center !important;
  place-items: center !important;
  overflow: visible !important;
}
#matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card,
#matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card img {
  transform: none !important;
}

/* Game7.34 outcome labels and combat readability */
.match-result-badge {
  display: inline-block;
  margin-left: 0.35rem;
  padding: 0.05rem 0.38rem;
  border-radius: 999px;
  font-size: 0.74rem;
  line-height: 1.2;
  vertical-align: middle;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.match-result-badge.win {
  color: #b7ffbf;
  background: rgba(20, 118, 44, 0.28);
  border: 1px solid rgba(91, 255, 127, 0.72);
}
.match-result-badge.lose {
  color: #ffc2c2;
  background: rgba(146, 26, 32, 0.28);
  border: 1px solid rgba(255, 136, 136, 0.72);
}
.winner-name-badge {
  display: inline-block;
  margin-left: 0.45rem;
  color: #90ff9e !important;
  font-weight: 1000 !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-shadow: 0 0 10px rgba(57, 255, 89, 0.36);
}
.board-card.opponent-facing .battle-burst,
.battle-burst {
  transform: translate(-50%, -50%) rotate(0deg) !important;
}

/* Game7.35 defeat/removal and preview interaction fixes */
.card-fly.flip-out-horizontal {
  transform-style: preserve-3d;
  backface-visibility: visible;
  transition-property: transform, left, top, opacity, width !important;
  transition-timing-function: cubic-bezier(.19,.78,.24,1), ease, ease, ease, ease !important;
}
.zoom-modal {
  pointer-events: auto !important;
  cursor: zoom-out !important;
}
.zoom-card-wrap,
.zoom-card-wrap img {
  pointer-events: none !important;
}

/* Game7.36 music, draw/discard timing, preview toggle, and opponent damage readability fixes */
#toggleMusicBtn {
  display: inline-flex !important;
}
.card-draw-reveal-fly {
  transform-style: preserve-3d !important;
  backface-visibility: visible !important;
  transition-property: transform, left, top, width, opacity !important;
  transition-timing-function: cubic-bezier(.2,.8,.22,1), ease, ease, ease, ease !important;
}
.board-card.opponent-facing .battle-burst,
.board-cell .board-card.opponent-facing .battle-burst {
  transform: translate(-50%, -50%) rotate(180deg) !important;
}
.board-card:not(.opponent-facing) .battle-burst {
  transform: translate(-50%, -50%) rotate(0deg) !important;
}
.zoom-modal:not(.hidden) {
  pointer-events: auto !important;
  cursor: zoom-out !important;
}


/* Game7.37 collection page preview/list toggle */
.collection-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
.collection-header-row h2 { margin: 0; }
.collection-list {
  display: grid;
  gap: 0.45rem;
}
.collection-list-row {
  width: 100%;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0.65rem;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.045);
  color: var(--text);
  text-align: left;
  cursor: zoom-in;
}
.collection-list-row:hover {
  background: rgba(154,107,255,0.16);
}
.collection-list-row img {
  width: 44px;
  aspect-ratio: 0.724;
  object-fit: contain;
  border-radius: 4px;
  display: block;
}
.collection-list-main {
  min-width: 0;
  display: grid;
  gap: 0.15rem;
}
.collection-list-main strong,
.collection-list-main .small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.collection-list-meta {
  color: var(--accent-2);
  font-size: 0.9rem;
  white-space: nowrap;
}


/* Game7.39: audio controls live in Settings; Deck Builder panel only displays when Deck Builder tab is active. */
.settings-audio-controls {
  margin: 0.25rem 0 1rem;
  padding: 0.85rem;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
}
.settings-audio-controls h3 {
  margin: 0 0 0.6rem;
}
.settings-audio-buttons {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
}
#tab-settings #toggleMusicBtn,
#tab-settings #toggleSfxBtn {
  display: inline-flex !important;
}

/* Game7.40: Settings audio volume controls. */
.settings-volume-row {
  margin-top: 0.75rem;
  display: grid;
  grid-template-columns: minmax(150px, 1fr) minmax(180px, 2fr);
  gap: 0.75rem;
  align-items: center;
}
.settings-volume-row label {
  font-weight: 700;
  color: var(--text);
}
.settings-volume-row span {
  color: var(--gold);
}
.settings-volume-row input[type="range"] {
  width: 100%;
  accent-color: var(--purple);
}
@media (max-width: 680px) {
  .settings-volume-row {
    grid-template-columns: 1fr;
  }
}


/* Game7.41: unhide Settings volume sliders that older audio-removal CSS hid by ID. */
#tab-settings .settings-volume-row,
#tab-settings .settings-volume-row label {
  display: grid !important;
}
#tab-settings #musicVolumeSlider,
#tab-settings #sfxVolumeSlider {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100% !important;
  min-width: 180px !important;
  height: auto !important;
}
#tab-settings #musicVolumeValue,
#tab-settings #sfxVolumeValue {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Game7.43: deck testing / simulation deck visual cues */
.deck-slot-pill.simulation-deck-slot {
  border: 1px solid rgba(191, 230, 200, 0.45);
}
.card-tile.simulation-unowned-card {
  outline: 1px dashed rgba(255, 255, 255, 0.22);
}
.card-tile.simulation-unowned-card .card-qty::after {
  content: " owned";
  font-size: 0.68rem;
  opacity: 0.72;
}
#deckNameInput:disabled {
  opacity: 0.75;
  cursor: default;
}
.card-tile.deck-unowned-card {
  opacity: 0.58;
}
.card-tile.deck-unowned-card .deck-line-controls .primary {
  filter: grayscale(0.65);
}


.admin-update-card {
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 16px;
  padding: 16px;
  margin: 10px 0 18px;
  background: rgba(0, 0, 0, 0.20);
}

.admin-update-row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin: 10px 0;
}

.admin-update-row input[type="file"] {
  max-width: 100%;
}

/* Game7.47 layout-only patch from Game7.46 baseline:
   column 1 right 2px; column 2 right 1px; column 4 left 1px; column 5 left 2px. */
.cardplay-law-layout.vertical {
  /* column 1: Game7.46 20px + 2px = 22px */
  --slot-1-1-x: 22px !important;
  --slot-2-1-x: 22px !important;
  --slot-3-1-x: 22px !important;
  --slot-4-1-x: 22px !important;
  --slot-5-1-x: 22px !important;

  /* column 2: Game7.46 10px + 1px = 11px */
  --slot-1-2-x: 11px !important;
  --slot-2-2-x: 11px !important;
  --slot-3-2-x: 11px !important;
  --slot-4-2-x: 11px !important;
  --slot-5-2-x: 11px !important;

  /* column 4: Game7.46 -10px - 1px = -11px */
  --slot-1-4-x: -11px !important;
  --slot-2-4-x: -11px !important;
  --slot-3-4-x: -11px !important;
  --slot-4-4-x: -11px !important;
  --slot-5-4-x: -11px !important;

  /* column 5: Game7.46 -23px - 2px = -25px */
  --slot-1-5-x: -25px !important;
  --slot-2-5-x: -25px !important;
  --slot-3-5-x: -25px !important;
  --slot-4-5-x: -25px !important;
  --slot-5-5-x: -25px !important;
}

/* Game7.48 layout-only patch from Game7.47 baseline:
   column 1 right 2px; column 2 right 1px; column 4 left 1px; column 5 left 2px. */
.cardplay-law-layout.vertical {
  /* column 1: Game7.47 22px + 2px = 24px */
  --slot-1-1-x: 24px !important;
  --slot-2-1-x: 24px !important;
  --slot-3-1-x: 24px !important;
  --slot-4-1-x: 24px !important;
  --slot-5-1-x: 24px !important;

  /* column 2: Game7.47 11px + 1px = 12px */
  --slot-1-2-x: 12px !important;
  --slot-2-2-x: 12px !important;
  --slot-3-2-x: 12px !important;
  --slot-4-2-x: 12px !important;
  --slot-5-2-x: 12px !important;

  /* column 4: Game7.47 -11px - 1px = -12px */
  --slot-1-4-x: -12px !important;
  --slot-2-4-x: -12px !important;
  --slot-3-4-x: -12px !important;
  --slot-4-4-x: -12px !important;
  --slot-5-4-x: -12px !important;

  /* column 5: Game7.47 -25px - 2px = -27px */
  --slot-1-5-x: -27px !important;
  --slot-2-5-x: -27px !important;
  --slot-3-5-x: -27px !important;
  --slot-4-5-x: -27px !important;
  --slot-5-5-x: -27px !important;
}


/* Game7.49 layout-only patch from Game7.48 baseline:
   column 1 right 3px. */
.cardplay-law-layout.vertical {
  /* column 1: Game7.48 24px + 3px = 27px */
  --slot-1-1-x: 27px !important;
  --slot-2-1-x: 27px !important;
  --slot-3-1-x: 27px !important;
  --slot-4-1-x: 27px !important;
  --slot-5-1-x: 27px !important;
}

/* Game7.50 admin user stats and compact two-column collection list view. */
.collection-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}
.collection-list-row-two-line {
  grid-template-columns: 44px minmax(0, 1fr);
}
.collection-list-two-line-main {
  gap: 0.25rem;
}
.collection-list-line {
  min-width: 0;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
}
.collection-list-line strong,
.collection-list-line .small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.collection-list-line-bottom {
  color: var(--muted);
}
@media (max-width: 900px) {
  .collection-list {
    grid-template-columns: 1fr;
  }
}

.admin-stats-card {
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 0.85rem;
  margin-bottom: 1rem;
  background: rgba(255,255,255,0.04);
}
.admin-stats-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}
.admin-stats-header h3 {
  margin: 0;
}
.admin-period-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  color: var(--muted);
  font-weight: 700;
}
.admin-period-label select {
  min-width: 150px;
}
.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
}
.admin-stat-pill {
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 0.65rem;
  background: rgba(0,0,0,0.20);
  display: grid;
  gap: 0.25rem;
}
.admin-stat-pill span {
  color: var(--muted);
  font-size: 0.82rem;
}
.admin-stat-pill strong {
  color: var(--gold);
  font-size: 1.3rem;
}
.admin-users-list {
  gap: 0.75rem;
}
.admin-user-row-expanded {
  grid-template-columns: minmax(180px, 1.2fr) minmax(260px, 2fr) auto;
}
.admin-user-main,
.admin-user-details,
.admin-user-actions {
  min-width: 0;
}
.admin-user-actions {
  display: flex;
  justify-content: flex-end;
}
@media (max-width: 1100px) {
  .admin-user-row-expanded {
    grid-template-columns: 1fr;
  }
  .admin-user-actions {
    justify-content: flex-start;
  }
}
@media (max-width: 760px) {
  .admin-stats-grid {
    grid-template-columns: 1fr;
  }
  .admin-period-label {
    align-items: stretch;
    flex-direction: column;
    width: 100%;
  }
}

/* Game7.51 admin grant-all booster control. */
.admin-grant-all-card {
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 16px;
  padding: 0.85rem;
  margin: 0.35rem 0 1rem;
  background: rgba(255,255,255,0.04);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.admin-grant-all-card h3 {
  margin: 0 0 0.25rem;
}
.admin-grant-all-card p {
  margin: 0;
}
@media (max-width: 760px) {
  .admin-grant-all-card {
    align-items: stretch;
    flex-direction: column;
  }
}


/* Game7.54: password change controls in Settings. */
.settings-password-controls {
  margin: 0.25rem 0 1rem;
  padding: 0.85rem;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
}
.settings-password-controls h3 {
  margin: 0 0 0.6rem;
}
.settings-password-controls label {
  margin-top: 0.55rem;
}
.settings-password-controls button {
  margin-top: 0.75rem;
}

.deck-management-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}

button.danger {
  border-color: rgba(255, 104, 104, 0.65);
  color: #ffd6d6;
}

/* Game7.58 opening dice throw animation and upgraded defeat explosion. */
.d10-throw-die {
  position: fixed;
  width: 54px;
  height: 54px;
  margin-left: -27px;
  margin-top: -27px;
  z-index: 100000;
  pointer-events: none;
  display: grid;
  place-items: center;
  font-weight: 1000;
  font-size: 1.35rem;
  line-height: 1;
  color: #111018;
  text-shadow: 0 1px 0 rgba(255,255,255,0.6);
  background:
    radial-gradient(circle at 34% 26%, rgba(255,255,255,0.92), rgba(255,255,255,0.18) 24%, transparent 26%),
    linear-gradient(135deg, #fff3a4 0%, #d8a833 46%, #8e5f13 100%);
  border: 2px solid rgba(255, 245, 165, 0.96);
  clip-path: polygon(50% 0%, 86% 11%, 100% 50%, 86% 89%, 50% 100%, 14% 89%, 0% 50%, 14% 11%);
  box-shadow:
    0 16px 24px rgba(0,0,0,0.5),
    inset 0 2px 8px rgba(255,255,255,0.45),
    inset 0 -6px 12px rgba(82,39,0,0.38),
    0 0 22px rgba(255,221,86,0.24);
  transform: translate(0, 0) rotate(0deg) scale(0.88);
  opacity: 0.98;
  transition: transform var(--dur, 1700ms) cubic-bezier(.18,.78,.24,1.02), opacity 240ms ease, filter 240ms ease;
  will-change: transform, opacity;
}
.d10-throw-die.opponent-die {
  background:
    radial-gradient(circle at 34% 26%, rgba(255,255,255,0.92), rgba(255,255,255,0.14) 24%, transparent 26%),
    linear-gradient(135deg, #d7c7ff 0%, #8d72e4 48%, #3a286f 100%);
  color: #fff9b3;
  border-color: rgba(210,190,255,0.96);
}
.d10-throw-die.rolling-across-board {
  transform: translate(var(--dx), var(--dy)) rotate(var(--rot)) scale(1.12);
}
.d10-throw-die.landed {
  filter: brightness(1.18) drop-shadow(0 0 16px rgba(255, 225, 84, 0.35));
  animation: diceLandBounce 360ms ease-out both;
}
.d10-throw-die.fade-out {
  opacity: 0;
}
@keyframes diceLandBounce {
  0% { transform: translate(var(--dx), var(--dy)) rotate(var(--rot)) scale(1.16); }
  38% { transform: translate(var(--dx), calc(var(--dy) - 12px)) rotate(var(--rot)) scale(1.26); }
  100% { transform: translate(var(--dx), var(--dy)) rotate(var(--rot)) scale(1.08); }
}

.explode-fx {
  width: 92% !important;
  background:
    radial-gradient(circle, rgba(255,255,225,1) 0%, rgba(255,224,83,1) 14%, rgba(255,128,16,0.98) 31%, rgba(233,38,24,0.76) 52%, rgba(103,12,9,0.34) 72%, transparent 78%) !important;
  box-shadow: 0 0 26px rgba(255,187,67,0.82), 0 0 54px rgba(255,55,31,0.42) !important;
  animation: explodePulseBig 560ms ease-out forwards !important;
}
.explode-fx::before,
.explode-fx::after {
  content: '';
  position: absolute;
  inset: 10%;
  border-radius: 50%;
  pointer-events: none;
}
.explode-fx::before {
  border: 3px solid rgba(255,238,122,0.86);
  animation: explodeRing 560ms ease-out forwards;
}
.explode-fx::after {
  background: conic-gradient(from 15deg, transparent 0 8%, rgba(255,238,120,0.95) 9% 12%, transparent 13% 22%, rgba(255,110,22,0.9) 23% 26%, transparent 27% 38%, rgba(255,238,120,0.95) 39% 42%, transparent 43% 58%, rgba(255,110,22,0.9) 59% 62%, transparent 63% 76%, rgba(255,238,120,0.95) 77% 80%, transparent 81% 100%);
  animation: explodeSparks 560ms ease-out forwards;
}
@keyframes explodePulseBig {
  from { opacity: 0; transform: translate(-50%, -50%) scale(0.22); }
  22% { opacity: 1; transform: translate(-50%, -50%) scale(0.82); }
  to { opacity: 0; transform: translate(-50%, -50%) scale(1.65); }
}
@keyframes explodeRing {
  from { opacity: 0.95; transform: scale(0.42); }
  to { opacity: 0; transform: scale(2.05); }
}
@keyframes explodeSparks {
  from { opacity: 1; transform: scale(0.6) rotate(0deg); }
  to { opacity: 0; transform: scale(2.4) rotate(34deg); }
}

/* Game7.59: real physical opening dice, front-only promo shimmer, stronger explosion. */
.opening-dice-layer {
  position: fixed;
  inset: 0;
  z-index: 250000 !important;
  pointer-events: none;
  perspective: 900px;
}
.d10-throw-die.physical-d10 {
  position: fixed;
  width: 76px !important;
  height: 76px !important;
  margin-left: -38px !important;
  margin-top: -38px !important;
  display: grid;
  place-items: center;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  clip-path: none !important;
  color: #111018;
  transform-style: preserve-3d;
  transform: translate(0,0) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(0.92);
  transition: transform var(--dur, 1950ms) cubic-bezier(.12,.76,.12,1.0), opacity 260ms ease, filter 220ms ease;
  will-change: transform, opacity;
  opacity: 1;
}
.d10-throw-die.physical-d10 .d10-body {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  clip-path: polygon(50% 0%, 82% 11%, 100% 50%, 82% 89%, 50% 100%, 18% 89%, 0% 50%, 18% 11%);
  background:
    linear-gradient(150deg, rgba(255,255,255,0.92) 0 12%, transparent 13% 100%),
    conic-gradient(from 20deg,
      #fff6b9 0 10%, #d7a22e 10% 22%, #fff0a2 22% 32%, #9b5f08 32% 46%,
      #ffe07a 46% 59%, #b97812 59% 72%, #fff8c8 72% 84%, #8a550d 84% 100%);
  border: 3px solid rgba(255,245,170,0.98);
  box-shadow:
    0 18px 28px rgba(0,0,0,0.62),
    inset 0 4px 12px rgba(255,255,255,0.55),
    inset 0 -10px 16px rgba(78,37,0,0.48),
    0 0 26px rgba(255,221,80,0.34);
}
.d10-throw-die.physical-d10.opponent-die .d10-body {
  background:
    linear-gradient(150deg, rgba(255,255,255,0.80) 0 12%, transparent 13% 100%),
    conic-gradient(from 20deg,
      #e4d8ff 0 10%, #8e71e9 10% 22%, #cab8ff 22% 32%, #3d286f 32% 46%,
      #a891ff 46% 59%, #5a3aa0 59% 72%, #eee7ff 72% 84%, #26194e 84% 100%);
  border-color: rgba(214,197,255,0.98);
}
.d10-throw-die.physical-d10 .d10-facet {
  position: absolute;
  inset: 9%;
  border: 1px solid rgba(255,255,255,0.23);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  opacity: 0.55;
}
.d10-throw-die.physical-d10 .f1 { transform: rotate(18deg) scale(0.92); }
.d10-throw-die.physical-d10 .f2 { transform: rotate(78deg) scale(0.76); opacity: 0.38; }
.d10-throw-die.physical-d10 .f3 { transform: rotate(138deg) scale(0.62); opacity: 0.30; }
.d10-throw-die.physical-d10 .d10-value {
  position: relative;
  z-index: 2;
  min-width: 42px;
  text-align: center;
  font-weight: 1000;
  font-size: 1.95rem;
  color: #171018;
  text-shadow: 0 2px 1px rgba(255,255,255,0.58), 0 -1px 0 rgba(0,0,0,0.18);
}
.d10-throw-die.physical-d10.opponent-die .d10-value {
  color: #fff6b4;
  text-shadow: 0 2px 2px rgba(0,0,0,0.55);
}
.d10-throw-die.physical-d10.rolling-across-board {
  transform: translate(var(--dx), var(--dy)) rotateX(760deg) rotateY(-620deg) rotateZ(var(--rot)) scale(1.18) !important;
}
.d10-throw-die.physical-d10.rolling-across-board .d10-body {
  animation: d10PhysicalTumble 280ms linear infinite;
}
.d10-throw-die.physical-d10.landed {
  filter: brightness(1.2) drop-shadow(0 0 18px rgba(255,225,84,0.45));
  animation: diceLandBouncePhysical 420ms ease-out both;
}
.d10-throw-die.physical-d10.landed .d10-body {
  animation: none;
}
.d10-throw-die.physical-d10.fade-out {
  opacity: 0;
}
@keyframes d10PhysicalTumble {
  from { filter: brightness(0.96); }
  50% { filter: brightness(1.22); }
  to { filter: brightness(0.96); }
}
@keyframes diceLandBouncePhysical {
  0% { transform: translate(var(--dx), var(--dy)) rotateX(760deg) rotateY(-620deg) rotateZ(var(--rot)) scale(1.18); }
  42% { transform: translate(var(--dx), calc(var(--dy) - 16px)) rotateX(720deg) rotateY(-540deg) rotateZ(var(--rot)) scale(1.28); }
  100% { transform: translate(var(--dx), var(--dy)) rotateX(720deg) rotateY(-540deg) rotateZ(var(--rot)) scale(1.12); }
}

/* Do not shimmer face-down backs even when the hidden card is a promo. */
.board-card:not(:has(img[data-zoom])).foil::after,
.pile-card:not(:has(img[data-zoom])).foil::after {
  display: none !important;
  content: none !important;
}

/* Make promo shimmer visible in collection preview and list views. */
#tab-collection .card-tile.foil::after {
  border-radius: 10px;
  inset: 0;
  z-index: 2;
}
#tab-collection .collection-list-row.foil {
  position: relative;
  overflow: hidden;
}
#tab-collection .collection-list-row.foil::after {
  border-radius: inherit;
  z-index: 0;
}
#tab-collection .collection-list-row.foil > * {
  position: relative;
  z-index: 1;
}

.exploding-cell {
  animation: boardCellExplosionShake 420ms linear both;
}
.explode-fx.upgraded-explosion-fx {
  width: 128% !important;
  z-index: 120 !important;
  background:
    radial-gradient(circle, rgba(255,255,255,1) 0%, rgba(255,252,165,1) 12%, rgba(255,165,29,1) 28%, rgba(244,46,24,0.95) 48%, rgba(120,10,4,0.55) 67%, transparent 76%) !important;
  box-shadow: 0 0 38px rgba(255,226,87,0.95), 0 0 88px rgba(255,66,22,0.62), 0 0 128px rgba(255,10,0,0.34) !important;
  animation: explodePulseHuge 680ms ease-out forwards !important;
}
.explosion-spark {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 7px;
  height: 24px;
  border-radius: 999px;
  background: linear-gradient(to bottom, rgba(255,255,200,1), rgba(255,123,12,0.95), transparent);
  transform-origin: center bottom;
  opacity: 0;
  animation: explosionSparkFly 680ms ease-out forwards;
}
.explosion-spark.s0 { --a: 0deg; --d: 70px; } .explosion-spark.s1 { --a: 20deg; --d: 82px; }
.explosion-spark.s2 { --a: 40deg; --d: 64px; } .explosion-spark.s3 { --a: 60deg; --d: 88px; }
.explosion-spark.s4 { --a: 80deg; --d: 73px; } .explosion-spark.s5 { --a: 100deg; --d: 91px; }
.explosion-spark.s6 { --a: 120deg; --d: 68px; } .explosion-spark.s7 { --a: 140deg; --d: 86px; }
.explosion-spark.s8 { --a: 160deg; --d: 76px; } .explosion-spark.s9 { --a: 180deg; --d: 92px; }
.explosion-spark.s10 { --a: 200deg; --d: 66px; } .explosion-spark.s11 { --a: 220deg; --d: 85px; }
.explosion-spark.s12 { --a: 240deg; --d: 72px; } .explosion-spark.s13 { --a: 260deg; --d: 90px; }
.explosion-spark.s14 { --a: 280deg; --d: 70px; } .explosion-spark.s15 { --a: 300deg; --d: 83px; }
.explosion-spark.s16 { --a: 320deg; --d: 74px; } .explosion-spark.s17 { --a: 340deg; --d: 89px; }
@keyframes explodePulseHuge {
  from { opacity: 0; transform: translate(-50%, -50%) scale(0.12); }
  18% { opacity: 1; transform: translate(-50%, -50%) scale(0.86); }
  55% { opacity: 0.92; transform: translate(-50%, -50%) scale(1.28); }
  to { opacity: 0; transform: translate(-50%, -50%) scale(1.95); }
}
@keyframes explosionSparkFly {
  0% { opacity: 1; transform: rotate(var(--a)) translateY(0) scaleY(0.6); }
  72% { opacity: 0.92; }
  100% { opacity: 0; transform: rotate(var(--a)) translateY(calc(-1 * var(--d))) scaleY(0.15); }
}
@keyframes boardCellExplosionShake {
  0%, 100% { transform: translate(0,0); }
  18% { transform: translate(2px,-1px); }
  34% { transform: translate(-2px,1px); }
  50% { transform: translate(1px,2px); }
  66% { transform: translate(-1px,-2px); }
  82% { transform: translate(1px,-1px); }
}

/* Game7.60: slower, visibly 3D d10 dice and smaller explosion tuned to SFX volume. */
.d10-throw-die.physical-d10.poly-d10 {
  width: 96px !important;
  height: 96px !important;
  margin-left: -48px !important;
  margin-top: -48px !important;
  perspective: 900px;
  transform: translate(0,0) rotateX(-18deg) rotateY(20deg) rotateZ(0deg) scale(0.84) !important;
  transition: transform var(--dur, 2850ms) cubic-bezier(.17,.72,.12,1.0), opacity 300ms ease, filter 220ms ease !important;
}
.d10-throw-die.physical-d10.poly-d10 .d10-polyhedron {
  position: absolute;
  inset: 11px;
  transform-style: preserve-3d;
  transform: rotateX(-14deg) rotateY(20deg) rotateZ(-7deg);
  filter: drop-shadow(0 22px 18px rgba(0,0,0,0.52));
}
.d10-throw-die.physical-d10.poly-d10 .d10-ground-shadow {
  position: absolute;
  left: 12%;
  right: 12%;
  bottom: 7%;
  height: 18%;
  border-radius: 50%;
  background: radial-gradient(ellipse, rgba(0,0,0,0.55), transparent 68%);
  filter: blur(2px);
  transform: translateZ(-70px) rotateX(70deg);
  opacity: 0.72;
}
.d10-throw-die.physical-d10.poly-d10 .d10-face {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 50px;
  height: 66px;
  margin-left: -25px;
  margin-top: -33px;
  display: grid;
  place-items: center;
  clip-path: polygon(50% 0%, 92% 34%, 82% 78%, 50% 100%, 18% 78%, 8% 34%);
  transform-style: preserve-3d;
  backface-visibility: visible;
  border: 1px solid rgba(255, 249, 196, 0.75);
  box-shadow:
    inset 0 2px 7px rgba(255,255,255,0.55),
    inset 0 -8px 12px rgba(88,44,0,0.42),
    0 0 3px rgba(0,0,0,0.35);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.86), rgba(255,255,255,0.06) 28%, transparent 29%),
    linear-gradient(160deg, #fff3a0 0%, #d6a438 45%, #875712 100%);
  color: #1a1214;
  text-shadow: 0 1px 0 rgba(255,255,255,0.72), 0 -1px 0 rgba(0,0,0,0.18);
}
.d10-throw-die.physical-d10.poly-d10.opponent-die .d10-face {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.75), rgba(255,255,255,0.05) 28%, transparent 29%),
    linear-gradient(160deg, #e6ddff 0%, #8f72ed 48%, #342363 100%);
  color: #fff4ad;
  border-color: rgba(221, 208, 255, 0.82);
  text-shadow: 0 1px 2px rgba(0,0,0,0.7);
}
.d10-throw-die.physical-d10.poly-d10 .d10-face b {
  display: inline-block;
  font-size: 1.12rem;
  font-weight: 1000;
  transform: translateZ(3px);
}
.d10-throw-die.physical-d10.poly-d10 .d10-face-1  { transform: rotateY(0deg) translateZ(38px) rotateX(-8deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-2  { transform: rotateY(36deg) translateZ(38px) rotateX(18deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-3  { transform: rotateY(72deg) translateZ(38px) rotateX(-18deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-4  { transform: rotateY(108deg) translateZ(38px) rotateX(20deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-5  { transform: rotateY(144deg) translateZ(38px) rotateX(-20deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-6  { transform: rotateY(180deg) translateZ(38px) rotateX(18deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-7  { transform: rotateY(216deg) translateZ(38px) rotateX(-18deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-8  { transform: rotateY(252deg) translateZ(38px) rotateX(20deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-9  { transform: rotateY(288deg) translateZ(38px) rotateX(-20deg); }
.d10-throw-die.physical-d10.poly-d10 .d10-face-10 { transform: rotateY(324deg) translateZ(38px) rotateX(18deg); }
.d10-throw-die.physical-d10.poly-d10.rolling-across-board {
  transform: translate(var(--dx), var(--dy)) rotateX(1030deg) rotateY(-940deg) rotateZ(var(--rot)) scale(1.05) !important;
}
.d10-throw-die.physical-d10.poly-d10.rolling-across-board .d10-polyhedron {
  animation: polyD10Tumble 440ms linear infinite;
}
.d10-throw-die.physical-d10.poly-d10.landed {
  filter: brightness(1.14) drop-shadow(0 0 14px rgba(255,225,84,0.38));
  animation: diceLandBouncePoly 480ms ease-out both !important;
}
.d10-throw-die.physical-d10.poly-d10.landed .d10-polyhedron {
  animation: none !important;
  transform: rotateX(-12deg) rotateY(0deg) rotateZ(0deg);
}
@keyframes polyD10Tumble {
  0%   { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); }
  25%  { transform: rotateX(112deg) rotateY(74deg) rotateZ(52deg); }
  50%  { transform: rotateX(228deg) rotateY(170deg) rotateZ(114deg); }
  75%  { transform: rotateX(338deg) rotateY(258deg) rotateZ(187deg); }
  100% { transform: rotateX(456deg) rotateY(360deg) rotateZ(252deg); }
}
@keyframes diceLandBouncePoly {
  0% { transform: translate(var(--dx), var(--dy)) rotateX(1030deg) rotateY(-940deg) rotateZ(var(--rot)) scale(1.06); }
  42% { transform: translate(var(--dx), calc(var(--dy) - 12px)) rotateX(1080deg) rotateY(-900deg) rotateZ(var(--rot)) scale(1.14); }
  100% { transform: translate(var(--dx), var(--dy)) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1.0); }
}
.exploding-cell {
  animation: boardCellExplosionShakeSmaller 340ms linear both !important;
}
.explode-fx.upgraded-explosion-fx {
  width: 96% !important;
  box-shadow: 0 0 24px rgba(255,226,87,0.8), 0 0 56px rgba(255,66,22,0.45), 0 0 80px rgba(255,10,0,0.2) !important;
  animation: explodePulseGame760 520ms ease-out forwards !important;
}
.explode-fx.upgraded-explosion-fx .explosion-spark {
  width: 5px !important;
  height: 17px !important;
  animation-duration: 520ms !important;
}
.explosion-spark.s0 { --d: 48px; } .explosion-spark.s1 { --d: 58px; }
.explosion-spark.s2 { --d: 45px; } .explosion-spark.s3 { --d: 60px; }
.explosion-spark.s4 { --d: 50px; } .explosion-spark.s5 { --d: 63px; }
.explosion-spark.s6 { --d: 46px; } .explosion-spark.s7 { --d: 58px; }
.explosion-spark.s8 { --d: 51px; } .explosion-spark.s9 { --d: 64px; }
.explosion-spark.s10 { --d: 45px; } .explosion-spark.s11 { --d: 57px; }
.explosion-spark.s12 { --d: 49px; } .explosion-spark.s13 { --d: 62px; }
.explosion-spark.s14 { --d: 48px; } .explosion-spark.s15 { --d: 56px; }
.explosion-spark.s16 { --d: 50px; } .explosion-spark.s17 { --d: 59px; }
@keyframes explodePulseGame760 {
  from { opacity: 0; transform: translate(-50%, -50%) scale(0.12); }
  20% { opacity: 1; transform: translate(-50%, -50%) scale(0.68); }
  56% { opacity: 0.88; transform: translate(-50%, -50%) scale(0.98); }
  to { opacity: 0; transform: translate(-50%, -50%) scale(1.34); }
}
@keyframes boardCellExplosionShakeSmaller {
  0%, 100% { transform: translate(0,0); }
  22% { transform: translate(1px,-1px); }
  44% { transform: translate(-1px,1px); }
  66% { transform: translate(1px,1px); }
  88% { transform: translate(-1px,-1px); }
}

/* Game7.63 draw-to-hand orientation fix: keep face-down ATAC backs upright. */
.card-draw-back-fly,
.card-draw-reveal-fly {
  transform-style: preserve-3d !important;
  backface-visibility: visible !important;
}

/* Game7.65 / playatac tutorial mode */
.tutorial-launch-btn {
  margin-top: 10px;
  width: 100%;
  border-color: rgba(168,155,233,0.8);
}
body.tutorial-mode .match-screen { background: rgba(10, 9, 12, 0.98); }
.tutorial-overlay-host {
  display: none;
  width: 100%;
  margin-top: 0.75rem;
  flex: 0 0 auto;
}
body.tutorial-mode .tutorial-overlay-host {
  display: block;
}
.tutorial-overlay {
  position: static;
  width: 100%;
  z-index: 30;
  pointer-events: none;
}
.tutorial-card {
  pointer-events: auto;
  position: relative;
  overflow: hidden;
  background: rgba(24, 22, 28, 0.94);
  border: 1px solid rgba(168,155,233,0.75);
  box-shadow: 0 18px 40px rgba(0,0,0,0.45), 0 0 24px rgba(168,155,233,0.18);
  border-radius: 18px;
  padding: 14px 16px;
  width: 100%;
  box-sizing: border-box;
  color: #fff;
  text-align: left;
  backdrop-filter: blur(8px);
}

.tutorial-card.tutorial-attention {
  animation: tutorialBoxPop 0.72s ease-out;
}
.tutorial-card.tutorial-attention::before {
  content: "";
  position: absolute;
  inset: -40%;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,0.96) 0 2%, transparent 3% 100%),
    conic-gradient(from 0deg, transparent 0 8deg, rgba(255,255,255,0.90) 9deg 13deg, transparent 14deg 38deg, rgba(191,230,200,0.75) 39deg 43deg, transparent 44deg 80deg, rgba(168,155,233,0.75) 81deg 86deg, transparent 87deg 130deg, rgba(255,255,255,0.90) 131deg 135deg, transparent 136deg 185deg, rgba(191,230,200,0.75) 186deg 191deg, transparent 192deg 245deg, rgba(168,155,233,0.75) 246deg 251deg, transparent 252deg 360deg);
  opacity: 0;
  transform: scale(0.05) rotate(0deg);
  animation: tutorialTextExplosion 0.72s ease-out;
  mix-blend-mode: screen;
  z-index: 0;
}
.tutorial-card > * {
  position: relative;
  z-index: 1;
}
@keyframes tutorialBoxPop {
  0% { transform: scale(0.985); box-shadow: 0 18px 40px rgba(0,0,0,0.45), 0 0 0 rgba(255,255,255,0); }
  30% { transform: scale(1.035); box-shadow: 0 18px 40px rgba(0,0,0,0.45), 0 0 36px rgba(255,255,255,0.65); }
  100% { transform: scale(1); }
}
@keyframes tutorialTextExplosion {
  0% { opacity: 0; transform: scale(0.08) rotate(-10deg); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: scale(1.35) rotate(16deg); }
}

.tutorial-kicker {
  color: #bfe6c8;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.tutorial-title {
  font-size: clamp(14px, 1.7vw, 19px);
  font-weight: 800;
  line-height: 1.18;
}
.tutorial-subtitle {
  margin-top: 6px;
  color: rgba(255,255,255,0.82);
  font-size: clamp(13px, 1.4vw, 16px);
}
.tutorial-actions {
  margin-top: 10px;
  display: flex;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}
.tutorial-forced-cell {
  position: relative;
  outline: 4px solid rgba(191,230,200,0.98) !important;
  outline-offset: -4px;
  box-shadow: inset 0 0 0 999px rgba(191,230,200,0.10), 0 0 24px rgba(191,230,200,0.85) !important;
  animation: tutorialPulse 0.85s ease-in-out infinite alternate;
  z-index: 20;
}
.tutorial-forced-cell::after {
  content: "PLAY HERE";
  position: absolute;
  left: 50%;
  top: 6px;
  transform: translateX(-50%);
  background: rgba(24,22,28,0.92);
  border: 1px solid rgba(191,230,200,0.9);
  border-radius: 999px;
  color: #bfe6c8;
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 0.08em;
  padding: 3px 8px;
  white-space: nowrap;
  pointer-events: none;
}
@keyframes tutorialPulse {
  from { filter: brightness(1); transform: scale(1); }
  to { filter: brightness(1.2); transform: scale(1.025); }
}
body.tutorial-mode .side-info-actions .dangerish { display: none; }

.tutorial-secondary-cell {
  position: relative;
  outline: 3px dashed rgba(168,155,233,0.9) !important;
  outline-offset: -5px;
  box-shadow: inset 0 0 0 999px rgba(168,155,233,0.08), 0 0 16px rgba(168,155,233,0.55) !important;
  z-index: 19;
}
.tutorial-secondary-cell::before {
  content: "LEGAL";
  position: absolute;
  left: 50%;
  top: 6px;
  bottom: auto;
  transform: translateX(-50%);
  background: rgba(24,22,28,0.76);
  border: 1px solid rgba(168,155,233,0.85);
  border-radius: 999px;
  color: #d8d0ff;
  font-weight: 800;
  font-size: 9px;
  letter-spacing: 0.07em;
  padding: 2px 6px;
  white-space: nowrap;
  pointer-events: none;
}

.tutorial-card.tutorial-small-title .tutorial-title {
  font-size: clamp(11px, 1.45vw, 15px);
}
.pile-slot.tutorial-secondary-cell::before {
  content: "LEGAL";
  position: absolute;
  left: 50%;
  top: 6px;
  transform: translateX(-50%);
  background: rgba(24,22,28,0.76);
  border: 1px solid rgba(168,155,233,0.85);
  border-radius: 999px;
  color: #d8d0ff;
  font-weight: 800;
  font-size: 9px;
  letter-spacing: 0.07em;
  padding: 2px 6px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 4;
}

@media (max-width: 1180px) {
  .tutorial-overlay {
    width: 100%;
  }
  .tutorial-card { text-align: left; }
  .tutorial-actions { justify-content: flex-start; }
}

/* playatac1.26: tutorial-only enlarged directional numbers on cards */
body.tutorial-mode .board-card {
  position: relative !important;
}
body.tutorial-mode .tutorial-number-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
  font-size: clamp(15px, 1.4vw, 18px);
  font-weight: 900;
  line-height: 1;
  color: #ffffff;
  text-shadow: 0 1px 2px #000, 0 0 4px #000, 0 0 8px rgba(0,0,0,0.9);
}
body.tutorial-mode .tutorial-number-overlay .tnum {
  position: absolute;
  transform: translate(-50%, -50%);
  min-width: 1.35em;
  text-align: center;
}
body.tutorial-mode .tutorial-number-overlay .tnum-tl { left: 22%; top: 19%; }
body.tutorial-mode .tutorial-number-overlay .tnum-tm { left: 50%; top: 13%; }
body.tutorial-mode .tutorial-number-overlay .tnum-tr { left: 78%; top: 19%; }
body.tutorial-mode .tutorial-number-overlay .tnum-ml { left: 16%; top: 50%; }
body.tutorial-mode .tutorial-number-overlay .tnum-mr { left: 84%; top: 50%; }
body.tutorial-mode .tutorial-number-overlay .tnum-bl { left: 22%; top: 81%; }
body.tutorial-mode .tutorial-number-overlay .tnum-bm { left: 50%; top: 87%; }
body.tutorial-mode .tutorial-number-overlay .tnum-br { left: 78%; top: 81%; }


/* playatac mobile/touch patch */
html {
  -webkit-text-size-adjust: 100%;
}

button,
input,
select,
.tab,
.cta-link {
  min-height: 44px;
}

button,
.tab,
.card-tile,
.deck-slot-pill,
.clean-hand-card,
.board-cell {
  touch-action: manipulation;
}

/* Disable hover effects and the floating magnifier on touch devices */
@media (hover: none), (pointer: coarse) {
  #matchMagnifierLens,
  .match-magnifier-lens {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .board-card:hover,
  .clean-hand-card:hover,
  .clean-card:hover img,
  #tab-collection .clean-card:hover img,
  #tab-decks .clean-card:hover img {
    transform: none !important;
    box-shadow: none !important;
    filter: none !important;
  }

  .zoom-card-wrap {
    max-width: 94vw !important;
    max-height: 94dvh !important;
  }

  .zoom-card-wrap img {
    max-height: 94dvh !important;
    object-fit: contain !important;
  }
}

/* Phone/tablet layout */
@media (max-width: 900px), (hover: none) and (pointer: coarse) and (max-width: 1100px) {
  .hero {
    padding: 0.5rem !important;
  }

  .hero-inner {
    padding: 0.75rem !important;
  }

  .dragonfly-badge {
    width: 64px !important;
    height: 64px !important;
  }

  .app-shell {
    padding: 0 0.5rem 1rem !important;
  }

  .tabs {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 0.5rem !important;
  }

  .tab {
    flex: 0 0 auto !important;
    padding-left: 0.9rem !important;
    padding-right: 0.9rem !important;
  }

  .two-col,
  .builder-layout,
  .builder-layout-wide {
    grid-template-columns: 1fr !important;
  }

  .collection-grid,
  .collection-grid.compact,
  #currentDeckList.current-deck-grid,
  #deckCardLibrary.collection-grid.compact {
    grid-template-columns: repeat(auto-fill, minmax(112px, 1fr)) !important;
  }

  body.in-match {
    overflow: hidden !important;
  }

  .match-screen,
  .match-screen-inner {
    height: 100dvh !important;
    min-height: 100dvh !important;
    overflow: hidden !important;
  }

  .match-screen-inner {
    padding:
      max(6px, env(safe-area-inset-top))
      max(6px, env(safe-area-inset-right))
      max(8px, env(safe-area-inset-bottom))
      max(6px, env(safe-area-inset-left)) !important;
  }

  .match-screen-shell {
    height: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.35rem !important;
    overflow: hidden !important;
  }

  .board-wrap-panel {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
    padding: 0.25rem !important;
  }

  .cardplay-law-layout.vertical {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    grid-template-areas:
      "opponent"
      "board"
      "player" !important;
    gap: 0.35rem !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
    align-items: stretch !important;
    justify-content: center !important;
    --mobile-hand-card-w: clamp(50px, 15vw, 72px);
  }

  .cardplay-law-layout.vertical .opponent-side-table {
    grid-area: opponent !important;
  }

  .cardplay-law-layout.vertical .player-side-table {
    grid-area: player !important;
  }

  .cardplay-law-layout.vertical > .board-panel.vertical {
    grid-area: board !important;
    width: min(100%, calc((100dvh - 225px) * 587 / 916)) !important;
    height: auto !important;
    max-height: calc(100dvh - 225px) !important;
    min-height: 0 !important;
    aspect-ratio: 587 / 916 !important;
    justify-self: center !important;
    align-self: center !important;
    margin: 0 auto !important;
    overflow: visible !important;
  }

  .cardplay-law-layout.vertical .side-table,
  #matchScreen .cardplay-law-layout.vertical .player-side-table {
    min-height: 0 !important;
    height: auto !important;
    padding: 0.35rem !important;
    border-radius: 10px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: center !important;
    overflow: visible !important;
  }

  .cardplay-law-layout.vertical .opponent-hand-slot {
    display: none !important;
  }

  .cardplay-law-layout.vertical .side-info-box,
  #matchScreen .cardplay-law-layout.vertical .player-side-table .player-info-box {
    padding: 0.35rem 0.5rem !important;
    border-radius: 10px !important;
    font-size: 0.78rem !important;
  }

  .cardplay-law-layout.vertical .side-player-label,
  .cardplay-law-layout.vertical .side-die-roll,
  .cardplay-law-layout.vertical .side-stat-line {
    font-size: 0.78rem !important;
    line-height: 1.15 !important;
  }

  .cardplay-law-layout.vertical .side-info-actions {
    display: flex !important;
    gap: 0.35rem !important;
    flex-wrap: wrap !important;
    margin-top: 0.35rem !important;
  }

  .cardplay-law-layout.vertical .side-info-actions button {
    min-height: 36px !important;
    padding: 0.35rem 0.5rem !important;
    font-size: 0.76rem !important;
  }

  .cardplay-law-layout.vertical .grid-board.vertical .board-card,
  .cardplay-law-layout.vertical .grid-board.vertical .board-card:active {
    transform: rotate(var(--card-rot)) !important;
  }

  #matchScreen .cardplay-law-layout.vertical .player-hand-slot {
    flex: 0 0 auto !important;
    min-height: calc(var(--mobile-hand-card-w) * 1.4 + 18px) !important;
    max-height: calc(var(--mobile-hand-card-w) * 1.4 + 26px) !important;
    width: 100% !important;
    margin: 0.35rem 0 0 0 !important;
    padding: 0.4rem !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
  }

  #matchScreen .cardplay-law-layout.vertical #playerHand.clean-hand {
    display: flex !important;
    flex-wrap: nowrap !important;
    grid-template-columns: none !important;
    gap: 0.4rem !important;
    width: max-content !important;
    min-width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    justify-content: flex-start !important;
    align-items: center !important;
    overflow: visible !important;
  }

  #matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card,
  #matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle,
  #matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:hover,
  #matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle:active,
  #matchScreen .cardplay-law-layout.vertical #playerHand .clean-hand-card.full-card-drag-handle.selected {
    width: var(--mobile-hand-card-w) !important;
    height: calc(var(--mobile-hand-card-w) * 1.4) !important;
    min-width: var(--mobile-hand-card-w) !important;
    min-height: calc(var(--mobile-hand-card-w) * 1.4) !important;
    max-width: var(--mobile-hand-card-w) !important;
    max-height: calc(var(--mobile-hand-card-w) * 1.4) !important;
    transform: none !important;
    touch-action: none !important;
  }

  .cardplay-law-layout.vertical .selected-card-title {
    font-size: 0.78rem !important;
    margin-bottom: 0.25rem !important;
  }

  .cardplay-law-layout.vertical .selected-card-actions {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0.35rem !important;
  }

  .cardplay-law-layout.vertical .selected-card-actions button {
    min-height: 42px !important;
    padding: 0.4rem 0.25rem !important;
    font-size: 0.78rem !important;
  }

  .tutorial-overlay-host {
    max-height: 28dvh !important;
    overflow: auto !important;
  }

  .tutorial-card {
    padding: 10px 12px !important;
  }

  .tutorial-title {
    font-size: 14px !important;
  }

  .tutorial-subtitle {
    font-size: 12px !important;
  }
}

@media (max-width: 480px) {
  .cardplay-law-layout.vertical > .board-panel.vertical {
    width: min(100%, calc((100dvh - 245px) * 587 / 916)) !important;
    max-height: calc(100dvh - 245px) !important;
  }

  .cardplay-law-layout.vertical .side-info-box,
  #matchScreen .cardplay-law-layout.vertical .player-side-table .player-info-box {
    font-size: 0.72rem !important;
  }

  .cardplay-law-layout.vertical .selected-card-actions button {
    font-size: 0.72rem !important;
  }
}

@media (orientation: landscape) and (max-height: 520px) {
  .cardplay-law-layout.vertical {
    grid-template-rows: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "board"
      "player" !important;
  }

  .cardplay-law-layout.vertical .opponent-side-table {
    display: none !important;
  }

  .cardplay-law-layout.vertical > .board-panel.vertical {
    width: min(100%, calc((100dvh - 125px) * 587 / 916)) !important;
    max-height: calc(100dvh - 125px) !important;
  }
}

