/* =========================================================
   Aréna Manager - styling igazítva a fő weboldalhoz
   ========================================================= */

:root {
    --bg-deep:        #0b0805;
    --bg-dark:        #110b07;
    --bg-elev:        #1a120b;
    --bg-card:        #1e1610;
    --bg-soft:        #2a1f15;

    --line:           #3a2b1c;
    --line-soft:      #2a1f15;

    --text:           #f5ebd9;
    --text-dim:       #c9bba0;
    --text-mute:      #8a7c66;

    --gold:           #d4a64a;
    --gold-bright:    #f0c45a;
    --bronze:         #a36a2c;
    --blood:          #8a1f1f;
    --blood-bright:   #c83232;
    --sand:           #d8c08a;
    --green:          #6a8a3a;

    --shadow-lg:      0 30px 60px -20px rgba(0,0,0,.7);
    --shadow-md:      0 16px 32px -16px rgba(0,0,0,.6);

    --radius-sm:      6px;
    --radius:         12px;
    --radius-lg:      18px;

    --maxw:           1280px;

    --font-display:   'Cinzel', 'Times New Roman', serif;
    --font-body:      'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
/* Globális GUI-skála: minden elem (font, padding, kép, fixed overlay) arányosan ~75%-ra. */
html { overflow-x: hidden; zoom: 0.75; }
body {
    margin: 0;
    background: var(--bg-deep);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    min-height: 100vh;
    background-image:
        radial-gradient(900px 500px at 90% -10%, rgba(212,166,74,.08), transparent 60%),
        radial-gradient(800px 600px at -10% 80%, rgba(138,31,31,.10), transparent 60%);
}

a { color: var(--gold-bright); text-decoration: none; transition: color .2s; }
a:hover { color: var(--sand); }

/* ============== Scrollbar — gladiátor téma ============== */
* { scrollbar-color: var(--gold) var(--bg-elev); scrollbar-width: thin; }
*::-webkit-scrollbar { width: 12px; height: 12px; }
*::-webkit-scrollbar-track {
    background: var(--bg-elev);
    border-left: 1px solid var(--line-soft);
}
*::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--gold), #8a5e1c);
    border: 2px solid var(--bg-elev);
    border-radius: 6px;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.25);
}
*::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, var(--gold-bright), var(--gold)); }
*::-webkit-scrollbar-corner { background: var(--bg-elev); }

.container {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 24px;
    width: 100%;
}

h1, h2, h3 {
    font-family: var(--font-display);
    color: var(--text);
    letter-spacing: .02em;
    line-height: 1.15;
    margin: 0 0 .5em;
    font-weight: 700;
}
h1 { font-size: clamp(1.7rem, 3.6vw, 2.6rem); }
h2 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); color: var(--gold); }
h3 { font-size: 1.05rem; letter-spacing: .04em; }

.kicker {
    text-transform: uppercase;
    letter-spacing: .25em;
    font-size: .75rem;
    font-weight: 600;
    color: var(--gold);
    margin: 0 0 1em;
}

.muted { color: var(--text-mute); }
.dim   { color: var(--text-dim); }
.small { font-size: .82rem; }
.center{ text-align: center; }
.accent{ color: var(--gold-bright); }
.danger{ color: var(--blood-bright); }
.hidden{ display: none !important; }

/* ============== Header / Nav ============== */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(11, 8, 5, .92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--line);
}
.nav-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 24px;
    gap: 24px;
}
.brand { display: flex; align-items: center; gap: 12px; color: var(--text); }
.brand:hover { color: var(--text); }
.brand-mark {
    width: 40px; height: 40px;
    border: 2px solid var(--gold);
    color: var(--gold);
    font-family: var(--font-display);
    font-weight: 900;
    font-size: 1rem;
    display: grid;
    place-items: center;
    border-radius: 4px;
    background: linear-gradient(180deg, rgba(212,166,74,.15), rgba(212,166,74,0));
}
.brand-text strong {
    font-family: var(--font-display);
    font-size: 1rem;
    letter-spacing: .08em;
    display: block;
    line-height: 1;
}
.brand-text em {
    font-style: normal;
    font-size: .68rem;
    color: var(--text-mute);
    letter-spacing: .15em;
    text-transform: uppercase;
}
.nav { display: flex; align-items: center; gap: 24px; }
.nav a {
    color: var(--text-dim);
    font-weight: 500;
    font-size: .92rem;
    position: relative;
    padding: 6px 0;
}
.nav a::after {
    content: ""; position: absolute; left: 0; bottom: 0;
    width: 0; height: 2px;
    background: var(--gold);
    transition: width .25s;
}
.nav a:hover, .nav a.active { color: var(--text); }
.nav a:hover::after, .nav a.active::after { width: 100%; }
.nav .cta-link {
    border: 1px solid var(--gold);
    color: var(--gold);
    padding: 6px 14px;
    border-radius: var(--radius-sm);
}
.nav .cta-link::after { display: none; }
.nav .cta-link:hover { background: var(--gold); color: var(--bg-deep); }
/* Nézői oldal — külön ablakban nyíló link, vizuálisan elkülönítve a sima
   route-link-ektől, hogy egyértelmű legyen: ez nem belső navigáció. */
.nav .nav-viewer {
    border: 1px solid var(--line);
    color: var(--text-dim);
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    transition: border-color .2s, color .2s, background .2s;
}
.nav .nav-viewer::after { display: none; }
.nav .nav-viewer:hover {
    border-color: var(--gold);
    color: var(--gold);
    background: rgba(212,166,74,.06);
}

.nav-toggle {
    display: none;
    background: none; border: 0;
    width: 38px; height: 38px;
    cursor: pointer;
    flex-direction: column;
    justify-content: center;
    gap: 5px; padding: 0;
}
.nav-toggle span {
    display: block; height: 2px; width: 26px;
    background: var(--gold);
    transition: transform .25s, opacity .25s;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============== Main / sections ============== */
main {
    padding: 32px 0 80px;
    min-height: calc(100vh - 200px);
}

.page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}
.page-head .titles { flex: 1 1 auto; }
.page-head .actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ============== Buttons ============== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: .92rem;
    letter-spacing: .03em;
    transition: transform .15s, background .2s, color .2s, box-shadow .2s, border-color .2s;
    cursor: pointer;
    border: 1px solid transparent;
    font-family: var(--font-body);
    background: transparent;
    color: var(--text);
    text-decoration: none;
}
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn-primary {
    background: linear-gradient(180deg, var(--gold-bright), var(--bronze));
    color: #1a1006;
    box-shadow: 0 8px 18px -10px rgba(212,166,74,.6);
}
.btn-primary:hover:not(:disabled) { transform: translateY(-1px); color: #1a1006; }
.btn-ghost  { border-color: var(--line); color: var(--text); }
.btn-ghost:hover:not(:disabled) { border-color: var(--gold); color: var(--gold-bright); }
.btn-danger { border-color: rgba(200,50,50,.5); color: #e08a8a; }
.btn-danger:hover:not(:disabled) { background: rgba(138,31,31,.18); border-color: var(--blood-bright); color: #f0a0a0; }
.btn-sm { padding: 6px 12px; font-size: .82rem; }
.btn-icon { padding: 8px 10px; }

/* ============== Cards / panels ============== */
.card {
    background: linear-gradient(180deg, var(--bg-card), var(--bg-elev));
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 22px;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
}
.card::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
    opacity: .55;
}
.card + .card { margin-top: 18px; }
.grid > .card { margin-top: 0; }   /* gridben a gap kezeli a kozt, ne dupplazzunk */
.card h2, .card h3 { margin-top: 0; }

.grid { display: grid; gap: 18px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
@media (max-width: 980px) {
    .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* ============== Forms ============== */
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 14px 18px;
}
.form-grid .full { grid-column: 1 / -1; }
@media (max-width: 720px) { .form-grid { grid-template-columns: 1fr; } }

label.field {
    display: grid;
    gap: 6px;
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--text-mute);
}
label.field input,
label.field select,
label.field textarea {
    background: var(--bg-deep);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    color: var(--text);
    padding: 10px 12px;
    font-family: var(--font-body);
    font-size: .95rem;
    text-transform: none;
    letter-spacing: normal;
    transition: border-color .15s, background .15s;
}
label.field input:focus,
label.field select:focus,
label.field textarea:focus {
    outline: none;
    border-color: var(--gold);
    background: #0d0904;
}
label.field input.short { max-width: 9rem; text-transform: uppercase; }

label.checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: .9rem;
    color: var(--text-dim);
    cursor: pointer;
    user-select: none;
    text-transform: none;
    letter-spacing: normal;
}
label.checkbox input { accent-color: var(--gold); width: 16px; height: 16px; }

/* ============== Tables / lists ============== */
table {
    width: 100%;
    border-collapse: collapse;
    font-size: .92rem;
}
table th, table td {
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid var(--line-soft);
    vertical-align: middle;
}
table th {
    color: var(--text-mute);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-size: .72rem;
}
table tr:hover td { background: rgba(212,166,74,.04); }
table .actions-cell { text-align: right; white-space: nowrap; }
table .actions-cell .btn { margin-left: 6px; }

.empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-mute);
    font-style: italic;
}

