/* ── MODAL OVERLAY ────────────────────────────────────────────── */
.modal-overlay {
    position:        fixed;
    inset:           0;
    background:      rgba(11,31,58,0.6);
    backdrop-filter: blur(4px);
    z-index:         2000;
    display:         flex;
    align-items:     center;
    justify-content: center;
    padding:         20px;
    opacity:         0;
    pointer-events:  none;
    transition:      opacity 0.2s ease;
}

.modal-overlay.active {
    opacity:        1;
    pointer-events: auto;
}

/* ── MODAL TARTALOM ───────────────────────────────────────────── */
.modal-content {
    background:    white;
    border-radius: var(--radius-lg);
    padding:       32px;
    width:         100%;
    max-width:     540px;
    max-height:    90vh;
    overflow-y:    auto;
    box-shadow:    var(--shadow-lg);
    transform:     translateY(16px) scale(0.97);
    transition:    transform 0.25s cubic-bezier(0.4,0,0.2,1);
    position:      relative;
}

.modal-overlay.active .modal-content {
    transform: translateY(0) scale(1);
}

.modal-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    margin-bottom:   28px;
    padding-bottom:  20px;
    border-bottom:   2px solid var(--gray-light);
}

.modal-title {
    font-size:   20px;
    font-weight: 700;
    color:       var(--be-navy);
    display:     flex;
    align-items: center;
    gap:         10px;
}

.modal-title i { color: var(--be-red); }

.modal-close {
    width:         36px;
    height:        36px;
    border-radius: 50%;
    border:        none;
    background:    var(--light);
    color:         var(--gray);
    font-size:     20px;
    line-height:   1;
    transition:    var(--transition);
    display:       flex;
    align-items:   center;
    justify-content: center;
}

.modal-close:hover {
    background: var(--danger);
    color:      white;
}

/* ── ADMIN LOGIN MODAL ────────────────────────────────────────── */
.admin-login-icon {
    text-align:    center;
    font-size:     48px;
    margin-bottom: 12px;
}

.admin-login-title {
    text-align:    center;
    font-size:     22px;
    font-weight:   700;
    color:         var(--be-navy);
    margin-bottom: 6px;
}

.admin-login-sub {
    text-align:    center;
    color:         var(--gray);
    font-size:     14px;
    margin-bottom: 28px;
}

.password-input-wrap {
    position: relative;
}

.password-input-wrap input {
    padding-right: 50px;
}

.password-toggle {
    position:   absolute;
    right:      14px;
    top:        50%;
    transform:  translateY(-50%);
    background: none;
    border:     none;
    color:      var(--gray);
    font-size:  16px;
    padding:    4px;
}

.password-toggle:hover { color: var(--be-navy); }

/* ── ADMIN PANEL MODAL ────────────────────────────────────────── */
.admin-panel .modal-content {
    max-width: 680px;
}

.admin-tabs {
    display:       flex;
    gap:           4px;
    margin-bottom: 28px;
    background:    var(--light);
    border-radius: var(--radius-sm);
    padding:       4px;
}

.admin-tab {
    flex:          1;
    padding:       10px 14px;
    border-radius: 6px;
    border:        none;
    background:    transparent;
    font-weight:   600;
    font-size:     13px;
    color:         var(--gray);
    cursor:        pointer;
    transition:    var(--transition);
    text-align:    center;
    font-family:   var(--font-main);
}

.admin-tab.active {
    background: white;
    color:      var(--be-navy);
    box-shadow: var(--shadow-sm);
}

.admin-tab-content { display: none; }
.admin-tab-content.active { display: block; }

/* Megjelenítési mód rádiók */
.display-mode-options {
    display:       flex;
    flex-direction: column;
    gap:           12px;
    margin-top:    12px;
}

.display-mode-option {
    display:       flex;
    align-items:   flex-start;
    gap:           12px;
    padding:       16px;
    border:        2px solid var(--gray-light);
    border-radius: var(--radius-sm);
    cursor:        pointer;
    transition:    var(--transition);
}

.display-mode-option:has(input:checked) {
    border-color: var(--be-navy);
    background:   rgba(11,31,58,0.03);
}

.display-mode-option input[type="radio"] {
    margin-top: 3px;
    flex-shrink: 0;
    width:       18px;
    height:      18px;
    accent-color: var(--be-navy);
}

.display-mode-label { font-weight: 600; font-size: 15px; color: var(--dark); }
.display-mode-desc  { font-size: 13px; color: var(--gray); margin-top: 3px; }

/* Kiállás árak rács */
.fixture-prices-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap:                   12px;
    margin-top:            12px;
}

.fixture-price-item label {
    display:       block;
    font-size:     12px;
    font-weight:   600;
    color:         var(--gray);
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.fixture-price-item input {
    width:         100%;
    padding:       10px 14px;
    border:        1.5px solid var(--gray-light);
    border-radius: var(--radius-sm);
    font-size:     14px;
    font-family:   var(--font-main);
    color:         var(--dark);
    transition:    border-color 0.2s;
}

.fixture-price-item input:focus {
    outline:      none;
    border-color: var(--be-navy);
}

/* Admin panel alsó gombok */
.admin-footer {
    display:        flex;
    gap:            12px;
    margin-top:     28px;
    padding-top:    20px;
    border-top:     1px solid var(--gray-light);
}

.admin-footer .btn { flex: 1; }

/* Kijelentkezés gomb */
.admin-logout-btn {
    background: none;
    border:     none;
    color:      var(--gray);
    font-size:  13px;
    cursor:     pointer;
    display:    flex;
    align-items: center;
    gap:        6px;
    padding:    6px 0;
    transition: color 0.15s;
}

.admin-logout-btn:hover { color: var(--danger); }

/* ── ÉRTESÍTÉSEK ──────────────────────────────────────────────── */
#notificationContainer {
    position:   fixed;
    bottom:     24px;
    right:      24px;
    z-index:    9999;
    display:    flex;
    flex-direction: column;
    gap:        10px;
    max-width:  420px;
    pointer-events: none;
}

.notification {
    background:   white;
    border-radius: var(--radius);
    padding:      18px 20px;
    box-shadow:   var(--shadow-lg);
    display:      flex;
    align-items:  flex-start;
    gap:          14px;
    border-left:  5px solid var(--primary);
    animation:    slideInRight 0.3s ease-out;
    pointer-events: auto;
}

.notification.warning { border-left-color: var(--warning); }
.notification.error   { border-left-color: var(--danger); }
.notification.success { border-left-color: var(--success); }

.notification-icon { font-size: 20px; margin-top: 1px; color: var(--primary); }
.notification.warning .notification-icon { color: var(--warning); }
.notification.error   .notification-icon { color: var(--danger); }
.notification.success .notification-icon { color: var(--success); }

.notification-content { flex: 1; font-size: 14px; line-height: 1.5; color: var(--dark); }

.notification-close {
    background: none;
    border:     none;
    color:      var(--gray);
    font-size:  18px;
    cursor:     pointer;
    padding:    0;
    line-height: 1;
    flex-shrink: 0;
}

.notification-close:hover { color: var(--danger); }

/* ── MOBILBARÁT ───────────────────────────────────────────────── */
@media (max-width: 600px) {
    .modal-content          { padding: 22px 18px; }
    .admin-tabs             { flex-wrap: wrap; }
    .fixture-prices-grid    { grid-template-columns: 1fr 1fr; }
    #notificationContainer  { right: 12px; left: 12px; max-width: none; }
}
