@import url('https://fonts.googleapis.com/css2?family=Exo+2:wght@400;500;600;700&family=Rajdhani:wght@400;500;600&display=swap');

:root {
  --bg:        #0a0a14;
  --bg2:       #12121f;
  --bg3:       #1a1a2e;
  --bg4:       #222238;
  --accent:    #7c6fe0;
  --accent2:   #a89df0;
  --border:    rgba(255,255,255,0.07);
  --border2:   rgba(255,255,255,0.14);
  --text:      #ddddf0;
  --text2:     #7878a0;
  --text3:     #4a4a70;
  --radius:    10px;
  --radius-lg: 14px;
  --font:      'Exo 2', sans-serif;
  --font-alt:  'Rajdhani', sans-serif;
}

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

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 14px;
  min-height: 100vh;
}

/* ── NAV ── */
nav {
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 1.5rem;
  height: 54px;
  position: sticky;
  top: 0;
  z-index: 100;
}
.logo {
  font-family: var(--font-alt);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 1.5px;
  margin-right: auto;
  text-transform: uppercase;
}
.logo span { color: var(--accent2); }
.nav-btn {
  background: none;
  border: none;
  color: var(--text2);
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  padding: 0 16px;
  height: 54px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
}
.nav-btn:hover { color: var(--text); }
.nav-btn.active { color: var(--accent2); border-bottom-color: var(--accent); }

/* ── PAGES ── */
.page { display: none; padding: 1.2rem 1.5rem 2rem; }
.page.active { display: block; }

/* ── NAV CLEAR BTN ── */
.nav-clear {
  background: none;
  border: 1px solid var(--border2);
  border-radius: 6px;
  color: var(--text2);
  font-family: var(--font);
  font-size: 11px;
  padding: 4px 12px;
  height: auto;
  border-bottom: 1px solid var(--border2);
  cursor: pointer;
  transition: color .13s, background .13s;
}
.nav-clear:hover { background: var(--bg3); color: var(--text); }

/* ── TEMTEM GRID ── */
.temtem-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-bottom: 1rem;
}
.temtem-card {
  width: 100px;
  flex-shrink: 0;
  background: var(--bg3);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: border-color .18s, transform .18s, opacity .2s, filter .2s;
}
.temtem-card:hover { border-color: var(--border2); transform: translateY(-3px); }
.temtem-card.filtered { opacity: .1; filter: grayscale(.9); pointer-events: none; }
.temtem-card.active-sel {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(124,111,224,.25);
}
.tem-img-wrap {
  position: relative;
  background: var(--bg3);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  overflow: hidden;
}
.tem-img-wrap img {
  width: 100%;
  max-width: 84px;
  object-fit: contain;
  padding: 8px 8px 28px;
}
.tem-name {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 5px 8px;
  background: rgba(10,10,20,0.75);
  font-family: var(--font-alt);
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
  text-transform: capitalize;
  letter-spacing: .5px;
  backdrop-filter: blur(4px);
}

/* ── FILTERS ZONE ── */
.filters-zone {
  display: flex;
  justify-content: center;
  margin-bottom: 1.4rem;
}

/* Grille 2 lignes de 6 = 12 types, centrée */
.type-filter-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
}

/* ── SELECTED TYPES DISPLAY ── */

/* Card conteneur */
.selected-types-display {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 16px;
  padding: 4px;
  margin-top: 0;
  height: 98vh;
  display: flex;
  flex-direction: column;
}
.selected-types-display .types-layout {
  flex: 1;
  min-height: 0;
}

/*
  Layout CSS grid :
  - col gauche (55%) : neutre, span toute la hauteur
  - col droite (45%) : type2 haut, type3 bas, hauteurs égales
*/
.types-layout {
  display: grid;
  grid-template-columns: 55fr 45fr;
  grid-template-rows: 1fr 1fr;
  gap: 2px;
  column-gap: 2px;
  width: 100%;
}

/* Neutre : occupe les 2 lignes à gauche */
.type-card.is-neutre {
  grid-column: 1;
  grid-row: 1 / 3;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.type-card.is-neutre img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 0;
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--tc) 30%, transparent));
}

/* Conteneur secondaires : occupe col droite, span toute la hauteur */
.types-secondary {
  grid-column: 2;
  grid-row: 1 / 3;
  display: grid;
  grid-template-rows: 1fr 1fr; /* défaut 2 lignes */
  gap: 2px;
  align-items: stretch;
  height: 100%;
}
/* 1 seul secondaire */
.types-secondary[data-count="1"] { grid-template-rows: 1fr; }
/* 2 secondaires */
.types-secondary[data-count="2"] { grid-template-rows: 1fr 1fr; }
/* 3 secondaires */
.types-secondary[data-count="3"] { grid-template-rows: 1fr 1fr 1fr; }
/* 4 secondaires : 2 colonnes × 2 lignes, toutes cellules identiques */
.types-secondary[data-count="4"] {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-auto-rows: 1fr;
}
/* Force toutes les cellules à la même hauteur */
.types-secondary[data-count="4"] .type-card.is-secondary {
  height: 100%;
}

