@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');

:root{
    /* Variables */
    --background-color: #212529;
    --main-color: Dodgerblue;
    --font-color: #F5F5F5;
    --border-color: #B6B6B6;
    --success_color: #4BB543;
    --danger-color: Tomato;

    /* Transition */
    --transition: all 0.25s ease-out;
}

::selection {
    background-color: #cce2ff;
    color: var(--background-color);
}

*{
    /* Reset du CSS de base du navigateur */
    margin: 0;
    padding: 0;
    box-sizing: border-box;

    /* Police d'écriture du site */
    font-family: "Noto Sans JP", sans-serif;
}   

/* Les balises html et body ont une hauteur de base pour que le footer soit tjrs collé en bas */

html{
    height: 100%;
}

body{
    min-height: 100%;
    display: flex;
    flex-direction: column;
}

main{
    margin: 20px 0;
}

a{
    cursor: pointer;
}

/* Navbar */

.navbar{
    background-color: var(--background-color);
    color: var(--font-color);
    height: 4em;
    padding: 0 20px;
}

.header_title{
    margin: 0 10px;
    font-size: 1.4em;
    font-weight: 500;
}

.header_menu{
    padding: 0 15px;
    height: 100%;
    font-weight: 450;
    color: var(--font-color);
    text-decoration: none;
}

.header_menu:hover{
    /* background-color: var(--border-color); */
    cursor: pointer;
    background-color: #34373a;
}

.header_logout{
    transition: var(--transition);
    text-decoration: none;
    color: var(--border-color);
}

.header_logout:hover{
    transition: var(--transition);
    color: var(--font-color);
}

/* Footer */

footer{
    /* position: absolute;
    bottom: 0; */
    margin-top: auto;
    width:100%;
    height:40px;
    color: var(--font-color);
    background:var(--background-color);
}

/* Card */

.card{
    border: 1px solid var(--border-color);
    border-radius: 1.5%;
    min-width: 320px;
    max-width: 70%;
    margin: 2.5em 0;
    padding: 10px;
    box-shadow: 2.5px 2.5px 10px #d8d8d8;
    width: 23em;
}

.card_tall{
    height: 21em;
}

.card_medium{
    height: 19.5em;
}

.card_small{
    height: 14em;
}

.card_title{
    font-weight: 500;
    font-size: 1.5em;
    margin-bottom: 20px;
}

.card_input_container{
    margin: 10px 0 0px;
}

.card_input{
    margin: 10px 0;
    font-size: 1em;
    width: 100%;
    min-width: 10em;
    padding: 5px;
    border: 1px solid var(--border-color);
}

.card_textarea{
    margin: 15px 0;
    font-size: 1em;
    width: 100%;
    min-width: 10em;
    border: 1px solid var(--border-color);
    resize: none;
    padding: 5px;
}

.card_textarea_medium{
    height: 10em;
}

.card_textarea_small{
    height: 6em;
}

input:focus, textarea:focus{
    border: 1px solid transparent;
    outline: none;
    box-shadow: 0 0 5px var(--main-color);
}

input:read-only, textarea:read-only{
    pointer-events:none;
    filter: brightness(0.95);
}

input:read-only:focus, textarea:read-only:focus{
    outline: none;
    box-shadow: none;
}

.card_checkbox{
    margin: 20px 0;
}

/* Liste */

.main_content{
    margin: 20px 0px;
}

.list_container{
    padding: 5px 20px;
}

.list_content{
    background: #F1F1F1;
    border: 1px solid #B6B6B6;
    box-sizing: border-box;
    width: 25em;
    height: 4.5em;
}

.list_content.large.tall{
    width: 27em;
    height: 7em;
}

.list_left_box{
    float: left;
    height: 4.5em;
    width: 4em;
    border-right: 1px solid var(--border-color);
}

.list_left_box.tall{
    height: 7em;
}

.list_right_box{
    float: right;
    height: 4.5em;
    width: 80%;
}

.list_right_box.tall{
    height: 7em;
}

.list_text{
    margin: 0 20px;
}

.list_subtext{
    margin: 0 20px;
    font-size: 0.9em;
    filter: opacity(0.75);
}

.hidden_text{
    display: none;
}

.icon{
    transition: var(--transition);
    cursor: pointer;
    color: var(--border-color);
    /* Icônes légérement plus sombres */
    filter: brightness(0.85);
}

.icon:hover{
    transition: var(--transition);
    color: var(--background-color);
}

.icon_arrow{
    margin: 0 20px;  
}

.icon_edit{
    margin: 0 10px;
    color: var(--border-color);
    filter: brightness(0.8);
}

/* Boutons */

.button_container{
    margin: 10px 0 20px;
}

/* sbs = side by side */
.button_sbs_left{
    margin-right: 5px;
}

.button_sbs_right{
    margin-left: 5px;
}

.button{
    transition: var(--transition);
    background-color: var(--main-color);
    color: white;
    text-decoration: none;
    border-radius: 2%;
    padding: 5px 15px;
    cursor: pointer;
    border: 2px solid var(--main-color);
    font-size: 1em;
}

.button:hover{
    transition: var(--transition);
    color: var(--main-color);
    background: white;
}

.icon_button{
    vertical-align: top;
}

.button_danger{
    background: var(--danger-color);
    border-color: var(--danger-color);
}

.button_danger:hover{
    background: white;
    color: var(--danger-color);
}

/* Alert */

.alert{
    height: 3.5em;
    padding: 0 10px;
}

.alert_success{
    color: #155724;
    background-color: #d4edda;
}

.alert_danger{
    color: #721c24;
    background-color: #f8d7da;
}

.alert_icon_danger{
    color: #721c24;
}

.alert_icon_success{
    color: #155724;
}


/* Flex */

.flex{
    display: flex;
}

.flex_vertical{
    align-items: center;
}

.flex_column{
    flex-direction: column;
}

.flex_center{
    justify-content: center;
}

.flex_end{
    justify-content: end;
}

.flex_one{
    flex: 1;
}

/* Position */

.text_centered{
    text-align: center;
}

.vertical_center{
    vertical-align: center;
}

.float_right{
    float: right;
}

/* Largeur / Hauteur */

.w_50{
    width: 50%;
}

.w_11{
    width: 11em;
}

.mtop_10
{
    margin-top: 10px;
}


/* Responsive */

@media only screen and (max-device-width: 900px) {
    .card_title{
        font-size: 1em;
    }
    .w_50{
        width: 80%;
    }
    .header_title{
        display: none;
    }
}