/* ============== Badges / chips ============== */
.chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    font-size: .75rem;
    color: var(--text-dim);
    background: rgba(0,0,0,.25);
    text-transform: uppercase;
    letter-spacing: .1em;
}
.chip.gold { border-color: var(--gold); color: var(--gold); }
.chip.blood { border-color: var(--blood-bright); color: #e08a8a; background: rgba(138,31,31,.18); }
.chip.green { border-color: var(--green); color: #b6cf83; }

.tag-abbr {
    font-family: var(--font-display);
    color: var(--gold-bright);
    letter-spacing: .12em;
    font-weight: 700;
}

/* ============== Music player rows ============== */
.music-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: rgba(0,0,0,.25);
    margin-bottom: 8px;
}
.music-row .meta { display: flex; align-items: center; gap: 12px; min-width: 0; }
.music-row .meta .name { font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.music-row .meta .cat { color: var(--text-mute); font-size: .8rem; }
.music-row .controls { display: flex; gap: 6px; }
.music-row.is-playing { border-color: var(--gold); box-shadow: inset 0 0 0 1px var(--gold); }
.music-row.is-playing .meta .name { color: var(--gold); }

/* ============== Performance editor ============== */
/* A fellépés-szerkesztő full-width: a max-w és a 24px oldalsó padding eltűnik,
   hogy a sticky pool és a szekció-grid a teljes képernyőt használja. */
.container.perf-edit-page {
    max-width: none;
    padding: 0 12px;
}
/* Felső adatdoboz mint <details>: kattintható summary, alapból összecsukva
   (új fellépésnél nyitva). A preview a summary jobb oldalán mutatja a kulcs-mezőket. */
.perf-meta-card { padding-bottom: 14px; }
.perf-meta-card > .perf-meta-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.perf-meta-card > .perf-meta-summary::-webkit-details-marker { display: none; }
.perf-meta-card > .perf-meta-summary::before {
    content: "▸";
    color: var(--gold);
    transition: transform .15s;
    display: inline-block;
    flex: 0 0 auto;
}
.perf-meta-card[open] > .perf-meta-summary::before { transform: rotate(90deg); }
.perf-meta-card .perf-meta-title {
    color: var(--gold);
    font-family: var(--font-display);
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .9rem;
    flex: 0 0 auto;
}
.perf-meta-card .perf-meta-preview {
    color: var(--text-dim);
    font-size: .9rem;
    margin-left: auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}
.perf-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 16px;
    align-items: start;
    margin-top: 14px;
    /* Stretching grid item magassága miatt a sticky aside ne ragadjon — a min-content
       lehetővé teszi, hogy a sidebar a saját méretén maradjon. */
}
.perf-pool-side {
    /* Auto-magas, nincs sticky és nincs belső scroll — az oldallal együtt görög. */
    align-self: start;
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 14px;
}
.perf-pool-side h3 {
    color: var(--gold);
    font-family: var(--font-display);
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .85rem;
    margin: 0 0 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.perf-pool-side h3 .dim { font-family: var(--font-body); letter-spacing: 0; text-transform: none; font-size: .8rem; }
.perf-pool-side .pool-filters {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin: 0 0 10px;
    padding: 8px 10px;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius-sm);
    background: rgba(0,0,0,.18);
}
.perf-pool-side .pool-filters label.checkbox { font-size: 12.5px; gap: 6px; }
.perf-pool-side .perf-pool-grid {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.perf-pool-side .perf-pool-grid label.checkbox {
    border: 1px solid var(--line);
    padding: 6px 8px;
    border-radius: var(--radius-sm);
    font-size: 12.5px;
    line-height: 1.3;
}
.perf-pool-side .perf-pool-grid label.checkbox.is-empty { display: none; }
.perf-sections-area { min-width: 0; }
.sections-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
    margin-bottom: 14px;
    padding: 10px 14px;
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    position: sticky;
    /* A header alatt megáll, hogy ne csússzon alá. */
    top: 64px;
    z-index: 5;
}
.sections-toolbar h2 { margin: 0; font-size: 1.05rem; }
.sections-toolbar .toolbar-filters {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.sections-toolbar .toolbar-filters label.checkbox { font-size: 13px; gap: 6px; }
.sections-grid {
    display: grid;
    /* A min(560px, 100%) miatt szűk képernyőn nem csordul ki — a 560px
       minimum lehetővé teszi, hogy két páros (~280px) elférjen egymás mellett
       a szekción belül; a páros-area lent flex-wrap-pal tördel. */
    grid-template-columns: repeat(auto-fill, minmax(min(560px, 100%), 1fr));
    gap: 14px;
}
.sections-grid.hide-interludes .section-block[data-mode="interlude"] { display: none; }
.sections-grid .add-section-card {
    border: 1px dashed var(--line);
    border-radius: var(--radius);
    background: rgba(0,0,0,.12);
    color: var(--text-mute);
    cursor: pointer;
    padding: 18px;
    min-height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-body);
    font-size: .9rem;
    transition: color .15s, border-color .15s, background .15s;
}
.sections-grid .add-section-card:hover {
    color: var(--gold);
    border-color: var(--gold);
    background: rgba(212,166,74,.08);
}
@media (max-width: 1100px) {
    .perf-layout { grid-template-columns: 280px 1fr; }
}
@media (max-width: 900px) {
    .perf-layout { grid-template-columns: 1fr; }
    .perf-pool-side {
        position: static;
        max-height: none;
    }
    .sections-toolbar { position: static; }
}

.section-block {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 18px;
    margin-bottom: 14px;
    background: rgba(0,0,0,.22);
}
.sections-grid .section-block { margin-bottom: 0; }
.section-block h3 { color: var(--gold); margin: 0 0 10px; }
.section-block .head-row {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    margin-bottom: 10px; flex-wrap: wrap;
}
.fighter-row {
    /* Kompakt sor: glad-select | weapon-btn | [swap] | [trash] */
    display: grid;
    grid-template-columns: minmax(52px, 62px) auto auto auto;
    gap: 6px;
    align-items: center;
    padding: 5px 6px;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius-sm);
    margin-bottom: 0;
    background: rgba(0,0,0,.2);
    min-width: 0;
    transition: background .15s, border-color .15s;
}
/* "Halhat" jelzés: maga a kártya kap vörös színezést — nem ugrál a layout. */
.fighter-row.can-die {
    border-color: rgba(200,50,50,.55);
    background: rgba(138,31,31,.28);
}
.fighter-row select {
    background: var(--bg-deep); border: 1px solid var(--line); border-radius: var(--radius-sm);
    color: var(--text); padding: 5px 6px; font-size: .85rem;
    min-width: 0; max-width: 100%;
}
.fighter-row.can-die select { border-color: rgba(200,50,50,.45); }
.fighter-row .team-swap-btn { font-size: .9rem; line-height: 1; padding: 4px 6px; }
.fighter-row .weapon-btn {
    /* Egységes szélesség → soha nem ugrál a layout fegyvernem-váltás közben.
       124px épp elég a leghosszabb fegyvernemnek (Hoplomachus) is. */
    font-size: .8rem;
    padding: 4px 7px;
    width: 124px;
    display: inline-flex; align-items: center; gap: 5px;
    overflow: hidden;
    text-align: left;
    justify-content: flex-start;
}
.fighter-row .weapon-btn .weapon-btn-icon { flex: 0 0 auto; opacity: .85; }
.fighter-row .weapon-btn .weapon-btn-name {
    flex: 1 1 auto; min-width: 0;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.icon-btn {
    background: transparent; border: 1px solid var(--line); color: var(--text-mute);
    border-radius: var(--radius-sm); padding: 5px;
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer; transition: color .15s, border-color .15s, background .15s;
}
.icon-btn:hover { color: var(--gold-bright); border-color: var(--gold); background: rgba(212,166,74,.08); }
.icon-btn svg { width: 15px; height: 15px; display: block; }
/* Kuka-ikon variáns: alaphelyzetben is enyhén bordós, hover-en hangsúlyos */
.icon-btn--danger { color: #c69090; }
.icon-btn--danger:hover {
    color: var(--blood-bright);
    border-color: var(--blood);
    background: rgba(138,31,31,.14);
}

@media (max-width: 720px) {
    .fighter-row { grid-template-columns: 1fr 1fr; }
    .fighter-row > button { grid-column: span 2; justify-self: start; }
}

.field-label { font-size: .82rem; color: var(--text-dim); display: block; }

/* Fegyvernem-választó dialóg rács */
.weapon-pick-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 6px;
}
.weapon-pick {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.weapon-pick:hover { border-color: var(--gold); background: rgba(212,166,74,.06); }
.weapon-pick:has(input:checked) { border-color: var(--gold); background: rgba(212,166,74,.12); }

/* Páros csoportok az editorban — kompakt, flow-layout, több páros egymás mellé */
.duel-pairs-area {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.duel-pair {
    /* Fix szélesség → a párosok mindig ugyanúgy néznek ki, nem ugrál a layout.
       glad(62) + gap(6) + weapon(124) + sor-padding(12) ≈ 204 → +box-padding(10) ≈ 214 */
    border: 1px dashed var(--line);
    border-radius: var(--radius-sm);
    padding: 5px 5px;
    background: rgba(0,0,0,.12);
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 0 0 218px;
    width: 218px;
    box-sizing: border-box;
}
@media (max-width: 720px) {
    .duel-pair { flex: 1 1 100%; width: 100%; }
}
.duel-pair .pair-head {
    /* nowrap: a kuka SOSE menjen új sorba, akkor sem, ha a badge hosszú. */
    display: flex; align-items: center; gap: 8px; flex-wrap: nowrap;
    letter-spacing: .15em; text-transform: uppercase;
    font-size: .72rem;
    min-width: 0;
}
.duel-pair .pair-head > :first-child { flex: 0 0 auto; white-space: nowrap; }
.duel-pair .pair-head .spacer { flex: 1 1 auto; min-width: 0; }
/* Korhűségi badge a páros-doboz alján, középre — új sorban, hogy a fejléc-gombok
   (pin / kuka) ne szorítsák el. */
.duel-pair .pair-foot {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 4px;
    padding-top: 4px;
    border-top: 1px dashed var(--line);
}
.duel-pair .pair-foot .pair-badge {
    letter-spacing: 0; text-transform: none;
    text-align: center;
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
}
.duel-pair .pair-head .pair-del-btn { flex: 0 0 auto; }
.duel-pair .pair-del-btn { padding: 3px; }
.duel-pair .pair-del-btn svg { width: 13px; height: 13px; }
.duel-pair .pair-head .pair-pin-btn { flex: 0 0 auto; padding: 2px 5px; font-size: .9rem; }
/* Pinelt páros: arany szegély + halvány arany háttér, hogy egyértelmű legyen,
   hogy ezt nem cseréli újra a generátor. */
.duel-pair.is-pinned {
    border: 1px solid var(--gold);
    background: rgba(199, 165, 79, .08);
    box-shadow: 0 0 0 1px rgba(199, 165, 79, .15);
}
.duel-pair.is-pinned .pair-pin-btn {
    color: var(--gold);
}
/* Páros mód: nincs kuka, nincs csapat-swap → kétoszlopos elrendezés. */
.duel-pair .fighter-row.no-del {
    grid-template-columns: minmax(56px, 75px) auto;
    padding: 4px 6px;
}
/* Típus-gomb (Páros / Csapat / Közjáték: ...) — a régi mode-select helyett */
.type-btn {
    border: 1px solid var(--line);
    background: var(--bg-deep);
}
.type-btn:hover { border-color: var(--gold); color: var(--gold); }

/* Közjáték (interlude) szekció törzse — read-only összefoglaló */
.interlude-body {
    padding: 6px 2px 2px;
}
.interlude-body .field {
    margin: 0;
}

/* Típus-választó dialógus (Páros / Csapat / közjáték presetek) */
.type-pick-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 8px;
}
.type-pick {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 10px 12px;
    background: var(--bg-deep);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    color: var(--text);
    cursor: pointer;
    text-align: left;
    font-family: var(--font-body);
    transition: border-color .15s, background .15s;
}
.type-pick:hover { border-color: var(--gold); background: rgba(212,166,74,.06); }
.type-pick.is-current {
    border-color: var(--gold);
    background: rgba(212,166,74,.12);
    box-shadow: 0 0 0 1px var(--gold) inset;
}
.type-pick .type-pick-name { font-weight: 600; font-size: .92rem; }
.type-pick .type-pick-sub { font-size: .78rem; color: var(--text-mute); }
/* Sor-elrendezésű típus-pick (közjátékok: name + szerkeszt + töröl) */
.type-pick--row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 6px;
    align-items: center;
    padding: 4px;
}
.type-pick--row .type-pick-main {
    background: transparent; border: none; color: inherit;
    text-align: left; padding: 8px 10px; cursor: pointer;
    display: flex; flex-direction: column; gap: 2px; font-family: var(--font-body);
    border-radius: var(--radius-sm);
}
.type-pick--row .type-pick-main:hover { background: rgba(212,166,74,.06); }

/* Csapatdobozok (csapatküzdelem) — egymás alatt, bennük flow-layout chipek */
.team-box {
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: rgba(0,0,0,.14);
    padding: 8px 10px;
    margin-bottom: 10px;
}
.team-box[data-team="A"] { border-left: 3px solid var(--gold); }
.team-box[data-team="B"] { border-left: 3px solid var(--blood-bright); }
.team-head {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    margin-bottom: 8px;
}
.team-head h3 { margin: 0; font-size: 1rem; }
.team-fighters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.team-fighters .fighter-row {
    margin-bottom: 0;
    /* Chip-szerű kompakt kártya — flow layoutban összerendezve.
       glad | weapon | swap | trash → 4 oszlop. */
    grid-template-columns: minmax(56px, 75px) auto auto auto;
}
.team-fighters .empty.small { padding: 8px 4px; }
/* Generátor eredmény — kompakt flow elrendezés */
.gen-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
    margin-top: 8px;
}
.gen-section {
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    background: rgba(0,0,0,.22);
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.gen-section.is-highlight {
    border-color: var(--gold);
    background: linear-gradient(180deg, rgba(212,166,74,.10), rgba(0,0,0,.22));
    box-shadow: 0 0 18px -8px rgba(212,166,74,.55);
}
.gen-section.is-highlight .gen-section-head { color: var(--gold-bright); }
.gen-section-head {
    color: var(--gold);
    font-family: var(--font-display);
    font-size: .85rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--line-soft);
    padding-bottom: 4px;
    margin-bottom: 2px;
}
.gen-pair-line {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    padding: 4px 6px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--line-soft);
    background: rgba(0,0,0,.18);
    font-size: .85rem;
}
.gen-pair-line.ok   { border-color: rgba(106,138,58,.55); background: rgba(106,138,58,.08); }
.gen-pair-line.warn { border-color: rgba(212,166,74,.45); background: rgba(212,166,74,.06); }
.gen-pair-line.bad  { border-color: rgba(200,50,50,.55); background: rgba(138,31,31,.10); }
.gen-pair-line .gen-f { color: var(--text); }
.gen-pair-line .gen-f.die { color: #f0a0a0; }
.gen-pair-line .gen-vs { color: var(--text-mute); font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; }

/* ============== Live overlay ============== */
.live-overlay {
    position: fixed;
    inset: 0;
    background: var(--bg-deep);
    background-image:
        radial-gradient(1100px 600px at 70% 20%, rgba(212,166,74,.15), transparent 60%),
        radial-gradient(900px 600px at 20% 90%, rgba(138,31,31,.20), transparent 60%);
    z-index: 200;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.live-overlay.hidden { display: none; }

.live-shell {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    /* Vízszintes swipe a JS-é (szekcióléptetés), függőleges görgetés a böngészőé. */
    touch-action: pan-y;
}
/* A touch-target elemnek (ahol a touchstart történik) is `pan-y`-nak kell
   lennie — Android Chrome itt dönti el, hogy a gesztus a JS-é vagy a böngészőé.
   Az interaktív elemek (gomb, link, input) maradjanak `auto`-n, hogy a tap-jük
   sértetlen legyen. */
.live-content,
.live-header,
.live-footer,
.live-grand,
.live-section { touch-action: pan-y; }
.live-header,
.live-footer {
    flex-shrink: 0;
    background: linear-gradient(180deg, rgba(20,12,7,.96), rgba(11,8,5,.94));
    backdrop-filter: blur(4px);
}
.live-header {
    border-bottom: 1px solid var(--gold);
    padding: 14px 0;
}
.live-footer {
    border-top: 2px solid var(--gold);
    padding: 12px 0 14px;
    display: flex;
    flex-direction: column;
}
.live-content {
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;          /* swipe közben a szomszédok kilógnak — vágjuk le */
    padding: 20px 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    position: relative;          /* a szomszéd-overlay anchor-ja */
    will-change: transform;
}
/* Ha a tartalom kifér, vertikálisan is közepre kerül; ha nem fér ki, a margin auto
   nullára esik, és a content normálisan görget. */
.live-content > .container { margin-block: auto; will-change: transform; }

/* Swipe-szomszéd: a `.live-content` mellé ±100%-on ül, és a húzással együtt
   transzformálódik — így a következő/előző szekció beúszik a mostani mellé. */
.live-content-neighbor {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    padding: 20px 0;
    pointer-events: none;        /* swipe közben ne legyen kattintható */
    will-change: transform;
}
.live-content-neighbor > .container { margin-block: auto; }
.live-content-neighbor--prev { left: -100%; }
.live-content-neighbor--next { left: 100%; }

.live-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.live-title { min-width: 0; flex: 1; }
.live-title h2 { margin: 0; color: var(--gold); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.live-title .sub { color: var(--text-mute); font-size: .85rem; letter-spacing: .15em; text-transform: uppercase; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.live-nav {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.live-nav .pos {
    font-family: var(--font-display);
    font-size: 1rem;
    color: var(--gold);
    letter-spacing: .15em;
    text-transform: uppercase;
    min-width: 70px;
    text-align: center;
}
.live-nav .btn { min-width: 0; padding: 6px 12px; }

/* Aktív szekció jelzés a header-ben — pozíció-badge "is-live" módban. */
.live-nav .pos.is-live {
    color: var(--blood-bright);
    border: 1px solid var(--blood-bright);
    background: rgba(138,31,31,.12);
    border-radius: 999px;
    padding: 4px 10px;
    box-shadow: 0 0 16px -6px rgba(200,50,50,.6);
}
.live-nav .pos.is-live::before {
    content: "● ";
    color: var(--blood-bright);
    animation: pulse-live 1.6s ease-in-out infinite;
}
@keyframes pulse-live {
    0%, 100% { opacity: 1; }
    50% { opacity: .35; }
}

/* "Szekció indítása" gomb — alaphelyzetben kiemelt, aktív állapotban
   diszkrét, kattintásra-disabled badge. */
.live-nav .activate-btn { white-space: nowrap; }
.live-nav .activate-btn.is-active {
    border: 1px solid var(--blood-bright);
    color: var(--blood-bright);
    background: rgba(138,31,31,.10);
    cursor: default;
    opacity: 1;
}
.live-nav .activate-btn.is-active::before {
    content: "";
}

/* Diszkrét keret-glow az élő szekció tartalom körül a manager nézetben. */
.live-content.is-live {
    box-shadow: inset 0 0 0 2px rgba(200,50,50,.35),
                inset 0 0 36px -8px rgba(200,50,50,.25);
}

.fighters-live {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
    margin-bottom: 24px;
}
.fighter-layout { margin-bottom: 24px; }
.live-pair { margin-bottom: 18px; }
.live-pair .fighters-live { margin-bottom: 0; }
.live-pair-head {
    color: var(--gold);
    font-family: var(--font-display);
    letter-spacing: .15em;
    text-transform: uppercase;
    font-size: .9rem;
    margin-bottom: 8px;
}
.team-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 18px;
    align-items: stretch;
}
.team-col .team-label {
    color: var(--gold);
    font-family: var(--font-display);
    letter-spacing: .18em;
    text-transform: uppercase;
    font-size: 1rem;
    margin-bottom: 10px;
    text-align: center;
}
.team-col .fighters-live { grid-template-columns: 1fr; gap: 10px; margin-bottom: 0; }
.team-vs {
    align-self: center;
    color: var(--blood-bright);
    font-family: var(--font-display);
    font-size: 2rem;
    letter-spacing: .12em;
}
@media (max-width: 720px) {
    .team-row { grid-template-columns: 1fr; }
    .team-vs { font-size: 1.4rem; text-align: center; }
}

/* Páros küzdelem — két harcos VS középen */
.pair-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 18px;
    align-items: stretch;
}
.pair-row .pair-slot { display: flex; }
.pair-row .pair-slot > .fighter-card { flex: 1; }
.pair-vs {
    align-self: center;
    color: var(--blood-bright);
    font-family: var(--font-display);
    font-size: 2rem;
    letter-spacing: .12em;
}
@media (max-width: 720px) {
    .pair-row { grid-template-columns: 1fr; }
    .pair-vs { font-size: 1.4rem; text-align: center; }
}
.fighter-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 18px;
    background: linear-gradient(180deg, var(--bg-card), var(--bg-elev));
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

/* Karakterlap-fotó háttérként az élő nézetben, ha az img sikeresen betöltődik.
   404-nél az onerror eltávolítja az img-t és az `has-bg` class-t, így a
   sima gradient marad érintetlen. */
.fighter-card .fighter-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 25%;
    opacity: .38;
    pointer-events: none;
    z-index: 0;
}
.fighter-card.has-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.30) 0%, rgba(0,0,0,.78) 100%);
    z-index: 0;
    pointer-events: none;
}
.fighter-card .fighter-card-inner {
    position: relative;
    z-index: 1;
}

