/* Стили для системы проверки RTP слотов */
/* 2025-11-03: Обновлена палитра на монохром и добавлены стили для барабанов */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --base-900: #0f0f10;
    --base-800: #161618;
    --base-700: #1f1f22;
    --base-600: #2a2a2d;
    --base-500: #3a3a3f;
    --base-400: #505056;
    --base-300: #6b6b72;
    --accent: #c7c7c7;
    --accent-strong: #f0f0f0;
    --danger: #d9534f;
    --success: #5cb85c;
    --shadow: rgba(0, 0, 0, 0.35);
    --mono-font: 'Fira Mono', 'Roboto Mono', monospace;
}

body {
    font-family: 'Inter', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background: var(--base-900);
    color: var(--accent-strong);
    min-height: 100vh;
    padding: 32px;
}

.layout-dark .container {
    max-width: 1480px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.header {
    background: var(--base-800);
    border: 1px solid var(--base-600);
    border-radius: 16px;
    padding: 24px 32px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    box-shadow: 0 16px 40px var(--shadow);
}

.header h1 {
    font-size: 28px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.nav {
    display: flex;
    gap: 12px;
}

.nav-link {
    text-decoration: none;
    color: var(--accent-strong);
    background: var(--base-700);
    border: 1px solid var(--base-600);
    border-radius: 8px;
    padding: 10px 18px;
    font-size: 14px;
    transition: background 0.2s ease, border 0.2s ease;
}

.nav-link:hover {
    background: var(--base-600);
}

.nav-link.active {
    border-color: var(--accent);
    background: var(--base-600);
}

.main {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.panel {
    background: var(--base-800);
    border: 1px solid var(--base-600);
    border-radius: 16px;
    padding: 24px 28px;
    box-shadow: 0 12px 32px var(--shadow);
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.panel-header h2 {
    font-size: 20px;
    font-weight: 600;
    color: var(--accent-strong);
}

.actions-inline {
    display: flex;
    gap: 12px;
}

.symbols-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 16px;
}

.symbol-card {
    background: var(--base-700);
    border: 1px solid var(--base-500);
    border-radius: 12px;
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* 2025-11-12: Индивидуальные превью символов в списке */
.symbol-thumb {
    width: 82px;
    height: 82px;
    border-radius: 14px;
    background: var(--base-600);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px auto;
    overflow: hidden;
    font-size: 28px;
    color: var(--base-100);
    font-weight: 600;
    text-transform: uppercase;
}

.symbol-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.symbol-thumb.placeholder {
    border: 1px dashed var(--base-500);
}

.symbol-code {
    font-size: 22px;
    font-weight: 600;
}

.symbol-name {
    font-size: 16px;
    color: var(--accent);
}

.symbol-line {
    display: flex;
    justify-content: center;
    font-size: 14px;
    color: var(--accent);
}

.symbol-char {
    font-family: var(--mono-font);
}

.symbol-payouts {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 13px;
    color: var(--accent);
}

.symbol-actions {
    display: flex;
    gap: 8px;
}

.btn {
    border: 1px solid var(--base-500);
    border-radius: 8px;
    padding: 10px 18px;
    font-size: 14px;
    background: var(--base-700);
    color: var(--accent-strong);
    cursor: pointer;
    transition: background 0.2s ease, border 0.2s ease, transform 0.2s ease;
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.btn:hover {
    background: var(--base-600);
    transform: translateY(-1px);
}

.btn-primary {
    background: var(--base-500);
    border-color: var(--base-400);
}

.btn-primary:hover {
    background: var(--base-400);
}

.btn-secondary {
    background: var(--base-700);
}

.btn-accent {
    background: var(--accent);
    color: var(--base-900);
    border-color: var(--accent);
}

.btn-accent:hover {
    background: var(--accent-strong);
    border-color: var(--accent-strong);
}

.btn-ghost {
    background: transparent;
    border-color: var(--base-500);
}

.btn-danger {
    background: var(--danger);
    border-color: var(--danger);
}

.btn-danger:hover {
    background: #bf4240;
    border-color: #bf4240;
}

.settings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 16px;
}

.settings-actions {
    display: flex;
    justify-content: flex-end;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.form-group label {
    font-size: 13px;
    color: var(--accent);
}

.form-group input,
.form-group textarea,
.form-group select {
    background: var(--base-700);
    color: var(--accent-strong);
    border: 1px solid var(--base-500);
    border-radius: 8px;
    padding: 10px 12px;
    font-size: 14px;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--accent);
}

.double-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.triple-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 16px;
}

.modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 1000;
}

.modal.open {
    display: flex;
}

.modal-content {
    background: var(--base-800);
    border: 1px solid var(--base-600);
    border-radius: 16px;
    padding: 28px;
    width: 100%;
    max-width: 520px;
    max-height: 90vh;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
    box-shadow: 0 18px 48px var(--shadow);
}

.modal-content h2 {
    font-size: 22px;
}

.modal-close {
    align-self: flex-end;
    background: transparent;
    border: none;
    color: var(--accent);
    font-size: 22px;
    cursor: pointer;
}

.modal-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-top: 20px; /* 2025-11-12: Добавлен отступ для разделения кнопок и формы */
}

.modal-actions .btn {
    flex: 1;
}

/* 2025-11-12: Превью загруженного изображения символа в модалке */
.symbol-image-preview {
    margin-top: 8px;
    border: 1px dashed var(--base-600);
    border-radius: 8px;
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 120px;
    background: var(--base-700);
}

.symbol-image-preview img {
    max-width: 100%;
    max-height: 120px;
    object-fit: contain;
    border-radius: 6px;
}

.symbol-image-preview .placeholder {
    font-size: 13px;
    color: var(--muted);
}

.reels-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 20px;
}

