/* ANIMATIONS */
@keyframes fadeIn
{
    from 
    {
        opacity: 0;
    }
    to 
    {
        opacity: 1;
    }
}
@keyframes shake 
{
    0% 
    { 
        transform: translate3d(0.1rem, 0.1rem, 0) rotate3d(1, 1, 0, 0deg); 
    }
    10% 
    { 
        transform: translate3d(-0.1rem, -0.2rem, 0) rotate3d(1, 1, 0, -1deg); 
    }
    20% 
    { 
        transform: translate3d(-0.3rem, 0rem, 0) rotate3d(1, 1, 0, 1deg); 
    }
    30% 
    { 
        transform: translate3d(0.3rem, 0.2rem, 0) rotate3d(1, 1, 0, 0deg); 
    }
    40% 
    { 
        transform: translate3d(0.1rem, -0.1rem, 0) rotate3d(1, 1, 0, 1deg); 
    }
    50% 
    { 
        transform: translate3d(-0.1rem, 0.2rem, 0) rotate3d(1, 1, 0, -1deg); 
    }
    60% 
    { 
        transform: translate3d(-0.3rem, 0.1rem, 0) rotate3d(1, 1, 0, 0deg); 
    }
    70% 
    { 
        transform: translate3d(0.3rem, 0.1rem, 0) rotate3d(1, 1, 0, -1deg); 
    }
    80% 
    { 
        transform: translate3d(-0.1rem, -0.1rem, 0) rotate3d(1, 1, 0, 1deg); 
    }
    90% 
    { 
        transform: translate3d(0.1rem, 0.2rem, 0) rotate3d(1, 1, 0, 0deg); 
    }
    100% 
    { 
        transform: translate3d(0.1rem, -0.2rem, 0) rotate3d(1, 1, 0, -1deg); 
    }
}

