:root {
    --header-h: 64px;
    --cell: clamp(24px, 4.4vh, 40px);
    --sideW: clamp(54px, 8vw, 76px);
    --feltA: rgba(8,58,46,.58);
    --feltB: rgba(5,32,25,.58);
    --gold1: #ffe39b;
    --gold2: #ffc94a;
    --chipA: #86efac;
    --chipB: #86efac;
    --chipText: #071018;
    --hlY-outline: rgba(255,210,77,.22);
    --hlY-bg: rgba(255,210,77,.10);
    --hlY-shadow: rgba(255,210,77,.10);
    --hlG-outline: rgba(120,255,200,.22);
    --hlG-shadow: rgba(120,255,200,.12);

    /* === VIDEO TUNING === */
    --ov-desktop-fit: cover;
    --ov-desktop-scale: 1.03;
    --ov-desktop-y: 4%;

    --ov-mobile-zoom: 2.5;
    --ov-mobile-y: -2%;
}

* {
    box-sizing: border-box;
}

html, body {
    height: 100%;
    margin: 0;
    overflow: hidden;
    background: #000;
    color: #fff;
    font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

/* === TOPBAR === */
.topbar {
    height: var(--header-h);
    display: flex;
    align-items: center;
    background: rgba(0,0,0,.55);
    border-bottom: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(10px);
    position: relative;
    z-index: 50;
}

.topbar-inner {
    width: min(1400px,96vw);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

.brand-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #78ffc8;
    box-shadow: 0 0 18px rgba(120,255,200,.55);
}

.brand-title {
    font-weight: 950;
    letter-spacing: .5px;
    opacity: .95;
}

.topbar-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(0,0,0,.28);
    font-weight: 850;
    font-size: 13px;
}

.pill b {
    font-weight: 950;
}

.pill.gold {
    border-color: rgba(255,210,77,.35);
    background: rgba(255,210,77,.10);
}

.pill.live {
    font-weight: 950;
    letter-spacing: .2px;
}

.live-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #ff3355;
    box-shadow: 0 0 14px rgba(255,51,85,.55);
}

/* === STAGE/VIDEO === */
.stage {
    height: 100dvh;
    position: relative;
    overflow: hidden;
}

.video-full {
    position: absolute;
    inset: 0;
    background: #000;
    overflow: hidden;
}

.webrtc-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #000;
    overflow: hidden;
}

/* ===== OVENPLAYER WRAPPERS ===== */
.webrtc-video,
.webrtc-video > div,
.ovenplayer,
.ovenplayer .op-wrapper,
.ovenplayer .op-player,
.ovenplayer .op-media-element-container,
.ovenplayer .op-media-element {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    background: #000 !important;
}

/* desktop/base */
.webrtc-video video,
.webrtc-video iframe,
.webrtc-video canvas,
.ovenplayer video,
.ovenplayer .op-media-element video,
.ovenplayer .op-media-element iframe,
.ovenplayer .op-media-element canvas {
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    display: block !important;
    object-fit: var(--ov-desktop-fit) !important;
    object-position: 50% 50% !important;
    transform: translateY(var(--ov-desktop-y)) scale(var(--ov-desktop-scale)) !important;
    transform-origin: 50% 50% !important;
    margin: 0 !important;
    background: #000 !important;
}

