:root {
    --rooster-font-size: 0.8em;
    --rooster-col-width: 102px;
    --rooster-col-height: calc(95px + var(--rooster-font-size));
    --rooster-bg-size: ;
    --rooster-gap: 10px;
    --rooster-max-cols: 6;

    --highlight-blue: rgba(0, 162, 255, 0.5);
    
    --audray_blue: #00A2FF;
    --audray_pink: #E9465E;
}

.font-permanent-marker {
    font-family: "Permanent Marker", "Kristen ITC", "Comic Sans", cursive;
    font-weight: 400;
    font-style: normal;
}

.font-teko {
    font-family: "Teko", "Lucida Console", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
}

.embossed_font {
    color: var(--audray_pink);               /* fill color */
    -webkit-text-stroke: 2px #007BC7;  /* stroke width and color, firefox seems to support it too o.O */
    -webkit-text-fill-color: var(--audray_pink);  /* fill color for webkit, firefox seems to support it too o.O */        
    --shadow-color: #1B3D63;
    text-shadow: -5px 0px 0 var(--shadow-color), 
                 -5.5px 0px 0 var(--shadow-color),
                 -5.5px 3px 0 var(--shadow-color),
                 -5px 3px 0 var(--shadow-color),
                 0px 3px 0 var(--shadow-color),
                 1px 3px 0 var(--shadow-color),
                 -2px 3px 0 var(--shadow-color),
                 -1px 3px 0 var(--shadow-color),
                 -5.5px -1px 0 var(--shadow-color)
                 ;
}

@keyframes tilt-shaking {
  0% { transform: rotate(0deg); }
  25% { transform: rotate(5deg); }
  50% { transform: rotate(0eg); }
  75% { transform: rotate(-5deg); }
  100% { transform: rotate(0deg); }
}

.faded {
    opacity: 30%;
}

.rounded_corner {
    border-radius: 8px;
}

body {
    margin: 0;
    padding: 20px;
    background: #f0f0f0;
    font-size: 16px;
    background-color: #ffffff;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    background-attachment: fixed;
    background-image: url(../images/Website_Background_Top.png);
}

#main {
    display: flex;
    flex-wrap: wrap;                
    gap: 20px;
}

#rooster_container {
    border: 3px var(--audray_blue) solid;
    border-radius: 30px;
    /* box-shadow: 0 0 10px 5px var(--highlight-blue); */

    flex: 0 0 calc(var(--rooster-col-width) + (2* var(--rooster-gap)));
    margin-left: auto;
    margin-right: auto;
    height: fit-content;
    width: fit-content;
    margin-top: -18px;

    background-repeat: no-repeat;
    background-position: center center;
    /* background-size: contain;*/
    background-size: 70%;
    /*background-attachment: fixed;*/
    background-image: url(../images/anivice_t.png);    
    /*background-color: rgba(255,255,255,0.8);
    background-blend-mode: lighten;  */

    & > legend {
        margin-left: 12px;
    }

}

#selfStats {
    padding: var(--rooster-gap);
}

#rooster {        
/*    
    display: grid;    
    justify-content: center;
    align-content: center;
    justify-items: center;
    align-items: center;
    grid-template-columns: repeat(auto-fill, minmax(var(--rooster-col-width), 1fr));
    max-width: calc(var(--rooster-max-cols) * var(--rooster-col-width) + (var(--rooster-max-cols)-1) * var(--rooster-gap));
    gap: var(--rooster-gap);
    padding: var(--rooster-gap);
*/
    display: flex;
    flex-flow: row wrap;
    gap: var(--rooster-gap);
    justify-content: center;
    min-width: calc(calc(calc(var(--rooster-max-cols) * var(--rooster-col-width)) + calc(var(--rooster-max-cols) * var(--rooster-gap)))/2);
    max-width: calc(calc(var(--rooster-max-cols) * var(--rooster-col-width)) + calc(var(--rooster-max-cols) * var(--rooster-gap)))/2;

    padding: var(--rooster-gap);

    & > div {
        height: var(--rooster-col-height);
        width: var(--rooster-col-width);
        background-repeat: no-repeat;
        background-size: 68%;
        background-position: center center;
    }

    & > div.animon {
        height: var(--rooster-col-height);
        width: var(--rooster-col-width);
        background-repeat: no-repeat;

        
        text-align: center;
        position:relative; /* Needded to align span to bottom */

        background-size: 68%;
        background-position: center top;

        transition: background-size 0.5s ease; /* Animate background size */

        & .animon_footer, & .float_left, & .float_right {
            position:absolute;
            font-size: var(--rooster-font-size);    
            transition: 
                opacity 0.5s ease, 
                transform 0.5s ease;            
        }

        & > .float_left {    
            right:0;
            top: 18px;
            /* transform: translateY(-50px);*/
            transform-origin: right;
            color: red;
            display: none;
        }        

        & > .float_right {    
            right:0;
            top: 5px;
            /* transform: translateY(-5px); */
            transform-origin: right;
        }

        & > .animon_footer {    
            width: 100%;
            bottom:0;
            left: 50%;
            transform: translateX(-50%);
            transform-origin: bottom;
        }        

        &:has(span):hover { 
            /*margin: 0 40px;
            transform: scale(1.4); */
            background-size: 100%;
            box-shadow: 0 0 2px 2px var(--highlight-blue);
        }

        &:hover > .shrinkh {        
            /* opacity: 0;  display: none; , but animated!*/
            transform: translateX(-50%) scaleY(0);
            pointer-events: none; /* optional: avoids hover glitches */        
        }

        &:hover > .shrinkv {        
            transform: translateX(-50%) scaleX(0);
            pointer-events: none; /* optional: avoids hover glitches */        
        }        

    }

}

