/* ============================================
   RESPONSIVE.CSS - TOUS LES STYLES RESPONSIVES MOBILES
   ============================================ */

/* STYLE SIMPLE DIRECT - TOUTES LES PAGES SAUF INDEX */
@media (max-width: 1200px) {
  body.apropos-page main h1,
  body.partenaires-page main h1,
  body.contact-page main h1,
  body.don-page main h1,
  body.votez-page main h1,
  body.boutique-page main h1,
  body:not(.index-page) main h1 {
    font-size: 40px !important;
  }
  
  body.apropos-page main p,
  body.partenaires-page main p,
  body.contact-page main p,
  body.don-page main p,
  body.votez-page main p,
  body.boutique-page main p,
  body:not(.index-page) main p {
    font-size: 30px !important;
  }
}

/* ============================================
   PAGE INDEX - RESPONSIVE MOBILE (depuis style.css)
   ============================================ */

/* Mobile - Écrans jusqu'à 768px */
@media (max-width: 768px) {
  .elegant-divider {
    width: 90%;
    margin: 30px auto;
  }
  
  /* Titre OxyZen dans le ciel procédural sur mobile */
  h1 {
    position: fixed !important;
    top: 15px !important;
    left: 20px !important;
    color: rgb(17, 209, 235) !important;
    font-family: Georgia, "Times New Roman", Times, serif !important;
    font-size: 26px !important;
    z-index: 50 !important;
    text-align: right !important;
    padding: 6px 10px !important;
    border-radius: 6px !important;
  }
  
  /* Sous-titre "Version Bêta" sous le titre - MOBILE UNIQUEMENT */
  h1 + p {
    position: absolute !important;
    top: 60px !important;
    left: 30px !important;
    z-index: 49 !important;
    text-align: right !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  
  /* Canvas sans marge pour que le titre soit dans le ciel */
  #canvas {
    margin-top: 0 !important;
  }

  /* Slogan */
  .slogan {
    left: 45% !important;
    top: 14% !important;
    transform: translateX(-50%) !important;
    position: absolute !important; 
    font-size: 22px !important;
    text-align: center;
    width: 100% !important;
  }
  
  .slogan p {
    font-size: 30px !important;
    text-align: center;
  }
  
  .slogan-line1 {
    font-size: 30px !important;
  }
  
  .slogan-line2 {
    font-size: 30px !important;
  }

  .découvrir {
    font-size: 12px !important;
    text-align: center !important;
    position: absolute !important;
    top: 60% !important;
    left: 45% !important;
    transform: translateX(-50%) !important;
    width: 90% !important;
    max-width: 350px !important;
  }

  .video-container {
    height: 400px !important;
    position: absolute !important;
    left: 50% !important;
    top: 28% !important;
    transform: translateX(-50%) !important;
    width: 90% !important;
    max-width: 400px !important;
  }
  
  /* Trait élégant responsive */
  .elegant-divider {
    width: 80% !important;
    margin: 20px auto !important;
    transform: translateX(-50%) translateY(400px) !important;
    top: 28% !important;
  }
  
  /* Bouton audio responsive - comme en desktop */
  .beach-sound-controls.minimized,
  .beach-sound-controls.minimized *,
  .beach-sound-controls.minimized *::before,
  .beach-sound-controls.minimized *::after {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border: none !important;
    outline: none !important;
    bottom: 30px !important;
    left: 40px !important;
  }
  
  .beach-sound-controls.minimized .toggle-size-btn {
    border: 2px solid transparent !important;
    color: black !important;
    transition: all 0.3s ease !important;
  }

  .beach-sound-controls.minimized .toggle-size-btn:hover {
    border: 2px solid rgb(0, 238, 255) !important;
    color: #0468ec !important;
    transform: scale(1.1) !important;
  }

  /* Bouton "Téléchargez le hub central" plus bas sur mobile */
  .button {
    top: 82% !important; /* Descendu de 70% à 85% */
    font-size: 14px !important;
    padding: 8px 12px !important;
    white-space: nowrap !important;
  }

  .version {
    position: absolute !important;
    top: 85% !important;
    left: 45% !important;
    font-size: 12px !important;
    transform: translateX(-50%) !important;
    text-align: center !important;
    width: 100% !important;
    z-index: 10 !important;
  }

  /* Vidéo Mocica responsive */
  body.index-page main video {
    display: block !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    max-width: 90% !important;
    width: 100% !important;
    height: auto !important;
    margin: 40px auto !important;
    margin-top: 120px !important;
    border-radius: 15px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2) !important;
    z-index: 10 !important;
    position: relative !important;
  }

  /* Flèches transparentes sur mobile */
  .arrow-left, .arrow-right {
    display: block !important;
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 36px !important;
    color: rgba(255, 255, 255, 0.3) !important;
    z-index: 40 !important;
    pointer-events: none !important;
    font-family: Arial, sans-serif !important;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.5) !important;
  }

  .arrow-left {
    left: 20px !important;
  }

  .arrow-right {
    right: 20px !important;
  }
}

