/* ========== THEME VARIABLES (with RGB components) ========== */
body.theme-default {
    --bg-primary: #061a2d;
    --bg-primary-r: 6; --bg-primary-g: 26; --bg-primary-b: 45;
    --bg-secondary: #0a2f4f;
    --bg-secondary-r: 10; --bg-secondary-g: 47; --bg-secondary-b: 79;
    --bg-tertiary: #1a3a5a;
    --bg-tertiary-r: 26; --bg-tertiary-g: 58; --bg-tertiary-b: 90;
    --text-primary: #f0f8ff;
    --text-primary-r: 240; --text-primary-g: 248; --text-primary-b: 255;
    --accent-primary: #2a8cd6;
    --accent-primary-r: 42; --accent-primary-g: 140; --accent-primary-b: 214;
    --accent-secondary: #3a9eff;
    --accent-secondary-r: 58; --accent-secondary-g: 158; --accent-secondary-b: 255;
}

body.theme-light {
    --bg-primary: #f0f4fa;
    --bg-primary-r: 240; --bg-primary-g: 244; --bg-primary-b: 250;
    --bg-secondary: #e0e8f0;
    --bg-secondary-r: 224; --bg-secondary-g: 232; --bg-secondary-b: 240;
    --bg-tertiary: #d0dce8;
    --bg-tertiary-r: 208; --bg-tertiary-g: 220; --bg-tertiary-b: 232;
    --text-primary: #1a2a3a;
    --text-primary-r: 26; --text-primary-g: 42; --text-primary-b: 58;
    --accent-primary: #2a8cd6;
    --accent-primary-r: 42; --accent-primary-g: 140; --accent-primary-b: 214;
    --accent-secondary: #3a9eff;
    --accent-secondary-r: 58; --accent-secondary-g: 158; --accent-secondary-b: 255;
}

body.theme-blue {
    --bg-primary: #1a3a6a;
    --bg-primary-r: 26; --bg-primary-g: 58; --bg-primary-b: 106;
    --bg-secondary: #2a4a8a;
    --bg-secondary-r: 42; --bg-secondary-g: 74; --bg-secondary-b: 138;
    --bg-tertiary: #3a5aaa;
    --bg-tertiary-r: 58; --bg-tertiary-g: 90; --bg-tertiary-b: 170;
    --text-primary: #ffffff;
    --text-primary-r: 255; --text-primary-g: 255; --text-primary-b: 255;
    --accent-primary: #8ac4ff;
    --accent-primary-r: 138; --accent-primary-g: 196; --accent-primary-b: 255;
    --accent-secondary: #a0d4ff;
    --accent-secondary-r: 160; --accent-secondary-g: 212; --accent-secondary-b: 255;
}

body.theme-green {
    --bg-primary: #1a4a2a;
    --bg-primary-r: 26; --bg-primary-g: 74; --bg-primary-b: 42;
    --bg-secondary: #2a6a3a;
    --bg-secondary-r: 42; --bg-secondary-g: 106; --bg-secondary-b: 58;
    --bg-tertiary: #3a8a4a;
    --bg-tertiary-r: 58; --bg-tertiary-g: 138; --bg-tertiary-b: 74;
    --text-primary: #ffffff;
    --text-primary-r: 255; --text-primary-g: 255; --text-primary-b: 255;
    --accent-primary: #8aff8c;
    --accent-primary-r: 138; --accent-primary-g: 255; --accent-primary-b: 140;
    --accent-secondary: #a0ffa0;
    --accent-secondary-r: 160; --accent-secondary-g: 255; --accent-secondary-b: 160;
}

body.theme-purple {
    --bg-primary: #2a1a4a;
    --bg-primary-r: 42; --bg-primary-g: 26; --bg-primary-b: 74;
    --bg-secondary: #3a2a6a;
    --bg-secondary-r: 58; --bg-secondary-g: 42; --bg-secondary-b: 106;
    --bg-tertiary: #4a3a8a;
    --bg-tertiary-r: 74; --bg-tertiary-g: 58; --bg-tertiary-b: 138;
    --text-primary: #ffffff;
    --text-primary-r: 255; --text-primary-g: 255; --text-primary-b: 255;
    --accent-primary: #cc8aff;
    --accent-primary-r: 204; --accent-primary-g: 138; --accent-primary-b: 255;
    --accent-secondary: #dca0ff;
    --accent-secondary-r: 220; --accent-secondary-g: 160; --accent-secondary-b: 255;
}

body.theme-orange {
    --bg-primary: #4a2a1a;
    --bg-primary-r: 74; --bg-primary-g: 42; --bg-primary-b: 26;
    --bg-secondary: #6a3a2a;
    --bg-secondary-r: 106; --bg-secondary-g: 58; --bg-secondary-b: 42;
    --bg-tertiary: #8a4a3a;
    --bg-tertiary-r: 138; --bg-tertiary-g: 74; --bg-tertiary-b: 58;
    --text-primary: #ffffff;
    --text-primary-r: 255; --text-primary-g: 255; --text-primary-b: 255;
    --accent-primary: #ffaa4a;
    --accent-primary-r: 255; --accent-primary-g: 170; --accent-primary-b: 74;
    --accent-secondary: #ffbb6a;
    --accent-secondary-r: 255; --accent-secondary-g: 187; --accent-secondary-b: 106;
}

body.theme-dark {
    --bg-primary: #0a0a1a;
    --bg-primary-r: 10; --bg-primary-g: 10; --bg-primary-b: 26;
    --bg-secondary: #1a1a2a;
    --bg-secondary-r: 26; --bg-secondary-g: 26; --bg-secondary-b: 42;
    --bg-tertiary: #2a2a3a;
    --bg-tertiary-r: 42; --bg-tertiary-g: 42; --bg-tertiary-b: 58;
    --text-primary: #c0c0ff;
    --text-primary-r: 192; --text-primary-g: 192; --text-primary-b: 255;
    --accent-primary: #6a4aff;
    --accent-primary-r: 106; --accent-primary-g: 74; --accent-primary-b: 255;
    --accent-secondary: #8a6aff;
    --accent-secondary-r: 138; --accent-secondary-g: 106; --accent-secondary-b: 255;
}

/* ========== OTHER STYLES (unchanged but with variables) ========== */

/* Jab popup open ho, ye class body par laga do */
body.popup-open .pm-window {
    pointer-events: none !important;
}

/* ========== TOOLBAR HEIGHT REDUCTION ========== */
.format-toolbar {
    padding-top: 4px !important;
    padding-bottom: 4px !important;
}

.format-left button,
.format-left select,
.format-left .format-btn,
.format-right .radio-toolbar-player {
    margin: 2px 0 !important;
    line-height: 1.2 !important;
}

/* ========== PRIVATE MESSAGING WINDOWS ========== */
.pm-window {
    position: absolute;
    width: 320px;
    background: linear-gradient(145deg, var(--bg-secondary), var(--bg-tertiary));
    border: 2px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.6);
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    color: var(--text-primary);
    font-family: inherit;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    backdrop-filter: blur(5px);
    resize: both;
    overflow: hidden;
}

.pm-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
    background: rgba(0,0,0,0.3);
    border-bottom: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    cursor: grab;
}
.pm-header:active {
    cursor: grabbing;
}

.pm-title {
    font-weight: bold;
    color: var(--accent-primary);
    font-size: 14px;
}

