/* ===== УЛУЧШЕННЫЕ РАЗМЕРЫ И КОМПАКТНОСТЬ ===== */

/* Более компактный заголовок */
header {
    padding: 0.8rem 1rem 0.3rem;
}

header h1 {
    font-size: clamp(1.3rem, 3.5vw, 2rem);
}

.subtitle {
    font-size: 0.9rem;
    margin-top: 0.2rem;
}

/* Компактные вкладки */
.tabs {
    padding: 0.4rem;
    gap: 0.3rem;
}

.tab-btn {
    padding: 0.4rem 0.8rem;
    font-size: 0.85rem;
}

/* ===== КОМПАКТНЫЕ ЭЛЕМЕНТЫ УПРАВЛЕНИЯ В ОДНУ СТРОКУ ===== */
.controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    padding: 0.8rem;
    margin-bottom: 0.3rem;
    gap: 1.5rem;
}

/* Скрываем старый селектор колод */
.deck-selector-container {
    display: none !important;
}

/* Группа выбора расклада и колоды рядом */
.control-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.control-group label {
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    color: var(--gold);
}

/* Выпадающий список колоды с превью */
.deck-dropdown {
    position: relative;
    display: inline-block;
}

.deck-dropdown-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.8rem;
    background: linear-gradient(135deg, var(--wood-light) 0%, var(--wood) 100%);
    border: 2px solid var(--gold-dim);
    border-radius: 8px;
    color: var(--parchment);
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    cursor: pointer;
    min-width: 180px;
    transition: all 0.3s ease;
}

.deck-dropdown-btn:hover {
    border-color: var(--gold);
    box-shadow: 0 0 10px rgba(212, 175, 55, 0.3);
}

.deck-dropdown-btn img {
    width: 30px;
    height: 45px;
    object-fit: cover;
    border-radius: 3px;
    border: 1px solid var(--gold-dim);
}

.deck-dropdown-btn .dropdown-arrow {
    margin-left: auto;
}

.deck-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    min-width: 220px;
    max-height: 350px;
    overflow-y: auto;
    background: linear-gradient(135deg, var(--wood) 0%, var(--wood-dark) 100%);
    border: 2px solid var(--gold);
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
    display: none;
    margin-top: 4px;
}

.deck-dropdown.open .deck-dropdown-menu {
    display: block;
}

.deck-dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.5rem 0.8rem;
    cursor: pointer;
    transition: background 0.2s ease;
    border-bottom: 1px solid rgba(212, 175, 55, 0.2);
}

.deck-dropdown-item:last-child {
    border-bottom: none;
}

.deck-dropdown-item:hover {
    background: rgba(212, 175, 55, 0.2);
}

.deck-dropdown-item.active {
    background: rgba(212, 175, 55, 0.3);
}

.deck-dropdown-item img {
    width: 40px;
    height: 60px;
    object-fit: cover;
    border-radius: 4px;
    border: 2px solid var(--gold-dim);
}

.deck-dropdown-item .deck-item-name {
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    color: var(--parchment);
}

/* Компактные кнопки действий */
.actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.4rem;
    margin-bottom: 0.3rem;
    padding: 0.5rem;
}

.action-btn {
    padding: 0.4rem 0.8rem;
    font-size: 0.8rem;
}

/* Компактная информация о колоде */
.deck-info,
.rune-bag-info {
    margin-bottom: 0.3rem;
    font-size: 0.85rem;
    padding: 0.3rem;
}

/* ===== УВЕЛИЧЕННЫЕ КАРТЫ (1.5x) ===== */
.card-slot {
    width: 150px;
    height: 225px;
    border-radius: 10px;
}

.card-slot::before {
    top: -20px;
    font-size: 0.75rem;
}

.tarot-card {
    width: 150px;
    height: 225px;
    border-radius: 10px;
}

.tarot-card .card-front {
    border-radius: 10px;
    padding: 8px;
    border-width: 3px;
}

/* ===== КАРТЫ С ИЗОБРАЖЕНИЯМИ - ПОЛНОЕ ОТОБРАЖЕНИЕ ===== */
.card-front.has-image {
    padding: 0;
    background: transparent;
    overflow: hidden;
}

