/* ============================================
   IMPORT POLICE ET RÉINITIALISATION DE BASE
   ============================================ */

/* Import de la police Roboto depuis Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;700&display=swap');

/* Réinitialisation minimale : supprime les marges et paddings par défaut */
* { box-sizing: border-box; margin: 0; padding: 0; }

/* Fait en sorte que html et body prennent 100% de la hauteur */
html, body { height: 100%; }

/* Styles de base pour le body */
body {
  font-family: 'Roboto', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  color: #222;              /* Couleur du texte gris foncé */
  line-height: 1.5;         /* Hauteur de ligne pour meilleure lisibilité */
  background: #f7f8fb;      /* Couleur de fond bleu clair */
  -webkit-font-smoothing: antialiased; /* Lisse les polices sur navigateurs */
  padding-top: 64px;        /* Espace en haut pour la barre de navigation fixe */
}

.container { max-width: 1100px; margin: 0 auto; padding: 1.5rem; }

/* ============================================
   BARRE DE NAVIGATION
   ============================================ */

/* Conteneur principal de la navigation */
.topnav {
  background: #0b3b5b; /* Bleu foncé */
  color: #fff;
  position: fixed;      /* Fixée en haut de la page */
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;          /* Au-dessus de la majorité du contenu */
  display: flex;
  align-items: center;
  padding: 0.5rem 1rem;
  box-shadow: 0 4px 12px rgba(11,59,91,0.12); /* Ombre subtile */
}

/* Logo/Nom dans la barre de navigation */
.topnav .brand { 
  font-weight: 700;     /* Texte en gras */
  font-size: 1.1rem; 
}

/* Menu (liste de navigation) */
.topnav .menu { 
  list-style: none;     /* Retire les puces */
  display: flex;
  gap: 0.5rem;          /* Espace entre les éléments */
  margin-left: auto;    /* Posse le menu à droite */
}

/* Liens du menu */
.topnav .menu li a { 
  color: #fff;
  display: block;
  padding: 0.6rem 0.8rem;
  text-decoration: none;
  border-radius: 6px;
}

/* Effet au survol des liens */
.topnav .menu li a:hover, .topnav .menu li a:focus { 
  background: rgba(255,255,255,0.08); /* Fond blanc semi-transparent */
}

/* Bouton menu (hamburger) */
.menu-icon {
  display: none;         /* Caché par défaut (affiché en mobile) */
  margin-left: auto;
  color: #fff;
  font-size: 1.5rem;
}

/* ============================================
   MENU MOBILE (écrans ≤ 800px)
   ============================================ */

@media (max-width: 800px) {
  /* Ajuste le padding du body pour laisser espace à la barre mobile */
  body {
    padding-top: 60px;
  }
  
  /* Réorganise la barre navigation pour mobile */
  .topnav {
    padding: 0.8rem 1rem;
    justify-content: space-between; /* Écarte le nom et l'icône menu */
  }
  
  /* Cache les liens du menu sur mobile (affichés dans le dropdown) */
  .topnav .menu {
    display: none;
  }
  
  /* Icône hamburger (☰) */
  .menu-icon {
    position: relative;
    background: none;
    border: none;
    color: white;
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0.3rem 0.5rem;
    display: block;
  }
  
  /* Menu déroulant sous la barre (s'affiche quand .is-open) */
  .menu.is-open {
    display: block;
    position: absolute;
    top: 100%;         /* Directement sous la barre */
    left: 0;
    right: 0;
    background: #0b3b5b;
    padding: 0.5rem 0;
    list-style: none;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
  }
  
  /* Liens du menu déroulant */
  .menu.is-open a {
    color: white;
    text-decoration: none;
    padding: 1rem;
    display: block;
    border-top: 1px solid rgba(255,255,255,0.1); /* Ligne de séparation */
  }
  
  /* Survol des liens du menu déroulant */
  .menu.is-open a:hover {
    background: rgba(255,255,255,0.1);
  }
}

/* ============================================
   SECTION HÉROS (en-tête avec photo et texte)
   ============================================ */

/* Layout en grille : texte à gauche, photo à droite */
.hero { 
  display: grid;
  grid-template-columns: 1fr 300px; /* Colonne flexible + colonne fixe */
  gap: 1.5rem;
  align-items: center;
  padding: 2rem 1.5rem;
}