.pm-controls {
    display: flex;
    gap: 5px;
}
.pm-controls button {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: none;
    color: var(--text-primary);
    width: 24px;
    height: 24px;
    border-radius: 12px;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pm-controls button:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.2);
}

.pm-body {
    padding: 10px;
    display: flex;
    flex-direction: column;
    height: 300px;
}

.pm-messages {
    flex: 1;
    overflow-y: auto;
    margin-bottom: 10px;
    padding: 5px;
    background: rgba(0,0,0,0.2);
    border-radius: 8px;
}

.pm-message img {
    max-width: 60px;
    max-height: 60px;
    border-radius: 6px;
}

.pm-message {
    margin: 5px 0;
    padding: 6px 10px;
    border-radius: 12px;
    max-width: 80%;
    word-wrap: break-word;
}

.pm-message.mine {
    background: var(--accent-primary);
    color: var(--text-primary);
    margin-left: auto;
    text-align: right;
}
.pm-message.theirs {
    background: var(--bg-tertiary);
    color: var(--text-primary);
    margin-right: auto;
    text-align: left;
}

.pm-input-area {
    display: flex;
    gap: 5px;
}
.pm-input {
    flex: 1;
    padding: 8px;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    border-radius: 20px;
    background: rgba(0,0,0,0.3);
    color: var(--text-primary);
}
.pm-input:focus {
    outline: none;
    border-color: var(--accent-secondary);
}
.pm-send, .pm-smiley {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    border: none;
    color: var(--text-primary);
    padding: 8px 12px;
    border-radius: 20px;
    cursor: pointer;
    font-size: 14px;
}
.pm-smiley {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
}

.pm-color-picker {
    width: 30px;
    height: 30px;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    border-radius: 15px;
    background: transparent;
    cursor: pointer;
    padding: 2px;
}

.pm-options {
    display: flex;
    gap: 5px;
    padding: 5px 10px 10px 10px;
    border-top: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
}
.pm-options button {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    color: var(--text-primary);
    padding: 4px 8px;
    border-radius: 12px;
    cursor: pointer;
    font-size: 11px;
    flex: 1;
}
.pm-options button:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.2);
}

/* Fix for minimized PM window */
.pm-window.minimized .pm-body,
.pm-window.minimized .pm-options {
    display: none;
}
.pm-window.minimized {
    height: auto;
    min-height: 40px;
}

.manage-action {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    color: var(--text-primary);
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    transition: 0.2s;
}
.manage-action:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.2);
    border-color: var(--accent-secondary);
}
/* ========== MODERN COMPACT PROFILE MODAL ========== */
#profile-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.8);
    backdrop-filter: blur(5px);
    z-index: 1000;
    display: flex;
    justify-content: center;
    align-items: center;
}

.profile-modal-content {
    background: #0f2a3f;
    border: 1px solid rgba(42,140,214,0.5);
    border-radius: 16px;
    padding: 20px 25px;
    width: 520px;
    max-width: 95vw;
    color: white;
    box-shadow: 0 15px 30px rgba(0,0,0,0.6);
    max-height: 85vh;
    overflow-y: auto;
}

.profile-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 20px;
    margin-top: 10px;
}

.avatar-section {
    grid-column: span 2;
    text-align: center;
    margin-bottom: 5px;
}

.avatar-preview {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: #1a3a55;
    margin: 0 auto 8px;
    border: 2px solid #2a8cd6;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 3px 10px rgba(42,140,214,0.3);
    cursor: pointer;
    transition: transform 0.2s;
}
.avatar-preview:hover {
    transform: scale(1.05);
}

.profile-field label {
    display: block;
    color: #8ac4ff;
    margin-bottom: 3px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3px;
    text-transform: uppercase;
}

.profile-field input,
.profile-field select,
.profile-field textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid rgba(42,140,214,0.4);
    border-radius: 6px;
    background: rgba(10,30,50,0.9);
    color: white;
    font-size: 12px;
    transition: all 0.2s;
}
.profile-field input:focus,
.profile-field select:focus,
.profile-field textarea:focus {
    outline: none;
    border-color: #3a9eff;
    box-shadow: 0 0 0 2px rgba(58,158,255,0.2);
}
.profile-field input:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.profile-buttons {
    grid-column: span 2;
    display: flex;
    gap: 10px;
    margin-top: 15px;
}
.profile-btn-primary {
    flex: 1;
    padding: 10px;
    background: #2a8cd6;
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-weight: 600;
    font-size: 13px;
    transition: all 0.2s;
}
.profile-btn-primary:hover {
    background: #3a9eff;
    transform: translateY(-1px);
    box-shadow: 0 5px 15px rgba(42,140,214,0.4);
}
.profile-btn-secondary {
    flex: 1;
    padding: 10px;
    background: rgba(255,255,255,0.08);
    color: white;
    border: 1px solid rgba(42,140,214,0.4);
    border-radius: 8px;
    cursor: pointer;
    font-weight: 600;
    font-size: 13px;
    transition: all 0.2s;
}
.profile-btn-secondary:hover {
    background: rgba(255,255,255,0.15);
}

/* ========== COMPACT WIDE USER PROFILE POPUP (2-COLUMN DETAILS) ========== */
.user-profile-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(8px);
    z-index: 2000;
    display: flex;
    justify-content: center;
    align-items: center;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.user-profile-content {
    background: linear-gradient(145deg, #122b3f, #1a3a55);
    border: 1px solid rgba(42, 140, 214, 0.4);
    border-radius: 20px;
    padding: 20px;
    width: 420px;
    max-width: 95vw;
    color: white;
    box-shadow: 0 20px 40px rgba(0,0,0,0.5);
    position: relative;
    max-height: 80vh;
    overflow-y: auto;
}

.user-profile-avatar {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background: linear-gradient(135deg, #1e3a5a, #0f2a3f);
    margin: 0 auto 12px;
    border: 3px solid #2a8cd6;
    padding: 3px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

.user-profile-avatar img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,0.2);
}

.user-profile-avatar span {
    font-size: 45px;
    line-height: 80px;
}

.user-profile-name {
    font-size: 22px;
    font-weight: 700;
    text-align: center;
    background: linear-gradient(135deg, #fff, #c3e0ff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 5px;
}

.user-profile-role-box {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 12px;
    margin: 15px 0;
    border-radius: 16px;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(42, 140, 214, 0.3);
    backdrop-filter: blur(5px);
}
.role-icon {
    font-size: 24px;
}
.role-text {
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.role-box-admin {
    border-color: gold;
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.2);
}
.role-box-mod {
    border-color: #6bff6b;
    box-shadow: 0 0 15px rgba(107, 255, 107, 0.2);
}
.role-box-user {
    border-color: cornflowerblue;
    box-shadow: 0 0 15px rgba(100, 149, 237, 0.2);
}
.role-box-guest {
    border-color: #ccc;
    box-shadow: 0 0 15px rgba(204, 204, 204, 0.2);
}

.user-profile-details-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 15px 0;
}

.detail-card {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(42, 140, 214, 0.3);
    border-radius: 12px;
    padding: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: all 0.2s;
}
.detail-card:hover {
    border-color: #3a9eff;
    background: rgba(0, 0, 0, 0.35);
}

.detail-icon {
    width: 36px;
    height: 36px;
    background: rgba(42, 140, 214, 0.2);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    border: 1px solid rgba(42,140,214,0.3);
}

.detail-content {
    flex: 1;
    text-align: left;
}

.detail-label {
    font-size: 9px;
    color: #8ac4ff;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    font-weight: 600;
    margin-bottom: 2px;
}

.detail-value {
    font-size: 13px;
    font-weight: 500;
    color: white;
    word-break: break-word;
    line-height: 1.3;
}

.detail-card.full-width {
    grid-column: span 2;
}

.user-profile-buttons {
    display: flex;
    gap: 12px;
    margin-top: 15px;
}
.user-profile-btn {
    flex: 1;
    padding: 10px;
    border: none;
    border-radius: 10px;
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}
.user-profile-btn-primary {
    background: linear-gradient(135deg, #2a8cd6, #3a9eff);
    color: white;
}
.user-profile-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(42,140,214,0.4);
}
.user-profile-btn-secondary {
    background: rgba(255,255,255,0.08);
    color: white;
    border: 1px solid rgba(42,140,214,0.4);
}
.user-profile-btn-secondary:hover {
    background: rgba(255,255,255,0.15);
}

.user-profile-close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(42,140,214,0.4);
    color: white;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.user-profile-close:hover {
    background: rgba(255,255,255,0.2);
    border-color: #3a9eff;
    transform: rotate(90deg);
}
    
/* Clear Chat Button */
.clear-chat-btn {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.08);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    color: var(--text-primary);
    padding: 6px 18px;
    border-radius: 30px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-right: 8px;
}
.clear-chat-btn:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.15);
    border-color: var(--accent-secondary);
    transform: scale(1.05);
}
    
