@import url('https://fonts.googleapis.com/css2?family=Audiowide&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lilita+One&display=swap');

:root {
--glow-primary: rgba(56, 189, 248, 0.7);
--glow-secondary: rgba(94, 234, 212, 0.6);
--neon-pink: rgba(236, 72, 153, 0.8);
--neon-blue: rgba(143, 25, 158, 0.8);
--neon-green: rgba(100, 9, 85, 0.8);
--card-width-mobile: 280px;
--card-width-tablet: 300px;
--card-width-desktop: 320px;
}

body {
overflow-x: hidden;
min-height: 100vh;
margin: 0;
padding: 0;
padding-top: 0 !important;
}

body::before {
display: none !important;
}

html {
min-height: 100%;
}

.no-select {
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-tap-highlight-color: transparent;
}

.select-mode-title {
text-align: center;
font-family: 'Audiowide', cursive, sans-serif;
letter-spacing: 0.1em;
color: #fff;
text-shadow: 0 2px 16px #7b2cbf, 0 0 8px #38bdf8;
margin-bottom: 3rem;
padding: 0 1rem;
padding-top: 100px !important;
margin-top: 0 !important;

font-size: 2rem;
line-height: 1.2;
}

@media (max-width: 900px) {
.select-mode-title {
margin-bottom: 1.5rem !important;
padding-top: 140px !important;
}
}


.modes-grid-container {
width: 100%;
max-width: 1400px;
margin: 0 auto;
padding: 2rem 1rem 4rem;
box-sizing: border-box;
}

@media (max-width: 900px) {
.modes-grid-container {
padding: 0.5rem 1rem 3rem;
}
}

.modes-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
gap: 2rem;
width: 100%;
   justify-items: stretch;
 justify-content: center;
 grid-auto-columns: minmax(min(100%, 320px), 1fr);
}

/* Carte de mode */
.mode-card {
position: relative;
background: linear-gradient(135deg, rgba(30, 20, 60, 0.95), rgba(40, 25, 70, 0.95));
backdrop-filter: blur(10px);
border-radius: 1.25rem;
overflow: hidden;
border: 2px solid rgba(236, 72, 153, 0.6);
box-shadow: 
0 10px 30px rgba(0, 0, 0, 0.8),
0 0 25px rgba(236, 72, 153, 0.4),
0 0 12px rgba(143, 25, 158, 0.4),
inset 0 0 100px rgba(99, 46, 185, 0.15);
transition: background 0.3s, transform 0.2s, box-shadow 0.3s;
cursor: url('/static/cursor/select.cur'), pointer;
 width: 100%;
}

.mode-card::before {
content: '';
position: absolute;
inset: -3px;
background: linear-gradient(135deg, 
rgba(236, 72, 153, 0.6) 0%, 
rgba(143, 25, 158, 0.6) 50%, 
rgba(123, 44, 191, 0.6) 100%);
border-radius: 1.25rem;
opacity: 0;
z-index: -1;
filter: blur(12px);
transition: opacity 0.3s ease;
}

.mode-card:hover::before {
opacity: 1;
}

.mode-card:hover {
transform: scale(1.05) translateY(-4px);
background: linear-gradient(135deg, rgba(50, 30, 90, 0.98), rgba(60, 35, 100, 0.98));
box-shadow: 
0 16px 32px rgba(0, 0, 0, 0.9),
0 0 40px rgba(236, 72, 153, 0.6),
0 0 20px rgba(143, 25, 158, 0.6),
inset 0 0 120px rgba(236, 72, 153, 0.2);
border-color: rgba(236, 72, 153, 0.8);
}

.mode-card.coming-soon {
opacity: 0.85;
}

.mode-card.coming-soon:hover {
transform: translateY(-5px) scale(1.01);
}

.mode-card-inner {
position: relative;
height: 100%;
display: flex;
flex-direction: column;
}

.mode-image-wrapper {
position: relative;
width: 100%;
height: 220px;
overflow: hidden;
}

