/* styles.css */

/* ================================== */
/* == Változók (Színtémák) == */
/* ================================== */
/* ... (Változók változatlanok maradnak) ... */
:root {
  /* == Világos Mód (Alapértelmezett) == */
  --bg-primary: #ffffff;
  --bg-secondary: #f8f9fa;
  --bg-tertiary: #e9ecef;
  --bg-sidebar: #f1f3f5;
  --bg-message: #ffffff;
  --text-primary: #212529;
  --text-secondary: #6c757d;
  --text-accent: #007bff;
  --text-on-accent-bg: #ffffff;
  --text-on-sidebar-bg: #343a40;
  --border-primary: #dee2e6;
  --border-secondary: #ced4da;
  --border-sidebar: #adb5bd;
  --button-primary-bg: #007bff;
  --button-primary-hover-bg: #0056b3;
  --button-danger-bg: #dc3545;
  --button-danger-hover-bg: #c82333;
  --button-success-bg: #28a745;
  --button-success-hover-bg: #218838;
  --button-info-bg: #17a2b8;
  --button-info-hover-bg: #117a8b;
  --shadow-color: rgba(0, 0, 0, 0.1);
  --shadow-sm: 0 1px 2px 0 var(--shadow-color);
  --shadow-md: 0 4px 6px -1px var(--shadow-color), 0 2px 4px -1px var(--shadow-color);
  --shadow-lg: 0 10px 15px -3px var(--shadow-color), 0 4px 6px -2px var(--shadow-color);
  --modal-overlay: rgba(0, 0, 0, 0.5);
}

body.dark-mode {
  /* == Sötét Mód == */
  --bg-primary: #1e1e1e;
  --bg-secondary: #2a2a2a;
  --bg-tertiary: #333333;
  --bg-sidebar: #252525;
  --bg-message: #3b3b3b;
  --text-primary: #e9ecef;
  --text-secondary: #adb5bd;
  --text-accent: #58a6ff;
  --text-on-accent-bg: #ffffff;
  --text-on-sidebar-bg: #d4d4d4;
  --border-primary: #495057;
  --border-secondary: #555555;
  --border-sidebar: #444444;
  --button-primary-bg: #0d6efd;
  --button-primary-hover-bg: #0b5ed7;
  --button-danger-bg: #dc3545;
  --button-danger-hover-bg: #bb2d3b;
  --button-success-bg: #198754;
  --button-success-hover-bg: #157347;
  --button-info-bg: #0dcaf0;
  --button-info-hover-bg: #31d2f2;
  --shadow-color: rgba(255, 255, 255, 0.08);
  --modal-overlay: rgba(0, 0, 0, 0.8);
}

/* ================================== */
/* == Alap Stílusok & Reset == */
/* ================================== */
* { box-sizing: border-box; }
html { height: 100%; font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif; line-height: 1.5; }
body { height: 100%; margin: 0; display: flex; flex-direction: column; background-color: var(--bg-primary); color: var(--text-primary); transition: background-color 0.3s ease, color 0.3s ease; }
body:not(.login-page) { overflow: hidden; }
body:not(.login-page) html { overflow: hidden; }
.pagename { text-align: center; font-size: 1.6em; font-weight: bold; margin-bottom: 15px; color: var(--text-primary); padding-top: 20px; flex-shrink: 0; }