/* === ukrycie tylko realnego spinnera OME/OvenPlayer === */
.ovp-spinner,
.ovp-loading-spinner,
.ovenplayer .ovp-spinner,
.ovenplayer .ovp-loading-spinner,
[class*="ovp-spinner"],
[class*="loading-spinner"],
[class*="player-spinner"] {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* === TIMER RING === */
.timer-ring {
    position: absolute;
    left: 50%;
    bottom: 440px;
    transform: translateX(-50%);
    width: 76px;
    height: 76px;
    display: grid;
    place-items: center;
    z-index: 20;
}

.timer-ring[hidden] {
    display: none !important;
}

.timer-svg {
    position: absolute;
    inset: 0;
    transform: scaleX(-1);
}

.timer-progress {
    fill: none;
    stroke: #35ff7a;
    stroke-width: 10;
    stroke-linecap: round;
    stroke-dasharray: 326.73;
    stroke-dashoffset: 0;
    filter: drop-shadow(0 0 10px rgba(0,0,0,.4));
    transform-box: fill-box;
    transform-origin: center;
    transform: rotate(-90deg);
    transition: stroke 120ms linear, stroke-dashoffset 120ms linear;
    will-change: stroke-dashoffset, stroke;
}

.timer-text {
    position: relative;
    font-weight: 950;
    font-size: 30px;
    line-height: 1;
    text-shadow: 0 2px 10px rgba(0,0,0,.55);
}

/* === BADGES / UI === */
.round-result {
    position: absolute;
    left: 50%;
    bottom: 440px;
    transform: translateX(-50%);
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: none;
    backdrop-filter: none;
    font-weight: 950;
    letter-spacing: .2px;
    z-index: 21;
    display: grid;
    place-items: center;
}

.round-result[hidden] {
    display: none !important;
}

.round-result .rr-num {
    width: 76px;
    height: 76px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    color: #fff;
    font-size: 40px;
    line-height: 1;
    text-shadow: 0 2px 10px rgba(0,0,0,.45);
    border: 1px solid rgba(255,255,255,.14);
}

.round-result.green .rr-num { background: rgba(0,180,0,.85); }
.round-result.red .rr-num { background: rgba(210,0,0,.85); }
.round-result.black .rr-num { background: rgba(0,0,0,.85); }

.result-badge {
    position: absolute;
    left: 14px;
    bottom: 14px;
    padding: 10px 14px;
    border-radius: 14px;
    background: rgba(0,0,0,.50);
    border: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(10px);
    font-weight: 950;
    z-index: 20;
    width: fit-content;
    max-width: calc(100vw - 28px);
    box-sizing: border-box;
}

.result-badge[hidden] {
    display: none !important;
}

.result-badge.win {
    outline: 2px solid rgba(0,200,0,.35);
}

.result-badge.lose {
    outline: 2px solid rgba(200,0,0,.35);
}

.result-badge.push {
    outline: 2px solid rgba(180,180,180,.25);
}

.last-results {
    position: absolute;
    right: 14px;
    top: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 14px;
    background: rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(10px);
    z-index: 20;
}

.lr-title {
    font-weight: 950;
    font-size: 12px;
    opacity: .8;
    letter-spacing: .25px;
}

.lr-row {
    display: flex;
    gap: 6px;
}

.lr {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    font-weight: 950;
    font-size: 12px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.18);
}

.lr.red {
    background: rgba(150,20,28,.92);
}

.lr.black {
    background: rgba(10,12,16,.92);
}

.lr.green {
    background: rgba(8,115,72,.92);
}

.icon-btn {
    position: absolute;
    right: 14px;
    top: 74px;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.38);
    color: #fff;
    cursor: pointer;
    display: grid;
    place-items: center;
    backdrop-filter: blur(10px);
    z-index: 20;
}

.quality-btn {
    top: 74px;
    right: 66px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: auto;
    min-width: 44px;
    padding: 0 12px;
}

.quality-badge {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .02em;
    color: rgba(255,255,255,.92);
}

.quality-pop {
    position: absolute;
    right: 66px;
    top: 126px;
    display: none;
    min-width: 220px;
    padding: 12px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(0,0,0,.56);
    backdrop-filter: blur(14px);
    box-shadow: 0 14px 36px rgba(0,0,0,.28);
    z-index: 24;
}

.quality-pop.open {
    display: grid;
    gap: 10px;
}

.quality-pop-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.quality-pop-title {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,.72);
}

.quality-list {
    display: grid;
    gap: 8px;
}

.quality-option {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.06);
    color: #fff;
    font: inherit;
    text-align: left;
    cursor: pointer;
    transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

.quality-option:hover {
    background: rgba(255,255,255,.10);
    border-color: rgba(255,255,255,.16);
}

.quality-option:active {
    transform: scale(.985);
}