.fighter-card .abbr {
    font-family: var(--font-display);
    font-size: 2rem;
    color: var(--gold-bright);
    letter-spacing: .08em;
    margin-bottom: 4px;
}
.fighter-card .full { font-size: 1rem; color: var(--text); margin-bottom: 4px; }
.fighter-card .weapon { color: var(--text-mute); font-size: .85rem; text-transform: uppercase; letter-spacing: .12em; }
.fighter-card .info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.fighter-card .info-row .info-text { min-width: 0; flex: 1; }
.fighter-card .info-row .info-text .full,
.fighter-card .info-row .info-text .weapon {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.fighter-card .info-row .entry-btn { flex-shrink: 0; }
/* "Nincs bevonuló" — szándékosan más arculat, hogy ne tűnjön csak halványított
   ▶-gombnak: szaggatott vörös-bronz keret, sötét vászon, áthúzott hangjegy érzet. */
.fighter-card .info-row .entry-btn--missing,
.entry-btn--missing {
    flex-shrink: 0;
    background: rgba(20, 12, 6, .55);
    color: rgba(212, 166, 74, .55);
    border: 1px dashed rgba(212, 166, 74, .45);
    font-style: italic;
    font-weight: 500;
    letter-spacing: .04em;
    box-shadow: none;
    opacity: 1;                 /* a globális .btn:disabled opacity-jét felülírjuk */
    cursor: not-allowed;
}
.fighter-card .info-row .entry-none {
    font-size: .75rem;
    color: var(--text-mute);
    flex-shrink: 0;
}

/* Élő mód — kiegészítő zenék (Csönd / harci / narrálás / vox populi) sora a footer-ben */
.aux-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    position: relative;
    z-index: 1;
}
.live-footer .aux-bar { margin-bottom: 0; }
/* A teljes gomb-keret kattintható legyen, ne csak a szöveg.
   A position:relative + z-index biztosítja, hogy semmi át ne fedje (pl. siblingek
   pseudo-jei vagy a now-playing border-top zónája).
   A ::before pszeudó pedig kiterjeszti a click-targetet az egész button-box-ra
   minden böngészőn — Safari iOS-en előfordult, hogy csak a text-rectangle volt
   eseményérzékeny. */
