/* ===============================
   Base
   =============================== */
:root{
  --bg:#0f1115;
  --panel:#151922;
  --panel2:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.10);
  --text:#e8eef5;
  --muted:rgba(232,238,245,.70);
  --accent:#9f9;
  --danger:#ff6b6b;

  --topbar-h:0px;
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --pad:16px;
  --gap:12px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font);
}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ===============================
   Header commun
   =============================== */
.topbar{
  position:fixed;
  top:0;left:0;right:0;
  height:var(--topbar-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--gap);
  padding:0 var(--pad);
  background:rgba(20,20,20,.90);
  border-bottom:1px solid var(--border);
  backdrop-filter: blur(8px);
  z-index:1000;
}
.brand{
  color:var(--text);
  font-weight:800;
  letter-spacing:.2px;
}
.topbar__nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.navlink{
  color:var(--text);
  opacity:.9;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid transparent;
}
.navlink:hover{
  background:rgba(255,255,255,.08);
  text-decoration:none;
}
.navlink[aria-current="page"]{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.10);
}

/* ===============================
   Layout
   =============================== */
main{padding-top:var(--topbar-h)}
.page{
  max-width:1100px;
  margin:0 auto;
  padding:18px var(--pad);
}
.panel{
  background:var(--panel2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  box-shadow:var(--shadow);
  margin-bottom:14px;
}
.row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.muted{color:var(--muted)}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

/* ===============================
   Form controls
   =============================== */
input, select, textarea, button{
  font:inherit;
}
input, select, textarea{
  background:rgba(0,0,0,.35);
  color:var(--text);
  border:1px solid rgba(255,255,255,.14);
  border-radius:10px;
  padding:10px 10px;
  outline:none;
}
input:focus, select:focus, textarea:focus{
  border-color:rgba(160,255,160,.55);
  box-shadow:0 0 0 3px rgba(160,255,160,.10);
}
label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
label > input, label > select, label > textarea{min-width:180px}

.btn, button{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:var(--text);
  padding:10px 12px;
  border-radius:10px;
  cursor:pointer;
}
.btn:hover, button:hover{background:rgba(255,255,255,.12)}
.btn--danger{
  border-color:rgba(255,80,80,.35);
}
.btn--danger:hover{
  background:rgba(255,80,80,.15);
}

/* ===============================
   Tables (admin)
   =============================== */
.table{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.trow{
  display:grid;
  grid-template-columns: 2.2fr .9fr 1.1fr 1fr 1fr .6fr .8fr;
  gap:10px;
  align-items:center;
  padding:10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  background:rgba(0,0,0,.25);
  overflow:hidden;
}
.trow.thead{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.14);
  font-weight:700;
}
.trow button{padding:8px 10px}

/* Responsive admin */
@media (max-width: 980px){
  .trow{grid-template-columns: 1.6fr 1fr 1fr .9fr .9fr .7fr .9fr}
}
@media (max-width: 720px){
  .trow{grid-template-columns: 1fr 1fr; row-gap:8px}
  .trow.thead{display:none}
}

/* ===============================
   Choose Hero (gardé + harmonisé)
   =============================== */
.page-choose-hero {
  background: transparent;
  color: var(--text);
}
.page-choose-hero .container {
  max-width: 1000px;
  margin: 0 auto;
  padding: 24px;
}
.page-choose-hero .hint { color: var(--muted); }
.page-choose-hero .error { color: #ff9a9a; min-height: 20px; margin-bottom: 12px; }

.hero-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.hero-card {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  border-radius: 14px;
  padding: 14px;
  cursor: pointer;
  transition: transform .15s ease, background .15s ease;
}
.hero-card:hover {
  background: rgba(255,255,255,.12);
  transform: translateY(-2px);
}
.hero-portrait {
  height: 160px;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 10px;
}
.hero-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 14px;
  opacity: .95;
}
.hero-meta small { opacity: .8; }

/* ===============================
   Canvas pages
   =============================== */
.canvas-full{
  position:fixed;
  top:var(--topbar-h);
  left:0;right:0;bottom:0;
}
.canvas-full canvas{
  width:100%;
  height:100%;
  display:block;
}
/* ===============================
   Admin 2 colonnes
   =============================== */
.admin-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:14px;
  align-items:start;
}
.admin-col{
  min-width:0;
}
@media (max-width: 980px){
  .admin-grid{ grid-template-columns: 1fr; }
}

/* Table admin: grille plus compacte pour list */
.table .trow{
  grid-template-columns: 1.9fr .9fr 1.1fr 1fr .9fr .6fr;
}
.table .trow .actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
}