/* ========== PROFESSIONAL SETTINGS BUTTON ========== */
.settings-btn {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.settings-btn:hover {
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.2);
    border-color: var(--accent-secondary);
    transform: rotate(45deg) scale(1.1);
    box-shadow: 0 0 20px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.6);
}

.settings-btn svg {
    width: 22px;
    height: 22px;
    fill: var(--text-primary);
    transition: all 0.3s ease;
}

.settings-btn:hover svg {
    fill: var(--accent-primary);
}

/* ========== GLOBAL STYLES ========== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

body {
    background: #060f1e;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    overflow: hidden;
    font-family: 'Exo 2', 'Rajdhani', sans-serif;
}

/* Animated grid background */
body::before {
    content: '';
    position: fixed; inset: 0; z-index: 0;
    background-image:
        linear-gradient(rgba(0,140,255,0.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,140,255,0.055) 1px, transparent 1px);
    background-size: 38px 38px;
    animation: gridScroll 12s linear infinite;
    pointer-events: none;
}
@keyframes gridScroll {
    from { background-position: 0 0; }
    to   { background-position: 38px 38px; }
}

/* Radial center glow */
body::after {
    content: '';
    position: fixed; inset: 0; z-index: 0;
    background: radial-gradient(ellipse 75% 65% at 50% 50%,
        rgba(0,120,220,0.14) 0%, transparent 70%);
    pointer-events: none;
}