.aux-bar .aux-btn {
    flex: 1 1 auto;
    min-width: 140px;
    position: relative;
    z-index: 1;
}
.aux-bar .aux-btn::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
}
.fighter-card.can-die {
    border-color: var(--blood-bright);
    box-shadow: 0 0 24px -6px rgba(200,50,50,.55);
    background: linear-gradient(180deg, rgba(138,31,31,.25), rgba(40,10,10,.6));
}
.fighter-card.can-die::after {
    content: "HALHAT";
    position: absolute;
    top: 10px; right: 10px;
    background: var(--blood);
    color: #fff;
    padding: 3px 9px;
    border-radius: 999px;
    font-size: .68rem;
    letter-spacing: .25em;
    font-weight: 700;
}

/* Aktív fogadás / elo mod jelzes a fellepes-lista tetejen. */
.live-status-bar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    padding: 12px 18px;
    margin-bottom: 16px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(0,0,0,.45);
    color: var(--text);
    font-size: .92rem;
}
.live-status-bar .lsb-icon {
    font-size: 1.1rem;
    flex-shrink: 0;
}
.live-status-bar .lsb-main { flex: 1 1 auto; min-width: 200px; }
.live-status-bar .lsb-main strong { color: var(--gold-bright); }
.live-status-bar .lsb-sub {
    color: var(--text-mute);
    font-size: .82rem;
    letter-spacing: .08em;
}
.live-status-bar--betting {
    border-color: var(--gold);
    background: linear-gradient(90deg, rgba(212,166,74,.10), rgba(0,0,0,.45));
}
.live-status-bar--locked {
    border-color: rgba(212,166,74,.4);
    background: rgba(0,0,0,.55);
    opacity: .85;
}
.live-status-bar--live {
    border-color: var(--blood-bright);
    background: linear-gradient(90deg, rgba(138,31,31,.16), rgba(0,0,0,.45));
}
.live-status-bar--live .lsb-icon {
    color: var(--blood-bright);
    animation: live-status-pulse 1.4s ease-in-out infinite;
}
@keyframes live-status-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: .35; }
}