.quality-option span {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .01em;
}

.quality-option small {
    font-size: 11px;
    color: rgba(255,255,255,.62);
    font-weight: 700;
}

.quality-option.is-active,
.quality-option[aria-selected="true"] {
    background: rgba(255,255,255,.14);
    border-color: rgba(255,255,255,.24);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}

.quality-note {
    font-size: 12px;
    color: rgba(255,255,255,.78);
    text-align: right;
    font-weight: 600;
}

.vol-btn {
    top: 74px;
}

.vol-pop {
    top: 124px;
}

.vol-pop {
    position: absolute;
    right: 14px;
    top: 124px;
    display: none;
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(0,0,0,.55);
    border: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(10px);
    z-index: 23;
}

.vol-pop.open {
    display: block;
}

.vol-pop input[type="range"] {
    width: 160px;
}

/* === ROULETTE TABLE === */
.table-overlay {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 18px;
    z-index: 12;
    width: min(1180px,96vw);
    padding: 10px 10px 8px;
    border-radius: 16px;
    background: rgba(0,0,0,.18);
    border: 1px solid rgba(255,255,255,.10);
    backdrop-filter: blur(6px);
    transition: transform 260ms ease, opacity 260ms ease, filter 260ms ease;
    transform-origin: bottom center;
}

.table-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2px 6px 8px;
    font-weight: 950;
    letter-spacing: .25px;
    text-shadow: 0 2px 10px rgba(0,0,0,.55);
}

#betStateText {
    font-size: 12px;
    opacity: .85;
}

.table-wrap {
    padding: 10px;
    border-radius: 14px;
    background: radial-gradient(900px 260px at 50% 0%, rgba(255,255,255,.06), transparent 65%), linear-gradient(180deg, var(--feltA), var(--feltB));
    border: 2px solid rgba(120,255,200,.22);
    box-shadow: 0 0 22px rgba(120,255,200,.14);
}

/* GRID */
.rb-grid {
    display: grid;
    gap: 6px;
    grid-template-columns: var(--sideW) repeat(12,1fr) var(--sideW);
    grid-auto-rows: var(--cell);
    align-items: stretch;
    position: relative;
}

/* CELLS */
.rb-cell {
    display: grid;
    place-items: center;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.35);
    cursor: pointer;
    user-select: none;
    font-weight: 950;
    font-size: 14px;
    letter-spacing: .2px;
    position: relative;
    transition: transform .06s ease, filter .15s ease, box-shadow .15s ease, outline .15s ease, background .15s ease;
}

.rb-cell:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
}

.rb-cell:active {
    transform: translateY(0) scale(.985);
}

.rb-cell.num.red {
    background: rgba(170,25,38,.88);
}

.rb-cell.num.black {
    background: rgba(10,12,16,.88);
}

.rb-cell.zero {
    background: rgba(8,125,80,.92);
    border-color: rgba(120,255,200,.22);
    font-size: 18px;
}

.rb-cell.out {
    background: rgba(0,0,0,.18);
    border-color: rgba(120,255,200,.12);
    font-weight: 900;
    font-size: 13px;
}

.rb-cell.out.big {
    font-size: 13px;
}

.rb-cell.selected {
    box-shadow: 0 0 0 3px rgba(255,210,77,.85) inset, 0 0 18px rgba(255,210,77,.18);
}

/* diamonds */
.rb-cell.diamond {
    color: transparent;
}

.rb-cell.diamond::before {
    content: "";
    width: 22px;
    height: 22px;
    transform: rotate(45deg);
    border-radius: 4px;
    display: block;
}

.rb-cell.diamond.red::before {
    background: rgba(255,40,70,.92);
}

.rb-cell.diamond.black::before {
    background: rgba(0,0,0,.88);
    border: 1px solid rgba(255,255,255,.10);
}

