/* ================================================================
   LAYOUT.CSS — TurkSesli Premium Layout
   3-Column: Left Sidebar | Center Chat | Right Panel
   Mobile-first responsive
   ================================================================ */

#main-screen {
    width: 100%; height: 100vh;
    display: flex; flex-direction: column;
    position: relative; z-index: 1;
}

/* ── Top Room Bar ── */
.top-rooms-bar {
    display: flex; align-items: center; gap: 6px;
    padding: 6px 14px;
    background: rgba(2, 6, 18, 0.75);
    border-bottom: 1px solid var(--border-faint);
    flex-shrink: 0; overflow-x: auto; scrollbar-width: none;
    backdrop-filter: blur(12px);
    position: relative; z-index: 2;
}
.top-rooms-bar::-webkit-scrollbar { display: none; }
.top-rooms-label { font-size: 11px; opacity: 0.3; flex-shrink: 0; }
.top-rooms-title {
    font-size: 10px; font-weight: 700;
    color: var(--sapphire-light);
    text-transform: uppercase; letter-spacing: 1.4px;
    flex-shrink: 0;
    font-family: var(--font-body);
    opacity: 0.75;
}
.top-rooms-sep {
    width: 1px; height: 14px;
    background: var(--border-soft);
    flex-shrink: 0;
    margin: 0 2px;
}

.horizontal-room-list { list-style:none; padding:0; margin:0; display:flex; gap:3px; flex-wrap:nowrap; }
.horizontal-room-list .room-item {
    padding: 4px 11px;
    border-radius: var(--r-full);
    background: transparent;
    border: 1px solid transparent;
    font-size: 11px; font-weight: 500; color: var(--text-muted);
    cursor: pointer; white-space: nowrap;
    transition: all 0.2s var(--ease-io);
    display: flex; align-items: center; gap: 5px;
    font-family: var(--font-body);
}
.horizontal-room-list .room-item:hover {
    background: rgba(255,255,255,0.06);
    border-color: var(--border-soft);
    color: var(--text-primary);
}
.horizontal-room-list .room-item.active-room {
    background: rgba(59,130,246,0.12);
    border-color: rgba(59,130,246,0.35);
    color: var(--sapphire-light);
    box-shadow: 0 0 12px rgba(59,130,246,0.1);
}

/* ── 3-Column Container ── */
.chat-container {
    display: flex; flex: 1; min-height: 0;
    padding: 10px; gap: 8px;
    position: relative; z-index: 1;
}

/* ================================================================
   LEFT SIDEBAR
   ================================================================ */
.sidebar {
    width: 196px; min-width: 196px; max-width: 196px;
    display: flex; flex-direction: column;
    border-radius: var(--r-lg);
    background: var(--glass-light);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255,255,255,0.04);
    overflow: hidden;
    transition: box-shadow 0.3s;
}

/* Header: logo + icon buttons */
.sidebar-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 11px 8px;
    border-bottom: 1px solid var(--border-faint);
    flex-shrink: 0;
}
.site-logo {
    max-width: 88px; height: 28px; object-fit: contain;
    filter: none;
    flex-shrink: 0;
}

.sidebar-header-btns { display: flex; align-items: center; gap: 2px; }
.hdr-btn {
    width: 26px; height: 26px;
    border-radius: var(--r-sm);
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-muted);
    font-size: 11px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.2s var(--ease-io); padding: 0;
    position: relative;
}
.hdr-btn:hover {
    background: rgba(255,255,255,0.07);
    border-color: var(--border-soft);
    color: var(--text-primary);
}
.hdr-btn:hover::after {
    content: attr(title);
    position: absolute; bottom: -28px; left: 50%;
    transform: translateX(-50%);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    color: var(--text-secondary);
    font-size: 10px; white-space: nowrap;
    padding: 3px 8px; border-radius: var(--r-xs);
    pointer-events: none; z-index: 100;
    font-family: var(--font-body);
}
.hdr-btn-danger:hover {
    background: rgba(239,68,68,0.1);
    border-color: rgba(239,68,68,0.3);
    color: #f87171;
}

/* Users section */
.sidebar-users-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 11px 5px;
    font-size: 9px; font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase; letter-spacing: 1.2px;
    flex-shrink: 0;
    font-family: var(--font-body);
}

.sidebar-users { flex: 1; overflow-y: auto; padding: 3px 6px 6px; min-height: 0; }
#user-list { list-style: none; padding: 0; margin: 0; }