/* Titre principal */
.hero-content h1.nom { 
  font-size: 2rem;
  margin-bottom: .25rem; 
}

/* Sous-titre (Étudiant en...) */
.hero-content .role { 
  color: #0b3b5b;
  font-weight: 600;
  margin-bottom: .75rem; 
}

/* Sous-titre de section (À propos de moi) */
.hero-content h2 { 
  margin-top: .5rem;
  margin-bottom: .5rem; 
}

/* Photo dans la section héros */
.hero-photo img { 
  width: 100%;
  height: auto;
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(11,59,91,0.12);
}

/* Padding interne du contenu texte */
.hero-content { 
  padding: 0 0.6rem; 
}

/* Mode responsive pour tablettes et mobiles */
@media (max-width: 900px) {
  .hero { 
    grid-template-columns: 1fr; /* Une seule colonne */
    text-align: center;
  }
  .hero-photo { 
    order: -1; /* Affiche la photo avant le texte */
  }
}

/* ============================================
   SECTIONS PRINCIPALES
   ============================================ */

/* Chaque section (Formation, Expérience, etc.) */
.section { 
  padding: 1.5rem 0;
  border-top: 1px solid rgba(16,24,32,0.04); /* Ligne très fine de séparation */
}

/* Titre de section */
.section h2 { 
  text-align: center;
  margin-bottom: 1rem;
  color: #0b3b5b;
}

/* ============================================
   CARTES (cards) - Formation, Expérience, Projets
   ============================================ */

/* Grille réactive : affiche 1 à N cartes selon l'espace */
.cards { 
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); /* Colonnes minimum 260px */
  gap: 1rem;
}

/* Cartes avec alignement vertical (ex: Expérience) */
.cards.vertical { 
  align-items: stretch;
}

/* Chaque carte */
.card { 
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(16,24,32,0.06);
  display: flex;
  flex-direction: column; /* Contenu aligné verticalement */
}

/* Image dans la carte */
.card img { 
  width: 100%;
  height: 160px;
  object-fit: contain;        /* L'image se redimensionne sans déformation */
  object-position: center;    /* Centrée dans son conteneur */
  background: #f4f6f8;        /* Fond léger si l'image ne remplit pas */
  padding: 8px;
}

/* Contenu texte de la carte */
.card .card-body { 
  padding: 0.9rem;
}

/* Titre de la carte */
.card h3 { 
  margin-bottom: 0.5rem;
}

/* Paragraphes de la carte */
.card p { 
  margin-bottom: 0.6rem;
  color: #444;
}

/* ============================================
   CARTES DE PROJETS - Effets interactifs
   ============================================ */

/* Lien clicable d'une carte de projet */
.project .project-link { 
  color: inherit;
  text-decoration: none;
  display: block;
  transition: transform 200ms ease, box-shadow 200ms ease;
  transform-origin: center center;
}

/* Image du projet avec transition */
.project .project-link img { 
  transition: transform 220ms ease;
}

/* Effet au survol d'une carte de projet : monte et grossit légèrement */
.project .project-link:hover { 
  transform: translateY(-6px) scale(1.03); /* Monte de 6px et grossit de 3% */
  box-shadow: 0 14px 36px rgba(11,59,91,0.14); /* Ombre plus prononcée */
  cursor: pointer;
}

/* Effet au clic sur une carte de projet */
.project .project-link:active { 
  transform: translateY(-3px) scale(0.995); /* Descend légèrement */
}

/* ============================================
   ADAPTATIONS POUR APPAREILS TACTILES
   ============================================ */

/* Désactive les animations de hover sur appareils tactiles */
@media (hover: none) {
  .project .project-link, .project .project-link img { 
    transition: none;
    transform: none;
    box-shadow: none;
  }
}

/* ============================================
   GRILLES ET LAYOUTS UTILITAIRES
   ============================================ */

/* Grille à 2 colonnes (non utilisée actuellement) */
.grid-2 { 
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
  gap: 1rem;
  justify-content: center;
}

/* Grille à 3 colonnes (utilisée pour la section Divers) */
.grid-3 { 
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 300px));
  gap: 1rem;
  justify-content: center;
}

/* ============================================
   COMPÉTENCES
   ============================================ */

/* Conteneur principal des compétences */
.skills { 
  display: block;
  margin-top: 0.5rem;
}

