/* Wizard Battles - Arcane Duel Theater Phase 1
 * Directional token layer + technical mock styles.
 */

:root {
    --adt-bg-0: #06101f;
    --adt-bg-1: #09172c;
    --adt-bg-2: #11213c;
    --adt-ink-strong: #edf4ff;
    --adt-ink-soft: rgba(218, 231, 248, 0.82);
    --adt-ink-muted: rgba(178, 197, 223, 0.62);
    --adt-line-soft: rgba(146, 182, 232, 0.18);
    --adt-line-strong: rgba(198, 224, 255, 0.28);
    --adt-glow-cool: rgba(120, 186, 255, 0.28);
    --adt-glow-warm: rgba(242, 193, 108, 0.28);
    --adt-glow-rival: rgba(197, 106, 141, 0.24);
    --adt-glow-player: rgba(87, 206, 178, 0.24);
    --adt-glow-special: rgba(168, 124, 214, 0.24);
    --adt-shell:
        radial-gradient(circle at 16% 12%, rgba(120, 186, 255, 0.14), rgba(120, 186, 255, 0) 34%),
        radial-gradient(circle at 84% 16%, rgba(242, 193, 108, 0.12), rgba(242, 193, 108, 0) 32%),
        linear-gradient(180deg, rgba(10, 18, 34, 0.96), rgba(7, 14, 28, 0.98));
    --adt-panel:
        linear-gradient(160deg, rgba(13, 26, 55, 0.92), rgba(8, 17, 36, 0.96));
    --adt-panel-alt:
        linear-gradient(160deg, rgba(22, 23, 54, 0.9), rgba(10, 15, 34, 0.96));
    --adt-player-panel:
        radial-gradient(circle at 18% 20%, rgba(87, 206, 178, 0.14), rgba(87, 206, 178, 0) 30%),
        linear-gradient(160deg, rgba(12, 32, 56, 0.94), rgba(8, 18, 35, 0.98));
    --adt-rival-panel:
        radial-gradient(circle at 84% 24%, rgba(168, 124, 214, 0.13), rgba(168, 124, 214, 0) 32%),
        radial-gradient(circle at 20% 18%, rgba(197, 106, 141, 0.11), rgba(197, 106, 141, 0) 28%),
        linear-gradient(160deg, rgba(32, 21, 58, 0.94), rgba(9, 16, 34, 0.98));
    --adt-altar:
        radial-gradient(circle at 50% 0%, rgba(242, 193, 108, 0.14), rgba(242, 193, 108, 0) 44%),
        radial-gradient(circle at 12% 40%, rgba(120, 186, 255, 0.13), rgba(120, 186, 255, 0) 34%),
        linear-gradient(160deg, rgba(12, 26, 54, 0.96), rgba(8, 16, 35, 0.98));
    --adt-dock:
        radial-gradient(circle at 18% 0%, rgba(87, 206, 178, 0.15), rgba(87, 206, 178, 0) 28%),
        radial-gradient(circle at 82% 0%, rgba(168, 124, 214, 0.14), rgba(168, 124, 214, 0) 26%),
        linear-gradient(180deg, rgba(10, 19, 35, 0.96), rgba(8, 13, 28, 0.99));
    --adt-radius-shell: 34px;
    --adt-radius-panel: 24px;
    --adt-radius-chip: 999px;
    --adt-shadow-shell: 0 30px 80px rgba(2, 7, 18, 0.54);
    --adt-shadow-panel: 0 18px 34px rgba(2, 7, 18, 0.32);
    --adt-shadow-card: 0 18px 26px rgba(2, 7, 18, 0.34);
    --adt-space-1: 4px;
    --adt-space-2: 8px;
    --adt-space-3: 12px;
    --adt-space-4: 16px;
    --adt-space-5: 20px;
    --adt-space-6: 24px;
    --adt-space-7: 32px;
    --adt-space-8: 40px;
    --adt-motion-fast: 160ms;
    --adt-motion-base: 240ms;
}

html.adt-mock-html,
body.adt-mock-body {
    min-height: 100%;
    margin: 0;
    background:
        linear-gradient(180deg, rgba(8, 12, 20, 0.36), rgba(8, 12, 20, 0.72)),
        url('../../assets/backgrounds/bg_hub_main.avif') center / cover no-repeat fixed;
    color: var(--adt-ink-strong);
}

body.adt-mock-body {
    font-family: var(--font-primary-ui);
}

.adt-mock-page {
    min-height: 100dvh;
    padding: max(20px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(20px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
    background:
        linear-gradient(180deg, rgba(3, 7, 16, 0.36), rgba(3, 7, 16, 0.78)),
        radial-gradient(circle at 50% 0%, rgba(120, 186, 255, 0.08), rgba(120, 186, 255, 0) 24%);
}

.adt-shell-layout {
    width: min(1440px, 100%);
    margin: 0 auto;
    display: grid;
    gap: 18px;
}

.adt-brief {
    display: grid;
    gap: 10px;
    padding: 14px 18px;
    border: 1px solid rgba(234, 243, 255, 0.14);
    border-radius: 20px;
    background:
        linear-gradient(160deg, rgba(10, 17, 32, 0.9), rgba(7, 11, 24, 0.92));
    box-shadow: var(--adt-shadow-panel);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.adt-brief-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.adt-kicker,
.adt-pill {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 12px;
    border-radius: var(--adt-radius-chip);
    border: 1px solid var(--adt-line-soft);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--adt-ink-soft);
    background: rgba(255, 255, 255, 0.04);
}

.adt-kicker {
    border-color: rgba(242, 193, 108, 0.24);
    color: #f7dca2;
}

.adt-brief h1 {
    margin: 0;
    font-size: clamp(1.6rem, 3.3vw, 2.8rem);
    line-height: 0.96;
    letter-spacing: 0.02em;
}

.adt-brief p {
    margin: 0;
    max-width: 76ch;
    color: var(--adt-ink-soft);
    font-family: var(--font-magical);
    font-size: 1rem;
    line-height: 1.32;
}

.adt-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.adt-stage {
    position: relative;
    overflow: hidden;
    border-radius: var(--adt-radius-shell);
    border: 1px solid rgba(232, 241, 255, 0.14);
    background: var(--adt-shell);
    box-shadow: var(--adt-shadow-shell);
    isolation: isolate;
}

.adt-stage::before,
.adt-stage::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.adt-stage::before {
    background:
        radial-gradient(circle at 22% 48%, rgba(87, 206, 178, 0.1), rgba(87, 206, 178, 0) 28%),
        radial-gradient(circle at 78% 42%, rgba(168, 124, 214, 0.1), rgba(168, 124, 214, 0) 26%),
        radial-gradient(circle at 50% 100%, rgba(242, 193, 108, 0.12), rgba(242, 193, 108, 0) 32%);
    opacity: 0.94;
}

.adt-stage::after {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.04) 50%, rgba(255, 255, 255, 0) 100%);
    transform: translateX(-100%);
    animation: adt-stage-scan 7s linear infinite;
    opacity: 0.42;
}

.adt-stage-inner {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 10px;
    padding: 16px;
}

.adt-topbar {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr) 72px auto;
    gap: 12px;
    align-items: center;
}

.adt-score-chip,
.adt-round-chip,
.adt-menu-button,
.adt-ticker,
.adt-lane,
.adt-altar,
.adt-command-rail,
.adt-note {
    box-shadow: var(--adt-shadow-panel);
}

.adt-score-chip,
.adt-round-chip {
    display: grid;
    gap: 3px;
    place-items: center;
    min-height: 64px;
    padding: 8px 12px;
    border-radius: 18px;
    border: 1px solid var(--adt-line-soft);
    background: var(--adt-panel);
}

.adt-score-chip--rival {
    background:
        radial-gradient(circle at 18% 16%, rgba(197, 106, 141, 0.16), rgba(197, 106, 141, 0) 42%),
        linear-gradient(160deg, rgba(66, 24, 40, 0.94), rgba(27, 13, 22, 0.98));
}

.adt-score-chip--player {
    background:
        radial-gradient(circle at 18% 16%, rgba(242, 193, 108, 0.16), rgba(242, 193, 108, 0) 42%),
        linear-gradient(160deg, rgba(67, 49, 22, 0.94), rgba(25, 18, 10, 0.98));
}

.adt-score-label,
.adt-round-label {
    font-size: 0.58rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--adt-ink-muted);
}

.adt-score-value,
.adt-round-value {
    font-family: var(--font-numeric);
    font-size: 1.7rem;
    font-weight: 900;
    line-height: 1;
}

.adt-round-chip {
    grid-template-columns: auto auto auto;
    grid-auto-flow: column;
    justify-content: center;
    min-height: 58px;
    border-radius: 999px;
    background:
        radial-gradient(circle at 50% 0%, rgba(120, 186, 255, 0.16), rgba(120, 186, 255, 0) 42%),
        linear-gradient(160deg, rgba(16, 31, 62, 0.95), rgba(12, 20, 42, 0.98));
}

.adt-round-star {
    color: #f7dca2;
}

.adt-menu-button {
    width: 58px;
    height: 58px;
    justify-self: end;
    border-radius: 18px;
    border: 1px solid var(--adt-line-strong);
    background:
        radial-gradient(circle at 50% 0%, rgba(120, 186, 255, 0.18), rgba(120, 186, 255, 0) 42%),
        linear-gradient(160deg, rgba(18, 33, 62, 0.95), rgba(11, 21, 44, 0.98));
    position: relative;
}

.adt-menu-button::before,
.adt-menu-button::after,
.adt-menu-button span {
    content: '';
    position: absolute;
    left: 16px;
    right: 16px;
    height: 2px;
    border-radius: 999px;
    background: rgba(236, 244, 255, 0.92);
}

.adt-menu-button::before {
    top: 18px;
}

.adt-menu-button span {
    top: 27px;
}

.adt-menu-button::after {
    top: 36px;
}

.adt-ticker {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    min-height: 54px;
    padding: 10px 14px;
    border-radius: 18px;
    border: 1px solid var(--adt-line-soft);
    background:
        radial-gradient(circle at 12% 18%, rgba(120, 186, 255, 0.16), rgba(120, 186, 255, 0) 34%),
        linear-gradient(160deg, rgba(11, 21, 47, 0.94), rgba(6, 14, 30, 0.98));
}

.adt-ticker-icon {
    width: 30px;
    height: 30px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(242, 193, 108, 0.24);
    background: rgba(242, 193, 108, 0.1);
}

.adt-ticker-icon img,
.adt-stat-cluster img,
.adt-note-inline img {
    width: 16px;
    height: 16px;
}

.adt-ticker-copy {
    display: grid;
    gap: 3px;
}

.adt-ticker-label {
    font-size: 0.56rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--adt-ink-muted);
}

.adt-ticker-text {
    font-size: 0.92rem;
    color: var(--adt-ink-strong);
}

.adt-ticker-state {
    min-width: 92px;
    justify-content: center;
}

.adt-arena {
    display: grid;
    gap: 12px;
}

.adt-lane {
    position: relative;
    padding: 20px 16px 16px;
    border-radius: 28px;
    border: 1px solid var(--adt-line-soft);
}

.adt-lane--rival {
    background: var(--adt-rival-panel);
}

.adt-lane--player {
    background: var(--adt-player-panel);
}

.adt-lane-badge {
    position: absolute;
    top: 10px;
    left: 12px;
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 10px;
    border-radius: var(--adt-radius-chip);
    border: 1px solid var(--adt-line-soft);
    background: rgba(7, 15, 32, 0.54);
    font-size: 0.58rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.adt-lane--rival .adt-lane-badge {
    color: #ffbed2;
    border-color: rgba(255, 186, 209, 0.18);
}

.adt-lane--player .adt-lane-badge {
    color: #b8fae9;
    border-color: rgba(165, 243, 221, 0.18);
}

.adt-slot-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.adt-slot {
    position: relative;
    min-height: 244px;
    padding: 16px 12px 12px;
    border-radius: 24px;
    border: 1px solid rgba(160, 194, 240, 0.1);
    background:
        linear-gradient(180deg, rgba(7, 16, 34, 0.32), rgba(7, 16, 34, 0.08));
}

.adt-slot::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        radial-gradient(circle at 50% 0%, rgba(242, 193, 108, 0.1), rgba(242, 193, 108, 0) 34%);
    opacity: 0;
    transition: opacity var(--adt-motion-base) ease;
}

.adt-slot--active::before,
.adt-slot--filled::before {
    opacity: 1;
}

.adt-slot--active {
    border-color: rgba(242, 193, 108, 0.24);
    box-shadow:
        0 0 0 1px rgba(242, 193, 108, 0.1),
        0 22px 32px rgba(2, 7, 18, 0.26),
        0 0 32px rgba(242, 193, 108, 0.1);
}

.adt-slot-label {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: var(--adt-radius-chip);
    border: 1px solid rgba(179, 207, 245, 0.16);
    background: rgba(7, 15, 32, 0.52);
    font-size: 0.56rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--adt-ink-soft);
}

.adt-card-shell {
    position: relative;
    display: grid;
    place-items: center;
    width: min(100%, 144px);
    margin: 10px auto 0;
    padding: 7px;
    border-radius: 18px;
    border: 1px solid rgba(208, 225, 251, 0.14);
    background:
        linear-gradient(160deg, rgba(10, 18, 34, 0.88), rgba(7, 12, 24, 0.96));
    box-shadow: var(--adt-shadow-card);
}

.adt-card-shell img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 12px;
}

.adt-card-back img {
    filter: saturate(0.9);
}

.adt-card-meta {
    display: grid;
    gap: 6px;
    margin-top: 12px;
}

.adt-mini-stat {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 8px;
    align-items: center;
    min-height: 34px;
    padding: 0 10px;
    border-radius: 14px;
    border: 1px solid rgba(168, 198, 241, 0.12);
    background: rgba(7, 15, 32, 0.54);
}

.adt-mini-stat strong {
    font-family: var(--font-numeric);
    font-size: 0.88rem;
}

.adt-mini-stat span {
    font-size: 0.62rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--adt-ink-muted);
}

.adt-slot-empty {
    width: min(100%, 134px);
    aspect-ratio: 5 / 7;
    margin: 12px auto 0;
    border-radius: 18px;
    border: 1px dashed rgba(182, 210, 246, 0.16);
    background:
        radial-gradient(circle at 50% 28%, rgba(120, 186, 255, 0.08), rgba(120, 186, 255, 0) 44%),
        linear-gradient(180deg, rgba(7, 15, 32, 0.44), rgba(7, 15, 32, 0.2));
}

.adt-altar {
    display: grid;
    gap: 10px;
    padding: 14px;
    border-radius: 28px;
    border: 1px solid rgba(204, 224, 255, 0.18);
    background: var(--adt-altar);
}

.adt-altar-top {
    display: grid;
    grid-template-columns: auto auto minmax(0, 1fr) auto auto;
    gap: 10px;
    align-items: center;
}

.adt-altar-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: var(--adt-radius-chip);
    border: 1px solid var(--adt-line-soft);
    background: rgba(255, 255, 255, 0.04);
    font-size: 0.62rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.adt-altar-chip--duel {
    color: #f7dca2;
    border-color: rgba(242, 193, 108, 0.22);
}

.adt-altar-main {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr) 144px 156px;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border-radius: 22px;
    border: 1px solid var(--adt-line-soft);
    background:
        radial-gradient(circle at 14% 18%, rgba(120, 186, 255, 0.16), rgba(120, 186, 255, 0) 24%),
        linear-gradient(160deg, rgba(11, 22, 45, 0.94), rgba(8, 16, 32, 0.98));
}

.adt-altar-orb {
    width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    border: 1px solid rgba(188, 214, 248, 0.18);
    background:
        radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0) 42%),
        linear-gradient(160deg, rgba(41, 79, 156, 0.96), rgba(21, 47, 96, 0.98));
}

.adt-altar-orb span {
    font-size: 1.2rem;
}

.adt-altar-copy {
    display: grid;
    gap: 4px;
}