@keyframes rotate {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Corner brackets */
.login-corner {
    position: fixed; width: 52px; height: 52px; z-index: 5; pointer-events:none;
}
.login-corner.c-tl { top:18px; left:18px;  border-top:2px solid #00b4ff; border-left:2px solid #00b4ff; opacity:.35; }
.login-corner.c-tr { top:18px; right:18px; border-top:2px solid #00b4ff; border-right:2px solid #00b4ff; opacity:.35; }
.login-corner.c-bl { bottom:18px; left:18px;  border-bottom:2px solid #00b4ff; border-left:2px solid #00b4ff; opacity:.35; }
.login-corner.c-br { bottom:18px; right:18px; border-bottom:2px solid #00b4ff; border-right:2px solid #00b4ff; opacity:.35; }

/* Scanline animation */
.login-scanline {
    position: fixed; left:0; right:0; height:2px; z-index:5; pointer-events:none;
    background: linear-gradient(90deg, transparent, rgba(0,180,255,.22), transparent);
    animation: loginScan 7s ease-in-out infinite;
}
@keyframes loginScan {
    0%   { top:0;    opacity:0; }
    5%   { opacity:1; }
    95%  { opacity:1; }
    100% { top:100%; opacity:0; }
}

/* Floating particles */
.login-particle {
    position: fixed; border-radius: 50%;
    background: rgba(0,180,255,0.45);
    pointer-events: none; z-index: 0;
    animation: loginRise linear infinite;
}
@keyframes loginRise {
    from { transform: translateY(0) scale(1); opacity:.5; }
    to   { transform: translateY(-100vh) scale(0); opacity:0; }
}

/* ========== LOGIN SCREEN – PROFESSIONAL ========== */
.login-wrapper {
    position: relative;
    z-index: 10;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
    gap: 18px;
    animation: wrapperIn 0.7s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes wrapperIn {
    from { opacity:0; transform:translateY(30px); }
    to   { opacity:1; transform:translateY(0); }
}

/* ── Card outer ── */
.login-box {
    width: 860px;
    max-width: 97vw;
    background: rgba(14,28,55,0.92);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 16px;
    border: 1px solid rgba(0,180,255,0.2);
    box-shadow:
        0 0 0 1px rgba(0,180,255,0.04) inset,
        0 24px 60px rgba(0,0,0,0.6),
        0 0 50px rgba(0,100,220,0.08);
    overflow: hidden;
    position: relative;
    color: white;
    display: grid;
    grid-template-columns: 1fr auto;
}
.login-box::before {
    content:'';
    position:absolute; top:0; left:8%; right:8%; height:1px;
    background:linear-gradient(90deg,transparent,#00b4ff,transparent);
    opacity:.5; z-index:1;
}

/* ── Left panel ── */
.left-panel {
    padding: 30px 34px 30px;
    border-right: 1px solid rgba(0,180,255,0.15);
    position: relative;
    display: flex;
    flex-direction: column;
}

/* ── Right panel ── */
.right-panel {
    width: 230px;
    background: linear-gradient(170deg, #102038 0%, #091628 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 30px 22px;
    gap: 16px;
    position: relative;
}
.right-panel::before {
    content:'';
    position:absolute; left:0; top:15%; bottom:15%; width:1px;
    background:linear-gradient(to bottom,transparent,rgba(0,180,255,0.3),transparent);
    opacity:.4;
}

/* Right panel mini ring logo */
.rp-logo-mini { display:flex; flex-direction:column; align-items:center; gap:8px; }
.rp-ring-wrap { width:46px; height:46px; position:relative; }
.rp-ring-o {
    position:absolute; inset:0; border-radius:50%;
    border:2px solid transparent;
    border-top-color:#00b4ff; border-right-color:rgba(0,180,255,.2);
    animation:spinOuter 2s linear infinite;
}
.rp-ring-i {
    position:absolute; inset:7px; border-radius:50%;
    border:1.5px solid transparent;
    border-bottom-color:#00e5ff; border-left-color:rgba(0,229,255,.2);
    animation:spinInner 1.4s linear infinite;
}
.rp-ring-c {
    position:absolute; inset:13px;
    display:flex; align-items:center; justify-content:center;
    border-radius:50%; background:rgba(0,80,160,.4);
    border:1px solid rgba(0,180,255,.35);
}
.rp-ring-c svg { filter:drop-shadow(0 0 4px #00b4ff); }
.rp-name {
    font-family:'Orbitron',monospace;
    font-size:14px; font-weight:900; letter-spacing:3px;
    background:linear-gradient(135deg,#fff 20%,#80d8ff 60%,#00b4ff 100%);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
    filter:drop-shadow(0 0 8px rgba(0,180,255,.4));
}
.rp-name span { -webkit-text-fill-color:#00b4ff; }
.rp-badge {
    background: linear-gradient(135deg,#ffaa00,#ff7700);
    color:#000; font-family:'Orbitron',monospace;
    font-size:10px; font-weight:900; letter-spacing:2px;
    padding:6px 16px; border-radius:25px;
    box-shadow:0 0 18px rgba(255,150,0,.4);
}
.rp-divider {
    width:80%; height:1px;
    background:linear-gradient(90deg,transparent,rgba(0,180,255,.3),transparent);
}
.rp-secure { display:flex; flex-direction:column; gap:8px; width:100%; }
.rp-secure-row {
    display:flex; align-items:center; gap:7px;
    font-size:10px; letter-spacing:.5px;
    color:rgba(160,210,255,.65);
    font-family:'Exo 2','Rajdhani',sans-serif;
}
.rp-check { color:#00b4ff; font-size:10px; flex-shrink:0; }
.rp-version {
    font-size:9px; letter-spacing:2.5px; text-transform:uppercase;
    color:rgba(0,180,255,.4);
    font-family:'Rajdhani',sans-serif;
}

/* ── Fields wrap ── */
.fields-wrap { display:flex; flex-direction:column; gap:14px; }
#register-fields { display:none; }

/* ── Field label ── */
.field-label {
    display:flex; align-items:center; gap:6px;
    font-family:'Orbitron',monospace;
    font-size:10px; font-weight:700; letter-spacing:2px;
    color:#00b4ff; text-transform:uppercase;
    margin-bottom:6px;
}

/* ── Input wrapper ── */
.input-wrapper, .field-wrap { position:relative; display:flex; align-items:center; }

/* ── Input ── */
input {
    width:100%;
    padding: 12px 14px 12px 42px;
    border-radius: 9px;
    border: 1px solid rgba(0,140,230,0.25);
    background: rgba(15,35,70,0.65);
    color: #e0f4ff;
    font-family:'Rajdhani',sans-serif;
    font-size:14px; font-weight:500; letter-spacing:0.5px;
    transition:all .22s;
}
input:hover {
    border-color: rgba(0,180,255,0.5);
    background: rgba(18,40,80,0.75);
}
input:focus {
    outline:none;
    border-color: #00b4ff;
    background: rgba(20,45,90,0.85);
    box-shadow: 0 0 0 3px rgba(0,180,255,0.12);
}
input::placeholder { color:rgba(120,180,230,0.28); font-weight:400; }

/* ── Input icon ── */
.input-icon, .field-icon {
    position:absolute; left:12px; top:50%; transform:translateY(-50%);
    pointer-events:none; transition:all .2s;
    display:flex; align-items:center; justify-content:center;
    color:rgba(0,180,255,.45); font-size:14px; z-index:1;
}
.input-icon svg, .field-icon svg {
    width:16px; height:16px;
    stroke:rgba(0,180,255,.45); fill:none;
    stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round;
    transition:stroke .2s, filter .2s;
}
.input-wrapper:focus-within .input-icon svg,
.field-wrap:focus-within .field-icon svg {
    stroke:#00b4ff;
    filter:drop-shadow(0 0 5px rgba(0,180,255,.6));
}

/* Two-col grid */
.input-row, .two-col { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* ── Options row ── */
.auth-options, .options-row {
    display:flex; justify-content:space-between; align-items:center;
    margin: 2px 0 4px;
}
.remember-wrap, .remember {
    display:flex; align-items:center; gap:7px; cursor:pointer;
}
.custom-check, .chk-box {
    width:15px; height:15px;
    border:1px solid rgba(0,160,230,0.4); border-radius:4px;
    background:rgba(10,30,65,0.7);
    display:flex; align-items:center; justify-content:center;
    transition:all 0.2s; flex-shrink:0; font-size:9px; color:white;
}
.remember-wrap.checked .custom-check,
.remember.on .chk-box { background:#0066cc; border-color:#00b4ff; }
.remember-text, .remember-lbl {
    font-family:'Rajdhani',sans-serif;
    font-size:11px; color:rgba(160,210,255,0.5); letter-spacing:0.5px;
}
.forgot-link, .forgot {
    font-family:'Rajdhani',sans-serif;
    font-size:11px; color:rgba(0,180,255,0.55);
    cursor:pointer; letter-spacing:0.5px; transition:color 0.2s;
}
.forgot-link:hover, .forgot:hover { color:#00b4ff; }

/* ── Buttons row ── */
.btn-row {
    display:flex; align-items:center; gap:12px;
    margin-top: 6px;
}

/* ── Main login button ── */
.btn, .btn-login {
    flex:1; padding:13px;
    background:linear-gradient(135deg,#0055aa,#0077dd,#00b4ff);
    border:none; border-radius:10px;
    color:#fff;
    font-family:'Orbitron',monospace;
    font-size:11px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
    cursor:pointer; position:relative; overflow:hidden;
    transition:all 0.3s;
    box-shadow:0 5px 22px rgba(0,140,220,0.35);
    width: 100%;
}
.btn-row .btn, .btn-row .btn-login { width:auto; }
.btn::after, .btn-login::after {
    content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
    transition:left .5s;
}
.btn:hover::after, .btn-login:hover::after { left:100%; }
.btn:hover, .btn-login:hover { transform:translateY(-2px); box-shadow:0 10px 32px rgba(0,160,255,0.5); }
.btn:active, .btn-login:active { transform:translateY(0); }

/* ── OR badge ── */
.or-badge {
    width:34px; height:34px; border-radius:50%;
    background:#0d1f3c;
    border:2px solid rgba(0,160,230,.35);
    display:flex; align-items:center; justify-content:center;
    font-family:'Orbitron',monospace;
    font-size:9px; font-weight:700; letter-spacing:1px;
    color:rgba(160,210,255,.5);
    flex-shrink:0;
}

/* OR divider (tab style) */
.or {
    display:flex; align-items:center; gap:10px; margin:12px 0;
}
.or::before,.or::after { content:''; flex:1; height:1px; background:rgba(0,140,220,0.2); }
.or span {
    font-family:'Rajdhani',sans-serif;
    font-size:10px; letter-spacing:2px;
    color:rgba(160,210,255,0.3); text-transform:uppercase;
}

/* ── Register / secondary button ── */
.btn-register, .btn-secondary {
    flex:1; padding:13px;
    background:transparent;
    border:1.5px solid rgba(0,160,230,.4);
    border-radius:10px;
    color:rgba(160,210,255,.75);
    font-family:'Orbitron',monospace;
    font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
    cursor:pointer; transition:all .25s;
    width:100%;
}
.btn-row .btn-register, .btn-row .btn-secondary { width:auto; }
.btn-register:hover, .btn-secondary:hover {
    background:rgba(0,120,220,.18);
    border-color:#00b4ff; color:#fff;
}

/* ── Guest full-width button ── */
.guest-btn-full {
    width:100%;
    display:flex; align-items:center; justify-content:center; gap:8px;
    background:rgba(0,60,130,.2);
    border:1px solid rgba(0,180,255,.2);
    border-radius:10px;
    color:rgba(160,210,255,.6); font-family:'Rajdhani',sans-serif;
    font-size:12px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase;
    padding:10px; cursor:pointer; transition:all .22s;
    margin-top:2px;
}
.guest-btn-full:hover { background:rgba(0,100,200,.3); border-color:#00b4ff; color:#fff; }
.guest-dot { width:7px; height:7px; border-radius:50%; background:#44ff88; box-shadow:0 0 6px #44ff88; flex-shrink:0; }

/* ── Auth tabs (old tab layout compat) ── */
.auth-tabs { display:flex; border-bottom:1px solid rgba(0,140,220,0.2); }
.auth-tab {
    flex:1; padding:14px; text-align:center;
    font-family:'Rajdhani',sans-serif;
    font-size:12px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
    color:rgba(160,210,255,0.4); cursor:pointer;
    border-bottom:2px solid transparent; transition:all 0.25s;
}
.auth-tab.active { color:#fff; border-bottom-color:#00b4ff; background:rgba(0,140,220,0.07); }
.auth-tab:hover:not(.active){ color:rgba(160,210,255,0.7); background:rgba(0,140,220,0.04); }
.auth-body { padding:24px 28px 28px; }
.input-group { margin-bottom:14px; }
.input-group label {
    display:block; font-family:'Rajdhani',sans-serif;
    font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
    color:rgba(0,180,255,0.6); margin-bottom:5px;
}

/* ── Credit badge ── */
.credit {
    display:flex; align-items:center; gap:12px;
    padding:10px 22px;
    background:linear-gradient(135deg,rgba(0,20,50,.75),rgba(0,10,30,.85));
    border:1px solid rgba(0,180,255,.2);
    border-radius:40px;
    backdrop-filter:blur(12px);
    box-shadow:0 0 20px rgba(0,100,200,.12), inset 0 1px 0 rgba(0,180,255,.1);
    position:relative; overflow:hidden; margin-top:2px;
}
.credit::before {
    content:'';
    position:absolute; top:0; left:-100%; width:100%; height:100%;
    background:linear-gradient(90deg,transparent,rgba(0,180,255,.06),transparent);
    animation:shimmer 4s ease-in-out infinite;
}
@keyframes shimmer { 0%{left:-100%} 60%,100%{left:120%} }
.credit-icon {
    width:30px; height:30px; flex-shrink:0; border-radius:50%;
    background:linear-gradient(135deg,#0055aa,#00aaff);
    border:1.5px solid rgba(0,180,255,.5);
    display:flex; align-items:center; justify-content:center; font-size:13px;
    box-shadow:0 0 10px rgba(0,150,255,.4);
}
.credit-text { display:flex; flex-direction:column; gap:1px; }
.credit-made {
    font-family:'Rajdhani',sans-serif;
    font-size:9px; letter-spacing:2.5px; text-transform:uppercase;
    color:rgba(100,170,220,.45);
}
.credit-name {
    font-family:'Orbitron',monospace;
    font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
    background:linear-gradient(90deg,#fff 20%,#80d8ff 55%,#00b4ff 100%);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
    filter:drop-shadow(0 0 6px rgba(0,180,255,.5));
}
.credit-divider {
    width:1px; height:28px; flex-shrink:0;
    background:linear-gradient(to bottom,transparent,rgba(0,180,255,.3),transparent);
}
.credit-year {
    font-family:'Orbitron',monospace;
    font-size:10px; font-weight:600; letter-spacing:1px;
    color:rgba(0,180,255,.5);
}
/* legacy compat */
.credit span { color:rgba(0,180,255,.6); font-weight:600; }
.small-link {
    font-size:11px; color:#a0c8e8; cursor:pointer;
    text-align:center; transition:color 0.2s;
    display:inline-block; width:100%; margin-top:5px;
    font-family:'Rajdhani',sans-serif;
}
.small-link:hover { color:#fff; text-decoration:underline; }
.features-strip, .feature-list { display:none; }
.free { display:none; }
h2 { margin:0 0 8px 0; font-size:20px; font-weight:700;
    background:linear-gradient(135deg,#fff,#c3e0ff);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.free { display:none; }

/* ========== CHAT SCREEN ========== */
.chat-container {
    width: 100vw;
    height: 100vh;
    background: linear-gradient(145deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.chat-header {
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.9);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    padding: 8px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
    box-shadow: 0 5px 20px rgba(0,0,0,0.3);
    z-index: 10;
}

.chat-header h2 {
    color: var(--text-primary);
    font-size: 18px;
    font-weight: 600;
    background: linear-gradient(135deg, var(--text-primary), rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.8));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    display: flex;
    align-items: center;
    gap: 10px;
}

.settings-btn {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    color: var(--text-primary);
    font-size: 18px;
    padding: 5px 10px;
    border-radius: 20px;
    cursor: pointer;
    transition: 0.2s;
    margin-left: 10px;
}

.settings-btn:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.2);
    transform: scale(1.05);
}

.chat-main {
    display: flex;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* Rooms Sidebar */
.rooms-sidebar {
    width: 260px;
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.7);
    backdrop-filter: blur(8px);
    border-right: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    flex-shrink: 0;
}

.rooms-header {
    padding: 15px 20px 10px 20px;
    border-bottom: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.15);
}

.rooms-header h4 {
    color: var(--text-primary);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 8px;
}

.rooms-header h4::before {
    content: '📋';
    font-size: 16px;
    color: var(--accent-primary);
}

#rooms-list {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
}

.room-item {
    padding: 7px 10px;
    margin: 3px 0;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.4);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.15);
    color: var(--text-primary);
}

.room-item:hover {
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
    border-color: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    transform: translateX(2px);
}

.room-item.active {
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.25);
    border-color: var(--accent-primary);
    border-left: 3px solid var(--accent-secondary);
}

.room-icon-wrap {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    flex-shrink: 0;
}

.room-item-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.room-item-name {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.room-item.active .room-item-name {
    color: var(--text-primary);
}

.room-item-desc {
    font-size: 9px;
    color: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.6);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.room-count {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.08);
    padding: 2px 6px;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 600;
    white-space: nowrap;
    color: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.7);
    flex-shrink: 0;
}

.room-item.active .room-count {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.15);
    color: var(--text-primary);
}

/* Messages Area */
.messages-area {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: rgba(var(--bg-primary-r), var(--bg-primary-g), var(--bg-primary-b), 0.5);
    backdrop-filter: blur(5px);
    min-width: 0;
    height: 100%;
    overflow: hidden;
}

.messages-list {
    flex: 1;
    overflow-y: auto;
    padding: 20px 24px;
}

.message-bubble {
    padding: 8px 12px;
    margin: 6px 0;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.7);
    backdrop-filter: blur(5px);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    max-width: 80%;
    color: var(--text-primary);
    font-size: 14px;
}

.message-bubble strong {
    color: var(--accent-primary);
    margin-right: 6px;
    font-weight: 600;
}

.message-bubble img {
    max-width: 100%;
    border-radius: 8px;
}

.system-message {
    text-align: center;
    color: var(--accent-primary);
    font-style: italic;
    padding: 6px 14px;
    font-size: 12px;
    margin: 8px 0;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.5);
    border-radius: 30px;
    display: inline-block;
    width: auto;
    margin-left: auto;
    margin-right: auto;
}

/* Formatting Toolbar */
.format-toolbar {
    display: flex;
    padding: 10px 20px;
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.7);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    border-bottom: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    gap: 5px;
    flex-wrap: wrap;
    align-items: center;
    flex-shrink: 0;
    justify-content: space-between;
}

.format-left {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
    align-items: center;
}

.format-right {
    display: flex;
    align-items: center;
}

.format-btn {
    padding: 6px 12px;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    border-radius: 30px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    min-width: 36px;
    height: 34px;
    transition: all 0.2s;
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.format-btn:hover {
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.8);
    border-color: var(--accent-secondary);
    color: var(--text-primary);
}

.format-btn.active {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color: var(--text-primary);
    border-color: transparent;
    box-shadow: 0 4px 10px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
}

.color-picker {
    width: 36px;
    height: 34px;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    border-radius: 30px;
    cursor: pointer;
    padding: 2px;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
}

#fontSize {
    width: 65px;
    padding: 6px;
    border-radius: 30px;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
    color: var(--text-primary);
    height: 34px;
    font-size: 12px;
}

#fontSize option {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

/* Status Dropdown */
.status-dropdown {
    padding: 6px 12px;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    border-radius: 30px;
    color: var(--text-primary);
    font-size: 12px;
    font-weight: 600;
    height: 34px;
    cursor: pointer;
}

.status-dropdown:hover {
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.8);
    border-color: var(--accent-secondary);
}

.status-dropdown option {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

/* ========== RADIO PLAYER IN TOOLBAR ========== */
.radio-toolbar-player {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.15);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    border-radius: 30px;
    padding: 2px 8px 4px 8px;
    color: var(--text-primary);
    transition: all 0.2s;
}
.radio-toolbar-player:hover {
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.25);
    border-color: var(--accent-secondary);
}

.radio-play-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-primary);
    transition: transform 0.2s;
}
.radio-play-btn:hover {
    transform: scale(1.05);
}

.radio-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: 0.3px;
}

.radio-wave {
    display: flex;
    gap: 2px;
    margin-left: 4px;
}
.radio-wave i {
    width: 2px;
    height: 12px;
    background: var(--accent-primary);
    display: block;
    animation: wave 1s infinite ease-in-out;
    opacity: 0.3;
    border-radius: 2px;
}
.radio-toolbar-player.playing .radio-wave i {
    opacity: 1;
    background: var(--text-primary);
}
.radio-wave i:nth-child(2) { animation-delay: 0.1s; }
.radio-wave i:nth-child(3) { animation-delay: 0.2s; }
.radio-wave i:nth-child(4) { animation-delay: 0.3s; }
.radio-wave i:nth-child(5) { animation-delay: 0.4s; }
.radio-wave i:nth-child(6) { animation-delay: 0.5s; }

@keyframes wave {
    0%,100% { height: 8px; }
    50% { height: 16px; }
}

/* ========== MINI RADIO PLAYER – FLOATING PREMIUM ========== */
#radioMini {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.85);
  backdrop-filter: blur(10px);
  padding: 10px 16px;
  border-radius: 40px;
  color: var(--text-primary);
  font-family: Arial, sans-serif;
  box-shadow: 0 10px 25px rgba(0,0,0,0.4);
  z-index: 9999;
  border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.1);
  transition: all 0.3s ease;
}

#radioMini:hover {
  background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.9);
  box-shadow: 0 15px 30px rgba(0,0,0,0.5);
}

.radioPlay {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: linear-gradient(135deg, #ff4d4d, #ff7a18);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  transition: transform 0.2s;
}

.radioPlay:hover {
  transform: scale(1.08);
}

.radioName {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0.5px;
}

.radioWave {
  display: flex;
  gap: 3px;
  margin-top: 2px;
}

.radioWave i {
  width: 3px;
  height: 10px;
  background: #00ffcc;
  display: block;
  animation: wave 1s infinite ease-in-out;
  opacity: 0.4;
  border-radius: 3px;
}

#radioMini.playing .radioWave i {
  opacity: 1;
}

.radioWave i:nth-child(2) { animation-delay: 0.1s; }
.radioWave i:nth-child(3) { animation-delay: 0.2s; }
.radioWave i:nth-child(4) { animation-delay: 0.3s; }
.radioWave i:nth-child(5) { animation-delay: 0.4s; }
.radioWave i:nth-child(6) { animation-delay: 0.5s; }

/* User items with status badges */
.user-item {
    padding: 8px 12px;
    margin: 3px 0;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.5);
    border-radius: 8px;
    font-size: 13px;
    transition: all 0.2s;
    color: var(--text-primary);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.2);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.user-status-badge {
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.status-online { 
    background: rgba(46, 204, 113, 0.15); 
    color: #2ecc71; 
    border: 1px solid rgba(46, 204, 113, 0.2);
}
.status-away { 
    background: rgba(243, 156, 18, 0.15); 
    color: #f39c12; 
    border: 1px solid rgba(243, 156, 18, 0.2);
}
.status-busy { 
    background: rgba(231, 76, 60, 0.15); 
    color: #e74c3c; 
    border: 1px solid rgba(231, 76, 60, 0.2);
}
.status-brb { 
    background: rgba(52, 152, 219, 0.15); 
    color: #3498db; 
    border: 1px solid rgba(52, 152, 219, 0.2);
}

.status-online::before { content: '●'; margin-right: 3px; }
.status-away::before { content: '◐'; margin-right: 3px; }
.status-busy::before { content: '■'; margin-right: 3px; }
.status-brb::before { content: '◑'; margin-right: 3px; }

/* Smiley Popup */
#smiley-popup {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.95);
    backdrop-filter: blur(10px);
    border-radius: 18px;
    padding: 12px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.4);
    z-index: 999999;
    max-width: 800px;
    max-height: 500px;
    overflow-y: auto;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
}

.smiley-grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 5px;
}

.smiley-grid span {
    font-size: 24px;
    cursor: pointer;
    padding: 6px;
    text-align: center;
    border-radius: 10px;
    transition: all 0.2s;
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.05);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.2);
}