@media (max-width: 900px) {
.mode-image-wrapper {
height: 160px;
}

.mode-card {
border: 3px solid rgba(236, 72, 153, 0.8);
background: linear-gradient(135deg, rgba(30, 20, 60, 0.98), rgba(40, 25, 70, 0.98));
box-shadow: 
0 8px 24px rgba(0, 0, 0, 0.9),
0 0 35px rgba(236, 72, 153, 0.6),
0 0 18px rgba(143, 25, 158, 0.6),
inset 0 0 100px rgba(99, 46, 185, 0.2);
}


@media (min-width: 600px) and (max-width: 900px) {
   .mode-card {
      height: 460px;
   }
   .mode-card-inner { height: 100%; }
   .mode-description {
      display: -webkit-box;
         line-clamp: 3;
      -webkit-line-clamp: 3;
      -webkit-box-orient: vertical;
      overflow: hidden;
      min-height: calc(1.6em * 3);
   }
   .mode-image-wrapper { height: 180px; }
   .mode-title { 
      display: -webkit-box;
      -webkit-line-clamp: 1;
      line-clamp: 1;
      -webkit-box-orient: vertical;
      overflow: hidden;
      min-height: 1.8em;
   }
   .mode-actions { min-height: 56px; }
}
.mode-card::before {
inset: -4px;
opacity: 0.4;
}

.mode-card:hover {
border-color: rgba(236, 72, 153, 1);
background: linear-gradient(135deg, rgba(50, 30, 90, 1), rgba(60, 35, 100, 1));
box-shadow: 
0 12px 32px rgba(0, 0, 0, 0.95),
0 0 45px rgba(236, 72, 153, 0.8),
0 0 25px rgba(143, 25, 158, 0.8),
inset 0 0 120px rgba(236, 72, 153, 0.25);
}
}

.mode-image {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1), filter 0.4s ease;
filter: brightness(1) contrast(1.05);
}

.mode-card:hover .mode-image {
transform: scale(1.08);
filter: brightness(0.9) contrast(1.05);
}

.mode-overlay {
position: absolute;
inset: 0;
background: linear-gradient(
to bottom,
rgba(15, 23, 42, 0) 0%,
rgba(15, 23, 42, 0.3) 50%,
rgba(15, 23, 42, 0.9) 100%
);
transition: background 0.4s ease;
@media (max-width: 599px) {
.modes-grid { 
   grid-template-columns: 1fr; 
   justify-items: stretch; 
   justify-content: center;
}
}

pointer-events: none;
}

.mode-card:hover .mode-overlay {
background: linear-gradient(
to bottom,
rgba(15, 23, 42, 0.2) 0%,
rgba(15, 23, 42, 0.5) 50%,
rgba(15, 23, 42, 0.95) 100%
);
}

.coming-soon-badge {
position: absolute;
top: 15px;
right: 15px;
background: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);
color: white;
padding: 8px 16px;
border-radius: 8px;
font-weight: bold;
font-size: 0.75rem;
letter-spacing: 1.5px;
z-index: 10;
box-shadow: 0 4px 12px rgba(239, 68, 68, 0.5);
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6);
animation: pulse-badge 2s ease-in-out infinite;
border: 2px solid rgba(255, 255, 255, 0.4);
}

@keyframes pulse-badge {
0%, 100% {
transform: scale(1);
box-shadow: 0 4px 12px rgba(239, 68, 68, 0.5);
}
50% {
transform: scale(1.08);
box-shadow: 0 6px 20px rgba(239, 68, 68, 0.7);
}
}

.mode-content {
padding: 1.5rem;
flex: 1;
display: flex;
flex-direction: column;
gap: 1rem;
}

@media (max-width: 900px) {
.mode-content {
padding: 1rem;
gap: 0.75rem;
}
}

.mode-icon {
font-size: 2.5rem;
text-align: center;
filter: drop-shadow(0 4px 8px rgba(236, 72, 153, 0.5)) drop-shadow(0 0 4px rgba(123, 44, 191, 0.4));
animation: floatIcon 3s ease-in-out infinite;
}

@keyframes floatIcon {
0%, 100% { transform: translateY(0px); }
50% { transform: translateY(-8px); }
}

.mode-title {
font-family: 'Audiowide', sans-serif;
font-size: 1.5rem;
font-weight: bold;
text-align: center;
color: #fff;
text-shadow: 0 2px 8px #7b2cbf, 0 0 4px #38bdf8;
letter-spacing: 2px;
margin: 0;
}

.mode-description {
text-align: center;
color: #cbd5e1;
font-size: 0.95rem;
line-height: 1.6;
margin: 0;
flex: 1;
}

.mode-actions {
display: flex;
justify-content: center;
align-items: center;
gap: 0.75rem;
margin-top: auto;
}