.adt-altar-title {
    font-size: 1.22rem;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.adt-altar-sub {
    color: var(--adt-ink-soft);
    font-family: var(--font-magical);
    font-size: 0.98rem;
    line-height: 1.14;
}

.adt-turn-cluster,
.adt-stat-cluster {
    display: grid;
    gap: 6px;
    align-content: center;
    min-height: 84px;
    padding: 10px 12px;
    border-radius: 18px;
    border: 1px solid var(--adt-line-soft);
    background: rgba(7, 16, 32, 0.54);
}

.adt-turn-cluster {
    border-color: rgba(125, 230, 200, 0.18);
}

.adt-turn-value,
.adt-stat-value {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: var(--adt-radius-chip);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.adt-turn-value {
    color: #b9ffe7;
    background: rgba(87, 206, 178, 0.12);
    border: 1px solid rgba(87, 206, 178, 0.22);
}

.adt-stat-value {
    justify-content: flex-start;
    gap: 8px;
    color: #f7dca2;
    background: rgba(242, 193, 108, 0.1);
    border: 1px solid rgba(242, 193, 108, 0.22);
}

.adt-stat-cluster img {
    width: 18px;
    height: 18px;
}

.adt-command-rail {
    display: grid;
    gap: 12px;
    padding: 14px 16px 18px;
    border-radius: 28px;
    border: 1px solid rgba(230, 240, 255, 0.12);
    background: var(--adt-dock);
}

.adt-command-top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
}

.adt-command-title {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: var(--adt-radius-chip);
    background: rgba(87, 206, 178, 0.14);
    border: 1px solid rgba(87, 206, 178, 0.22);
    color: #b9ffe7;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.adt-command-sub {
    color: var(--adt-ink-soft);
    font-size: 0.94rem;
}

.adt-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 18px;
    border: 1px solid rgba(249, 220, 158, 0.24);
    background:
        linear-gradient(145deg, rgba(188, 126, 48, 0.96), rgba(122, 78, 24, 0.98));
    color: #fff2d2;
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.adt-hand-row {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

.adt-hand-card {
    width: min(100%, 134px);
    display: grid;
    gap: 8px;
    padding: 8px;
    border-radius: 18px;
    border: 1px solid rgba(205, 224, 250, 0.12);
    background:
        linear-gradient(160deg, rgba(10, 17, 31, 0.92), rgba(8, 13, 25, 0.98));
    box-shadow: var(--adt-shadow-card);
    transition: transform var(--adt-motion-base) ease, border-color var(--adt-motion-base) ease, box-shadow var(--adt-motion-base) ease;
}

.adt-hand-card img {
    width: 100%;
    display: block;
    border-radius: 12px;
}

.adt-hand-card--focus {
    transform: translateY(-8px) scale(1.02);
    border-color: rgba(242, 193, 108, 0.24);
    box-shadow:
        0 20px 28px rgba(2, 7, 18, 0.36),
        0 0 28px rgba(242, 193, 108, 0.12);
}

.adt-hand-caption {
    display: grid;
    gap: 4px;
    padding: 0 4px 2px;
}

.adt-hand-caption strong {
    font-size: 0.82rem;
    line-height: 1.1;
}

.adt-hand-caption span {
    color: var(--adt-ink-muted);
    font-size: 0.64rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.adt-notes-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.adt-note {
    display: grid;
    gap: 10px;
    padding: 16px 18px;
    border-radius: 20px;
    border: 1px solid rgba(232, 241, 255, 0.12);
    background:
        linear-gradient(160deg, rgba(9, 16, 30, 0.92), rgba(7, 11, 22, 0.96));
}

.adt-note h2 {
    margin: 0;
    font-size: 0.84rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.adt-note p,
.adt-note li {
    margin: 0;
    color: var(--adt-ink-soft);
    font-size: 0.92rem;
    line-height: 1.28;
}

.adt-note ul {
    display: grid;
    gap: 8px;
    padding-left: 18px;
    margin: 0;
}

.adt-note-inline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--adt-ink-soft);
}

@keyframes adt-stage-scan {
    from {
        transform: translateX(-100%);
    }
    to {
        transform: translateX(100%);
    }
}

@media (max-width: 1100px) {
    .adt-altar-main {
        grid-template-columns: 52px minmax(0, 1fr) 132px 142px;
    }
}

@media (max-width: 900px) {
    .adt-stage-inner {
        padding: 12px;
        gap: 8px;
    }

    .adt-topbar {
        grid-template-columns: 64px minmax(0, 1fr) 64px auto;
        gap: 8px;
    }

    .adt-score-chip,
    .adt-round-chip {
        min-height: 58px;
    }

    .adt-slot-grid {
        gap: 8px;
    }

    .adt-slot {
        min-height: 212px;
        padding: 14px 8px 10px;
        border-radius: 20px;
    }

    .adt-card-shell,
    .adt-slot-empty {
        width: min(100%, 116px);
    }

    .adt-altar {
        padding: 12px;
        border-radius: 24px;
    }

    .adt-altar-top {
        grid-template-columns: repeat(4, minmax(0, auto));
    }

    .adt-altar-main {
        grid-template-columns: 44px minmax(0, 1fr);
    }

    .adt-turn-cluster,
    .adt-stat-cluster {
        min-height: auto;
    }

    .adt-command-top {
        grid-template-columns: 1fr;
        justify-items: start;
    }

    .adt-notes-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .adt-mock-page {
        padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
    }

    .adt-shell-layout {
        gap: 12px;
    }

    .adt-brief {
        padding: 10px 12px;
        gap: 8px;
    }

    .adt-brief h1 {
        font-size: 1.16rem;
        line-height: 1.02;
    }

    .adt-brief p {
        display: none;
    }

    .adt-pill-row {
        gap: 6px;
    }

    .adt-pill,
    .adt-kicker {
        min-height: 24px;
        padding: 0 8px;
        font-size: 0.52rem;
        letter-spacing: 0.1em;
    }

    .adt-stage {
        border-radius: 26px;
    }

    .adt-topbar {
        grid-template-columns: 58px minmax(0, 1fr) 58px auto;
        gap: 6px;
    }

    .adt-score-chip,
    .adt-round-chip {
        min-height: 54px;
        padding: 6px 8px;
        border-radius: 16px;
    }

    .adt-score-value,
    .adt-round-value {
        font-size: 1.4rem;
    }

    .adt-menu-button {
        width: 52px;
        height: 52px;
        border-radius: 16px;
    }

    .adt-menu-button::before,
    .adt-menu-button::after,
    .adt-menu-button span {
        left: 14px;
        right: 14px;
    }

    .adt-ticker {
        grid-template-columns: auto minmax(0, 1fr);
        padding: 8px 10px;
        min-height: 48px;
    }

    .adt-ticker-state {
        display: none;
    }

    .adt-ticker-text {
        font-size: 0.82rem;
    }

    .adt-lane {
        padding: 18px 10px 10px;
        border-radius: 22px;
    }

    .adt-slot-grid {
        gap: 6px;
    }

    .adt-slot {
        min-height: 176px;
        padding: 12px 6px 8px;
        border-radius: 18px;
    }

    .adt-slot-label {
        min-height: 20px;
        padding: 0 6px;
        font-size: 0.46rem;
    }

    .adt-card-shell,
    .adt-slot-empty {
        width: min(100%, 92px);
        border-radius: 14px;
    }

    .adt-card-meta {
        gap: 4px;
        margin-top: 8px;
    }

    .adt-mini-stat {
        min-height: 28px;
        padding: 0 8px;
    }

    .adt-mini-stat strong {
        font-size: 0.78rem;
    }

    .adt-mini-stat span {
        font-size: 0.48rem;
    }

    .adt-altar {
        gap: 8px;
        padding: 10px;
    }

    .adt-altar-top {
        gap: 6px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .adt-altar-chip {
        min-height: 24px;
        padding: 0 8px;
        font-size: 0.46rem;
    }

    .adt-altar-main {
        gap: 8px;
        padding: 10px;
        border-radius: 18px;
    }

    .adt-altar-orb {
        width: 42px;
        height: 42px;
        border-radius: 14px;
    }

    .adt-altar-title {
        font-size: 1rem;
    }

    .adt-altar-sub {
        font-size: 0.78rem;
    }

    .adt-turn-cluster,
    .adt-stat-cluster {
        gap: 4px;
        padding: 8px;
        border-radius: 14px;
    }

    .adt-turn-value,
    .adt-stat-value {
        min-height: 26px;
        padding: 0 10px;
        font-size: 0.6rem;
    }

    .adt-command-rail {
        gap: 10px;
        padding: 12px 10px 14px;
        border-radius: 22px;
    }

    .adt-command-sub {
        font-size: 0.82rem;
    }

    .adt-cta {
        width: 100%;
    }

    .adt-hand-row {
        gap: 8px;
    }

    .adt-hand-card {
        width: min(100%, 106px);
        gap: 6px;
        padding: 6px;
        border-radius: 14px;
    }

    .adt-hand-caption strong {
        font-size: 0.7rem;
    }

    .adt-hand-caption span {
        font-size: 0.52rem;
    }

.adt-notes-grid {
        display: none;
    }
}

/* ==========================================
   Live app mapping - Phase 1 Block 1
   Header + ticker + duel altar
   ========================================== */

body[data-theme="wizardbattles"] #wb-game-header,
body[data-theme="wizardbattles"] #wb-next-effect-indicator,
body[data-theme="wizardbattles"] #wb-duel-context-indicator {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

body[data-theme="wizardbattles"] #wb-game-header::before,
body[data-theme="wizardbattles"] #wb-next-effect-indicator::before,
body[data-theme="wizardbattles"] #wb-duel-context-indicator::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0) 32%);
    opacity: 0.9;
    z-index: 0;
}

body[data-theme="wizardbattles"] #wb-game-header::after,
body[data-theme="wizardbattles"] #wb-next-effect-indicator::after,
body[data-theme="wizardbattles"] #wb-duel-context-indicator::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 12% 12%, rgba(120, 186, 255, 0.13), rgba(120, 186, 255, 0) 32%),
        radial-gradient(circle at 88% 18%, rgba(242, 193, 108, 0.11), rgba(242, 193, 108, 0) 28%);
    opacity: 0.92;
    z-index: 0;
}

body[data-theme="wizardbattles"] #wb-game-header > *,
body[data-theme="wizardbattles"] #wb-next-effect-indicator > *,
body[data-theme="wizardbattles"] #wb-duel-context-indicator > * {
    position: relative;
    z-index: 1;
}