/* ================================== */
/* == Fő Elrendezés (main.php) == */
/* ================================== */
.chat-container { display: flex; flex-direction: column; flex: 1; overflow: hidden; width: 100%; }
.login-page .chat-container.login { flex: 0 1 auto; overflow: visible; box-shadow: var(--shadow-md); max-width: 400px; margin: 20px auto; padding: 30px; background-color: var(--bg-secondary); border-radius: 8px; text-align: center; }
.main-content { display: flex; flex: 1; overflow: hidden; }
.sidebar { width: 250px; background-color: var(--bg-sidebar); color: var(--text-on-sidebar-bg); padding: 15px; display: flex; flex-direction: column; border-right: 1px solid var(--border-primary); transition: background-color 0.3s ease, border-color 0.3s ease, width 0.3s ease; flex-shrink: 0; overflow-y: auto; }
.room-list-section, .private-chat-section, .private-partners-section, .online-users-area { margin-bottom: 20px; }
.sidebar > div:last-child { margin-bottom: 0; }
.room-list-section h3, .private-chat-section h3, .private-partners-section h3, .online-users-area h3 { text-align: center; margin-top: 0; margin-bottom: 10px; font-size: 1.1em; color: var(--text-on-sidebar-bg); padding-bottom: 8px; border-bottom: 1px solid var(--border-sidebar); }
#roomList, #conversation-list, #privateUsers, #userList { list-style: none; padding: 0; margin: 0; }
.create-room-area { margin-top: 15px; border-top: 1px solid var(--border-sidebar); padding-top: 15px; }
.create-room-area input[type="text"] { width: calc(100% - 20px); padding: 8px 10px; margin-bottom: 10px; border: 1px solid var(--border-secondary); border-radius: 4px; background-color: var(--bg-primary); color: var(--text-primary); }
.create-room-area button { width: 100%; padding: 8px 10px; background-color: var(--button-success-bg); color: var(--text-on-accent-bg); border: none; border-radius: 4px; cursor: pointer; transition: background-color 0.2s; }
.create-room-area button:hover { background-color: var(--button-success-hover-bg); }
.create-room-area .error-message { color: var(--button-danger-bg); font-size: 0.9em; margin-top: 5px; text-align: center; }
.chat-window { flex: 1; display: flex; flex-direction: column; overflow: hidden; background-color: var(--bg-secondary); }
.chat-header { padding: 10px 20px; background-color: var(--bg-tertiary); border-bottom: 1px solid var(--border-primary); flex-shrink: 0; text-align: center; }
.chat-header h2 { margin: 0; font-size: 1.2em; color: var(--text-primary); font-weight: 600; }

/* ================================== */
/* == Felső Sáv (Top Bar) == */
/* ================================== */
.top-bar { display: flex; justify-content: flex-end; align-items: center; padding: 10px 20px; background-color: var(--button-primary-bg); color: var(--text-on-accent-bg); box-shadow: var(--shadow-sm); transition: background-color 0.3s ease; flex-shrink: 0; }
.top-bar .button, .top-bar button { border: none; padding: 8px 14px; color: var(--text-on-accent-bg); cursor: pointer; border-radius: 5px; margin-left: 10px; font-size: 0.9em; background-color: transparent; transition: background-color 0.2s ease; }
.logout-button { background-color: var(--button-danger-bg); }
.logout-button:hover { background-color: var(--button-danger-hover-bg); }
.send-private-message-button { padding: 12px 20px; background: var(--button-success-bg); color: var(--text-on-accent-bg); border: none; cursor: pointer; border-radius: 20px; font-size: 1em; font-weight: 500; transition: background-color 0.2s ease; }
.dropdown { position: relative; display: inline-block; }
.dropdown-button { background-color: var(--button-info-bg); }
.dropdown-button:hover { background-color: var(--button-info-hover-bg); }
.dropdown-content { display: none; position: absolute; right: 0; top: 100%; background-color: var(--bg-primary); min-width: 160px; box-shadow: var(--shadow-lg); border: 1px solid var(--border-primary); border-radius: 5px; z-index: 11; }
.dropdown-content a { color: var(--text-primary); padding: 12px 16px; text-decoration: none; display: block; transition: background-color 0.2s ease; }
.dropdown-content a:hover { background-color: var(--bg-tertiary); }
.dropdown:hover .dropdown-content { display: block; }
.dark-mode-toggle { background: none; color: var(--text-on-accent-bg); font-size: 1.3em; line-height: 1; cursor: pointer; border: none; margin-left: 15px; padding: 5px; display: flex; align-items: center; justify-content: center; }

/* ================================== */
/* == Chat Üzenetek == */
/* ================================== */
.chat-messages { flex: 1 1 auto; overflow-y: auto; padding: 20px; -webkit-overflow-scrolling: touch; will-change: scroll-position; }
.message { padding: 10px 15px; margin-bottom: 10px; border-radius: 12px; background-color: var(--bg-message); border: 1px solid var(--border-primary); box-shadow: var(--shadow-sm); word-break: break-word; color: var(--text-primary); transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease; max-width: 80%; line-height: 1.4; }
/* Saját üzenet stílusa (megmarad a CSS-ben, de JS nem adja hozzá a class-t) */
.message.sent { margin-left: auto; margin-right: 0; background-color: var(--button-primary-bg); color: var(--text-on-accent-bg); border-color: var(--button-primary-hover-bg); }
body.dark-mode .message.sent { background-color: var(--button-primary-bg); border-color: var(--button-primary-hover-bg); color: var(--text-on-accent-bg); }
.message strong { font-weight: 600; margin-right: 5px; display: inline-block; }
.message .message-time { font-size: 0.8em; color: var(--text-secondary); margin-left: 5px; }
.message .deleted-message { font-style: italic; color: var(--text-secondary); }