/* User items — compact & elegant */
.user-item {
    display: flex; align-items: center;
    padding: 5px 6px;
    border-radius: var(--r-sm);
    margin-bottom: 2px;
    border: 1px solid transparent;
    transition: all 0.18s var(--ease-io); cursor: pointer;
    position: relative;
}
.user-item:hover {
    background: rgba(59,130,246,0.08);
    border-color: rgba(59,130,246,0.15);
}
.user-avatar {
    width: 27px; height: 27px;
    border-radius: var(--r-sm);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    display: flex; justify-content: center; align-items: center;
    font-weight: 700; color: var(--text-secondary);
    margin-right: 8px; font-size: 10px;
    position: relative; flex-shrink: 0;
    font-family: var(--font-display);
    overflow: hidden;
    background-size: cover; background-position: center;
}
.user-item.is-me .user-avatar {
    background: linear-gradient(135deg, var(--sapphire), var(--cyan));
    border-color: transparent;
    box-shadow: 0 0 10px rgba(59,130,246,0.3);
}
.online-dot {
    width: 7px; height: 7px;
    background: var(--cyan);
    border-radius: var(--r-full);
    position: absolute; bottom: -1px; right: -1px;
    border: 1.5px solid var(--bg-base);
    box-shadow: 0 0 6px rgba(6,182,212,0.5);
}
.user-info-container { flex: 1; overflow: hidden; min-width: 0; }
.user-name-text {
    font-size: 11.5px; font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    transition: color 0.15s;
    font-family: var(--font-body);
}
.user-item:hover .user-name-text { color: var(--sapphire-light); }
.user-role-text { font-size: 9.5px; color: var(--text-muted); margin-top: 1px; }
.role-badge-admin {
    color: var(--cyan-light); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.5px;
}
.role-badge-mod { color: var(--violet-light); font-weight: 700; text-transform: uppercase; }
.user-actions { display: flex; align-items: center; gap: 2px; flex-wrap: wrap; }
.afk-dot {
    position: absolute; bottom: -5px; right: -5px;
    font-size: 9px; background: var(--bg-base);
    border-radius: var(--r-full); width: 13px; height: 13px;
    display: flex; justify-content: center; align-items: center;
}

/* ================================================================
   CENTER CHAT AREA
   ================================================================ */
.chat-area {
    flex: 1; min-width: 0;
    display: flex; flex-direction: column;
    border-radius: var(--r-lg);
    background: var(--glass-light);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255,255,255,0.04);
    overflow: hidden;
}

#messages-area {
    flex: 1; padding: 16px 18px;
    overflow-y: auto;
    display: flex; flex-direction: column; gap: 6px;
    scroll-behavior: smooth;
}

/* Toolbar */
.chat-toolbar {
    background: rgba(3, 7, 18, 0.7);
    padding: 5px 10px;
    display: flex; gap: 3px; align-items: center;
    border-bottom: 1px solid var(--border-faint);
    flex-shrink: 0; overflow-x: auto; scrollbar-width: none;
    backdrop-filter: blur(8px);
}
.chat-toolbar::-webkit-scrollbar { display: none; }
.toolbar-sep { width: 1px; height: 16px; background: var(--border-faint); margin: 0 4px; flex-shrink: 0; }

.toolbar-btn {
    background: transparent;
    color: var(--text-muted);
    border: 1px solid transparent;
    padding: 4px 8px;
    border-radius: var(--r-xs);
    cursor: pointer; font-weight: 600;
    font-size: 11.5px;
    transition: all 0.18s var(--ease-io);
    font-family: var(--font-body);
    white-space: nowrap;
}
.toolbar-btn:hover {
    background: rgba(255,255,255,0.07);
    border-color: var(--border-soft);
    color: var(--text-primary);
}
.toolbar-btn.active {
    background: rgba(59,130,246,0.15);
    border-color: rgba(59,130,246,0.4);
    color: var(--sapphire-light);
}
.chat-toolbar .font-size-btn {
    background: rgba(6,182,212,0.08) !important;
    color: var(--cyan-light) !important;
    border: 1px solid rgba(6,182,212,0.2) !important;
    font-weight: 700; font-family: var(--font-mono) !important; font-size: 10px !important;
}
.chat-toolbar .font-size-btn:hover {
    background: rgba(6,182,212,0.18) !important;
    border-color: rgba(6,182,212,0.4) !important;
}

/* Input area */
.input-area {
    display: flex; padding: 8px 12px;
    background: rgba(2,5,16,0.6);
    gap: 8px; align-items: center;
    border-top: 1px solid var(--border-faint);
    flex-shrink: 0; backdrop-filter: blur(12px);
}
.input-area input {
    flex: 1; padding: 10px 14px;
    background: rgba(8,14,28,0.8);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    color: var(--text-primary);
    font-size: 13px; outline: none;
    font-family: var(--font-body);
    transition: all 0.25s var(--ease-io);
    box-shadow: inset 0 2px 6px rgba(0,0,0,0.3);
}
.input-area input::placeholder { color: var(--text-muted); }
.input-area input:focus {
    border-color: rgba(59,130,246,0.4);
    background: rgba(5,10,22,0.9);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.12), inset 0 2px 6px rgba(0,0,0,0.3);
}
.input-area button {
    padding: 0 20px; height: 38px;
    background: linear-gradient(135deg, var(--sapphire) 0%, var(--cyan) 100%);
    color: #fff; border: none; border-radius: var(--r-md);
    cursor: pointer; font-weight: 700; font-size: 12.5px;
    font-family: var(--font-body);
    transition: all 0.25s var(--ease-out);
    box-shadow: 0 3px 16px rgba(59,130,246,0.35), inset 0 1px 0 rgba(255,255,255,0.12);
    flex-shrink: 0; letter-spacing: 0.02em;
    position: relative; overflow: hidden;
}
.input-area button::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.12), transparent);
    opacity: 0; transition: opacity 0.2s;
}
.input-area button:hover { transform: translateY(-1px); box-shadow: 0 6px 22px rgba(59,130,246,0.5); }
.input-area button:hover::before { opacity: 1; }
.input-area button:active { transform: translateY(0); }

/* ================================================================
   RIGHT PANEL
   ================================================================ */
.right-panel {
    width: 182px; min-width: 182px; max-width: 182px;
    display: flex; flex-direction: column; gap: 7px;
    overflow-y: auto; scrollbar-width: none;
}
.right-panel::-webkit-scrollbar { display: none; }