/* ============================================
   PAGE PARTENAIRES - RESPONSIVE MOBILE (depuis style.css)
   ============================================ */

/* Mobile - Écrans jusqu'à 768px */
@media (max-width: 768px) {
  /* Agrandir le bandeau header sur toutes les pages sauf index */
  body:not(.index-page) header {
    height: 80px !important;
    padding: 0 20px !important;
  }

  body:not(.index-page) .logo {
    font-size: 28px !important;
  }

  body:not(.index-page) .home-icon {
    font-size: 24px !important;
  }

  body:not(.index-page) #openBtn {
    top: 30px !important;
    right: 20px !important;
  }

  body:not(.index-page) .hamburger-icon {
    width: 35px !important;
    height: 24px !important;
  }

  body:not(.index-page) .hamburger-icon span {
    height: 4px !important;
  }

  body:not(.index-page) .hamburger {
    width: 250px !important;
    min-height: 180px !important;
    max-height: 80vh !important;
    top: 70px !important;
    right: 20px !important;
  }

  /* Page partenaires - Textes agrandis */
  body.partenaires-page main h1 {
    font-size: 24px !important;
    margin-bottom: 15px !important;
  }
  
  
  /* Page partenaires - Uniquement le texte <p> */
  body.partenaires-page main > p:first-child {
    font-size: 18px !important;
    margin-bottom: 25px !important;
    padding: 0 10px !important;
    text-align: center !important;
  
  }
  
  body.partenaires-page main .partenaires-container {
    padding: 15px 0 !important;
  }
  
  body.partenaires-page main .partenaires-scroll {
    gap: 20px !important;
    padding: 15px 5px !important;
  }
  
  body.partenaires-page main .partenaire-item {
    min-width: 150px !important;
    max-width: 200px !important;
    padding: 15px !important;
    flex-direction: column !important;
    gap: 20px !important;
  }
  
  body.partenaires-page main .partenaire-item img {
    max-height: 80px !important;
  }
  
  body.partenaires-page main .scroll-btn {
    width: 40px !important;
    height: 40px !important;
    font-size: 1.2rem !important;
    padding: 10px !important;
  }
  
  body.partenaires-page main .scroll-left {
    left: 5px !important;
  }
  
  body.partenaires-page main .scroll-right {
    right: 5px !important;
  }
  
  body.partenaires-page main .button {
    padding: 12px 25px !important;
    font-size: 1rem !important;
    margin-top: 25px !important;
  }
  
  /* Page à propos */
  body.apropos-page main .carousel-img {
    width: 100% !important;
    max-width: 350px !important;
    height: 250px !important;
  }
  
  /* Ancien style pour compatibilité */
  body.partenaire-item {
    flex-direction: column !important;
    gap: 20px !important;
  }
}

