.tab-contents.village .buildings-holder {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1em;
}

.buildings-holder .building {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 2em calc(var(--dice-size) + 2em) 2em;
}

.buildings-holder .building .name-holder {
    grid-row: 1;
    grid-column: 1 / 3;
    border-radius: 0.5em 0.5em 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-bg-dark);
}

.buildings-holder .building .name-holder .name {
    text-align: center;
    font-size: 1.25em;
}

.buildings-holder .building .purchase {
    grid-row: 2 / 4;
    grid-column: 1 / 3;
    border-radius: 0 0 0.5em 0.5em;
    display: flex;
    justify-content: center;
    align-items: center;
}

.buildings-holder .building .purchase > * {
    font-size: 2em;
}

.buildings-holder .building .desc {
    grid-row: 2;
    grid-column: 1;
    padding: 0.25em;
    background-color: var(--color-bg-gray);
    font-size: 0.8em;
}

.buildings-holder .building .dice-tray {
    grid-row: 2;
    grid-column: 2;
    align-self: center;
    justify-self: center;
    display: flex;
    gap: 0.5em;
}

.buildings-holder .building .production-holder {
    grid-row: 3;
    grid-column: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5em;
    border-radius: 0 0 0 0.5em;
    background-color: var(--color-bg-dark);
    overflow: hidden;
}

.buildings-holder .building .extras-holder {
    grid-row: 3;
    grid-column: 2;
    border-radius: 0 0 0.5em 0;
    background-color: var(--color-bg-dark);
    padding: 0.3em;
}

.buildings-holder .building .extras-holder .progressbar {
    width: 100%;
    height: 100%;
    position: relative;
    border-radius: 0.5em;
    background-color: var(--color-progressbar);
    overflow: hidden;
}

.buildings-holder .building .extras-holder .progressbar .current {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: calc(100% * (var(--max) - var(--current)) / var(--max));
    background-color: var(--color-progressbar-current);
}

.buildings-holder .building .extras-holder .progressbar .growth {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: calc(100% * (var(--max) - var(--current) - var(--growth)) / var(--max));
    background-color: var(--color-progressbar-growth);
}

.buildings-holder .building .extras-holder .progressbar .status {
    position: absolute;
    left: 0;
    right: 0;
    text-align: center;
}

.buildings-holder .building .extras-holder .choice-list {
    width: 100%;
    height: 100%;
    display: flex;
    gap: 0.125em;
    align-items: stretch;
}

.buildings-holder .building .extras-holder .choice-list .choice {
    flex-basis: 0;
    flex-grow: 1;
    background-color: var(--color-bg-secondary);
    display: flex;
    justify-content: center;
    align-items: center;
}

.buildings-holder .building .extras-holder .choice-list .choice.selected {
    background-color: var(--color-bg-dark);
}

.buildings-holder .building .extras-holder .choice-list .choice:not(.selected):hover {
    background-color: var(--color-button-hover);
    cursor: pointer;
}

.buildings-holder .building .extras-holder .choice-list .choice:first-child {
    border-radius: 0.5em 0 0 0.5em;
}

.buildings-holder .building .extras-holder .choice-list .choice:last-child {
    border-radius: 0 0.5em 0.5em 0;
}

.buildings-holder .building.built .purchase {
    display: none;
}

.buildings-holder .building:not(.built) .desc { display: none; }
.buildings-holder .building:not(.built) .dice-tray { display: none; }
.buildings-holder .building:not(.built) .production-holder { display: none; }
.buildings-holder .building:not(.built) .extras-holder { display: none; }