body[data-theme="wizardbattles"] #wb-game-header {
    display: grid;
    grid-template-columns: minmax(76px, max-content) minmax(0, 1fr) minmax(76px, max-content);
    align-items: center;
    gap: 14px;
    padding: 12px 76px 12px 16px;
    border-radius: 28px 28px 20px 20px;
    border: 1px solid rgba(226, 239, 255, 0.14);
    background:
        radial-gradient(circle at 18% 14%, rgba(197, 106, 141, 0.12), rgba(197, 106, 141, 0) 24%),
        radial-gradient(circle at 52% -10%, rgba(120, 186, 255, 0.18), rgba(120, 186, 255, 0) 36%),
        radial-gradient(circle at 84% 12%, rgba(242, 193, 108, 0.14), rgba(242, 193, 108, 0) 28%),
        var(--adt-shell);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 18px 36px rgba(2, 7, 18, 0.44);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-center-chip {
    min-width: 0;
    display: flex;
    justify-content: center;
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip {
    min-height: 68px;
    min-width: 76px;
    gap: 4px;
    padding: 8px 15px 10px;
    border-radius: 22px;
    border: 1px solid var(--adt-line-soft);
    background: var(--adt-panel);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 14px 24px rgba(2, 7, 18, 0.28);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--cpu {
    border-color: rgba(255, 186, 209, 0.16);
    background: var(--adt-rival-panel);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--player {
    border-color: rgba(255, 222, 159, 0.16);
    background:
        radial-gradient(circle at 18% 18%, rgba(242, 193, 108, 0.14), rgba(242, 193, 108, 0) 34%),
        linear-gradient(160deg, rgba(52, 38, 16, 0.94), rgba(19, 14, 8, 0.98));
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-label,
body[data-theme="wizardbattles"] #wb-game-header .wb-round-label {
    color: rgba(211, 225, 244, 0.62);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--cpu .wb-score-label {
    color: rgba(255, 208, 223, 0.7);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--player .wb-score-label {
    color: rgba(255, 226, 178, 0.72);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-value {
    font-size: clamp(1.48rem, 2vw, 1.72rem);
    color: var(--adt-ink-strong);
    text-shadow:
        0 0 18px rgba(120, 186, 255, 0.28),
        0 3px 8px rgba(0, 0, 0, 0.4);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--cpu .wb-score-value {
    color: #ffd3df;
    text-shadow:
        0 0 20px rgba(197, 106, 141, 0.3),
        0 3px 8px rgba(0, 0, 0, 0.42);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--player .wb-score-value {
    color: #ffe4a8;
    text-shadow:
        0 0 22px rgba(242, 193, 108, 0.34),
        0 3px 8px rgba(0, 0, 0, 0.42);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-round-chip {
    min-height: 64px;
    min-width: 132px;
    gap: 7px;
    padding: 9px 20px;
    border-radius: 999px;
    border: 1px solid rgba(171, 205, 247, 0.22);
    background:
        radial-gradient(circle at 50% 0%, rgba(120, 186, 255, 0.22), rgba(120, 186, 255, 0) 44%),
        linear-gradient(160deg, rgba(17, 32, 63, 0.95), rgba(11, 20, 42, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 16px 28px rgba(2, 7, 18, 0.3),
        0 0 24px rgba(120, 186, 255, 0.12);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-round-icon {
    color: #f7dca2;
    text-shadow: 0 0 16px rgba(242, 193, 108, 0.32);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-round-value {
    font-size: clamp(1.08rem, 1.5vw, 1.24rem);
    color: #f4f8ff;
    text-shadow:
        0 0 18px rgba(120, 186, 255, 0.28),
        0 3px 8px rgba(0, 0, 0, 0.4);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    min-height: 56px;
    margin: 8px clamp(10px, 1.8vw, 16px) 6px;
    padding: 10px 14px;
    border-radius: 20px;
    border: 1px solid rgba(203, 227, 255, 0.14);
    background:
        radial-gradient(circle at 12% 18%, rgba(120, 186, 255, 0.18), rgba(120, 186, 255, 0) 30%),
        radial-gradient(circle at 84% 22%, rgba(242, 193, 108, 0.1), rgba(242, 193, 108, 0) 26%),
        var(--adt-panel);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 16px 28px rgba(2, 7, 18, 0.26);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-icon {
    width: 32px;
    height: 32px;
    border-radius: 12px;
    border: 1px solid rgba(242, 193, 108, 0.22);
    background:
        radial-gradient(circle at 34% 28%, rgba(255, 245, 208, 0.42), rgba(255, 245, 208, 0) 54%),
        linear-gradient(160deg, rgba(72, 52, 18, 0.92), rgba(31, 22, 9, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 10px 18px rgba(2, 7, 18, 0.22);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-copy {
    gap: 3px;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-label {
    font-size: 0.56rem;
    letter-spacing: 0.16em;
    color: rgba(211, 225, 244, 0.58);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
    font-size: 0.9rem;
    color: var(--adt-ink-strong);
    text-shadow: none;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-owner {
    min-width: 92px;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    border-color: rgba(171, 205, 247, 0.22);
    background: rgba(255, 255, 255, 0.05);
    color: var(--adt-ink-soft);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-owner.owner-player {
    border-color: rgba(118, 226, 191, 0.28);
    background: rgba(44, 116, 92, 0.24);
    color: #bff8e5;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-owner.owner-cpu {
    border-color: rgba(244, 148, 177, 0.28);
    background: rgba(98, 37, 54, 0.24);
    color: #ffd1df;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-owner.owner-neutral {
    color: rgba(227, 236, 249, 0.7);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator {
    display: grid;
    grid-template-columns: minmax(120px, 0.96fr) minmax(0, 1.7fr) minmax(208px, 1fr);
    gap: 10px;
    align-items: stretch;
    width: min(960px, calc(100% - 24px));
    max-width: min(960px, calc(100% - 24px));
    margin: 4px auto 10px;
    padding: 11px;
    border-radius: 30px;
    border: 1px solid rgba(var(--ctx-rgb, 125, 186, 255), 0.22);
    background:
        radial-gradient(circle at 50% 0%, rgba(242, 193, 108, 0.14), rgba(242, 193, 108, 0) 38%),
        radial-gradient(circle at 12% 50%, rgba(var(--ctx-rgb, 125, 186, 255), 0.16), rgba(var(--ctx-rgb, 125, 186, 255), 0) 34%),
        radial-gradient(circle at 86% 26%, rgba(168, 124, 214, 0.12), rgba(168, 124, 214, 0) 28%),
        var(--adt-altar);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.1),
        0 22px 38px rgba(2, 7, 18, 0.34),
        0 0 26px rgba(var(--ctx-rgb, 125, 186, 255), 0.1);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage {
    gap: 6px;
    min-width: 0;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage-chip {
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(196, 219, 249, 0.18);
    background: linear-gradient(160deg, rgba(15, 28, 58, 0.9), rgba(8, 15, 32, 0.94));
    color: rgba(232, 240, 250, 0.88);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 10px 18px rgba(2, 7, 18, 0.2);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage-chip--round {
    border-color: rgba(171, 205, 247, 0.2);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage-chip--duel {
    border-color: rgba(242, 193, 108, 0.24);
    background:
        radial-gradient(circle at 16% 18%, rgba(242, 193, 108, 0.16), rgba(242, 193, 108, 0) 32%),
        linear-gradient(160deg, rgba(66, 49, 18, 0.92), rgba(23, 17, 9, 0.96));
    color: #ffe8b6;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
    align-content: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 20px;
    border: 1px solid rgba(var(--ctx-rgb, 125, 186, 255), 0.2);
    background:
        radial-gradient(circle at 10% 22%, rgba(var(--ctx-rgb, 125, 186, 255), 0.12), rgba(var(--ctx-rgb, 125, 186, 255), 0) 36%),
        linear-gradient(160deg, rgba(14, 29, 58, 0.92), rgba(7, 15, 31, 0.96));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 16px 30px rgba(2, 7, 18, 0.22);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-orb {
    width: 58px;
    height: 58px;
    border-radius: 20px;
    border: 1px solid rgba(var(--ctx-rgb, 125, 186, 255), 0.26);
    background:
        radial-gradient(circle at 34% 28%, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0) 54%),
        linear-gradient(160deg, rgba(31, 57, 106, 0.96), rgba(13, 26, 62, 0.98));
    box-shadow:
        0 12px 22px rgba(2, 7, 18, 0.28),
        0 0 24px rgba(var(--ctx-rgb, 125, 186, 255), 0.12);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-icon {
    font-size: 1.32rem;
    color: #f2f7ff;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-copy {
    /* Ocultado: el título/subtítulo ("Tu Apertura", "Tu Turno") se elimina
       para dar más protagonismo a la info de la próxima habilidad */
    display: none;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-title {
    font-size: clamp(0.88rem, 1.22vw, 1rem);
    letter-spacing: 0.04em;
    color: var(--adt-ink-strong);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-sub {
    font-size: clamp(0.66rem, 0.92vw, 0.76rem);
    line-height: 1.14;
    color: rgba(221, 232, 247, 0.78);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
    justify-items: stretch;
    gap: 6px;
    min-height: 84px;
    padding: 8px 10px 9px;
    border-radius: 18px;
    border: 1px solid rgba(var(--ctx-rgb, 125, 186, 255), 0.18);
    background: linear-gradient(160deg, rgba(10, 22, 48, 0.86), rgba(7, 15, 31, 0.94));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 12px 22px rgba(2, 7, 18, 0.22);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel--turn {
    border-color: rgba(118, 226, 191, 0.18);
    background:
        radial-gradient(circle at 18% 16%, rgba(87, 206, 178, 0.14), rgba(87, 206, 178, 0) 34%),
        linear-gradient(160deg, rgba(11, 31, 44, 0.9), rgba(7, 17, 28, 0.96));
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel--stat {
    border-color: rgba(242, 193, 108, 0.18);
    background:
        radial-gradient(circle at 18% 16%, rgba(242, 193, 108, 0.14), rgba(242, 193, 108, 0) 34%),
        linear-gradient(160deg, rgba(44, 32, 13, 0.92), rgba(19, 14, 8, 0.96));
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail-label {
    font-size: 0.54rem;
    color: rgba(221, 232, 247, 0.58);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-turn {
    min-width: 0;
    min-height: 30px;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-cluster {
    flex-direction: column;
    gap: 8px;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-ring {
    width: 46px;
    height: 46px;
    border-radius: 16px;
    border: 1px solid rgba(255, 223, 164, 0.28);
    background:
        radial-gradient(circle at 34% 28%, rgba(255, 250, 230, 0.48), rgba(255, 250, 230, 0) 54%),
        linear-gradient(160deg, rgba(104, 76, 28, 0.94), rgba(40, 29, 13, 0.98));
    box-shadow:
        0 12px 22px rgba(2, 7, 18, 0.22),
        0 0 18px rgba(242, 193, 108, 0.14);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-icon {
    width: 24px;
    height: 24px;
    object-fit: contain;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.18));
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-name {
    max-width: 100%;
    font-size: 0.74rem;
    line-height: 1.05;
    letter-spacing: 0.08em;
    color: #fff1c8;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-name.is-pending {
    color: rgba(240, 233, 214, 0.72);
}

@media (max-width: 767px) {
    body[data-theme="wizardbattles"] #wb-game-header {
        width: calc(100% - 12px);
        margin: 0 auto;
        grid-template-columns: minmax(54px, max-content) minmax(0, 1fr) minmax(54px, max-content);
        gap: 8px;
        padding:
            max(env(safe-area-inset-top), 10px)
            calc(58px + max(env(safe-area-inset-right), 10px))
            10px
            max(env(safe-area-inset-left), 10px);
        border-radius: 24px 24px 18px 18px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip {
        min-width: 54px;
        min-height: 58px;
        padding: 6px 10px 7px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-label,
    body[data-theme="wizardbattles"] #wb-game-header .wb-round-label {
        font-size: 0.46rem;
        letter-spacing: 0.14em;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-value {
        font-size: clamp(1.18rem, 4vw, 1.38rem);
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-round-chip {
        min-width: 98px;
        min-height: 54px;
        gap: 5px;
        padding: 7px 12px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-round-value {
        font-size: 1rem;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator {
        width: calc(100% - 12px);
        margin: 6px auto 4px;
        min-height: 44px;
        gap: 10px;
        padding: 8px 10px;
        border-radius: 16px;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-icon {
        width: 24px;
        height: 24px;
        border-radius: 10px;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-label {
        font-size: 0.46rem;
        letter-spacing: 0.12em;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
        font-size: 0.68rem;
        line-height: 1.14;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-owner {
        min-width: 62px;
        min-height: 24px;
        padding: 0 8px;
        font-size: 0.48rem;
        letter-spacing: 0.08em;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        width: calc(100% - 12px);
        max-width: calc(100% - 12px);
        margin: 3px auto 6px;
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 10px;
        border-radius: 24px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage-chip {
        min-height: 24px;
        padding: 0 8px;
        font-size: 0.48rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
        gap: 10px;
        padding: 11px 12px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-orb {
        width: 38px;
        height: 38px;
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-icon {
        font-size: 0.96rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-title {
        font-size: 0.82rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-sub {
        font-size: 0.66rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail {
        gap: 8px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
        min-height: 76px;
        gap: 6px;
        padding: 9px 8px;
        border-radius: 16px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail-label {
        font-size: 0.48rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-turn {
        min-height: 28px;
        font-size: 0.62rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-cluster {
        flex-direction: row;
        gap: 6px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-ring {
        width: 26px;
        height: 26px;
        border-radius: 10px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-name {
        max-width: 90px;
        font-size: 0.62rem;
    }
}

/* ==========================================
   Live app mapping - Phase 1 Block 2
   Arena readability + mobile viewport recovery
   ========================================== */

body[data-theme="wizardbattles"] #game-board .battle-arena {
    --wb-slot-w: clamp(100px, 12vw, 142px);
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 50% 50%, rgba(246, 200, 106, 0.11), rgba(246, 200, 106, 0) 18%),
        radial-gradient(circle at 16% 22%, rgba(183, 74, 110, 0.18), rgba(183, 74, 110, 0) 30%),
        radial-gradient(circle at 84% 78%, rgba(62, 186, 161, 0.18), rgba(62, 186, 161, 0) 30%),
        linear-gradient(180deg, rgba(4, 8, 19, 0.36), rgba(3, 7, 16, 0.16));
}

body[data-theme="wizardbattles"] #game-board .battle-arena::before,
body[data-theme="wizardbattles"] #game-board .battle-arena::after {
    content: '';
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

body[data-theme="wizardbattles"] #game-board .battle-arena::before {
    left: 50%;
    top: 10%;
    width: min(82%, 980px);
    height: 1px;
    transform: translateX(-50%);
    background: linear-gradient(90deg, rgba(0, 0, 0, 0), rgba(246, 200, 106, 0.28), rgba(0, 0, 0, 0));
    opacity: 0.8;
}

body[data-theme="wizardbattles"] #game-board .battle-arena::after {
    inset: 14% 10% 18%;
    border-radius: 34px;
    background:
        radial-gradient(circle at 50% 48%, rgba(246, 200, 106, 0.06), rgba(246, 200, 106, 0) 28%),
        radial-gradient(circle at 28% 36%, rgba(183, 74, 110, 0.07), rgba(183, 74, 110, 0) 26%),
        radial-gradient(circle at 72% 64%, rgba(62, 186, 161, 0.08), rgba(62, 186, 161, 0) 24%);
    opacity: 0.92;
}

body[data-theme="wizardbattles"] #game-board .arena-rows {
    position: relative;
    z-index: 1;
    gap: clamp(5px, 0.75vw, 9px);
    padding: clamp(5px, 0.75vw, 9px);
    background:
        linear-gradient(180deg, rgba(44, 18, 31, 0.16), rgba(44, 18, 31, 0) 34%),
        linear-gradient(0deg, rgba(10, 75, 70, 0.14), rgba(10, 75, 70, 0) 36%),
        linear-gradient(180deg, rgba(7, 12, 28, 0.72), rgba(4, 8, 20, 0.34));
    border-color: rgba(216, 225, 239, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 18px 40px rgba(2, 8, 18, 0.2);
}

body[data-theme="wizardbattles"] #game-board .lineup-row {
    gap: clamp(4px, 0.8vw, 8px);
    padding: clamp(12px, 1.5vw, 18px) clamp(6px, 1vw, 10px) clamp(7px, 0.9vw, 11px);
    border-radius: clamp(18px, 2.2vw, 24px);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.07),
        0 14px 26px rgba(2, 8, 18, 0.22);
}

body[data-theme="wizardbattles"] #game-board .lineup-row::before {
    background:
        radial-gradient(circle at 18% 16%, rgba(255, 189, 208, 0.08) 0%, rgba(255, 189, 208, 0) 38%),
        radial-gradient(circle at 82% 84%, rgba(161, 225, 210, 0.08) 0%, rgba(161, 225, 210, 0) 40%);
    opacity: 1;
}

body[data-theme="wizardbattles"] #game-board .rival-zone {
    border-color: rgba(255, 184, 208, 0.16);
    background:
        radial-gradient(circle at 16% 18%, rgba(181, 63, 101, 0.24), rgba(181, 63, 101, 0) 28%),
        radial-gradient(circle at 84% 78%, rgba(134, 74, 152, 0.18), rgba(134, 74, 152, 0) 34%),
        linear-gradient(160deg, rgba(40, 19, 43, 0.96) 0%, rgba(17, 14, 34, 0.98) 100%);
}

body[data-theme="wizardbattles"] #game-board .player-zone {
    border-color: rgba(144, 235, 211, 0.16);
    background:
        radial-gradient(circle at 18% 18%, rgba(38, 128, 114, 0.24), rgba(38, 128, 114, 0) 30%),
        radial-gradient(circle at 82% 82%, rgba(71, 189, 168, 0.2), rgba(71, 189, 168, 0) 34%),
        linear-gradient(160deg, rgba(11, 38, 44, 0.96) 0%, rgba(10, 19, 31, 0.98) 100%);
}

body[data-theme="wizardbattles"] #game-board .rival-zone::after {
    border-color: rgba(255, 173, 203, 0.3);
    background: rgba(78, 20, 41, 0.56);
    color: #ffd8e4;
}

body[data-theme="wizardbattles"] #game-board .player-zone::after {
    border-color: rgba(129, 236, 210, 0.28);
    background: rgba(10, 77, 70, 0.54);
    color: #c7fff1;
}

body[data-theme="wizardbattles"] #game-board .slot-wrapper {
    gap: 4px;
    padding: clamp(2px, 0.45vw, 5px);
    border-radius: 16px;
    overflow: visible;
    border-color: rgba(255, 255, 255, 0.05);
    background:
        linear-gradient(180deg, rgba(8, 14, 27, 0.34), rgba(8, 14, 27, 0.12));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 10px 18px rgba(2, 8, 18, 0.12);
}

body[data-theme="wizardbattles"] #game-board .rival-zone .slot-wrapper {
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 192, 209, 0.08), rgba(255, 192, 209, 0) 42%),
        linear-gradient(180deg, rgba(25, 13, 30, 0.38), rgba(25, 13, 30, 0.14));
}

body[data-theme="wizardbattles"] #game-board .player-zone .slot-wrapper {
    background:
        radial-gradient(circle at 50% 0%, rgba(167, 247, 222, 0.08), rgba(167, 247, 222, 0) 42%),
        linear-gradient(180deg, rgba(10, 29, 31, 0.38), rgba(10, 29, 31, 0.14));
}

body[data-theme="wizardbattles"] #game-board .card-slot {
    position: relative;
    overflow: visible;
    border-color: rgba(217, 224, 236, 0.14);
    background:
        radial-gradient(circle at 50% 12%, rgba(246, 200, 106, 0.08), rgba(246, 200, 106, 0) 28%),
        linear-gradient(160deg, rgba(9, 14, 28, 0.95), rgba(5, 9, 19, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        inset 0 14px 24px rgba(1, 7, 18, 0.2),
        0 10px 18px rgba(2, 8, 18, 0.16);
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled .card-mini {
    width: calc(100% + 4px);
    height: calc(100% + 4px);
    margin: -2px;
    transform: scale(1.015);
    transform-origin: center center;
    filter: drop-shadow(0 12px 22px rgba(2, 8, 18, 0.24));
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled.has-slot-result-meta {
    align-items: center;
    justify-content: center;
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled.has-slot-result-meta .card-mini {
    height: calc(100% + 4px);
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled .card-mini img {
    border-radius: 8px;
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled .card-mini.card-mini--arena {
    width: 100%;
    height: 100%;
    margin: 0;
    transform: none;
    filter: none;
    display: block;
    overflow: visible;
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled.has-slot-result-meta .card-mini.card-mini--arena {
    height: 100%;
}

body[data-theme="wizardbattles"] #game-board .slot-art-shell {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: inherit;
    background:
        radial-gradient(circle at 50% 18%, rgba(255, 237, 190, 0.14), rgba(255, 237, 190, 0) 32%),
        linear-gradient(180deg, rgba(7, 14, 28, 0.06), rgba(7, 14, 28, 0.22));
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.05),
        inset 0 -18px 24px rgba(2, 8, 18, 0.14);
}

body[data-theme="wizardbattles"] #game-board .slot-art-shell[data-owner='cpu'] {
    background:
        radial-gradient(circle at 50% 18%, rgba(255, 209, 225, 0.16), rgba(255, 209, 225, 0) 34%),
        linear-gradient(180deg, rgba(35, 14, 31, 0.12), rgba(9, 8, 18, 0.24));
}

body[data-theme="wizardbattles"] #game-board .slot-art-shell[data-owner='player'] {
    background:
        radial-gradient(circle at 50% 18%, rgba(198, 255, 234, 0.14), rgba(198, 255, 234, 0) 34%),
        linear-gradient(180deg, rgba(11, 39, 36, 0.12), rgba(5, 13, 18, 0.24));
}

body[data-theme="wizardbattles"] #game-board .slot-art-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 20%;
    display: block;
    transform: scale(1.08);
    transform-origin: center top;
    filter: saturate(1.05) contrast(1.02);
}

body[data-theme="wizardbattles"] #game-board .card-slot.active-duel .slot-art-image,
body[data-theme="wizardbattles"] #game-board .card-slot.win .slot-art-image {
    transform: scale(1.12);
}

body[data-theme="wizardbattles"] #game-board .card-slot.loss .slot-art-image {
    filter: saturate(0.92) brightness(0.94);
}

body[data-theme="wizardbattles"] #game-board .slot-art-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0) 22%),
        linear-gradient(180deg, rgba(0, 0, 0, 0) 44%, rgba(1, 6, 14, 0.16) 78%, rgba(1, 6, 14, 0.34) 100%);
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge {
    position: absolute;
    top: 7px;
    right: 7px;
    z-index: 7;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 28px;
    padding: 3px 8px 3px 4px;
    border: 1px solid rgba(255, 216, 149, 0.34);
    border-radius: 13px;
    clip-path: polygon(10% 0, 100% 0, 100% 78%, 88% 100%, 0 100%, 0 20%);
    background:
        radial-gradient(circle at 28% 24%, rgba(255, 247, 229, 0.34), rgba(255, 247, 229, 0) 52%),
        linear-gradient(150deg, rgba(93, 68, 25, 0.96), rgba(35, 24, 10, 0.98));
    box-shadow:
        0 10px 18px rgba(2, 8, 18, 0.28),
        0 0 0 1px rgba(255, 210, 126, 0.08);
    transform: translate(8%, -10%);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge.is-win {
    border-color: rgba(144, 237, 176, 0.4);
    background:
        radial-gradient(circle at 28% 24%, rgba(231, 255, 241, 0.34), rgba(231, 255, 241, 0) 52%),
        linear-gradient(150deg, rgba(20, 88, 57, 0.96), rgba(9, 39, 24, 0.98));
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge.is-loss {
    border-color: rgba(255, 165, 183, 0.42);
    background:
        radial-gradient(circle at 28% 24%, rgba(255, 235, 240, 0.3), rgba(255, 235, 240, 0) 52%),
        linear-gradient(150deg, rgba(105, 31, 51, 0.96), rgba(46, 14, 24, 0.98));
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge.is-tie {
    border-color: rgba(176, 204, 239, 0.34);
    background:
        radial-gradient(circle at 28% 24%, rgba(244, 248, 255, 0.32), rgba(244, 248, 255, 0) 52%),
        linear-gradient(150deg, rgba(39, 58, 90, 0.96), rgba(18, 27, 45, 0.98));
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge-icon-wrap {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge-icon {
    width: 18px;
    height: 18px;
    object-fit: contain;
    display: block;
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge-value {
    font-family: var(--font-ui-metrics, var(--font-primary-ui));
    font-size: 0.72rem;
    font-weight: 900;
    line-height: 1;
    color: #fff8eb;
    letter-spacing: 0.01em;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.44);
}

body[data-theme="wizardbattles"] #game-board .rival-zone .card-slot {
    border-color: rgba(255, 190, 214, 0.2);
    background:
        radial-gradient(circle at 50% 12%, rgba(255, 205, 220, 0.1), rgba(255, 205, 220, 0) 26%),
        radial-gradient(circle at 50% 42%, rgba(161, 104, 189, 0.12), rgba(161, 104, 189, 0) 54%),
        linear-gradient(160deg, rgba(35, 17, 41, 0.96), rgba(15, 10, 27, 0.98));
}

body[data-theme="wizardbattles"] #game-board .player-zone .card-slot {
    border-color: rgba(157, 240, 218, 0.22);
    background:
        radial-gradient(circle at 50% 12%, rgba(187, 255, 235, 0.1), rgba(187, 255, 235, 0) 26%),
        radial-gradient(circle at 50% 42%, rgba(66, 190, 161, 0.12), rgba(66, 190, 161, 0) 54%),
        linear-gradient(160deg, rgba(10, 34, 37, 0.96), rgba(7, 14, 22, 0.98));
}

body[data-theme="wizardbattles"] #game-board .card-slot.empty {
    border-style: solid;
}

body[data-theme="wizardbattles"] #game-board .rival-zone .card-slot.empty {
    background-image:
        linear-gradient(145deg, rgba(31, 16, 36, 0.88), rgba(46, 18, 43, 0.7)),
        radial-gradient(circle at 50% 42%, rgba(255, 201, 217, 0.12), rgba(255, 201, 217, 0) 62%),
        url('../../assets/frames/slot_empty.avif');
    border-color: rgba(255, 189, 210, 0.22);
}

body[data-theme="wizardbattles"] #game-board .player-zone .card-slot.empty {
    background-image:
        linear-gradient(145deg, rgba(10, 28, 29, 0.88), rgba(14, 45, 44, 0.68)),
        radial-gradient(circle at 50% 42%, rgba(176, 255, 231, 0.12), rgba(176, 255, 231, 0) 62%),
        url('../../assets/frames/slot_empty.avif');
    border-color: rgba(157, 240, 218, 0.22);
}

body[data-theme="wizardbattles"] #game-board .slot-between-layer {
    display: none !important;
    min-height: 0;
}

body[data-theme="wizardbattles"] #game-board .slot-result-meta.slot-result-meta--between {
    display: none !important;
    max-width: min(100%, 82px);
    padding: 2px 7px;
    gap: 5px;
}

body[data-theme="wizardbattles"] #game-board .slot-result-meta-icon {
    width: 20px;
    height: 20px;
}

body[data-theme="wizardbattles"] #game-board .slot-result-meta-text {
    font-size: clamp(0.66rem, 1.3vw, 0.82rem);
}

body[data-theme="wizardbattles"] .pos-label-vertical {
    display: none !important;
}

body[data-theme="wizardbattles"] .mod-list-vertical {
    display: none !important;
}

body[data-theme="wizardbattles"] #combat-bottom-bar {
    background:
        radial-gradient(circle at 16% 0%, rgba(55, 171, 150, 0.18), rgba(55, 171, 150, 0) 28%),
        radial-gradient(circle at 84% 0%, rgba(183, 74, 110, 0.14), rgba(183, 74, 110, 0) 26%),
        radial-gradient(circle at 50% 0%, rgba(246, 200, 106, 0.12), rgba(246, 200, 106, 0) 34%),
        linear-gradient(180deg, rgba(8, 15, 28, 0.88), rgba(6, 11, 20, 0.98));
}

@media (min-width: 768px) {
    body[data-theme="wizardbattles"] #game-board {
        display: flex;
        flex-direction: column;
        min-height: calc(100dvh - 28px);
    }

    body[data-theme="wizardbattles"] #wb-game-header {
        padding:
            clamp(8px, 1vw, 12px)
            72px
            clamp(8px, 1vw, 12px)
            clamp(12px, 1.4vw, 18px);
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator {
        min-height: 48px;
        margin: 6px clamp(10px, 1vw, 16px) 4px;
        padding: 8px 12px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
        font-size: 0.82rem;
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena {
        --wb-slot-w: clamp(132px, 9.2vw, 170px);
        display: flex;
        flex: 1 1 auto;
        flex-direction: column;
        min-height: 0;
        width: min(1500px, calc(100% - 18px));
        max-width: min(1500px, calc(100% - 18px));
        margin: 0 auto;
        padding: 4px 6px 10px;
        gap: 8px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena::after {
        inset: 12% 7% 15%;
        border-radius: 30px;
    }

    body[data-theme="wizardbattles"] #game-board .arena-rows {
        flex: 1 1 auto;
        min-height: 0;
        gap: 6px;
        padding: 6px;
        border-radius: 28px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row {
        display: grid;
        grid-template-columns: repeat(3, max-content);
        width: min(980px, 100%);
        margin-inline: auto;
        justify-content: center;
        gap: clamp(16px, 2.3vw, 32px);
        padding: clamp(14px, 1.4vw, 18px) clamp(8px, 1vw, 12px) clamp(6px, 0.8vw, 10px);
        border-radius: 22px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row::after {
        top: 8px;
        left: 10px;
        min-height: 20px;
        padding: 0 8px;
        font-size: 0.54rem;
    }

    body[data-theme="wizardbattles"] #game-board .slot-wrapper {
        gap: 4px;
        padding: 4px 4px 5px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #game-board .card-slot {
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        grid-template-columns: minmax(116px, 0.72fr) minmax(0, 1.7fr) minmax(196px, 0.92fr);
        width: min(980px, calc(100% - 12px));
        max-width: min(980px, calc(100% - 12px));
        margin: 2px auto 6px;
        padding: 8px 10px;
        gap: 8px;
        border-radius: 24px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage {
        gap: 5px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage-chip {
        min-height: 24px;
        padding: 0 9px;
        font-size: 0.5rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
        gap: 8px;
        padding: 8px 10px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-orb {
        width: 48px;
        height: 48px;
        border-radius: 16px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-title {
        font-size: clamp(0.82rem, 1vw, 0.96rem);
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-sub {
        font-size: clamp(0.62rem, 0.78vw, 0.72rem);
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail {
        gap: 6px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
        min-height: 68px;
        gap: 4px;
        padding: 7px 8px;
        border-radius: 16px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-turn {
        min-height: 28px;
        font-size: 0.64rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-cluster {
        gap: 6px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-ring {
        width: 34px;
        height: 34px;
        border-radius: 12px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-name {
        font-size: 0.68rem;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        width: min(860px, calc(100% - 28px));
        margin: 0 auto 6px;
        padding: 8px 14px 12px;
        border-radius: 28px;
        border: 1px solid rgba(168, 198, 237, 0.16);
        box-shadow:
            0 18px 32px rgba(2, 8, 18, 0.24),
            inset 0 1px 0 rgba(255, 255, 255, 0.06);
        pointer-events: auto;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar > .w-full {
        padding-inline: 0;
    }

    body[data-theme="wizardbattles"] #hand-dock-toggle-btn {
        display: none;
    }

    body[data-theme="wizardbattles"] .hand-dock {
        --wb-hand-card-w: clamp(102px, 6.5vw, 126px);
        --wb-hand-overlap: clamp(18px, 1.4vw, 28px);
        padding: 0;
        border-top: 0;
    }

    body[data-theme="wizardbattles"] .hand-dock-header {
        display: none;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        min-height: clamp(122px, 13.4vw, 162px);
        overflow-y: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        justify-content: center;
        padding: 2px 10px 8px;
        overflow-x: auto;
        overflow-y: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini {
        box-shadow:
            0 12px 26px rgba(2, 8, 18, 0.3),
            0 0 0 1px rgba(193, 212, 242, 0.2);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar .combat-action-row {
        width: 100%;
        padding: 4px 0 0;
        gap: 10px;
        justify-content: space-between;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar .combat-bottom-actions {
        flex: 0 0 auto;
        overflow: visible;
        gap: 8px;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-exit-combat,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-lineup-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-hand-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-next-round-main {
        min-height: 38px;
        padding: 6px 12px;
        border-radius: 12px;
        font-size: 0.78rem;
    }
}

@media (min-width: 768px) and (max-height: 840px) {
    body[data-theme="wizardbattles"] #wb-game-header {
        padding:
            6px
            68px
            6px
            12px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip {
        min-height: 56px;
        min-width: 56px;
        padding: 5px 10px 6px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-round-chip {
        min-width: 116px;
        min-height: 56px;
        padding: 7px 14px;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator {
        min-height: 42px;
        margin-bottom: 2px;
        padding: 6px 10px;
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena {
        --wb-slot-w: clamp(118px, 8vw, 146px);
        gap: 6px;
        padding-bottom: 8px;
    }

    body[data-theme="wizardbattles"] #game-board .arena-rows {
        gap: 5px;
        padding: 5px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row {
        width: min(920px, 100%);
        gap: clamp(14px, 1.9vw, 24px);
        padding: 12px 7px 5px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        width: min(920px, calc(100% - 10px));
        max-width: min(920px, calc(100% - 10px));
        padding: 7px 8px;
        gap: 6px;
        border-radius: 20px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
        padding: 7px 8px;
        gap: 7px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-orb {
        width: 42px;
        height: 42px;
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
        min-height: 60px;
        padding: 6px 7px;
        gap: 3px;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar {
        width: min(820px, calc(100% - 22px));
        padding: 6px 12px 8px;
        border-radius: 24px;
    }

    body[data-theme="wizardbattles"] .hand-dock {
        --wb-hand-card-w: clamp(92px, 6.4vw, 114px);
        --wb-hand-overlap: clamp(16px, 1.2vw, 24px);
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        min-height: 146px;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar .combat-action-row {
        padding-top: 2px;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-exit-combat,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-lineup-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-hand-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-next-round-main {
        min-height: 34px;
        padding: 5px 10px;
        font-size: 0.74rem;
    }
}

@media (max-width: 767px) {
    body[data-theme="wizardbattles"] #wb-game-header {
        gap: 6px;
        padding:
            max(env(safe-area-inset-top), 8px)
            calc(54px + max(env(safe-area-inset-right), 10px))
            7px
            max(env(safe-area-inset-left), 8px);
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip {
        min-height: 52px;
        min-width: 48px;
        padding: 5px 8px 6px;
        border-radius: 16px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-round-chip {
        min-width: 88px;
        min-height: 48px;
        padding: 6px 10px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-value {
        font-size: clamp(1.12rem, 3.9vw, 1.3rem);
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-round-value {
        font-size: 0.94rem;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator {
        min-height: 32px;
        gap: 8px;
        padding: 4px 8px;
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-icon {
        width: 18px;
        height: 18px;
        border-radius: 8px;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
        font-size: 0.62rem;
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena {
        --wb-slot-w: clamp(72px, 20.4vw, 88px);
        padding: 1px 3px 4px;
        gap: 3px;
        background:
            radial-gradient(circle at 50% 48%, rgba(246, 200, 106, 0.13), rgba(246, 200, 106, 0) 16%),
            radial-gradient(circle at 14% 20%, rgba(183, 74, 110, 0.2), rgba(183, 74, 110, 0) 26%),
            radial-gradient(circle at 86% 80%, rgba(62, 186, 161, 0.22), rgba(62, 186, 161, 0) 28%),
            linear-gradient(180deg, rgba(4, 8, 19, 0.34), rgba(3, 7, 16, 0.12));
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena::after {
        inset: 12% 6% 14%;
        border-radius: 24px;
    }

    body[data-theme="wizardbattles"] #game-board .arena-rows {
        gap: 4px;
        padding: 4px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row {
        gap: 3px;
        padding: 10px 3px 4px;
        border-radius: 16px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row::after {
        top: 4px;
        left: 4px;
        min-height: 16px;
        padding: 0 5px;
        font-size: 0.44rem;
        letter-spacing: 0.12em;
    }

    body[data-theme="wizardbattles"] .slot-wrapper {
        gap: 2px;
        padding: 1px 0 2px;
        border-radius: 12px;
    }

    body[data-theme="wizardbattles"] .mod-list-vertical {
        display: none !important;
    }

    body[data-theme="wizardbattles"] #game-board .card-slot {
        height: calc(var(--wb-slot-w) * 1.28);
        border-radius: 10px;
    }

    body[data-theme="wizardbattles"] #game-board .rival-zone .card-slot {
        width: calc(var(--wb-slot-w) * 0.97);
        height: calc(var(--wb-slot-w) * 1.24);
    }

    body[data-theme="wizardbattles"] #game-board .slot-stat-badge {
        top: 6px;
        right: 5px;
        min-height: 22px;
        padding: 2px 6px 2px 4px;
        border-radius: 11px;
        transform: translate(6%, -8%);
    }

    body[data-theme="wizardbattles"] #game-board .slot-stat-badge-icon-wrap {
        width: 15px;
        height: 15px;
    }

    body[data-theme="wizardbattles"] #game-board .slot-stat-badge-icon {
        width: 11px;
        height: 11px;
    }

    body[data-theme="wizardbattles"] #game-board .slot-stat-badge-value {
        font-size: 0.58rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        grid-template-columns: minmax(0, 1fr) minmax(112px, 0.88fr);
        gap: 4px;
        padding: 6px;
        border-radius: 18px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage {
        grid-column: 1 / -1;
        gap: 4px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stage-chip {
        min-height: 18px;
        padding: 0 6px;
        font-size: 0.41rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
        grid-column: 1 / 2;
        padding: 6px 7px;
        gap: 6px;
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-orb {
        width: 40px;
        height: 40px;
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-title {
        font-size: 0.72rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-sub {
        font-size: 0.56rem;
        line-height: 1;
        -webkit-line-clamp: 1;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail {
        grid-column: 2 / 3;
        grid-template-columns: 1fr;
        gap: 6px;
        align-self: stretch;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
        min-height: 0;
        gap: 3px;
        padding: 5px 6px;
        border-radius: 12px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-rail-label {
        font-size: 0.44rem;
        letter-spacing: 0.12em;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-turn {
        min-height: 22px;
        font-size: 0.54rem;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-cluster {
        flex-direction: row;
        gap: 5px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-ring {
        width: 24px;
        height: 24px;
        border-radius: 9px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-stat-name {
        max-width: 70px;
        font-size: 0.54rem;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar {
        width: calc(100% - 8px);
        margin-inline: auto;
        border-radius: 20px 20px 0 0;
        box-shadow: 0 -10px 22px rgba(2, 8, 18, 0.24);
    }

    body[data-theme="wizardbattles"] .hand-dock-header {
        padding: 2px 8px 0;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-header,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-header {
        display: none;
    }

    body[data-theme="wizardbattles"] .hand-dock-phase-chip {
        min-height: 18px;
        padding: 0 7px;
        font-size: 0.48rem;
        letter-spacing: 0.1em;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        min-height: 172px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        padding: 2px 6px 1px;
        gap: 3px;
        scroll-padding-inline: 6px;
        overflow-x: auto;
        overflow-y: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content::before,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content::after {
        flex-basis: 8px;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini {
        width: clamp(90px, 26vw, 108px);
        height: calc(clamp(90px, 26vw, 108px) * 1.4);
        border-radius: 10px;
        box-shadow:
            0 6px 14px rgba(2, 8, 22, 0.28),
            0 0 0 1px rgba(191, 220, 255, 0.12);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content {
        min-height: 180px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content {
        padding-top: 0;
        padding-bottom: 4px;
        gap: 4px;
        overflow-x: auto;
        overflow-y: visible;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini {
        width: clamp(96px, 27vw, 114px);
        height: calc(clamp(96px, 27vw, 114px) * 1.4);
        border-radius: 11px;
    }

    body[data-theme="wizardbattles"] .hand--focus .hand-dock-content .card-mini.hand-card-focused {
        transform: translateY(-6px) scale(1.04);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar .combat-action-row {
        padding: 2px 8px calc(4px + env(safe-area-inset-bottom));
        gap: 4px;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-exit-combat,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-lineup-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-hand-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-next-round-main {
        min-height: 36px;
        padding: 6px 10px;
        border-radius: 13px;
        font-size: 0.74rem;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: 180px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(100px, 28vw, 116px);
        height: calc(clamp(100px, 28vw, 116px) * 1.4);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-cta='none'] {
        padding-bottom: calc(6px + env(safe-area-inset-bottom));
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-cta='none'] .combat-action-row {
        position: absolute;
        right: 10px;
        bottom: calc(6px + env(safe-area-inset-bottom));
        width: auto;
        padding: 0;
        z-index: 3;
        justify-content: end;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-cta='none'] #btn-exit-combat {
        min-width: 70px;
        min-height: 34px;
        padding: 6px 12px;
        border-radius: 14px;
        background: rgba(8, 20, 42, 0.88);
        border-color: rgba(163, 196, 242, 0.22);
        box-shadow: 0 10px 18px rgba(2, 8, 18, 0.22);
    }
}

@media (max-width: 767px) and (max-height: 860px) {
    body[data-theme="wizardbattles"] #game-board .battle-arena {
        --wb-slot-w: clamp(64px, 18vw, 78px);
    }

    body[data-theme="wizardbattles"] #game-board .arena-rows {
        gap: 3px;
        padding: 3px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row {
        padding: 10px 3px 4px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        gap: 4px;
        padding: 6px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
        padding: 6px 7px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
        padding: 5px 6px;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        min-height: 158px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini {
        width: clamp(84px, 24vw, 100px);
        height: calc(clamp(84px, 24vw, 100px) * 1.4);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: 166px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(90px, 25vw, 106px);
        height: calc(clamp(90px, 25vw, 106px) * 1.4);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-exit-combat,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-lineup-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-hand-btn,
    body[data-theme="wizardbattles"] #combat-bottom-bar #btn-next-round-main {
        min-height: 34px;
        padding: 5px 9px;
    }
}

@media (max-width: 767px) and (max-height: 760px) {
    body[data-theme="wizardbattles"] #wb-game-header {
        padding:
            max(env(safe-area-inset-top), 7px)
            calc(52px + max(env(safe-area-inset-right), 9px))
            6px
            max(env(safe-area-inset-left), 7px);
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator {
        min-height: 28px;
        padding: 3px 7px;
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena {
        --wb-slot-w: clamp(62px, 17.2vw, 74px);
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        padding: 5px;
        gap: 3px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-main {
        padding: 5px 6px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator .wb-duel-ctx-panel {
        padding: 4px 5px;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: 140px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(76px, 22vw, 90px);
        height: calc(clamp(76px, 22vw, 90px) * 1.4);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: 148px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(80px, 23vw, 94px);
        height: calc(clamp(80px, 23vw, 94px) * 1.4);
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-cta='none'] {
        padding-bottom: calc(4px + env(safe-area-inset-bottom));
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-cta='none'] .combat-action-row {
        right: 8px;
        bottom: calc(4px + env(safe-area-inset-bottom));
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-cta='none'] #btn-exit-combat {
        min-height: 30px;
        min-width: 64px;
        padding: 5px 10px;
        font-size: 0.7rem;
    }
}

/* ==========================================
   In-game HUD compact overhaul (2026-03-08)
   Mobile-first, dark + gold/amber
   ========================================== */

body[data-theme="wizardbattles"] {
    --wb-ig-bg-deep: #0d0d12;
    --wb-ig-bg-surface: #1a1a2e;
    --wb-ig-bg-surface-light: #252540;
    --wb-ig-border-subtle: #2a2a4a;
    --wb-ig-gold-primary: #d4a843;
    --wb-ig-gold-bright: #f0c951;
    --wb-ig-gold-dim: #8b7230;
    --wb-ig-amber-glow: rgba(212, 168, 67, 0.15);
    --wb-ig-text-primary: #e8e0d0;
    --wb-ig-text-secondary: #9a917e;
    --wb-ig-text-muted: #5c5647;
    --wb-ig-rival-accent: #c0392b;
    --wb-ig-rival-bg: rgba(192, 57, 43, 0.08);
    --wb-ig-player-accent: #2e86c1;
    --wb-ig-player-bg: rgba(46, 134, 193, 0.08);
    --wb-ig-success: #27ae60;
    --wb-ig-danger: #e74c3c;
}

body[data-theme="wizardbattles"] #view-game {
    background: transparent;
}

body[data-theme="wizardbattles"] #game-board {
    --wb-slot-w-board: clamp(92px, 27vw, 116px);
    --wb-slot-w: var(--wb-slot-w-board);
    --wb-lineup-gap: 6px;
    --wb-lineup-pad-top: 18px;
    --wb-lineup-pad-bottom: 8px;
    position: relative;
    width: 100%;
    min-height: 100dvh;
    height: 100dvh;
    margin: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 0;
    border-radius: 0;
    background:
        radial-gradient(ellipse at 50% 30%, var(--wb-ig-bg-surface) 0%, var(--wb-ig-bg-deep) 70%);
    box-shadow: none;
}

body[data-theme="wizardbattles"] #game-board[data-mobile-dock-mode='hand'],
body[data-theme="wizardbattles"] #game-board[data-mobile-dock-mode='plan'],
body[data-theme="wizardbattles"] #game-board[data-mobile-dock-mode='waiting'] {
    --wb-slot-w-board: clamp(96px, 27.5vw, 118px);
}

body[data-theme="wizardbattles"] .wb-indicators-bar {
    display: none !important;
}

body[data-theme="wizardbattles"] #wb-game-header {
    z-index: var(--wb-game-layer-shell);
    flex: 0 0 auto;
    height: calc(62px + max(env(safe-area-inset-top), 0px));
    min-height: calc(62px + max(env(safe-area-inset-top), 0px));
    max-height: calc(62px + max(env(safe-area-inset-top), 0px));
    display: grid;
    grid-template-columns: minmax(82px, auto) 1fr minmax(82px, auto);
    align-items: center;
    gap: 12px;
    padding:
        calc(max(env(safe-area-inset-top), 0px) + 6px)
        calc(56px + max(env(safe-area-inset-right), 8px))
        6px
        max(env(safe-area-inset-left), 10px);
    /* Sin radio en la parte inferior: el contenido del tablero empieza justo debajo */
    border-radius: 0;
    border-bottom: 1px solid rgba(240, 201, 81, 0.12);
    background:
        radial-gradient(circle at 50% -40%, rgba(244, 201, 81, 0.14), rgba(244, 201, 81, 0) 48%),
        linear-gradient(180deg, rgba(16, 20, 35, 0.98) 0%, rgba(9, 12, 24, 0.94) 100%);
    box-shadow:
        0 8px 20px rgba(0, 0, 0, 0.25),
        inset 0 1px 0 rgba(255, 247, 229, 0.05),
        inset 0 -1px 0 rgba(240, 201, 81, 0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip {
    position: relative;
    display: grid;
    gap: 1px;
    min-width: 0;
    min-height: 38px;
    padding: 6px 12px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 10px 18px rgba(0, 0, 0, 0.18);
    text-align: left;
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip::before {
    content: '';
    position: absolute;
    top: 9px;
    bottom: 9px;
    width: 3px;
    border-radius: 999px;
    opacity: 0.88;
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-label {
    margin: 0;
    color: var(--wb-ig-text-secondary);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.5rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    line-height: 1;
    text-transform: uppercase;
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-value {
    color: var(--wb-ig-text-primary);
    font-family: 'Cinzel', serif;
    font-size: 1.42rem;
    font-weight: 700;
    line-height: 1;
    text-shadow: 0 0 12px rgba(212, 168, 67, 0.14);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--cpu {
    justify-items: start;
    padding-left: 16px;
    background:
        linear-gradient(180deg, rgba(62, 20, 20, 0.72) 0%, rgba(32, 12, 18, 0.86) 100%);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--cpu::before {
    left: 8px;
    background: linear-gradient(180deg, rgba(231, 76, 60, 0.94) 0%, rgba(192, 57, 43, 0.62) 100%);
    box-shadow: 0 0 10px rgba(192, 57, 43, 0.34);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--cpu .wb-score-value {
    color: #f1c4bd;
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--player {
    justify-items: end;
    padding-right: 16px;
    text-align: right;
    background:
        linear-gradient(180deg, rgba(16, 36, 62, 0.72) 0%, rgba(10, 18, 38, 0.88) 100%);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--player::before {
    right: 8px;
    background: linear-gradient(180deg, rgba(88, 184, 245, 0.96) 0%, rgba(46, 134, 193, 0.62) 100%);
    box-shadow: 0 0 10px rgba(46, 134, 193, 0.34);
}

body[data-theme="wizardbattles"] #wb-game-header .wb-score-chip--player .wb-score-value {
    color: #d6e8f7;
}

body[data-theme="wizardbattles"] .wb-header-center {
    min-width: 0;
    display: grid;
    justify-items: center;
    gap: 4px;
    padding: 5px 10px;
    border-radius: 16px;
    border: 1px solid rgba(240, 201, 81, 0.08);
    background: rgba(5, 9, 18, 0.34);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body[data-theme="wizardbattles"] .wb-header-roundline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    color: var(--wb-ig-text-secondary);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.54rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    white-space: nowrap;
}

body[data-theme="wizardbattles"] .wb-header-round-token,
body[data-theme="wizardbattles"] .wb-header-duel {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    border: 1px solid rgba(240, 201, 81, 0.16);
    background:
        linear-gradient(180deg, rgba(18, 26, 46, 0.9) 0%, rgba(9, 15, 30, 0.96) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 8px 16px rgba(0, 0, 0, 0.16);
}

body[data-theme="wizardbattles"] .wb-header-round-token {
    color: var(--wb-ig-text-primary);
    font-family: 'Cinzel', serif;
    font-weight: 700;
    letter-spacing: 0.08em;
}

body[data-theme="wizardbattles"] .wb-header-separator {
    color: rgba(240, 201, 81, 0.44);
}

body[data-theme="wizardbattles"] .wb-header-turn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 26px;
    padding: 4px 12px;
    border-radius: 999px;
    border: 1px solid rgba(240, 201, 81, 0.18);
    background: rgba(255, 255, 255, 0.04);
    color: var(--wb-ig-text-primary);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.56rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    white-space: nowrap;
    box-shadow:
        0 8px 16px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body[data-theme="wizardbattles"] .wb-header-turn.owner-player {
    border-color: rgba(255, 212, 115, 0.56);
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 232, 157, 0.18), rgba(255, 232, 157, 0) 38%),
        linear-gradient(180deg, rgba(119, 82, 24, 0.92) 0%, rgba(58, 37, 11, 0.98) 100%);
    color: #fff4d7;
    box-shadow:
        0 10px 20px rgba(46, 28, 8, 0.24),
        inset 0 1px 0 rgba(255, 249, 226, 0.14),
        0 0 16px rgba(255, 196, 86, 0.18);
}

body[data-theme="wizardbattles"] .wb-header-turn.owner-cpu {
    border-color: rgba(242, 125, 109, 0.52);
    background:
        radial-gradient(circle at 22% 18%, rgba(255, 195, 186, 0.16), rgba(255, 195, 186, 0) 34%),
        linear-gradient(180deg, rgba(101, 36, 33, 0.94) 0%, rgba(51, 16, 19, 0.98) 100%);
    color: #ffe1d8;
    box-shadow:
        0 10px 20px rgba(48, 14, 18, 0.24),
        inset 0 1px 0 rgba(255, 236, 232, 0.12),
        0 0 14px rgba(197, 66, 56, 0.16);
}

body[data-theme="wizardbattles"] .wb-header-turn.owner-cpu.is-thinking {
    animation: wb-rival-thinking 0.95s ease-in-out infinite;
}

body[data-theme="wizardbattles"] .wb-header-turn.is-result {
    border-color: rgba(238, 221, 176, 0.32);
    background:
        linear-gradient(180deg, rgba(48, 43, 27, 0.92) 0%, rgba(24, 21, 14, 0.98) 100%);
    color: #f6e9c8;
}

body[data-theme="wizardbattles"] .wb-header-turn.owner-neutral {
    color: var(--wb-ig-text-secondary);
}

body[data-theme="wizardbattles"] #game-menu-button {
    top: calc(max(env(safe-area-inset-top), 0px) + 9px);
    right: max(env(safe-area-inset-right), 8px);
    width: 36px;
    height: 36px;
    border-radius: 12px;
    border: 1px solid rgba(240, 201, 81, 0.16);
    background:
        linear-gradient(180deg, rgba(23, 29, 50, 0.94) 0%, rgba(10, 14, 28, 0.98) 100%);
    box-shadow:
        0 10px 20px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

body[data-theme="wizardbattles"] #game-menu-button .hamburger-line {
    background: var(--wb-ig-text-primary);
}

body[data-theme="wizardbattles"] #game-board .battle-arena {
    --wb-slot-w: var(--wb-slot-w-board);
    flex: 1 1 auto;
    min-height: 0;
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 2px 4px 0;
    gap: 4px;
    background: none;
    box-shadow: none;
    border-radius: 0;
}

body[data-theme="wizardbattles"] #game-board .battle-arena::before,
body[data-theme="wizardbattles"] #game-board .battle-arena::after {
    display: none;
}

body[data-theme="wizardbattles"] #game-board .arena-rows {
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: stretch;
    gap: 4px;
    padding: 0;
    background: none;
    border: 0;
    box-shadow: none;
}

body[data-theme="wizardbattles"] #game-board .lineup-row {
    position: relative;
    width: 100%;
    min-height: 0;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--wb-lineup-gap);
    padding: var(--wb-lineup-pad-top) 6px var(--wb-lineup-pad-bottom);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: none;
    overflow: hidden;
}

body[data-theme="wizardbattles"] #game-board .lineup-row::before {
    content: '';
    position: absolute;
    inset: 0;
    background: none;
    box-shadow: none;
    pointer-events: none;
}

body[data-theme="wizardbattles"] #game-board .lineup-row::after {
    top: 6px;
    left: 8px;
    min-height: 16px;
    padding: 1px 6px;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(37, 37, 64, 0.8);
    color: var(--wb-ig-text-muted);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.5rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    box-shadow: none;
}

body[data-theme="wizardbattles"] #game-board .rival-zone {
    background:
        linear-gradient(180deg, rgba(192, 57, 43, 0.1), rgba(13, 13, 18, 0.12)),
        var(--wb-ig-rival-bg);
    border-color: rgba(192, 57, 43, 0.18);
}

body[data-theme="wizardbattles"] #game-board .player-zone {
    background:
        linear-gradient(180deg, rgba(46, 134, 193, 0.06), rgba(13, 13, 18, 0.12)),
        var(--wb-ig-player-bg);
    border-color: rgba(46, 134, 193, 0.18);
}

body[data-theme="wizardbattles"] #game-board .rival-zone::after {
    border-color: rgba(192, 57, 43, 0.2);
    color: #b7827c;
}

body[data-theme="wizardbattles"] #game-board .player-zone::after {
    border-color: rgba(46, 134, 193, 0.2);
    color: #7ea7c4;
}

body[data-theme="wizardbattles"] #game-board[data-arena-owner='player'] .player-zone {
    border-inline-start: 3px solid var(--wb-ig-gold-primary);
    box-shadow: inset 3px 0 0 var(--wb-ig-gold-primary), 0 0 18px var(--wb-ig-amber-glow);
}

body[data-theme="wizardbattles"] #game-board[data-arena-owner='cpu'] .rival-zone {
    border-inline-start: 3px solid rgba(192, 57, 43, 0.8);
    box-shadow: inset 3px 0 0 rgba(192, 57, 43, 0.8), 0 0 18px rgba(192, 57, 43, 0.08);
}

body[data-theme="wizardbattles"] #game-board[data-arena-owner='cpu'] .player-zone {
    opacity: 0.76;
}

body[data-theme="wizardbattles"] #game-board[data-arena-owner='cpu'][data-arena-tone='card'] .rival-zone::before {
    content: '...';
    inset: auto 10px 6px auto;
    width: auto;
    height: auto;
    color: rgba(192, 57, 43, 0.82);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    animation: wb-rival-thinking 0.9s ease-in-out infinite;
}

body[data-theme="wizardbattles"] #game-board .slot-wrapper {
    flex: 0 0 var(--wb-slot-w);
    width: var(--wb-slot-w);
    min-width: var(--wb-slot-w);
    max-width: var(--wb-slot-w);
    gap: 0;
    padding: 2px;
    border: 0;
    border-radius: 8px;
    background: none;
    box-shadow: none;
}

body[data-theme="wizardbattles"] #game-board .slot-wrapper::before {
    display: none;
}

body[data-theme="wizardbattles"] #game-board .card-slot {
    width: 100%;
    height: auto;
    aspect-ratio: 2 / 3;
    border-radius: 8px;
    border: 1px dashed var(--wb-ig-border-subtle);
    background:
        radial-gradient(circle at 50% 18%, rgba(212, 168, 67, 0.08), rgba(212, 168, 67, 0) 36%),
        linear-gradient(180deg, rgba(26, 26, 46, 0.88), rgba(13, 13, 18, 0.94));
    box-shadow: inset 0 1px 0 rgba(212, 168, 67, 0.05);
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled {
    border-style: solid;
    border-color: rgba(212, 168, 67, 0.16);
}

body[data-theme="wizardbattles"] #game-board .card-slot.active-duel {
    border: 1.5px solid var(--wb-ig-gold-primary);
    box-shadow: 0 0 12px rgba(212, 168, 67, 0.3);
}

body[data-theme="wizardbattles"] #game-board .rival-zone .card-slot {
    border-color: rgba(192, 57, 43, 0.26);
}

body[data-theme="wizardbattles"] #game-board .card-slot.pending-duel {
    border-color: rgba(240, 201, 81, 0.44);
    animation: none;
}

body[data-theme="wizardbattles"] .pos-label-vertical {
    padding: 0;
    color: var(--wb-ig-text-muted);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.48rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    white-space: nowrap;
    background: none;
    border: 0;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator {
    position: relative;
    z-index: var(--wb-game-layer-board);
    width: 100%;
    min-height: 54px;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 6px 10px;
    border-top: 1px solid var(--wb-ig-border-subtle);
    border-bottom: 1px solid var(--wb-ig-border-subtle);
    border-left: 0;
    border-right: 0;
    border-radius: 0;
    background: rgba(26, 26, 46, 0.9);
    box-shadow: none;
    overflow: hidden;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator.is-live.owner-player {
    border-bottom-color: var(--wb-ig-gold-primary);
    box-shadow:
        inset 0 -2px 0 var(--wb-ig-gold-primary),
        0 0 8px var(--wb-ig-amber-glow);
    animation: wb-player-turn-glow 0.8s ease-in-out infinite alternate;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator.is-live.owner-cpu {
    border-bottom-color: rgba(192, 57, 43, 0.5);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator[data-turn-state='waiting'] {
    box-shadow:
        inset 0 -2px 0 rgba(192, 57, 43, 0.5),
        0 0 10px rgba(120, 21, 21, 0.12);
}

body[data-theme="wizardbattles"] .wb-duel-ctx-summary {
    /* Sin el copy text, el summary es compacto: solo chips de ronda/duelo + badge de turno */
    flex: 0 0 auto;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stage {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stage-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 20px;
    padding: 0 7px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(236, 242, 252, 0.88);
    font-size: 0.56rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    white-space: nowrap;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stage-chip--duel {
    border-color: rgba(255, 214, 133, 0.2);
    color: #ffe1a2;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-copy {
    min-width: 0;
    flex: 1 1 auto;
    display: grid;
    gap: 1px;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-copy-top {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-icon {
    flex: 0 0 auto;
    font-size: 0.72rem;
    color: rgba(255, 225, 165, 0.82);
}

body[data-theme="wizardbattles"] .wb-duel-ctx-title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #fff3cf;
    font-family: 'Cinzel', serif;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-sub {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: rgba(223, 231, 245, 0.72);
    font-size: 0.62rem;
    line-height: 1.1;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-turn {
    flex: 0 0 auto;
    max-width: min(32vw, 196px);
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(243, 246, 255, 0.92);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.6rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-turn.owner-player {
    border-color: rgba(255, 210, 112, 0.54);
    background:
        radial-gradient(circle at 20% 24%, rgba(255, 241, 179, 0.18), rgba(255, 241, 179, 0) 34%),
        linear-gradient(180deg, rgba(120, 83, 21, 0.94) 0%, rgba(56, 37, 10, 0.98) 100%);
    color: #fff3d0;
    box-shadow:
        inset 0 1px 0 rgba(255, 248, 221, 0.14),
        0 0 14px rgba(255, 197, 82, 0.18);
}

body[data-theme="wizardbattles"] .wb-duel-ctx-turn.owner-cpu {
    border-color: rgba(242, 125, 109, 0.5);
    background:
        radial-gradient(circle at 22% 20%, rgba(255, 203, 194, 0.18), rgba(255, 203, 194, 0) 34%),
        linear-gradient(180deg, rgba(104, 36, 35, 0.95) 0%, rgba(53, 17, 20, 0.98) 100%);
    color: #ffe4dc;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-turn.is-thinking {
    animation: wb-rival-thinking 0.95s ease-in-out infinite;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-turn.is-result {
    border-color: rgba(241, 221, 173, 0.24);
    background:
        linear-gradient(180deg, rgba(48, 43, 28, 0.92) 0%, rgba(22, 19, 13, 0.98) 100%);
    color: #f6e7c3;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-attribute {
    /* Puede encoger para ceder espacio al indicador de habilidad */
    flex: 0 1 auto;
    min-width: 0;
    max-width: 88px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 8px;
    border-radius: 6px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    color: var(--wb-ig-gold-bright);
    overflow: hidden;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stat-ring {
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(13, 13, 18, 0.6);
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stat-icon {
    width: 13px;
    height: 13px;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stat-name {
    color: inherit;
    font-family: 'Cinzel', serif;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

body[data-theme="wizardbattles"] .wb-duel-ctx-stat-name.is-pending {
    color: var(--wb-ig-text-secondary);
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator[data-attribute='valor'] .wb-duel-ctx-attribute {
    background: rgba(231, 76, 60, 0.2);
    color: #e74c3c;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator[data-attribute='cunning'] .wb-duel-ctx-attribute {
    background: rgba(142, 68, 173, 0.2);
    color: #8e44ad;
}

body[data-theme="wizardbattles"] #wb-duel-context-indicator[data-attribute='magic'] .wb-duel-ctx-attribute,
body[data-theme="wizardbattles"] #wb-duel-context-indicator[data-attribute='skill'] .wb-duel-ctx-attribute,
body[data-theme="wizardbattles"] #wb-duel-context-indicator[data-attribute='intel'] .wb-duel-ctx-attribute {
    background: rgba(41, 128, 185, 0.2);
    color: #2980b9;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator {
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
    display: none;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    padding: 3px 8px;
    /* position:relative permite que .wb-next-effect-owner use posicionamiento absoluto */
    position: relative;
    border: 1px solid rgba(212, 168, 67, 0.14);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(39, 32, 18, 0.34), rgba(15, 15, 24, 0.24));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 8px 18px rgba(0, 0, 0, 0.12);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator.is-armed {
    display: flex;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator.tone-force {
    border-color: rgba(240, 201, 81, 0.22);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator.tone-control {
    border-color: rgba(126, 190, 255, 0.2);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator.tone-lock {
    border-color: rgba(231, 76, 60, 0.22);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator.tone-steal {
    border-color: rgba(178, 140, 255, 0.22);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-copy {
    min-width: 0;
    flex: 1 1 auto;
    display: grid;
    gap: 1px;
    overflow: hidden;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-label {
    display: block;
    color: var(--wb-ig-text-muted);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.42rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    line-height: 1;
    text-transform: uppercase;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-icon {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(212, 168, 67, 0.12);
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    width: max-content;
    max-width: 100%;
    color: var(--wb-ig-gold-primary);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.62rem;
    font-weight: 600;
    line-height: 1.12;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text.is-marquee {
    max-width: none;
    overflow: visible;
    text-overflow: clip;
    will-change: transform;
    animation: wb-next-effect-marquee var(--wb-next-effect-marquee-duration, 10s) linear infinite;
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text.is-marquee::after {
    content: attr(data-text);
    padding-left: 18px;
}

@keyframes wb-next-effect-marquee {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(calc(-1 * var(--wb-next-effect-marquee-distance, 0px)));
    }
}

body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-owner {
    /* Badge compacto en esquina superior-derecha: no consume espacio horizontal en el flex */
    position: absolute;
    top: 3px;
    right: 5px;
    min-width: 0;
    min-height: 0;
    padding: 1px 4px;
    border-radius: 999px;
    border: 1px solid rgba(212, 168, 67, 0.16);
    color: var(--wb-ig-text-secondary);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.46rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.3;
    background: rgba(255, 255, 255, 0.05);
}

body[data-theme="wizardbattles"] #combat-bottom-bar {
    position: relative;
    z-index: var(--wb-game-layer-dock);
    flex: 0 0 auto;
    display: block;
    overflow: visible;
    padding: 6px 8px calc(8px + env(safe-area-inset-bottom));
    border-top: 1px solid rgba(139, 114, 48, 0.48);
    background:
        linear-gradient(180deg, rgba(10, 10, 16, 0.96) 0%, rgba(13, 13, 18, 0.99) 100%);
    box-shadow: 0 -16px 26px rgba(0, 0, 0, 0.28);
}

/* La mano debe quedar por delante de cualquier overlay/modal del juego. */
body[data-theme="wizardbattles"] #combat-bottom-bar {
    z-index: var(--wb-game-layer-hand-top) !important;
    isolation: isolate;
}

body[data-theme="wizardbattles"] #combat-bottom-bar > .w-full,
body[data-theme="wizardbattles"] .hand-dock,
body[data-theme="wizardbattles"] .hand-dock-body {
    display: block !important;
    width: 100%;
    position: relative;
    z-index: 2;
}

body[data-theme="wizardbattles"] .hand-dock-body {
    display: flex !important;
}

body[data-theme="wizardbattles"] #hand-dock-toggle-btn,
body[data-theme="wizardbattles"] #combat-bottom-bar .combat-action-row {
    position: relative;
    z-index: 1;
}

body[data-theme="wizardbattles"] #combat-bottom-bar > .w-full {
    padding: 0;
}

body[data-theme="wizardbattles"] #hand-dock-toggle-btn {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 36px;
    height: 20px;
    border-radius: 999px;
    border: 1px solid rgba(139, 114, 48, 0.42);
    background: rgba(26, 26, 46, 0.96);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.22);
}

body[data-theme="wizardbattles"] .hand-dock {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    max-height: clamp(196px, 28vh, 320px);
    overflow: visible;
    background: transparent;
    border: 0;
    box-shadow: none;
}

body[data-theme="wizardbattles"] .hand-dock.hand--locked {
    opacity: 1;
    filter: none;
    pointer-events: none;
}

body[data-theme="wizardbattles"] .hand-dock-header,
body[data-theme="wizardbattles"] .hand-dock-title,
body[data-theme="wizardbattles"] .hand-dock-subtitle {
    display: none !important;
}

body[data-theme="wizardbattles"] .hand-dock-phase-chip {
    min-height: 18px;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid rgba(212, 168, 67, 0.16);
    background: rgba(255, 255, 255, 0.04);
    color: var(--wb-ig-text-secondary);
}

body[data-theme="wizardbattles"] .hand-dock-body,
body[data-theme="wizardbattles"] #player-hand.hand-dock-content,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
    min-height: clamp(172px, 22vh, 220px);
    max-height: clamp(196px, 26vh, 260px);
    overflow: visible;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
    position: relative;
    z-index: 4;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    gap: 8px;
    overflow-x: auto;
    overflow-y: visible;
    margin-top: -8px;
    padding: 12px 16px 8px;
    scroll-snap-type: x proximity;
    scroll-padding-inline: var(--wb-mobile-hand-edge-spacer, 10px);
    scrollbar-width: none;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content::-webkit-scrollbar {
    display: none;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content::before,
body[data-theme="wizardbattles"] #player-hand.hand-dock-content::after {
    content: '';
    flex: 0 0 var(--wb-mobile-hand-edge-spacer, 2px);
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content[data-hand-layout='center'] {
    justify-content: center;
    overflow-x: hidden;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content[data-hand-layout='center']::before,
body[data-theme="wizardbattles"] #player-hand.hand-dock-content[data-hand-layout='center']::after {
    flex-basis: 0;
    width: 0;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
    position: relative;
    z-index: 5;
    width: clamp(108px, 30vw, 132px);
    height: calc(clamp(108px, 30vw, 132px) * 1.4);
    flex: 0 0 auto;
    margin-left: 0 !important;
    border-radius: 10px;
    border: 1px solid rgba(212, 168, 67, 0.12);
    box-shadow: 0 10px 18px rgba(0, 0, 0, 0.28);
    transform-origin: center bottom;
    will-change: transform;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, z-index 180ms ease;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini img,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini img,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini img,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini img,
body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini img {
    object-fit: contain;
    background: linear-gradient(180deg, rgba(9, 17, 34, 0.88), rgba(5, 11, 22, 0.96));
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini + .card-mini {
    margin-left: 0 !important;
}

body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini:hover,
body[data-theme="wizardbattles"] .hand--focus .hand-dock-content .card-mini.hand-card-focused {
    transform: translateY(-10px) scale(1.05);
    z-index: 8;
    border-color: var(--wb-ig-gold-primary);
    box-shadow:
        0 16px 26px rgba(0, 0, 0, 0.34),
        0 0 12px rgba(212, 168, 67, 0.3);
}

body[data-theme="wizardbattles"] .hand--focus .hand-dock-content .card-mini {
    opacity: 0.72;
    filter: none;
    transform: none;
}

body[data-theme="wizardbattles"] #combat-bottom-bar .combat-action-row {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    align-items: center;
    gap: 6px;
    padding: 0;
}

body[data-theme="wizardbattles"] #combat-bottom-bar .combat-bottom-actions {
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-end;
    gap: 6px;
    flex-wrap: wrap;
}

body[data-theme="wizardbattles"] #combat-bottom-bar #btn-exit-combat,
body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-lineup-btn,
body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-hand-btn,
body[data-theme="wizardbattles"] #combat-bottom-bar #btn-next-round-main {
    min-height: 30px;
    padding: 5px 10px;
    border-radius: 8px;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
}

body[data-theme="wizardbattles"] #combat-bottom-bar #btn-exit-combat {
    border-color: rgba(139, 114, 48, 0.22);
    background: rgba(255, 255, 255, 0.03);
    color: var(--wb-ig-text-secondary);
}

body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-lineup-btn,
body[data-theme="wizardbattles"] #combat-bottom-bar #confirm-hand-btn,
body[data-theme="wizardbattles"] #combat-bottom-bar #btn-next-round-main {
    border-color: rgba(240, 201, 81, 0.28);
    background: linear-gradient(180deg, #d4a843 0%, #8b7230 100%);
    color: #0d0d12;
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge {
    top: 6px;
    right: 6px;
    left: auto;
    bottom: auto;
    border-radius: 999px;
    background: rgba(13, 13, 18, 0.78);
    border: 1px solid rgba(212, 168, 67, 0.24);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.24);
}

body[data-theme="wizardbattles"] #game-board .slot-stat-badge-value {
    color: var(--wb-ig-gold-bright);
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.7rem;
}

body[data-theme="wizardbattles"] #game-board .card-slot.filled .card-mini.card-mini--arena {
    overflow: hidden;
    border-radius: inherit;
}

body[data-theme="wizardbattles"] #game-board .slot-art-image {
    object-position: center 16%;
    transform: scale(1.12);
}

body[data-theme="wizardbattles"] #game-board .card-slot.active-duel .slot-art-image,
body[data-theme="wizardbattles"] #game-board .card-slot.win .slot-art-image {
    transform: scale(1.16);
}

@media (min-width: 768px) {
    body[data-theme="wizardbattles"] #game-board {
        --wb-slot-w-board: min(12vw, 140px);
        --wb-slot-w: var(--wb-slot-w-board);
        width: min(100%, 900px);
        margin: 0 auto;
        border-inline: 1px solid rgba(240, 201, 81, 0.08);
        box-shadow:
            0 24px 60px rgba(0, 0, 0, 0.28),
            0 0 0 1px rgba(240, 201, 81, 0.04);
    }

    body[data-theme="wizardbattles"] #wb-game-header {
        height: 68px;
        min-height: 68px;
        max-height: 68px;
        grid-template-columns: minmax(104px, auto) 1fr minmax(104px, auto);
        padding: 8px 62px 8px 14px;
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-value {
        font-size: 1.62rem;
    }

    body[data-theme="wizardbattles"] .wb-header-roundline {
        font-size: 0.7rem;
    }

    body[data-theme="wizardbattles"] .wb-header-turn {
        min-height: 24px;
        font-size: 0.58rem;
    }

    body[data-theme="wizardbattles"] #game-board .battle-arena {
        padding: 10px 14px 0;
        gap: 10px;
    }

    body[data-theme="wizardbattles"] #game-board .arena-rows {
        gap: 10px;
    }

    body[data-theme="wizardbattles"] #game-board .lineup-row {
        gap: 12px;
        padding: 22px 16px 14px;
        border-radius: 14px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        min-height: 52px;
        padding: 6px 12px;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-summary {
        gap: 8px;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-title {
        font-size: 0.72rem;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-sub {
        font-size: 0.58rem;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-turn {
        max-width: 180px;
        min-height: 26px;
        font-size: 0.54rem;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-stat-name {
        font-size: 0.88rem;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
        font-size: 0.74rem;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: clamp(138px, 17vh, 172px);
        max-height: clamp(158px, 20vh, 200px);
        overflow: visible;
    }

    body[data-theme="wizardbattles"] .hand-dock {
        max-height: clamp(168px, 22vh, 220px);
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        gap: 8px;
        padding: 6px 12px 8px;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(88px, 14vw, 108px);
        height: calc(clamp(88px, 14vw, 108px) * 1.4);
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini + .card-mini {
        margin-left: 0 !important;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini:hover,
    body[data-theme="wizardbattles"] .hand--focus .hand-dock-content .card-mini.hand-card-focused {
        transform: translateY(-4px) scale(1.02);
    }
}

@media (max-width: 767px) and (max-height: 860px) {
    body[data-theme="wizardbattles"] #game-board {
        --wb-slot-w-board: clamp(88px, 24vw, 102px);
        --wb-slot-w: var(--wb-slot-w-board);
    }
}

@media (min-width: 1024px) {
    body[data-theme="wizardbattles"] #card-inspection-modal .game-overlay-container {
        width: min(92vw, 760px);
        max-height: min(92vh, 880px);
    }

    body[data-theme="wizardbattles"] #card-inspection-modal .inspect-overlay-core {
        min-height: min(58vh, 620px);
        padding: 18px 22px 14px;
    }

    body[data-theme="wizardbattles"] #card-inspection-modal .overlay-actions {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        align-items: stretch;
        gap: 12px;
        padding: 16px 22px 20px;
    }

    body[data-theme="wizardbattles"] #card-inspection-modal .overlay-actions .btn-overlay-secondary,
    body[data-theme="wizardbattles"] #card-inspection-modal .overlay-actions .btn-overlay-primary {
        width: 100%;
        min-width: 0;
        margin: 0;
        padding: 14px 18px;
        font-size: 0.96rem;
        line-height: 1.15;
        letter-spacing: 0.04em;
        white-space: normal;
        text-align: center;
    }

    body[data-theme="wizardbattles"] #combat-bottom-bar {
        padding: 10px 14px calc(12px + env(safe-area-inset-bottom));
    }

    body[data-theme="wizardbattles"] .hand-dock {
        max-height: clamp(250px, 30vh, 320px);
        overflow: visible;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: clamp(208px, 24vh, 256px);
        max-height: clamp(240px, 28vh, 300px);
        overflow: visible;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        gap: 12px;
        padding: 12px 22px 14px;
        justify-content: flex-start;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(120px, 10.5vw, 158px);
        height: calc(clamp(120px, 10.5vw, 158px) * 1.4);
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini + .card-mini {
        margin-left: 0 !important;
    }
}

@media (max-width: 767px) and (max-height: 760px) {
    body[data-theme="wizardbattles"] #game-board {
        --wb-slot-w-board: clamp(84px, 23vw, 96px);
        --wb-slot-w: var(--wb-slot-w-board);
    }

    body[data-theme="wizardbattles"] #wb-game-header {
        height: calc(54px + max(env(safe-area-inset-top), 0px));
        min-height: calc(54px + max(env(safe-area-inset-top), 0px));
        max-height: calc(54px + max(env(safe-area-inset-top), 0px));
        grid-template-columns: minmax(72px, auto) 1fr minmax(72px, auto);
        gap: 8px;
        padding:
            calc(max(env(safe-area-inset-top), 0px) + 4px)
            calc(50px + max(env(safe-area-inset-right), 8px))
            4px
            max(env(safe-area-inset-left), 8px);
    }

    body[data-theme="wizardbattles"] #wb-game-header .wb-score-value {
        font-size: 1.2rem;
    }

    body[data-theme="wizardbattles"] .wb-header-roundline {
        font-size: 0.5rem;
        gap: 4px;
    }

    body[data-theme="wizardbattles"] .wb-header-turn {
        font-size: 0.48rem;
        padding-inline: 7px;
        min-height: 22px;
    }

    body[data-theme="wizardbattles"] #wb-duel-context-indicator {
        min-height: 48px;
        padding: 5px 6px;
        gap: 6px;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-summary {
        gap: 6px;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-stage {
        display: none;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-title {
        font-size: 0.58rem;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-sub {
        font-size: 0.5rem;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-turn {
        max-width: 118px;
        min-height: 24px;
        padding-inline: 8px;
        font-size: 0.45rem;
        letter-spacing: 0.06em;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-attribute {
        gap: 6px;
        padding: 3px 8px;
    }

    body[data-theme="wizardbattles"] .wb-duel-ctx-stat-name {
        font-size: 0.72rem;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-text {
        font-size: 0.62rem;
    }

    body[data-theme="wizardbattles"] #wb-next-effect-indicator .wb-next-effect-label {
        display: none;
    }

    body[data-theme="wizardbattles"] .hand-dock-body,
    body[data-theme="wizardbattles"] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] .hand-dock-body,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content {
        min-height: 148px;
        max-height: 168px;
        overflow: visible;
    }

    body[data-theme="wizardbattles"] .hand-dock {
        max-height: 178px;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content {
        margin-top: -4px;
        gap: 6px;
        padding: 4px 8px 4px;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='hand'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini,
    body[data-theme="wizardbattles"] #combat-bottom-bar[data-mobile-dock-mode='plan'][data-mobile-cta='none'] #player-hand.hand-dock-content .card-mini {
        width: clamp(70px, 18.8vw, 78px);
        height: calc(clamp(70px, 18.8vw, 78px) * 1.4);
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini + .card-mini {
        margin-left: 0 !important;
    }

    body[data-theme="wizardbattles"] #player-hand.hand-dock-content .card-mini:hover,
    body[data-theme="wizardbattles"] .hand--focus .hand-dock-content .card-mini.hand-card-focused {
        transform: translateY(-2px) scale(1.015);
    }
}

@keyframes wb-player-turn-glow {
    from {
        box-shadow:
            inset 0 -2px 0 var(--wb-ig-gold-primary),
            0 0 4px rgba(212, 168, 67, 0.08);
    }

    to {
        box-shadow:
            inset 0 -2px 0 var(--wb-ig-gold-primary),
            0 0 12px var(--wb-ig-amber-glow);
    }
}

@keyframes wb-rival-thinking {
    0%, 100% {
        opacity: 0.45;
        transform: translateY(0);
    }

    50% {
        opacity: 0.95;
        transform: translateY(-1px);
    }
}

/* ================================================================
   WIZARD BATTLES — RESULTADO ÉPICO (Teatro)
   Pantalla de victoria/derrota reimaginada con efectos cinematográficos
   ================================================================ */

/* ── 1. SISTEMA DE COLOR RGB POR ESTADO ──────────────────────── */
body[data-theme="wizardbattles"] #game-result-overlay { --rr:120;--rg:172;--rb:255; }
body[data-theme="wizardbattles"] #game-result-overlay.result-win  { --rr:228;--rg:182;--rb:48;  }
body[data-theme="wizardbattles"] #game-result-overlay.result-loss { --rr:220;--rg:52; --rb:88;  }
body[data-theme="wizardbattles"] #game-result-overlay.result-tie  { --rr:72; --rg:168;--rb:238; }

/* ── 2. OVERLAY BACKDROP ─────────────────────────────────────── */
body[data-theme="wizardbattles"] #game-result-overlay {
    background:
        radial-gradient(
            ellipse 90% 70% at 50% 0%,
            rgba(var(--rr),var(--rg),var(--rb),0.13) 0%,
            transparent 62%
        ),
        rgba(2,2,8,0.93) !important;
    backdrop-filter: blur(14px) saturate(0.55);
    -webkit-backdrop-filter: blur(14px) saturate(0.55);
}

/* ── 3. CARD PRINCIPAL ───────────────────────────────────────── */
body[data-theme="wizardbattles"] #game-result-overlay .result-overlay-container {
    position: relative;
    width: min(490px, 94vw) !important;
    max-height: min(96svh, 740px) !important;
    overflow: hidden;
    overflow-y: auto;
    border-radius: 28px !important;
    background:
        radial-gradient(
            ellipse 110% 58% at 50% -8%,
            rgba(var(--rr),var(--rg),var(--rb),0.18) 0%,
            transparent 52%
        ),
        linear-gradient(174deg, #130f22 0%, #06050e 100%) !important;
    border: 1px solid rgba(var(--rr),var(--rg),var(--rb),0.30) !important;
    box-shadow:
        0 0 0 1px rgba(var(--rr),var(--rg),var(--rb),0.07),
        0 0 100px rgba(var(--rr),var(--rg),var(--rb),0.11),
        0 48px 110px rgba(0,0,0,0.92),
        inset 0 1px 0 rgba(255,255,255,0.07) !important;
    animation: resultCardIn 0.72s cubic-bezier(0.16,1,0.3,1) 0.06s both;
}

@keyframes resultCardIn {
    from { transform:translateY(34px) scale(0.93); opacity:0; filter:blur(5px); }
    to   { transform:translateY(0) scale(1);       opacity:1; filter:blur(0);   }
}

/* Orbe de luz superior (pulsante) */
body[data-theme="wizardbattles"] #game-result-overlay .result-overlay-container::before {
    content: '';
    position: absolute;
    top: -90px; left: 50%;
    transform: translateX(-50%);
    width: 320px; height: 320px;
    border-radius: 50%;
    background: radial-gradient(
        circle,
        rgba(var(--rr),var(--rg),var(--rb),0.24) 0%,
        rgba(var(--rr),var(--rg),var(--rb),0.04) 45%,
        transparent 70%
    );
    filter: blur(28px);
    pointer-events: none;
    z-index: 0;
    animation: topOrbPulse 3.2s ease-in-out infinite alternate;
}

@keyframes topOrbPulse {
    from { opacity:0.55; transform:translateX(-50%) scale(0.82); }
    to   { opacity:1.00; transform:translateX(-50%) scale(1.18); }
}

/* Partículas flotantes — dots en background tileado que ascienden */
body[data-theme="wizardbattles"] #game-result-overlay .result-overlay-container::after {
    content: '';
    position: absolute;
    inset: -12px;
    pointer-events: none;
    z-index: 0;
    background-image:
        radial-gradient(circle 1.5px at 18px  40px,  rgba(var(--rr),var(--rg),var(--rb),0.75) 0%, transparent 100%),
        radial-gradient(circle 1px  at 66px  90px,  rgba(var(--rr),var(--rg),var(--rb),0.50) 0%, transparent 100%),
        radial-gradient(circle 2px  at 42px  145px, rgba(var(--rr),var(--rg),var(--rb),0.65) 0%, transparent 100%),
        radial-gradient(circle 1px  at 80px  20px,  rgba(var(--rr),var(--rg),var(--rb),0.40) 0%, transparent 100%),
        radial-gradient(circle 1.5px at 55px  110px, rgba(var(--rr),var(--rg),var(--rb),0.58) 0%, transparent 100%),
        radial-gradient(circle 1px  at 30px  170px, rgba(var(--rr),var(--rg),var(--rb),0.35) 0%, transparent 100%),
        radial-gradient(circle 2px  at 74px  60px,  rgba(var(--rr),var(--rg),var(--rb),0.45) 0%, transparent 100%),
        radial-gradient(circle 1px  at 10px  130px, rgba(var(--rr),var(--rg),var(--rb),0.30) 0%, transparent 100%);
    background-size: 100px 190px;
    opacity: 0.5;
    animation: particleAscend 11s linear infinite;
}

@keyframes particleAscend {
    0%   { background-position: 0 190px; }
    100% { background-position: 0 0;     }
}

/* ── 4. HEADER ───────────────────────────────────────────────── */
body[data-theme="wizardbattles"] #game-result-overlay .result-header {
    position: relative;
    z-index: 2;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
    height: auto !important;
    padding: clamp(22px,3.5vw,30px) clamp(16px,3vw,24px) 18px !important;
    border-bottom: 1px solid rgba(var(--rr),var(--rg),var(--rb),0.13) !important;
    background: linear-gradient(
        180deg,
        rgba(var(--rr),var(--rg),var(--rb),0.08) 0%,
        transparent 100%
    ) !important;
}

/* ── 5. STATE CHIP ───────────────────────────────────────────── */
body[data-theme="wizardbattles"] #result-state-chip,
body[data-theme="wizardbattles"] .result-state-chip {
    display: inline-flex !important;
    align-items: center !important;
    font-family: 'Cinzel', 'Palatino Linotype', 'Book Antiqua', serif !important;
    font-size: 0.62rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.24em !important;
    text-transform: uppercase !important;
    color: rgba(var(--rr),var(--rg),var(--rb),1) !important;
    padding: 5px 20px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(var(--rr),var(--rg),var(--rb),0.48) !important;
    background: rgba(var(--rr),var(--rg),var(--rb),0.09) !important;
    box-shadow:
        0 0 22px rgba(var(--rr),var(--rg),var(--rb),0.20),
        inset 0 1px 0 rgba(255,255,255,0.08) !important;
    min-height: unset !important;
    animation: chipExplosion 0.55s cubic-bezier(0.34,1.56,0.64,1) 0.28s both !important;
}

/* Override las variantes de color heredadas ya que ahora usamos --rr/rg/rb */
body[data-theme="wizardbattles"] .result-state-chip--win,
body[data-theme="wizardbattles"] .result-state-chip--loss,
body[data-theme="wizardbattles"] .result-state-chip--tie {
    border-color: rgba(var(--rr),var(--rg),var(--rb),0.48) !important;
    color: rgba(var(--rr),var(--rg),var(--rb),1) !important;
    background: rgba(var(--rr),var(--rg),var(--rb),0.09) !important;
}

@keyframes chipExplosion {
    from { transform:scale(0.3); opacity:0; }
    to   { transform:scale(1);   opacity:1; }
}

/* ── 6. TÍTULO ───────────────────────────────────────────────── */
body[data-theme="wizardbattles"] #result-title,
body[data-theme="wizardbattles"] .overlay-title {
    font-family: 'Cinzel', 'Palatino Linotype', 'Book Antiqua', serif !important;
    font-size: clamp(1.72rem,6.8vw,2.7rem) !important;
    font-weight: 900 !important;
    line-height: 1.05 !important;
    letter-spacing: -0.01em !important;
    text-align: center !important;
    color: #fff !important;
    text-shadow:
        0 0 28px rgba(var(--rr),var(--rg),var(--rb),0.68),
        0 0 64px rgba(var(--rr),var(--rg),var(--rb),0.30),
        0 4px 20px rgba(0,0,0,0.75) !important;
    animation: titleMaterialize 0.85s cubic-bezier(0.16,1,0.3,1) 0.38s both !important;
}

@keyframes titleMaterialize {
    from { transform:translateY(16px) scale(0.92); opacity:0; }
    to   { transform:translateY(0) scale(1);       opacity:1; }
}

/* ── 7. CONTENIDO PRINCIPAL ──────────────────────────────────── */
body[data-theme="wizardbattles"] #game-result-overlay .overlay-core,
body[data-theme="wizardbattles"] #game-result-overlay .result-content {
    position: relative;
    z-index: 2;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 14px !important;
    padding: clamp(14px,2.5vw,20px) clamp(16px,3vw,24px) !important;
}

/* ── 8. OCULTAR INFORMACIÓN REDUNDANTE ───────────────────────── */
body[data-theme="wizardbattles"] #result-meta-note,
body[data-theme="wizardbattles"] #result-round-stats,
body[data-theme="wizardbattles"] .result-summary-grid .result-summary-item:nth-child(3) {
    display: none !important;
}

/* ── 9. RETRATO DE DOBBY ─────────────────────────────────────── */
body[data-theme="wizardbattles"] .result-image-container {
    display: flex !important;
    justify-content: center !important;
    padding: 4px 0 0 !important;
}

body[data-theme="wizardbattles"] .result-hero-frame {
    position: relative !important;
    width: 106px !important;
    height: 106px !important;
    overflow: visible !important;
    border-radius: 50% !important;
    background: none !important;
    box-shadow: none !important;
    animation: portraitConjure 0.9s cubic-bezier(0.16,1,0.3,1) 0.48s both;
}

@keyframes portraitConjure {
    from { transform:scale(0.5); opacity:0; filter:blur(12px); }
    to   { transform:scale(1);   opacity:1; filter:blur(0);    }
}

body[data-theme="wizardbattles"] .result-hero-frame img {
    position: absolute !important;
    inset: 10px !important;
    width: calc(100% - 20px) !important;
    height: calc(100% - 20px) !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    border: 2px solid rgba(var(--rr),var(--rg),var(--rb),0.55) !important;
    box-shadow:
        0 0 0 5px rgba(var(--rr),var(--rg),var(--rb),0.07),
        0 0 28px rgba(var(--rr),var(--rg),var(--rb),0.32),
        0 10px 24px rgba(0,0,0,0.55) !important;
}

/* Anillo giratorio exterior */
body[data-theme="wizardbattles"] .result-hero-frame::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    border-radius: 50% !important;
    border: 2px solid transparent !important;
    border-top-color: rgba(var(--rr),var(--rg),var(--rb),0.85) !important;
    border-right-color: rgba(var(--rr),var(--rg),var(--rb),0.28) !important;
    animation: ringCW 2.8s linear infinite !important;
}

/* Anillo interior contra-giratorio */
body[data-theme="wizardbattles"] .result-hero-frame::after {
    content: '' !important;
    position: absolute !important;
    inset: 3px !important;
    border-radius: 50% !important;
    border: 1.5px solid transparent !important;
    border-bottom-color: rgba(var(--rr),var(--rg),var(--rb),0.55) !important;
    border-left-color: rgba(var(--rr),var(--rg),var(--rb),0.22) !important;
    animation: ringCW 4.2s linear infinite reverse !important;
}

@keyframes ringCW { to { transform: rotate(360deg); } }

/* ── 10. RESUMEN COMPACTO (Modo + Rondas) ────────────────────── */
body[data-theme="wizardbattles"] .result-summary-grid {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    grid-template-columns: unset !important;
}

body[data-theme="wizardbattles"] .result-summary-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    padding: 5px 14px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    background: rgba(255,255,255,0.03) !important;
    box-shadow: none !important;
}

body[data-theme="wizardbattles"] .result-summary-label {
    font-size: 0.58rem !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
    color: rgba(188,208,240,0.52) !important;
    font-weight: 600 !important;
}

body[data-theme="wizardbattles"] .result-summary-value {
    font-family: 'Cinzel', serif !important;
    font-size: 0.76rem !important;
    font-weight: 700 !important;
    color: rgba(218,232,252,0.9) !important;
}

/* ── 11. MARCADOR ────────────────────────────────────────────── */
body[data-theme="wizardbattles"] .result-score-display {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

body[data-theme="wizardbattles"] .result-score-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 18px 12px 22px !important;
    border-radius: 22px !important;
    background: linear-gradient(150deg,
        rgba(255,255,255,0.035),
        rgba(0,0,0,0.22)) !important;
    border: 1px solid rgba(255,255,255,0.07) !important;
    box-shadow:
        0 14px 30px rgba(0,0,0,0.38),
        inset 0 1px 0 rgba(255,255,255,0.05) !important;
    animation: scoreCardAppear 0.7s cubic-bezier(0.16,1,0.3,1) 0.58s both;
}

@keyframes scoreCardAppear {
    from { transform:translateY(22px) scale(0.90); opacity:0; }
    to   { transform:translateY(0) scale(1);       opacity:1; }
}

/* Ganador */
body[data-theme="wizardbattles"] .result-score-item.is-winner {
    border-color: rgba(var(--rr),var(--rg),var(--rb),0.42) !important;
    background: linear-gradient(150deg,
        rgba(var(--rr),var(--rg),var(--rb),0.13),
        rgba(var(--rr),var(--rg),var(--rb),0.04)) !important;
    box-shadow:
        0 0 0 1px rgba(var(--rr),var(--rg),var(--rb),0.14),
        0 0 46px rgba(var(--rr),var(--rg),var(--rb),0.16),
        0 16px 36px rgba(0,0,0,0.40),
        inset 0 1px 0 rgba(255,255,255,0.07) !important;
    animation:
        scoreCardAppear 0.7s cubic-bezier(0.16,1,0.3,1) 0.58s both,
        winnerGlowPulse 2.8s ease-in-out 1.4s infinite alternate !important;
}

@keyframes winnerGlowPulse {
    from { box-shadow: 0 0 0 1px rgba(var(--rr),var(--rg),var(--rb),0.10), 0 0 26px rgba(var(--rr),var(--rg),var(--rb),0.10), 0 16px 36px rgba(0,0,0,0.40), inset 0 1px 0 rgba(255,255,255,0.07); }
    to   { box-shadow: 0 0 0 1px rgba(var(--rr),var(--rg),var(--rb),0.28), 0 0 55px rgba(var(--rr),var(--rg),var(--rb),0.22), 0 16px 36px rgba(0,0,0,0.40), inset 0 1px 0 rgba(255,255,255,0.07); }
}

/* Perdedor: atenuado */
body[data-theme="wizardbattles"] .result-score-item.is-loser {
    opacity: 0.55 !important;
    filter: grayscale(0.6) !important;
}

/* Empate */
body[data-theme="wizardbattles"] .result-score-item.is-tie {
    border-color: rgba(var(--rr),var(--rg),var(--rb),0.22) !important;
}

/* Etiqueta CPU / Jugador */
body[data-theme="wizardbattles"] .result-score-label {
    font-family: 'Cinzel', serif !important;
    font-size: 0.60rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    color: rgba(185,208,242,0.65) !important;
    text-shadow: none !important;
}

/* ── EL NÚMERO — protagonista absoluto ── */
body[data-theme="wizardbattles"] .result-score-value {
    font-family: 'Cinzel', 'Palatino Linotype', serif !important;
    font-size: clamp(3.4rem,14vw,5.4rem) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    color: rgba(225,238,255,0.92) !important;
    text-shadow:
        0 0 22px rgba(var(--rr),var(--rg),var(--rb),0.42),
        0 6px 16px rgba(0,0,0,0.65) !important;
    animation: numberConjure 1.1s cubic-bezier(0.16,1,0.3,1) 0.76s both !important;
}

@keyframes numberConjure {
    from { transform:scale(0.25) translateY(6px); opacity:0; filter:blur(8px); }
    to   { transform:scale(1) translateY(0);      opacity:1; filter:blur(0);   }
}

/* Número ganador: color acento + super glow */
body[data-theme="wizardbattles"] .result-score-item.is-winner .result-score-value {
    color: rgb(var(--rr),var(--rg),var(--rb)) !important;
    text-shadow:
        0 0 32px rgba(var(--rr),var(--rg),var(--rb),0.80),
        0 0 70px rgba(var(--rr),var(--rg),var(--rb),0.38),
        0 6px 16px rgba(0,0,0,0.65) !important;
}

/* VS separador */
body[data-theme="wizardbattles"] .result-score-vs {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    height: 34px !important;
    min-width: unset !important;
    min-height: unset !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255,255,255,0.09) !important;
    background: rgba(255,255,255,0.03) !important;
    font-family: 'Cinzel', serif !important;
    font-size: 0.68rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.04em !important;
    color: rgba(180,205,242,0.55) !important;
    padding: 0 !important;
    align-self: center !important;
}

/* ── 12. MENSAJE ─────────────────────────────────────────────── */
body[data-theme="wizardbattles"] .result-message-container {
    width: 100% !important;
    padding: 14px 20px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(255,255,255,0.055) !important;
    background: rgba(255,255,255,0.022) !important;
    text-align: center !important;
    animation: msgReveal 0.7s cubic-bezier(0.16,1,0.3,1) 0.88s both;
}

@keyframes msgReveal {
    from { opacity:0; transform:translateY(10px); }
    to   { opacity:1; transform:translateY(0);    }
}

body[data-theme="wizardbattles"] .result-message-text {
    font-family: 'Cormorant Garamond', 'Garamond', 'Palatino Linotype', serif !important;
    font-size: clamp(0.88rem,2.8vw,1.0rem) !important;
    font-style: italic !important;
    font-weight: 500 !important;
    line-height: 1.58 !important;
    color: rgba(218,232,252,0.88) !important;
    letter-spacing: 0.015em !important;
    text-shadow: 0 2px 10px rgba(0,0,0,0.45) !important;
}

/* ── 13. BOTONES ─────────────────────────────────────────────── */
body[data-theme="wizardbattles"] #game-result-overlay .overlay-actions {
    display: flex !important;
    gap: 10px !important;
    padding: clamp(14px,2.5vw,18px) clamp(16px,3vw,24px) !important;
    border-top: 1px solid rgba(255,255,255,0.055) !important;
    background: linear-gradient(180deg, transparent, rgba(4,3,12,0.48)) !important;
    animation: actionsLand 0.6s cubic-bezier(0.16,1,0.3,1) 1.02s both;
}

@keyframes actionsLand {
    from { opacity:0; transform:translateY(18px); }
    to   { opacity:1; transform:translateY(0);    }
}

/* Botón primario — acento del resultado */
body[data-theme="wizardbattles"] #btn-result-play-again {
    flex: 1 !important;
    min-height: 52px !important;
    border-radius: 14px !important;
    background: linear-gradient(138deg,
        rgba(var(--rr),var(--rg),var(--rb),0.26),
        rgba(var(--rr),var(--rg),var(--rb),0.12)) !important;
    border: 1px solid rgba(var(--rr),var(--rg),var(--rb),0.48) !important;
    color: rgb(var(--rr),var(--rg),var(--rb)) !important;
    font-family: 'Cinzel', serif !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    box-shadow: 0 0 24px rgba(var(--rr),var(--rg),var(--rb),0.13) !important;
    transition: all 0.2s ease !important;
}

body[data-theme="wizardbattles"] #btn-result-play-again:hover {
    background: linear-gradient(138deg,
        rgba(var(--rr),var(--rg),var(--rb),0.38),
        rgba(var(--rr),var(--rg),var(--rb),0.20)) !important;
    box-shadow: 0 0 40px rgba(var(--rr),var(--rg),var(--rb),0.24) !important;
    transform: translateY(-2px) !important;
}

body[data-theme="wizardbattles"] #btn-result-play-again:active {
    transform: translateY(0) !important;
    transition: transform 0.08s ease !important;
}

/* Botón secundario — sutil */
body[data-theme="wizardbattles"] #btn-result-menu {
    flex: 1 !important;
    min-height: 52px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    color: rgba(188,210,248,0.72) !important;
    font-family: 'Cinzel', serif !important;
    font-size: 0.72rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

body[data-theme="wizardbattles"] #btn-result-menu:hover {
    background: rgba(255,255,255,0.08) !important;
    color: rgba(210,228,252,0.92) !important;
    transform: translateY(-2px) !important;
}

body[data-theme="wizardbattles"] #btn-result-menu:active {
    transform: translateY(0) !important;
    transition: transform 0.08s ease !important;
}
