@import url('fonts.css');

* {
    box-sizing: border-box;
    scroll-behavior: smooth;
    border: none;
    transition: background-color 0.4s, opacity 0.5s, color 0.4s;
    margin: 0;
    padding: 0;
}

html {
    background-color: var(--couleur-principale-gris-clair);
}

body {
    margin: auto;
    max-width: 800px;
    width: 100%;
}

body,
main {
    display: flex;
    flex-direction: column;
}

main {
    background-color: var(--couleur-principale);
    padding: 2ch;
    gap: 2ch;
}

nav {
    display: flex;
    gap: 2ch;
    width: 100%;
}

#avatar p {
    align-content: center;
    justify-content: center;
}

#accueil {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    padding-bottom: 2ch;
}

#avatar {
    display: grid;
    grid-template-columns: 1fr 0.5fr 1.5fr;
    gap: 2ch;
    width: 100%;
}

#partage,
#ailleurs {
    display: flex;
    flex-direction: column;
    gap: 2ch;
}

#theme {
    display: flex;
    flex-wrap: wrap;
}

.categorie {
    background-color: var(--couleur-principale-clair);
    padding: 2ch;
}

.tuile {
    display: flex;
    flex-wrap: wrap;
    background-color: var(--couleur-principale-gris-clair);
    padding: 2ch;
}

#titre .tuile {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}

#theme .tuile {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 0;
    aspect-ratio: 1 / 1;
    min-width: 0;
    min-height: 0;
}

.lien {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 2ch;
}

.lien .emoji {
    display: inline-block;
    text-decoration: none;
    line-height: 1;
    margin-right: 1ch;
    padding: 1ch;
}

.tags {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 2ch;
}

/* SECTION AVATAR */
.boby,
.site,
.mail {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    cursor: pointer;
    background-color: var(--couleur-principale-gris-clair);
    aspect-ratio: 1 / 1;
    width: 100%;
}

.forbidden {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    cursor: pointer;
    background-color: var(--couleur-principale-gris-clair);
    width: 100%;
}

.boby::before,
.forbidden::before,
.site::before,
.mail::before {
    pointer-events: none;
    position: absolute;
    content: "";
    background: color-mix(in srgb, var(--couleur-principale-gris-clair) 75%, transparent);
    inset: 0;
    z-index: 1;
}

.forbidden>*,
.boby>*,
.site>*,
.mail>* {
    position: relative;
    z-index: 2;
}

.forbidden p,
.boby p,
.site p,
.mail p {
    pointer-events: none;
    text-align: center;
    word-break: break-word;
    opacity: 0;
}

.hidden {
    display: none;
}

.forbidden.show p,
.boby.show p,
.site.show p,
.mail.show p {
    pointer-events: auto;
    opacity: 1;
    width: 100%;
}

.forbidden.show p,
.boby.show p,
.site.show p {
    color: var(--couleur-principale-fonce);
    padding: 1ch;
}

.forbidden {
    text-align: center;
    background-position: right bottom;
    background-repeat: no-repeat;
    background-image: var(--image-fond-boby-cours);
    background-size: 100% auto;
}

.boby {
    text-align: center;
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-image: var(--image-fond-boby-lunettes);
    aspect-ratio: 1 / 1;
    flex: 1;
}

.site {
    text-align: center;
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: auto 100%;
    background-image: var(--image-fond-site-valise);
    aspect-ratio: 0.5 / 1;
}

.mail {
    background-position: left bottom;
    background-repeat: no-repeat;
    background-size: contain;
    display: flex;
    flex-direction: column;
    align-content: space-between;
    background-image: var(--image-fond-communication);
    height: 100%;
    padding: 2ch;
    aspect-ratio: 1.5 / 1;
}

h1 {
    font-family: 'Black Extended', Arial, sans-serif;
    text-transform: uppercase;
    user-select: none;
    color: var(--couleur-principale);
    font-size: 4em;
}

#arlequin h1 {
    font-size: 1em;
}

#magic-o {
    cursor: pointer;
    color: inherit;
    all: unset;
    display: inline;
}

h2 {
    font-family: 'Bold Extended', Arial, sans-serif;
    color: var(--couleur-principale-gris-clair);
    font-size: 1em;
}

h3 {
    font-family: 'Extended', Arial, sans-serif;
    color: var(--couleur-principale-fonce);
    font-size: 1em;
}

h4 {
    font-family: 'Medium Extended', Arial, sans-serif;
    color: var(--couleur-principale-fonce);
    font-size: 1em;
}

h5 {
    font-family: 'Thin Extended', Arial, sans-serif;
    color: var(--couleur-principale-fonce);
    font-size: 1em;
}

.tags h5 {
    padding: 1ch;
    background-color: var(--couleur-principale-clair);
    color: var(--couleur-principale-gris-fonce);
    font-size: 0.8em;
}

h6 {
    font-family: 'Ultra Light Extended', Arial, sans-serif;
    color: var(--couleur-principale-fonce);
    font-size: 1em;
}

p,
a,
span {
    font-family: 'Light Extended', Arial, sans-serif;
    color: var(--couleur-principale-fonce);
    font-size: 1em;
}

a {
    display: inline-flex;
    text-decoration: none;
    font-weight: bold;
    height: auto;
    align-items: center;
    color: var(--couleur-principale);
    line-height: 1;
    font-size: 1em;
}

