body {
    padding-top: 90px;
    color: rgb(13, 3, 46);
    background-color: rgb(199, 217, 224);
}

p,
li {
    font-size: 1.1em;
    text-align: justify;
}

td {
    font-size: 1.2em;
}

h5 {
    font-weight: bold;
}

.text-highlighter {
    background-color: #97b1b7;
    line-height: 0 em;
    padding: 1px 0;
    margin-bottom: 10px;
}

.navbar {
    background-color: rgb(37, 48, 78);
    border-bottom: none;
}


/* A hover háttér a teljes li-re vonatkozzon */

.navbar-nav>li {
    position: relative;
    /* szükséges, hogy az a teljes li-ben legyen */
}


/* Link teljes magasságra, szélességre */

.navbar-nav>li>a {
    display: block;
    padding: 15px 15px;
    /* a kívánt padding */
    height: 100%;
    width: 100%;
    box-sizing: border-box;
    font-size: 18px;
    font-weight: 500;
    color: #b1c9cb;
}


/* Hover a li-n, ne az a-n */

.navbar-nav>li:hover {
    background-color: rgb(162, 178, 181);
}


/* Link színe hoverkor */

.navbar-nav>li:hover>a {
    background-color: transparent;
    /* hogy ne takarja az li-t */
    color: rgb(55, 81, 87);
    /* font-weight: bold; */
}


/* Hamburger gomb láthatóvá tétele mobilon (navbar-default class hiányában a BS3 nem ad neki színt) */

.navbar-toggle {
    border-color: rgba(177, 201, 203, 0.6);
}

.navbar-toggle .icon-bar {
    background-color: #b1c9cb;
}

.navbar-toggle:hover,
.navbar-toggle:focus {
    background-color: rgba(255, 255, 255, 0.1);
}


/* Mobilon a hamburger gomb a bal szélre, hogy ne ütközzön a jobb felső user-dropdown ikonnal */

@media (max-width: 767px) {
    .navbar-toggle {
        float: left !important;
        margin-left: 15px;
        margin-right: 0;
    }
}


/* Felhasználó-dropdown a navbar jobb felső sarkában, mindig látható (a collapse-en kívül).
   Asztalon és mobilon is ugyanúgy a jobb szélen marad. */

.user-dropdown-always {
    position: absolute;
    top: 0;
    right: 15px;
    z-index: 1001;
    margin: 0;
    padding: 0;
    list-style: none;
}

.user-dropdown-always>li {
    list-style: none;
}

.user-dropdown-always>li>a {
    display: block;
    padding: 15px 15px;
    line-height: 18px;
    /* az ikon font-size-éhez igazítva — különben az öröklött 1.42857 multiplier ~29px-re nyújtja a line-box-ot */
    color: #b1c9cb;
}


/* Hover/aktív állapot magán a linken — a li magasabb, mint az a (line-height öröködés miatt),
   ezért ha a li-re tennénk a háttérszínt, ~2 pixellel magasabb sávot foglalna mint a kattintható terület. */

.user-dropdown-always>li>a:hover,
.user-dropdown-always>li>a:focus,
.user-dropdown-always>li.open>a,
.user-dropdown-always>li.open>a:hover,
.user-dropdown-always>li.open>a:focus {
    background-color: rgb(162, 178, 181);
    color: rgb(55, 81, 87);
}


/* Asztalon: hagyjunk helyet a jobb szélen az admin/user-link számára, hogy ne fusson alá a dropdown ikonnak */

@media (min-width: 768px) {
    .navbar>.container>.navbar-collapse {
        padding-right: 60px;
    }
}

/* Tájkép-mobil / kis asztali (768–991px): a navbar linkek paddingje és font-mérete
   kisebb, így a jobboldali "{username} oldala" link nem ugrik új sorba a navbar-on belül. */
@media (min-width: 768px) and (max-width: 991px) {
    .navbar-nav > li > a {
        padding-left: 10px;
        padding-right: 10px;
        font-size: 16px;
    }
    .nav-separator {
        margin: 12px 8px;
    }
}


/* nav-separator: asztalon függőleges vonal, mobilon vízszintes */

.nav-separator {
    border-left: 1px solid rgba(177, 201, 203, 0.5);
    margin: 12px 16px;
    height: 26px;
    padding: 0;
    width: 0;
}

@media (max-width: 767px) {
    .nav-separator {
        border-left: none;
        border-top: 1px solid rgba(177, 201, 203, 0.5);
        margin: 6px 15px;
        height: 0;
        width: auto;
    }
}