.right-panel-card {
    border-radius: var(--r-lg);
    background: var(--glass-light);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,0.04);
    overflow: hidden; flex-shrink: 0;
}

.right-panel-title {
    font-size: 8.5px; font-weight: 700; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: 1.4px;
    padding: 9px 11px 7px;
    border-bottom: 1px solid var(--border-faint);
    display: flex; align-items: center; gap: 6px;
    font-family: var(--font-body);
}
.right-panel-title .rpt-accent {
    width: 14px; height: 2px;
    background: linear-gradient(90deg, var(--sapphire), var(--cyan));
    border-radius: var(--r-full);
    flex-shrink: 0;
}

.right-panel-tools { padding: 5px; display: flex; flex-direction: column; gap: 3px; }
.tool-sep { height: 1px; background: var(--border-faint); margin: 3px 0; }

.tool-btn {
    width: 100%; padding: 7px 9px;
    border-radius: var(--r-sm);
    border: 1px solid transparent;
    background: transparent;
    color: var(--text-muted);
    font-size: 11px; font-weight: 500; cursor: pointer;
    transition: all 0.18s var(--ease-io);
    text-align: left; display: flex; align-items: center; gap: 7px;
    font-family: var(--font-body);
}
.tool-btn:hover {
    background: rgba(255,255,255,0.06);
    border-color: var(--border-soft);
    color: var(--text-primary);
    transform: translateX(2px);
}
.tool-btn .tool-icon { font-size: 13px; flex-shrink: 0; }
.tool-btn.purple { color: #c084fc; }
.tool-btn.purple:hover { background: rgba(124,58,237,0.12); border-color: rgba(124,58,237,0.3); }
.tool-btn.orange { color: var(--warning); }
.tool-btn.orange:hover { background: rgba(245,158,11,0.1); border-color: rgba(245,158,11,0.25); }
.tool-btn.brown { color: #c8956a; }
.tool-btn.brown:hover { background: rgba(139,69,19,0.12); border-color: rgba(139,69,19,0.3); }
.tool-btn-warning { color: #f59e0b !important; }
.tool-btn-warning:hover { background: rgba(245,158,11,0.12) !important; border-color: rgba(245,158,11,0.35) !important; }
.tool-btn-info { color: #60a5fa !important; }
.tool-btn-info:hover { background: rgba(59,130,246,0.12) !important; border-color: rgba(59,130,246,0.35) !important; }

/* Voice status */
.voice-status-badge {
    display: flex; align-items: center; gap: 7px;
    padding: 8px 10px; font-size: 11px; font-weight: 500;
    border-radius: var(--r-sm); border: 1px solid var(--border-faint);
    color: var(--text-muted); background: rgba(0,0,0,0.2);
    transition: all 0.3s var(--ease-out);
    font-family: var(--font-body);
}
.voice-status-badge.listening { border-color: rgba(6,182,212,0.3); color: var(--cyan-light); background: rgba(6,182,212,0.07); animation: pulse-badge 2s infinite; --badge-glow: rgba(6,182,212,0.3); }
.voice-status-badge.speaking  { border-color: rgba(59,130,246,0.35); color: var(--sapphire-light); background: rgba(59,130,246,0.09); animation: pulse-badge 2s infinite; --badge-glow: rgba(59,130,246,0.3); }
.voice-status-badge.radio     { border-color: rgba(124,58,237,0.3); color: var(--violet-light); background: rgba(124,58,237,0.08); animation: pulse-badge 2s infinite; --badge-glow: rgba(124,58,237,0.3); }
.voice-status-badge.muted     { border-color: rgba(239,68,68,0.25); color: #f87171; background: rgba(239,68,68,0.07); }
@keyframes pulse-badge {
    0%, 100% { box-shadow: 0 0 0 0 var(--badge-glow, transparent); }
    50% { box-shadow: 0 0 0 4px transparent; }
}

.voice-controls { display: flex; flex-direction: column; gap: 4px; }

.voice-btn {
    display: flex; align-items: center; justify-content: center; gap: 7px;
    padding: 9px 8px; border-radius: var(--r-sm);
    border: 1px solid var(--border-soft);
    background: rgba(255,255,255,0.03);
    color: var(--text-secondary);
    font-size: 11px; font-weight: 600; cursor: pointer;
    transition: all 0.2s var(--ease-out);
    font-family: var(--font-body);
}
.voice-btn:hover { background: rgba(255,255,255,0.08); border-color: var(--border-mid); color: var(--text-primary); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.voice-btn.mic-active { background: rgba(239,68,68,0.1); color: #f87171; border-color: rgba(239,68,68,0.35); box-shadow: 0 0 16px rgba(239,68,68,0.15); }
.voice-btn.radio-btn { color: var(--violet-light); border-color: rgba(124,58,237,0.25); background: rgba(124,58,237,0.07); }
.voice-btn.hand-btn { color: var(--cyan-light); border-color: rgba(6,182,212,0.25); background: rgba(6,182,212,0.07); }

/* Mixer */
.mixer-row { display: flex; align-items: center; gap: 7px; margin-bottom: 5px; }
.mixer-row label { color: var(--cyan-light); font-size: 10px; width: 52px; font-weight: 600; display: flex; align-items: center; gap: 4px; font-family: var(--font-body); }
.mixer-row input[type=range] { flex: 1; cursor: pointer; height: 3px; background: rgba(255,255,255,0.08); border-radius: var(--r-full); outline: none; -webkit-appearance: none; }
.mixer-row input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; width: 13px; height: 13px; border-radius: var(--r-full); background: linear-gradient(135deg, var(--sapphire), var(--cyan)); cursor: pointer; box-shadow: 0 0 8px var(--sapphire-glow); }
.mixer-row .mute-icon { cursor: pointer; font-size: 13px; transition: transform 0.2s; opacity: 0.7; }
.mixer-row .mute-icon:hover { transform: scale(1.2); opacity: 1; }

/* ================================================================
   MOBILE — Profesyonel Tam Yeniden Tasarım
   ================================================================ */
.mobile-nav-bar { display: none; }
/* Overlay tamamen kaldırıldı — dışarı tıklama JS ile yönetiliyor */
.mobile-overlay { display: none !important; pointer-events: none !important; }
.mob-drawer-header { display: none; }

@media (max-width: 1024px) {
    .sidebar { width: 178px; min-width: 178px; max-width: 178px; }
    .right-panel { width: 166px; min-width: 166px; max-width: 166px; }
    .chat-container { padding: 8px; gap: 7px; }
}

@media (max-width: 768px) {
    /* ── TEMEL LAYOUT ── */
    body { overflow: hidden; }
    #main-screen {
        height: 100dvh;
        /* Alt nav 60px fixed — içerik o kadar kısa olmalı */
        padding-bottom: 60px;
        display: flex; flex-direction: column;
        box-sizing: border-box;
    }
    .chat-container {
        padding: 0; gap: 0; flex: 1; min-height: 0;
        flex-direction: row; /* sol sidebar, orta chat - drawer ile yönetilir */
        position: relative;
    }

    /* ── ÜST ODA BARI ── */
    .top-rooms-bar {
        padding: 5px 12px;
        background: rgba(2, 5, 16, 0.95);
        border-bottom: 1px solid rgba(255,255,255,0.06);
        flex-shrink: 0;
    }
    .top-rooms-title { font-size: 9px; }
    .horizontal-room-list .room-item { font-size: 10.5px; padding: 4px 10px; }

    /* ── SOL SIDEBAR (KİŞİLER DRAWER) ── */
    .sidebar {
        position: fixed;
        top: 38px; left: 0;
        width: 82vw; max-width: 300px;
        height: calc(100dvh - 38px);
        z-index: 900;
        transform: translateX(-100%);
        transition: transform 0.32s cubic-bezier(0.16, 1, 0.3, 1);
        border-radius: 0 16px 16px 0;
        border-left: none;
        border-right: 1px solid rgba(59,130,246,0.15);
        background: #060d1e !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        display: flex; flex-direction: column;
        overflow: hidden;
        box-shadow: none;
    }
    .sidebar.mobile-open {
        transform: translateX(0);
        box-shadow: 8px 0 40px rgba(0,0,0,0.5);
    }

    /* Sidebar mobil header — 2 satır: başlık + butonlar */
    .mob-drawer-header {
        display: flex !important;
        flex-direction: column;
        gap: 0;
        border-bottom: 1px solid rgba(255,255,255,0.07);
        background: rgba(5,12,30,0.95);
        flex-shrink: 0;
    }

    /* Üst satır: başlık + kapat */
    .mob-drawer-top-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 12px 14px 8px;
    }

    /* Alt satır: aksiyon butonları */
    .mob-drawer-btn-row {
        display: flex;
        align-items: center;
        gap: 6px;
        padding: 0 12px 12px;
        flex-wrap: wrap;
    }

    .mob-drawer-title {
        font-size: 13px; font-weight: 700;
        color: #f0f4ff;
        font-family: var(--font-body);
        display: flex; align-items: center; gap: 7px;
    }

    /* Mobil header butonları — tam etiketli */
    .mob-hdr-btn {
        display: inline-flex; align-items: center; gap: 5px;
        height: 34px; padding: 0 10px;
        border-radius: 8px;
        background: rgba(255,255,255,0.06);
        border: 1px solid rgba(255,255,255,0.09);
        color: rgba(200,215,235,0.9);
        font-size: 12px; font-weight: 500;
        cursor: pointer;
        font-family: var(--font-body);
        -webkit-tap-highlight-color: transparent;
        white-space: nowrap;
    }
    .mob-hdr-btn:active { transform: scale(0.94); background: rgba(255,255,255,0.13); }
    .mob-hdr-btn-danger {
        color: #f87171;
        background: rgba(239,68,68,0.1);
        border-color: rgba(239,68,68,0.2);
    }
    .mob-hdr-btn-danger:active { background: rgba(239,68,68,0.2); }

    .mob-drawer-close {
        width: 32px; height: 32px;
        border-radius: 8px;
        background: rgba(255,255,255,0.05);
        border: 1px solid rgba(255,255,255,0.08);
        color: rgba(148,163,184,0.8);
        font-size: 14px; cursor: pointer;
        display: flex; align-items: center; justify-content: center;
        -webkit-tap-highlight-color: transparent;
    }
    .mob-drawer-close:active { background: rgba(239,68,68,0.15); color: #f87171; }

    /* Sidebar normal header mobilde gizle */
    .sidebar-header { display: none; }

    .sidebar-users-header {
        padding: 8px 14px 5px;
        font-size: 9px;
    }
    .sidebar-users { flex: 1; overflow-y: auto; padding: 4px 8px 8px; }
    .user-item { padding: 10px 10px; margin-bottom: 2px; }
    .user-name-text { font-size: 13px !important; }

    /* ── SAĞ PANEL (ARAÇLAR) — Alt Sheet Stili ── */
    .right-panel {
        position: fixed;
        bottom: 60px; right: 0; left: 0;
        width: 100%; max-width: 100%;
        max-height: 65dvh;
        z-index: 800;
        transform: translateY(110%);
        transition: transform 0.32s cubic-bezier(0.16, 1, 0.3, 1);
        border-radius: 20px 20px 0 0;
        background: #060d1e !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        border: 1px solid rgba(255,255,255,0.08);
        border-bottom: none;
        padding: 0;
        overflow-y: auto;
        flex-direction: column;
        box-shadow: 0 -8px 40px rgba(0,0,0,0.7);
    }
    .right-panel.mobile-open {
        transform: translateY(0);
    }

    /* Sağ panel iç padding */
    .right-panel > * { padding-left: 16px; padding-right: 16px; }
    .right-panel .right-panel-card {
        border-radius: 0; border: none;
        border-bottom: 1px solid rgba(255,255,255,0.05);
        background: transparent;
        box-shadow: none;
    }
    .right-panel .right-panel-card:last-child { border-bottom: none; }

    /* Sağ panel drag handle */
    .right-panel::before {
        content: '';
        display: block;
        width: 36px; height: 4px;
        background: rgba(255,255,255,0.15);
        border-radius: 2px;
        margin: 10px auto 6px;
        flex-shrink: 0;
    }

    /* ── CHAT ALANI ── */
    .chat-area {
        flex: 1; min-width: 0; min-height: 0;
        border-radius: 0; border: none;
        border-top: 1px solid rgba(255,255,255,0.05);
        display: flex; flex-direction: column;
    }

    /* Mesaj alanı — alt nav için padding */
    #messages-area {
        padding: 12px 14px;
        padding-bottom: 10px;
        flex: 1; min-height: 0;
    }

    /* ── TOOLBAR — chat-toolbar.css'de yönetiliyor ── */

    /* ── GİRİŞ ALANI ── */
    .input-area {
        padding: 8px 10px;
        padding-bottom: max(8px, env(safe-area-inset-bottom, 0px));
        background: rgba(4, 8, 22, 0.98);
        border-top: 1px solid rgba(255,255,255,0.06);
        gap: 8px;
        flex-shrink: 0;
    }
    .input-area input {
        padding: 11px 14px;
        font-size: 15px; /* iOS zoom engelleme */
        border-radius: 22px;
    }
    .input-area button {
        padding: 0 18px; height: 42px;
        font-size: 13px;
        border-radius: 22px;
        flex-shrink: 0;
    }

    /* ── MOBİL ALT NAV ── */
    .mobile-nav-bar {
        display: flex !important;
        position: fixed; bottom: 0; left: 0; right: 0;
        height: 60px;
        background: rgba(4, 7, 18, 0.98);
        border-top: 1px solid rgba(255,255,255,0.07);
        z-index: 600;
        align-items: stretch;
        padding-bottom: env(safe-area-inset-bottom, 0px);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .mob-nav-btn {
        flex: 1;
        display: flex; flex-direction: column;
        align-items: center; justify-content: center;
        gap: 4px;
        background: transparent; border: none;
        color: rgba(100,116,139,0.8);
        cursor: pointer;
        transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
        padding: 0; position: relative;
        -webkit-tap-highlight-color: transparent;
    }
    /* Nav buton ikon container */
    .mob-nav-icon {
        width: 28px; height: 28px;
        display: flex; align-items: center; justify-content: center;
        border-radius: 9px;
        transition: all 0.22s cubic-bezier(0.16, 1, 0.3, 1);
        font-size: 17px;
    }
    .mob-nav-btn span.mob-label {
        font-size: 9.5px; font-weight: 600;
        letter-spacing: 0.1px;
        font-family: var(--font-body);
        color: inherit;
        transition: color 0.2s;
    }
    .mob-nav-btn.active {
        color: #60a5fa;
    }
    .mob-nav-btn.active .mob-nav-icon {
        background: rgba(59,130,246,0.15);
        box-shadow: 0 0 12px rgba(59,130,246,0.2);
    }
    /* Orta "Sohbet" butonu — farklı vurgulama */
    .mob-nav-btn:nth-child(2).active .mob-nav-icon {
        background: linear-gradient(135deg, rgba(59,130,246,0.2), rgba(6,182,212,0.15));
    }

    /* ── MODAL DÜZELTME ── */
    .modal-overlay { align-items: flex-end; }
    .modal-content {
        width: 100%;
        max-width: 100%;
        border-radius: 20px 20px 0 0 !important;
        max-height: 88dvh;
        overflow-y: auto;
        animation: mobileSheetIn 0.32s cubic-bezier(0.16, 1, 0.3, 1);
        margin: 0;
    }
    @keyframes mobileSheetIn {
        from { transform: translateY(100%); opacity: 0.8; }
        to   { transform: translateY(0); opacity: 1; }
    }

    /* ── TOAST MOBİL ── */
    #toast-container {
        top: auto;
        bottom: 72px;
        right: 12px; left: 12px;
        align-items: center;
    }
    .custom-toast {
        max-width: 100%;
        min-width: unset;
        width: 100%;
        font-size: 12.5px;
        padding: 11px 14px;
    }

    /* ── DM KUTUSU MOBİL ── */
    .dm-box {
        bottom: 60px;
        width: calc(100vw - 24px) !important;
        left: 12px; right: 12px;
        max-width: 360px;
    }

    /* ── REPLY PREVIEW ── */
    #reply-preview { padding: 6px 10px; }

    /* ================================================================
       TOUCH-FRIENDLY DÜZENLEMELER
       ================================================================ */

    /* Tüm tıklanabilir alanlarda highlight kaldır */
    * { -webkit-tap-highlight-color: transparent; }

    /* Oda listesi büyük dokunma alanı */
    .horizontal-room-list .room-item {
        padding: 6px 12px;
        font-size: 11px;
        min-height: 30px;
    }
    .horizontal-room-list .room-item.active-room {
        padding: 6px 14px;
    }

    /* Kullanıcı listesi daha geniş satırlar */
    .user-avatar { width: 32px !important; height: 32px !important; }
    .user-actions { gap: 4px !important; }
    .u-btn { width: 26px !important; height: 26px !important; font-size: 12px !important; }
    .u-btn-sm { width: 22px !important; height: 22px !important; }

    /* Voice butonlar büyük & tam genişlik */
    .voice-btn {
        padding: 13px 10px !important;
        font-size: 13px !important;
        border-radius: 10px !important;
        min-height: 44px;
    }

    /* Mesaj aksiyon butonları daha büyük touch alanı */
    .msg-action-btn {
        padding: 5px 9px;
        font-size: 12px;
        min-height: 28px;
        min-width: 28px;
    }

    /* Input gönder butonu tam yükseklik */
    .input-area button { min-height: 44px; }
    .input-area input { min-height: 44px; }

    /* Drawer kapat butonu büyük */
    .mob-drawer-close {
        width: 36px !important; height: 36px !important;
        font-size: 16px !important;
    }

    /* Scroll momentum iOS için */
    .sidebar-users,
    #messages-area,
    .right-panel {
        -webkit-overflow-scrolling: touch;
    }

    /* Reaction badge'ler daha büyük */
    .reaction-badge {
        padding: 4px 10px;
        font-size: 11.5px;
    }
}

/* ── Küçük Ekran ── */
@media (max-width: 375px) {
    .sidebar { width: 88vw; max-width: 88vw; }
    .mob-nav-btn span.mob-label { font-size: 8.5px; }
    #messages-area { padding: 10px; }
}

/* ── iPhone notch / Dynamic Island güvenli alan ── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
    @media (max-width: 768px) {
        .mobile-nav-bar { height: calc(60px + env(safe-area-inset-bottom, 0px)); }
        .right-panel { bottom: calc(60px + env(safe-area-inset-bottom, 0px)); }
    }
}

/* ================================================================
   LIGHT THEME
   ================================================================ */
body.light-theme {
    background: #f0f4ff;
    --text-primary: #0f172a;
    --text-secondary: #475569;
    --text-muted: #94a3b8;
    --border-faint: rgba(0,0,0,0.06);
    --border-soft: rgba(0,0,0,0.09);
    --border-mid: rgba(0,0,0,0.14);
    --glass-light: rgba(255,255,255,0.85);
    --glass-mid: rgba(255,255,255,0.92);
    --glass-heavy: rgba(255,255,255,0.97);
    --bg-base: #f0f4ff;
    --bg-surface: #e8eef8;
    --bg-elevated: #dde5f4;
    --bg-hover: #d0daf0;
}
body.light-theme .top-rooms-bar { background: rgba(240,244,255,0.9); border-bottom-color: rgba(0,0,0,0.07); }
body.light-theme .horizontal-room-list .room-item { color: #64748b; }
body.light-theme .horizontal-room-list .room-item:hover { background: rgba(0,0,0,0.05); color: #0f172a; }
body.light-theme .horizontal-room-list .room-item.active-room { background: rgba(59,130,246,0.1); color: #2563eb; border-color: rgba(59,130,246,0.3); }
body.light-theme .sidebar { background: rgba(255,255,255,0.88); border-color: rgba(0,0,0,0.08); box-shadow: 0 4px 20px rgba(0,0,0,0.06); }
body.light-theme .sidebar-header { border-bottom-color: rgba(0,0,0,0.07); }
body.light-theme .sidebar-users-header { color: #94a3b8; }
body.light-theme .hdr-btn { color: #64748b; }
body.light-theme .hdr-btn:hover { background: rgba(0,0,0,0.06); border-color: rgba(0,0,0,0.1); color: #0f172a; }
body.light-theme .hdr-btn-danger:hover { background: #fef2f2; color: #ef4444; border-color: #fca5a5; }
body.light-theme .user-name-text { color: #0f172a; }
body.light-theme .user-item:hover { background: rgba(59,130,246,0.07); border-color: rgba(59,130,246,0.2); }
body.light-theme .user-item:hover .user-name-text { color: #2563eb; }
body.light-theme .user-avatar { background: #e2e8f0; border-color: #cbd5e1; color: #334155; }
body.light-theme .online-dot { border-color: #fff; }
body.light-theme .chat-area { background: rgba(255,255,255,0.88); border-color: rgba(0,0,0,0.08); }
body.light-theme .chat-toolbar { background: rgba(240,244,255,0.8); border-bottom-color: rgba(0,0,0,0.06); }
body.light-theme .toolbar-btn { color: #64748b; }
body.light-theme .toolbar-btn:hover { background: rgba(0,0,0,0.06); border-color: rgba(0,0,0,0.1); color: #0f172a; }
body.light-theme .input-area { background: rgba(230,236,248,0.8); border-top-color: rgba(0,0,0,0.07); }
body.light-theme .input-area input { background: rgba(255,255,255,0.9); border-color: rgba(0,0,0,0.1); color: #0f172a; }
body.light-theme .input-area input::placeholder { color: #94a3b8; }
body.light-theme .input-area input:focus { border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,0.15); }
body.light-theme .right-panel-card { background: rgba(255,255,255,0.88); border-color: rgba(0,0,0,0.08); }
body.light-theme .right-panel-title { color: #94a3b8; border-bottom-color: rgba(0,0,0,0.06); }
body.light-theme .tool-btn { color: #64748b; }
body.light-theme .tool-btn:hover { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); color: #0f172a; }
body.light-theme .voice-status-badge { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); color: #64748b; }
body.light-theme .voice-btn { background: rgba(255,255,255,0.7); border-color: rgba(0,0,0,0.1); color: #475569; }
body.light-theme .voice-btn:hover { background: #fff; color: #0f172a; }
body.light-theme .mobile-nav-bar { background: rgba(255,255,255,0.97); border-top-color: rgba(0,0,0,0.1); }
body.light-theme .mob-nav-btn { color: #94a3b8; }
body.light-theme .mob-nav-btn.active { color: #2563eb; border-top-color: #2563eb; }
body.light-theme ::selection { background: rgba(59,130,246,0.2); color: #0f172a; }

/* ================================================================
   LAYOUT ADDITIONS — Toolbar tools, Right panel extras, Logout fix
   ================================================================ */

/* ── Çıkış butonu HER ZAMAN görünür ── */
#logout-btn {
    display: flex !important;
    color: #f87171 !important;
}

/* ── Toolbar emoji/gif butonları ── */
.tb-emoji-btn, .tb-gif-btn {
    font-size: 14px !important;
    padding: 4px 7px !important;
    letter-spacing: 0;
}
.toolbar-btn.active {
    background: rgba(59,130,246,0.18) !important;
    border-color: rgba(59,130,246,0.4) !important;
    color: var(--sapphire-light) !important;
}

/* toolbar-popup — artık tb-popup içinde yönetiliyor */

/* ── Sağ panel araçlar row (yazı boyutu) ── */
.tool-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 5px 3px;
}
.tool-row-label {
    font-size: 10.5px; font-weight: 600; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: 0.8px;
    font-family: var(--font-body);
}
.tool-row-btns { display: flex; gap: 3px; }
.tool-sz-btn {
    padding: 5px 9px; border-radius: var(--r-sm);
    background: rgba(6,182,212,0.08);
    border: 1px solid rgba(6,182,212,0.2);
    color: var(--cyan-light); font-size: 10.5px; font-weight: 800;
    cursor: pointer; transition: all 0.18s;
    font-family: var(--font-mono);
}
.tool-sz-btn:hover { background: rgba(6,182,212,0.18); border-color: rgba(6,182,212,0.4); transform: scale(1.08); }

/* ── Danger tool button (sohbet sil) ── */
.tool-btn-danger { color: #f87171 !important; border-color: rgba(239,68,68,0.2) !important; background: rgba(239,68,68,0.06) !important; }
.tool-btn-danger:hover { background: rgba(239,68,68,0.14) !important; border-color: rgba(239,68,68,0.35) !important; }

/* ── Renkleri biraz açıyoruz (daha az koyu dark mode) ── */
:root {
    --bg-void:        #040810;
    --bg-base:        #080f1e;
    --bg-surface:     #0c1528;
    --bg-raised:      #111e35;
    --bg-elevated:    #162340;
    --bg-hover:       #1a2a4a;
    --glass-light:    rgba(16, 26, 52, 0.6);
    --glass-mid:      rgba(10, 18, 38, 0.78);
    --glass-heavy:    rgba(7, 13, 28, 0.92);
}

body.light-theme .tool-row-label { color: #94a3b8; }
body.light-theme .tool-sz-btn { background: rgba(14,165,233,0.08); border-color: rgba(14,165,233,0.2); color: #0284c7; }
body.light-theme .tool-sz-btn:hover { background: rgba(14,165,233,0.16); }
body.light-theme .tool-btn-danger { color: #ef4444 !important; background: rgba(239,68,68,0.06) !important; border-color: rgba(239,68,68,0.18) !important; }

/* ================================================================
   MINIMAL RADIUS UPDATE — Oval azalt
   ================================================================ */
:root {
    --r-xs:  2px;
    --r-sm:  4px;
    --r-md:  6px;
    --r-lg:  8px;
    --r-xl:  10px;
    --r-full: 4px;   /* pill butonlar da köşeli */
    /* compat */
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 8px;
}
/* Sadece avatar ve online dot gerçek yuvarlak kalsın */
.user-avatar    { border-radius: 6px !important; }
.online-dot     { border-radius: 50% !important; }
.auth-form-logo { border-radius: 6px !important; }

/* ================================================================
   CHAT ACTION BAR (İstek Yap / Günün Sözü / Fal Bak)
   — mesaj alanının tam üstünde, toolbar'ın da üstünde
   ================================================================ */
.chat-action-bar {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 5px 10px;
    background: rgba(4, 8, 20, 0.65);
    border-bottom: 1px solid var(--border-faint);
    flex-shrink: 0;
    backdrop-filter: blur(10px);
    overflow-x: auto;
    scrollbar-width: none;
    order: -1;   /* mesaj alanının üstünde */
}
.chat-action-bar::-webkit-scrollbar { display: none; }
.action-bar-sep {
    flex: 1;
}
.action-bar-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 11px;
    border-radius: var(--r-sm);
    border: 1px solid transparent;
    font-size: 11px; font-weight: 600; cursor: pointer;
    white-space: nowrap;
    transition: all 0.18s var(--ease-io);
    font-family: var(--font-body);
    background: rgba(255,255,255,0.04);
    color: var(--text-secondary);
}
.action-bar-btn:hover {
    background: rgba(255,255,255,0.09);
    color: var(--text-primary);
    border-color: var(--border-soft);
    transform: translateY(-1px);
}
.action-bar-btn span { font-size: 13px; }
.ab-purple { color: #c084fc; border-color: rgba(192,132,252,0.15); background: rgba(124,58,237,0.07); }
.ab-purple:hover { background: rgba(124,58,237,0.15); border-color: rgba(192,132,252,0.35); }
.ab-orange { color: #fbbf24; border-color: rgba(251,191,36,0.15); background: rgba(245,158,11,0.07); }
.ab-orange:hover { background: rgba(245,158,11,0.15); border-color: rgba(251,191,36,0.35); }
.ab-brown  { color: #c8956a; border-color: rgba(200,149,106,0.15); background: rgba(139,69,19,0.07); }
.ab-brown:hover  { background: rgba(139,69,19,0.15); border-color: rgba(200,149,106,0.35); }

/* ================================================================
   CHAT-AREA flex sırası
   ================================================================ */
.chat-area {
    display: flex;
    flex-direction: column;
}
/* Sıralama: messages → toolbar → reply → input */
.chat-action-bar { display: none !important; } /* toolbar'a taşındı */
#messages-area   { order: 1; }
.chat-toolbar    { order: 2; }
#reply-preview   { order: 3; }
.input-area      { order: 4; }

/* popup bloğu — chat-toolbar.css'e taşındı */
body.light-theme .reply-preview-bar { background: rgba(14,165,233,0.07); border-top-color: rgba(14,165,233,0.15); }

/* ── Admin görünümü: kullanıcı IP ── */
.user-ip-text {
    font-size: 9px;
    font-family: var(--font-mono, monospace);
    color: rgba(6, 182, 212, 0.6);
    margin-top: 1px;
    letter-spacing: 0.3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ================================================================
   FIX: Sidebar genişliği, buton boyutları, user-actions
   ================================================================ */

/* Sidebar biraz daha geniş */
.sidebar {
    width: 230px !important;
    min-width: 230px !important;
    max-width: 230px !important;
}

/* user-item butonları küçük ve sıkışık */
.user-actions {
    display: flex;
    align-items: center;
    gap: 1px !important;
    flex-wrap: nowrap;
    flex-shrink: 0;
}

/* Normal buton */
.u-btn {
    width: 22px !important;
    height: 22px !important;
    font-size: 11px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 3px !important;
    border: 1px solid transparent !important;
    background: transparent !important;
    cursor: pointer;
    transition: background 0.15s;
    line-height: 1 !important;
}
.u-btn:hover {
    background: rgba(255,255,255,0.1) !important;
    border-color: rgba(255,255,255,0.12) !important;
}

/* Ekstra küçük buton (admin/mod aksiyonları) */
.u-btn-sm {
    width: 18px !important;
    height: 18px !important;
    font-size: 10px !important;
    opacity: 0.7;
}
.u-btn-sm:hover { opacity: 1 !important; }

/* Rank, partner rozetler */
.u-badge {
    font-size: 11px !important;
    padding: 0 !important;
    width: 18px !important;
    height: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* user-name-text daha uzun yer alsın */
.user-info-container {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}
.user-name-text {
    font-size: 11.5px !important;
    font-weight: 600 !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.user-role-text {
    font-size: 9.5px !important;
}

/* EQ bar küçült */
.eq-bar { height: 10px !important; }
.eq-bar span { width: 2px !important; }
.radio-eq { height: 12px !important; }
.radio-eq span { width: 2px !important; }

/* Sidebar tablet */
@media (max-width: 1024px) {
    .sidebar { width: 210px !important; min-width: 210px !important; max-width: 210px !important; }
}

/* Light theme */
body.light-theme .u-btn:hover { background: rgba(0,0,0,0.07) !important; }
/* ── Aşağı İn Butonu ── */
#scroll-down-btn {
    position: absolute;
    bottom: 70px; right: 14px;
    z-index: 50;
    background: rgba(59,130,246,0.9);
    color: #fff; border: none;
    border-radius: 50%;
    width: 40px; height: 40px;
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(59,130,246,0.5);
    font-size: 18px; font-weight: 700;
    align-items: center; justify-content: center;
    transition: all 0.2s;
    backdrop-filter: blur(8px);
}
#scroll-down-btn:hover { transform: scale(1.1); background: rgba(59,130,246,1); }
#scroll-down-btn:active { transform: scale(0.95); }
@media (max-width: 768px) {
    #scroll-down-btn { bottom: 75px; right: 10px; width: 36px; height: 36px; font-size: 16px; }
}
