:root{--panel-bg:#1e2a38;--panel-pad:1rem;--radius:.75rem;--accent:#3498db;--accent-hov:#2980b9;}
*{box-sizing:border-box;margin:0;padding:0}

@keyframes fadeIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);} }
.fade-in{animation:fadeIn .6s ease-out;}

/* -----------------------------------------------------------------
   BODY & GLOBAL BACKGROUND
------------------------------------------------------------------*/
body{font-family:'Segoe UI',sans-serif;background:linear-gradient(#0e1a2b,#1e2a38);color:#fff;
     min-height:100vh;display:flex;flex-direction:column;align-items:center;overflow-x:hidden;position:relative;}
body::before{content:"";position:fixed;inset:0;background:url('img/background.jpg') center/cover;
             opacity:.08;filter:blur(4px);z-index:-1;}

/* -----------------------------------------------------------------
   LOGO‑LINK (Ika Musume)
------------------------------------------------------------------*/
.logo-link{display:inline-flex;align-items:center;position:relative;}
.logo-link img{height:64px;border-radius:6px;transition:transform .2s;}
.logo-link:hover img{transform:scale(1.15);}
.logo-link::after{content:"de geso~";position:absolute;bottom:-1.4rem;left:50%;
                  transform:translateX(-50%);background:rgba(0,0,0,.7);color:#fff;
                  padding:2px 6px;border-radius:4px;font-size:.75rem;opacity:0;
                  transition:opacity .2s;white-space:nowrap;pointer-events:none;}
.logo-link:hover::after{opacity:1;}

/* -----------------------------------------------------------------
   PAGE TITLE WRAP
------------------------------------------------------------------*/
.page-title-wrap{display:flex;align-items:center;gap:.8rem;margin-top:2rem;}
.page-title-wrap h1{font-size:clamp(2rem,2vw,2.5rem);}

/* -----------------------------------------------------------------
   BURGER & SIDE MENU
------------------------------------------------------------------*/
.burger{position:absolute;top:20px;left:20px;width:42px;height:38px;background:none;border:none;cursor:pointer;z-index:1000;
        display:flex;flex-direction:column;justify-content:space-around;padding:6px;}
.burger span{display:block;width:100%;height:4px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s;}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

.side-menu{position:fixed;top:0;left:0;height:100vh;width:260px;background:#2c3e50;padding:2rem 1.5rem;
           transform:translateX(-100%);transition:transform .3s ease-out;z-index:999;
           display:flex;flex-direction:column;gap:1rem;}
.side-menu.open{transform:translateX(0);}
.side-menu h2{margin-top:0;font-size:1.5rem;color:#fff;}
.side-menu a{display:block;color:#ecf0f1;text-decoration:none;font-size:1.1rem;margin:.5rem 0;
             transition:color .2s;}
.side-menu a:hover{color:#3498db;}

/* -----------------------------------------------------------------
   HOME
------------------------------------------------------------------*/
#home-container{width:100%;max-width:1400px;margin:0 auto;padding:2rem;
                display:flex;gap:2rem;align-items:center;min-height:70vh;flex-wrap:wrap;}
.home-left{flex:1 1 320px;display:flex;flex-direction:column;align-items:center;gap:1.5rem;
           margin-top:-30px;}
.home-left .btn{min-width:220px;padding:1rem 2.3rem;font-size:1.15rem;}

.home-right{flex:1 1 320px;display:flex;align-items:center;justify-content:center;}

/* carte anime */
#home-anime-card{max-width:100%;}
.home-anime{display:flex;gap:2rem;align-items:flex-start;justify-content:center;flex-wrap:nowrap;}
/* Enlarged & responsive cover with max height cap */
.home-anime img{
  width:clamp(140px,32vw,180px);
  height:auto;
  max-height:60vh;
  border-radius:1rem;
  box-shadow:0 0 15px rgba(0,0,0,.5);
  margin-left:-12px;
  transition:transform .25s ease;
}
.home-anime .info{max-width:380px;}
.home-anime h2{margin:.2rem 0 .6rem;font-size:clamp(1.4rem,2vw,2rem);}
.home-anime p{margin:.25rem 0;line-height:1.35;}

/* -----------------------------------------------------------------
   BUTTONS & INPUTS
------------------------------------------------------------------*/
.btn{padding:.8rem 1.5rem;font-size:1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;
     box-shadow:0 0 8px rgba(0,0,0,.2);white-space:nowrap;transition:transform .2s,background .3s;}
.btn:hover{background:var(--accent-hov);transform:scale(1.05);}

.top-input{display:none;width:100%;max-width:1400px;gap:1rem;flex-wrap:wrap;align-items:center;justify-content:flex-start;padding:0 2.5rem;}
.input-group{flex:1;position:relative;}
input#guess{width:100%;padding:.8rem 1rem;font-size:1rem;background:#2c3e50;border:none;border-radius:8px;color:#fff;
            box-shadow:0 0 8px rgba(0,0,0,.2);}

/* --- Top stats (Challenge toolbar) placed at far left --- */
.top-stats{
  order:-1;
  background:#2c3e50;
  padding:.6rem .8rem;
  border-radius:8px;
  box-shadow:0 0 8px rgba(0,0,0,.2);
  font-size:.95rem;
  white-space:nowrap;
}

/* --- Suggestions (Challenge) : fond bleu foncé + scroll + plus d'options --- */
#suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:#0c3770f9;
             color:#fff;border-radius:6px;max-height:320px;overflow-y:auto;
             box-shadow:0 4px 12px rgba(0,0,0,.4);}
