.gallery-layout {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-rows: auto 1em 1fr auto auto;
    grid-template-areas: "header header header" ". . ." ". image ." ". info ." "footer footer footer";
    height: 100vh;
    width: 100vw;
    gap: 1rem;  
    justify-content: center;
}



.image-container {
    grid-area: image;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    padding: 30px;
}

.image-container img {
    max-width: calc(100vw - 120px); 
    max-height: 100%;
    object-fit: contain;
    
    /* Frame */
    padding: 3px;
    border-style: solid;
    border-width: 15px;
    border-top-color: #151515;
    border-right-color: #151515;
    border-bottom-color: #040404;
    border-left-color: #040404;
    box-shadow: 4px 4px 8px rgba(0, 0, 0, .6);
    background: black;
}

.info {
    grid-area: info;
    display: flex;
    flex-direction: row;
}

.artwork-info-card {
    padding: 10px;
    width: min(500px, calc(100% - 20px));
    margin-left: auto;
    margin-right: auto;
    background: #252525;
    color: #aaa;
    box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.6);
    font-size: 0.9em;

    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto auto;
    grid-template-areas: "title title" "description description" "material artist";
    gap: 1em;
}

.artwork-info-card--title {
    grid-area: title;
    font-size: 1em;
    font-weight: 500;
}

.artwork-info-card--description {
    grid-area: description;
    font-style: italic;
    font-size: 0.85em;
    width: 80%;
}

.artwork-info-card--size-material-year {
    grid-area: material;    
    font-size: 0.8em;
    align-self: end;
}

.artwork-info-card--artist {
    grid-area: artist;
    text-align: end;
    align-self: end;
}

.info-buttons {
    display: flex;
    flex-direction: column-reverse;
}

.item-button {
    font-size: 0.9em;
    margin-top: 0.2em;
    margin-bottom: 0.2em;
}
.item-button a {
    padding: 0.75em;
    width: 45px;
    text-align: center;
}