/* Custom fonts */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,200..800&family=Hanken+Grotesk:ital,wght@0,100..900;1,100..900&family=Host+Grotesk:ital,wght@0,300..800;1,300..800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,100..900;1,9..144,100..900&display=swap');

/* Phosphor icons */
@import url('https://cdn.jsdelivr.net/npm/@phosphor-icons/web@2.1.1/src/regular/style.css');

.ph {
    font-size: 24px;
    align-self: center;
}

/* General definitions */
:root {
    --primary: #E7B6F0;
    --on_primary: #462151;
    --secondary: #D6C0D6;
    --on_secondary: #3A2B3D;
    --tertiary: #F5B7B1;
    --on_tertiary: #4C2522;
    --surface_container: #231E23;
    --surface_container_high: #2E282E;
    --on_surface: #EAE0E7;
    --outline: #988E97;
    --outline_variant: #4C444C;
    --background: #333133;
    --on_background: #E5E3E6;

    --layout-side-padding-min: 1rem;
    --layout-side-padding: max(var(--layout-side-padding-min), calc(50vw - 720px + 1rem));
}

/* General styling */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: "Bricolage Grotesque", sans-serif;
    background: var(--background);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: var(--on_surface);
}

a, a:visited {
    color: inherit;
    text-decoration: none;
}

h1 {
    font-size: 30px;
    font-weight: 900;
    font-family: "Fraunces", serif;
    line-height: 150%;
}

/* Buttons styling */
.button,
.button:visited {
    display: flex;
    justify-content: center;
    width: fit-content;
    height: fit-content;
    padding: 8px 16px;
    color: var(--on_secondary);
    background: var(--secondary);
    border: none;
    border-radius: 6px;
    font-size: 16px;
    line-height: 150%;
    gap: 10px;
    font-family: "Bricolage Grotesque";
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
}

.button:hover {
    background: lch(from var(--secondary) calc(l + 10) c h);
}

.button_fill {
    width: 100%;
    text-align: center;
}

.button_primary,
.button_primary:visited {
    font-weight: 700;
    color: var(--on_primary);
    background: var(--primary);
}

.button_primary:hover {
    background: lch(from var(--primary) calc(l + 10) c h);
}

.button_tertiary,
.button_tertiary:visited {
    color: var(--on_tertiary);
    background: var(--tertiary);
}

.button_tertiary:hover {
    background: lch(from var(--tertiary) calc(l + 10) c h);
}

.button_orange,
.button_orange:visited {
    color: var(--on_tertiary);
    background: orangered;
}

.button_orange:hover {
    background: lch(from orangered calc(l + 10) c h);
}

.button_compact,
.button_compact:visited {
    color: var(--on_surface);
    background: var(--surface_container);
    padding: 0px 10px;
}

.button_compact:hover {
    background: lch(from var(--surface_container) calc(l + 10) c h);
}

.button_compact_active,
.button_compact_active:visited {
    color: var(--on_primary);
    background: var(--primary);
    padding: 0px 10px;
}

.button_compact_active:hover {
    background: lch(from var(--primary) calc(l + 10) c h);
}

.button_outline,
.button_outline:visited {
    color: var(--on_surface);
    background: none;
    box-shadow: inset 0px 0px 0px 2px var(--outline);
}

.button_outline:hover {
    background: lch(from var(--surface_container) calc(l + 10) c h);
}

/* Login forms styling */

/* Color flashMessage in green if an account is created successfully */
.alert-success {
    color: green
}

/* Color flashMessage in red if there is an error (account not created) */
.alert-error {
    color: red
}

.login_container {
    display: flex;
    margin: auto;
    flex-direction: column;
    gap: 50px;
    background: var(--surface_container);
    border-radius: 12px;
    padding: 40px 30px;
    width: 100%;
    max-width: 376px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
}

.form_content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

label {
    display: block;
    color: var(--on_surface);
    font-size: 16px;
    font-weight: 700;
    line-height: 150%;
    margin-top: 8px;
}

input[type="text"],
input[type="email"],
input[type="date"],
input[type="password"] {
    width: 100%;
    padding: 6px 8px;
    background: var(--surface_container_high);
    border: 1px solid var(--outline_variant);
    border-radius: 8px;
    color: var(--on_surface);
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 15px;
    transition: all 0.2s ease;
    outline: none;
}

input[type="text"]:focus,
input[type="password"]:focus {
    border-color: var(--primary);
    /* box-shadow: 0 0 0 3px rgba(212, 165, 232, 0.1); */
}

input::placeholder {
    color: rgba(255, 255, 255, 0.3);
}

.form_links {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    font-weight: 300;
    margin: 5px 0px;
}

.form_links a {
    color: var(--tertiary);
    text-decoration: none;
}

.form_links a:hover {
    text-decoration: underline;
}

.form_links span {
    color: var(--on_surface);
}

