/* Feuille de style — Classement des planetes SG-Return */
/* Extraite de index.html ; chargee via <link rel="stylesheet" href="style.css"> */

:root { color-scheme: dark; }
body { margin: 0; }
.sgr-app {
  /* Alias locaux : on respecte les tokens de l'hôte si présents, sinon thème sombre/spatial autonome */
  --bg:      var(--color-background-primary,   #0b0f17);
  --panel:   var(--color-background-secondary, #141a24);
  --panel-2: var(--color-background-tertiary,  #1b2330);
  --border:  var(--color-border-primary,       #2a3342);
  --border-2:var(--color-border-secondary,     #20283400);
  --border-3:var(--color-border-tertiary,      #222b38);
  --text:    var(--color-text-primary,         #e6edf3);
  --text-2:  var(--color-text-secondary,       #9aa6b6);
  --text-3:  var(--color-text-tertiary,        #6b7686);
  --radius:  var(--border-radius-md, 12px);
  --accent:  #7F77DD;

  box-sizing: border-box;
  min-height: 100vh;
  padding: 22px clamp(14px, 4vw, 34px) 40px;
  background:
    radial-gradient(1200px 600px at 12% -8%, #7F77DD18, transparent 60%),
    radial-gradient(900px 500px at 100% 0%, #378ADD14, transparent 55%),
    var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.45;
}
.sgr-app *, .sgr-app *::before, .sgr-app *::after { box-sizing: border-box; }
.wrap { max-width: 1440px; margin: 0 auto; }

/* ---- En-tête ---- */
.head { margin-bottom: 18px; }
.title h1 { margin: 0; font-size: clamp(19px, 2.4vw, 25px); font-weight: 650; letter-spacing: -0.01em; }
.title p { margin: 4px 0 0; color: var(--text-3); font-size: 12.5px; }
.title .dot { color: var(--accent); }

.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin-bottom: 18px; }
.stat { background: linear-gradient(180deg, var(--panel-2), var(--panel)); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 12px; min-width: 0; }
.stat .k { font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--text-3); display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.stat .k i { width: 8px; height: 8px; border-radius: 2px; flex: none; }
.stat .v { font-size: 20px; font-weight: 700; margin-top: 2px; line-height: 1.1; white-space: nowrap; }
.stat .s { font-size: 11px; color: var(--text-2); margin-top: 1px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---- Navigation par vues ---- */
.view-tabs { display: inline-flex; gap: 4px; padding: 4px; background: var(--panel); border: 1px solid var(--border); border-radius: 999px; margin-bottom: 16px; flex-wrap: wrap; }
.view-tab { appearance: none; border: 0; background: transparent; color: var(--text-2); font: inherit; font-size: 13px; font-weight: 550; padding: 7px 15px; border-radius: 999px; cursor: pointer; transition: background .15s, color .15s; white-space: nowrap; }
.view-tab:hover { color: var(--text); }
.view-tab.active { background: var(--accent); color: #fff; box-shadow: 0 2px 10px #7F77DD55; }

/* ---- Cartes / panneaux ---- */
.card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px clamp(12px,2vw,20px); margin-bottom: 16px; }
.card h2 { margin: 0 0 2px; font-size: 15px; font-weight: 620; }
.card .hint { margin: 0 0 14px; color: var(--text-3); font-size: 12px; }

.view { display: none; animation: fade .25s ease; }
.view.active { display: block; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* ---- Contrôles ---- */
.controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.seg { display: inline-flex; gap: 3px; padding: 3px; background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; flex-wrap: wrap; }
.seg button { appearance: none; border: 0; background: transparent; color: var(--text-2); font: inherit; font-size: 12.5px; padding: 6px 12px; border-radius: 7px; cursor: pointer; transition: background .12s, color .12s; }
.seg button:hover { color: var(--text); }
.seg button.active { background: var(--panel); color: var(--text); font-weight: 600; box-shadow: inset 0 0 0 1px var(--border); }
.seg button.active .swatch { box-shadow: 0 0 0 2px #fff3; }
.swatch { display: inline-block; width: 9px; height: 9px; border-radius: 3px; margin-right: 6px; vertical-align: -1px; }

.toggle { margin-left: auto; display: inline-flex; align-items: center; gap: 7px; color: var(--text-2); font-size: 12.5px; cursor: pointer; user-select: none; }
.toggle input { accent-color: var(--accent); width: 15px; height: 15px; }

select.picker { appearance: none; background: var(--panel-2); color: var(--text); border: 1px solid var(--border); border-radius: 9px; padding: 7px 30px 7px 11px; font: inherit; font-size: 12.5px; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%239aa6b6' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 11px center; }
label.lbl { font-size: 12.5px; color: var(--text-2); }

/* ---- Légende régions ---- */
.legend { display: flex; flex-wrap: wrap; gap: 6px 14px; margin: 2px 0 14px; }
.legend .it { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-2); cursor: default; }
.legend .it i { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }

/* ---- Chips (tri & radar) ---- */
.chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 6px 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 550; background: var(--panel-2); border: 1px solid var(--border); }
.chip i { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.chip button { appearance: none; border: 0; background: transparent; color: var(--text-3); cursor: pointer; font-size: 13px; line-height: 1; padding: 3px 4px; border-radius: 6px; transition: color .12s, background .12s; }
.chip button:hover { color: var(--text); background: var(--panel); }
.chip button:disabled { opacity: .25; cursor: default; background: none; }
.chip button[data-act="dir"] { font-size: 11px; font-weight: 600; color: var(--text-2); }

/* ---- Conteneurs canvas ---- */
.chart-box { position: relative; width: 100%; }
.chart-scroll { max-height: 70vh; overflow-y: auto; }
.grid-2 { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 860px) { .grid-2 { grid-template-columns: 1.1fr 1fr; } }

/* ---- Tableau : toutes les planètes ---- */
.tbl-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.search { position: relative; flex: 1 1 220px; min-width: 180px; }
.search input { width: 100%; background: var(--panel-2); color: var(--text); border: 1px solid var(--border); border-radius: 9px; padding: 8px 30px 8px 32px; font: inherit; font-size: 13px; }
.search input::placeholder { color: var(--text-3); }
.search input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px #7F77DD33; }
.search .ico { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--text-3); pointer-events: none; display: flex; }
.search .clear { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; color: var(--text-3); cursor: pointer; font-size: 16px; line-height: 1; padding: 0 2px; display: none; }
.search .clear:hover { color: var(--text); }
.tbl-count { color: var(--text-3); font-size: 12px; white-space: nowrap; }

.tbl-scroll { max-height: 68vh; overflow: auto; border: 1px solid var(--border); border-radius: var(--radius); }
table.ptbl { width: 100%; border-collapse: collapse; font-size: 12.5px; }
table.ptbl th, table.ptbl td { padding: 8px 10px; text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
table.ptbl th:first-child, table.ptbl td:first-child,
table.ptbl th.txt, table.ptbl td.txt { text-align: left; }
table.ptbl thead th { position: sticky; top: 0; z-index: 1; background: var(--panel-2); color: var(--text-2); font-weight: 600; cursor: pointer; user-select: none; border-bottom: 1px solid var(--border); }
table.ptbl thead th:hover { color: var(--text); }
table.ptbl thead th .arr { color: var(--accent); font-size: 10px; margin-left: 3px; }
table.ptbl tbody tr { border-bottom: 1px solid var(--border-3); }
table.ptbl tbody tr:hover { background: var(--panel-2); }
table.ptbl tbody tr:last-child { border-bottom: 0; }
table.ptbl td.coord { font-weight: 600; }
table.ptbl .pos { color: #6fcf97; } table.ptbl .neg { color: #eb7b6f; } table.ptbl .zero { color: var(--text-3); }
table.ptbl .owner { color: var(--text); } table.ptbl .empty { color: var(--text-3); font-style: italic; }
table.ptbl .bld { color: var(--accent); }
.tbl-empty { padding: 26px; text-align: center; color: var(--text-3); font-size: 13px; }

.banner { display: none; background: #E74C3C18; border: 1px solid #E74C3C66; color: #f3b6ad; padding: 14px 16px; border-radius: var(--radius); margin-bottom: 16px; font-size: 13px; }
.foot { color: var(--text-3); font-size: 11.5px; margin-top: 18px; text-align: center; }