/* Ligne de compétences (ex: techniques + humaines) */
.skills-row { 
  display: flex;
  gap: 1rem;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  margin-bottom: 1.75rem;
}

/* Panneau dans une ligne normale */
.skills-row .panel { 
  flex: 0 0 320px;     /* Largeur fixe */
  max-width: 320px;
}

/* Panneau dans une ligne unique (centering) */
.skills-row.single .panel { 
  flex-basis: 360px;
  max-width: 480px;
}

/* Adaptations pour tablettes et petits écrans */
@media (max-width: 820px) {
  .skills-row .panel { 
    flex: 1 1 100%;    /* Prend 100% de la largeur */
    max-width: 100%;
  }
  .skills-row.single .panel { 
    flex-basis: 100%;
    max-width: 100%;
  }
}

/* Adaptations pour très petits écrans */
@media (max-width: 900px) { 
  .grid-2, .grid-3 { 
    grid-template-columns: 1fr; /* Une seule colonne */
  } 
}

/* ============================================
   PANNEAUX (Panels) - Sections Divers, Compétences
   ============================================ */

/* Panneau générique (utilisé partout) */
.panel { 
  background: #fff;
  padding: 1rem;
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(16,24,32,0.06);
}

/* Images dans les panneaux */
.panel img { 
  width: 100%;
  height: 160px;
  object-fit: contain;
  object-position: center;
  background: #f4f6f8;
  border-radius: 6px;
  margin-top: 0.6rem;
  padding: 8px;
}

/* Listes dans les cartes */
.card-body ul { 
  list-style: disc;
  margin: 0.6rem 0 0.6rem 1.25rem;  /* Marges : haut/bas/gauche */
  padding-left: 0.35rem;             /* Petit espacement */
  line-height: 1.45;
}

.card-body ul li { 
  margin-bottom: .45rem;
}

/* Listes dans les panneaux */
.panel ul { 
  list-style: disc;
  margin: 0.6rem 0 0.6rem 1.25rem;
  padding-left: 0.35rem;
  line-height: 1.45;
}

.panel ul li { 
  margin-bottom: .45rem;
}

/* ============================================
   PIED DE PAGE (Footer)
   ============================================ */

.site-footer { 
  background: #071a2a;  /* Bleu très foncé */
  color: #fff;
  padding: 1rem 0;
}

.site-footer p { 
  margin: 0;
}

/* ============================================
   UTILITAIRES GÉNÉRAUX
   ============================================ */

/* Texte centré */
.center { 
  text-align: center;
}

/* ============================================
   LIEN CV - Effet de zoom au survol
   ============================================ */

.cv-link {
  display: inline-block;
  transition: transform 200ms ease; /* Animation lisse */
}

/* Grossit légèrement au survol */
.cv-link:hover {
  transform: scale(1.05); /* 5% plus grand */
}

/* Image du CV avec transition */
.cv-link {
  display: inline-block;
  transition: transform 200ms ease; /* Animation lisse */
  max-width: 630px; /* Agrandi x1.5 : largeur maximale 630px */
}
/* Grossit l'image au survol */
.cv-link:hover img {
  transform: scale(1.05);
}

/* Désactive l'effet sur appareils tactiles */
@media (hover: none) {
  .cv-link, .cv-link img { 
    transition: none;
    transform: none;
  }
}

/* ============================================
   ACCESSIBILITÉ
   ============================================ */

/* Contour de focus pour la navigation au clavier */
a:focus { 
  outline: 3px solid rgba(11,59,91,0.18);
  outline-offset: 2px;
}

/* ============================================
   IMAGES RESPONSIVE
   ============================================ */

/* Les images s'adaptent à leur conteneur */
img { 
  max-width: 100%;
  height: auto;
  display: block;
}

/* ============================================
   Ajustements spécifiques pour petits écrans
   - Rend la zone C.V plus adaptée sur téléphone
   ============================================ */
@media (max-width: 480px) {
  /* Le lien CV prend la largeur disponible (avec marge) et est centré */
  .cv-link {
    max-width: 90%;
    width: 90%;
    display: block;
    margin: 0.6rem auto; /* centré horizontalement */
  }

  /* L'image du CV remplit son conteneur, sans transformation au survol */
  .cv-link img {
    width: 100%;
    height: auto;
    transform: none;
  }

  /* Éviter les effets hover sur petits écrans */
  .cv-link:hover { transform: none; }
}