/* CHIP ON CELL */
.cell-chip {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 38px;
    height: 38px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    font-weight: 950;
    font-size: 12px;
    line-height: 1;
    color: #111;
    letter-spacing: .2px;
    background: radial-gradient(circle at 35% 28%, rgba(255,255,255,.55), rgba(255,255,255,0) 38%), radial-gradient(circle at 50% 65%, rgba(0,0,0,.25), rgba(0,0,0,0) 52%), linear-gradient(180deg, var(--chipA), var(--chipB));
    border: 2px solid rgba(255,255,255,.22);
    box-shadow: 0 10px 22px rgba(0,0,0,.45), inset 0 2px 2px rgba(255,255,255,.55), inset 0 -4px 10px rgba(0,0,0,.25);
    pointer-events: none;
    text-shadow: 0 1px 0 rgba(255,255,255,.25);
}

.cell-chip::before {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 999px;
    background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.35), rgba(255,255,255,0) 45%), linear-gradient(180deg, rgba(0,0,0,.10), rgba(255,255,255,.10));
    box-shadow: inset 0 0 0 2px rgba(0,0,0,.16), inset 0 0 0 6px rgba(255,255,255,.18);
    opacity: .95;
}

.cell-chip::after {
    content: "";
    position: absolute;
    inset: -2px;
    border-radius: 999px;
    background: repeating-conic-gradient(from -10deg, rgba(255,255,255,0) 0 10deg, rgba(255,255,255,.40) 10deg 14deg, rgba(255,255,255,0) 14deg 30deg);
    mask: radial-gradient(circle, transparent 0 58%, #000 60%);
    opacity: .55;
}

@media (max-width:720px) {
    .cell-chip {
        width: 34px;
        height: 34px;
        font-size: 11px;
    }

    .cell-chip::before {
        inset: 5px;
    }
}

/* CHIPBAR */
.chipbar {
    margin-top: 10px;
    padding: 8px;
    border-radius: 14px;
    background: rgba(0,0,0,.20);
    border: 1px solid rgba(255,255,255,.08);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.chipbar-left {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.chipbar-label {
    font-weight: 900;
    opacity: .75;
}

.chipbar-right {
    font-size: 12px;
    opacity: .7;
    font-weight: 800;
}

.chip {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 2px solid rgba(255,255,255,.22);
    background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.18), rgba(0,0,0,.30)), rgba(30,40,58,.85);
    color: #fff;
    font-weight: 950;
    cursor: pointer;
    position: relative;
    box-shadow: 0 10px 20px rgba(0,0,0,.35);
    transition: transform .08s ease, filter .15s ease, box-shadow .15s ease;
}

.chip span {
    position: relative;
    z-index: 2;
}

.chip::after {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 999px;
    border: 2px dashed rgba(255,255,255,.22);
    opacity: .55;
}

.chip:hover {
    transform: translateY(-1px);
    filter: brightness(1.08);
}

.chip:active {
    transform: translateY(0) scale(.985);
}

.chip.active {
    color: #111 !important;
    border-color: rgba(255,210,77,.65);
    background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.30), rgba(0,0,0,.18)), linear-gradient(180deg, var(--gold1), var(--gold2));
    box-shadow: 0 0 0 4px rgba(255,210,77,.18), 0 12px 26px rgba(0,0,0,.45);
}

.btn-clear {
    padding: 10px 14px;
    border-radius: 12px;
    border: 1px solid rgba(255,120,120,.25);
    background: rgba(210,70,70,.20);
    color: #fff;
    font-weight: 950;
    cursor: pointer;
}

.btn-clear[disabled] {
    opacity: .55;
    pointer-events: none;
}

/* OPEN vs MINI */
.table-overlay.open {
    opacity: .90;
    transform: translateX(-50%) translateY(0) scale(1);
    filter: none;
}

.table-overlay.mini {
    opacity: .50;
    transform: translateX(-50%) translateY(16px) scale(.60);
    filter: saturate(.9) brightness(.95);
}

.table-overlay.mini .chipbar {
    display: none;
}

.table-overlay.mini {
    padding: 8px 8px 6px;
}

.watermark {
    position: absolute;
    right: 12px;
    bottom: 8px;
    font-size: 12px;
    font-weight: 700;
    color: rgba(255,255,255,.55);
    pointer-events: none;
    z-index: 12;
}

