@import url('https://fonts.googleapis.com/css?family=Tajawal:300,400,500,700&display=swap');
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css");

:root {
    /* Professional Midnight Theme */
    --bg: #0b1120;         
    --card: #1e293b;       
    --card-hover: #334155;
    --sidebar-bg: #0f172a; 
    
    /* Corporate Blue Theme */
    --primary: #3b82f6;    
    --primary-glow: rgba(59, 130, 246, 0.25);
    --primary-text: #fff;
    
    --text: #f8fafc;
    --text-muted: #94a3b8; 
    --border: #334155;     
    
    --success: #10b981;
    --danger: #ef4444;
    --warning: #f59e0b;
    --radius: 10px;        
    --transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; font-family: "Tajawal", sans-serif; }

body { 
    background: var(--bg); color: var(--text); height: 100vh; overflow: hidden; letter-spacing: 0.01em; 
    display: flex; justify-content: center; align-items: center; padding: 20px; 
    background-image: linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
    background-size: 40px 40px;
}
.hidden { display: none !important; }

/* --- DASHBOARD LAYOUT --- */
.dashboard-container { display: flex; flex-direction: column; width: 100%; max-width: 1350px; height: 100%; gap: 20px; }
.top-navbar { width: 100%; height: 75px; background: var(--sidebar-bg); border: 1px solid var(--border); border-radius: 16px; display: flex; align-items: center; justify-content: space-between; padding: 0 25px; flex-shrink: 0; box-shadow: 0 10px 30px rgba(0,0,0,0.25); z-index: 100; }
.main-content { flex: 1; padding: 30px; overflow-y: auto; background: var(--card); border-radius: 16px; border: 1px solid var(--border); box-shadow: 0 10px 30px rgba(0,0,0,0.25); position: relative; }
.navbar-left, .navbar-center, .navbar-right { display: flex; align-items: center; }
.navbar-center { gap: 15px; height: 100%; }
.navbar-right { gap: 15px; }

