:root {
    --tower-bg: #000;
    --tower-panel: #0d0d0d;
    --tower-panel-soft: #15110e;
    --tower-line: rgba(255, 106, 26, 0.32);
    --tower-line-soft: rgba(255, 255, 255, 0.09);
    --tower-text: #fff8f1;
    --tower-muted: rgba(255, 216, 190, 0.62);
    --tower-orange: #ff6a1a;
    --tower-gold: #ffd36a;
    --tower-green: #55e68a;
    --tower-red: #ff536f;
}

* {
    box-sizing: border-box;
}

.tower-full-page {
    padding-top: 116px;
    min-height: 100vh;
    height: 100vh;
    background: #000;
    overflow: hidden;
}

.tower-shell {
    display: grid;
    grid-template-columns: 340px minmax(0, 1fr) 320px;
    gap: 14px;
    width: min(1760px, calc(100vw - 28px));
    min-height: 0;
    height: calc(100vh - 132px);
    margin: 0 auto;
    padding: 12px 0 18px;
    color: var(--tower-text);
    font-family: "Inter", "Segoe UI", sans-serif;
}

.tower-left-panel,
.tower-stage-panel,
.tower-queue-panel {
    min-width: 0;
    min-height: 0;
    border: 1px solid var(--tower-line);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(18, 18, 18, 0.96), rgba(5, 5, 5, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 106, 26, 0.16),
        0 18px 48px rgba(0, 0, 0, 0.42);
}

.tower-left-panel,
.tower-queue-panel {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 16px;
}

.tower-left-panel {
    overflow-y: auto;
}

.tower-queue-panel {
    overflow: hidden;
}

.tower-stage-panel {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
}

.tower-title-block h1,
.tower-panel-head h2,
.tower-stage-head h2 {
    margin: 0;
    color: #fff;
    font-family: "Orbitron", sans-serif;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
}

.tower-title-block h1 {
    font-size: 32px;
}

.tower-title-block p,
.tower-player-panel p {
    margin: 10px 0 0;
    color: var(--tower-muted);
    font-size: 13px;
    line-height: 1.5;
}

.tower-eyebrow,
.tower-admin-form span,
.tower-admin-queue-controls span,
.tower-prize-editor > span {
    display: block;
    color: rgba(255, 211, 106, 0.72);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.tower-status-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.tower-status-grid div {
    min-width: 0;
    border: 1px solid var(--tower-line-soft);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.035);
    padding: 11px 10px;
}

.tower-status-grid span {
    display: block;
    color: rgba(255, 255, 255, 0.42);
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.tower-status-grid strong {
    display: block;
    margin-top: 6px;
    color: var(--tower-gold);
    font-family: "Orbitron", sans-serif;
    font-size: 15px;
    overflow-wrap: anywhere;
}

.tower-notice {
    border: 1px solid rgba(255, 211, 106, 0.32);
    border-radius: 10px;
    background: rgba(255, 211, 106, 0.08);
    color: var(--tower-gold);
    padding: 11px 12px;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.35;
}

.tower-notice.is-error {
    border-color: rgba(255, 83, 111, 0.38);
    background: rgba(255, 83, 111, 0.09);
    color: #ffc2cc;
}

.tower-notice.is-success {
    border-color: rgba(85, 230, 138, 0.36);
    background: rgba(85, 230, 138, 0.08);
    color: #a6f7c2;
}

.hidden {
    display: none !important;
}

.tower-player-panel,
.tower-admin-panel {
    border: 1px solid var(--tower-line-soft);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.035);
    padding: 14px;
}

.tower-panel-head,
.tower-stage-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.tower-stage-head {
    border-bottom: 1px solid var(--tower-line-soft);
    padding: 18px 20px;
}

.tower-active-heading {
    display: flex;
    align-items: center;
    min-width: 0;
    gap: 12px;
}

.tower-active-heading .tower-contestant-avatar {
    flex: 0 0 auto;
}

.tower-active-heading h2 {
    overflow-wrap: anywhere;
}

.tower-panel-head h2,
.tower-stage-head h2 {
    margin-top: 6px;
    font-size: 18px;
}

.tower-badge {
    flex: 0 0 auto;
    border: 1px solid rgba(255, 106, 26, 0.38);
    border-radius: 999px;
    background: rgba(255, 106, 26, 0.1);
    color: #ffd0b4;
    padding: 7px 10px;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.12em;
    line-height: 1;
    text-transform: uppercase;
}

.tower-badge.is-admin {
    border-color: rgba(255, 211, 106, 0.4);
    background: rgba(255, 211, 106, 0.09);
    color: var(--tower-gold);
}

