@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap');
    
    :root {
      --neon-pink: #ff006e;
      --neon-blue: #00f5ff;
      --neon-yellow: #ffed00;
      --neon-purple: #b967ff;
      --dark-bg: #0a0e27;
      --grid-color: #1a1f3a;
      --shadow-glow: 0 0 20px rgba(255, 0, 110, 0.5);
      --muted: rgba(255, 255, 255, 0.7);
    }

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

    body {
      font-family: 'Press Start 2P', cursive;
      background: var(--dark-bg);
      color: var(--neon-blue);
      overflow-x: hidden;
      position: relative;
    }

    /* Grille rétro animée en arrière-plan */
    body::before {
      content: "";
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-image: 
        linear-gradient(0deg, transparent 24%, rgba(26, 31, 58, .5) 25%, rgba(26, 31, 58, .5) 26%, transparent 27%, transparent 74%, rgba(26, 31, 58, .5) 75%, rgba(26, 31, 58, .5) 76%, transparent 77%, transparent),
        linear-gradient(90deg, transparent 24%, rgba(26, 31, 58, .5) 25%, rgba(26, 31, 58, .5) 26%, transparent 27%, transparent 74%, rgba(26, 31, 58, .5) 75%, rgba(26, 31, 58, .5) 76%, transparent 77%, transparent);
      background-size: 50px 50px;
      animation: gridScroll 20s linear infinite;
      pointer-events: none;
      z-index: 0;
    }

    @keyframes gridScroll {
      0% { transform: perspective(500px) rotateX(60deg) translateY(0); }
      100% { transform: perspective(500px) rotateX(60deg) translateY(50px); }
    }

    /* Scanlines effet CRT */
    body::after {
      content: "";
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: repeating-linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.15),
        rgba(0, 0, 0, 0.15) 1px,
        transparent 1px,
        transparent 2px
      );
      pointer-events: none;
      z-index: 9999;
      animation: scanlines 8s linear infinite;
    }

    @keyframes scanlines {
      0% { transform: translateY(0); }
      100% { transform: translateY(10px); }
    }

    /* Navbar */
    .navbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 20px;
      background: rgba(10, 14, 39, 0.9);
      border-bottom: 3px solid var(--neon-pink);
      box-shadow: 0 0 20px var(--neon-pink), 0 5px 15px rgba(0, 0, 0, 0.5);
      position: relative;
      z-index: 100;
    }

    .navbar__logo h1 {
      font-size: 1.5rem;
      letter-spacing: 2px;
      text-shadow: 0 0 10px var(--neon-pink), 0 0 20px var(--neon-pink);
      animation: glitch 3s infinite;
      position: relative;
    }

    .navbar__logo h1::before {
      content: '█';
      position: absolute;
      right: -15px;
      animation: blink 1s infinite;
      color: var(--neon-blue);
    }

    

    @keyframes blink {
      0%, 49% { opacity: 1; }
      50%, 100% { opacity: 0; }
    }

    @keyframes glitch {
      0%, 90%, 100% { text-shadow: 0 0 10px var(--neon-pink), 0 0 20px var(--neon-pink); }
      95% { text-shadow: 0 0 10px var(--neon-blue), 2px 2px var(--neon-yellow); }
    }

    .gradient-next {
      color: var(--neon-pink);
    }

    .gradient-drop {
      color: var(--neon-blue);
    }

    .navbar__links {
      display: flex;
      list-style: none;
      gap: 20px;
    }

    .navbar__link a {
      color: var(--neon-yellow);
      text-decoration: none;
      font-size: 0.7rem;
      padding: 10px 15px;
      border: 2px solid var(--neon-yellow);
      background: rgba(255, 237, 0, 0.1);
      transition: all 0.3s;
      position: relative;
      text-shadow: 0 0 5px var(--neon-yellow);
    }

    .navbar__link a:hover {
      background: var(--neon-yellow);
      color: var(--dark-bg);
      box-shadow: 0 0 20px var(--neon-yellow);
      transform: scale(1.1);
    }

    .burger {
      display: none;
      flex-direction: column;
      gap: 5px;
      background: none;
      border: none;
      cursor: pointer;
    }

    .bar {
      width: 30px;
      height: 3px;
      background: var(--neon-pink);
      box-shadow: 0 0 10px var(--neon-pink);
      transition: all 0.3s;
    }

    /* Titre principal */
    .platform-title {
      text-align: center;
      margin: 40px 0;
      font-size: 2rem;
      color: var(--neon-blue);
      text-shadow: 0 0 20px var(--neon-blue), 0 0 30px var(--neon-blue);
      animation: pulse 2s infinite;
      position: relative;
      z-index: 1;
    }

    @keyframes pulse {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.7; }
    }

    /* Barre de recherche */
    .barrecherche {
      width: 80%;
      max-width: 600px;
      margin: 30px auto;
      display: flex;
      gap: 10px;
      position: relative;
      z-index: 1;
    }

    .barrecherche input {
      flex: 1;
      padding: 15px;
      background: rgba(10, 14, 39, 0.8);
      border: 2px solid var(--neon-purple);
      color: var(--neon-blue);
      font-family: 'Press Start 2P', cursive;
      font-size: 0.6rem;
      box-shadow: inset 0 0 10px rgba(185, 103, 255, 0.3);
    }

    .barrecherche input::placeholder {
      color: rgba(0, 245, 255, 0.5);
    }

    .barrecherche button {
      padding: 15px 25px;
      background: var(--neon-pink);
      border: none;
      color: white;
      font-family: 'Press Start 2P', cursive;
      font-size: 0.6rem;
      cursor: pointer;
      box-shadow: 0 0 20px var(--neon-pink);
      transition: all 0.3s;
    }

    .barrecherche button:hover {
      background: var(--neon-yellow);
      color: var(--dark-bg);
      box-shadow: 0 0 30px var(--neon-yellow);
      transform: scale(1.05);
    }

    /* Grille de jeux */
    main {
      width: 90%;
      max-width: 1400px;
      margin: 50px auto;
      position: relative;
      z-index: 1;
    }

    main section ul {
      list-style: none;
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
      gap: 30px;
    }

    .jeu {
      background: rgba(10, 14, 39, 0.8);
      border: 3px solid var(--neon-purple);
      padding: 15px;
      transition: all 0.3s;
      position: relative;
      cursor: pointer;
      box-shadow: 0 0 15px rgba(185, 103, 255, 0.5);
    }

    .jeu:hover {
      transform: translateY(-10px) scale(1.05);
      box-shadow: 0 0 30px var(--neon-pink), 0 10px 40px rgba(255, 0, 110, 0.4);
      border-color: var(--neon-pink);
    }

    .jeu::before {
      content: "";
      position: absolute;
      top: -2px;
      left: -2px;
      right: -2px;
      bottom: -2px;
      background: linear-gradient(45deg, var(--neon-pink), var(--neon-blue), var(--neon-yellow), var(--neon-purple));
      z-index: -1;
      opacity: 0;
      transition: opacity 0.3s;
    }

    .jeu:hover::before {
      opacity: 0.3;
      animation: borderRotate 2s linear infinite;
    }

    @keyframes borderRotate {
      0% { filter: hue-rotate(0deg); }
      100% { filter: hue-rotate(360deg); }
    }

    .number {
      position: absolute;
      top: -10px;
      left: -10px;
      width: 40px;
      height: 40px;
      background: var(--neon-pink);
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
      box-shadow: 0 0 20px var(--neon-pink);
      clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
    }

    .project-img {
      width: 100%;
      height: 200px;
      object-fit: cover;
      border: 2px solid var(--neon-blue);
      filter: saturate(1.2) contrast(1.1);
      margin-bottom: 15px;
    }

    figcaption {
      text-align: center;
    }

    figcaption h3 {
      font-size: 0.7rem;
      color: var(--neon-yellow);
      margin-bottom: 10px;
      text-shadow: 0 0 10px var(--neon-yellow);
    }

    figcaption time {
      font-size: 0.5rem;
      color: var(--neon-blue);
    }

    /* Modal */
    .modal {
      display: none;
      position: fixed;
      z-index: 1000;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      background: rgba(0, 0, 0, 0.95);
      align-items: center;
      justify-content: center;
    }

    .modal-content {
      background: rgba(10, 14, 39, 0.95);
      padding: 40px;
      border: 4px solid var(--neon-pink);
      box-shadow: 0 0 50px var(--neon-pink), inset 0 0 30px rgba(255, 0, 110, 0.2);
      display: flex;
      gap: 30px;
      max-width: 90vw;
      max-height: 90vh;
      overflow-y: auto;
      position: relative;
    }

    .modal-close {
      position: absolute;
      top: 20px;
      right: 30px;
      font-size: 2rem;
      color: var(--neon-pink);
      cursor: pointer;
      text-shadow: 0 0 20px var(--neon-pink);
      transition: all 0.3s;
    }

    .modal-close:hover {
      color: var(--neon-yellow);
      text-shadow: 0 0 30px var(--neon-yellow);
      transform: scale(1.2);
    }

    .modal-left {
      flex: 1;
    }

    .modal-right {
      flex: 2;
    }

    #modal-img {
      width: 100%;
      max-width: 400px;
      border: 3px solid var(--neon-blue);
      box-shadow: 0 0 30px var(--neon-blue);
    }

    #modal-title {
      font-size: 1.2rem;
      color: var(--neon-pink);
      margin-bottom: 20px;
      text-shadow: 0 0 20px var(--neon-pink);
    }

    #modal-desc {
      font-size: 0.5rem;
      line-height: 1.8;
      color: var(--neon-blue);
      margin-bottom: 30px;
    }

    #modal-tech {
      display: flex;
      gap: 20px;
      justify-content: center;
      flex-wrap: wrap;
    }

    #modal-tech img {
      width: 50px;
      height: 50px;
      padding: 5px;
      background: var(--neon-purple);
      border: 2px solid var(--neon-yellow);
      box-shadow: 0 0 15px var(--neon-yellow);
      transition: all 0.3s;
    }

    #modal-tech img:hover {
      transform: scale(1.2) ;
      box-shadow: 0 0 25px var(--neon-pink);
    }

    /* Footer */
    footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.75rem 1rem;
      text-align: center;
      color: var(--muted);
      border-top: 1px solid rgba(255,255,255,0.03);
      font-size: 1rem;
      background: transparent;
      position: relative;
      z-index: 40;
    }

    .social-links {
      display: flex;
      align-items: center;
      gap: 1rem;
    }

    .social-links h4 {
      color: var(--neon-pink);
      text-shadow: 0 0 1rem var(--neon-pink);
    }

    .social-links img {
      width: 30px;
      height: 30px;
      filter: brightness(0) saturate(100%) invert(100%);
      transition: all 0.3s;
    }

    .social-links img:hover {
      filter: drop-shadow(0 0 10px var(--neon-blue));
      transform: scale(1.3) ;
    }

    .no-result {
      text-align: center;
      padding: 40px;
      font-size: 0.8rem;
      color: var(--neon-pink);
      text-shadow: 0 0 20px var(--neon-pink);
    }

    /* Responsive */
    @media (max-width: 768px) {
      .navbar__links {
        display: none;
        position: fixed;
        top: 80px;
        left: 0;
        width: 100%;
        height: calc(100vh - 80px);
        background: rgba(10, 14, 39, 0.98);
        flex-direction: column;
        padding: 40px;
        gap: 30px;
      }

      .show-nav .navbar__links {
        display: flex;
      }

      .burger {
        display: flex;
      }

      .show-nav .bar:nth-child(1) {
        transform: rotate(45deg) translate(8px, 8px);
      }

      .show-nav .bar:nth-child(2) {
        opacity: 0;
      }

      .show-nav .bar:nth-child(3) {
        transform: rotate(-45deg) translate(8px, -8px);
      }

      .platform-title {
        font-size: 1.2rem;
      }

      .modal-content {
        flex-direction: column;
        padding: 20px;
      }

      footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 30px;
      background: rgba(10, 14, 39, 0.9);
      border-top: 3px solid var(--neon-blue);
      margin-top: 80px;
      position: relative;
      z-index: 1;
      font-size: 0.5rem;
    }

    .social-links {
      display: flex;
      align-items: center;
      gap: 15px;
    }

    .social-links h4 {
      color: var(--neon-pink);
      text-shadow: 0 0 10px var(--neon-pink);
    }

    .social-links img {
      width: 30px;
      height: 30px;
      filter: brightness(0) saturate(100%) invert(100%);
      transition: all 0.3s;
    }

    .social-links img:hover {
      filter: drop-shadow(0 0 10px var(--neon-blue));
      transform: scale(1.3) ;
    }

    .no-result {
      text-align: center;
      padding: 40px;
      font-size: 0.8rem;
      color: var(--neon-pink);
      text-shadow: 0 0 20px var(--neon-pink);
    }

    /* Responsive */
    @media (max-width: 768px) {
      .navbar__links {
        display: none;
        position: fixed;
        top: 80px;
        left: 0;
        width: 100%;
        height: calc(100vh - 80px);
        background: rgba(10, 14, 39, 0.98);
        flex-direction: column;
        padding: 40px;
        gap: 30px;
      }

      .show-nav .navbar__links {
        display: flex;
      }

      .burger {
        display: flex;
      }

      .show-nav .bar:nth-child(1) {
        transform: rotate(45deg) translate(8px, 8px);
      }

      .show-nav .bar:nth-child(2) {
        opacity: 0;
      }

      .show-nav .bar:nth-child(3) {
        transform: rotate(-45deg) translate(8px, -8px);
      }

      .platform-title {
        font-size: 1.2rem;
      }

      .modal-content {
        flex-direction: column;
        padding: 20px;
      }

      footer {
        flex-direction: column;
        gap: 20px;
      }
    }
  }