#suggestions:empty{display:none;}
#suggestions:not(:empty){border:1px solid rgba(255,255,255,.12);}
#suggestions .suggestion{display:flex;gap:.5rem;align-items:center;padding:8px 10px;border-bottom:1px solid rgb(83, 83, 100);
                         cursor:pointer;}
#suggestions .suggestion:last-child{border-bottom:none;}
#suggestions .suggestion:hover{background:rgba(255,255,255,.08);}
#suggestions img{width:40px;height:60px;border-radius:4px;object-fit:cover;}

/* slider esthétique (général) */
input[type=range]{-webkit-appearance:none;width:100%;height:8px;background:#34495e;border-radius:4px;outline:none;cursor:pointer;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);
                                        transition:transform .2s;}
input[type=range]:hover::-webkit-slider-thumb{transform:scale(1.15);}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);}

/* --- Slider du Game Setup : plus étroit --- */
#rounds-slider{max-width:320px;width:80%;margin:.25rem auto 0;display:block;}

/* -----------------------------------------------------------------
   MODE SELECT (nouveau look)
------------------------------------------------------------------*/
.mode-select{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem;}
.mode-select input{display:none;}
.mode-select label{background:#34495e;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;
                   transition:background .2s,transform .2s;user-select:none;}
.mode-select input:checked+label{background:var(--accent);transform:scale(1.05);}
.mode-select label:hover{background:#3d566e;}

/* -----------------------------------------------------------------
   CHALLENGE BOARD
------------------------------------------------------------------*/
.board{display:none;width:100%;max-width:1400px;margin:2rem auto;padding:0 2.5rem;
       grid-template-columns:repeat(3,1fr);gap:2rem;row-gap:1.5rem;align-items:stretch;}

.panel{background:var(--panel-bg);padding:var(--panel-pad);border-radius:var(--radius);box-shadow:0 0 10px rgba(0,0,0,.3);
       display:flex;flex-direction:column;min-height:230px;transition:transform .25s;}
.panel-title{margin:0 0 .8rem;font-size:1.25rem;text-align:center;}
.panel-body{flex:1 1 auto;}
.placeholder{opacity:.6;margin:0;}

.panel.fancy{position:relative;overflow:hidden;}
.panel.fancy::before{content:"";position:absolute;inset:-10%;background-image:var(--bg);background-size:cover;background-position:center;
                     opacity:.12;pointer-events:none;transition:opacity .25s;}
.panel:hover{transform:scale(1.03);}
.panel.fancy:hover::before{opacity:.25;}

.guess-card{display:grid;grid-template-columns:auto 1fr;gap:1rem;}
.guess-card img{width:90px;border-radius:8px;object-fit:cover;}
.guess-info h2,.guess-info h3{margin:0 0 .5rem;font-size:clamp(1.1rem,1.1vw,1.6rem);overflow-wrap:anywhere;}
.guess-info p{margin:1rem 0;}

#comparison-col{overflow:hidden !important;}
#comparison-col .panel-body{overflow:auto;max-height:none;}
.correct{color:#2ecc71;}
.wrong{color:#e74c3c;}

.summary h3{margin:0 0 1rem;text-align:center;}
.summary p{margin:.5rem 0;}

.score-panel{grid-column:1/3;grid-row:2;align-self:start;}
.score-display{text-align:center;font-size:1.1rem;}

.bonus-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem;}
.bonus-item{display:flex;align-items:flex-start;gap:.75rem;background:#34495e;border:none;border-radius:8px;
            padding:.6rem;text-align:left;color:#fff;cursor:pointer;transition:transform .2s,background .2s;}
.bonus-item:hover:not([disabled]){background:#3d566e;transform:scale(1.02);}
.bonus-item[disabled]{opacity:.5;cursor:not-allowed;}
.bonus-item img,.bonus-item .bonus-icon{width:32px;height:32px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;
                                        background:#2c3e50;font-weight:700;}
.bonus-icon{font-family:system-ui,Segoe UI,sans-serif;}
.bonus-text{line-height:1.2;}
.bonus-title{font-weight:600;}
.bonus-cost{opacity:.85;font-weight:400;margin-left:.35rem;font-size:.95rem;}
.bonus-desc{font-weight:normal;opacity:.9;font-size:.95rem;margin-top:.15rem;}

#history-panel{grid-column:3/4;grid-row:2;}
#history-content .history-item{display:flex;gap:.5rem;align-items:center;margin:.4rem 0;}



/* Compact anime card for Game Over modal */
.compact-anime-card {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: var(--panel-bg);
  padding: 1rem;
  border-radius: var(--radius);
  box-shadow: 0 0 10px rgba(0,0,0,.3);
  margin-bottom: 1rem;
  flex-wrap: nowrap;
}
.compact-anime-card img {
  width: 100px;
  height: auto;
  border-radius: 0.75rem;
  object-fit: cover;
}
.compact-anime-card .info {
  flex: 1;
}
.compact-anime-card .info h2 {
  margin: 0 0 .5rem;
  font-size: 1.1rem;
}
.compact-anime-card .info p {
  margin: .25rem 0;
  font-size: 0.95rem;
  opacity: 0.95;
}
.skipped-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}


/* ------------  MODALS  -------------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;
                visibility:hidden;opacity:0;transition:opacity .25s;z-index:1000;}
.modal-backdrop.active{visibility:visible;opacity:1;}
.modal-card{background:#2c3e50;padding:2rem;border-radius:1rem;box-shadow:0 0 20px rgba(0,0,0,.4);
            text-align:center;width:90%;max-width:420px;position:relative;overflow:hidden;}
.modal-card::before{content:"";position:absolute;inset:0;background-image:var(--cover,none);
                    background-size:cover;background-position:center;filter:blur(2px);opacity:.30;pointer-events:none;
                    transition:opacity .3s;}
.modal-card:hover::before{opacity:.25;}
.modal-card h2{margin-top:0;font-size:1.4rem;}
.modal-card h3{margin-bottom:.5rem;}

.modal-btn{padding:.7rem 1.6rem;margin:1rem .4rem 0;border:none;border-radius:8px;font-size:1rem;cursor:pointer;color:#fff;
           transition:transform .2s;}
.modal-btn:hover{transform:scale(1.08);}
.easy{background:#27ae60;}.easy:hover{background:#1e8449;}
.hard{background:#e74c3c;}.hard:hover{background:#c0392b;}
.close-btn{position:absolute;top:.6rem;right:.6rem;background:transparent;border:none;color:#fff;font-size:1.35rem;cursor:pointer;}

#choice-options{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;}
.choice-option{background:#34495e;padding:.6rem;border:none;border-radius:8px;color:#fff;font-size:1rem;cursor:pointer;
               transition:transform .2s;}
.choice-option:hover{background:#3d566e;transform:scale(1.05);}

/* -----------------------------------------------------------------
   LIBRARY
------------------------------------------------------------------*/
#library-container{display:none;width:100%;max-width:1400px;margin:0 auto;padding:2rem;}
.library-controls{display:flex;gap:1rem;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;}
.search-group{flex:1;min-width:240px;}
#library-container .search-group input{width:100%;padding:.8rem 1rem;font-size:1rem;background:#2c3e50;border:none;border-radius:8px;color:#fff;
                                       box-shadow:0 0 8px rgba(0,0,0,.2);}
.dataset-switch{display:flex;align-items:center;gap:.65rem;white-space:nowrap;}
.switch-label{opacity:.9;font-size:.95rem;}
.switch{position:relative;display:inline-block;width:58px;height:30px;}
.switch input{display:none;}
.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#3d566e;transition:.3s;border-radius:26px;}
.switch .slider::before{content:"";position:absolute;height:22px;width:22px;left:4px;top:4px;background:#fff;border-radius:50%;
                        transition:.25s;}
.switch input:checked + .slider{background:#27ae60;}
.switch input:checked + .slider::before{transform:translateX(28px);}

.search-mode{display:flex;align-items:center;gap:.6rem;}
.search-mode .mode-label{opacity:.9;font-size:.95rem;}
.search-mode select{-webkit-appearance:none;appearance:none;background:#34495e;color:#fff;border:none;border-radius:8px;
                   padding:.6rem 2.2rem .6rem .9rem;box-shadow:0 0 8px rgba(0,0,0,.2);cursor:pointer;}
.search-mode select:focus{outline:2px solid var(--accent);outline-offset:2px;}
.search-mode select{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 6"><path fill="%23ffffff" d="M0 0l5 6 5-6z"/></svg>');
                    background-repeat:no-repeat;background-position:right .6rem center;background-size:10px;}

.library-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start;}
@media (max-width:700px){.library-grid{grid-template-columns:1fr;}}
.library-item{display:flex;gap:1rem;align-items:flex-start;background:var(--panel-bg);padding:var(--panel-pad);border-radius:var(--radius);box-shadow:0 0 10px rgba(0,0,0,.3);
              transition:transform .25rem;}
.library-item:hover{transform:scale(1.02);}
.library-item img{width:160px;aspect-ratio:2/3;height:auto;border-radius:1rem;object-fit:cover;box-shadow:0 0 10px rgba(0,0,0,.4);}
.library-item .info h2{margin:0 0 .5rem;font-size:1.1rem;}
.library-item .info p{margin:.25rem 0;opacity:.95;}

#library-sentinel{height:1px;}

/* -----------------------------------------------------------------
   Stats
------------------------------------------------------------------*/
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:1100px;margin:0 auto;}
.stats-col{display:flex;gap:1rem;align-items:stretch;}
.stats-card{flex:1;background:#2c3e50;border-radius:10px;padding:1rem 1.2rem;}
.stats-note{font-size:.95rem;opacity:.75;}
.image-wrap, .guess-card a.cover, .library-item a.cover{display:inline-block;overflow:hidden;border-radius:1rem;}
.image-wrap img, .guess-card a.cover img, .library-item a.cover img{display:block;transition:transform .25s ease;}
.image-wrap:hover img, .guess-card a.cover:hover img, .library-item a.cover:hover img{transform:scale(1.06);}
.mal-link{cursor:pointer;text-decoration:none}
.mal-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.top-stats{margin-left:0;}


.stats-section {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 2rem;
  margin: 2rem 0;
  flex-wrap: wrap;
}
.stats-col {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex: 1 1 300px;
}
.vertical-separator {
  width: 2px;
  background: rgba(255,255,255,0.3);
  height: auto;
  align-self: stretch;
}
.stats-card {
  background: var(--panel-bg);
  padding: 1rem;
  border-radius: var(--radius);
  box-shadow: 0 0 10px rgba(6, 4, 35, 0.3);
}
.stats-subtitle {
  text-align: center;
  font-size: 1.3rem;
  margin-top: 2rem;
}
.stats-divider {
  margin: 3rem auto;
  border: none;
  height: 2px;
  width: 80%;
  background: rgba(255,255,255,0.2);
}

.modal-backdrop {
  transition: opacity 0.25s ease, visibility 0.25s ease;
}

/* --- Scroll for Game Over modal content --- */
#gameover-summary {
  max-height: 60vh;
  overflow-y: auto;
  padding-right: 0.5rem;
}


/* Daily mode buttons fix */
body.daily-mode .top-input #skip-btn,
body.daily-mode .top-input button[onclick="openSetupModal()"] {
  display: none !important;
}

/* -------- STATS PANELS LAYOUT FIX -------- */
.stats-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  margin-top: 2rem;
}

.stat-panel {
  background: var(--panel-bg);
  padding: 1.2rem;
  border-radius: var(--radius);
  box-shadow: 0 0 10px rgba(0,0,0,.3);
  text-align: center;
  width: 100%;
  max-width: 260px;
  flex: 1 1 240px;
}

.stats-wrapper {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.stats-sections {
  display: flex;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}

.player-stats,
.global-stats {
  flex: 1 1 45%;
}


.leaderboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.leaderboard-section {
  background: var(--panel-bg);
  padding: 1rem;
  border-radius: var(--radius);
  box-shadow: 0 0 8px rgba(0,0,0,0.3);
}

.leaderboard-section h3 {
  margin-bottom: 0.75rem;
  text-align: center;
  font-size: 1.2rem;
}

.table-scroll {
  max-height: 400px;
  overflow-y: auto;
}

.table-scroll table {
  width: 100%;
  border-collapse: collapse;
  color: #fff;
}

.table-scroll th,
.table-scroll td {
  padding: 0.6rem;
  text-align: left;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.table-scroll tbody tr:hover {
  background: rgba(255,255,255,0.05);
}

#ranking-search::placeholder {
  color: rgba(255,255,255,0.6);
}

.input-field {
  width: 100%;
  padding: 0.8rem 1rem;
  font-size: 1rem;
  background: #2c3e50;
  border: none;
  border-radius: 8px;
  color: #fff;
  margin: 0.75rem 0;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
}
.input-field:focus {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.notification {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: #2ecc71; /* success = vert */
  color: white;
  padding: 1rem 2rem;
  border-radius: 8px;
  font-size: 1rem;
  box-shadow: 0 0 10px rgba(0,0,0,.4);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.4s ease;
  z-index: 9999;
}

.notification.error {
  background: #e74c3c;
}

.notification.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

.hidden {
  display: none;
}

@media (max-width: 768px) {
  .page-title-wrap {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-top: 1rem;
  }

  .logo-link img {
    height: 48px;
    margin-bottom: 0.5rem;
  }

  .top-input {
    flex-direction: column;
    align-items: stretch;
    padding: 1rem;
    gap: 0.8rem;
  }

  .top-stats {
    order: initial;
    text-align: center;
    width: 100%;
    margin-bottom: 0.8rem;
  }

  .board {
    display: flex !important;
    flex-direction: column;
    padding: 1rem;
  }

  .panel {
    min-height: unset;
    padding: 1rem;
  }

  .bonus-list {
    flex-direction: column;
  }

  .bonus-item {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .bonus-text {
    font-size: 0.85rem;
  }

  .score-panel {
    grid-column: unset;
    grid-row: unset;
  }

  #history-panel {
    grid-column: unset;
    grid-row: unset;
  }

  #home-container {
    flex-direction: column;
    padding: 1.5rem;
  }

  .home-left, .home-right {
    width: 100%;
    align-items: center;
    justify-content: center;
  }

  .home-anime {
    flex-direction: column;
    gap: 1rem;
  }

  .modal-card {
    padding: 1.5rem;
    width: 95%;
  }

  .library-grid {
    grid-template-columns: 1fr;
  }
}


@media (max-width: 768px) {
  .top-input {
    flex-direction: row-reverse;
    justify-content: space-between;
  }

  .top-input #skip-btn {
    order: 1;
    flex: 1;
    margin-left: 0.5rem;
  }

  .top-input button[onclick="openSetupModal()"] {
    order: 2;
    flex: 1;
    margin-right: 0.5rem;
  }

  .board {
    display: flex !important;
    flex-direction: column;
  }

  #mystery-summary {
    order: 1;
  }

  #guess-col {
    order: 2;
  }

  #comparison-col {
    display: none;
  }

  .score-panel {
    order: 3;
  }

  #history-panel {
    order: 4;
  }
}

@media (max-width: 768px) {
  .top-input {
    flex-direction: column;
    align-items: stretch;
  }

  .top-input .btn {
    order: -1;
    width: 100%;
  }

  .top-stats {
    order: 10;
    width: 100%;
    margin-top: 0.5rem;
  }
}

.studio-logo {
  width: 64px !important;
  height: 32px !important;
  object-fit: contain;
  vertical-align: text-bottom;
  margin-right: 4px;
  opacity: 1;
  border-radius: 0px !important;
  background-color: #ffffff33;
  padding: 1px;
}
