/* css/genshin-styles.css */

.character-container {
    width: var(--character-size);
    height: var(--character-size);
    position: relative;
    display: inline-block;
    vertical-align: top;
    margin: 2px;
    cursor: grab;
    transition: box-shadow 0.2s ease, width 0.1s ease, height 0.1s ease;
}

.character-icon {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 4px;
    border: none;
}

.element-icon {
    position: absolute;
    top: 2px;
    right: 2px;
    width: calc(var(--character-size) * 0.3);
    height: calc(var(--character-size) * 0.3);
    min-width: 16px;
    min-height: 16px;
    max-width: 24px;
    max-height: 24px;
    z-index: 10;
    border-radius: 3px;
    padding: 1px;
    pointer-events: none;
}

.rank-tier {
    display: flex;
    flex-direction: column;
    padding: 0;
    position: relative;
}

.tier-characters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px;
    flex-grow: 1;
    min-height: calc(var(--character-size) + 10px);
    align-content: flex-start;
    cursor: default;
}

.character-pool {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-height: calc(var(--character-size) + 20px);
    align-content: flex-start;
    padding: 10px;
    position: relative;
}

.character-container:hover {
     box-shadow: 0 3px 6px rgba(0,0,0,0.2);
}
body.dark-theme .character-container:hover {
    box-shadow: 0 3px 6px rgba(255,255,255,0.1);
}

body.dragging-active .character-container {
    cursor: grabbing;
}