.btn-custom {
    display: inline-block;
    /* vagy default bootstrap btn display */
    padding: 6px 20px;
    /* belső tér, növeli a szélességet */
    min-width: 150px;
    /* minimális szélesség */
    color: rgb(43, 70, 77);
    background-color: #8ea0a9;
    font-weight: bold;
    text-align: center;
    /* középre a szöveg */
    border: none;
    transition: background-color 0.15s ease, color 0.15s ease;
}


/* Hover/focus: mint a korábbi dropdown menüpontoké volt */

.btn-custom:hover,
.btn-custom:focus,
.btn-custom:active,
a.btn-custom:hover,
a.btn-custom:focus {
    background-color: rgb(170, 198, 209);
    color: #3b5860;
    text-decoration: none;
}

/* Archívum + Üzenetek gombok / tab linkek: ne maradjon fekete focus körvonal
   kattintás után (érintőképernyőn különösen csúnya). Billentyűzettel navigáláskor
   a :focus-visible-en keresztül továbbra is látható a focus. */
.btn-custom:focus,
.btn-custom:active,
#showMessagesBtn:focus,
#showMessagesBtn:active,
.nav-tabs > li.tab-label > a:focus,
.nav-tabs > li.tab-label > a:active {
    outline: none !important;
    box-shadow: none !important;
}


/* Vörös gombnál (Meccsek törlése) tartsuk a piros vonalat hoveren is, sötétebbre */

#deleteMatchesBtn.btn-custom:hover,
#deleteMatchesBtn.btn-custom:focus,
#deleteMatchesBtn.btn-custom:active {
    background-color: #b32a36 !important;
    color: #fff !important;
}


/* Szervezés csoport linkjeinek színe (alap és hover) */


/* Ez minden .btn-custom linkre érvényes a #szervezesGroups collapse-en belül*/

#szervezesGroups .btn-custom {
    color: aliceblue;
    /* text-shadow: -0.5px -0.5px 0 black, 0.5px -0.5px 0 black; */
    padding-top: 10px;
    padding-bottom: 10px;
}

#szervezesGroups .btn-custom:hover,
#szervezesGroups .btn-custom:focus,
#szervezesGroups .btn-custom:active {
    color: rgb(49, 69, 86);
}


/* Vertikális gomb-csoport kis réssel a tagok között (admin tab-tournaments jobb oszlop).
   Bootstrap 3 alapból margin-top:-1px-szel összeolvasztja a gombokat — ezt felülírjuk. */

.btn-group-vertical.spaced {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.btn-group-vertical.spaced>.btn,
.btn-group-vertical.spaced>a.btn {
    margin-top: 0 !important;
    margin-left: 0 !important;
    border-radius: 4px !important;
    float: none;
}

.points-details summary {
    cursor: pointer;
    position: relative;
    padding-left: 25px;
    /* hely a nyílnak */
    font-weight: bold;
    font-size: 16px;
    list-style: none;
    /* eltávolítja az alap nyilat */
}


/* Alap nyíl */

.points-details summary::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 8px solid rgb(14, 12, 86);
    /* nyíl színe */
    transition: transform 0.3s ease;
}


/* Nyíl elforgatása, ha open */

.points-details[open] summary::before {
    transform: translateY(-50%) rotate(180deg);
}


/* Lenyíló tartalom stílusa */

.points-details ul {
    padding: 1em 2em 1em 2em;
    margin-top: 10px;
    background: #9abac0;
    border: 1px solid rgb(135, 153, 159);
    border-radius: 6px;
}

.pontozas {
    margin-bottom: 2em;
    padding: 0.5em;
    background-color: #b3ccd1;
    border-radius: 5px;
}


/* Saját darts-stílusú gomb */

.btn-subscribe {
    background: linear-gradient(135deg, rgb(230, 240, 240), rgb(160, 186, 200));
    border: 1px solid #80a2b8;
    padding: 8px 5px 5px 5px;
    border-radius: 6px;
    color: #0d3048;
    font-weight: bold;
    text-transform: uppercase;
    font-size: 12px;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: all 0.3s ease;
}

.btn-subscribe:link {
    color: #262440;
}


/* Hover effekt: világosabb és kis árnyék */

.btn-subscribe:hover {
    background: linear-gradient(135deg, gold, brown);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
    color: white;
    text-decoration: none;
}

.btn-subscribe-ok {
    color: rgb(14, 49, 59);
    font-weight: bold;
    background-color: #b2c5c8;
    margin-right: 5px;
}

.btn-subscribe-megse {
    color: rgb(14, 49, 59);
    font-weight: bold;
    background-color: #e3eff0;
}


