@import url('https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:ital,wght@0,400;0,700;1,400;1,700&display=swap');
@import url('https://cdn.jsdelivr.net/npm/open-dyslexic@latest/open-dyslexic-regular.css');

/* ── Alap ──────────────────────────────────────────────────────────────────── */
body {
  font-family: Arial, sans-serif;
  background: #f0f4f8;
  color: #111827;
  margin: 0;
  font-size: 18px;
}
.doboz {
  max-width: 900px;
  margin: 0 auto;
  padding: 24px;
}
.fejlec {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #1e3a5f;
  color: white;
  padding: 16px 20px;
  border-radius: 12px;
  margin-bottom: 20px;
}
.kartya {
  background: white;
  border-radius: 14px;
  padding: 32px;
  margin: 18px 0;
  box-shadow: 0 1px 6px rgba(0,0,0,.08);
}

/* ── Gombok ────────────────────────────────────────────────────────────────── */
button, .gomb {
  display: block;
  width: 280px;
  padding: 14px 24px;
  border: 0;
  border-radius: 10px;
  background: #2563eb;
  color: white;
  text-decoration: none;
  cursor: pointer;
  font-size: 18px;
  font-weight: bold;
  margin: 12px auto;
  text-align: center;
  box-sizing: border-box;
}
button:hover, .gomb:hover { background: #1d4ed8; }
button:focus,  .gomb:focus  { outline: 3px solid #93c5fd; }
button:active, .gomb:active { opacity: 0.9; }

/* Másodlagos gomb */
.gomb.masodlagos, button.masodlagos {
  display: inline-block;
  width: auto;
  padding: 10px 16px;
  border: 2px solid #2563eb;
  border-radius: 8px;
  background: transparent;
  color: #2563eb;
  font-size: 1em;
  font-weight: normal;
  margin: 4px auto;
}
.gomb.masodlagos:hover, button.masodlagos:hover { background: #eff6ff; }

/* Kis gomb */
.gomb.kis, button.kis {
  width: auto;
  display: inline-block;
  padding: 8px 16px;
  font-size: 15px;
  font-weight: normal;
  margin: 0 4px;
}

/* Törlés gomb */
.gomb.torles, button.torles {
  width: auto;
  display: inline-block;
  background: #fee2e2;
  color: #b91c1c;
  border: 1px solid #fca5a5;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: normal;
  margin: 0 4px;
}
.gomb.torles:hover, button.torles:hover { background: #fecaca; }

/* ── Menü ──────────────────────────────────────────────────────────────────── */
.menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.menu .gomb {
  width: 280px;
  margin: 0;
}

/* ── Input mezők ───────────────────────────────────────────────────────────── */
label { display: block; margin: 12px 0; }
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
select,
textarea {
  width: 100%;
  padding: 12px 14px;
  border: 2px solid #d1d5db;
  border-radius: 8px;
  font-size: 17px;
  box-sizing: border-box;
  margin-top: 4px;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
  border-color: #1d4ed8;
  outline: 3px solid #bfdbfe;
}
input[type="file"] { display: block; margin-top: 6px; }
input[aria-invalid="true"] { border: 2px solid #a00; }

/* ── Üzenetek ──────────────────────────────────────────────────────────────── */
.uzenet {
  padding: 16px;
  border-radius: 8px;
  font-weight: bold;
  margin: 12px 0;
}
.uzenet.error   { background: #fee2e2; color: #7f1d1d; border-left: 6px solid #b91c1c; }
.uzenet.success { background: #dcfce7; color: #14532d; border-left: 6px solid #15803d; }

/* ── Egyéb elemek ──────────────────────────────────────────────────────────── */
.gombsor { display: grid; gap: 10px; }
.tanulo-doboz p { margin: 10px 0; }
.rejtett { display: none; }
.mezo-hiba { margin: 0.35rem 0 0.8rem; font-weight: 600; }
.oldal-vege-nav { margin-top: 1.5rem; }
.kapcsolat { margin-top: 18px; padding: 16px; border: 2px solid #d1d5db; border-radius: 10px; }
.jelszo-sor { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.jelszo-sor input { flex: 1; width: auto; }
.jelszo-sor button { width: auto; display: inline-block; padding: 8px 12px;
  font-size: 20px; background: transparent; border: 1px solid #d1d5db;
  border-radius: 8px; cursor: pointer; margin: 0; font-weight: normal; }

/* ── sr-only ───────────────────────────────────────────────────────────────── */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0;
  margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ── Beállítások oldal ─────────────────────────────────────────────────────── */
fieldset { border: 1px solid #d1d5db; border-radius: 8px; padding: 14px 18px; margin: 16px 0; }
legend   { font-weight: bold; padding: 0 6px; }
fieldset label { display: flex; align-items: center; gap: 10px; margin: 8px 0; cursor: pointer; }
fieldset input[type="radio"] { width: 18px; height: 18px; cursor: pointer; }
.beallitasok-gombok { display: flex; flex-direction: column; gap: 12px; margin-top: 20px; max-width: 320px; }
.beallitasok-visszajelzes { margin-top: 12px; min-height: 24px; font-weight: bold; color: #16a34a; }

/* ── Akadálymentességi beállítások – data-* CSS ───────────────────────────── */

/* Betűtípus */
body[data-font="atkinson"]     { font-family: 'Atkinson Hyperlegible', Arial, sans-serif; }
body[data-font="verdana"]      { font-family: Verdana, sans-serif; }
body[data-font="opendyslexic"] { font-family: 'OpenDyslexic', Arial, sans-serif; }

/* Betűméret */
body[data-fontsize="nagy"]      { font-size: 1.25rem; }
body[data-fontsize="extranegy"] { font-size: 1.5rem; }
body[data-fontsize="orias"]     { font-size: 1.75rem; }

/* Kontraszt – magas, sárga */
body[data-contrast="high-yellow"] { background: #000 !important; color: #ffe600 !important; }
body[data-contrast="high-yellow"] .kartya,
body[data-contrast="high-yellow"] .doboz  { background: #111 !important; color: #ffe600 !important; box-shadow: none; }
body[data-contrast="high-yellow"] button,
body[data-contrast="high-yellow"] .gomb   { background: #222 !important; color: #ffe600 !important; border-color: #ffe600 !important; }
body[data-contrast="high-yellow"] a       { color: #ffe600 !important; }
body[data-contrast="high-yellow"] input,
body[data-contrast="high-yellow"] select  { background: #222 !important; color: #ffe600 !important; border-color: #ffe600 !important; }

/* Kontraszt – magas, fehér */
body[data-contrast="high-white"] { background: #000 !important; color: #fff !important; }
body[data-contrast="high-white"] .kartya,
body[data-contrast="high-white"] .doboz  { background: #111 !important; color: #fff !important; box-shadow: none; }
body[data-contrast="high-white"] button,
body[data-contrast="high-white"] .gomb   { background: #222 !important; color: #fff !important; border-color: #fff !important; }
body[data-contrast="high-white"] a       { color: #fff !important; }
body[data-contrast="high-white"] input,
body[data-contrast="high-white"] select  { background: #222 !important; color: #fff !important; border-color: #fff !important; }

/* Kontraszt – fordított */
body[data-contrast="inverted"] { background: #fff !important; color: #000 !important; }
body[data-contrast="inverted"] .kartya,
body[data-contrast="inverted"] .doboz  { background: #fff !important; color: #000 !important; border: 2px solid #000 !important; box-shadow: none; }
body[data-contrast="inverted"] button,
body[data-contrast="inverted"] .gomb   { background: #000 !important; color: #fff !important; }
body[data-contrast="inverted"] a       { color: #000 !important; text-decoration: underline; }

/* Sortávolság */
body[data-linespacing="novelt"] { line-height: 1.8; }
body[data-linespacing="dupla"]  { line-height: 2.2; }
body[data-linespacing="extra"]  { line-height: 2.6; }

/* --- Jelszó mező + megmutatás gomb egy sorban --- */
.jelszo-sor {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.jelszo-sor input {
  flex: 1;
}
.jelszo-sor button {
  flex-shrink: 0;
  background: none;
  border: 1px solid var(--szin-keret, #ccc);
  border-radius: 4px;
  padding: 0.3rem 0.5rem;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
}