.brand-group { display: flex;  align-items: center; gap: 10px; overflow: hidden; }
.brand-group img { height: 32px; filter: drop-shadow(0 0 5px var(--primary-glow)); }
.brand-group span { font-weight: 700; font-size: 1rem; color: #fff; white-space: nowrap; letter-spacing: 0.5px; }
.user-compact-profile { display: flex; align-items: center; gap: 12px; padding: 8px 12px; border-radius: var(--radius); transition: 0.2s; cursor: pointer; }
.user-compact-profile:hover { background: rgba(255, 255, 255, 0.05); }
.user-avatar-sm { width: 42px; height: 42px; border-radius: 50%; border: 2px solid var(--primary); object-fit: cover; box-shadow: 0 0 10px var(--primary-glow); }
.user-info-text { display: flex; flex-direction: column; justify-content: center; }
.user-info-text .u-name { font-size: 0.95rem; font-weight: 600; color: #fff; line-height: 1.2; margin-bottom: 3px; }
.user-info-text .u-role { font-size: 0.65rem; color: var(--primary); text-transform: uppercase; font-weight: 700; letter-spacing: 0.5px; background: rgba(59, 130, 246, 0.1); padding: 2px 6px; border-radius: 4px; display: inline-block; width: max-content; }

.nav-item { padding: 8px 16px; border-radius: var(--radius); color: var(--text-muted); cursor: pointer; transition: var(--transition); display: flex; align-items: center; gap: 8px; font-weight: 600; border: 1px solid transparent; position: relative; height: 40px; flex-shrink: 0; }
.nav-item:hover { background: rgba(255,255,255,0.05); color: #fff; }
.nav-item.active { background: rgba(59, 130, 246, 0.1); color: var(--primary); border-color: rgba(59, 130, 246, 0.3); }
.nav-item .nav-label { display: flex; align-items: center; gap: 8px; font-size: 0.95rem; white-space: nowrap; }

.dropdown-container { position: relative; }
.dropdown-container .arrow { transition: transform 0.3s; }
.dropdown-container:hover .arrow { transform: rotate(180deg); color: var(--primary); }
.dropdown-menu { visibility: hidden; opacity: 0; position: absolute; top: 130%; left: 50%; transform: translateX(-50%) translateY(10px); background: var(--sidebar-bg); border: 1px solid var(--border); border-radius: 12px; min-width: 200px; box-shadow: 0 10px 30px rgba(0,0,0,0.5); z-index: 100; padding: 10px; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); }
.dropdown-menu.dropdown-menu-right { left: auto; right: 0; transform: translateY(10px); }
.dropdown-container:hover .dropdown-menu { visibility: visible; opacity: 1; transform: translateX(-50%) translateY(0); top: calc(100% + 10px); }
.dropdown-container:hover .dropdown-menu.dropdown-menu-right { transform: translateY(0); }
.sub-item { padding: 12px 15px; color: var(--text-muted); font-size: 0.9rem; cursor: pointer; border-radius: 8px; transition: var(--transition); display: flex; align-items: center; gap: 12px; margin-bottom: 2px; font-weight: 500; white-space: nowrap; }
.sub-item:hover { color: #fff; background: rgba(255,255,255,0.05); transform: translateX(5px); }
[dir="rtl"] .sub-item:hover { transform: translateX(-5px); }
.sub-item.active { color: var(--primary); background: rgba(59, 130, 246, 0.05); border-left: 2px solid var(--primary); }
[dir="rtl"] .sub-item.active { border-left: none; border-right: 2px solid var(--primary); }

/* --- NEW PROFILE SETTINGS LAYOUT --- */
.profile-layout { display: grid; grid-template-columns: 320px 1fr; gap: 30px; }
.profile-card { background: var(--bg); border: 1px solid var(--border); border-radius: 16px; padding: 30px; box-shadow: 0 4px 15px rgba(0,0,0,0.1); overflow: hidden;}
.avatar-section { text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; height: fit-content; }
.img-wrapper { position: relative; width: 140px; height: 140px; margin: 0 auto 20px; }
.profile-img-large { width: 140px; height: 140px; border-radius: 50%; object-fit: cover; border: 4px solid var(--card); box-shadow: 0 0 0 2px var(--primary); }
.edit-overlay { position: absolute; bottom: 5px; right: 5px; background: var(--primary); width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; cursor: pointer; transition: 0.2s; box-shadow: 0 4px 10px rgba(0,0,0,0.3); }
.edit-overlay:hover { transform: scale(1.1); }

.settings-title { font-size: 1.1rem; color: #fff; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.05); display: flex; align-items: center; gap: 10px; font-weight: 600; }
.settings-title i { color: var(--primary); }

.connection-box { display: flex; align-items: center; justify-content: space-between; background: rgba(88, 101, 242, 0.05); border: 1px solid rgba(88, 101, 242, 0.2); padding: 20px; border-radius: 12px; transition: 0.3s; flex-wrap: wrap; gap: 10px;}
.connection-box:hover { border-color: #5865F2; background: rgba(88, 101, 242, 0.1); }
.conn-info { display: flex; align-items: center; gap: 15px; }
.discord-icon { font-size: 2.2rem; color: #5865F2; }
.conn-title { font-weight: 600; display: block; color: #fff; font-size: 0.95rem; margin-bottom: 3px; }
.conn-status { font-size: 0.85rem; color: var(--text-muted); }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); border-radius: 4px; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--primary); }

.status-badge { padding: 4px 10px; border-radius: 6px; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; display: inline-block; white-space: nowrap; }
.status-assigned { color: #60a5fa; background: rgba(59, 130, 246, 0.15); border: 1px solid rgba(59, 130, 246, 0.3); }
.status-review { color: #fbbf24; background: rgba(245, 158, 11, 0.15); border: 1px solid rgba(245, 158, 11, 0.3); }
.status-completed { color: #34d399; background: rgba(16, 185, 129, 0.15); border: 1px solid rgba(16, 185, 129, 0.3); }
.status-available { color: var(--text-muted); background: rgba(255, 255, 255, 0.05); border: 1px solid var(--border); }

/* --- INPUTS --- */
.lang-btn { background: var(--bg); border: 1px solid var(--border); color: var(--text); padding: 6px 14px; border-radius: 6px; cursor: pointer; font-size: 0.8rem; transition: 0.3s; white-space: nowrap; }
.lang-btn:hover { border-color: var(--primary); color: var(--primary); }
.input-group { position: relative; margin-bottom: 20px; width: 100%;}
.input-group .icon { position: absolute; left: 15px; top: 50%; transform: translateY(39%); color: var(--text-muted); z-index: 2; pointer-events: none; font-size: 0.9rem; }
.input-group label { display: block; font-size: 0.8rem; color: var(--text-muted); margin-bottom: 8px; font-weight: 500; }
.input-group input, .input-group select, .input-group textarea { width: 100%; background: var(--card); border: 1px solid var(--border); padding: 12px 12px 12px 45px; color: #fff; border-radius: 8px; outline: none; transition: var(--transition); font-size: 0.95rem; }
.input-group select { padding-left: 15px; } /* Adjust select padding */
.search-input { background: var(--bg) !important; border: 1px solid var(--border) !important; color: white !important; padding: 10px 15px !important; width: 100% !important; max-width: 250px;}
.input-group input:focus, .input-group select:focus, .input-group textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.input-group input:focus + .icon { color: var(--primary); }
.file-drop-area { border: 2px dashed var(--border); padding: 40px 20px; text-align: center; border-radius: 12px; cursor: pointer; background: rgba(255,255,255,0.01); position: relative; transition: all 0.3s ease; width: 100%; word-break: break-word;}
.file-drop-area:hover, .file-drop-area.drag-over { border-color: var(--primary); background: rgba(59, 130, 246, 0.05); }
.file-drop-area.file-selected { border-color: var(--success); background: rgba(16, 185, 129, 0.05); color: var(--success); }
.file-drop-area input { position: absolute; inset: 0; opacity: 0; cursor: pointer; height: 100%; width: 100%; }

.btn-discord { background: #5865F2; color: #fff; padding: 12px 24px; border: none; border-radius: 8px; cursor: pointer; font-weight: 600; display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; transition: var(--transition); }
.btn-discord:hover { background: #4752C4; box-shadow: 0 4px 15px rgba(88, 101, 242, 0.3); }

/* --- CARDS & WIDGETS --- */
.section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 25px; background: var(--bg); border: 1px solid var(--border); border-left: 4px solid var(--primary); padding: 25px 30px; border-radius: 12px; flex-wrap: wrap; gap: 15px;}
.filters { background: var(--bg); padding: 5px; border-radius: 8px; border: 1px solid var(--border); display: inline-flex; gap: 5px; flex-wrap: wrap; align-items: center; width: 100%;}
.filters input { background: transparent; border: none; padding: 8px 12px; color: #fff; outline: none; flex: 1; min-width: 150px;}
.filters button { background: transparent; border: none; color: var(--text-muted); padding: 8px 16px; cursor: pointer; border-radius: 6px; font-weight: 500; transition: var(--transition); font-size: 0.9rem; white-space: nowrap;}
.filters button:hover { color: var(--text); background: rgba(255,255,255,0.05); }
.filters button.active { background: var(--card); color: var(--primary); box-shadow: 0 2px 5px rgba(0,0,0,0.2); }

.welcome-banner { background: linear-gradient(135deg, rgba(59, 130, 246, 0.15), var(--bg)); border: 1px solid rgba(59, 130, 246, 0.2); padding: 40px; border-radius: 16px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; position: relative; overflow: hidden; flex-wrap: wrap; gap: 20px;}
.welcome-banner::after { content: ''; position: absolute; top: -50px; right: -50px; width: 200px; height: 200px; background: var(--primary); filter: blur(100px); opacity: 0.15; pointer-events: none; }
.welcome-text h1 { font-size: 1.8rem; margin-bottom: 8px; color: #fff; letter-spacing: -0.5px; }
.welcome-text p { color: var(--text-muted); font-size: 1rem; margin: 0;}
.btn-glass { background: rgba(59, 130, 246, 0.1); border: 1px solid rgba(59, 130, 246, 0.3); color: var(--primary); padding: 10px 25px; border-radius: 8px; cursor: pointer; font-weight: 600; transition: 0.3s; display: flex; align-items: center; gap: 8px; white-space: nowrap; justify-content: center;}
.btn-glass:hover { background: var(--primary); color: #fff; box-shadow: 0 0 15px var(--primary-glow); }

.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 25px; }
.stat-card { background: var(--bg); padding: 25px; border-radius: 12px; border: 1px solid var(--border); position: relative; overflow: hidden; transition: transform 0.2s; display: flex; align-items: center; gap: 20px;}
.stat-card:hover { transform: translateY(-5px); box-shadow: 0 10px 20px -5px rgba(0,0,0,0.3); }
.stat-card.blue { border-top: 4px solid var(--primary); }
.stat-card.blue h1 { color: #fff; }
.stat-card.green { border-top: 4px solid var(--success); }
.stat-card.green h1 { color: #fff; }
.stat-card.purple { border-top: 4px solid #a855f7; }
.stat-card.purple h1 { color: #fff; }
.stat-icon-box { width: 50px; height: 50px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; flex-shrink: 0;}
.stat-icon-box.blue { background: rgba(59, 130, 246, 0.1); color: #60a5fa; }
.stat-icon-box.green { background: rgba(16, 185, 129, 0.1); color: #34d399; }
.stat-icon-box.purple { background: rgba(168, 85, 247, 0.1); color: #a855f7; }
.stat-info { display: flex; flex-direction: column;}
.stat-info h3 { margin: 0 0 5px 0; font-size: 0.8rem; color: var(--text-muted); text-transform: uppercase; font-weight: 700; }
.stat-info h1 { margin: 0; font-size: 1.8rem; color: #fff; line-height: 1;}

.btn-icon-only { background: transparent; border: none; color: var(--text-muted); cursor: pointer; transition: 0.3s; width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0;}
.btn-icon-only:hover { color: var(--primary); background: rgba(255,255,255,0.05); }

.page-hero { background: linear-gradient(to right, rgba(59, 130, 246, 0.08), transparent); padding: 30px; border-radius: 12px; margin-bottom: 30px; border-left: 4px solid var(--primary); display: flex; justify-content: space-between; align-items: center; border: 1px solid var(--border); border-left-width: 4px; flex-wrap: wrap; gap: 15px;}
.page-hero h1 { font-size: 1.8rem; margin-bottom: 5px; color: #fff; font-weight: 700; }
.page-hero p { color: var(--text-muted); margin: 0;}

.task-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.task-card { background: var(--bg); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; position: relative; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); display: flex; flex-direction: column; cursor: pointer; }
.task-card:hover { transform: translateY(-5px); border-color: var(--primary); box-shadow: 0 15px 30px -10px rgba(0,0,0,0.4); }
.task-card .task-banner { height: 180px; width: 100%; object-fit: cover; border-bottom: 1px solid var(--border); }
.task-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.task-price-badge { background: rgba(16, 185, 129, 0.1); color: var(--success); border: 1px solid rgba(16, 185, 129, 0.2); padding: 5px 12px; border-radius: 6px; font-weight: 700; font-size: 0.95rem; white-space: nowrap;}

.wallet-grid { display: grid; grid-template-columns: 1fr; gap: 30px; }
.wallet-action-card { background: var(--bg); border: 1px solid var(--border); border-left: 4px solid var(--primary); border-radius: 12px; padding: 30px; position: relative; overflow: hidden; }
.wallet-action-card h3 { margin-bottom: 25px; color: #fff; display: flex; align-items: center; gap: 12px; }
.balance-hero { font-size: 1.8rem; font-weight: 800; color: var(--success); background: rgba(16, 185, 129, 0.1); border: 1px solid rgba(16, 185, 129, 0.3); padding: 8px 20px; border-radius: 8px; letter-spacing: -0.5px; white-space: nowrap; text-align: center;}

.chat-container { height: calc(100vh - 220px); min-height: 400px; background: var(--bg); border: 1px solid var(--border); border-radius: 16px; display: flex; flex-direction: column; overflow: hidden; }
.chat-header-bar { padding: 15px 25px; background: var(--card); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 12px; }
.live-dot { width: 8px; height: 8px; background: var(--success); border-radius: 50%; box-shadow: 0 0 10px var(--success); flex-shrink: 0;}
.chat-feed { flex: 1; padding: 20px; overflow-y: auto; display: flex; flex-direction: column; gap: 20px; background: var(--bg); }
.msg-row { display: flex; gap: 10px; max-width: 85%; }
.msg-row.me { align-self: flex-end; flex-direction: row-reverse; }
.msg-avatar { width: 36px; height: 36px; border-radius: 8px; object-fit: cover; border: 1px solid var(--border); flex-shrink: 0;}
.msg-bubble { background: var(--card); padding: 12px 15px; border-radius: 12px; position: relative; min-width: 100px; border: 1px solid var(--border); box-shadow: 0 2px 4px rgba(0,0,0,0.1); word-break: break-word;}
.msg-row.me .msg-bubble { background: var(--primary); color: white; border-color: var(--primary); }
.msg-name { font-weight: 700; color: #fff; font-size: 0.8rem; margin-bottom: 6px; display: block; }
.msg-row.me .msg-name { color: #e0f2fe; }
.msg-row.me .msg-content { color: white; }
.chat-controls { background: var(--card); border-top: 1px solid var(--border); padding: 15px; display: flex; flex-direction: column; gap: 10px; }
.input-wrapper { display: flex; align-items: center; gap: 10px; border: 1px solid var(--border); padding: 5px 10px; border-radius: 10px; transition: var(--transition); background: var(--bg); width: 100%;}
.input-wrapper:focus-within { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-glow); }
#chat-input { flex: 1; width: 100%; padding: 10px; margin: 0; border: none; background: transparent; color: #fff; font-size: 1rem; outline: none; min-width: 0; /* Important for flex child input */}
.send-btn { background: var(--primary); color: #fff; border: none; width: 40px; height: 40px; border-radius: 8px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: 0.2s; flex-shrink: 0;}
.send-btn:hover { background: #2563eb; }
.chat-media { max-width: 100%; max-height: 200px; border-radius: 8px; margin-top: 8px; object-fit: contain; background: rgba(0,0,0,0.2); display: block; }
.chat-video { max-width: 100%; border-radius: 8px; margin-top: 8px; }

.admin-quick-stats { display: flex; gap: 15px; flex-wrap: wrap;}
.mini-stat { background: rgba(0,0,0,0.3); border: 1px solid var(--border); padding: 8px 15px; border-radius: 8px; text-align: center; flex: 1; min-width: 100px; }
.mini-stat .value { font-size: 1.1rem; font-weight: 700; display: block; }
.admin-card { background: var(--bg); border: 1px solid var(--border); border-radius: 12px; padding: 0; display: flex; flex-direction: column; gap: 0; transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1); position: relative; overflow: hidden; margin-bottom: 20px;}
.admin-card:hover { transform: translateY(-3px); border-color: var(--primary); box-shadow: 0 15px 30px -10px rgba(0, 0, 0, 0.3); }
.admin-card-header { padding: 20px; display: flex; gap: 15px; align-items: flex-start; border-bottom: 1px solid var(--border); background: rgba(255,255,255,0.01); flex-wrap: wrap;}
.admin-avatar-box { width: 45px; height: 45px; background: var(--bg); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-weight: 700; color: var(--primary); font-size: 1.2rem; border: 1px solid var(--border); flex-shrink: 0;}
.admin-info { flex: 1; min-width: 200px;}
.admin-info h4 { margin: 0 0 5px 0; font-size: 1.05rem; color: #fff; font-weight: 600; word-break: break-word;}
.price-tag-large { font-size: 1rem; font-weight: 700; color: var(--success); background: rgba(16, 185, 129, 0.1); padding: 4px 10px; border-radius: 6px; white-space: nowrap; height: fit-content;}
.sub-meta { margin: 0; font-size: 0.85rem; color: var(--text-muted); }
.sub-meta .highlight { color: #e2e8f0; font-weight: 500; }
.admin-card-body { padding: 20px; background: rgba(0, 0, 0, 0.1); }
.submission-note-box { background: rgba(255, 255, 255, 0.02); border-left: 3px solid var(--primary); padding: 15px; border-radius: 0 6px 6px 0; overflow-x: auto;}
.note-label { display: block; font-size: 0.7rem; text-transform: uppercase; color: var(--text-muted); margin-bottom: 5px; font-weight: 700; letter-spacing: 0.5px; }
.submission-note-box p { margin: 0; color: #cbd5e1; font-style: italic; font-size: 0.95rem; line-height: 1.5; white-space: pre-wrap; word-break: break-word;}
.admin-card-footer { padding: 15px 20px; display: flex; justify-content: space-between; align-items: center; background: var(--card); border-top: 1px solid var(--border); flex-wrap: wrap; gap: 15px; }
.btn-download-large { display: inline-flex; align-items: center; justify-content: center; gap: 8px; color: var(--primary); text-decoration: none; font-weight: 600; font-size: 0.9rem; padding: 8px 16px; border: 1px solid var(--border); border-radius: 8px; transition: 0.2s; background: var(--bg); white-space: nowrap; width: 100%;}
.btn-download-large:hover { border-color: var(--primary); background: rgba(59, 130, 246, 0.05); }

.amount-rejected { color: var(--text-muted); text-decoration: line-through; font-weight: bold; }
.admin-avatar-box.warning { color: var(--warning); border-color: rgba(245, 158, 11, 0.3); background: rgba(245, 158, 11, 0.05); }
.price-tag-large.warning { color: var(--warning); background: rgba(245, 158, 11, 0.1); }
.submission-note-box.warning { border-left-color: var(--warning); background: rgba(245, 158, 11, 0.02); }
.submission-note-box.warning .note-label { color: var(--warning); }
.admin-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; width: 100%;}
.pay-input-group { position: relative; display: flex; align-items: center; flex: 1; min-width: 120px;}
.pay-input-group .currency { position: absolute; left: 10px; color: var(--success); font-weight: bold; z-index: 2; }
.pay-input-group input { width: 100%; padding: 8px 10px 8px 25px; margin: 0; background: var(--bg); border: 1px solid var(--border); color: #fff; font-weight: bold; font-size: 0.95rem; border-radius: 6px; outline: none; }
.pay-input-group input:focus { border-color: var(--success); }
.btn-action { flex: 1; padding: 8px 16px; border-radius: 6px; border: none; font-weight: 600; font-size: 0.9rem; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: 0.2s; white-space: nowrap; min-width: 100px;}
.btn-action.approve { background: var(--success); color: #022c22; }
.btn-action.approve:hover { opacity: 0.9; transform: translateY(-1px); }
.btn-action.reject { background: transparent; color: var(--danger); border: 1px solid var(--danger); }
.btn-action.reject:hover { background: var(--danger); color: #fff; }

/* Wrapper for tables to allow horizontal scrolling */
.table-wrapper { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 12px; border: 1px solid var(--border); background: var(--bg);}
.glass-table { width: 100%; border-collapse: collapse; min-width: 700px; /* Minimum width before scrolling */ }
.glass-table th, .glass-table td { text-align: left; padding: 15px; border-bottom: 1px solid rgba(255,255,255,0.05); }
.glass-table th { color: var(--text-muted); font-size: 0.85rem; font-weight: 600; text-transform: uppercase; background: rgba(0,0,0,0.2);}
.glass-table tbody tr { transition: 0.2s; }
.glass-table tbody tr:hover { background: rgba(255, 255, 255, 0.03); }
.glass-table td { color: #e2e8f0; }

.wallet-history-card { max-height: 500px; overflow: hidden; background: var(--bg); border: 1px solid var(--border); border-radius: 12px; padding: 0; position: relative; display: flex; flex-direction: column;}
.wallet-history-card h3 { padding: 20px; margin: 0; background: var(--bg); border-bottom: 1px solid var(--border); flex-shrink: 0;}
.history-table-wrapper { overflow-y: auto; overflow-x: auto; flex: 1; -webkit-overflow-scrolling: touch;}
.history-table { width: 100%; border-collapse: collapse; min-width: 600px; }
.history-table th { position: sticky; top: 0; background: var(--card); z-index: 2; text-align: left; color: var(--text-muted); padding: 15px; border-bottom: 1px solid var(--border); font-weight: 600; font-size: 0.85rem; text-transform: uppercase; }
.history-table td { padding: 15px; color: #cbd5e1; border-bottom: 1px solid rgba(255,255,255,0.03); }

.action-btn-group { display: flex; gap: 8px; }
.btn-icon { width: 32px; height: 32px; border-radius: 6px; border: 1px solid var(--border); background: transparent; color: var(--text-muted); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: 0.2s; flex-shrink: 0;}
.btn-edit:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.btn-view:hover { background: #fff; color: #000; border-color: #fff; }
.btn-delete:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
input:disabled { background-color: var(--card); opacity: 0.7; }
.disabledbtn { opacity: 0.6; cursor: not-allowed; pointer-events: none; }
.chat-role { font-size: 0.65rem; padding: 2px 6px; border-radius: 4px; margin-left: 8px; vertical-align: middle; font-weight: 800; letter-spacing: 0.5px; white-space: nowrap;}
.chat-role.ceo-badge { background: linear-gradient(135deg, #FFD700 0%, #FDB931 100%); color: #000; border: 1px solid #FFD700; }
.chat-role.manager-badge { background: rgba(168, 85, 247, 0.15); color: #d8b4fe; border: 1px solid rgba(168, 85, 247, 0.3); }
.chat-role.admin-badge { background: rgba(239, 68, 68, 0.15); color: #fca5a5; border: 1px solid rgba(239, 68, 68, 0.3); }
.chat-role.dev-badge { background: rgba(59, 130, 246, 0.15); color: #93c5fd; border: 1px solid rgba(59, 130, 246, 0.3); }

/* --- BUTTONS & VARS --- */
.btn-primary { background: var(--primary); color: #fff; padding: 12px 24px; border: none; border-radius: 8px; cursor: pointer; font-weight: 600; transition: var(--transition); box-shadow: 0 4px 6px -1px rgba(59, 130, 246, 0.3); display: inline-flex; justify-content: center; align-items: center; gap: 8px;}
.btn-primary:hover { background: #2563eb; transform: translateY(-1px); box-shadow: 0 10px 15px -3px rgba(59, 130, 246, 0.4); }
.btn-success { background: var(--success); color: #022c22; padding: 12px; border: none; border-radius: 8px; cursor: pointer; width: 100%; font-weight: 700; }
.btn-full { width: 100%; }
.btn-sm { padding: 8px 20px; font-size: 0.85rem; }

/* --- MODALS --- */
.modal { position: fixed; inset: 0; background: rgba(0,0,0,0.8); backdrop-filter: blur(8px); display: flex; justify-content: center; align-items: center; z-index: 2000; padding: 15px;}
.modal-content { background: var(--bg); padding: 25px; border-radius: 16px; width: 100%; max-width: 600px; border: 1px solid var(--border); max-height: 90vh; overflow-y: auto; position: relative; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5); animation: slideUp 0.3s cubic-bezier(0.16, 1, 0.3, 1); display: flex; flex-direction: column;}
.modal-sm { max-width: 400px; }
.modal-lg { max-width: 800px; }
.close { position: absolute; top: 15px; right: 15px; width: 32px; height: 32px; background: var(--card); border-radius: 50%; color: var(--text-muted); text-align: center; line-height: 32px; cursor: pointer; z-index: 10; transition: 0.2s; border: 1px solid var(--border); }
.close:hover { background: var(--danger); color: #fff; border-color: var(--danger); transform: rotate(90deg); }
.modal-header-row { padding-bottom: 15px; border-bottom: 1px solid var(--border); margin-bottom: 20px; display: flex; justify-content: space-between; align-items: center; padding-right: 40px; /* Space for close btn */}
.modal-title { font-size: 1.3rem; font-weight: 700; color: #fff; word-break: break-word;}
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-top: 10px; }
.span-2 { grid-column: 1 / -1; }
.gallery-wrapper { background: #000; border-radius: 12px; padding: 10px; margin-bottom: 20px; border: 1px solid var(--border); }
.main-image-frame { width: 100%; height: 250px; border-radius: 8px; overflow: hidden; margin-bottom: 10px; background: #111; display: flex; align-items: center; justify-content: center; }
.main-image-frame img, .main-image-frame video { width: 100%; height: 100%; object-fit: contain; }
.thumbnails-row { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 5px; -webkit-overflow-scrolling: touch;}
.thumb-item { width: 50px; height: 50px; border-radius: 6px; object-fit: cover; cursor: pointer; border: 2px solid transparent; transition: 0.2s; opacity: 0.6; flex-shrink: 0;}
.thumb-item:hover, .thumb-item.active { border-color: var(--primary); opacity: 1; }

@keyframes slideDown { from { opacity: 0; max-height: 0; } to { opacity: 1; max-height: 500px; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

.custom-file-upload { display: block; width: 100%; margin-top: 10px; margin-bottom: 15px; cursor: pointer; }
.custom-file-upload input[type="file"] { display: none; }
.upload-ui { background: rgba(255, 255, 255, 0.02); border: 2px dashed var(--border); border-radius: 8px; padding: 20px; text-align: center; color: var(--text-muted); font-size: 0.9rem; font-weight: 600; transition: all 0.3s ease; display: flex; align-items: center; justify-content: center; gap: 10px; word-break: break-word;}
.custom-file-upload:hover .upload-ui { border-color: var(--primary); background: rgba(59, 130, 246, 0.05); color: var(--primary); }
.submission-box textarea { width: 100%; background: var(--bg); border: 1px solid var(--border); color: #fff; padding: 15px; border-radius: 8px; resize: vertical; min-height: 100px; outline: none; font-family: inherit; }
.submission-box textarea:focus { border-color: var(--primary); }
.btn-download { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 12px; background: var(--bg); border: 1px solid var(--border); color: var(--text); border-radius: 8px; text-decoration: none; font-weight: 600; transition: all 0.3s ease; margin-top: 15px; }
.btn-download:hover { border-color: var(--primary); color: var(--primary); background: rgba(59, 130, 246, 0.05); transform: translateY(-2px); }

/* --- DASHBOARD LAYOUT (BOXED) --- */
.dash-split-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; margin-top: 20px; }
.section-header-simple { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }
.section-header-simple h3 { margin: 0; font-size: 1.1rem; color: #fff; display: flex; gap: 10px; align-items: center; font-weight: 600; }
.section-header-simple button { background: none; border: none; color: var(--text-muted); cursor: pointer; transition: 0.3s; }
.section-header-simple button:hover { color: var(--primary); transform: rotate(180deg); }
.activity-timeline { max-height: 350px; overflow-y: auto; padding-right: 5px; margin-top: 10px; scroll-behavior: smooth; }
.timeline-item { position: relative; padding-bottom: 20px; padding-left: 20px; border-left: 2px solid var(--border); margin-left: 10px; }
.timeline-dot { position: absolute; left: -11px; top: 0; width: 20px; height: 20px; border-radius: 50%; background: var(--card); border: 3px solid var(--border); z-index: 2; }
.timeline-dot.money { border-color: var(--success); }
.timeline-dot.job { border-color: var(--primary); }
.timeline-dot.alert { border-color: var(--danger); }
.timeline-content { background: var(--bg); border: 1px solid var(--border); padding: 12px; border-radius: 8px; transition: 0.2s; word-break: break-word;}
.timeline-content:hover { border-color: var(--primary); transform: translateX(5px); }
.time-meta { font-size: 0.75rem; color: var(--text-muted); margin-bottom: 5px; display: block; }
.act-text { font-size: 0.85rem; color: #cbd5e1; line-height: 1.4; }
.dash-widget { background: var(--bg); border: 1px solid var(--border); border-radius: 12px; padding: 20px; margin-bottom: 20px; }
.widget-header { display: flex; justify-content: space-between; margin-bottom: 15px; align-items: center; }
.widget-header h4 { margin: 0; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); font-weight: 700; }
.widget-header .link { font-size: 0.8rem; color: var(--primary); cursor: pointer; font-weight: 600; white-space: nowrap;}
.mini-project-item { display: flex; align-items: center; gap: 12px; padding: 10px; background: rgba(255,255,255,0.02); border-radius: 8px; margin-bottom: 10px; border: 1px solid transparent; transition: 0.2s; cursor: pointer; }
.mini-project-item:hover { border-color: var(--primary); background: rgba(59, 130, 246, 0.05); }
.mini-img { width: 40px; height: 40px; border-radius: 6px; object-fit: cover; background: #000; flex-shrink: 0;}
.mini-info { overflow: hidden; }
.mini-info h5 { margin: 0; font-size: 0.9rem; color: #fff; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
.mini-info span { font-size: 0.7rem; color: var(--text-muted); }
.empty-mini { font-size: 0.85rem; color: var(--text-muted); text-align: center; padding: 20px; font-style: italic; }
.quick-actions-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.quick-actions-grid button { background: rgba(255,255,255,0.02); border: 1px solid var(--border); color: #cbd5e1; padding: 12px; border-radius: 8px; cursor: pointer; font-size: 0.8rem; display: flex; flex-direction: column; align-items: center; gap: 8px; transition: 0.2s; }
.quick-actions-grid button i { font-size: 1.2rem; color: var(--primary); }
.quick-actions-grid button:hover { background: var(--bg); border-color: var(--primary); color: #fff; transform: translateY(-2px); }

.stat-card { display: flex; align-items: center; gap: 15px; padding: 20px; }
.stat-icon-box { width: 45px; height: 45px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0;}
.stat-icon-box.blue { background: rgba(59, 130, 246, 0.1); color: #60a5fa; }
.stat-icon-box.green { background: rgba(16, 185, 129, 0.1); color: #34d399; }
.stat-icon-box.purple { background: rgba(168, 85, 247, 0.1); color: #a855f7; }
.stat-info { overflow: hidden; }
.stat-info h3 { margin: 0 0 5px 0; font-size: 0.75rem; color: var(--text-muted); text-transform: uppercase; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
.stat-info h1 { margin: 0; font-size: 1.6rem; color: #fff; line-height: 1;}

.modal-tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 20px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.modal-tabs::-webkit-scrollbar { height: 2px; }
.modal-tab-btn { background: transparent; border: none; color: var(--text-muted); padding: 12px 15px; cursor: pointer; font-weight: 600; font-size: 0.9rem; border-bottom: 2px solid transparent; transition: 0.3s; white-space: nowrap; }
.modal-tab-btn:hover { color: #fff; }
.modal-tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }

.progress-feed { background: var(--bg); border: 1px solid var(--border); border-radius: 12px; padding: 15px; max-height: 300px; overflow-y: auto; margin-bottom: 15px; }
.update-card { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 15px; margin-bottom: 15px; }
.update-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.update-avatar { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex-shrink: 0;}
.update-meta h5 { margin: 0; color: #fff; font-size: 0.9rem; }
.update-meta span { font-size: 0.7rem; color: var(--text-muted); }
.update-body p { color: #cbd5e1; font-size: 0.9rem; line-height: 1.5; margin-bottom: 10px; word-break: break-word;}
.update-img { width: 100%; max-height: 250px; object-fit: cover; border-radius: 8px; margin-top: 10px; border: 1px solid var(--border); }

.comments-section { margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.05); }
.comment-item { display: flex; gap: 8px; margin-bottom: 10px; font-size: 0.85rem; }
.comment-item .c-avatar { width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0;}
.comment-content { background: rgba(255,255,255,0.03); padding: 8px 12px; border-radius: 10px; flex: 1; word-break: break-word;}
.comment-user { color: var(--primary); font-weight: 700; font-size: 0.75rem; display: block; margin-bottom: 2px; }
.comment-text { color: #e2e8f0; }

.new-update-box { background: var(--bg); padding: 15px; border-radius: 12px; border: 1px solid var(--border); margin-bottom: 20px; }
.new-update-box textarea { width: 100%; background: var(--card); border: 1px solid var(--border); color: #fff; padding: 10px; border-radius: 8px; min-height: 80px; resize: vertical; outline: none; transition: 0.2s; font-size: 0.9rem;}
.new-update-box textarea:focus { border-color: var(--primary); }
.update-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; flex-wrap: wrap; gap: 10px;}

.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-bottom: 20px; background: rgba(255,255,255,0.02); padding: 15px; border-radius: 12px; border: 1px solid var(--border); }
.info-item { overflow: hidden; }
.info-item label { display: block; font-size: 0.65rem; color: var(--text-muted); margin-bottom: 3px; text-transform: uppercase; font-weight: 700; letter-spacing: 0.5px; white-space: nowrap; text-overflow: ellipsis; overflow: hidden;}
.info-item span { font-size: 0.95rem; color: #fff; font-weight: 600; word-break: break-word;}

/* --- INBOX SYSTEM (MAILS) --- */
.inbox-layout {
    display: flex;
    gap: 20px;
    height: calc(100vh - 200px);
    min-height: 400px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
}

.inbox-list {
    width: 320px;
    background: var(--card);
    border-right: 1px solid var(--border);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
}

.mail-item {
    padding: 15px;
    border-bottom: 1px solid var(--border);
    cursor: pointer;
    transition: 0.2s;
    position: relative;
}

.mail-item:hover { background: rgba(255, 255, 255, 0.02); }
.mail-item.active { background: rgba(59, 130, 246, 0.1); border-left: 3px solid var(--primary); }
.mail-item.unread::after { content: ''; position: absolute; top: 15px; right: 15px; width: 8px; height: 8px; background: var(--primary); border-radius: 50%; box-shadow: 0 0 8px var(--primary-glow); }

.mail-subject { font-weight: 700; color: #fff; font-size: 0.95rem; margin-bottom: 5px; padding-right: 15px; word-break: break-word;}
.mail-preview { color: var(--text-muted); font-size: 0.8rem; line-height: 1.4; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.mail-date { font-size: 0.7rem; color: #666; margin-top: 5px; display: block; }

.inbox-view {
    flex: 1;
    padding: 25px;
    overflow-y: auto;
    background: var(--bg);
    display: flex;
    flex-direction: column;
    min-width: 0; /* Prevent flex blowout */
}

.empty-inbox-msg { margin: auto; text-align: center; color: var(--text-muted); font-size: 1rem; }

.mail-view-header { border-bottom: 1px solid var(--border); padding-bottom: 15px; margin-bottom: 15px; }
.mail-view-subject { font-size: 1.3rem; color: #fff; margin-bottom: 8px; word-break: break-word;}
.mail-view-meta { display: flex; justify-content: space-between; align-items: center; color: var(--text-muted); font-size: 0.85rem; flex-wrap: wrap; gap: 10px;}
.mail-view-sender { font-weight: 600; color: var(--primary); }
.mail-view-body { color: #cbd5e1; line-height: 1.6; font-size: 0.95rem; white-space: pre-wrap; word-break: break-word; }

.mail-attachment { margin-top: 20px; padding: 10px; background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 8px; display: inline-block; max-width: 100%;}
.mail-attachment img { max-width: 100%; max-height: 250px; border-radius: 6px; cursor: pointer; object-fit: contain;}


/* ==========================================================================
   📱 MOBILE RESPONSIVENESS (Ultra Refined) 📱
   ========================================================================== */
@media (max-width: 900px) {
    /* 1. Reset Body & Containers */
    body {
        padding: 0 !important;
        background-color: var(--bg); /* Solid background for mobile performance */
        background-image: none;
    }

    .dashboard-container {
        height: 100dvh; /* Use dynamic viewport height */
        max-width: 100vw;
        gap: 0;
    }

    .main-content {
        height: calc(100dvh - 65px); /* Subtract header height */
        padding: 15px;
        border: none;
        border-radius: 0;
        box-shadow: none;
    }

    /* 2. Top Navbar - Sleek & Scrollable */
    .top-navbar {
        height: auto;
        min-height: 65px;
        padding: 10px 15px;
        flex-wrap: wrap;
        border-radius: 0;
        border-left: none;
        border-right: none;
        border-top: none;
        gap: 10px;
    }

    .navbar-left { flex: 1; }
    .navbar-right { flex: 1; justify-content: flex-end; }
    
    .navbar-center {
        flex: 100%;
        order: 3;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 5px;
        justify-content: flex-start;
    }

    /* Hide scrollbar for navbar */
    .navbar-center::-webkit-scrollbar { display: none; }
    .navbar-center { -ms-overflow-style: none; scrollbar-width: none; }

    .brand-group span { display: none; } /* Hide text, keep logo */
    .user-info-text { display: none; } /* Hide user name */
    .lang-btn { padding: 6px 10px; }

    /* Dropdowns adjustment */
    .dropdown-menu {
        position: fixed;
        top: auto !important;
        bottom: 20px;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 90%;
        max-width: 300px;
        z-index: 2000;
        background: var(--card);
        box-shadow: 0 -10px 40px rgba(0,0,0,0.8);
    }
    
    .dropdown-container:hover .dropdown-menu {
        transform: translateX(-50%) !important;
    }

    /* 3. Hero & Banners */
    .welcome-banner, .page-hero {
        padding: 20px 15px;
        flex-direction: column;
        text-align: center;
        align-items: center;
    }
    
    .welcome-banner::after { display: none; } /* Remove large glow on mobile */
    .welcome-text h1 { font-size: 1.5rem; }

    .filters { justify-content: center; width: 100%; }
    .filters input { width: 100%; flex: none; }
    .filters button { flex: 1; text-align: center; padding: 10px;}

    /* 4. Layout Grids to Single Column */
    .stats-grid, .dash-split-grid, .task-grid, .wallet-grid, .profile-layout {
        grid-template-columns: 1fr !important;
        gap: 15px;
    }
    
    .form-grid { grid-template-columns: 1fr; }

    /* 5. Tables & Horizontal Scrolling */
    .table-wrapper, .wallet-history-card {
        margin: 0 -15px; /* Bleed to edges */
        width: calc(100% + 30px);
        border-radius: 0;
        border-left: none;
        border-right: none;
    }
    
    .glass-table, .history-table {
        font-size: 0.8rem;
    }
    
    .glass-table th, .history-table th { padding: 10px; }
    .glass-table td, .history-table td { padding: 10px; }

    /* 6. Inbox Redesign for Mobile */
    .inbox-layout {
        flex-direction: column;
        height: calc(100dvh - 160px);
        margin: 0 -15px;
        width: calc(100% + 30px);
        border-radius: 0;
        border-left: none;
        border-right: none;
    }

    .inbox-list {
        width: 100%;
        max-height: 40%;
        border-right: none;
        border-bottom: 1px solid var(--border);
    }

    .inbox-view {
        flex: 1;
        padding: 15px;
    }

    .mail-view-subject { font-size: 1.1rem; }

    /* 7. Chat Mobile */
    .chat-container {
        margin: 0 -15px;
        width: calc(100% + 30px);
        height: calc(100dvh - 160px);
        border-radius: 0;
        border: none;
        border-top: 1px solid var(--border);
    }
    
    .msg-row { max-width: 90%; }
    .msg-bubble { padding: 10px 12px; }

    /* 8. Admin Cards */
    .admin-card-header {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    
    .admin-info { min-width: 100%; }
    .admin-info h4 { justify-content: center; }
    
    .admin-card-footer {
        flex-direction: column;
        gap: 15px;
    }
    
    .admin-actions { flex-direction: column; }
    .pay-input-group { width: 100%; }

    /* 9. Modals */
    .modal { padding: 10px; }
    .modal-content {
        padding: 20px 15px;
        max-height: 95dvh;
    }
    
    .modal-header-row { flex-direction: column; align-items: flex-start; gap: 10px; }
    .modal-title { font-size: 1.1rem; }
    
    .info-grid { grid-template-columns: 1fr; gap: 10px; padding: 10px; }
    .info-item { display: flex; justify-content: space-between; align-items: center; }
    .info-item label { margin: 0; }
    
    .main-image-frame { height: 200px; }
    
    .btn-full { padding: 15px; }
}

/* Small adjustments for very small screens */
@media (max-width: 380px) {
    .stat-card { flex-direction: column; text-align: center; gap: 10px; }
    .stat-icon-box { margin: 0 auto; }
}