/* ================================== */
/* == Chat Bevitel == */
/* ================================== */
.chat-input { display: flex; align-items: center; padding: 15px 20px; background-color: var(--bg-tertiary); border-top: 1px solid var(--border-primary); z-index: 5; transition: background-color 0.3s ease, border-color 0.3s ease; flex-shrink: 0; }
.chat-input input[type="text"] { flex: 1; padding: 12px 15px; border: 1px solid var(--border-secondary); border-radius: 20px; margin-right: 10px; color: var(--text-primary); background-color: var(--bg-primary); font-size: 1em; transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease, box-shadow 0.2s ease; }
.chat-input input[type="text"]:focus { outline: none; border-color: var(--button-primary-bg); box-shadow: 0 0 0 3px color-mix(in srgb, var(--button-primary-bg) 25%, transparent); }
body.dark-mode .chat-input input[type="text"]:focus { box-shadow: 0 0 0 3px color-mix(in srgb, var(--button-primary-bg) 30%, transparent); }
.chat-input button { padding: 12px 20px; background: var(--button-success-bg); color: var(--text-on-accent-bg); border: none; cursor: pointer; border-radius: 20px; font-size: 1em; font-weight: 500; transition: background-color 0.2s ease; flex-shrink: 0; }
.chat-input button:hover { background: var(--button-success-hover-bg); }

/* ================================== */
/* == Oldalsáv Elemek (Listák) == */
/* ================================== */
#roomList li, #conversation-list li, #privateUsers p, #userList .user-profile-link { padding: 8px 10px; cursor: pointer; color: var(--text-on-sidebar-bg); transition: background-color 0.2s ease, color 0.2s ease; text-align: left; display: block; width: 100%; background: none; border: none; border-bottom: 1px solid var(--border-sidebar); font-size: 0.95em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; text-decoration: none; }
#roomList li:last-child, #conversation-list li:last-child, #privateUsers p:last-child, #userList div:last-child .user-profile-link { border-bottom: none; }
#roomList li:hover, #conversation-list li:hover, #privateUsers p:hover, #userList .user-profile-link:hover { background-color: var(--bg-tertiary); color: var(--text-primary); }
#roomList li.active-room { background-color: var(--button-primary-bg); color: var(--text-on-accent-bg); font-weight: bold; }
body.dark-mode #roomList li.active-room { background-color: var(--button-primary-bg); color: var(--text-on-accent-bg); }
#userList div { border: none; }
.conversation-item.unread .partner-name { font-weight: bold; }
.unread-badge { display: inline-block; min-width: 18px; height: 18px; padding: 0 5px; margin-left: 8px; font-size: 0.8em; font-weight: bold; line-height: 18px; color: white; text-align: center; white-space: nowrap; vertical-align: middle; background-color: var(--button-danger-bg); border-radius: 9px; box-shadow: var(--shadow-sm); float: right; }