/* a Bejelentkezés oldalon a Maradj belépve label */

.normal-label {
    font-weight: normal;
}


/* Jobb oldali fix panel - illesztve a meglévő designhoz */

.right-panel {
    position: absolute;
    right: 20px;
    top: 100px;
    transform: translateY(-50%);
    width: 240px;
    background-color: rgb(192, 213, 217);
    /* .pontozas színvilág */
    padding: 10px;
    border-radius: 8px;
    /* border: 1px solid rgb(125, 147, 162); table border szín */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    text-align: center;
    z-index: 1000;
}


/* Gomb alap */

.right-panel button {
    width: 100%;
    padding: 10px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: bold;
    text-transform: uppercase;
    border: 1px solid #7496ad;
    cursor: pointer;
    transition: all 0.3s ease;
}


/* Regisztráció törlése */

.danger-btn {
    background: linear-gradient(135deg, rgb(230, 240, 240), rgb(160, 186, 200));
    color: rgb(9, 6, 47);
}

.danger-btn:hover {
    background: linear-gradient(135deg, gold, brown);
    color: white;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}


/* Leíratkozás */

.warning-btn {
    background: linear-gradient(155deg, rgb(237 250 254), rgb(140 161 168));
    color: rgb(9, 6, 47);
}

.warning-btn:hover {
    background: linear-gradient(135deg, gold, brown);
    color: white;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}

.home-buttons {
    display: flex;
    gap: 10px;
    /* távolság a gombok között */
}

.home-buttons form {
    margin: 0;
    /* hogy ne legyen extra térköz */
}


/* set_msg() fv. alert stílusa */

.alert {
    padding: 8px !important;
    margin-bottom: 0px;
}

.alert-with-link {
    display: flex;
    /* Flex konténer */
    justify-content: space-between;
    /* Üzenet balra, link jobbra */
    align-items: center;
    /* Vertikálisan középre */
    padding: 8px;
    /* Padding az alert-ben */
}

.right-link {
    font-weight: 600;
    text-decoration: none;
    color: #337ab7;
}

.right-link:hover {
    text-decoration: underline;
}


/*  ---------------  Dropdown nav menü -----------------*/


/* általános dropdown kinézet */

.custom-dropdown li a {
    padding: 10px 15px;
    margin: 3px 8px;
    border-radius: 4px;
    color: rgb(249, 251, 252);
    font-weight: 500;
    transition: all 0.2s;
}

.custom-dropdown li a:hover {
    background-color: #f2c230 !important;
    color: #1a3148 !important;
}

.dropdown-icon .glyphicon {
    font-size: 20px;
    vertical-align: middle;
    /* középre igazítás az szöveghez képest */
    margin-right: 0px;
    /* kis térköz a caret előtt */
}


/* kis tér a csoportok között */

.custom-dropdown .divider {
    margin: 3px 0;
}

.dropdown-menu {
    background-color: #ddd7ca;
    max-height: 50vh;
    overflow-y: auto;
}

.dropdown-menu-custom {
    background-color: #8ea0a9;
    border: none;
    border-radius: 4px;
}

.dropdown-menu-custom>li>a {
    background-color: rgb(97 113 117);
    color: rgb(222 233 235);
    font-weight: bold;
    font-size: 1em;
    padding: 6px 15px;
}

ul.dropdown-menu-custom {
    background-color: rgb(97 113 117);
}

ul.dropdown-menu.dropdown-menu-custom {
    padding: 0;
}

.dropdown-menu-custom>li>a:hover,
.dropdown-menu-custom>li>a:focus {
    background-color: rgb(170, 198, 209);
    color: #3b5860;
}

.dropdown-menu-custom>.divider {
    background-color: rgb(43, 70, 77);
    opacity: 0;
}

.dropdown-menu li {
    border-bottom: 1px solid #ddd;
}

.dropdown-menu li:last-child {
    border-bottom: none;
}


/* Regisztráció - kékes szürke */

.menu-reg {
    background-color: #5d768d;
}

.menu-reg:hover {
    background-color: #5d768d;
}


/* Regisztráció törlése - pirosas kékes szürke */

.menu-del {
    background-color: #c77e14;
}

.menu-del:hover {
    background-color: #c77e14;
}


/* Feliratkozás - zöldes szürke */

.menu-sub {
    background-color: #7aa2a5;
}

.menu-sub:hover {
    background-color: #7aa2a5;
}


/* Leiratkozás - pirosas zöldes szürke */

.menu-unsub {
    background-color: #c99b59;
}

.menu-unsub:hover {
    background-color: #c99b59;
}


/* Bejelentkezés */

