/* ========================================
   MAIN.CSS - REFACTORISÉ
   ======================================== */

/* Reset de base */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-size: var(--font-size-base);
}

body {
    font-family: var(--font-main);
    background-color: var(--color-bg);
    color: var(--color-text);
    padding: var(--padding-page);
    height: 100vh;
}

/* ---- GRID PRINCIPALE ---- */

.container {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-desktop), 1fr);
    grid-template-rows: repeat(8, 1fr);
    gap: var(--gap-desktop);
    height: 100%;
    width: 100%;
}

/* ---- HEADER & NAVIGATION ---- */

.header {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
}

.nav {
    grid-column: 2 / 2;
    grid-row: 1 / 2;
}

.info {
    grid-column: 6 / 6;
    grid-row: 1 / 2;
}

.cv {
    grid-column: 7 / 7;
    grid-row: 1 / 2;
}

/* ---- LISTE PROJETS ---- */

.project-list {
    grid-column: 2 / 6;
    grid-row: 2 / 6;
    display: grid;
    grid-template-columns: subgrid;
    align-content: start;
}

.project-item {
    display: contents;
}

.project-item span {
    padding: 2px 0;
}

/* ---- FOOTER ---- */

.footer-date {
    grid-column: 2 / 4;
    grid-row: 8 / 9;
    display: flex;
    align-items: flex-end;
}

.footer-mail-label {
    grid-column: 6 / 7;
    grid-row: 8 / 9;
    display: flex;
    align-items: flex-end;
}

.footer-mail {
    grid-column: 7 / 9;
    grid-row: 8 / 9;
    display: flex;
    align-items: flex-end;
}

/* ---- TYPOGRAPHIE ---- */

h1 {
    font-weight: normal;
}

p {
    line-height: var(--line-height);
}

/* ---- LIENS ---- */

a {
    color: var(--color-link);
    text-decoration: none;
    transition: text-decoration var(--transition-speed) var(--transition-ease);
}

a:hover {
    text-decoration: underline;
}

/* Style spécifique pour les liens info */
.info-links a {
    display: block;
    line-height: var(--line-height);
}