/* Győztes-jelölés (manager élő nézet, páros küzdelem). A nézői /fellepes
   oldal arany kerettel jelöli azokat, akikre a néző fogadott; itt a
   manager azt jelöli, hogy a páros melyik gladiátora nyert. A két dolog
   vizuálisan külön él: itt csak a kártya kap arany ragyogást, és a gomb
   állapota mutatja, hogy a "győztes" be van állítva. */
.fighter-card.is-winner {
    border-color: var(--gold-bright);
    box-shadow: 0 0 26px -4px rgba(212,166,74,.6);
}
.fighter-card.is-winner::before {
    background: linear-gradient(180deg, rgba(40,28,8,.32) 0%, rgba(0,0,0,.78) 100%) !important;
}
.fighter-card .winner-btn {
    margin-top: 10px;
    width: 100%;
    border: 1px solid var(--line);
    background: rgba(0,0,0,.5);
    color: var(--text-dim);
    padding: 8px 12px;
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .85rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    cursor: pointer;
    transition: border-color .2s, color .2s, background .2s;
}
.fighter-card .winner-btn:hover,
.fighter-card .winner-btn:focus-visible {
    border-color: var(--gold);
    color: var(--gold);
    outline: none;
}
.fighter-card .winner-btn.is-winner {
    border-color: var(--gold-bright);
    background: linear-gradient(180deg, rgba(212,166,74,.28), rgba(80,52,18,.6));
    color: var(--gold-bright);
}

/* Élő mód indító preload-képernyő (zenék letöltése IndexedDB-be) */
.live-preload {
    max-width: 540px;
    margin: 80px auto 0;
    padding: 32px 28px;
    border: 1px solid var(--gold);
    border-radius: var(--radius);
    background:
        radial-gradient(800px 300px at 50% 0%, rgba(212,166,74,.18), transparent 60%),
        rgba(0,0,0,.45);
    text-align: center;
    box-shadow: var(--shadow-lg);
}
.live-preload h2 { margin: 0 0 8px; color: var(--gold); }
.live-preload p { margin: 0 0 18px; }
.preload-bar {
    height: 10px;
    background: rgba(0,0,0,.5);
    border: 1px solid var(--line);
    border-radius: 999px;
    overflow: hidden;
}
.preload-bar-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--bronze), var(--gold-bright));
    transition: width .15s ease-out;
}
.preload-text {
    margin-top: 8px;
    color: var(--text-mute);
    font-size: .9rem;
    letter-spacing: .04em;
}