/* Petit mobile - Écrans jusqu'à 480px */
@media (max-width: 480px) {
  body.partenaires-page main {
    padding: 10px !important;
  }
  
  body.partenaires-page main h1 {
    font-size: 28px !important;
    margin-bottom: 10px !important;
  }
  
  body.partenaires-page main p {
    font-size: 22px !important;
    margin-bottom: 20px !important;
    padding: 0 5px !important;
  }
  
  body.partenaires-page main .partenaires-container {
    padding: 10px 0 !important;
  }
  
  body.partenaires-page main .partenaires-scroll {
    gap: 15px !important;
    padding: 10px 5px !important;
  }
  
  body.partenaires-page main .partenaire-item {
    min-width: 120px !important;
    max-width: 160px !important;
    padding: 10px !important;
  }
  
  body.partenaires-page main .partenaire-item img {
    max-height: 60px !important;
  }
  
  body.partenaires-page main .scroll-btn {
    width: 35px !important;
    height: 35px !important;
    font-size: 1rem !important;
    padding: 8px !important;
  }
  
  body.partenaires-page main .scroll-left {
    left: 2px !important;
  }
  
  body.partenaires-page main .scroll-right {
    right: 2px !important;
  }
  
  body.partenaires-page main .button {
    padding: 10px 20px !important;
    font-size: 0.9rem !important;
    margin-top: 20px !important;
  }
}