/* Game tile */
.game_tile {
    display: flex;
    width: 380px;
    flex-direction: column;
    align-items: flex-start;
    border-radius: 20px;
    background: var(--surface_container);
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.game_tile_top {
    display: flex;
    border-radius: 20px;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);

    overflow: hidden;
    position: relative;
    box-sizing: content-box;
}

.game_tile_top_img {
    width: 100%;
    position: relative;
    object-fit: cover;
    height: 100%;
}

.game_tile_top_price {
    padding: 0 21px;
    border-radius: 10px 0 0 10px;
    background-color: var(--surface_container_high);
    position: absolute;
    bottom: 10%;
    right: 0;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.game_tile_top_price_promo {
    padding: 0 21px;
    border-radius: 10px 0 0 10px;
    background-color: green;
    position: absolute;
    bottom: 10%;
    right: 0;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.game_tile_top_price_txt {
    color: var(--on_background);
    font-size: 32px;
    font-weight: 900;
    line-height: 150%;
}

.game_tile_bot {
    width: 100%;
    display: flex;
    flex-direction: column;
    padding: 20px;
    gap: 13px;
    align-items: stretch;
    box-sizing: border-box;
}

.game_tile_bot_tags {
    display: flex;
    flex-direction: row;
    column-gap: 10px;
    font-size: 13px;
    font-style: italic;
    overflow: auto;
}

.game_tile_bot_actions {
    display: flex;
    flex-direction: row;
    column-gap: 14px;
    justify-content: right;
}

.game_tag {
    padding: 4px 8px;
    color: var(--on_secondary);
    background: var(--secondary);
    border-radius: 6px;
    font-size: 13px;
    white-space: nowrap;
}

/* Navbar */
.navbar-top {
    display: flex;
    align-items: center;
    background: var(--surface_container);
    gap: 10px;
    padding: 10px var(--layout-side-padding);
}

.navbar-bottom {
    display: flex;
    align-items: center;
    background: var(--surface_container_high);
    gap: 10px;
    padding: 10px var(--layout-side-padding);
}

.searchbar {
    display: flex;
    background: var(--surface_container_high);
    gap: 10px;
    padding: 10px;
    border-radius: 6px;
    width: 100%;
}

input.searchbar-input {
    background: none;
    border: none;
    border-radius: 0px;
    padding: 0px;
}

/* Footer */
.footer {
    display: flex;
    align-items: center;
    background: var(--surface_container);
    gap: 10px;
    padding: 10px var(--layout-side-padding);
    margin-top: auto;
}

.link {
    text-decoration: underline;
    font-style: italic;
}

/* Game Info */
.game_info {
    margin: 32px var(--layout-side-padding) 0px var(--layout-side-padding);
}

.game_info_bg_img {
    top: 0;
    z-index: -1;
    width: 100%;
    height: 448px;
    position: absolute;
    filter: blur(10px);
}

.game_info_basics {
    display: flex;
    gap: 20px;
    align-items: center;
}

.game_info_basics_img {
    width: 60%;
    border-radius: 20px;
    height: 100%;
}

.game_info_basics_right {
    display: flex;
    flex-direction: column;
    width: 40%;
    gap: 10px;
}

.price_tag {
    display: flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    height: auto;
    padding: 0px 21px;
    color: var(--on_surface);
    background: var(--surface_container_high);
    border: 1pt solid var(--outline_variant);
    border-radius: 6px;
    font-size: 20px;
    font-weight: 800;
    line-height: 150%;
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: space-between;
    margin: 5px 0px;
    width: 100%;
    max-width: 500px;
}

.pagination_group {
    display: flex;
    gap: 10px;
}

/* Privacy policy page */

.privacy {
    line-height: 1.6;
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

h1.privacy_title {
    border-bottom: 3px solid var(--primary);
    padding-bottom: 10px;
}

h2.privacy_subtitle {
    margin-top: 30px;
}

.update-date {
    font-style: italic;
}

.highlight {
    padding: 15px;
    border-left: 4px solid var(--primary);
    margin: 20px 0;
}

ul {
    margin-left: 20px;
}


/* table styling */
thead {
    background-color: var(--primary);
    color: var(--on_primary);
}

tbody {
    background-color: var(--secondary);
    color: var(--on_secondary);
}

table {
    border-collapse: collapse;
    border: 2px solid var(--outline);
    font-family: sans-serif;
    font-size: 0.8rem;
    letter-spacing: 1px;
    margin: 60px auto;
}



th,
td {
    border: 1px solid var(--outline);
    padding: 8px 10px;
}

td {
    text-align: center;
}

.flex {
    display: flex;
    flex-wrap: wrap;          /* retour à la ligne si trop d’éléments */
    gap: 10px;                /* espace entre les éléments */
    align-items: center;      /* alignement vertical */
    justify-content: flex-start; /* ou center / space-between */
}