/* Élő mód — nyitás / zárás díszes blokk */
.live-grand {
    max-width: 760px;
    margin: 24px auto;
    padding: 44px 32px 36px;
    border: 1px solid var(--gold);
    border-radius: var(--radius);
    background:
        radial-gradient(900px 360px at 50% -10%, rgba(212,166,74,.22), transparent 60%),
        radial-gradient(700px 400px at 50% 120%, rgba(138,31,31,.20), transparent 60%),
        rgba(0,0,0,.45);
    text-align: center;
    box-shadow: 0 18px 60px -22px rgba(0,0,0,.7), inset 0 0 0 1px rgba(212,166,74,.12);
    position: relative;
}
.live-grand::before,
.live-grand::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 64px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.live-grand::before { top: 18px; }
.live-grand::after  { bottom: 18px; }
.live-grand .kicker {
    color: var(--gold);
    font-size: .85rem;
    letter-spacing: .4em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 14px;
}
.live-grand-title {
    font-family: var(--font-display);
    color: var(--text);
    font-size: clamp(2rem, 6vw, 3.6rem);
    line-height: 1.1;
    letter-spacing: .03em;
    margin: 0 0 6px;
}
.live-grand-date {
    color: var(--text-mute);
    font-size: .95rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    margin-bottom: 22px;
}
.live-grand-rule {
    width: 120px;
    height: 1px;
    margin: 14px auto 18px;
    background: linear-gradient(90deg, transparent, var(--gold-bright), transparent);
}
.live-grand-sub {
    color: var(--text);
    opacity: .85;
    font-size: 1rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 28px;
}
.live-grand-music {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 18px 24px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: linear-gradient(180deg, rgba(20,12,7,.6), rgba(11,8,5,.8));
    min-width: 280px;
}
.live-grand-music .lgm-label {
    color: var(--gold);
    font-family: var(--font-display);
    font-size: .8rem;
    letter-spacing: .3em;
    text-transform: uppercase;
}
.live-grand-music .lgm-name {
    font-size: 1.25rem;
    color: var(--text);
    font-weight: 600;
    max-width: 460px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.live-grand-music .lgm-btn {
    margin-top: 6px;
    min-width: 200px;
    font-size: 1rem;
    letter-spacing: .1em;
}
.live-grand-music--empty .lgm-none {
    color: var(--text-mute);
    font-style: italic;
}
.live-grand--closing {
    background:
        radial-gradient(900px 360px at 50% -10%, rgba(138,31,31,.22), transparent 60%),
        radial-gradient(700px 400px at 50% 120%, rgba(212,166,74,.18), transparent 60%),
        rgba(0,0,0,.45);
}

/* Közjáték kiemelő blokk az élő felületen */
.interlude-live {
    border: 1px solid var(--gold);
    border-radius: var(--radius);
    padding: 28px 22px;
    margin-bottom: 14px;
    background:
        radial-gradient(800px 300px at 50% 0%, rgba(212,166,74,.18), transparent 60%),
        rgba(0,0,0,.35);
    text-align: center;
}
.interlude-live .kicker {
    color: var(--gold);
    font-size: .85rem;
    letter-spacing: .35em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 8px;
}
.interlude-live .interlude-name {
    font-family: var(--font-display);
    color: var(--text);
    font-size: clamp(1.8rem, 5vw, 3rem);
    margin: 0;
    letter-spacing: .04em;
    line-height: 1.1;
}

.music-block {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 16px;
    margin-bottom: 12px;
    background: rgba(0,0,0,.3);
}
.music-block h3 {
    color: var(--gold);
    font-size: .82rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    margin: 0 0 10px;
}
.music-block .row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.music-block .row .name {
    flex: 1 1 240px;
    min-width: 0;
    color: var(--text);
    font-weight: 600;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.music-block .none { color: var(--text-mute); font-style: italic; }

.now-playing {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    padding: 10px 12px 0;
    margin-top: 10px;
    border-top: 1px solid var(--line-soft);
    position: relative;
    overflow: hidden;
}
/* A now-playing gyermekei a fade-bar (háttér) FÖLÖTT legyenek. */
.now-playing > *:not(.fade-bar) { position: relative; z-index: 1; }
.now-playing .label {
    font-family: var(--font-display);
    color: var(--gold);
    letter-spacing: .2em;
    text-transform: uppercase;
    font-size: .78rem;
}
.now-playing .track { flex: 1 1 200px; min-width: 0; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 600; }
.now-playing .time { font-family: monospace; color: var(--text-dim); font-size: .92rem; }

/* Fade-out vizualizáció: Csönd / Szünet / új zene indítása esetén az
   elhalkulás idejét mutatja egy "draining" háttérsáv a now-playing row-ban.
   A bar abszolút módon a row teljes területére kifeszítve ül, a fill
   100%→0% szélességre csökken a fade időtartama alatt. Nem tol el semmit,
   és pointer-events: none miatt nem fog közbe interakciókat sem. */
.fade-bar {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}
.fade-bar[hidden] { display: none; }
.fade-bar-fill {
    height: 100%;
    width: 100%;
    background: linear-gradient(90deg,
        rgba(212,166,74,.05) 0%,
        rgba(212,166,74,.22) 55%,
        rgba(200,50,50,.32) 100%);
    border-right: 1px solid rgba(240,160,160,.55);
    box-shadow: inset -2px 0 8px -2px rgba(240,160,160,.45);
    will-change: width;
}

/* ============== Misc ============== */
.row-flex { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.spacer { flex: 1 1 auto; }
hr.sep { border: none; border-top: 1px solid var(--line); margin: 18px 0; }

.toast-stack {
    position: fixed;
    top: 80px; right: 20px;
    z-index: 300;
    display: flex; flex-direction: column;
    gap: 8px;
    max-width: 320px;
}
.toast {
    background: var(--bg-elev);
    border: 1px solid var(--gold);
    border-left: 3px solid var(--gold);
    color: var(--text);
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-md);
    font-size: .9rem;
    animation: toastIn .25s ease;
}
.toast.error { border-color: var(--blood-bright); }
.toast.ok    { border-color: var(--green); }
@keyframes toastIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: none; } }

.footer-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 18px;
    align-items: start;
    padding: 30px 24px;
    border-top: 1px solid var(--line);
    margin-top: 40px;
}
.footer-nav { display: flex; gap: 18px; flex-wrap: wrap; }
.footer-nav a { color: var(--text-dim); font-size: .88rem; }
.footer-nav a:hover { color: var(--gold); }
.footer-note { grid-column: 1 / -1; border-top: 1px solid var(--line); padding-top: 14px; margin: 14px 0 0; }

@media (max-width: 720px) {
    .nav-toggle { display: flex; }
    .nav {
        position: absolute;
        top: 100%; left: 0; right: 0;
        flex-direction: column;
        align-items: stretch;
        background: rgba(11, 8, 5, .98);
        border-top: 1px solid var(--line);
        gap: 0; padding: 8px 0;
        max-height: 0; overflow: hidden;
        transition: max-height .3s ease;
    }
    .nav.open { max-height: 600px; }
    .nav a { padding: 12px 24px; border-bottom: 1px solid var(--line); }
    .nav a:last-child { border-bottom: 0; }
    .nav .cta-link { margin: 10px 24px; text-align: center; }
    .footer-inner { grid-template-columns: 1fr; }
}

/* ============== Section block ============== */
.section-block { transition: border-color .15s; }
.section-block .title-input {
    background: var(--bg-deep);
    border: 1px solid var(--line);
    color: var(--text);
    border-radius: 6px;
    padding: 6px 10px;
    min-width: 220px;
    font-family: var(--font-body);
}
.section-block .sub-label {
    font-size: .78rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--gold);
    margin: 4px 0;
}
.cat-select {
    background: var(--bg-deep);
    border: 1px solid var(--line);
    color: var(--text);
    border-radius: 6px;
    padding: 6px 8px;
    font-size: .85rem;
}

/* ============== Pair badge (inline a páros fejlécében) ============== */
.pair-badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: .75rem;
    border: 1px solid;
    line-height: 1.4;
}
.pair-badge.ok   { color: #b6cf83;          background: rgba(106,138,58,.12); border-color: rgba(106,138,58,.45); }
.pair-badge.warn { color: var(--gold-bright); background: rgba(212,166,74,.10); border-color: rgba(212,166,74,.45); }
.pair-badge.bad  { color: #f0a0a0;          background: rgba(138,31,31,.20); border-color: rgba(200,50,50,.55); }

.callout {
    padding: 14px 18px;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    margin: 14px 0;
    background: rgba(0,0,0,.25);
}
.callout.warn {
    border-color: rgba(212,166,74,.5);
    background: rgba(212,166,74,.06);
    color: var(--text-dim);
}
.callout ul { margin: 8px 0 0; padding-left: 22px; }
.callout li { margin-bottom: 4px; }

/* ============== Modal ============== */
/* A háttér-elsötétítés és a blur a fellepes/.char-dialog::backdrop arculatát
   követi, hogy a manager modaljai ugyanúgy "kiemeljenek" a háttérből. */
.modal-back {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.72);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 250;
    display: grid;
    place-items: center;
    padding: 20px;
    overflow-y: auto;
}
/* A modal-okban lévő görgetősávok azonos arany témát kapnak, mint az
   oldalszintű (* {...}) szabály — egyes böngészők belső scroll-konténereken
   nem mindig öröklik következetesen, ezért explicit megismételjük. */
.modal-back,
.modal,
.modal-body,
.modal-list {
    scrollbar-color: var(--gold) var(--bg-elev);
    scrollbar-width: thin;
}
.modal-back::-webkit-scrollbar,
.modal::-webkit-scrollbar,
.modal-body::-webkit-scrollbar,
.modal-list::-webkit-scrollbar { width: 12px; height: 12px; }
.modal-back::-webkit-scrollbar-track,
.modal::-webkit-scrollbar-track,
.modal-body::-webkit-scrollbar-track,
.modal-list::-webkit-scrollbar-track {
    background: var(--bg-elev);
    border-left: 1px solid var(--line-soft);
}
.modal-back::-webkit-scrollbar-thumb,
.modal::-webkit-scrollbar-thumb,
.modal-body::-webkit-scrollbar-thumb,
.modal-list::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--gold), #8a5e1c);
    border: 2px solid var(--bg-elev);
    border-radius: 6px;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.25);
}
.modal-back::-webkit-scrollbar-thumb:hover,
.modal::-webkit-scrollbar-thumb:hover,
.modal-body::-webkit-scrollbar-thumb:hover,
.modal-list::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, var(--gold-bright), var(--gold));
}
.modal-back::-webkit-scrollbar-corner,
.modal::-webkit-scrollbar-corner,
.modal-body::-webkit-scrollbar-corner,
.modal-list::-webkit-scrollbar-corner { background: var(--bg-elev); }
.modal {
    background: linear-gradient(180deg, var(--bg-card), var(--bg-elev));
    border: 1px solid var(--gold);
    border-radius: var(--radius);
    padding: 24px;
    width: 100%;
    max-width: 720px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
}
/* Magas modal: nincs belső scroll, hagyja, hogy a tartalom nőjön. A .modal-back
   eleve scrollozik, ha kisebb a képernyő — így nagy kijelzőn minden látszik
   görgetés nélkül, kicsin pedig a háttér görgetése veszi át. */