.tower-actions,
.tower-admin-queue-controls {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 14px;
}

.tower-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border: 1px solid rgba(255, 106, 26, 0.42);
    border-radius: 10px;
    background: #14100d;
    color: #ffd5bd;
    padding: 10px 14px;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.14s ease, border-color 0.14s ease, background 0.14s ease;
}

.tower-action:hover:not(:disabled) {
    transform: translateY(-1px);
    border-color: rgba(255, 106, 26, 0.74);
    background: #1d120b;
}

.tower-action:disabled {
    cursor: not-allowed;
    opacity: 0.42;
}

.tower-action.is-primary {
    border-color: rgba(255, 126, 40, 0.72);
    background: linear-gradient(180deg, #ff8b1f 0%, #ff5b00 100%);
    color: #fff;
}

.tower-action.is-amber {
    border-color: rgba(255, 211, 106, 0.55);
    background: rgba(255, 211, 106, 0.12);
    color: #ffe9a8;
}

.tower-action.is-green {
    border-color: rgba(85, 230, 138, 0.5);
    background: rgba(85, 230, 138, 0.12);
    color: #b8ffd1;
}

.tower-action.is-danger {
    border-color: rgba(255, 83, 111, 0.42);
    background: rgba(255, 83, 111, 0.1);
    color: #ffc2cc;
}

.tower-admin-form {
    display: grid;
    gap: 10px;
    margin-top: 14px;
}

.tower-admin-form label,
.tower-admin-queue-controls label {
    display: block;
}

.tower-admin-form input,
.tower-admin-form select,
.tower-admin-queue-controls input,
.tower-prize-editor input {
    width: 100%;
    height: 40px;
    margin-top: 6px;
    border: 1px solid rgba(255, 106, 26, 0.34);
    border-radius: 10px;
    background: #080808;
    color: #fff8f1;
    padding: 8px 10px;
    font-size: 13px;
    outline: none;
}

.tower-admin-form input:focus,
.tower-admin-form select:focus,
.tower-admin-queue-controls input:focus,
.tower-prize-editor input:focus {
    border-color: rgba(255, 106, 26, 0.78);
    box-shadow: 0 0 0 2px rgba(255, 106, 26, 0.14);
}

.tower-prize-editor {
    display: grid;
    gap: 8px;
}

#towerPrizeInputs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
}

.tower-prize-input {
    position: relative;
}

.tower-prize-input span {
    position: absolute;
    top: 6px;
    left: 9px;
    color: rgba(255, 255, 255, 0.42);
    font-size: 9px;
    font-weight: 900;
}

.tower-prize-input input {
    padding-top: 17px;
}

.tower-board-wrap {
    position: relative;
    display: grid;
    min-height: 0;
    overflow: hidden;
}

.tower-board {
    display: flex;
    flex-direction: column-reverse;
    gap: 10px;
    min-height: 0;
    height: 100%;
    padding: 16px 18px;
    background:
        linear-gradient(90deg, rgba(255, 106, 26, 0.04), transparent 22%, transparent 78%, rgba(255, 106, 26, 0.04)),
        rgba(0, 0, 0, 0.16);
    overflow-y: auto;
}

.tower-row {
    flex: 0 0 auto;
    display: grid;
    grid-template-columns: clamp(88px, 9vw, 112px) minmax(0, 1fr) clamp(96px, 9vw, 118px);
    align-items: center;
    gap: 12px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.035);
    padding: 10px;
    min-height: 70px;
}

.tower-row.is-current {
    border-color: rgba(255, 211, 106, 0.55);
    background: rgba(255, 211, 106, 0.07);
    box-shadow: 0 0 24px rgba(255, 211, 106, 0.09);
}

.tower-row.is-cleared {
    border-color: rgba(85, 230, 138, 0.42);
    background: rgba(85, 230, 138, 0.07);
}

.tower-row.is-busted {
    border-color: rgba(255, 83, 111, 0.45);
    background: rgba(255, 83, 111, 0.07);
}

.tower-level-label strong {
    display: block;
    color: #fff;
    font-family: "Orbitron", sans-serif;
    font-size: 15px;
}