.smiley-grid span:hover {
    background: var(--accent-primary);
    transform: scale(1.1);
}

.close-popup-btn {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    color: var(--text-primary);
    font-size: 18px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
}

.close-popup-btn:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.2);
    border-color: var(--accent-secondary);
    transform: scale(1.05);
}

/* ========== BANNER STYLES ========== */
#banner-area {
    flex: 2;
    text-align: center;
    font-weight: bold;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding: 5px 15px;
    border-radius: 30px;
    background: linear-gradient(145deg, rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.15), rgba(var(--accent-secondary-r), var(--accent-secondary-g), var(--accent-secondary-b), 0.05));
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    box-shadow: 0 0 15px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    animation: bannerGlow 3s infinite alternate;
    margin: 0 15px;
    font-size: 16px;
    letter-spacing: 0.5px;
    backdrop-filter: blur(5px);
}

#banner-text {
    display: inline-block;
    color: var(--text-primary);
    text-shadow: 0 0 10px rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.5), 0 0 20px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.8);
}
.banner-slide {
    animation: slideText 20s linear infinite;
}
.banner-static {
    animation: none;
}

@keyframes bannerGlow {
    0% {
        box-shadow: 0 0 10px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
        border-color: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    }
    100% {
        box-shadow: 0 0 25px rgba(var(--accent-secondary-r), var(--accent-secondary-g), var(--accent-secondary-b), 0.7), 0 0 40px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
        border-color: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.5);
    }
}