/* ================================== */
/* == Modális Ablak (Privát Chat) == */
/* ================================== */
.modal { display: none; position: fixed; z-index: 100; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: var(--modal-overlay); }
.modal-content { background-color: var(--bg-primary); color: var(--text-primary); margin: 10% auto; padding: 25px; border: 1px solid var(--border-secondary); border-radius: 8px; width: 80%; max-width: 600px; box-shadow: var(--shadow-lg); position: relative; transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease; display: flex; flex-direction: column; max-height: 80vh; overflow: hidden; }
.modal .close { color: var(--text-secondary); position: absolute; top: 10px; right: 15px; font-size: 28px; font-weight: bold; cursor: pointer; line-height: 1; transition: color 0.2s ease; }
.modal .close:hover, .modal .close:focus { color: var(--text-primary); text-decoration: none; }
.modal h3#modalTitle { margin-top: 0; margin-bottom: 15px; padding-right: 150px; flex-shrink: 0; }
.modal #blockUserButton, .modal #reportConversationButton { position: absolute; top: 12px; padding: 4px 8px; font-size: 0.8em; border: none; border-radius: 4px; cursor: pointer; transition: background-color 0.2s ease; flex-shrink: 0; color: var(--text-on-accent-bg); }
.modal #blockUserButton { right: 50px; background-color: var(--button-danger-bg); }
.modal #blockUserButton:hover { background-color: var(--button-danger-hover-bg); }
/* JAVÍTVA: Jelentés gomb színe visszaállítva */
.modal #reportConversationButton { right: 125px; background-color: var(--button-danger-bg); }
.modal #reportConversationButton:hover { background-color: var(--button-danger-hover-bg); }
.modal-messages { flex: 1 1 auto; overflow-y: auto; border: 1px solid var(--border-primary); background-color: var(--bg-secondary); padding: 10px; margin-top: 5px; margin-bottom: 15px; border-radius: 5px; min-height: 100px; }
.modal-messages div { margin-bottom: 5px; font-size: 0.95em; word-break: break-word; line-height: 1.4; }
.modal-messages div strong { color: var(--text-accent); margin-right: 3px; font-weight: 600; }
/* Időbélyeg stílus (JS formázza) */
.modal-messages div span { font-size: 0.85em; color: var(--text-secondary); margin-left: 5px; }
.modal .chat-input { position: static; padding: 10px 15px; border-top: 1px solid var(--border-primary); flex-shrink: 0; margin: 0 -25px -25px -25px; border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; }
.modal .chat-input input[type="text"] { padding: 10px 12px; font-size: 0.95em; }
.modal .chat-input button { padding: 10px 15px; font-size: 0.95em; }

/* ================================== */
/* == Bejelentkező Oldal (index.html) Stílusok == */
/* ================================== */
body.login-page { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 100vh; padding: 20px; overflow-y: auto; }
body.login-page html { overflow-y: auto; }
.login-page .pagename { margin-bottom: 30px; font-size: 2em; }
.login-page form label { display: block; margin-bottom: 5px; text-align: left; color: var(--text-secondary); font-weight: 500; }
.login-page form input[type="text"], .login-page form input[type="password"] { width: 100%; padding: 12px; margin-bottom: 15px; border: 1px solid var(--border-secondary); border-radius: 4px; background-color: var(--bg-primary); color: var(--text-primary); font-size: 1em; }
.login-page form input[type="text"]:focus, .login-page form input[type="password"]:focus { outline: none; border-color: var(--button-primary-bg); box-shadow: 0 0 0 3px color-mix(in srgb, var(--button-primary-bg) 25%, transparent); }
body.dark-mode .login-page form input[type="text"]:focus, body.dark-mode .login-page form input[type="password"]:focus { box-shadow: 0 0 0 3px color-mix(in srgb, var(--button-primary-bg) 30%, transparent); }
.login-page form button { padding: 12px 20px; border: none; border-radius: 4px; cursor: pointer; font-size: 1em; font-weight: 500; margin: 10px 5px; transition: background-color 0.2s ease, transform 0.1s ease; }
.login-page form button:active { transform: scale(0.98); }
.login-page form button[type="submit"] { background-color: var(--button-success-bg); color: var(--text-on-accent-bg); }
.login-page form button[type="submit"]:hover { background-color: var(--button-success-hover-bg); }
.login-page form button[type="button"] { background-color: var(--button-info-bg); color: var(--text-on-accent-bg); }
.login-page form button[type="button"]:hover { background-color: var(--button-info-hover-bg); }
.login-page footer { margin-top: 40px; padding-bottom: 20px; text-align: center; width: 100%; }
.login-page footer a { color: var(--text-secondary); text-decoration: none; margin: 0 15px; transition: color 0.2s ease; font-size: 0.9em; }
.login-page footer a:hover { color: var(--text-primary); text-decoration: underline; }

/* ================================== */
/* == Mobilnézet (Reszponzivitás) == */
/* ================================== */
/* --- Tablet nézet (Pl. 768px alatt) --- */
@media (max-width: 768px) {
  .sidebar { width: 200px; padding: 10px; }
  .chat-input { padding: 10px 15px; }
  .chat-input input[type="text"] { padding: 10px 12px; font-size: 0.95em; }
  .chat-input button { padding: 10px 15px; font-size: 0.95em;}
  .top-bar { padding: 8px 15px; }
  .top-bar .button, .top-bar button, .logout-button, .dropdown-button { padding: 6px 10px; font-size: 0.85em; margin-left: 8px; }
  .dark-mode-toggle { font-size: 1.2em; margin-left: 10px; }
  .chat-messages { padding: 15px; }
  .message { max-width: 90%; padding: 8px 12px; }
  #roomList li, #conversation-list li, #privateUsers p, #userList .user-profile-link { padding: 8px 10px; font-size: 0.9em; }
  .modal-content { width: 90%; max-width: 500px; }
}

