@font-face {
    font-family: MavenPro;
    src: url(fonts/Maven_Pro/MavenPro-VariableFont_wght.ttf);
}


:root {
    --background:linear-gradient(45deg, darkmagenta, darkorchid, darkslateblue);
    --default-color:white;
    --font-family:MavenPro, sans-serif;
    /**/
    --container-margin:80px;
    /**/
    --album-item-min-width:350px;
    --album-item-flex-direction:row;
}

* {
    box-sizing:border-box;
}

html {
    margin:0; padding:0;
}

body {
    margin:0;
    font-family:var(--font-family);
    background:var(--background) center/cover no-repeat fixed;
}

/* header*/

header {
    padding-left: var(--container-margin);
    padding-right: var(--container-margin);
    color:var(--default-color);
}

header a {
    color:inherit;
}

header h1 a {
    text-decoration: none;
}

/* album container */

.album-container {
    margin:var(--container-margin);
    color:var(--default-color);
    /**/
    display:grid;
    grid-gap:20px;
    grid-template-columns:repeat(auto-fit, minmax(var(--album-item-min-width), 1fr));
    grid-auto-rows:minmax(auto, 1fr);
    grid-auto-flow: dense;
}

.album-container > .item {
    color:var(--default-color);
    text-decoration: none;
    /**/
    background-color:rgba(240, 248, 255, 0.3);
    box-shadow:4px 4px 3px 3px rgba(256, 256, 256, .5);
    padding:20px;
    /**/
    display:flex;
    flex-direction:var(--album-item-flex-direction);
    align-items:center;
    justify-content:center;
}

.album-container > .item > img {
    object-fit: cover;
    border-bottom-right-radius: 10px;
    border-top-right-radius: 10px;
    box-shadow:2px 3px 2px 2px rgba(240, 248, 255, 0.3);
    /**/
    flex-shrink:0;
} 


/*--featured item styling*/ 

.album-container > .featured {
    text-align:center;
    /**/
    grid-row:span 2;
}

.album-container > .featured img {
    width: 200px;
    height: 300px;
}

.album-container > .featured h2 {
    font-size:1.2rem;
}

.album-container > .featured h3, .container > .featured p {
    font-size:1rem;
}


/*Photos container*/


/*modal for viewing the photos in full size*/
.photos-modal {
    background-color: rgba(0,0,0,0.9);
    /**/
    display: none; /**/
    position: fixed;
    overflow:hidden;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
}

.photos-modal > .close-button {
    color:var(--default-color);
    background:none;
    border:none;
    outline:none;
    font-size: 2.5rem;
    /**/
    position: absolute;
    z-index: 2;
    top: 20px;
    right: 30px;
}

.photos-modal img {
    max-width: 85vw;
    max-height: 85vh;
    position: absolute;
    top:0;right:0;bottom:0;left:0;
    margin:auto;
}

.photos-modal img.ready {
    border:1px solid var(--default-color);
}

.photos-modal img.loading-image {
    width:25vmax;
    max-width: 200px;
}

.photos-container {
    margin:var(--container-margin);
    color:var(--default-color);
    /**/
    display:grid;
    grid-gap:10px;
    grid-auto-flow:column dense;
    grid-template-rows: repeat(4, 15vh);
    grid-auto-columns: 15vh;
    /**/
    overflow-x:scroll;
    overflow-y:hidden;/*unfortunately, horizontal scrollbar causes also a vertical one, which I can't solve the right way, so I just made it hiddden.
    However, this doesn't come fron nowhere. Some of the vertical content is under the horizontal scrollbar, so I have to give the container some padding, to "solve" it.*/
    padding-bottom:15px;
}

.photos-container > .item {
    border:2px solid var(--default-color);
    cursor: zoom-in;
}

.photos-container > .item img {
    /**/
    width: 100%;
    height: 100%;
    object-fit: cover;
}


/**/

.photos-container > .item.invisible img {
    display:none;
}

.photos-container > .item.r1 {
    grid-row: span 1;
}

.photos-container > .item.r2 {
    grid-row: span 2;
}

.photos-container > .item.r3 {
    grid-row: span 3;
}

.photos-container > .item.r4 {
    grid-row: span 4;
}

.photos-container > .item.c1 {
    grid-column: span 1;
}

.photos-container > .item.c2 {
    grid-column: span 2;
}

.photos-container > .item.c3 {
    grid-column: span 2;
}

.photos-container > .item.c4 {
    grid-column: span 2;
}

/**/
h1, h2, h3, p {
    padding-left:7px;
    padding-right:7px;
}

h2 {
    font-size:.9rem;
    margin-top:0;
}

h3, p {
    font-size:.7rem;
}


@media screen and (max-width:480px) {
    :root {
        --container-margin:20px;
        --album-item-min-width:88vw;
        --album-item-flex-direction:column;
        text-align:center;
    }

    .container > .item > .album-body {
        margin-top:10px;
    }
}