/* ================================
   Multi-Tracker - app.css
   -> Design repris de styles.css (fond + glass + badges)
   -> Conserve les classes de ta V2 (.app/.topbar/.card/.panel/.row…)
   ================================ */

/* ---------- Theme tokens (from styles.css + compat) ---------- */
:root{
  --bg0:#070A12;
  --bg1:#0B1020;

  --text:#EAF0FF;
  --muted:rgba(234,240,255,.65);

  --border:rgba(255,255,255,.10);

  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);

  --good:#35E3A1;
  --bad:#FF6B8A;
  --neutral:#FBBF24;

  --accent:#38bdf8;   /* cyan */
  --accent2:#6366f1;  /* indigo */

  --shadow: 0 30px 90px rgba(0,0,0,.55);
  --shadow2: 0 14px 40px rgba(0,0,0,.35);

  --rApp: 22px;   /* compat */
  --rCard: 16px;  /* compat */
}

/* ---------- Global reset ---------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  min-height:100vh;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);

  display:grid;
  place-items:center;
  padding: 26px;

  /* ✅ IMAGE DE FOND */
  background-image: url("../images/background/background.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

/* liens neutres */
a, a:visited{ color: inherit; text-decoration:none; }
.hidden{ display:none; }
.muted{ color: var(--muted); }

/* ---------- App shell (ex .card de styles.css -> ici .app) ---------- */
.app{
  width: min(1100px, 96vw);
  min-height: 78vh;

  border-radius: var(--rApp);
  border: 1px solid var(--border);

  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  box-shadow: var(--shadow);

  padding: 18px;
  position: relative;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  display:flex;
  flex-direction:column;
  overflow:hidden;
}

/* Petit glow discret */
.app::before{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  background:
    radial-gradient(500px 160px at 20% 0%, rgba(56,189,248,.14), transparent 60%),
    radial-gradient(520px 170px at 80% 0%, rgba(99,102,241,.12), transparent 60%),
    radial-gradient(500px 170px at 50% 100%, rgba(34,197,94,.10), transparent 60%);
  opacity:.9;
}
.app > *{ position:relative; z-index:1; }

/* ---------- Topbar ---------- */
.topbar{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;

  position: sticky;
  top: 0;
  z-index: 10;

  padding: 16px 16px 14px;
  margin: -18px -18px 10px;

  background: transparent;
  border: none;
  box-shadow: none;

  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}



.topbar--actions{
  display:flex;
  align-items:center;
  gap: 12px;
}

.topbar__center{ flex:1; min-width:0; text-align:center; }

.topbar__title{
  margin:0;
  font-size: 30px;
  font-weight: 900;
  letter-spacing: -.02em;
  line-height: 1.1;
  text-align: center;

  /* Texte en dégradé comme styles.css */
  background: linear-gradient(90deg, #eaf0ff, rgba(56,189,248,.95), rgba(99,102,241,.95));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.topbar__subtitle{
  margin-top: 6px;
  font-size: 13px;
  color: rgba(234,240,255,.70);
}

/* boutons icônes (back / refresh) */
.iconbtn{
  width: 42px;
  height: 42px;
  border-radius: 999px;

  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: var(--text);

  cursor:pointer;
  font-size: 18px;

  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  transition: transform .12s ease, border-color .2s ease, background .2s ease;
}
.iconbtn:hover{
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.10);
  transform: translateY(-1px);
}
.iconbtn:active{ transform: translateY(0); }

/* ---------- Content ---------- */
.content{ flex:1; padding: 4px 2px 2px; }

/* ---------- Home grid ---------- */
.grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
  margin-top: 14px;
}

/* ---------- Cards (home) -> style “btn gaming” de styles.css ---------- */
.card{
  position: relative;
  overflow: hidden;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;

  padding: 14px 14px;
  border-radius: 18px;

  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow2);

  transition: transform .12s ease, border-color .2s ease, background .2s ease;
}
.card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(400px 120px at 30% 10%, rgba(56,189,248,.14), transparent 60%),
    radial-gradient(360px 130px at 80% 20%, rgba(34,197,94,.10), transparent 60%),
    radial-gradient(400px 140px at 50% 90%, rgba(99,102,241,.10), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.card > *{ position:relative; z-index:1; }

.card--tap{ cursor:pointer; }
.card--tap:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
}
.card--tap:active{ transform: translateY(0); }

.avatar{
  width: 46px;
  height: 46px;
  border-radius: 14px;

  display:flex;
  align-items:center;
  justify-content:center;

  font-weight: 900;
  letter-spacing: .2px;

  background: radial-gradient(circle at 30% 25%, rgba(99,102,241,.35), rgba(56,189,248,.18));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  flex: 0 0 auto;
}

.card__text{ flex:1; min-width:0; }
.card__title{
  font-weight: 900;
  letter-spacing: -.01em;

  background: linear-gradient(90deg, rgba(234,240,255,1), rgba(56,189,248,.95));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}
.card__meta{
  margin-top: 4px;
  color: rgba(234,240,255,.55);
  font-size: 12px;
}
.chev{
  opacity: .85;
  font-weight: 900;
  color: rgba(56,189,248,.95);
  font-size: 20px;
  padding-left: 4px;
}

/* ---------- Panels (profile) ---------- */
.panel{
  margin-top: 18px;
  padding: 16px;
  border-radius: var(--rCard);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
  box-shadow: var(--shadow2);
}

.panel__title{
  margin: 0 0 12px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: -.01em;
  color: rgba(234,240,255,.92);
  text-align: center;
}

/* ---------- List rows (profile stats) ---------- */
.list{
  display:grid;
  gap: 10px;
}