/* --- Kis mobil nézet (Pl. 600px alatt) --- */
@media (max-width: 600px) {
  .main-content { flex-direction: column; }
  .sidebar { width: 100%; max-height: 45vh; border-right: none; border-bottom: 1px solid var(--border-primary); padding: 10px; overflow-y: auto; }
  .sidebar .room-list-section, .sidebar .private-chat-section, .sidebar .private-partners-section, .sidebar .online-users-area { height: auto; overflow-y: visible; margin-bottom: 15px; border-bottom: none; padding: 0; }
  .sidebar > div:last-child { margin-bottom: 0; }
  .sidebar h3 { margin-bottom: 8px; padding-bottom: 5px; font-size: 1em; text-align: left; }
  #roomList li, #conversation-list li, #privateUsers p, #userList .user-profile-link { padding: 6px 8px; font-size: 0.9em; border-bottom: 1px solid var(--border-sidebar); }
  #roomList li:last-child, #conversation-list li:last-child, #privateUsers p:last-child, #userList div:last-child .user-profile-link { border-bottom: none; }
  .chat-window { flex: 1; min-height: 0; }
  .chat-header { padding: 8px 15px; }
  .chat-header h2 { font-size: 1.1em; }
  .chat-messages { padding: 10px; }
  .chat-input { padding: 8px 10px; }
   .chat-input input[type="text"] { font-size: 0.9em; padding: 8px 12px; }
   .chat-input button { font-size: 0.9em; padding: 8px 12px; }
  .modal-content { width: 95%; margin: 5vh auto; padding: 15px; max-height: 90vh; }
  .modal h3#modalTitle { margin-bottom: 10px; padding-right: 140px; font-size: 1.1em; }
   .modal #blockUserButton { top: 8px; right: 45px; padding: 3px 6px; font-size: 0.75em; }
    .modal #reportConversationButton { top: 8px; right: 105px; padding: 3px 6px; font-size: 0.75em; }
  .modal .close { top: 8px; right: 12px; font-size: 24px; }
  .modal-messages { flex: 1; margin-top: 5px; margin-bottom: 10px; padding: 8px; }
   .modal-messages div { font-size: 0.9em; }
  .modal .chat-input { padding: 10px; margin: 0 -15px -15px -15px; }
  .modal .chat-input input { padding: 8px 10px; font-size: 0.9em; }
  .modal .chat-input button { padding: 8px 12px; font-size: 0.9em; }
  .login-page .chat-container.login { max-width: 95%; padding: 20px; }
  .login-page form button { padding: 10px 15px; font-size: 0.95em; }
  .login-page footer a { margin: 0 8px; }
}

/* Kisegítő osztályok */
.error-message { color: var(--button-danger-bg); font-size: 0.9em; margin-top: 5px; }

.search-container {
    position: relative;
    display: inline-block;
    margin: 0 10px;
}

.search-icon-button {
    background: none;
    border: none;
    font-size: 1.2rem;
    cursor: pointer;
    padding: 5px;
}

.search-wrapper {
    position: absolute;
    top: 40px;
    right: 0;
    z-index: 1000;
    background: white;
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 5px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.search-results-dropdown {
    max-height: 200px;
    overflow-y: auto;
    width: 200px;
}

.search-result-item {
    padding: 8px;
    cursor: pointer;
    border-bottom: 1px solid #eee;
    color: #333;
}

.search-result-item:hover {
    background-color: #f0f0f0;
}

/* Dark mode esetén */
body.dark-mode .search-wrapper {
    background: #2c2c2c;
    border-color: #444;
}
body.dark-mode .search-result-item {
    color: #eee;
}
.gallery-card {
    position: relative;
    width: 180px;
    height: 180px;
    overflow: hidden;
}

.gallery-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gallery-delete-btn {
    position: absolute;
    top: 5px;
    right: 5px;
    z-index: 99999;
}
.gallery-card {
    position: relative;
    width: 130px;
    min-height: 160px;
    overflow: hidden;
}

.gallery-card img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    display: block;
}

.gallery-private-box {
    width: 100%;
    height: 120px;
    background: #222;
    color: white;
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-weight: bold;
}

.gallery-private-box small {
    font-size: 0.75em;
    opacity: 0.8;
}

.gallery-delete-btn {
    margin-top: 6px;
}