/* Très petit mobile - Écrans jusqu'à 360px */
@media (max-width: 360px) {
  body.partenaires-page main h1 {
    font-size: 26px !important;
  }
  
  body.partenaires-page main p {
    font-size: 20px !important;
  }
  
  body.partenaires-page main .partenaire-item {
    min-width: 100px !important;
    max-width: 140px !important;
    padding: 8px !important;
  }
  
  body.partenaires-page main .partenaire-item img {
    max-height: 50px !important;
  }
  
  body.partenaires-page main .scroll-btn {
    width: 30px !important;
    height: 30px !important;
    font-size: 0.9rem !important;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.partenaire-item {
    flex-direction: column !important;
    gap: 20px !important;
  }
  
  body.apropos-page main .carousel-img {
    width: 100% !important;
    max-width: 350px !important;
    height: 250px !important;
  }
}
/* ============================================
   PAGE INDEX - RESPONSIVE MOBILE
   ============================================ */

/* Mobile - Écrans jusqu'à 768px */
@media (max-width: 768px) {
  body.index-page main .hud-container {
    transform: scale(0.8) !important;
    top: 10px !important;
    right: 10px !important;
  }
  
  body.index-page main .social-hub-container {
    transform: scale(0.8) !important;
    bottom: 10px !important;
    left: 10px !important;
  }
  
  body.index-page main .game-actions-container {
    transform: scale(0.8) !important;
    bottom: 10px !important;
    right: 10px !important;
  }
  
  body.index-page main .arrow-left,
  body.index-page main .arrow-right {
    font-size: 2rem !important;
    padding: 10px 15px !important;
  }
  
  body.index-page main .arrow-left {
    left: 10px !important;
  }
  
  body.index-page main .arrow-right {
    right: 10px !important;
  }

  html body.index-page main p {
    left: 30px !important;
  }

  html body.index-page main h1 {
    left: 1px !important;
  }

  /* Version Beta - déplacer à droite */
  html body.index-page main p {
    left: 40px !important;
  }
}

/* Petit mobile - Écrans jusqu'à 480px */
@media (max-width: 480px) {
  body.index-page main .hud-container {
    transform: scale(0.7) !important;
    top: 5px !important;
    right: 5px !important;
  }
  
  body.index-page main .social-hub-container {
    transform: scale(0.7) !important;
    bottom: 5px !important;
    left: 5px !important;
  }
  
  body.index-page main .game-actions-container {
    transform: scale(0.7) !important;
    bottom: 5px !important;
    right: 5px !important;
  }
  
  body.index-page main .arrow-left,
  body.index-page main .arrow-right {
    font-size: 1.5rem !important;
    padding: 8px 12px !important;
  }
  
  body.index-page main .arrow-left {
    left: 5px !important;
  }
  
  body.index-page main .arrow-right {
    right: 5px !important;
  }
}

/* Très petit mobile - Écrans jusqu'à 360px */
@media (max-width: 360px) {
  body.index-page main .hud-container {
    transform: scale(0.6) !important;
    top: 2px !important;
    right: 2px !important;
  }
  
  body.index-page main .social-hub-container {
    transform: scale(0.6) !important;
    bottom: 2px !important;
    left: 2px !important;
  }
  
  body.index-page main .game-actions-container {
    transform: scale(0.6) !important;
    bottom: 2px !important;
    right: 2px !important;
  }
  
  body.index-page main .arrow-left,
  body.index-page main .arrow-right {
    font-size: 1.2rem !important;
    padding: 6px 10px !important;
  }
}

/* ============================================
   PAGE DON - RESPONSIVE MOBILE
   ============================================ */

/* Mobile - Écrans jusqu'à 768px */
@media (max-width: 768px) {
  body.don-page main {
    padding: 20px !important;
  }
  
  body.don-page main h1 {
    font-size: 32px !important;
  }
  
  body.don-page main p {
    font-size: 24px !important;
    margin: 15px 0 !important;
  }
  
  body.don-page main .button {
    padding: 15px 30px !important;
    font-size: 1.1rem !important;
  }
  
  body.don-page main .button-don {
    padding: 15px 30px !important;
    font-size: 1.1rem !important;
  }
  
  body.don-page main img {
    max-width: 100% !important;
    height: auto !important;
  }
}

/* Petit mobile - Écrans jusqu'à 480px */
@media (max-width: 480px) {
  body.don-page main {
    padding: 15px !important;
  }
  
  body.don-page main h1 {
    font-size: 28px !important;
  }
  
  body.don-page main p {
    font-size: 22px !important;
    margin: 12px 0 !important;
  }
  
  body.don-page main .button {
    padding: 12px 25px !important;
    font-size: 1rem !important;
  }
  
  body.don-page main .button-don {
    padding: 12px 25px !important;
    font-size: 1rem !important;
  }
}

/* Très petit mobile - Écrans jusqu'à 360px */
@media (max-width: 360px) {
  body.don-page main {
    padding: 10px !important;
  }
  
  body.don-page main h1 {
    font-size: 26px !important;
  }
  
  body.don-page main p {
    font-size: 20px !important;
    margin: 10px 0 !important;
  }
  
  body.don-page main .button {
    padding: 10px 20px !important;
    font-size: 0.9rem !important;
  }
  
  body.don-page main .button-don {
    padding: 10px 20px !important;
    font-size: 0.9rem !important;
  }
}

/* ============================================
   PAGE VOTEZ - RESPONSIVE MOBILE
   ============================================ */

/* Mobile - Écrans jusqu'à 768px */
@media (max-width: 768px) {
  body.votez-page main {
    padding: 20px !important;
  }
  
  body.votez-page main h1 {
    font-size: 32px !important;
  }
  
  body.votez-page main p {
    font-size: 24px !important;
    margin: 15px 0 !important;
  }
  
  body.votez-page main .button {
    padding: 15px 30px !important;
    font-size: 1.1rem !important;
  }
}

/* Petit mobile - Écrans jusqu'à 480px */
@media (max-width: 480px) {
  body.votez-page main {
    padding: 15px !important;
  }
  
  body.votez-page main h1 {
    font-size: 28px !important;
  }
  
  body.votez-page main p {
    font-size: 22px !important;
    margin: 12px 0 !important;
  }
  
  body.votez-page main .button {
    padding: 12px 25px !important;
    font-size: 1rem !important;
  }
}

/* Très petit mobile - Écrans jusqu'à 360px */
@media (max-width: 360px) {
  body.votez-page main {
    padding: 10px !important;
  }
  
  body.votez-page main h1 {
    font-size: 26px !important;
  }
  
  body.votez-page main p {
    font-size: 20px !important;
    margin: 10px 0 !important;
  }
  
  body.votez-page main .button {
    padding: 10px 20px !important;
    font-size: 0.9rem !important;
  }
}

/* ============================================
   PAGE A PROPOS - RESPONSIVE MOBILE
   ============================================ */

/* Mobile - Écrans jusqu'à 768px */
@media (max-width: 768px) {
  body.apropos-page main {
    padding: 20px !important;
  }
  
  body.apropos-page main h1 {
    font-size: 32px !important;
  }
  
  body.apropos-page main p {
    font-size: 24px !important;
    margin: 15px 0 !important;
  }
  
  body.apropos-page main .carousel-container {
    max-width: 100% !important;
    margin: 20px 0 !important;
  }
  
  body.apropos-page main .carousel-img {
    width: 100% !important;
    max-width: 350px !important;
    height: 250px !important;
  }
}

/* Petit mobile - Écrans jusqu'à 480px */
@media (max-width: 480px) {
  body.apropos-page main {
    padding: 15px !important;
  }
  
  body.apropos-page main h1 {
    font-size: 28px !important;
  }
  
  body.apropos-page main p {
    font-size: 22px !important;
    margin: 12px 0 !important;
  }
  
  body.apropos-page main .carousel-img {
    height: 200px !important;
  }
}

/* Très petit mobile - Écrans jusqu'à 360px */
@media (max-width: 360px) {
  body.apropos-page main {
    padding: 10px !important;
  }
  
  body.apropos-page main h1 {
    font-size: 26px !important;
  }
  
  body.apropos-page main p {
    font-size: 20px !important;
    margin: 10px 0 !important;
  }
  
  body.apropos-page main .carousel-img {
    height: 180px !important;
  }
}


/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .services-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  body.apropos-page main .service-item {
    padding: 20px;
  }
  
  body.apropos-page main .service-header {
    flex-direction: column;
    text-align: center;
    gap: 15px;
  }
  
  body.apropos-page main .service-image {
    flex: 0 0 auto;
    width: 250px;
    height: 150px;
  }
  
  body.apropos-page main .service-title {
    font-size: 20px;
  }
  
  body.apropos-page main .service-description {
    font-size: 14px;
  }
  
  body.apropos-page main .section-title {
    font-size: 2em;
  }
  
  body.apropos-page main .section-description {
    font-size: 1.1em;
    padding: 0 10px;
  }
}