#ranklist_container {
    
    border: none;
    flex: 1 1 500px; /* grow, shrink, base 500px */
    min-width: 300px;    /* allow shrink below 500px if wrapped */

    & legend {
        width: auto;
        margin-left: auto;
        margin-right: auto;
        display: none;
    }

}

#ranklist {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.rank_entry {
    padding-left: 1em;
    padding-right: 1em;
    border: 3px black solid;
    border-radius: 30px;

    display: grid;
    grid-auto-flow: column;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto; /* or any other row sizes */
    grid-column-gap: 10px;
    min-width: fit-content;

    & > div {
        height: 100%;
    }

    & > div.rank_user {
        font-size: 3em;        
        grid-column: 1 / -1; 
    }

    & > div.rank_stats {
        min-width: 250px;
        display: grid;
        grid-column-gap: 2px;        
    
        & .rank_complete {
            font-size: 40px;
        }

        & .rank_pos {
            font-size: 25px;
        }
    }

}

div.card_caroussel {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto; /* or any other row sizes */ 
    align-content: center;

    & > div:has(Button) {
        align-self: center;
        height: 95%;
        width: 50px;
    }

    & > div > button {
        color: white;
        background-color: black;
        border-color: black;
        border-radius: 10px;
        box-shadow: inset 0px 0px 10px 0px rgba(255,255,255,120);
        font-size: 2em;
        width: 100%;
        height: 100%;
    }   

    & div.card_caroussel_window {
        overflow: hidden;
        display: grid;
        grid-auto-flow: column;
        padding-left: 10px;
        padding-right: 10px;
        gap: 10px;
        min-width:200px;

        & div.animon {
            width: 100px;
            height: 120px;
            background-repeat: no-repeat;
            background-position: center center;
            position:relative; 

            & > .float_left {    
                left:0;
                top: 50%;
                transform: translateY(-50%);
                position:absolute;
                font-size: var(--rooster-font-size);
            }                    
        }
    }

}

.animon_type {
    border-radius: 5px;
    font-size: 0.7em;    
    color: white;
    min-width: 30px;
    text-align: center;
    padding: 3px 4px 3px 4px;
    box-shadow: inset 0px 0px 1px 0px rgba(0,0,0,10);
    text-transform: uppercase;
    display: inline-block;

    --type-color: #dcdcdc;
    background-color: var(--type-color); 
    box-shadow: inset 0px 0px 1px 0px color-mix(in srgb, var(--type-color), black 50%);      
}

#mobileLogo {
    width:fit-content;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 760px) and (hover: hover) {
    #rooster {
        /* grid-template-columns: repeat(var(--rooster-max-cols), var(--rooster-col-width)); */
        min-width: calc(calc(var(--rooster-max-cols) * var(--rooster-col-width)) + calc(var(--rooster-max-cols) * var(--rooster-gap)));        
    }
}     

@media (min-width: 1326px) {
    body {
        background-image: url(../images/Website_Background_Ecke.png);
    }
    #ranklist_container > legend {
        display: block;
    }    
    #mobileLogo {
        display: none;
    }
}

@media (hover: none) {
  #main {
    display: block;    
  }
  #rooster {
    /*width: calc(calc(calc(var(--rooster-max-cols) * var(--rooster-col-width)) + calc(var(--rooster-max-cols) * var(--rooster-gap)))/2);*/
    max-width: calc(calc(calc(var(--rooster-max-cols) * var(--rooster-col-width)) + calc(var(--rooster-max-cols) * var(--rooster-gap)))/2); 
  }
}


/* classes for detail dialog */
dialog {
    border: 5px var(--audray_blue) solid;
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.3);
    max-width: 800px;
    width: 90%;
    height: 90%;
    max-height: 480px;
    font-size: 1.5em;
    
    &::backdrop {
        background: rgba(0,0,0,0.5);
    }

    & label {
        color: var(--audray_pink);
    }

    & > #modalClose {
        position: absolute;
        top: 10px;
        right: 10px;
        cursor: pointer;
        font-size: 30px;
        border: none;
        background: none;
        color: #E9475F;
        font-weight: 800;
    }
}