.tower-level-label span,
.tower-prize-label span {
    display: block;
    margin-top: 3px;
    color: rgba(255, 255, 255, 0.42);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.tower-box-grid {
    display: grid;
    gap: 8px;
    align-items: stretch;
    min-width: 0;
}

.tower-box-grid.boxes-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tower-box-grid.boxes-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.tower-box-grid.boxes-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.tower-box {
    position: relative;
    display: grid;
    place-items: center;
    width: 100%;
    height: clamp(40px, 5.2vh, 48px);
    min-height: 0;
    aspect-ratio: auto;
    border: 1px solid rgba(255, 106, 26, 0.34);
    border-radius: 9px;
    background: linear-gradient(180deg, #16110e, #090909);
    color: rgba(255, 255, 255, 0.74);
    font-family: "Orbitron", sans-serif;
    font-size: 16px;
    font-weight: 900;
    line-height: 1;
    cursor: pointer;
    overflow: hidden;
    transform: translateZ(0);
}

.tower-box:disabled {
    cursor: default;
    opacity: 0.62;
}

.tower-row.is-current .tower-box:not(:disabled):hover {
    border-color: rgba(255, 211, 106, 0.78);
    color: #fff;
    transform: translateY(-1px);
}

.tower-box.is-selected,
.tower-box.is-safe {
    border-color: rgba(85, 230, 138, 0.68);
    background: rgba(85, 230, 138, 0.16);
    color: #caffd8;
}

.tower-box.is-bust {
    border-color: rgba(255, 83, 111, 0.72);
    background:
        radial-gradient(circle at center, rgba(255, 66, 66, 0.34), transparent 58%),
        rgba(30, 0, 0, 0.86);
    color: #ffd2d9;
    animation: towerBombDetonate 0.36s ease-out;
}

.tower-bomb {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 3;
    width: 1.55rem;
    height: 1.55rem;
    border-radius: 999px;
    background:
        radial-gradient(circle at 35% 30%, #fff5b8, #ff7600 28%, #2a0202 68%);
    box-shadow:
        0 0 18px rgba(255, 90, 0, 0.88),
        0 0 34px rgba(255, 36, 36, 0.5);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.2);
    animation: towerBombPop 0.36s ease-out forwards;
}

.tower-bomb::after {
    content: '';
    position: absolute;
    left: 50%;
    top: -0.42rem;
    width: 0.44rem;
    height: 0.62rem;
    border-top: 2px solid #f7d07a;
    border-left: 2px solid #f7d07a;
    border-radius: 0.5rem 0 0 0;
    transform: rotate(18deg);
}

.tower-blast {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 4;
    width: 0.8rem;
    height: 0.8rem;
    border: 2px solid rgba(255, 132, 0, 0.95);
    border-radius: 999px;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -50%) scale(0.35);
    animation: towerBombBlast 0.44s ease-out;
}

.tower-box-sr {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.tower-box.is-revealed-safe {
    border-color: rgba(255, 211, 106, 0.72);
    background: rgba(255, 211, 106, 0.14);
    color: #ffe9a8;
}

.tower-prize-label {
    text-align: right;
}

.tower-prize-label strong {
    display: block;
    color: var(--tower-gold);
    font-family: "Orbitron", sans-serif;
    font-size: 14px;
}

@keyframes towerBombDetonate {
    0% { transform: scale(1); filter: brightness(1); }
    22% { transform: translate3d(-3px, 2px, 0) scale(1.06); filter: brightness(1.75); }
    46% { transform: translate3d(3px, -2px, 0) scale(1.02); }
    72% { transform: translate3d(-2px, 1px, 0) scale(0.98); }
    100% { transform: scale(1); filter: brightness(1); }
}

@keyframes towerBombPop {
    0% { opacity: 0; transform: translate(-50%, -50%) scale(0.2); }
    32% { opacity: 1; transform: translate(-50%, -50%) scale(1.28); }
    100% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

@keyframes towerBombBlast {
    0% { opacity: 0.95; transform: translate(-50%, -50%) scale(0.35); }
    70% { opacity: 0.42; transform: translate(-50%, -50%) scale(4.2); }
    100% { opacity: 0; transform: translate(-50%, -50%) scale(5.2); }
}

.tower-queue-list {
    display: grid;
    flex: 1 1 auto;
    align-content: start;
    gap: 9px;
    min-height: 0;
    padding-right: 4px;
    overflow-y: auto;
}

.tower-queue-join {
    display: grid;
    gap: 10px;
    border: 1px solid rgba(255, 106, 26, 0.22);
    border-radius: 12px;
    background: rgba(255, 106, 26, 0.06);
    padding: 12px;
}

.tower-queue-join p {
    margin: 5px 0 0;
    color: rgba(255, 255, 255, 0.55);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.4;
}

.tower-contestant-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 7px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.035);
    padding: 11px;
}

.tower-contestant-avatar {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(255, 106, 26, 0.32);
    border-radius: 999px;
    background: rgba(255, 106, 26, 0.1);
    color: #ffd0b4;
    font-family: "Orbitron", sans-serif;
    font-size: 11px;
    font-weight: 900;
    object-fit: cover;
    overflow: hidden;
}

.tower-contestant-avatar img {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    object-fit: cover;
}

.tower-contestant-avatar.is-empty {
    opacity: 0.46;
}

.tower-contestant-main {
    min-width: 0;
}

.tower-contestant-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.tower-contestant-topline span {
    flex: 0 0 auto;
    color: rgba(255, 211, 106, 0.58);
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.tower-contestant-card.is-playing {
    border-color: rgba(255, 211, 106, 0.48);
    background: rgba(255, 211, 106, 0.08);
}

.tower-contestant-card.is-cashed_out {
    border-color: rgba(85, 230, 138, 0.38);
}

.tower-contestant-card.is-busted {
    border-color: rgba(255, 83, 111, 0.35);
}

.tower-contestant-card h3 {
    margin: 0;
    color: #fff;
    font-size: 14px;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tower-contestant-card p {
    margin: 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.35;
}

.tower-contestant-card button {
    min-height: 34px;
    border-radius: 8px;
    font-size: 10px;
}

.tower-moment {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 5;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 14px;
    width: min(420px, calc(100% - 32px));
    border: 1px solid rgba(255, 106, 26, 0.42);
    border-radius: 14px;
    background:
        radial-gradient(circle at top right, rgba(255, 106, 26, 0.24), transparent 42%),
        rgba(8, 8, 8, 0.94);
    box-shadow:
        0 24px 70px rgba(0, 0, 0, 0.62),
        0 0 34px rgba(255, 106, 26, 0.22);
    padding: 18px;
    pointer-events: none;
    transform: translate(-50%, -50%) scale(0.98);
    opacity: 0;
}

.tower-moment.is-visible {
    animation: towerMomentPulse 1.75s ease forwards;
}

.tower-moment.is-loss {
    border-color: rgba(255, 83, 111, 0.62);
    background:
        radial-gradient(circle at top right, rgba(255, 83, 111, 0.24), transparent 42%),
        rgba(8, 8, 8, 0.95);
    box-shadow:
        0 24px 70px rgba(0, 0, 0, 0.62),
        0 0 38px rgba(255, 83, 111, 0.22);
}

.tower-moment .tower-contestant-avatar {
    width: 62px;
    height: 62px;
    font-size: 14px;
}

.tower-moment span,
.tower-moment small {
    display: block;
    color: rgba(255, 211, 106, 0.72);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.18em;
    line-height: 1.2;
    text-transform: uppercase;
}

.tower-moment strong {
    display: block;
    margin: 5px 0;
    color: #fff;
    font-family: "Orbitron", sans-serif;
    font-size: clamp(18px, 3vw, 27px);
    font-weight: 900;
    line-height: 1;
    overflow-wrap: anywhere;
    text-transform: uppercase;
}

.tower-moment small {
    color: rgba(255, 255, 255, 0.48);
    letter-spacing: 0.12em;
}

@keyframes towerMomentPulse {
    0% {
        opacity: 0;
        transform: translate(-50%, -46%) scale(0.96);
    }

    14%,
    76% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }

    100% {
        opacity: 0;
        transform: translate(-50%, -54%) scale(0.98);
    }
}

.tower-empty {
    display: grid;
    place-items: center;
    min-height: 120px;
    border: 1px dashed rgba(255, 255, 255, 0.14);
    border-radius: 10px;
    color: rgba(255, 255, 255, 0.38);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-align: center;
    text-transform: uppercase;
}

@media (max-width: 1180px) {
    .tower-full-page {
        padding-top: 88px;
        height: auto;
        overflow: visible;
    }

    .tower-shell {
        grid-template-columns: 1fr;
        width: min(980px, calc(100vw - 24px));
        min-height: calc(100vh - 104px);
        height: auto;
    }

    .tower-board {
        max-height: none;
    }

    .tower-queue-list {
        max-height: min(460px, 60vh);
    }

}

@media (max-width: 720px) {
    .tower-shell {
        width: calc(100vw - 18px);
    }

    .tower-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .tower-prize-label {
        text-align: left;
    }

    .tower-box {
        height: 38px;
        min-height: 0;
        aspect-ratio: auto;
    }

    #towerPrizeInputs,
    .tower-status-grid {
        grid-template-columns: 1fr;
    }
}