/* Secondaires : toutes les cellules font exactement la même taille */
.type-card.is-secondary {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 0;
  min-width: 0;
  overflow: hidden;
}
.type-card.is-secondary img {
  flex: 1;
  min-height: 0;
  min-width: 0;
  width: 100%;
  height: 0; /* force via flex */
  object-fit: contain;
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--tc) 30%, transparent));
}

/* SOLO (aucun neutre) : tous en ligne, même taille */
.types-layout.solo-layout {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}
.type-card.is-solo {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  min-width: 200px;
  max-width: 400px;
}
.type-card.is-solo img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 0 12px color-mix(in srgb, var(--tc) 35%, transparent));
}

/* Label commun */
.type-card-label {
  font-family: var(--font-alt);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .6px;
  color: color-mix(in srgb, var(--tc) 95%, white);
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 2px;
  width: 100%;
}

/* Carte générique */
.type-card {
  animation: pop-in .18s ease;
}

@keyframes pop-in {
  from { transform: scale(.75); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}

.type-img-btn {
  background: var(--bg3);
  border: 1.5px solid transparent;
  border-radius: 8px;
  padding: 6px 4px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color .15s, background .15s, transform .12s;
}
.type-img-btn span {
  font-family: var(--font-alt);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .3px;
  color: var(--tc);
  white-space: nowrap;
}
.type-img-btn:hover:not(.selected) {
  background: var(--bg4);
  border-color: color-mix(in srgb, var(--tc) 40%, transparent);
  transform: scale(1.04);
}
.type-img-btn.selected {
  background: color-mix(in srgb, var(--tc) 16%, var(--bg3));
  border-color: var(--tc);
  box-shadow: 0 0 8px color-mix(in srgb, var(--tc) 35%, transparent);
}

/* ── PARAMS PAGE ── */
.params-wrap { max-width: 680px; }
.params-wrap h2 {
  font-family: var(--font-alt);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: .5px;
  margin-bottom: 1rem;
}
.param-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  margin-bottom: 7px;
  overflow: hidden;
  transition: border-color .15s;
}
.param-card.open { border-color: var(--border2); }
.param-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  cursor: pointer;
  user-select: none;
  transition: background .12s;
}
.param-header:hover { background: var(--bg3); }
.param-thumb {
  width: 42px; height: 42px;
  object-fit: contain;
  border-radius: 8px;
  background: var(--bg3);
  padding: 4px;
  flex-shrink: 0;
}
.param-name {
  font-family: var(--font-alt);
  font-size: 14px;
  font-weight: 600;
  text-transform: capitalize;
  letter-spacing: .4px;
  flex: 1;
}
.param-badges { display: flex; gap: 3px; flex-wrap: wrap; }
.chevron {
  width: 15px; height: 15px;
  stroke: var(--text2);
  flex-shrink: 0;
  transition: transform .2s;
}
.param-card.open .chevron { transform: rotate(180deg); }
.param-body {
  display: none;
  padding: 12px 14px 14px;
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg3) 60%, transparent);
}
.param-card.open .param-body { display: block; }
.sub-label {
  font-family: var(--font-alt);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
  margin-bottom: 8px;
}
.param-types-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 12px;
}
.param-toggle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px 5px 6px;
  border-radius: 20px;
  border: 1.5px solid var(--border2);
  background: var(--bg4);
  color: var(--text2);
  font-family: var(--font);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all .14s;
}
.param-toggle img { width: 16px; height: 16px; object-fit: contain; }
.param-toggle.active {
  background: color-mix(in srgb, var(--tc) 18%, var(--bg3));
  border-color: var(--tc);
  color: color-mix(in srgb, var(--tc) 90%, white);
}
.param-toggle:hover:not(.active) { background: var(--bg3); color: var(--text); }
.save-row { display: flex; align-items: center; gap: 10px; }
.save-btn {
  padding: 7px 20px;
  border-radius: 8px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-family: var(--font);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, transform .1s;
}
.save-btn:hover { background: #6a5dd4; }
.save-btn:active { transform: scale(.97); }
.save-ok { font-size: 12px; opacity: 0; transition: opacity .3s; }
.save-ok.show { opacity: 1; }

.type-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 7px 2px 3px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 600;
  font-family: var(--font-alt);
  letter-spacing: .3px;
  background: color-mix(in srgb, var(--tc) 18%, var(--bg3));
  border: 1px solid color-mix(in srgb, var(--tc) 38%, transparent);
  color: color-mix(in srgb, var(--tc) 90%, white);
}
.type-badge img { width: 12px; height: 12px; object-fit: contain; }

.state-msg { padding: 2rem; text-align: center; color: var(--text2); font-size: 13px; }
.state-msg.error { color: #e86262; }

@media (max-width: 500px) {
  .type-filter-grid { grid-template-columns: repeat(6, 1fr); max-width: 100%; }
}