/* Responsive pour l'image Electron Satellite */
@media (max-width: 768px) {
  body.apropos-page main img[alt="Electron Satellite"] {
    width: 90%;
    height: 250px;
    margin: 15px auto;
  }
}

@media (max-width: 480px) {
  body.apropos-page main img[alt="Electron Satellite"] {
    width: 95%;
    height: 200px;
    margin: 10px auto;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .propos-content {
    padding: 25px;
    margin: 20px auto;
  }
  
  body.apropos-page main .oxygen-title {
    font-size: 2em;
  }
  
  body.apropos-page main .oxygen-text {
    font-size: 1.1em;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .carousel-row {
    flex-direction: column !important;
    gap: 20px !important;
  }
  
  body.apropos-page main .carousel-img {
    width: 100% !important;
    max-width: 350px !important;
    height: 250px !important;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .image-with-text {
    flex-direction: column !important;
    gap: 20px !important;
    margin-bottom: 30px !important;
  }
  
  body.apropos-page main .image-with-text .img-muscat-vignes {
    width: 100% !important;
    max-width: 350px !important;
    height: 250px !important;
  }
  
  body.apropos-page main .image-caption {
    padding: 20px !important;
  }
  
  body.apropos-page main .image-caption h3 {
    font-size: 1.2em !important;
    margin-bottom: 10px !important;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .alternate-section {
    flex-direction: column !important;
    gap: 20px !important;
    padding: 0 15px !important;
  }
  
  body.apropos-page main .alternate-section.reverse {
    flex-direction: column !important;
  }
  
  body.apropos-page main .alternate-text {
    padding: 20px !important;
  }
  
  body.apropos-page main .alternate-text h3 {
    font-size: 1.4em !important;
    margin-bottom: 15px !important;
  }
  
  body.apropos-page main .alternate-text p {
    font-size: 1.2em !important;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .depot-text {
    padding: 20px !important;
    margin-bottom: 30px !important;
  }
  
  body.apropos-page main .depot-text h3 {
    font-size: 1.4em !important;
    margin-bottom: 15px !important;
  }
  
  body.apropos-page main .depot-text p {
    font-size: 1.2em !important;
  }
}


/* ============================================
   ACCESSIBILITÉ ET OPTIMISATIONS
   ============================================ */

/* Réductions de mouvement pour les utilisateurs sensibles */
@media (prefers-reduced-motion: reduce) {
  body.partenaires-page main .partenaire-item {
    transition: none !important;
  }
  
  body.partenaires-page main .partenaire-item img {
    transition: none !important;
  }
  
  body.partenaires-page main .scroll-btn {
    transition: none !important;
  }
  
  body.index-page main .hud-container,
  body.index-page main .social-hub-container,
  body.index-page main .game-actions-container {
    transition: none !important;
  }
  
  body.don-page main .button,
  body.don-page main .button-don {
    transition: none !important;
  }
  
  body.votez-page main .button {
    transition: none !important;
  }
}

/* Mode sombre (si supporté) */
@media (prefers-color-scheme: dark) {
  body.partenaires-page main .partenaire-item {
    background: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  body.partenaires-page main .partenaire-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
  }
  
  body.partenaires-page main .partenaire-item p {
    color: #e0e0e0 !important;
  }
}

/* Focus pour accessibilité */
body.partenaires-page main .partenaire-item:focus-within {
  outline: 3px solid #4F46E5 !important;
  outline-offset: 2px !important;
}

body.don-page main .button:focus,
body.don-page main .button-don:focus {
  outline: 3px solid #4F46E5 !important;
  outline-offset: 2px !important;
}

body.votez-page main .button:focus {
  outline: 3px solid #4F46E5 !important;
  outline-offset: 2px !important;
}

/* ============================================
   UTILITAIRE RESPONSIVE
   ============================================ */

/* Classes utilitaires pour responsive */
.text-responsive {
  font-size: clamp(1rem, 2.5vw, 1.5rem) !important;
}

.text-responsive-small {
  font-size: clamp(0.8rem, 2vw, 1.2rem) !important;
}

.text-responsive-large {
  font-size: clamp(1.2rem, 3vw, 2rem) !important;
}

.container-responsive {
  padding: clamp(10px, 3vw, 30px) !important;
}

.button-responsive {
  padding: clamp(8px, 2vw, 16px) clamp(16px, 4vw, 32px) !important;
  font-size: clamp(0.9rem, 2.5vw, 1.1rem) !important;
}

/* Masquer des éléments sur mobile */
@media (max-width: 768px) {
  .hide-mobile {
    display: none !important;
  }
}

/* Afficher seulement sur mobile */
@media (min-width: 769px) {
  .show-mobile-only {
    display: none !important;
  }
}

/* Masquer sur petit mobile */
@media (max-width: 480px) {
  .hide-small-mobile {
    display: none !important;
  }
}

/* Afficher seulement sur petit mobile */
@media (min-width: 481px) {
  .show-small-mobile-only {
    display: none !important;
  }
}

/* Responsive pour mobile */
@media (max-width: 768px) {
  body.apropos-page main .project-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 15px;
  }
  
  body.apropos-page main .project-item {
    padding: 20px;
  }
  
  body.apropos-page main .project-image {
    height: 180px;
  }
}

@media (max-width: 480px) {
  body.apropos-page main .project-image {
    height: 160px;
  }
  
  body.apropos-page main .project-title {
    font-size: 20px;
  }
  
  body.apropos-page main .project-description {
    font-size: 14px;
  }
}

.copyright {
  text-align: center;
  margin-top: 20px;
}