@media (max-width:720px) {
    .table-overlay {
        bottom: 10px;
    }

    .last-results {
        top: 10px;
        right: 10px;
    }

    .icon-btn {
        top: 64px;
        right: 10px;
    }

    .vol-pop {
        top: 114px;
        right: 10px;
    }

    .table-overlay.mini {
        transform: translateX(-50%) translateY(18px) scale(.70);
    }
}

/* ===== LOCKED ===== */
.table-overlay.locked {
    opacity: .78;
}

.table-overlay.locked #betStateText {
    color: rgba(255,210,77,.95);
}

.table-overlay.locked .rb-grid {
    pointer-events: auto;
    filter: grayscale(.25) brightness(.95);
}

.table-overlay.locked .rb-cell {
    cursor: not-allowed;
}

/* HIGHLIGHTS */
.rb-cell.grouped {
    filter: brightness(1.16);
    outline: 2px solid var(--hlG-outline);
    box-shadow: 0 0 18px var(--hlG-shadow);
}

.rb-cell.prehover {
    filter: brightness(1.14);
    outline: 2px solid rgba(255,210,77,.28);
    box-shadow: 0 0 18px rgba(255,210,77,.10);
}

.rb-cell.hovered {
    filter: brightness(1.14);
    outline: 2px solid rgba(255,210,77,.25);
}

.rb-cell[data-type="NUMBER"]:hover {
    filter: brightness(1.12);
    outline: 2px solid var(--hlY-outline);
    box-shadow: 0 0 16px var(--hlY-shadow);
}

.rb-cell[data-type="DOZEN"]:hover,
.rb-cell[data-type="COLUMN"]:hover {
    filter: brightness(1.10);
    background: var(--hlY-bg);
    outline: 2px solid var(--hlY-outline);
    box-shadow: 0 0 14px var(--hlY-shadow);
}

/* HOTSPOTS */
.bet-hotspot {
    position: absolute;
    z-index: 35;
    cursor: pointer;
    border-radius: 10px;
    background: transparent !important;
    outline: none !important;
    box-shadow: none !important;
    transition: none !important;
}

.bet-hotspot:hover,
.bet-hotspot:active,
.bet-hotspot:focus {
    background: transparent !important;
    outline: none !important;
    box-shadow: none !important;
}

.bet-hotspot .cell-chip {
    width: 34px;
    height: 34px;
    font-size: 11px;
}

.table-overlay.locked .bet-hotspot {
    pointer-events: none;
}

.table-overlay.locked .rb-cell.prehover,
.table-overlay.locked .rb-cell.hovout,
.table-overlay.locked .rb-cell.hovcell,
.table-overlay.locked .rb-cell.hovered {
    filter: none !important;
    outline: none !important;
    box-shadow: none !important;
    transform: none !important;
}

/* =========================================================
   MOBILE PATCH (ONLY <=720px)
   ========================================================= */