.modal.modal--tall {
    max-height: none;
    overflow-y: visible;
}
/* Keretes modal: rögzített fejléc + görgethető törzs + ragadó lábléc.
   A láblécben lévő gombok mindig láthatók maradnak akkor is, ha a lista nagy. */
.modal.modal--framed {
    display: flex; flex-direction: column;
    padding: 0;
    max-height: 85vh;
    overflow: hidden;
}
.modal--framed .modal-head {
    padding: 18px 22px 12px;
    border-bottom: 1px solid var(--line-soft);
    background: linear-gradient(180deg, var(--bg-card), rgba(0,0,0,0));
}
.modal--framed .modal-head h2 { margin: 0 0 4px; }
.modal--framed .modal-head p { margin: 0 0 8px; }
.modal--framed .modal-body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 12px 22px;
    min-height: 0;
}
.modal--framed .modal-foot {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 22px;
    border-top: 1px solid var(--line-soft);
    background: var(--bg-elev);
}
.modal--framed .modal-foot .spacer { flex: 1 1 auto; }
.modal-search {
    width: 100%;
    background: var(--bg-deep);
    border: 1px solid var(--line);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    font-family: var(--font-body);
    font-size: .9rem;
}
.modal-search:focus { outline: none; border-color: var(--gold); }
.modal h2 { color: var(--gold); margin-top: 0; }
.modal-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 8px;
    margin: 0;
}

/* ============== Now playing toggles ============== */
.np-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text-dim);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    cursor: pointer;
    user-select: none;
    padding: 4px 8px;
    border: 1px solid var(--line);
    border-radius: 6px;
}
.np-toggle input { accent-color: var(--gold); }