.reel-sets {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.reel-set-item {
    border: 1px solid var(--base-600);
    background: var(--base-700);
    color: var(--accent-strong);
    border-radius: 10px;
    padding: 12px 14px;
    text-align: left;
    cursor: pointer;
    transition: background 0.2s ease, border 0.2s ease;
}

.reel-set-item .title {
    font-size: 15px;
    font-weight: 500;
}

.reel-set-item .meta {
    font-size: 12px;
    color: var(--accent);
}

.reel-set-item:hover {
    background: var(--base-600);
}

.reel-set-item.selected {
    border-color: var(--accent);
}

.reel-set-item.active {
    background: var(--base-600);
}

.reel-set-item .actions-inline {
    margin-top: 10px; /* отступ от заголовка/меты до кнопок */
    gap: 12px;        /* расстояние между кнопками */
}

.reel-editor {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.set-meta {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

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

.switch span {
    font-size: 13px;
    color: var(--accent);
}

.symbol-palette {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.chip {
    border: 1px solid var(--base-500);
    background: var(--base-700);
    color: var(--accent-strong);
    border-radius: 24px;
    padding: 6px 12px;
    font-size: 13px;
    cursor: pointer;
}

.chip:hover {
    background: var(--base-600);
}

/* 2025-11-12: Интерфейс управления бонусными шаблонами */
.bonus-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 20px;
}

.bonus-sidebar {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.bonus-item {
    border: 1px solid var(--base-600);
    background: var(--base-700);
    border-radius: 10px;
    padding: 12px 14px;
    text-align: left;
    cursor: pointer;
    transition: background 0.2s ease, border 0.2s ease;
}

.bonus-item:hover {
    background: var(--base-600);
}

.bonus-item.selected {
    border-color: var(--accent);
    background: var(--base-600);
}

.bonus-item-title {
    font-size: 15px;
    font-weight: 500;
}

.bonus-item-meta {
    font-size: 12px;
    color: var(--accent);
}

.bonus-editor {
    background: var(--base-700);
    border: 1px solid var(--base-600);
    border-radius: 12px;
    padding: 20px;
    min-height: 320px;
}

.bonus-form {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.bonus-panel {
    margin-top: 18px;
    padding: 18px;
    background: var(--base-700);
    border: 1px solid var(--base-600);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.bonus-panel-header h3 {
    font-size: 16px;
    margin-bottom: 4px;
}

.bonus-panel-header p {
    font-size: 13px;
    color: var(--accent);
}

.bonus-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-height: 44px;
    align-items: center;
}

.chip-bonus {
    background: rgba(1, 208, 219, 0.14);
    border: 1px solid rgba(1, 208, 219, 0.4);
    color: var(--accent-strong);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.chip-bonus .chip-remove {
    background: transparent;
    border: none;
    color: var(--accent);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 0 2px;
}

.chip-bonus .chip-remove:hover {
    color: var(--accent-strong);
}

.chips-selector {
    display: flex;
    gap: 12px;
    align-items: center;
}

.bonus-select {
    flex: 1;
    background: var(--base-700);
    border: 1px solid var(--base-500);
    border-radius: 10px;
    padding: 10px 12px;
    color: var(--accent-strong);
}

.bonus-actions {
    justify-content: flex-start;
    gap: 12px;
}

.bonus-actions .btn {
    flex: 0;
}

.reels-wrapper {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}

.reel-card {
    background: var(--base-700);
    border: 1px solid var(--base-600);
    border-radius: 12px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.reel-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
}

.reel-label {
    margin-top: 6px;
    border: 1px solid var(--base-500);
    border-radius: 6px;
    padding: 6px 8px;
    background: var(--base-600);
    color: var(--accent-strong);
    width: 120px;
    font-size: 12px;
}

.reel-length {
    font-size: 12px;
    color: var(--accent);
}

.reel-text {
    border: 1px solid var(--base-500);
    background: var(--base-600);
    color: var(--accent-strong);
    border-radius: 10px;
    padding: 12px;
    min-height: 160px;
    font-family: var(--mono-font);
    font-size: 13px;
    resize: vertical;
}

.reel-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap; /* чтобы кнопки не выезжали за карточку */
}

.reel-actions .btn {
    flex: 1 1 32%;
    min-width: 0;
    padding: 10px 12px;
}

.reel-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.reel-controls-right {
    display: flex;
    gap: 10px;
}

.empty {
    color: var(--accent);
    font-size: 14px;
    opacity: 0.7;
}

/* Симулятор */
.slot-container {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

/* Онлайн-симулятор: сетка игроков */
.players-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 14px;
}

.player-card {
    background: var(--base-700);
    border: 1px solid var(--base-600);
    border-radius: 12px;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.player-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.player-title { font-weight: 600; }
.player-spins { color: var(--accent); font-size: 12px; }

.player-line { display: flex; justify-content: space-between; font-size: 14px; }
.provider-profit strong { color: var(--accent-strong); }

.player-actions { display: flex; justify-content: flex-end; }

.slot-machine {
    background: var(--base-800);
    border: 1px solid var(--base-600);
    border-radius: 16px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.slot-row {
    display: flex;
    justify-content: center;
    gap: 12px;
}

.slot-cell {
    width: 80px;
    height: 80px;
    background: var(--base-700);
    border: 1px solid var(--base-500);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    transition: transform 0.2s ease;
}

/* 2025-11-12: Отображение изображений символов на поле слота */
.slot-cell.with-image img {
    width: 70%;
    height: 70%;
    object-fit: contain;
    pointer-events: none;
}

.slot-cell.spinning {
    animation: spin 0.25s linear infinite;
}

@keyframes spin {
    0% { transform: rotateY(0deg); }
    100% { transform: rotateY(360deg); }
}

.slot-controls {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
    align-items: center;
}

.last-win {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 14px;
    color: var(--accent);
}

.win-amount {
    font-size: 20px;
    font-weight: 600;
    color: var(--accent-strong);
}

.simulation-section,
.history-section {
    background: var(--base-800);
    border: 1px solid var(--base-600);
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.simulation-controls {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.simulation-results {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

.result-item {
    background: var(--base-700);
    border: 1px solid var(--base-500);
    border-radius: 10px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.result-label {
    font-size: 12px;
    color: var(--accent);
}

.result-value {
    font-size: 20px;
    font-weight: 600;
}

.history-table-container {
    overflow-x: auto;
    border: 1px solid var(--base-600);
    border-radius: 12px;
}

.history-table {
    width: 100%;
    border-collapse: collapse;
}

.history-table th,
.history-table td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--base-600);
    font-size: 13px;
}

.history-table th {
    text-align: left;
    background: var(--base-700);
}

.history-table tbody tr:hover {
    background: var(--base-700);
}

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: var(--base-800);
}

::-webkit-scrollbar-thumb {
    background: var(--base-500);
    border-radius: 6px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--base-400);
}

@media (max-width: 992px) {
    body {
        padding: 16px;
    }

    .reels-layout {
        grid-template-columns: 1fr;
    }

    .bonus-layout {
        grid-template-columns: 1fr;
    }

    .reel-controls {
        flex-direction: column;
        gap: 14px;
        align-items: stretch;
    }

    .reel-controls-right {
        justify-content: space-between;
    }
}