.menu-login {
    color: #050a0f !important;
    background-color: #8a8f97;
}

.menu-login:hover {
    background-color: #8a8f97;
}


/* Kijelentkezés */

.menu-logout {
    color: #050a0f !important;
    background-color: #a6acb5;
}

.menu-logout:hover {
    background-color: #a6acb5;
}

.big-caret {
    margin-left: 0px;
    border-top-width: 7px;
    /* nyíl mérete */
    border-right-width: 7px;
    border-left-width: 7px;
}

.dropdown-header {
    font-size: 1em;
    color: #28424f;
    text-align: center;
}

.row {
    margin-top: 20px;
}

.table {
    border: none;
    margin-bottom: 0px;
}


/* submit buttons */

.btn-submit {
    font-weight: bold;
    color: rgb(27, 62, 91);
    background-color: rgb(150, 185, 185);
    padding-top: 8px;
}


/*  ----------- RANGLISTA táblázat stílusa ----------- */

table.table {
    width: 100%;
    /* border-collapse: collapse; */
    font-family: Arial, sans-serif;
}


/* Adatsorok stílusa */

.table th,
.table td {
    /* vastagság + szín */
    border: 1px solid rgb(125, 147, 162);
    padding: 8px;
    text-align: center;
    vertical-align: middle !important;
}


/* Fejléc stílus */

th.leaderboard-th {
    text-align: center;
    font-weight: bold;
    padding: 10px;
    border-bottom: 2px solid #333;
    /* alsó vonal */
}


/* Username oszlop jobboldali vastag vonallal */

th.username-col,
td.username-col {
    border-right: 0.15em solid #506774;
    /* vastag elválasztó vonal, 0.25em ~ 4px, ha a betűméret 16px (alapértelmezett) */
}


/* Gap oszlop teljesen átlátszó */

.gap {
    width: 20px;
    border: none !important;
    background-color: transparent;
}


/* Fejlécek és adatok vizuális konzisztenciája */

table.table th.leaderboard-th {
    background-color: rgb(150, 185, 185);
}

.table tr:first-child th {
    border-top: 2px solid rgb(125, 147, 162);
}

th.leaderboard-th.third {
    border-right: 0.2em solid #506774;
}

.table-bordered,
.table-bordered>thead>tr>th,
.table-bordered>tbody>tr>td {
    border: 1px solid #999;
}

.tbl-group-head {
    background-color: #afc9cf;
}


/* msg stílus */

#msg {
    opacity: 1;
    transition: opacity 0.5s ease;
}

#msg.fade-out {
    opacity: 0;
}

#register-form label {
    font-style: italic;
    font-weight: normal;
}


/* Panel kisebb és laposabb */

.panel {
    border-radius: 6px;
    margin-bottom: 6px;
    box-shadow: none;
}

.panel-body {
    background-color: #c0ced3;
}

.panel-body .list-group .list-group-item:hover {
    background-color: #cdd8da;
}


/* Fejléc (accordion gomb) */

.panel-heading {
    padding: 6px 10px;
    background-color: #a5bcbf;
    border-bottom: 1px solid #ddd;
}

.panel-default>.panel-heading {
    background-color: #a5bcbf;
}


/* Cím */

.panel-title {
    font-size: 16px;
    margin: 0;
}


/* Kattintható rész */

.panel-title a {
    display: block;
    text-decoration: none;
    color: #333;
}


/* Hover effekt */

.panel-title a:hover {
    color: #d5dae0;
}


/* Lista kompaktabb */

.list-group-item {
    background-color: #c0ced3;
    padding: 6px 10px;
    font-size: 13px;
}

.list-group-item a {
    font-weight: bold;
    color: #333;
}

.text-muted {
    color: #050650;
}


/* forgatható nyíl az mycontent.php Archív eredményényén */

.arrow-icon {
    font-size: 10px;
    /* kisebb ikon */
    margin-right: 6px;
    transition: transform 0.3s ease;
    display: inline-block;
    opacity: 0.6;
}


/* Nyitott állapot */

.panel-heading a[aria-expanded="true"] .arrow-icon {
    transform: rotate(180deg);
}

#showSearchBtn {
    margin-left: 10px;
    background-color: #a7c8d3;
}

#searchForm input {
    margin-top: 10px;
}

.nav-tabs>li>a {
    color: #142447;
    font-size: 18px;
    font-weight: 500;
}

.nav-tabs>li.active>a,
.nav-tabs>li.active>a:hover,
.nav-tabs>li.active>a:focus {
    color: #142447;
    font-size: 18px;
    font-weight: 600;
    background-color: rgb(186 204 211);
}