.row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;

  padding: 12px 12px;
  border-radius: var(--rCard);

  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));

  transition: transform .12s ease, border-color .2s ease, background .2s ease;
}
.row:hover{
  border-color: rgba(255,255,255,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  transform: translateY(-1px);
}
.row:active{ transform: translateY(0); }

.row__left{ min-width:0; }
.row__title{
  font-weight: 900;
  letter-spacing: .15px;

  display:flex;
  align-items:center;
  gap: 10px;
}
.row__sub{
  color: var(--muted);
  font-size: 13px;
  margin-top: 4px;
}
.row__right{ text-align:right; }
.row__value{
  font-weight: 900;
  letter-spacing: .2px;
}

/* badges / pills */
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 7px 10px;
  border-radius: 999px;

  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);

  color: rgba(234,240,255,.85);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .02em;
}

.badge-blue{
  border-color: rgba(56,189,248,.35);
  box-shadow: 0 0 0 1px rgba(56,189,248,.10) inset;
}
.badge-green{
  border-color: rgba(34,197,94,.35);
  box-shadow: 0 0 0 1px rgba(34,197,94,.10) inset;
}
.badge-gold{
  border-color: rgba(251,191,36,.35);
  box-shadow: 0 0 0 1px rgba(251,191,36,.10) inset;
}

.good{ color: var(--good); font-weight: 800; }
.bad{ color: var(--bad); font-weight: 800; }
.neutral{ color: var(--neutral); font-weight: 800; }

/* ---------- Notes / status ---------- */
.note{
  margin-top: 14px;
  padding: 14px;
  border: 1px dashed rgba(148,163,184,.25);
  border-radius: var(--rCard);
  color: rgba(229,231,235,.92);
  background: rgba(255,255,255,.015);
}
.note__title{ font-weight: 900; margin-bottom: 6px; }
.note__text{ color: var(--muted); font-size: 13px; line-height: 1.45; }

.status{
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 14px;

  border: 1px solid rgba(255,255,255,.10);
  color: var(--text);
  background: rgba(255,255,255,.02);
}
.status--error{
  border-color: rgba(255,107,138,.35);
  background: rgba(255,107,138,.10);
  color: #ffd0da;
}
.status--info{
  border-color: rgba(56,189,248,.35);
  background: rgba(56,189,248,.10);
}

/* ---------- Game icons / Rank icons ---------- */
.game-icon{
  width: 28px;
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;
}

.rankline{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.rank-icon{
  width: 26px;
  height: 26px;
  object-fit: contain;
  flex-shrink: 0;
}
.rank-icon--lol{ width: 26px; height: 26px; }
.rank-icon--rl{ width: 26px; height: 26px; }

/* ---------- Match page: Scoreboard (conservé de styles.css) ---------- */
.scoreboard{ display: grid; gap: 14px; }
@media (min-width: 880px){
  .scoreboard{ grid-template-columns: 1fr 1fr; gap: 18px; }
}
.team-col{
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
  border-radius: var(--rCard);
  padding: 12px;
}
.team-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 10px;
}
.team-title{ font-weight: 800; letter-spacing: -.01em; }
.team-result{ font-weight: 900; }

.sb-table{ display:grid; gap: 6px; }

.sb-row{
  display:grid;
  grid-template-columns: 1fr 86px 56px 76px;
  align-items:center;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}
.sb-header{
  background: rgba(255,255,255,.00);
  border-color: rgba(255,255,255,.00);
  padding: 0 2px 6px;
  font-size: 12px;
  color: rgba(234,240,255,.55);
}
.sb-player{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.sb-name{ min-width:0; }
.sb-summ{
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-champ{ font-size: 12px; line-height: 1.1; }
.sb-kda, .sb-cs, .sb-dmg{
  text-align:right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.sb-me{
  border-color: rgba(56,189,248,.35);
  box-shadow: 0 0 0 1px rgba(56,189,248,.10) inset;
}

/* Avatar image (Discord) */
.avatar--img{
  display:block;
  object-fit: cover;      /* remplit proprement */
  object-position: center;
  border-radius: 14px;    /* same shape as current */
}

@media (max-width: 520px){
  html, body{
    height: 100%;
    overflow: hidden; /* pas de scroll page */
  }

  body{
    padding: 0;
  }

  .app{
    width: 100vw;
    height: 100dvh;     /* 100dvh plutôt que 90dvh */
    border-radius: 0;
    overflow: hidden;   /* on garde le glass */
    display: flex;
    flex-direction: column;
  }

  /* Topbar : respirer + pas collé aux bords */
  .topbar{
    margin: 0 0 14px;
    padding: 14px 14px;
  }

  .content{
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch; /* scroll iOS fluide */
    padding: 10px 10px 16px;           /* un peu d’air */
  }

  /* Panel stats : plus aéré + moins “emboîté” */
  .panel{
    margin-top: 0;
    padding: 18px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  }

  .panel__title{
    margin-bottom: 14px;
    font-size: 18px;
  }

  /* Espacement entre les cartes */
  .list{
    gap: 14px;
  }

  /* Cartes de stats : plus grandes, moins compactes */
  .row{
    padding: 16px 16px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025));
  }

  .row__title{
    gap: 12px;
    font-size: 18px;
  }

  .row__sub{
    margin-top: 6px;
    font-size: 14px;
  }

  .row__value{
    font-size: 18px;
  }

  .game-icon{
    width: 32px;
    height: 32px;
  }

  .badge{
    padding: 8px 12px;
    font-size: 12px;
  }
  /* (optionnel) évite que la grille colle en bas */
  .grid{
    margin-top: 14px;
    padding-bottom: 14px;
  }
}
