:root{
  --bg:#121212; --panel:#1e1e1e; --text:#eee; --muted:#aaa; --line:#444;
  --ok:#00c853; --warn:#ffd600; --orange:#ff9100; --err:#ff1744; --active:#00e676;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  padding: 2rem 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

.panel {
  background: var(--panel);
  border-radius: 12px;
  box-shadow: 0 0 10px rgba(0,0,0,.5);
  padding: 1rem;
  width: 100%;
  max-width: 980px;
}

h1, h2 { margin: 0 0 .75rem 0; }
.centered { text-align: center; }



select, input[type="text"] {
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background:#2a2a2a;
  color: var(--text);
}

.chips { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.75rem; }
.chips label { display:flex; align-items:center; gap:.3rem; }

button {
  padding: 8px 12px;
  border: none;
  border-radius: 8px;
  background-color: #444;
  color: #fff;
  cursor: pointer;
}
button:disabled { background-color: #222; color: #777; cursor: not-allowed; }

.muted { color: var(--muted); }
.page-title { width:100%; text-align:center; margin: .25rem 0 0 0; }

/* --- Title + radios --- */
.page-title {
  width:100%;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:.75rem;
  text-align:center;
  margin:.25rem 0 0 0;
}

.title-toggle {
  display:flex;
  align-items:center;
  gap:.5rem;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 9999px;
  padding: .4rem .8rem;
  font-size: 1.1rem;
  color: var(--text);
  cursor: pointer;
}
.title-toggle .chevron { transform: translateY(1px); transition: transform .2s ease; }
.title-toggle[aria-expanded="false"] .chevron { transform: rotate(-90deg) translateY(-1px); }

.radio-group {
  display:flex;
  gap: .75rem;
  border: none;
  margin: 0;
  padding: 0;
}
.radio-group label {
  display:flex;
  align-items:center;
  gap:.35rem;
  background:#1a1a1a;
  border:1px solid var(--line);
  border-radius:9999px;
  padding:.35rem .7rem;
  user-select:none;
}
.radio-group input[type="radio"] { accent-color: var(--active); }

/* --- Collapsible panel --- */
.collapsible {
  width:100%;
  overflow: hidden;
  transition: max-height .28s ease;
  will-change: max-height;
  max-height: 9999px; /* open állapot */
}
.collapsible:not(.open) { max-height: 0; }


/* ===== Dashboard kiegészítések – nem írunk felül meglévőt ===== */

/* konténer az oldaltörzsnek (dashboard.html) */
.wrap {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

/* egyszerű sor-utility */
.row {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  align-items: center;
}
.row.between { justify-content: space-between; }

/* kártya-panel Chartokhoz és vezérlőkhöz */
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 1rem;
  margin: .75rem 0;
  box-shadow: 0 1px 0 rgba(0,0,0,.25);
}

/* apró jelvények */
.chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  background: #1a1a1a;
  border: 1px solid var(--line);
  border-radius: 9999px;
  padding: .25rem .6rem;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.chip.ok    { border-color: var(--ok);    }
.chip.warn  { border-color: var(--warn);  }
.chip.err   { border-color: var(--err);   }
.chip.muted { color: var(--muted); border-color: #333; }

a.chip { text-decoration: none; }

/* bemenetek a sötét témához (egységes stílus) */
select, input[type="text"], button {
  background:#1a1a1a;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .45rem .6rem;
}
button { cursor: pointer; }
button:hover { filter: brightness(1.05); }
button:disabled { opacity:.6; cursor: not-allowed; }

/* grafikonok mérete */
canvas { width: 100%; height: 320px; }

/* halvány szöveg egységesen */
.muted { color: var(--muted); }

/* rácsvonalak a Chart.js-hez (ha custom plugin használja a változókat) */
:root {
  --grid: rgba(255,255,255,0.08);
}

/* host-grid az indexhez vagy jövőbeli listanézethez */
.host-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: .9rem;
}


/* flatpickr dark + altInput igazítás */
.flatpickr-calendar {
  background: #1e1e1e; border-color: var(--line);
}
.flatpickr-day.inRange,
.flatpickr-day.selected {
  background: #2a2a2a; border-color: var(--active);
}
.flatpickr-time input,
.flatpickr-time .flatpickr-time-separator {
  color: var(--text);
}
.flatpickr-monthDropdown-months,
.numInput { color: var(--text); }

/* altInput kinézet az app inputjaival egységesen */
input.flatpickr-input,
input.flatpickr-input[readonly].altInput {
  background:#2a2a2a; color:var(--text);
  border:1px solid var(--line); border-radius:8px;
  padding:6px 8px; height:auto;
}