@keyframes slideText {
    0% { transform: translateX(100%); }
    10% { transform: translateX(0); }
    90% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}

/* ========== PRELOADER ========== */

#preloader {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: #030d1a;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 99999;
    overflow: hidden;
    transition: opacity 0.9s ease, visibility 0.9s ease;
}

#preloader.hidden {
    opacity: 0;
    visibility: hidden;
}

/* Grid background */
#preloader::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(42,140,214,0.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(42,140,214,0.07) 1px, transparent 1px);
    background-size: 40px 40px;
    animation: gridMove 8s linear infinite;
}

@keyframes gridMove {
    0%   { transform: translateY(0); }
    100% { transform: translateY(40px); }
}

/* Radial glow */
#preloader::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 55% at 50% 50%,
        rgba(42,140,214,0.18) 0%,
        rgba(3,13,26,0) 70%);
    pointer-events: none;
}

/* Center content */
.preloader-content {
    position: relative;
    z-index: 2;
    text-align: center;
    width: 380px;
}

/* LOGO MARK */
.logo-mark {
    width: 90px;
    height: 90px;
    margin: 0 auto 28px;
    position: relative;
}

.logo-ring-outer {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 2px solid transparent;
    border-top-color: #3a9eff;
    border-right-color: rgba(58,158,255,0.3);
    animation: spinOuter 2s linear infinite;
}