@media (max-width: 720px) {

    :root {
        --header-h: 72px;
    }

    .topbar {
        height: var(--header-h);
    }

    .topbar-inner {
        width: 100%;
        padding: 8px 10px;
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-rows: auto auto;
        gap: 6px 10px;
        align-items: center;
    }

    .brand {
        grid-column: 1 / -1;
        grid-row: 1;
        min-width: 0;
    }

    .brand-title {
        font-size: 15px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .topbar-right {
        grid-column: 1 / -1;
        grid-row: 2;
        display: flex;
        justify-content: flex-end;
        gap: 8px;
        flex-wrap: nowrap;
        min-width: 0;
    }

    .pill {
        padding: 6px 10px;
        font-size: 11px;
        white-space: nowrap;
    }

    .pill.gold {
        padding: 6px 10px;
    }

    .stage {
        height: calc(100dvh - var(--header-h));
    }

    .last-results {
        position: fixed;
        top: calc(env(safe-area-inset-top) + 64px);
        left: 50%;
        transform: translateX(-50%);
        width: max-content;
        max-width: calc(100vw - 20px);
        box-sizing: border-box;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        padding: 8px 10px;
        overflow: hidden;
    }

    .table-overlay {
        z-index: 40;
    }

    .timer-ring {
        left: 12px;
        bottom: 12px;
        right: auto;
        top: auto;
        transform: none;
        width: 66px;
        height: 66px;
        z-index: 45;
    }

    .timer-text {
        font-size: 26px;
    }

    .table-overlay.mini {
        position: fixed;
        left: 50%;
        bottom: 10px;
        top: auto;
        transform: translateX(-50%);
        width: min(98vw, 820px);
        max-width: 98vw;
        padding: 8px 8px 6px;
        opacity: .55;
    }

    .table-overlay.mini .chipbar {
        display: none;
    }

    .table-wrap {
        padding: 8px;
        overflow: hidden;
    }

    :root {
        --sideW: clamp(38px, 7vw, 52px);
        --cell: clamp(22px, 4.2vh, 34px);
        --gap: 4px;
    }

    .rb-grid {
        gap: var(--gap);
        grid-auto-rows: var(--cell);
    }

    .rb-cell {
        border-radius: 7px;
        font-size: 12px;
    }

    .rb-cell.zero {
        font-size: 15px;
    }

    .chipbar-left {
        flex-wrap: wrap;
    }

    .chip {
        width: 38px;
        height: 38px;
    }

    .btn-clear {
        padding: 9px 12px;
    }

    .table-overlay {
        transition: opacity 220ms ease, filter 220ms ease;
        will-change: opacity, transform;
        transform: translateZ(0);
        backface-visibility: hidden;
    }

    .video-full {
        background: #000;
        overflow: hidden;
    }

    /* ===== MOBILE VIDEO ===== */
    .webrtc-video video,
    .webrtc-video iframe,
    .webrtc-video canvas,
    .ovenplayer video,
    .ovenplayer .op-media-element video,
    .ovenplayer .op-media-element iframe,
    .ovenplayer .op-media-element canvas {
        object-fit: contain !important;
        object-position: 50% 50% !important;
        transform: translateY(var(--ov-mobile-y)) scale(var(--ov-mobile-zoom)) !important;
        transform-origin: 50% 50% !important;
        background: #000 !important;
    }
}

/* PORTRAIT: OPEN = obrót 90° */
@media (max-width: 720px) and (orientation: portrait) {

    .table-overlay.open {
        position: fixed;
        left: 50%;
        top: calc(var(--header-h) + (100dvh - var(--header-h))/2);
        bottom: auto;
        width: calc(100dvh - var(--header-h) - 22px);
        max-width: none;
        transform-origin: center;
        transform: translate(-50%,-50%) rotate(90deg) scale(.90);
    }

    .table-overlay.mini {
        transform: translateX(-50%);
        width: min(98vw, 820px);
    }

    .rb-cell[data-type="COLUMN"] {
        white-space: nowrap;
    }
}

/* Ultra small */
@media (max-width: 380px) {
    :root {
        --sideW: 34px;
        --cell: 20px;
        --gap: 3px;
    }

    .rb-cell {
        font-size: 11px;
    }

    .rb-cell.zero {
        font-size: 14px;
    }

    .chip {
        width: 34px;
        height: 34px;
    }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    .table-overlay {
        transition: none !important;
    }
}

@media (max-width: 720px) and (orientation: portrait) {

    .table-overlay.open .rb-cell[data-type="NUMBER"] {
        color: transparent;
    }

    .table-overlay.open .rb-cell[data-type="NUMBER"]::after {
        content: attr(data-value);
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%) rotate(-90deg);
        transform-origin: center;
        color: #fff;
        font-weight: 950;
        letter-spacing: .2px;
        line-height: 1;
        pointer-events: none;
        text-shadow: 0 2px 10px rgba(0,0,0,.55);
    }

    .table-overlay.open .rb-cell.zero[data-type="NUMBER"]::after {
        font-size: 18px;
    }
}

/* =========================================================
   MOBILE PORTRAIT / BETS OPEN
   ========================================================= */