.mode-play-btn {
flex: 1;
display: flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
padding: 0.85rem 1.5rem;
background: linear-gradient(90deg, #632eb9, #7b2cbf);
color: #fff;
border: none;
border-radius: 2em;
font-weight: bold;
font-size: 0.95rem;
letter-spacing: 0.05em;
text-decoration: none;
text-shadow: 0 2px 8px #7b2cbf, 0 0 4px #38bdf8;
cursor: url('/static/cursor/select.cur'), pointer;
transition: background 0.3s, transform 0.2s, box-shadow 0.3s;
box-shadow: 0 0 18px rgba(56, 189, 248, 0.7), 0 0 8px rgba(236, 72, 153, 0.8);
font-family: 'Lilita One', cursive;
}

.mode-play-btn:hover {
transform: scale(1.07) translateY(-2px);
box-shadow: 0 0 32px rgba(236, 72, 153, 0.8), 0 0 16px rgba(143, 25, 158, 0.8);
background: linear-gradient(90deg, #ec4899, #8f199e);
}

.mode-play-btn:active {
transform: translateY(0);
box-shadow: 0 3px 10px rgba(56, 189, 248, 0.3);
}

.mode-play-btn *, .mode-play-btn {
cursor: url('/static/cursor/select.cur'), pointer !important;
}

.mode-play-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
background: #666;
}

.mode-play-btn:disabled:hover {
transform: none;
box-shadow: 0 4px 12px rgba(56, 189, 248, 0.3);
}

.mode-btn-icon {
width: 18px;
height: 18px;
}

.mode-leaderboard-btn {
display: flex;
align-items: center;
justify-content: center;
width: 52px;
height: 52px;
background: linear-gradient(135deg, rgba(255, 215, 0, 0.8), rgba(255, 165, 0, 0.7));
border: 2px solid rgba(255, 215, 0, 0.6);
border-radius: 10px;
font-size: 1.4rem;
text-decoration: none;
transition: background 0.3s, transform 0.2s, box-shadow 0.3s;
cursor: url('/static/cursor/select.cur'), pointer;
box-shadow: 0 0 8px rgba(255, 215, 0, 0.3), 0 0 4px rgba(255, 165, 0, 0.25);
}

.mode-leaderboard-btn:hover {
background: linear-gradient(135deg, rgba(255, 165, 0, 0.85), rgba(255, 140, 0, 0.8));
border-color: rgba(255, 165, 0, 0.7);
transform: scale(1.07) translateY(-2px);
box-shadow: 0 0 12px rgba(255, 215, 0, 0.4), 0 0 6px rgba(255, 165, 0, 0.35);
}


@media (min-width: 901px) {
.select-mode-title {
padding-top: 220px !important;
margin-top: 0 !important;
}
}

@media (max-width: 900px) {
.select-mode-title {
padding-top: 100px !important;
margin-top: 0 !important;
}
}

@media (min-width: 600px) and (max-width: 900px) {
.modes-grid {
grid-template-columns: repeat(2, 1fr);
gap: 1.5rem;
}
}

@media (min-width: 901px) and (max-width: 1200px) {
.select-mode-title {
font-size: 2.5rem;
padding-top: 12vh;
}

.modes-grid {
grid-template-columns: repeat(2, 1fr);
gap: 2rem;
}

.mode-image-wrapper {
height: 240px;
}

 .mode-card { height: 500px; }
 .mode-card-inner { height: 100%; }
 .mode-title {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 1.8em;
 }
 .mode-description {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: calc(1.6em * 3);
 }
 .mode-actions { min-height: 56px; }
}

@media (min-width: 1201px) and (max-width: 1600px) {
.select-mode-title {
font-size: 3rem;
padding-top: 10vh;
}

.modes-grid {
grid-template-columns: repeat(3, 1fr);
gap: 2.5rem;
}

.mode-image-wrapper {
height: 260px;
}
}

@media (min-width: 1601px) {
.select-mode-title {
font-size: 3.5rem;
padding-top: 8vh;
}

.modes-grid {
grid-template-columns: repeat(3, 1fr);
gap: 3rem;
max-width: 1600px;
}

.mode-image-wrapper {
height: 280px;
}

.mode-card {
border-radius: 1.5rem;
}
}

@media (max-width: 380px) {
.select-mode-title {
font-size: 1.6rem;
}

.modes-grid {
 grid-template-columns: 1fr;
 justify-items: center;
gap: 1.5rem;
}

.mode-title {
font-size: 1.3rem;
}

.mode-description {
font-size: 0.85rem;
}

.mode-play-btn {
padding: 0.75rem 1.25rem;
font-size: 0.85rem;
}

.coming-soon-badge {
font-size: 0.65rem;
padding: 6px 12px;
}
}

@media (orientation: landscape) and (max-height: 600px) {
.select-mode-title {
padding-top: 5vh;
font-size: 1.8rem;
margin-bottom: 2rem;
}

.modes-grid-container {
padding: 1rem 1rem 2rem;
}

.mode-image-wrapper {
height: 180px;
}
}

@media (prefers-reduced-motion: reduce) {
.mode-card {
transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.mode-card::before {
animation: none;
}

.mode-icon {
animation: none;
}

.coming-soon-badge {
animation: none;
}

.mode-image {
transition: transform 0.3s ease;
}
}

@media (pointer: coarse) {
.mode-play-btn {
min-height: 48px;
padding: 0.9rem 1.5rem;
}

.mode-leaderboard-btn {
width: 52px;
height: 52px;
}
}

.nom-auteur {
font-family: 'Iceberg', cursive, sans-serif;
color: #fff;
text-align: center;
padding: 1rem;
font-size: 0.9rem;
}