.bluesky .emoji {
    background-color: var(--couleur-reseaux-bluesky);
}

.tumblr .emoji {
    background-color: var(--couleur-reseaux-tumblr);
}

.reddit .emoji {
    background-color: var(--couleur-reseaux-reddit);
}

.noir .emoji {
    background-color: black;
}

.blanc .emoji {
    background-color: white;
}

.bandcamp .emoji {
    background-color: var(--couleur-reseaux-bandcamp);
}

.soundcloud .emoji {
    background-color: var(--couleur-reseaux-soundcloud);
}

.youtube .emoji {
    background-color: var(--couleur-reseaux-youtube);
}

.letterboxd .emoji {
    background-color: var(--couleur-reseaux-letterboxd);
}

.steam .emoji {
    background-color: var(--couleur-reseaux-steam);
}

.linkedin .emoji {
    background-color: var(--couleur-reseaux-linkedin);
}

.scb .emoji {
    background-color: var(--couleur-ailleurs-scb);
}

.sds .emoji {
    background-color: var(--couleur-ailleurs-sds);
}

.brain .emoji {
    background-color: var(--couleur-ailleurs-brain);
}

.slate .emoji {
    background-color: var(--couleur-ailleurs-slate);
}

#theme #light,
#theme #dark {
    background-color: #33a9b5;
}

#theme #rouge,
#theme #dark-rouge {
    background-color: #B53F33;
}

#theme #vert,
#theme #dark-vert {
    background-color: #68B533;
}

#theme #violet,
#theme #dark-violet {
    background-color: #8033B5;
}

#theme #arlequin {
    background-color: var(--couleur-principale-gris-clair);
}

:root {
    /* site */
    --couleur-principale: #33a9b5;
    --couleur-principale-clair: #F3FDFE;
    --couleur-principale-fonce: #031314;
    --couleur-principale-gris-clair: #d8e3e4;
    --couleur-principale-gris-fonce: #303d3e;
    --couleur-principale-rouge: #B53F33;
    --couleur-principale-rouge-clair: #fff8f7;
    --couleur-principale-rouge-fonce: #0f0303;
    --couleur-principale-rouge-gris-clair: #dad1d0;
    --couleur-principale-rouge-gris-fonce: #58413f;
    --couleur-principale-vert: #68B533;
    --couleur-principale-vert-clair: #f6fff0;
    --couleur-principale-vert-fonce: #0b1305;
    --couleur-principale-vert-gris-clair: #dbe2d6;
    --couleur-principale-vert-gris-fonce: #394730;
    --couleur-principale-violet: #8033B5;
    --couleur-principale-violet-clair: #f6f0ff;
    --couleur-principale-violet-fonce: #0c0513;
    --couleur-principale-violet-gris-clair: #ddd6e2;
    --couleur-principale-violet-gris-fonce: #3b3047;
    --couleur-fond-formulaire: rgba(255, 255, 255, 0.5);
    --couleur-fond-formulaire-sombre: rgba(0, 0, 0, 0.5);
    /* réseaux */
    --couleur-reseaux-bluesky: #1085fd;
    --couleur-reseaux-reddit: #ff4500;
    --couleur-reseaux-tumblr: #34465e;
    --couleur-reseaux-medium: #12100e;
    --couleur-reseaux-linkedin: #0074b4;
    --couleur-reseaux-letterboxd: #202830;
    --couleur-reseaux-steam: #1386b7;
    --couleur-reseaux-steam-bleu-fonce: #111d2e;
    --couleur-reseaux-bandcamp: #6399a8;
    --couleur-reseaux-youtube: #ff0931;
    --couleur-reseaux-soundcloud: #ff5500;
    /* ailleurs */
    --couleur-ailleurs-slate: #6e0031;
    --couleur-ailleurs-brain: #fbabaa;
    --couleur-ailleurs-scb: #f37008;
    --couleur-ailleurs-sds: #0107ed;
    /* images */
    --image-fond-boby-lunettes: url('../assets/images/avatar-sansfond-lunettes.png');
    --image-fond-boby-sanslunettes: url('../assets/images/avatar-sansfond-sanslunettes.png');
    --image-fond-site-valise: url('../assets/images/avatar-sansfond-valise.png');
    --image-fond-communication: url('../assets/images/avatar-sansfond-communication.png');
    --image-fond-boby-cours: url('../assets/images/avatar-sansfond-cours.png');
}

/* COULEURS SELECTION TEXTE */
::selection {
    background-color: var(--couleur-principale-fonce);
    color: var(--couleur-principale-clair);
}

::-moz-selection {
    background-color: var(--couleur-principale-fonce);
    color: var(--couleur-principale-clair);
}

/* TAILLE ECRAN */
@media (max-width: 600px) {
    #avatar {
        display: grid;
        grid-template-rows: auto auto;
        grid-template-columns: 1fr 0.5fr;
        gap: 2ch;
    }

    .boby {
        grid-column: 1 / 2;
        grid-row: 1;
        aspect-ratio: 1 / 1;
    }

    .site {
        grid-column: 2 / 3;
        grid-row: 1;
        aspect-ratio: 0.5 / 1;
    }

    .mail {
        grid-column: 1 / 3;
        grid-row: 2;
        width: 100%;
        aspect-ratio: 1.5 / 1;
    }

    #theme .tuile {
        font-size: 0.75em;
        padding: 0;
        margin: 0;
    }
}