/* statistics.php tabok mobil portré nézetben egymás alá */
@media (max-width: 767px) {
    ul#statsTabs.nav-tabs {
        border-bottom: none !important;
    }
    ul#statsTabs.nav-tabs > li {
        float: none !important;
        display: block !important;
        width: 100% !important;
        margin: 0 0 3px 0 !important;
    }
    ul#statsTabs.nav-tabs > li > a {
        border-radius: 4px !important;
        margin-right: 0 !important;
        border: 1px solid #ddd !important;
    }
    ul#statsTabs.nav-tabs > li.active > a,
    ul#statsTabs.nav-tabs > li.active > a:hover,
    ul#statsTabs.nav-tabs > li.active > a:focus {
        border: 1px solid #ddd !important;
    }
}


/* TOURNAMENT.php - EREDMÉNYEK -- játékos kereső */

.search-inline {
    position: absolute;
    left: 0;
    top: 0;
    white-space: nowrap;
}


/* gomb */

.search-inline .search-btn {
    display: inline-block;
    vertical-align: middle;
}


/* max 1/3 oldal szélesség */

#searchWrapper {
    display: none;
    /* alapból zárt */
    margin-left: 5px;
    vertical-align: middle;
    max-width: 33vw;
    /* viewport szélesség 1/3-a */
    min-width: 100px;
    /* ne legyen túl kicsi */
}


/* input teljesen kitölti a wrapper-t */

#searchWrapper .form-control {
    width: 50%;
}


/* amikor megnyitod */

#searchWrapper.active {
    display: inline-block;
    /* gomb mellé kerül */
}


/* input-group ne törje a layoutot */

#searchWrapper .input-group {
    display: inline-block;
    vertical-align: middle;
    width: 100%;
}


/* egységes magasság */

.search-inline .btn,
.search-inline .form-control {
    height: 35px !important;
    padding: 4px 10px;
}

.input-group-btn .btn {
    height: 30px;
}


/* Jelszó megjelenítő szem-gomb a form-control magasságához igazodjon */

.input-group-btn .btn.toggle-pw {
    height: 34px;
}

#searchInput {
    font-size: 16px;
    /* alap 13-14px Bootstrap 3-ban */
    font-weight: 600;
}


/* ARCHIVUM TÁBLÁZAT csoportkörök */

.group-results {
    background: #4c7d88;
    padding: 5px;
    font-weight: 600;
    color: #e2e7ea;
}

.modal-dialog {
    display: inline-block;
    width: auto;
    margin: 30px auto;
}

.modal {
    text-align: center;
}


/* mycontent.php/ÜZENETEK gomb */

#showMessagesBtn {
    margin-left: 40px;
}

/* Mobilon a 3 gomb (Archívum/Keresés/Üzenetek) sortörhet — ne legyen extra bal margó,
   és adjunk kis alsó térközt, hogy a wrap-elt gombok ne ragadjanak össze függőlegesen */
@media (max-width: 767px) {
    #showMessagesBtn {
        margin-left: 0;
    }
    .clearfix > div > .btn {
        margin-bottom: 5px;
    }
}

@media (max-width: 768px) {
    .btn-subscribe-ok,
    .btn-subscribe-megse {
        display: block;
        width: 100%;
        float: none !important;
        margin: 5px 0 0 0;
    }
}


/* Admin → Versenyek tab: 2-oszlopos elrendezés mobilon egymás alá */

@media (max-width: 768px) {
    .admin-tournaments-flex {
        flex-direction: column !important;
    }
    .admin-tournaments-flex>div {
        width: 100% !important;
    }
}


/* Globális: az oldal sose görögjön vízszintesen.
   A táblázatok belül a .table-responsive wrapperben kapnak saját görgetést. */

html,
body {
    overflow-x: hidden !important;
    max-width: 100%;
}

@media (max-width: 768px) {
    .container {
        padding-left: 10px;
        padding-right: 10px;
    }
    .table-responsive {
        width: 100%;
        max-width: 100%;
    }
    /* style.css 14. sor: td { font-size: 1.2em } - mobilon kisebb és sortörhető */
    .table-responsive td,
    .table-responsive th {
        font-size: 0.85em;
        padding: 4px 6px !important;
        white-space: normal !important;
        word-break: break-word;
        overflow-wrap: anywhere;
    }
    /* Mobilon elrejtett oszlopok (admin Felhasználók tab + bárhol használható) */
    .hide-mobile {
        display: none !important;
    }
}


/* Frissítés ikon forgatás animációja (admin Versenyek tab #refreshGroupsBtn) */

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}