@media (max-width: 720px) and (orientation: portrait) {

    .table-overlay.open .cell-chip {
        z-index: 6;
        transform: translate(-50%,-50%) rotate(-90deg);
        transform-origin: center;
    }

    .table-overlay.open .rb-cell[data-type="NUMBER"]::after {
        z-index: 2;
    }

    .table-overlay.open .rb-cell[data-type="NUMBER"]:has(.cell-chip)::after {
        top: 18%;
        transform: translate(-50%, -50%) rotate(-90deg);
    }

    .table-overlay.open .rb-cell.out:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="DOZEN"]:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="COLUMN"]:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="EVENODD"]:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="LOWHIGH"]:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="COLOR"]:has(.cell-chip) {
        place-items: start center;
        padding-top: 6px;
    }

    .table-overlay.open .rb-cell.out:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="DOZEN"]:has(.cell-chip),
    .table-overlay.open .rb-cell[data-type="COLUMN"]:has(.cell-chip) {
        font-size: 12px;
        line-height: 1;
    }
}

@media (max-width: 720px) and (orientation: portrait) {

    .table-overlay.open .chipbar-label,
    .table-overlay.open .chip span {
        display: inline-block;
        transform: rotate(-90deg);
        transform-origin: center;
    }

    .table-overlay.open .chip span {
        line-height: 1;
    }
}

@media (max-width: 720px) {

    .round-result {
        left: 50%;
        right: auto;
        top: 38%;
        bottom: auto;
        transform: translate(-50%, -50%);
        z-index: 46;
    }

    .round-result .rr-num {
        width: 64px;
        height: 64px;
        border-radius: 18px;
        font-size: 34px;
    }

    .result-badge {
        position: fixed;
        top: auto;
        left: auto;
        right: max(10px, env(safe-area-inset-right));
        bottom: max(10px, env(safe-area-inset-bottom));
        z-index: 9999;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: auto;
        max-width: min(calc(100vw - 20px), 280px);
        min-height: 44px;
        padding: 10px 14px;
        font-size: clamp(12px, 3.4vw, 15px);
        line-height: 1.2;
        text-align: center;
        white-space: normal;
        word-break: keep-all;
        overflow-wrap: anywhere;
        box-sizing: border-box;
    }
}

/* ===== LOADER FULLSCREEN ===== */
.app-loader {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100dvh;
    overflow: hidden;
    overscroll-behavior: none;
    z-index: 99999;
    opacity: 1;
    transition: opacity .55s ease;
}

.app-loader.is-hidden {
    opacity: 0;
    pointer-events: none;
}

.app-loader .loader-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.03);
    filter: brightness(.95);
    pointer-events: none;
}

.app-loader::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.25);
}

.app-loader .loader-card {
    position: relative;
    z-index: 1;
    height: 100%;
    width: 100%;
    display: grid;
    place-items: center;
    gap: 10px;
    text-align: center;
    padding: calc(env(safe-area-inset-top) + 18px) 16px calc(env(safe-area-inset-bottom) + 18px);
    transition: transform .55s ease, opacity .55s ease;
}

.app-loader.is-hidden .loader-card {
    opacity: 0;
    transform: translateY(8px);
}

.loader-img {
    width: min(320px, 80vw);
    height: auto;
    border-radius: 16px;
    animation: logoPulse 1.6s ease-in-out infinite;
    will-change: transform, filter, opacity;
}

.loader-copy {
    display: grid;
    gap: 10px;
    justify-items: center;
    width: min(640px, 86vw);
}

.loader-title {
    color: #fff;
    font-size: clamp(22px, 2.2vw, 30px);
    font-weight: 500;
    letter-spacing: .01em;
    text-transform: none;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .45);
}

.loader-sub {
    color: rgba(255,255,255,.92);
    font-size: clamp(14px, 1.2vw, 17px);
    line-height: 1.55;
    font-weight: 400;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .45);
    max-width: 54ch;
}

.loader-hint {
    color: rgba(255,255,255,.68);
    font-size: 12px;
    line-height: 1.55;
    max-width: 58ch;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .35);
}