/* RESET */
html, body, header, nav, footer, main, section, div, span, h1, h2, p, a, img, .partie-conteneur > form, label, input, textarea, button
{
	margin: 0;
	padding: 0;
	border: 0;
	box-sizing: border-box;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
a
{
	display: inline-block;
}
ul
{
	list-style: none;
}
img
{
    vertical-align: middle;
    max-width: 100%;
}
:root
{
    /* couleurs */
    --couleur-froid: rgb(157, 166, 182);
    --couleur-chaud: rgb(61, 28, 11);
    --couleur-blanc: #ffffdb;
    --couleur-noir: #262632;
    --couleur-alert: red;
    --couleur-succes: green;

    /* espaces */
    --espace-xxl: 30vw;
    --espace-s: 3vw;
    --espace-xs: 1vw;
}
/* BASE */
html
{
    overflow-x: hidden;
	font-size: clamp(16px, 1vw, 1vw);
    font-family: Arial, Helvetica, sans-serif;
}
body
{
    overflow-x: hidden;
    min-height: 100vh;
    width: 100%;
    display: flex;
    flex-direction: column;
    background-color: var(--couleur-noir);
}
h1
{
    margin-bottom: 2rem;
    text-align: center;
    font-size: 3rem;
    color: var(--couleur-froid);
}
h2
{
    margin-bottom: 1rem;
    font-size: 1.5rem;
    color: var(--couleur-froid);
}
/* header */
header
{
    padding: var(--espace-xs) var(--espace-s);
}
/* main */
main
{
    display: flex;
    flex-direction: column;
    flex: 1;
    width: 100%;
    opacity: 0;
    animation: 0.1s ease-in forwards fadeIn;
}
main > div
{
    padding: var(--espace-s) var(--espace-s);
}
input:hover
{
    cursor: pointer;
}

/* CLASSES CSS */

/* ---> Accueil <--- */
.accueil-conteneur
{
    margin: auto;
}
.accueil-conteneur > h1 > span
{
    display: block;
    font-size: 0.5em;
}
.accueil-conteneur > p
{
    margin-bottom: 1rem;
    text-align: center;
    color: var(--couleur-blanc);
}
.accueil-conteneur > form
{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}
.bulle-communication 
{
    border-radius: 1rem;
    padding: 1rem;
    position: absolute;
    top: -2rem;
    left: 0;
    width: 100%;
    text-align: center;
    font-weight: bold;
    color: var(--couleur-noir);
    background-color: var(--couleur-blanc);
    transform: translate3d(0, -100%, 0);
    opacity: 0;
}
.bulle-communication::before
{
    z-index: -1;
    content: '';
    display: block;
    position: absolute;
    margin-top: -40px;
    padding-top: 0px;
    bottom: -1.5rem;
    left: 0.2rem;
    border-width: 3rem 0 0 3rem;
    border-style: solid;
    border-color: var(--couleur-blanc) transparent;
    width: 0rem;
    border-radius: 0 0 40px 0;
}
.bulle-question
{
    animation: 0.5s ease-in forwards fadeIn;
}
.bulle-reponse
{
    animation: 0.5s ease-in 1s forwards fadeIn;
}
/* ---> Partie <--- */
/* Commun à toutes les cartes/images */
.img-conteneur
{
    position: relative;
    pointer-events: none;
    width: 100%;
    height: 100%;
    filter: grayscale(0);
    transform-origin: bottom center;
    transition: transform 0.3s ease-in-out, filter 0.3s ease-in-out;
}
.img-conteneur > img
{
    border: 0.3rem solid var(--couleur-froid);
    border-bottom-width: 4%;
    border-bottom-width: 4%;
    border-top-color: #ced3dd ;
    border-bottom-color: #676f7d;
    border-top-left-radius: 40%;
    border-top-right-radius: 40%;
    border-bottom-left-radius: 0.5rem;
    border-bottom-right-radius: 0.5rem;
    width: 100%;
    height: 100%;
    transition: border-width 0.3s ease-in-out;
}
.img-conteneur > p
{
    position: absolute;
    left: 0;
    width: 100%;
    height: 1rem;
    font-size: 80%;
    color : #ffffdb;
    text-align: center;
    transition: bottom 0.3s ease-in-out;
}
.bouton-conteneur
{
    position: relative;
    text-align: center;
}
.bouton-conteneur:hover
{
    cursor: pointer;
}
.bouton-conteneur > input, .bouton-conteneur > a
{
    border-radius: 2rem;
    padding: 0.5rem 1rem;
    width: 100%;
    text-align: center;
    font-size: 1rem;
    text-decoration: none;
    transition: background-color 0.2s ease-in-out;
    color: var(--couleur-chaud);
    background-color: var(--couleur-blanc);
}
.bouton-conteneur > input[type='submit']:hover, .bouton-conteneur > a:hover
{
    background-color: var(--couleur-froid);
}
.bouton-conteneur > img
{
    width: 5rem;
    filter: contrast(80%);
    transition: filter 0.2s ease-in-out, transform 0.2s ease-in-out;
}
.bouton-conteneur > img ~ input
{
    padding: 0;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}
.bouton-conteneur:hover > img
{
    filter: contrast(120%);
    transform: scale3d(1.1, 1.1, 1);
}
/* Conteneur */
.partie-conteneur
{
    flex: 1;
    display: flex;
    flex-direction: column;
}
.partie-conteneur > form
{
    flex: 1;
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    grid-template-rows: 45% 55%;
    align-items: center;
}
/* Actions */
.partie-conteneur > form > .actions
{
    margin: 0 auto;
    max-width: 70%;
    position: relative;
    z-index: 1;
    grid-column: span 6;
    align-self: start;
    display: flex;
    flex-direction: column;
    justify-content: baseline;
}
.partie-conteneur > form > .actions > div
{
    display: grid;
    grid-template-columns: repeat(4, 5rem);
    gap: 1rem 5rem;
}
.partie-conteneur > form > .actions > h2
{
    text-align: center;
}
.partie-conteneur > form > .actions > div.decision
{
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}
.partie-conteneur > form > .actions.decision > div > div:nth-of-type(1) > input
{
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.partie-conteneur > form > .actions.decision > div > div:nth-of-type(2) > input
{
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.partie-conteneur > form > .actions.decision > div > div:last-of-type
{
    grid-column: span 2;
}
/* Menu */
.menu-conteneur
{
    align-self: start;
    grid-column: span 2;
}
.menu-conteneur > h2
{
    text-align: right;
}
.menu-conteneur > .bouton-conteneur
{
    margin-left: auto;
    max-width: 10rem;
}
.menu-conteneur > div:first-of-type
{
    margin-bottom: 1rem;
}
/* Résultat final */
.partie-conteneur > form > .actions.resultatFinal > p
{
    text-align: center;
    font-size: 1rem;
    color: var(--couleur-blanc);
}
.partie-conteneur > form > .actions.resultatFinal > p:not(:last-of-type)
{
    margin-bottom: 1rem;
}
/* Joueur : Historique des actions */
.partie-conteneur
{
    background-image: url('../images/qui-est-ce-personnage-partie-background.png');
    background-size: cover;
    background-position: center center;
}
.partie-conteneur > form > .historique
{
    grid-column: span 2;
    align-self: start;
}
.partie-conteneur > form > .historique > div
{
    max-width: fit-content;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.3rem;
}
.partie-conteneur > form > .historique > div > p
{
    border: 0.2rem solid transparent;
    border-radius: 0.2rem;
    padding: 0.2rem 0.4rem;
    text-align: center;
    font-size: 0.9em;
    color: var(--couleur-blanc);
}
.partie-conteneur > form > .historique > div > p.reponse-affirmative
{
    border-color: var(--couleur-succes);
}
.partie-conteneur > form > .historique > div > p.reponse-negative
{
    border-color: var(--couleur-alert);
}
/* IA : Historique des actions (pour debug) */
.partie-conteneur > form > .historiqueIA
{
    grid-column: span 2;
    align-self: baseline;
}
.partie-conteneur > form > .historiqueIA > h2
{
    text-align: right;
}
.partie-conteneur > form > .historiqueIA > div
{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 2rem;
}
.partie-conteneur > form > .historiqueIA > div > p
{
    margin: 0;
    padding: 0.2rem;
    position: relative;
    display: inline-block;
    text-align: right;
    color: var(--couleur-froid);
}
.partie-conteneur > form > .historiqueIA > div > p.reponse-affirmative
{
    background-color: rgba(23, 172, 23, 0.219);
}
.partie-conteneur > form > .historiqueIA > div > p.reponse-negative
{
    background-color: rgba(170, 26, 26, 0.211);
}
/* Carte des Joueurs */
.partie-conteneur > form > .carteJoueur
{
    z-index: 1;
    position: relative;
}
.partie-conteneur > form > .carteJoueur > .img-conteneur > img
{
    border-radius: 2rem;
    border-width: 0.5rem;
}
.partie-conteneur > form > .carteJoueur > .img-conteneur > p
{
    border-width: 0.5rem;
    bottom: 1rem;
    font-size: 1rem;
}
.partie-conteneur > form > .carteJoueurHumain > .bulle-communication::before
{
    left: auto;
    right: 0.2rem;
    transform: scale3d(-1, 1, 1);
}
.partie-conteneur > form > .carteJoueurIA > .img-conteneur
{
    z-index: 1;
    position: relative;
}
.partie-conteneur > form > .carteJoueurIA > .img-conteneur > input[type='text']
{
    pointer-events: all;
    position: absolute;
    border-radius: 0.5rem;
    padding: 0.2rem;
    bottom: 1.5rem;
    left: 50%;
    width: 80%;
    text-align: center;
    transform: translate3d(-50%, 0, 0);
}
.partie-conteneur > form > .carteJoueurIA > .img-conteneur > input[type='submit']
{
    border: 0.2rem solid var(--couleur-blanc);
    pointer-events: all;
    position: absolute;
    left: 50%;
    top: 2.5rem;
    width: 5rem;
    height: 5rem;
    border-radius: 50%;
    background-color: var(--couleur-froid);
    box-shadow: 0 -5px 0 rgb(16, 29, 48);
    transform-origin: top center;
    transform: translate3d(-50%, 0, 0);
    transition: box-shadow 0.2s ease-in-out, transform 0.2s ease-in-out;
    background-image: url("../images/qui-est-ce-bouton-personnage-mystere.webp");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}
/* Plateau */
.partie-conteneur > form > .plateau
{
    z-index: 2;
    margin: 0 auto;
    position: relative;
    display: flex;
    flex-direction: column;
    grid-column: span 8;
    width: 90%;
    perspective: 90rem;
}
.partie-conteneur > form > .plateau > .surface
{
    position: absolute;
    bottom: -2vh;
    left: 0;
    width: 100%;
    height: 132%;
    perspective: 50vw;
}
.partie-conteneur > form > .plateau > .surface::before, .partie-conteneur > form > .plateau > .surface::after
{
    content: '';
    position: absolute;
    left: 0;
    display: block;
    width: 100%;
    box-shadow: 0.5rem -0.3rem 0.75rem rgba(3, 2, 37, 0.656);
}
.partie-conteneur > form > .plateau > .surface::before
{
    bottom: -1rem;
    height: 1rem;
    background: url("../images/qui-est-ce-plateau.webp");
    background-size: cover;
    filter: brightness(0.8);
}
.partie-conteneur > form > .plateau > .surface::after
{
    border-top-left-radius: 0.5rem;
    border-top-right-radius: 0.5rem;
    bottom: 0;
    height: 100%;
    background: url("../images/qui-est-ce-plateau.webp");
    background-size: cover;
    transform-origin: bottom center;
    transform: rotate3d(1, 0, 0, 37deg);
}
.partie-conteneur > form > .plateau > div:not(:first-of-type)
{
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(8, auto);
    gap: 1rem;
    transform-style: preserve-3d;
}
.partie-conteneur > form > .plateau > div:nth-of-type(2)
{
    width: 70%;
    max-height: 30%;
}
.partie-conteneur > form > .plateau > div:nth-of-type(3)
{
    margin-top: -0.2rem;
    width: 80%;
    max-height: 33%;
}
.partie-conteneur > form > .plateau > div:nth-of-type(4)
{
    margin-top: -0.2rem;
    width: 90%;
    max-height: 36%;
}
.partie-conteneur > form > .plateau > div > .personnage
{
    position: relative;
    aspect-ratio: 360/480;
    height: 100%;
    transform-style: preserve-3d;
}
.partie-conteneur > form > .plateau > div > .personnage > input
{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}
.partie-conteneur > form > .plateau > div > .personnage:nth-child(n+5):nth-child(8n+5)
{
    z-index: 4;
}
.partie-conteneur > form > .plateau > div > .personnage:nth-child(n+6):nth-child(8n+6)
{
    z-index: 3;
}
.partie-conteneur > form > .plateau > div > .personnage:nth-child(n+7):nth-child(8n+7)
{
    z-index: 2;
}
.partie-conteneur > form > .plateau > div > .personnage > .img-conteneur
{
    width: 100%;
    height: 100%;
    filter: grayscale(0);
    transform-origin: bottom center;
    transition: transform 0.3s ease-in-out, filter 0.3s ease-in-out;
}
.partie-conteneur > form > .plateau > div > .personnage > .img-conteneur > img
{    
    transition: border-color 0.3s ease-in-out, filter 0.2s ease-in-out;
}
.partie-conteneur > form > .plateau > div > .personnage:hover > .img-conteneur > img
{
    border-color: #96888e rgb(103, 84, 95) #3b2f34;
    filter: saturate(150%);
    animation: 0.2s ease-in shake;
    transition: border-color 0.1s ease-in-out 0.1s, filter 0.1s ease-in-out 0.1s;
}
.partie-conteneur > form > .plateau > div > .personnage:hover > .img-conteneur > p
{
    animation: 0.2s ease-in shake;
}
.partie-conteneur > form > .plateau > div > .personnage > .img-conteneur.personnageJoueurHumain > img, .carteJoueurHumain > .img-conteneur > img
{
    border-color: rgb(216, 181, 9);
    border-top-color: rgb(248, 224, 36) ;
    border-bottom-color: rgb(112, 96, 6);
}
.partie-conteneur > form > .plateau > div > .personnage > .img-conteneur::before {
    content: "";
    border-top-left-radius: 40%;
    border-top-right-radius: 40%;
    border-bottom-left-radius: 20%;
    border-bottom-right-radius: 5%;
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    height: 100%;
    width: 100%;
    box-shadow: 0.1rem -0.4rem 0.2rem rgb(52, 52, 66, 0.7);
    transform-origin: bottom center;
    transform: scale3d(1, 0.3, 1) skewX(-3deg) translate3d(0, 0.5rem, 0);
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out, background-color 0.3s ease-in-out, border-top-left-radius 0.3s ease-in-out, border-top-right-radius 0.3s ease-in-out, border-bottom-left-radius 0.3s ease-in-out;
    background-color: rgb(52, 52, 66, 0.7);
}
.partie-conteneur > form > .plateau > div:nth-of-type(2) > .personnage > .img-conteneur > p
{
    bottom: 0.15rem;
    font-size: 0.7rem;
}
.partie-conteneur > form > .plateau > div:nth-of-type(3) > .personnage > .img-conteneur > p
{
    bottom: 0.3rem;
    font-size: 0.8rem;
}
.partie-conteneur > form > .plateau > div:nth-of-type(4) > .personnage > .img-conteneur > p
{
    bottom: 0.4rem;
    font-size: 0.9rem;
}
/* Cartes Couchées */
.partie-conteneur > form > .plateau > div > .personnage > input:checked ~ .img-conteneur
{
    transform: rotate3d(1, 0, 0, 45deg);
    filter: grayscale(0.6) contrast(0.4);
}
.partie-conteneur > form > .plateau > div > .personnage > input:checked ~ .img-conteneur::before
{
    border-bottom-left-radius: 0.5rem;
    transform: scale3d(1, 1, 1) skewX(-1deg) translate3d(0, 0.2rem, 0);
    box-shadow: 0.1rem -0.2rem 0rem rgba(0, 0, 5, 0.9);
    background-color: rgb(0, 0, 5, 0.9);
}
.partie-conteneur > form > .plateau > div > .personnage > input:checked ~ .img-conteneur > img
{
    border-top-width: 0.2rem;
    border-bottom-width: 0.5rem;
}
.partie-conteneur > form > .plateau > div:nth-of-type(2) > .personnage > input:checked ~ .img-conteneur > p
{
    bottom: 0.2rem;
}
.partie-conteneur > form > .plateau > div:nth-of-type(3) > .personnage > input:checked ~ .img-conteneur > p
{
    bottom: 0.4rem;
}
.partie-conteneur > form > .plateau > div:nth-of-type(4) > .personnage > input:checked ~ .img-conteneur > p
{
    bottom: 0.5rem;
}
/* PAGE ERREUR 404 */
.erreur404-conteneur
{
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
@media (min-aspect-ratio: 3/4) and (max-aspect-ratio: 4/3) 
{
    .partie-conteneur > form 
    {
        grid-template-rows: 40% 20% 38%;
        gap: 0;
    }
    .partie-conteneur > form > .carteJoueur > .bulle-communication
    {
        top: 25%;
        bottom: unset;
        transform: translate3d(0, -50%, 0);
    }
    .partie-conteneur > form > .carteJoueur > .bulle-communication::before
    {
        margin: 0;
        border-width: 2rem 0 0 2rem;
        top: 50%;
        bottom: unset;
    }
    .partie-conteneur > form > .carteJoueurHumain > .bulle-communication
    {
        right: unset;
        left: 100%;
    }
    .partie-conteneur > form > .carteJoueurHumain > .bulle-communication::before
    {
        left: -1rem;
        right: unset;
        transform: translate3d(0, -50%, 0) scale3d(1, -1, 1);
    }
    .partie-conteneur > form > .carteJoueurIA > .bulle-communication
    {
        left: unset;
        right: 100%;
    }
    .partie-conteneur > form > .carteJoueurIA > .bulle-communication::before
    {
        right: -1rem;
        left: unset;
        transform: translate3d(0, -50%, 0) scale3d(-1, -1, 1);
    }
    .partie-conteneur > form > .actions > div 
    {
        gap: 1rem 3.7rem;
    }
    .partie-conteneur > form > .carteJoueur > .img-conteneur
    {
        margin: 0 auto;
        max-width: 8rem;
    }
    .partie-conteneur > form > .carteJoueurHumain 
    {
        order: 1;
        grid-column: 1/span 2;
    }
    .partie-conteneur > form > .plateau 
    {
        order: 3;
        grid-column: span 10;
    }
    .partie-conteneur > form > .carteJoueurIA
    {
        order: 2;
        grid-column: 9/span 2;
    }
}