.logo-ring-inner {
    position: absolute;
    inset: 10px;
    border-radius: 50%;
    border: 1.5px solid transparent;
    border-bottom-color: #8ac4ff;
    border-left-color: rgba(138,196,255,0.3);
    animation: spinInner 1.5s linear infinite;
}

@keyframes spinOuter { to { transform: rotate(360deg); } }
@keyframes spinInner { to { transform: rotate(-360deg); } }

.logo-icon {
    position: absolute;
    inset: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle, rgba(42,140,214,0.25) 0%, rgba(3,13,26,0.8) 100%);
    border-radius: 50%;
    border: 1px solid rgba(42,140,214,0.4);
}

.logo-icon svg {
    width: 28px;
    height: 28px;
    fill: none;
    stroke: #3a9eff;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 0 6px rgba(58,158,255,0.8));
    animation: iconPulse 2s ease-in-out infinite;
}

@keyframes iconPulse {
    0%,100% { filter: drop-shadow(0 0 4px rgba(58,158,255,0.6)); }
    50%      { filter: drop-shadow(0 0 14px rgba(58,158,255,1)); }
}

.logo-dot {
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #3a9eff;
    box-shadow: 0 0 8px #3a9eff;
}
.logo-dot:nth-child(1) { top: -3px; left: 50%; transform: translateX(-50%); }
.logo-dot:nth-child(2) { bottom: -3px; left: 50%; transform: translateX(-50%); }

/* Brand name */
.preloader-brand {
    font-family: 'Orbitron', monospace;
    font-size: 36px;
    font-weight: 900;
    letter-spacing: 10px;
    color: transparent;
    background: linear-gradient(135deg, #ffffff 30%, #8ac4ff 60%, #3a9eff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 20px rgba(58,158,255,0.5));
    animation: brandReveal 0.8s cubic-bezier(0.16,1,0.3,1) both;
    animation-delay: 0.2s;
    margin-bottom: 4px;
}

@keyframes brandReveal {
    from { opacity: 0; transform: translateY(15px) scale(0.95); letter-spacing: 20px; }
    to   { opacity: 1; transform: translateY(0) scale(1); letter-spacing: 10px; }
}

/* Tagline */
.preloader-tagline {
    font-family: 'Rajdhani', sans-serif;
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 5px;
    color: rgba(138,196,255,0.6);
    text-transform: uppercase;
    margin-bottom: 36px;
    animation: fadeUp 0.8s ease both;
    animation-delay: 0.5s;
}

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Progress bar */
.preloader-progress-container {
    position: relative;
    width: 100%;
    height: 3px;
    background: rgba(255,255,255,0.07);
    border-radius: 10px;
    overflow: visible;
    margin-bottom: 16px;
}

.preloader-progress-bar {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, #2a8cd6, #3a9eff, #8ac4ff);
    border-radius: 10px;
    transition: width 0.08s linear;
    position: relative;
}

.preloader-progress-bar::after {
    content: '';
    position: absolute;
    right: -1px;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 10px #3a9eff, 0 0 20px #3a9eff;
}

/* Side markers */
.progress-markers {
    display: flex;
    justify-content: space-between;
    margin-bottom: 5px;
}
.progress-markers span {
    font-family: 'Rajdhani', sans-serif;
    font-size: 9px;
    color: rgba(138,196,255,0.3);
    letter-spacing: 1px;
}

/* Percent + status row */
.preloader-status-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 12px;
}

#progressPercent {
    font-family: 'Orbitron', monospace;
    font-size: 13px;
    font-weight: 700;
    color: #3a9eff;
    letter-spacing: 1px;
}

.preloader-status-text {
    font-family: 'Rajdhani', sans-serif;
    font-size: 11px;
    letter-spacing: 2px;
    color: rgba(138,196,255,0.5);
    text-transform: uppercase;
    animation: blinkStatus 1.4s ease-in-out infinite;
}

@keyframes blinkStatus {
    0%,100% { opacity: 0.5; }
    50%      { opacity: 1; }
}

/* Floating particles */
.particle {
    position: absolute;
    border-radius: 50%;
    background: rgba(58,158,255,0.5);
    pointer-events: none;
    animation: floatUp linear infinite;
}

@keyframes floatUp {
    0%   { transform: translateY(0) scale(1);   opacity: 0.6; }
    100% { transform: translateY(-100vh) scale(0); opacity: 0; }
}

/* Corner decorations */
.corner {
    position: absolute;
    width: 50px;
    height: 50px;
    opacity: 0.35;
}
.corner-tl { top: 20px; left: 20px; border-top: 1.5px solid #3a9eff; border-left: 1.5px solid #3a9eff; }
.corner-tr { top: 20px; right: 20px; border-top: 1.5px solid #3a9eff; border-right: 1.5px solid #3a9eff; }
.corner-bl { bottom: 20px; left: 20px; border-bottom: 1.5px solid #3a9eff; border-left: 1.5px solid #3a9eff; }
.corner-br { bottom: 20px; right: 20px; border-bottom: 1.5px solid #3a9eff; border-right: 1.5px solid #3a9eff; }

/* Scanline */
.scanline {
    position: absolute;
    left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(58,158,255,0.4), transparent);
    animation: scan 4s ease-in-out infinite;
    pointer-events: none;
}
@keyframes scan {
    0%   { top: 0%;   opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 1; }
    100% { top: 100%; opacity: 0; }
}

/* ========== MESSAGE AVATAR & TIMESTAMP STYLES ========== */
.msg-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--accent-primary);
}
.msg-avatar-placeholder {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--bg-tertiary), rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.7));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: bold;
    color: var(--accent-primary);
    border: 2px solid var(--accent-primary);
}
/* Adjust message bubble for new layout */
.message-bubble {
    padding: 8px 12px;
    margin: 6px 0;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.7);
    backdrop-filter: blur(5px);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    max-width: 80%;
    color: var(--text-primary);
    font-size: 14px;
}