/* Fegyvernem-képek a gladiátor-szerkesztőben */
.weapon-images {
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 14px 16px;
    margin: 0;
}
.weapon-images legend {
    padding: 0 6px;
    font-family: 'Cinzel', serif;
    color: var(--gold);
    font-size: .95rem;
    letter-spacing: .06em;
}
#weaponImagesGrid,
#meImageGrid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
}
.weapon-image-card {
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 10px;
    background: rgba(0,0,0,.18);
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.weapon-image-head {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.weapon-image-thumb {
    aspect-ratio: 3 / 4;
    background: rgba(0,0,0,.35);
    border: 1px dashed var(--line);
    border-radius: 4px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.weapon-image-thumb.is-empty { background: rgba(255,255,255,.02); }
.weapon-image-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.weapon-image-actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.weapon-image-actions .btn { flex: 1 1 auto; text-align: center; }

/* Read-only fellépés-szerkesztő (lezárt fellépés) — minden mező pointer-events:none */
.perf-readonly .form-grid input,
.perf-readonly .form-grid select,
.perf-readonly .form-grid textarea,
.perf-readonly #sectionsWrap input,
.perf-readonly #sectionsWrap select,
.perf-readonly #sectionsWrap textarea,
.perf-readonly #sectionsWrap button,
.perf-readonly #perfPoolGrid input,
.perf-readonly #perfPoolWrap button {
    pointer-events: none;
    opacity: .65;
}
.perf-readonly #regenPerf,
.perf-readonly #perfMusicBtn { pointer-events: none; opacity: .55; }

/* Statisztika modal */
.perf-stats-modal { max-width: 720px; }
.perf-stats-section { margin: 14px 0; }
.perf-stats-section h3 { margin: 0 0 8px; font-size: 1.05em; }
.perf-stats-list { display: flex; flex-direction: column; gap: 8px; }
.perf-stats-row {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px; background: var(--bg-soft); border-radius: 6px;
}
.perf-stats-row .ps-title { flex: 1 1 auto; font-weight: 500; }
.perf-stats-row .ps-bar {
    flex: 0 0 160px; height: 8px; background: #2a1f15;
    border-radius: 4px; overflow: hidden;
}
.perf-stats-row .ps-bar-fill { height: 100%; background: #c8995a; }
.perf-stats-row .ps-count { flex: 0 0 50px; text-align: right; font-variant-numeric: tabular-nums; }
.perf-stats-pair { padding: 10px 12px; background: var(--bg-soft); border-radius: 6px; margin-bottom: 10px; }
.perf-stats-pair.is-draw { border-left: 3px solid #c8995a; }
.perf-stats-pair-head { display: flex; gap: 10px; font-weight: 500; margin-bottom: 6px; align-items: center; flex-wrap: wrap; }
.perf-stats-pair-head .ps-winner-label {
    font-size: .85em;
    padding: 2px 8px;
    border-radius: 4px;
    background: rgba(0,0,0,.25);
}
.perf-stats-pair-head .ps-winner-label.is-winner { color: #7fcc7f; border: 1px solid rgba(127,204,127,.45); }
.perf-stats-pair-head .ps-winner-label.is-draw   { color: #c8995a; border: 1px solid rgba(200,153,90,.45); }
.perf-stats-pair-head .ps-winner-label.dim       { color: var(--text-dim); font-style: italic; }
.perf-stats-row.is-winner { background: rgba(127,204,127,.08); border: 1px solid rgba(127,204,127,.25); }
.perf-stats-row.is-winner .ps-title { color: #7fcc7f; }
.perf-stats-empty { color: var(--text-dim); font-style: italic; padding: 10px 0; }

/* Élő mód view-only sáv (lezárt fellépés újranyitása megtekintésre) */
.live-viewonly-banner {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 16px;
    background: #2a1f12; color: #e0a85a;
    border-bottom: 1px solid #a37b3d;
    font-size: .95em;
    z-index: 5;
}
.live-viewonly-banner > span { flex: 1 1 auto; }

/* Print */
@media print { .site-header, .site-footer, .live-overlay { display: none; } }

/* ============== Auth gate ============== */

.auth-screen {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 56px 16px 80px;
    min-height: 60vh;
}
.auth-card {
    width: 100%;
    max-width: 460px;
}
.auth-head {
    display: flex; align-items: center; gap: 14px;
    margin-bottom: 20px;
}
.auth-mark {
    width: 52px; height: 52px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold) 0%, var(--bronze) 100%);
    color: var(--bg-deep);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .02em;
    font-size: 1.05rem;
    box-shadow: var(--shadow-md);
}
.auth-titles h1 { margin: 0; font-size: 1.5rem; }
.auth-titles p { margin: 4px 0 0; font-size: .85rem; }

.auth-form {
    display: flex; flex-direction: column; gap: 14px;
    margin: 8px 0 4px;
}
.auth-form .field {
    display: flex; flex-direction: column; gap: 6px;
}
.auth-form .field > span {
    font-size: .8rem; letter-spacing: .04em; color: var(--text-dim);
    text-transform: uppercase;
}
.auth-form input {
    width: 100%;
    padding: 12px 14px;
    background: var(--bg-deep);
    border: 1px solid var(--line);
    color: var(--text);
    font: inherit;
    border-radius: var(--radius-sm);
    outline: none;
    transition: border-color .2s, box-shadow .2s;
}
.auth-form input:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(212,166,74,.18);
}
.auth-submit {
    margin-top: 6px;
    align-self: stretch;
    padding: 12px 18px;
    font-size: 1rem;
}
.auth-error {
    background: rgba(200,50,50,.08);
    border: 1px solid rgba(200,50,50,.3);
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    color: #f0a0a0;
    margin: 0;
    font-size: .9rem;
}
.auth-actions {
    display: flex; gap: 10px; flex-wrap: wrap;
    margin-top: 14px;
}
.auth-actions .btn { flex: 1 1 auto; min-width: 140px; }
.auth-footer {
    margin-top: 22px;
    padding-top: 14px;
    border-top: 1px solid var(--line-soft);
    text-align: center;
}
.btn-link {
    background: transparent;
    border: 0;
    color: var(--text-mute);
    font: inherit;
    cursor: pointer;
    padding: 4px 8px;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.btn-link:hover { color: var(--gold-bright); }

/* ============== User badge a header-ben ============== */

.user-badge {
    display: flex; align-items: center; gap: 6px;
    margin-left: 12px;
}
.user-badge-link {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 12px;
    background: var(--bg-elev);
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--text);
    transition: border-color .2s, color .2s;
}
.user-badge-link:hover {
    border-color: var(--gold);
    color: var(--gold-bright);
}
.user-badge-name {
    font-weight: 600;
    font-size: .85rem;
}
.user-badge-role {
    font-size: .68rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 2px 7px;
    border-radius: 999px;
    background: var(--gold);
    color: var(--bg-deep);
    font-weight: 700;
}
.user-badge-logout {
    background: transparent;
    border: 1px solid var(--line);
    color: var(--text-dim);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 1.1rem;
    padding: 4px 10px;
    transition: border-color .2s, color .2s;
}
.user-badge-logout:hover {
    border-color: var(--blood-bright);
    color: #f0a0a0;
}

/* "Kilépés" menüpont a fő navban — a user-badge ikon mellett ad egy
   jól látható szöveges kijelentkezési opciót, ami burger-menüben is működik. */
.nav .nav-logout-link {
    color: #e08a8a;
}
.nav .nav-logout-link:hover { color: #f0a0a0; }
.nav .nav-logout-link::after { background: var(--blood-bright); }

/* ============== Users (admin) tábla ============== */

.users-table-wrap { overflow-x: auto; }
.users-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
}
.users-table thead th {
    text-align: left;
    padding: 8px 10px;
    color: var(--text-dim);
    font-weight: 600;
    text-transform: uppercase;
    font-size: .75rem;
    letter-spacing: .04em;
    border-bottom: 1px solid var(--line);
}
.users-table tbody td {
    padding: 10px;
    border-bottom: 1px solid var(--line-soft);
    vertical-align: middle;
}
.users-table tbody tr:hover { background: rgba(212,166,74,.04); }
.users-table code {
    font-family: 'Inter', monospace;
    font-size: .85rem;
    color: var(--text-dim);
}
.users-table select {
    padding: 4px 8px;
    background: var(--bg-deep);
    border: 1px solid var(--line);
    color: var(--text);
    border-radius: var(--radius-sm);
    font: inherit;
}
.users-inline-input {
    background: transparent;
    border: 1px solid transparent;
    padding: 4px 6px;
    color: var(--text);
    font: inherit;
    width: 100%;
    min-width: 100px;
    max-width: 100%;
    border-radius: var(--radius-sm);
    transition: border-color .15s, background .15s;
}
.users-inline-input:hover {
    border-color: var(--line);
    background: rgba(212,166,74,.04);
}
.users-inline-input:focus {
    border-color: var(--gold);
    background: var(--bg-deep);
    outline: none;
}
.users-inline-input--mono {
    font-family: 'Inter', monospace;
    font-size: .85rem;
    color: var(--text-dim);
}
.users-inline-input--mono:focus { color: var(--text); }
.users-table .actions-col {
    text-align: right;
    white-space: nowrap;
}
.users-email-cell {
    display: flex;
    align-items: center;
    gap: 6px;
}
.users-email-cell .users-inline-input { flex: 1 1 auto; min-width: 140px; }
.users-email-cell .btn-icon {
    flex: 0 0 auto;
    padding: 2px 6px;
    font-size: .85rem;
    line-height: 1;
    color: var(--text-dim);
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    cursor: pointer;
}
.users-email-cell .btn-icon:hover:not(:disabled) {
    color: var(--text);
    border-color: var(--line);
    background: rgba(212,166,74,.06);
}
.users-email-cell .btn-icon:disabled {
    opacity: .35;
    cursor: not-allowed;
}

/* Iskolai érdeklődések tábla — az üzenet-cella hosszú szöveg miatt kapott
   szélesség-korlátot, hogy a többi oszlop ne nyomódjon szét. */
.inq-table .inq-msg {
    max-width: 360px;
    min-width: 200px;
    color: var(--text-dim);
    line-height: 1.45;
}
.inq-table td { vertical-align: top; }
.inq-table .actions-col .btn { margin-left: 4px; }
.status-ok   { color: #7fcc7f; }
.status-wait { color: var(--gold-bright); }
.status-bad  { color: var(--blood-bright); }

/* Temp password modál */
.temp-pw-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.7);
    display: flex; align-items: center; justify-content: center;
    z-index: 1000;
    padding: 16px;
}
.temp-pw-modal {
    max-width: 480px;
    width: 100%;
}
.temp-pw-box {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 14px;
    background: var(--bg-deep);
    border: 1px solid var(--gold);
    border-radius: var(--radius-sm);
    margin: 14px 0;
}
.temp-pw-box code {
    flex: 1 1 auto;
    font-family: ui-monospace, 'SF Mono', Consolas, monospace;
    font-size: 1.2rem;
    letter-spacing: .08em;
    color: var(--gold-bright);
    word-break: break-all;
}

/* ============== Adatbázis admin oldal ============== */

.db-info {
    list-style: none;
    padding: 0;
    margin: 0;
}
.db-info li {
    padding: 6px 0;
    border-bottom: 1px solid var(--line-soft);
    display: flex;
    justify-content: space-between;
    gap: 12px;
    font-size: .9rem;
}
.db-info li:last-child { border-bottom: 0; }
.db-info code {
    font-family: ui-monospace, Consolas, monospace;
    color: var(--text-dim);
}

/* ============== Profil — email-verifikáció utólag ============== */

.email-verify-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 8px;
}
.email-verify-actions .btn-sm { flex: 0 0 auto; }
.email-verify-actions .dim,
.email-verify-actions .status-ok,
.email-verify-actions .status-bad {
    font-size: .85rem;
}

/* ============== Kiegészítő szerepkörök (lannista, summa rudis, …) ============== */

.role-checks { border: 1px solid var(--line-soft); border-radius: 8px; padding: 12px 14px; }
.role-checks > legend { padding: 0 6px; font-weight: 600; }
.role-checks-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 6px 14px;
}
.role-check {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 4px;
    border-radius: 6px;
    cursor: pointer;
}
.role-check:hover { background: rgba(255,255,255,0.03); }
.role-check input[type="checkbox"] { margin-top: 3px; flex: 0 0 auto; }
.role-check-text { line-height: 1.35; }

.role-chip-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.role-chip {
    display: inline-block;
    padding: 3px 9px;
    border-radius: 999px;
    background: rgba(180, 130, 60, 0.18);
    color: #d6b074;
    border: 1px solid rgba(180, 130, 60, 0.45);
    font-size: .82rem;
    line-height: 1.3;
}
.role-chip-sm { font-size: .72rem; padding: 1px 7px; }
.row-roles { margin-top: 4px; display: flex; flex-wrap: wrap; gap: 4px; }
.field-label-like { display: block; font-weight: 600; margin-bottom: 4px; }
