/* TRC2 Portal — stile web minimale (dark, coerente coi token del viewer ma SEMPLICE).
   La rifinitura grafica è un'altra cosa: qui basta che sia leggibile e ordinato. */
:root {
  --bg: #0B0E17; --surface: #11151F; --raised: #1D2331; --inset: #0A0D15;
  --border: #ffffff20; --text0: #EEF1F8; --text1: #A7AFC2; --text2: #6A7388;
  --accent: #3B82F6; --accent2: #6EA8FF; --online: #34D399; --danger: #F87171;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--text0);
  font-family: -apple-system, "Segoe UI", Inter, system-ui, sans-serif; font-size: 14px;
}
.muted { color: var(--text2); }
a { color: var(--accent2); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px; background: #070910; border-bottom: 1px solid var(--border);
}
.brand { font-weight: 700; font-size: 18px; color: var(--text0); }
.brand .badge {
  display: inline-block; background: var(--accent); color: #fff; border-radius: 6px;
  padding: 0 7px; margin-left: 2px;
}
nav { display: flex; align-items: center; gap: 16px; }
nav .inline { display: inline; margin: 0; }
button.link { background: none; border: 0; color: var(--text1); cursor: pointer; font: inherit; }

main { max-width: 920px; margin: 28px auto; padding: 0 20px; }
footer { max-width: 920px; margin: 40px auto; padding: 0 20px; font-size: 12px; }

.card {
  background: var(--surface); border: 1px solid var(--border); border-radius: 14px;
  padding: 22px; margin-bottom: 18px;
}
h1 { font-size: 22px; margin: 0 0 6px; }
h2 { font-size: 17px; margin: 0 0 14px; }

.actions { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.btn {
  display: inline-block; padding: 10px 16px; border-radius: 10px; cursor: pointer;
  background: var(--raised); color: var(--text0); border: 1px solid var(--border);
  font-weight: 600; font-size: 13.5px;
}
.btn.primary { background: var(--accent); color: #fff; border: 0; }
.btn.danger { background: #F8717129; color: var(--danger); border: 0; }
.btn:hover { text-decoration: none; filter: brightness(1.08); }

label { display: block; margin: 12px 0 4px; color: var(--text1); font-size: 12.5px; }
input[type=text], input[type=password], input[type=email], textarea, select {
  width: 100%; padding: 10px 12px; border-radius: 10px; background: var(--inset);
  border: 1px solid var(--border); color: var(--text0); font: inherit;
}
input:focus, textarea:focus, select:focus { outline: none; border-color: #3B82F661; }
.row { display: flex; gap: 14px; flex-wrap: wrap; }
.row > div { flex: 1; min-width: 200px; }

.err { background: #F8717129; color: var(--danger); padding: 10px 12px; border-radius: 10px; margin: 10px 0; }
.ok  { background: #34D39929; color: var(--online); padding: 10px 12px; border-radius: 10px; margin: 10px 0; }

table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--border); }
th { color: var(--text2); font-size: 12px; font-weight: 600; }
code, .mono { font-family: "Cascadia Code", Menlo, Consolas, monospace; }
.pill { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 11px; background: var(--raised); color: var(--text1); }
.pill.on { background: #34D39929; color: var(--online); }
