body { font-size: 16px; }
.page-container { padding: 0 5px; }
.main-columns { flex-direction: column !important; gap: 0 !important; }
.main-col, .main-col-left { width: 100% !important; max-width: 100% !important; min-width: 0 !important; }
.main-columns > .main-col > .box { margin: 10px 0 !important; }
.header { font-size: 20px; border-radius: 14px 14px 0 0; padding: 14px 0 8px 0; }
.logo { font-size: 18px; gap: 8px; }
.menu { flex-wrap: wrap; gap: 4px; padding: 6px 0; justify-content: center; }
.menu a { font-size: 13px; padding: 6px 12px; border-radius: 8px; margin: 0 1px; min-height: 32px; gap: 4px; display: inline-flex; align-items: center; }
.menu a i { font-size: 12px; }

/* Menu mobile với breakpoint trung gian */
@media (max-width: 600px) and (min-width: 451px) {
    .menu a {
        font-size: 11px !important;
        padding: 5px 8px !important;
        gap: 3px !important;
    }
    .menu a i {
        font-size: 13px !important;
    }
}
.box, .login-box { max-width: 100%; border-radius: 14px; margin: 12px auto; padding: 0; }

@media (max-width: 450px) {
    .menu {
        gap: 2px !important;
        padding: 4px 0 !important;
    }
    .menu a {
        font-size: 10px !important;
        padding: 6px 4px !important;
        min-width: 48px !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 2px !important;
        text-align: center !important;
        line-height: 1.1 !important;
        margin: 0 1px !important;
        border-radius: 6px !important;
    }
    .menu a i {
        font-size: 14px !important;
        margin: 0 !important;
        display: block !important;
    }
    
    /* Cải thiện active state cho mobile */
    .menu a.active {
        background: linear-gradient(135deg, #3ecf8e 0%, #2b7a78 100%) !important;
        color: white !important;
        font-weight: bold !important;
    }
    
    /* Responsive text cho các menu items dài */
    .menu a:nth-child(1) { /* Trang Chủ */
        /* Giữ nguyên */
    }
    .menu a:nth-child(2) { /* Tải về */
        /* Giữ nguyên */
    }
    .menu a:nth-child(3) { /* BXH */
        /* Giữ nguyên */
    }
    .menu a:nth-child(4) { /* Chat */
        /* Giữ nguyên */
    }
    
    /* Đối với các menu có text dài hơn */
    .menu a[href*="profile"] {
        font-size: 9px !important;
    }
    .menu a[href*="admin"] {
        font-size: 9px !important;
    }
    .menu a[href*="deposit"] {
        font-size: 8px !important;
        line-height: 1 !important;
    }
    .menu a[href*="login"] {
        font-size: 8px !important;
    }
    .menu a[href*="register"] {
        font-size: 8px !important;
        line-height: 1 !important;
    }
    .menu a[href*="logout"] {
        font-size: 9px !important;
    }
}

/* Màn hình cực nhỏ (dưới 350px) */
@media (max-width: 350px) {
    .menu a {
        font-size: 8px !important;
        padding: 4px 2px !important;
        min-width: 42px !important;
        gap: 1px !important;
    }
    
    .menu a i {
        font-size: 12px !important;
    }
    
    /* Text còn nhỏ hơn cho menu items dài */
    .menu a[href*="deposit"] {
        font-size: 7px !important;
    }
    .menu a[href*="register"] {
        font-size: 6px !important;
    }
    .menu a[href*="login"] {
        font-size: 7px !important;
    }
}

.box-title { font-size: 16px; padding: 14px 10px; border-radius: 14px 14px 0 0; }
.chat-list { padding: 14px 6px; min-height: 120px; border-radius: 0 0 14px 14px; }
.chat-item { padding: 10px 0; border-radius: 12px; }
.avatar { width: 38px; height: 38px; margin-right: 8px; border-width: 2px; min-width: 36px; min-height: 36px; }
.username { font-size: 15px; margin-right: 6px; }
.status-dot { width: 10px; height: 10px; margin-right: 4px; }
.time { font-size: 12px; margin-left: 6px; }
.message { font-size: 16px; margin-top: 3px; }
.chat-form-custom { padding: 10px; gap: 8px; border-radius: 0 0 14px 14px; }
.chat-form-custom input[type=text] { font-size: 15px; padding: 10px 12px; border-radius: 8px; min-height: 36px; }
.chat-form-custom button { font-size: 15px; padding: 0 18px; border-radius: 8px; min-height: 36px; }
.category-box { border-radius: 14px; margin-top: 12px; }
.category-list { padding: 10px 4px; gap: 10px; }
.category-item { font-size: 15px; padding: 12px 12px; border-radius: 10px; gap: 8px; min-height: 36px; }
.category-icon { font-size: 16px; min-width: 20px; }
.download-box { border-radius: 14px; margin-bottom: 12px; }
.download-list { gap: 8px; padding: 10px 0 8px 0; }
.download-btn { font-size: 15px; padding: 8px 18px; border-radius: 10px; min-height: 36px; }
.compact-download { border-radius: 10px; }
.compact-download-list { gap: 6px; padding: 6px 0 5px 0; }
.compact-btn { font-size: 13px !important; padding: 5px 12px !important; border-radius: 7px !important; min-height: 36px; }
.stats { font-size: 15px; border-radius: 0 0 14px 14px; padding: 12px 6px; }
.profile-box { max-width: 100%; border-radius: 10px; padding: 12px 4px 12px 4px; }
.profile-box button { font-size: 14px; padding: 7px 14px; border-radius: 8px; min-height: 36px; }
.profile-box input[type="password"] { font-size: 14px; padding: 8px 10px; border-radius: 8px; min-height: 36px; }
.profile-header { flex-direction: column; gap: 6px; text-align: center; }
.profile-info { text-align: center; }
.profile-avatar { width: 38px; height: 38px; }
.profile-username { font-size: 15px; }
.profile-section { padding: 10px 3px; border-radius: 8px; }
.profile-section-title { font-size: 13px; }
.profile-logout-btn { font-size: 14px; padding: 7px 14px; border-radius: 8px; min-height: 36px; }
.admin-table th, .admin-table td { font-size: 13px; padding: 7px 4px; }
.admin-action { font-size: 14px; padding: 7px 12px; border-radius: 8px; min-height: 36px; }
#toast.toast, .toast { font-size: 14px; padding: 10px 18px; border-radius: 10px; min-width: 140px; }
#delete-modal { min-width: 200px; padding: 16px 12px 12px 12px; border-radius: 12px; }
#delete-modal .modal-title { font-size: 15px; margin-bottom: 8px; }
#delete-modal .modal-desc { font-size: 13px; margin-bottom: 12px; }
#delete-modal .modal-btn { font-size: 14px; padding: 7px 16px; border-radius: 8px; min-height: 36px; }
.topic-title {
    /* reset lại cho PC nếu bị ảnh hưởng */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 16px;
    font-weight: 600;
    color: #2b7a78;
    margin-bottom: 8px;
    text-decoration: none;
    display: block;
}
.topic-content {
    flex: 1;
    min-width: 0;
}

@media (max-width: 700px) {
    .topic-item {
        flex-direction: row !important;
        align-items: flex-start !important;
        gap: 10px !important;
        padding: 12px 6px !important;
    }
    .topic-avatar {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
    }
    .topic-content {
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        min-width: 0 !important;
        width: 100% !important;
        padding: 0 !important;
    }
    .topic-title {
        display: block !important;
        white-space: normal !important;
        word-break: break-word !important;
        overflow: visible !important;
        text-overflow: unset !important;
        font-size: 15px !important;
        color: #2b7a78 !important;
        font-weight: bold !important;
        background: none !important;
        min-height: unset !important;
        margin-bottom: 6px !important;
        letter-spacing: normal !important;
        text-align: left !important;
    }
    .topic-preview {
        font-size: 13px !important;
        -webkit-line-clamp: 1 !important;
        margin-bottom: 4px !important;
    }
    .topic-meta {
        gap: 8px !important;
        font-size: 12px !important;
    }
    .topic-stats, .topic-stat {
        display: none !important;
    }
} 
/* 1. GIỮ NGUYÊN KHUNG BAO NGOÀI */
.donate-wrapper {
    position: fixed;
    bottom: 20px;
    right: 20px; /* Cách lề phải 20px */
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: flex-end; /* QUAN TRỌNG: Canh lề phải để bong bóng nở sang trái */
}

/* 2. GIỮ NGUYÊN NÚT BẤM */
.donate-btn-group {
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    animation: float 2s ease-in-out infinite;
}

.donate-btn-group img {
    width: 60px;
    transition: transform 0.2s;
}
.donate-btn-group:hover img { transform: scale(1.1); }

.donate-btn-group span {
    background: #ffe600; color: #d60000;
    padding: 4px 10px; border-radius: 20px;
    font-weight: bold; font-size: 13px;
    margin-top: 5px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    white-space: nowrap; /* Giữ chữ trên 1 dòng */
}

/* 3. SỬA LẠI KHUNG QR (Lệch sang trái) */
.qr-bubble {
    display: none;
    position: absolute;
    bottom: 100%; 
    right: 0; /* Neo chặt vào bên phải, khung sẽ dài ra phía trái */
    margin-bottom: 15px;
    
    background: white;
    padding: 10px;
    border-radius: 10px 10px 0 10px; /* Bo tròn góc, trừ góc dưới phải cho nhọn */
    box-shadow: 0 5px 15px rgba(0,0,0,0.2);
    width: 200px;
    text-align: center;
    animation: popUp 0.3s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

/* SỬA LẠI MŨI TÊN (Chuyển sang góc phải) */
.qr-bubble::after {
    content: "";
    position: absolute;
    top: 100%;
    right: 25px; /* Đặt mũi tên lệch về bên phải (thẳng hàng với icon) */
    /* Bỏ left: 50% cũ đi */
    border-width: 10px;
    border-style: solid;
    border-color: white transparent transparent transparent;
}

.qr-img { width: 100%; border-radius: 5px; }
.qr-text { font-size: 13px; margin-top: 5px; color: #333; }

@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
@keyframes popUp { from{opacity:0; transform:scale(0.8) translateY(10px); transform-origin: bottom right;} to{opacity:1; transform:scale(1) translateY(0); transform-origin: bottom right;} }