.card-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    /* Изменено с cover на contain для полного отображения */
    border-radius: 7px;
    background: #f4e4bc;
    /* Фон для пустых областей */
}

/* ===== КОНТРАСТНЫЙ ТЕКСТ НА КАРТАХ ===== */
.card-number {
    font-size: 1.1rem;
    color: #000;
    background: rgba(255, 255, 255, 0.85);
    padding: 2px 8px;
    border-radius: 4px;
    text-shadow: none;
}

.card-symbol {
    font-size: 4rem;
    filter: drop-shadow(2px 2px 3px rgba(255, 255, 255, 0.9)) drop-shadow(-2px -2px 3px rgba(255, 255, 255, 0.9));
}

.card-name {
    font-size: 0.95rem;
    max-height: none;
    color: #000;
    background: rgba(255, 255, 255, 0.9);
    padding: 3px 8px;
    border-radius: 4px;
    text-shadow: none;
    font-weight: 600;
}

/* Темные колоды - светлый текст на тёмном фоне */
.card-front[style*="background"] .card-number,
.card-front[style*="background"] .card-name {
    color: #fff;
    background: rgba(0, 0, 0, 0.75);
}

.card-front[style*="background"] .card-symbol {
    filter: drop-shadow(2px 2px 3px rgba(0, 0, 0, 0.9)) drop-shadow(-2px -2px 3px rgba(0, 0, 0, 0.9));
}

/* ===== УВЕЛИЧЕННЫЕ РУНЫ (1.5x) ===== */
.rune-slot {
    width: 120px;
    height: 150px;
    border-radius: 15px;
}

.rune {
    width: 120px;
    height: 150px;
    border-radius: 15px;
}

.rune-symbol {
    font-size: 4rem;
}

.rune-name {
    font-size: 0.9rem;
}

/* Кнопка инфо для увеличенных карт/рун */
.info-btn {
    width: 26px;
    height: 26px;
    font-size: 0.95rem;
    top: -8px;
    right: -8px;
}

/* ===== УЛУЧШЕННОЕ МОДАЛЬНОЕ ОКНО ===== */
.modal-content {
    max-width: 700px;
    max-height: 85vh;
}

.modal-header {
    padding: 1rem 1.5rem;
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
}

.modal-icon {
    font-size: 4rem;
    min-width: 80px;
    text-align: center;
}

/* Модальное окно с изображением слева */
.modal-with-image .modal-body {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
}

.modal-card-image {
    width: 180px;
    min-width: 180px;
    height: 270px;
    object-fit: contain;
    border-radius: 10px;
    border: 3px solid var(--gold);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5);
    background: #f4e4bc;
}

.modal-rune-image {
    width: 120px;
    min-width: 120px;
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 5rem;
    background:
        radial-gradient(ellipse at 30% 30%, #9a9a9a 0%, transparent 50%),
        linear-gradient(135deg, #7a7a7a 0%, #5a5a5a 50%, #3a3a3a 100%);
    border-radius: 15px;
    border: 3px solid var(--gold);
    color: var(--gold);
    text-shadow: 0 0 10px var(--gold-dim);
}

.modal-description {
    flex: 1;
}

.modal-description h3 {
    margin-top: 0;
}

/* Стол занимает больше места */
.table {
    min-height: 500px;
    padding: 1.5rem;
    flex: 1;
}

/* Компактный футер */
footer {
    padding: 0.5rem;
    font-size: 0.85rem;
}

/* Адаптивность для маленьких экранов */
@media (max-width: 768px) {
    .controls {
        flex-direction: column;
        gap: 0.8rem;
    }

    .modal-with-image .modal-body {
        flex-direction: column;
        align-items: center;
    }

    .modal-card-image,
    .modal-rune-image {
        margin-bottom: 1rem;
    }

    .card-slot,
    .tarot-card {
        width: 120px;
        height: 180px;
    }

    .rune-slot,
    .rune {
        width: 100px;
        height: 125px;
    }
}