/* ========== Drawing Canvas ========== */
#draw-canvas {
    border: 2px solid var(--accent-primary);
    border-radius: 12px;
    margin: 8px auto;
    display: none;
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.7);
    width: calc(100% - 40px);
    max-width: 350px;
    height: auto;
    cursor: crosshair;
    box-shadow: 0 5px 20px rgba(0,0,0,0.3);
}

/* Input Area */
.input-area {
    padding: 12px 20px;
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.7);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    display: flex;
    gap: 10px;
    flex-shrink: 0;
    width: 100%;
}

.input-area input {
    flex: 1;
    min-width: 0;
    padding: 12px 18px;
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    border-radius: 30px;
    font-size: 14px;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
    color: var(--text-primary);
    height: 44px;
}

.input-area input:focus {
    outline: none;
    border-color: var(--accent-secondary);
    box-shadow: 0 0 0 3px rgba(var(--accent-secondary-r), var(--accent-secondary-g), var(--accent-secondary-b), 0.15);
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.7);
}

.input-area input::placeholder {
    color: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.5);
}

.input-area button {
    padding: 12px 25px;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color: var(--text-primary);
    border: none;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
    box-shadow: 0 5px 15px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3);
    height: 44px;
    min-width: 90px;
    letter-spacing: 0.5px;
    border: 1px solid rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
}

.input-area button:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
}

.input-area button:active {
    transform: translateY(0);
}

/* Users Sidebar */
.users-sidebar {
    width: 260px;
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.7);
    backdrop-filter: blur(8px);
    border-left: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    flex-shrink: 0;
}

.users-header {
    padding: 15px 20px 10px 20px;
    border-bottom: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.15);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.users-header h3 {
    color: var(--text-primary);
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.users-header h3::before {
    content: '👥';
    font-size: 16px;
    color: var(--accent-primary);
}

#user-count {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.15);
    padding: 3px 8px;
    border-radius: 30px;
    font-size: 11px;
    font-weight: 600;
    color: var(--accent-primary);
}

#users-list {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
}

/* User Tabs */
.user-tabs {
    display: flex;
    border-top: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    background: rgba(var(--bg-secondary-r), var(--bg-secondary-g), var(--bg-secondary-b), 0.8);
    padding: 5px;
    gap: 3px;
}

.user-tab {
    flex: 1;
    padding: 8px 5px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.7);
    cursor: pointer;
    border-radius: 6px;
    transition: all 0.2s;
}

.user-tab:hover {
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.2);
    color: var(--text-primary);
}

.user-tab.active {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color: var(--text-primary);
}

.logout-btn {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.08);
    color: var(--text-primary);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    padding: 6px 18px;
    border-radius: 30px;
    cursor: pointer;
    font-size: 13px;
    transition: all 0.2s;
    font-weight: 500;
}

.logout-btn:hover {
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.15);
    border-color: var(--accent-secondary);
    transform: scale(1.05);
}

/* Scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.3); }
::-webkit-scrollbar-thumb { background: var(--accent-primary); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent-secondary); }

/* Mobile Responsive */
@media (max-width: 600px) {
    .login-box {
        width: 100%;
        padding: 15px;
    }
    .input-row { grid-template-columns: 1fr; }
    .credit {
        font-size: 10px;
        padding: 5px 12px;
    }
    .rooms-sidebar, .users-sidebar {
        width: 180px;
    }
    .input-area button {
        min-width: 70px;
        padding: 10px 12px;
    }
    .format-left {
        width: 100%;
    }
    .format-right {
        width: 100%;
        margin-top: 5px;
        justify-content: flex-end;
    }
}

/* Banner types */
.banner-info { color: var(--accent-primary); border-left: 3px solid var(--accent-primary); }
.banner-warning { color: #ffaa00; border-left: 3px solid #ffaa00; animation: bannerGlow 2s infinite alternate; }
.banner-success { color: #6bff6b; border-left: 3px solid #6bff6b; }

@media (max-width: 768px) {
    #banner-area {
        font-size: 12px;
        margin: 0 5px;
        padding: 3px 8px;
    }
}

/* ========== MIC BUTTON ========== */
.mic-btn {
    padding: 6px 12px;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.6);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.4);
    border-radius: 30px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    height: 34px;
    min-width: 36px;
    transition: all 0.2s;
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}
.mic-btn:hover { background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.8); border-color: var(--accent-secondary); }
.mic-btn.recording {
    background: rgba(255, 40, 40, 0.15);
    border: 2px solid #ff2828;
    color: #ff4444;
    animation: micpulse 1s infinite;
}
@keyframes micpulse {
    0%,100% { box-shadow: 0 0 6px rgba(255,40,40,0.4); }
    50%      { box-shadow: 0 0 16px rgba(255,40,40,0.8); }
}
.mic-rec-timer {
    font-size: 11px; font-weight: 700;
    font-family: monospace; color: #ff4444; min-width: 30px;
}
/* ========== VOICE MESSAGE PLAYER ========== */
.voice-message {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px;
    background: rgba(var(--bg-tertiary-r), var(--bg-tertiary-g), var(--bg-tertiary-b), 0.75);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.2);
    border-radius: 20px;
    padding: 5px 10px 5px 6px;
    min-width: 220px;
    max-width: 300px;
    height: 40px;
}
.voice-play-btn {
    width: 28px; height: 28px; border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    border: none; color: var(--text-primary); font-size: 11px;
    cursor: pointer; display: flex; align-items: center;
    justify-content: center; flex-shrink: 0; transition: all 0.15s;
}
.voice-play-btn:hover { transform: scale(1.08); }
.voice-waveform {
    flex: 1; display: flex; align-items: center;
    gap: 2px; height: 24px; cursor: pointer;
}
.voice-bar {
    width: 3px; border-radius: 2px;
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.35);
    transition: background 0.15s; min-height: 3px;
}
.voice-bar.played { background: var(--accent-secondary); }
.voice-right {
    display: flex; flex-direction: column;
    align-items: flex-end; gap: 2px; flex-shrink: 0;
}
.voice-time {
    font-size: 9px; color: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.8);
    font-family: monospace; white-space: nowrap;
}
.voice-speed-btn {
    font-size: 8px; font-weight: 700;
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.12);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.28);
    border-radius: 4px; color: var(--accent-primary);
    padding: 1px 5px; cursor: pointer; transition: all 0.15s;
    white-space: nowrap;
}
.voice-speed-btn:hover { background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.3); color: var(--text-primary); }

/* ===== THEME TOGGLE BUTTON ===== */
.theme-toggle-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(var(--text-primary-r), var(--text-primary-g), var(--text-primary-b), 0.1);
    border: 1px solid rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    color: var(--accent-primary);
    margin-right: 5px;
}

.theme-toggle-btn:hover {
    background: rgba(var(--accent-primary-r), var(--accent-primary-g), var(--accent-primary-b), 0.2);
    border-color: var(--accent-secondary);
    transform: rotate(30deg) scale(1.05);
}