.app-loader[data-mode="loading"] .loader-title {
    letter-spacing: .02em;
}

.app-loader[data-mode="disconnect"] .loader-title,
.app-loader[data-mode="error"] .loader-title {
    color: rgba(255,255,255,.96);
}

@keyframes logoPulse {
    0%, 100% {
        transform: scale(1);
        filter: brightness(.85);
        opacity: .85;
    }

    50% {
        transform: scale(1.03);
        filter: brightness(1.20);
        opacity: 1;
    }
}

/* Quality icon (SVG) */
.quality-btn .quality-ic{
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    opacity: .95;
}

.quality-btn.is-auto .quality-badge {
    color: rgba(255,255,255,.82);
}

/* Volume icon (SVG) */
.vol-btn .vol-ic{
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.vol-btn.is-muted .vol-ic--on { display:none; }
.vol-btn:not(.is-muted) .vol-ic--muted { display:none; }

/* === QUALITY / VOLUME MOBILE LAYOUT === */
@media (max-width: 720px) {
    .vol-btn,
    .quality-btn {
        position: fixed;
        right: 12px;
        left: auto;
        bottom: auto;
        z-index: 60;
    }

    .vol-btn {
        top: calc(var(--header-h, 72px) + 64px);
    }

    .quality-btn {
        top: calc(var(--header-h, 72px) + 116px);
        padding: 0 10px;
        min-width: 44px;
    }

    .quality-badge {
        font-size: 11px;
    }

    .quality-pop {
        position: fixed;
        top: calc(var(--header-h, 72px) + 168px);
        right: 12px;
        bottom: auto;
        left: auto;
        min-width: 190px;
        max-width: min(220px, calc(100vw - 24px));
        padding: 10px;
        z-index: 61;
    }

    .quality-pop-title,
    .quality-note {
        font-size: 11px;
    }

    .quality-option {
        padding: 10px 11px;
    }

    .quality-option span {
        font-size: 12px;
    }

    .quality-option small {
        font-size: 10px;
    }

    .vol-pop {
        display: none !important;
    }
}

/* === Desktop: lower results / volume / quality a bit === */
@media (min-width: 721px) {
    .last-results {
        top: 60px;
    }

    .vol-btn {
        top: 110px;
    }

    .quality-btn {
        top: 110px;
    }

    .vol-pop {
        top: 160px;
    }

    .quality-pop {
        top: 160px;
    }
}

@media (max-width: 430px) {
    .last-results {
        position: fixed;
        top: calc(env(safe-area-inset-top) + 64px);
        left: 50%;
        transform: translateX(-50%);
        width: max-content;
        max-width: calc(100vw - 16px);
        box-sizing: border-box;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        padding: 7px 8px;
        overflow: hidden;
    }

    .lr-title {
        flex: 0 0 auto;
        font-size: 10px;
        white-space: nowrap;
    }

    .lr-row {
        flex: 0 1 auto;
        min-width: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 4px;
        overflow-x: auto;
        overflow-y: hidden;
        white-space: nowrap;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .lr-row::-webkit-scrollbar {
        display: none;
    }

    .lr {
        flex: 0 0 auto;
        width: 21px;
        height: 21px;
        min-width: 21px;
        font-size: 10px;
        border-radius: 6px;
    }
}

/* === OME hard autoplay / no direct interaction === */
.webrtc-video,
.webrtc-video video,
.webrtc-video iframe,
.webrtc-video canvas {
    pointer-events: none !important;
}

.stream-shield {
    position: absolute;
    inset: 0;
    z-index: 9;
    background: transparent;
    pointer-events: auto;
}

.icon-btn,
.quality-pop,
.vol-pop,
.timer-ring,
.round-result,
.result-badge,
.last-results,
.table-overlay,
.app-loader {
    z-index: 20;
}

/* TEST OVERRIDE */
#webrtcPlayer, #webrtcPlayer video, .ovenplayer, .ovenplayer video {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
  visibility: visible !important;
  opacity: 1 !important;
  background: #000 !important;
}
