.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.page-header h2{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text-primary);letter-spacing:-.5px}.header-actions{display:flex;gap:var(--spacing-sm);align-items:center}.btn-success{background:#10b981;color:#fff;border:1px solid #059669}.btn-success:hover{background:#059669}.empty-state{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl);color:var(--color-text-secondary)}.empty-state p{font-size:var(--text-lg);margin-bottom:var(--spacing-lg)}.filters-bar{display:flex;gap:var(--spacing-md);align-items:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);flex-wrap:wrap}.search-box{flex:1;min-width:250px;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-gray-50);transition:all var(--transition-base)}.search-box:focus-within{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #0000000d}.search-box svg{color:var(--color-text-tertiary);flex-shrink:0}.search-input{flex:1;border:none;background:none;outline:none;font-size:var(--text-sm);color:var(--color-text-primary)}.search-input::placeholder{color:var(--color-text-tertiary)}.filter-group{display:flex;align-items:center;gap:var(--spacing-sm)}.filter-group svg{color:var(--color-text-tertiary)}.filter-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;font-size:var(--text-sm);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base)}.filter-select:hover{border-color:var(--color-gray-400)}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0000000d}.results-count{font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap;margin-left:auto}.accounts-table-container{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;box-shadow:var(--shadow-sm)}.accounts-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.accounts-table thead{background:var(--color-gray-50);border-bottom:2px solid var(--color-border)}.accounts-table th{padding:var(--spacing-md) var(--spacing-sm);text-align:left;font-weight:var(--font-semibold);color:var(--color-text-secondary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.accounts-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--transition-base)}.accounts-table th.sortable:hover{color:var(--color-text-primary);background:var(--color-gray-100)}.accounts-table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color var(--transition-base)}.accounts-table tbody tr:hover{background:var(--color-gray-50)}.accounts-table tbody tr.selected{background:#eff6ff}.accounts-table tbody tr.selected:hover{background:#dbeafe}.accounts-table td{padding:var(--spacing-md) var(--spacing-sm);vertical-align:middle}.checkbox-col{width:40px;text-align:center}.checkbox-btn{background:none;border:none;cursor:pointer;padding:4px;display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:color var(--transition-base);border-radius:var(--radius-sm)}.checkbox-btn:hover{color:var(--color-primary);background:var(--color-gray-100)}.avatar-col{width:50px;text-align:center}.account-avatar-small{width:36px;height:36px;border-radius:var(--radius-md);object-fit:cover;border:2px solid var(--color-border)}.account-avatar-placeholder{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-gray-200);display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);color:var(--color-text-secondary);font-size:var(--text-sm)}.account-name-cell{display:flex;align-items:center;gap:var(--spacing-md)}.account-name-info{display:flex;flex-direction:column;gap:2px}.account-name-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:none;border:none;padding:0;cursor:pointer;color:var(--color-text-primary);font-weight:var(--font-semibold);font-size:var(--text-sm);transition:all var(--transition-base);text-align:left}.account-name-link:hover{color:var(--color-gray-700)}.account-name-link .chat-icon{opacity:0;transition:opacity var(--transition-base);color:var(--color-gray-500)}.account-name-link:hover .chat-icon{opacity:1}.account-name-cell .display-name{color:var(--color-text-tertiary);font-size:var(--text-xs)}.phone-number,.user-id{font-family:var(--font-mono);color:var(--color-text-secondary);font-size:var(--text-xs)}.proxy-info{display:flex;flex-direction:column;gap:2px}.proxy-info strong{color:var(--color-text-primary);font-size:var(--text-xs)}.proxy-info small{color:var(--color-text-tertiary);font-size:11px;font-family:var(--font-mono)}.timestamp{color:var(--color-text-secondary);font-size:var(--text-xs);white-space:nowrap}.text-muted{color:var(--color-text-tertiary);font-style:italic}.actions-col{width:100px;text-align:center}.action-buttons{display:flex;gap:var(--spacing-xs);justify-content:center}.btn-icon{padding:var(--spacing-xs);min-width:auto;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center}.btn-icon svg{flex-shrink:0}.account-footer{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);font-size:var(--text-xs);color:var(--color-text-muted);display:flex;justify-content:space-between;align-items:center}.loading{text-align:center;padding:var(--spacing-2xl);font-size:var(--text-lg);color:var(--color-text-secondary);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.loading:before{content:"⏳";font-size:var(--text-4xl);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-base)}.modal{background:var(--color-white);padding:var(--spacing-xl);border-radius:var(--radius-xl);min-width:400px;max-width:90%;box-shadow:var(--shadow-xl);border:1px solid var(--color-border);animation:slideUp var(--transition-slow)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal h3{margin-bottom:var(--spacing-lg);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary)}.modal-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg);justify-content:flex-end}.qr-modal{text-align:center;min-width:450px}.qr-image{width:320px;height:320px;margin:var(--spacing-lg) auto;display:block;border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-white);padding:var(--spacing-md);box-shadow:var(--shadow-md)}.qr-instruction{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:var(--text-sm);line-height:1.6}.qr-instruction strong{color:var(--color-text-primary);font-weight:var(--font-semibold)}@media (max-width: 1200px){.accounts-table th,.accounts-table td{padding:var(--spacing-sm) 6px;font-size:12px}.proxy-info small{display:none}}@media (max-width: 992px){.filters-bar{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.filter-group{width:100%}.filter-select{flex:1}.results-count{margin-left:0;text-align:center}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.page-header h2{text-align:center;font-size:var(--text-2xl)}.header-actions{width:100%;flex-wrap:wrap;justify-content:center}.header-actions .btn{flex:1;min-width:120px;justify-content:center}.accounts-table-container{background:transparent;border:none;box-shadow:none}.accounts-table{display:block}.accounts-table thead{display:none}.accounts-table tbody{display:flex;flex-direction:column;gap:var(--spacing-md)}.accounts-table tbody tr{display:flex;flex-direction:column;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.accounts-table tbody tr.selected{border-color:var(--color-gray-400);box-shadow:var(--shadow-md)}.accounts-table td{display:flex;align-items:center;padding:var(--spacing-xs) 0;border:none}.accounts-table td:before{content:attr(data-label);font-weight:var(--font-semibold);font-size:var(--text-xs);color:var(--color-text-tertiary);min-width:100px;text-transform:uppercase}.accounts-table .checkbox-col{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:auto}.accounts-table .checkbox-col:before{display:none}.accounts-table tbody tr{position:relative}.accounts-table .avatar-col{justify-content:center;padding:var(--spacing-md) 0}.accounts-table .avatar-col:before{display:none}.account-avatar-small,.account-avatar-placeholder{width:56px;height:56px;font-size:var(--text-xl)}.accounts-table .actions-col{justify-content:center;padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm)}.accounts-table .actions-col:before{display:none}.action-buttons{gap:var(--spacing-sm)}.btn-icon{width:40px;height:40px}}@media (max-width: 480px){.page-header h2{font-size:var(--text-xl)}.header-actions .btn{font-size:var(--text-xs);padding:var(--spacing-sm);min-width:100px}.header-actions .btn svg{width:16px;height:16px}.modal{min-width:auto;width:calc(100% - var(--spacing-lg));margin:var(--spacing-sm);padding:var(--spacing-lg)}.qr-modal{min-width:auto}.qr-image{width:100%;max-width:260px;height:auto}.modal h3{font-size:var(--text-lg)}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.chat-container{display:grid;grid-template-columns:280px 360px 1fr;gap:0;height:calc(100vh - 140px);background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}.mobile-chat-nav,.btn-back-mobile{display:none}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.panel-header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0;letter-spacing:-.2px}.btn-refresh{background:transparent;border:none;padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-tertiary);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.btn-refresh:hover{background:var(--color-gray-200);color:var(--color-text-primary);transform:rotate(90deg)}.btn-refresh:active{transform:rotate(180deg)}.account-selector{background:var(--color-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.account-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.account-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--spacing-sm);border:1px solid transparent}.account-item:hover{background:var(--color-white);border-color:var(--color-border);box-shadow:var(--shadow-sm)}.account-item.active{background:var(--color-gray-700);color:var(--color-white);box-shadow:var(--shadow-md);border-color:var(--color-gray-700)}.account-avatar{width:48px;height:48px;border-radius:var(--radius-lg);object-fit:cover;border:2px solid var(--color-border);background:var(--color-white);flex-shrink:0}.account-item.active .account-avatar{border-color:#ffffff4d}.account-avatar-placeholder{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--color-gray-300);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:var(--text-xl);flex-shrink:0}.account-item.active .account-avatar-placeholder{background:#fff3;color:var(--color-white)}.account-info{flex:1;min-width:0}.account-name{font-size:var(--text-sm);font-weight:var(--font-semibold);margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);opacity:.85}.status-dot{width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-gray-500);animation:statusPulse 2s ease-in-out infinite}.status-dot.online{background:#16a34a}.status-dot.offline{background:#dc2626}.account-item.active .status-dot.online{background:#4ade80}.account-item.active .status-dot.offline{background:#f87171}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.conversations-panel{background:var(--color-white);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.conversations-list{flex:1;overflow-y:auto;overflow-x:hidden}.conversations-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar,.account-list::-webkit-scrollbar{width:4px}.conversations-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track,.account-list::-webkit-scrollbar-track{background:transparent}.conversations-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb,.account-list::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}.conversations-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover,.account-list::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.conversation-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-base);position:relative}.conversation-item:hover{background:var(--color-bg)}.conversation-item.active{background:var(--color-gray-100);border-left:3px solid var(--color-gray-700)}.conversation-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-gray-700)}.conv-avatar{width:52px;height:52px;border-radius:var(--radius-lg);object-fit:cover;flex-shrink:0;border:2px solid var(--color-border);background:var(--color-white)}.conv-avatar-placeholder{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--color-gray-300);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);flex-shrink:0;border:2px solid var(--color-border)}.conv-info{flex:1;min-width:0}.conv-name{font-size:var(--text-sm);font-weight:var(--font-semibold);margin-bottom:var(--spacing-xs);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-preview{font-size:var(--text-xs);color:var(--color-text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{background:var(--color-gray-700);color:var(--color-white);border-radius:var(--radius-full);padding:2px 8px;font-size:var(--text-xs);font-weight:var(--font-bold);flex-shrink:0;min-width:20px;text-align:center}.chat-area{display:flex;flex-direction:column;background:var(--color-white);overflow:hidden}.chat-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border);background:var(--color-white);display:flex;justify-content:space-between;align-items:center}.header-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-sync{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-gray-100);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.btn-sync:hover:not(:disabled){background:var(--color-gray-200);color:var(--color-text-primary)}.btn-sync:disabled{opacity:.6;cursor:not-allowed}.btn-sync .spinner{animation:spin 1s linear infinite}.chat-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;letter-spacing:-.2px}.chat-badge{background:var(--color-gray-200);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:var(--font-medium);border:1px solid var(--color-border)}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-lg) var(--spacing-xl);background:var(--color-bg);scroll-behavior:smooth}.load-more-indicator{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--color-text-tertiary);font-size:var(--text-xs);margin-bottom:var(--spacing-md)}.end-of-messages{text-align:center;padding:var(--spacing-md);color:var(--color-text-muted);font-size:var(--text-xs);margin-bottom:var(--spacing-md);font-weight:var(--font-medium)}.message{margin-bottom:var(--spacing-md);display:flex;flex-direction:column;animation:messageSlideIn var(--transition-slow) ease-out}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-self{align-items:flex-end}.message-other{align-items:flex-start}.message-sender{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-tertiary);margin-bottom:var(--spacing-xs);padding:0 var(--spacing-md)}.message-content-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);max-width:70%;position:relative}.message-self .message-content-wrapper{flex-direction:row-reverse}.message-bubble{flex:1;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);word-wrap:break-word;box-shadow:var(--shadow-sm);border:1px solid transparent}.message-self .message-bubble{background:var(--color-gray-700);color:var(--color-white);border-bottom-right-radius:var(--radius-sm)}.message-other .message-bubble{background:var(--color-white);color:var(--color-text-primary);border:1px solid var(--color-border);border-bottom-left-radius:var(--radius-sm)}.message-text{font-size:var(--text-sm);line-height:1.6;white-space:pre-wrap;word-break:break-word}.message-sticker-container{display:flex;align-items:center;justify-content:center}.sticker-image{max-width:150px;max-height:150px;object-fit:contain}.sticker-fallback{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-gray-100);border-radius:var(--radius-lg)}.sticker-icon{font-size:48px}.sticker-text{font-size:var(--text-xs);color:var(--color-text-tertiary);font-style:italic}.message-image-container{display:flex;flex-direction:column;align-items:center}.message-image{max-width:300px;max-height:400px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);object-fit:contain}.message-image:hover{transform:scale(1.02);box-shadow:var(--shadow-lg)}.image-fallback{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-lg);background:var(--color-gray-100);border-radius:var(--radius-lg);color:var(--color-text-tertiary);font-size:var(--text-sm)}.message-voice{display:flex;align-items:center}.voice-player{max-width:250px;height:36px}.message-file{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-gray-100);border-radius:var(--radius-lg);min-width:200px}.file-icon{font-size:24px}.file-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.file-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:var(--text-xs);color:var(--color-text-tertiary)}.file-download{font-size:var(--text-xs);color:var(--color-gray-700);text-decoration:none;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-base)}.file-download:hover{background:var(--color-gray-700);color:var(--color-white)}.message-link{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-gray-100);border-radius:var(--radius-lg);max-width:300px;border:1px solid var(--color-border)}.link-thumb{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.link-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:0}.link-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-gray-700);text-decoration:none;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.link-title:hover{text-decoration:underline}.link-desc{font-size:var(--text-xs);color:var(--color-text-tertiary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.message-gif{display:flex;align-items:center;justify-content:center}.gif-image{max-width:250px;max-height:250px;border-radius:var(--radius-md)}.message-video{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.video-thumb{max-width:250px;max-height:200px;border-radius:var(--radius-md);object-fit:cover}.video-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;opacity:.8;pointer-events:none}.video-link{font-size:var(--text-xs);color:var(--color-gray-700);text-decoration:none;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-border)}.video-link:hover{background:var(--color-gray-700);color:var(--color-white)}.message-media{font-size:var(--text-xs);font-style:italic;opacity:.85;display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-gray-100);border-radius:var(--radius-md)}.message-footer{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-xs);padding:0 var(--spacing-md)}.message-time,.message-status{font-size:var(--text-xs);color:var(--color-text-muted)}.message-sending{opacity:.6}.btn-delete-message{background:var(--color-gray-200);border:1px solid var(--color-border);width:28px;height:28px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);opacity:0;transition:all var(--transition-base);flex-shrink:0;visibility:hidden}.message-content-wrapper:hover .btn-delete-message{opacity:1;visibility:visible}.btn-delete-message:hover{background:var(--color-gray-900);color:var(--color-white);border-color:var(--color-gray-900);transform:scale(1.1)}.btn-delete-message:active{transform:scale(.95)}.message-input-form{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-border);background:var(--color-white);display:flex;gap:var(--spacing-md);align-items:center}.message-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-border-dark);border-radius:var(--radius-full);font-size:var(--text-sm);font-family:inherit;transition:all var(--transition-base);background:var(--color-white);color:var(--color-text-primary)}.message-input:focus{outline:none;border-color:var(--color-gray-700);box-shadow:0 0 0 3px #4950571a}.message-input::placeholder{color:var(--color-text-muted)}.message-input:disabled{opacity:.6;cursor:not-allowed;background:var(--color-gray-100)}.btn-send{width:44px;height:44px;border-radius:var(--radius-full);border:none;background:var(--color-gray-700);color:var(--color-white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);box-shadow:var(--shadow-md);flex-shrink:0}.btn-send:hover:not(:disabled){background:var(--color-gray-800);transform:scale(1.05);box-shadow:var(--shadow-lg)}.btn-send:active:not(:disabled){transform:scale(.95)}.btn-send:disabled{opacity:.5;cursor:not-allowed;transform:none;background:var(--color-gray-400)}.empty-state,.loading-container,.empty-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;color:var(--color-text-tertiary)}.empty-state p,.loading-container p,.empty-messages p{font-size:var(--text-sm);font-weight:var(--font-medium);margin:var(--spacing-sm) 0 var(--spacing-xs) 0;color:var(--color-text-primary)}.empty-state small,.empty-messages small{font-size:var(--text-xs);color:var(--color-text-muted)}.empty-icon{font-size:64px;margin-bottom:var(--spacing-md);opacity:.3;filter:grayscale(100%)}.chat-placeholder{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.placeholder-content{text-align:center;max-width:400px;padding:var(--spacing-2xl)}.placeholder-icon{font-size:80px;margin-bottom:var(--spacing-lg);opacity:.2;filter:grayscale(100%)}.placeholder-content h3{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.placeholder-content p{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0;line-height:1.6}.spinner{animation:spin 1s linear infinite}.message-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.message-menu{position:fixed;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:1000;min-width:200px;overflow:hidden;animation:menuSlideIn var(--transition-fast)}@keyframes menuSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.menu-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);border:none;background:var(--color-white);cursor:pointer;transition:all var(--transition-base);text-align:left;font-size:var(--text-sm)}.menu-item:hover{background:var(--color-gray-100)}.menu-item svg{flex-shrink:0;color:var(--color-text-tertiary)}.menu-item span{flex:1;font-weight:var(--font-medium);color:var(--color-text-primary)}.menu-item small{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.menu-item-danger{color:var(--color-gray-900)}.menu-item-danger svg{color:var(--color-gray-900)}.menu-item-danger span{color:var(--color-gray-900)}.menu-item-danger:hover{background:var(--color-gray-900);color:var(--color-white)}.menu-item-danger:hover svg,.menu-item-danger:hover span{color:var(--color-white)}.menu-item+.menu-item{border-top:1px solid var(--color-border)}.message-actions{display:flex;align-items:center}@media (max-width: 1200px){.chat-container{grid-template-columns:240px 320px 1fr}}@media (max-width: 992px){.chat-container{grid-template-columns:200px 280px 1fr}.message-content-wrapper{max-width:80%}.account-name,.conv-name{font-size:var(--text-xs)}}@media (max-width: 768px){.chat-container{display:block;position:relative;height:calc(100vh - 120px);border-radius:var(--radius-lg)}.mobile-chat-nav{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-white);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:20}.mobile-chat-nav .btn{flex:1;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);gap:var(--spacing-xs);background:var(--color-gray-100);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-base)}.mobile-chat-nav .btn.active{background:var(--color-gray-700);color:var(--color-white);border-color:var(--color-gray-700)}.account-selector,.conversations-panel,.chat-area{display:none;position:absolute;top:52px;left:0;right:0;bottom:0;z-index:10;border-right:none}.account-selector{background:var(--color-bg)}.conversations-panel{background:var(--color-white)}.chat-area{background:var(--color-white);flex-direction:column}.account-selector.mobile-visible,.conversations-panel.mobile-visible,.chat-area.mobile-visible{display:flex}.chat-header{padding:var(--spacing-md);flex-shrink:0;gap:var(--spacing-sm)}.btn-back-mobile{display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border:1px solid var(--color-border);padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-base);flex-shrink:0;width:36px;height:36px}.btn-back-mobile:hover{background:var(--color-gray-200);color:var(--color-text-primary)}.chat-header h3{font-size:var(--text-base);margin:0}.header-info{flex:1;min-width:0}.header-info h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{flex-shrink:0}.btn-sync{padding:var(--spacing-sm);min-width:36px;height:36px}.btn-sync span{display:none}.message-content-wrapper{max-width:85%}.messages-container{padding:var(--spacing-md);flex:1;min-height:0;overflow-y:auto}.message-input-form{padding:var(--spacing-md);flex-shrink:0;background:var(--color-white);border-top:1px solid var(--color-border)}.message-input{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-sm)}.btn-send{width:40px;height:40px}.chat-placeholder{padding:var(--spacing-lg);flex:1;display:flex}.placeholder-icon{font-size:48px}.placeholder-content h3{font-size:var(--text-lg)}.placeholder-content p{font-size:var(--text-xs)}.panel-header{padding:var(--spacing-md)}.panel-header h3{font-size:var(--text-sm)}.account-list{padding:var(--spacing-sm)}.account-item{padding:var(--spacing-sm) var(--spacing-md)}.account-avatar,.account-avatar-placeholder{width:44px;height:44px;font-size:var(--text-lg)}.conversation-item{padding:var(--spacing-sm) var(--spacing-md)}.conv-avatar,.conv-avatar-placeholder{width:48px;height:48px;font-size:var(--text-xl)}.chat-badge{font-size:10px;padding:2px var(--spacing-sm);display:none}.message-menu{min-width:180px;max-width:calc(100vw - 32px)}}@media (max-width: 480px){.chat-container{height:calc(100vh - 100px);border-radius:var(--radius-md)}.mobile-chat-nav{padding:var(--spacing-xs) var(--spacing-sm)}.mobile-chat-nav .btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:11px}.message-bubble{padding:var(--spacing-sm) var(--spacing-md)}.message-text{font-size:var(--text-xs)}.message-time{font-size:10px}.menu-item{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-xs)}.conv-avatar,.conv-avatar-placeholder{width:44px;height:44px;font-size:var(--text-lg)}.account-avatar,.account-avatar-placeholder{width:40px;height:40px;font-size:var(--text-base)}.chat-header{padding:var(--spacing-sm)}.btn-back-mobile{width:32px;height:32px;padding:var(--spacing-xs)}.btn-sync{min-width:32px;height:32px;padding:var(--spacing-xs)}.messages-container{padding:var(--spacing-sm)}.message-input-form{padding:var(--spacing-sm);gap:var(--spacing-sm)}.btn-send{width:36px;height:36px}.message-content-wrapper{max-width:90%}}.notification{position:fixed;top:80px;right:20px;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);background:var(--color-white);box-shadow:var(--shadow-xl);z-index:1000;animation:slideIn .3s ease-out;border:1px solid var(--color-border)}.notification-success{border-left:4px solid #16a34a}.notification-success svg{color:#16a34a}.notification-error{border-left:4px solid #dc2626}.notification-error svg{color:#dc2626}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.contacts-container{display:grid;grid-template-columns:280px 400px 1fr;gap:0;height:calc(100vh - 140px);background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}.mobile-contacts-nav{display:none}.contacts-account-selector{background:var(--color-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.contacts-panel{background:var(--color-white);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.contacts-tabs{display:flex;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:transparent;border:none;cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-tertiary);transition:all var(--transition-base);position:relative}.tab-btn:hover{color:var(--color-text-primary);background:var(--color-gray-100)}.tab-btn.active{color:var(--color-text-primary);background:var(--color-white)}.tab-btn.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color-gray-700)}.tab-badge{background:var(--color-gray-200);color:var(--color-text-secondary);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold)}.tab-badge.pending{background:var(--color-gray-700);color:var(--color-white)}.search-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-white)}.search-bar .search-icon{color:var(--color-text-muted);flex-shrink:0}.search-bar input{flex:1;border:none;outline:none;font-size:var(--text-sm);background:transparent;color:var(--color-text-primary)}.search-bar input::placeholder{color:var(--color-text-muted)}.clear-btn{background:var(--color-gray-200);border:none;padding:var(--spacing-xs);border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.clear-btn:hover{background:var(--color-gray-300);color:var(--color-text-primary)}.contacts-content{flex:1;overflow-y:auto}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--color-text-tertiary);height:100%}.loading-state p,.empty-state p{font-size:var(--text-sm);font-weight:var(--font-medium);margin:var(--spacing-md) 0 var(--spacing-xs) 0;color:var(--color-text-primary)}.empty-state small{font-size:var(--text-xs);color:var(--color-text-muted)}.empty-icon{opacity:.3;color:var(--color-gray-500)}.friends-list,.pending-list{padding:var(--spacing-sm)}.friend-item,.pending-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);position:relative;margin-bottom:var(--spacing-xs)}.friend-item:hover,.pending-item:hover{background:var(--color-gray-100)}.friend-item.active{background:var(--color-gray-200);border-left:3px solid var(--color-gray-700)}.friend-avatar,.friend-avatar-placeholder{width:48px;height:48px;border-radius:var(--radius-lg);flex-shrink:0}.friend-avatar{object-fit:cover;border:2px solid var(--color-border)}.friend-avatar-placeholder{background:var(--color-gray-300);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-lg)}.friend-info{flex:1;min-width:0}.friend-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-phone{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--color-text-tertiary)}.friend-phone span:empty:before,.friend-phone span:contains("Chưa có"){font-style:italic;opacity:.7}.request-message{font-size:var(--text-xs);color:var(--color-text-secondary);font-style:italic;margin-top:var(--spacing-xs)}.btn-more{background:transparent;border:none;padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-tertiary);opacity:0;transition:all var(--transition-base)}.friend-item:hover .btn-more{opacity:1}.btn-more:hover{background:var(--color-gray-200);color:var(--color-text-primary)}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.action-menu{position:absolute;right:0;top:100%;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;min-width:160px;overflow:hidden}.action-menu button{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);background:transparent;border:none;cursor:pointer;font-size:var(--text-sm);color:var(--color-text-primary);transition:all var(--transition-base)}.action-menu button:hover{background:var(--color-gray-100)}.action-menu button.danger{color:#dc2626}.action-menu button.danger:hover{background:#fef2f2}.action-menu button+button{border-top:1px solid var(--color-border)}.pending-actions{display:flex;gap:var(--spacing-sm)}.btn-accept,.btn-reject{width:36px;height:36px;border-radius:var(--radius-full);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.btn-accept{background:var(--color-gray-700);color:var(--color-white)}.btn-accept:hover:not(:disabled){background:var(--color-gray-800);transform:scale(1.1)}.btn-reject{background:var(--color-gray-200);color:var(--color-text-secondary)}.btn-reject:hover:not(:disabled){background:#fef2f2;color:#dc2626;transform:scale(1.1)}.btn-accept:disabled,.btn-reject:disabled{opacity:.5;cursor:not-allowed}.search-tab{padding:var(--spacing-lg)}.search-form{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.search-input-group{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base)}.search-input-group:focus-within{border-color:var(--color-gray-700);box-shadow:0 0 0 3px #4950571a}.search-input-group .input-icon{color:var(--color-text-muted);flex-shrink:0}.search-input-group input{flex:1;border:none;outline:none;background:transparent;font-size:var(--text-sm);color:var(--color-text-primary)}.search-input-group input::placeholder{color:var(--color-text-muted)}.btn-search{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-gray-700);color:var(--color-white);border:none;border-radius:var(--radius-lg);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-base)}.btn-search:hover:not(:disabled){background:var(--color-gray-800)}.btn-search:disabled{opacity:.5;cursor:not-allowed}.search-result{margin-top:var(--spacing-lg)}.result-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl)}.result-avatar,.result-avatar-placeholder{width:64px;height:64px;border-radius:var(--radius-xl);flex-shrink:0}.result-avatar{object-fit:cover;border:2px solid var(--color-border)}.result-avatar-placeholder{background:var(--color-gray-300);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-2xl)}.result-info{flex:1}.result-name{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.result-phone{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);color:var(--color-text-tertiary)}.result-status{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic;margin-top:var(--spacing-xs)}.btn-add-friend{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-gray-700);color:var(--color-white);border:none;border-radius:var(--radius-lg);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-base)}.btn-add-friend:hover:not(:disabled){background:var(--color-gray-800);transform:scale(1.02)}.btn-add-friend:disabled{opacity:.5;cursor:not-allowed}.search-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center}.hint-icon{opacity:.2;color:var(--color-gray-500);margin-bottom:var(--spacing-md)}.search-hint p{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.search-hint small{font-size:var(--text-sm);color:var(--color-text-muted)}.friend-detail-panel{background:var(--color-white);display:flex;flex-direction:column;overflow:hidden}.detail-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.detail-header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0}.btn-back-mobile{display:none}.detail-content{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.detail-avatar-section{display:flex;flex-direction:column;align-items:center;padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-xl)}.detail-avatar,.detail-avatar-placeholder{width:120px;height:120px;border-radius:var(--radius-2xl);margin-bottom:var(--spacing-lg)}.detail-avatar{object-fit:cover;border:4px solid var(--color-border)}.detail-avatar-placeholder{background:var(--color-gray-300);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:48px}.detail-name{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;text-align:center}.detail-status{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0;text-align:center}.detail-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);transition:all var(--transition-base)}.action-btn:hover{background:var(--color-gray-100);border-color:var(--color-gray-300)}.action-btn.primary{background:var(--color-gray-700);color:var(--color-white);border-color:var(--color-gray-700)}.action-btn.primary:hover{background:var(--color-gray-800);transform:translateY(-1px);box-shadow:var(--shadow-md)}.detail-info-section{margin-bottom:var(--spacing-xl)}.detail-info-section h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--spacing-md) 0}.info-row{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border)}.info-row svg{color:var(--color-text-tertiary);flex-shrink:0;margin-top:2px}.info-row div{flex:1}.info-row label{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.info-row span{font-size:var(--text-sm);color:var(--color-text-primary)}.info-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);font-style:italic}.detail-danger-zone{padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.detail-danger-zone h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--spacing-md) 0}.danger-btn{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-base);margin-bottom:var(--spacing-sm)}.danger-btn:hover:not(:disabled){background:#fef2f2;border-color:#fecaca;color:#dc2626}.danger-btn.block:hover:not(:disabled){background:#fef2f2;border-color:#fecaca;color:#dc2626}.danger-btn:disabled{opacity:.5;cursor:not-allowed}.detail-placeholder{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.detail-placeholder .placeholder-content{text-align:center;padding:var(--spacing-2xl)}.detail-placeholder .placeholder-icon{opacity:.2;color:var(--color-gray-500);margin-bottom:var(--spacing-lg)}.detail-placeholder h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.detail-placeholder p{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}@media (max-width: 1200px){.contacts-container{grid-template-columns:240px 360px 1fr}}@media (max-width: 992px){.contacts-container{grid-template-columns:200px 320px 1fr}.detail-avatar,.detail-avatar-placeholder{width:100px;height:100px;font-size:40px}.result-avatar,.result-avatar-placeholder{width:56px;height:56px;font-size:var(--text-xl)}}@media (max-width: 768px){.contacts-container{display:block;position:relative;height:calc(100vh - 120px);border-radius:var(--radius-lg)}.mobile-contacts-nav{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-white);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:20}.mobile-contacts-nav .btn{flex:1;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);gap:var(--spacing-xs);background:var(--color-gray-100);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-base)}.mobile-contacts-nav .btn.active{background:var(--color-gray-700);color:var(--color-white);border-color:var(--color-gray-700)}.contacts-account-selector,.contacts-panel,.friend-detail-panel{display:none;position:absolute;top:52px;left:0;right:0;bottom:0;z-index:10;border-right:none}.contacts-account-selector{background:var(--color-bg)}.contacts-panel,.friend-detail-panel{background:var(--color-white)}.contacts-account-selector.mobile-visible,.contacts-panel.mobile-visible,.friend-detail-panel.mobile-visible{display:flex}.btn-back-mobile{display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border:1px solid var(--color-border);padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-base);flex-shrink:0;width:36px;height:36px}.btn-back-mobile:hover{background:var(--color-gray-200);color:var(--color-text-primary)}.contacts-tabs{flex-wrap:nowrap;overflow-x:auto}.tab-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-xs);white-space:nowrap}.tab-btn span{display:none}.tab-badge{font-size:10px;padding:1px 6px}.search-form{flex-direction:column}.btn-search{width:100%;justify-content:center}.result-card{flex-direction:column;text-align:center;gap:var(--spacing-md)}.btn-add-friend{width:100%;justify-content:center}.detail-content{padding:var(--spacing-lg)}.detail-avatar,.detail-avatar-placeholder{width:80px;height:80px;font-size:32px}.detail-name{font-size:var(--text-lg)}.detail-actions{flex-direction:column}.action-btn{flex-direction:row;justify-content:center}.friend-avatar,.friend-avatar-placeholder{width:44px;height:44px;font-size:var(--text-base)}.friend-name{font-size:var(--text-xs)}.btn-more{opacity:1}.action-menu{position:fixed;left:var(--spacing-md);right:var(--spacing-md);bottom:var(--spacing-md);top:auto;border-radius:var(--radius-xl)}}.groups-list{padding:var(--spacing-sm)}.group-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--spacing-xs)}.group-item:hover{background:var(--color-gray-100)}.group-item.active{background:var(--color-gray-200);border-left:3px solid var(--color-gray-700)}.group-avatar,.group-avatar-placeholder{width:48px;height:48px;border-radius:var(--radius-lg);flex-shrink:0}.group-avatar{object-fit:cover;border:2px solid var(--color-border)}.group-avatar-placeholder{background:var(--color-gray-300);color:var(--color-gray-600);display:flex;align-items:center;justify-content:center}.group-info{flex:1;min-width:0}.group-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-member-count{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--color-text-tertiary)}.chevron-icon{color:var(--color-text-muted);flex-shrink:0}.member-count{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-left:auto}.bulk-actions-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.btn-select-all{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-base)}.btn-select-all:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}.bulk-buttons{display:flex;gap:var(--spacing-sm)}.btn-bulk{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-gray-700);color:var(--color-white);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-base)}.btn-bulk:hover{background:var(--color-gray-800)}.members-content{flex:1;overflow-y:auto}.members-list{padding:var(--spacing-sm)}.member-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--spacing-xs)}.member-item:hover{background:var(--color-gray-100)}.member-item.selected{background:var(--color-gray-200)}.member-checkbox{color:var(--color-text-muted);flex-shrink:0}.member-checkbox .checked{color:var(--color-gray-700)}.member-avatar,.member-avatar-placeholder{width:40px;height:40px;border-radius:var(--radius-md);flex-shrink:0}.member-avatar{object-fit:cover;border:1px solid var(--color-border)}.member-avatar-placeholder{background:var(--color-gray-300);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-sm)}.member-info{flex:1;min-width:0}.member-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-role{font-size:var(--text-xs);color:var(--color-gray-600);background:var(--color-gray-200);padding:2px 6px;border-radius:var(--radius-sm);margin-top:var(--spacing-xs);display:inline-block}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.bulk-modal{background:var(--color-white);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-xl);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0}.btn-close{background:transparent;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);transition:all var(--transition-base)}.btn-close:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-lg)}.modal-info{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.modal-body textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);resize:vertical;font-family:inherit}.modal-body textarea:focus{outline:none;border-color:var(--color-gray-700);box-shadow:0 0 0 3px #4950571a}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg)}.modal-footer .btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base)}.modal-footer .btn-ghost{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.modal-footer .btn-ghost:hover{background:var(--color-gray-100)}.modal-footer .btn-primary{background:var(--color-gray-700);border:none;color:var(--color-white)}.modal-footer .btn-primary:hover:not(:disabled){background:var(--color-gray-800)}.modal-footer .btn-primary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.contacts-container{height:calc(100vh - 100px);border-radius:var(--radius-md)}.mobile-contacts-nav{padding:var(--spacing-xs) var(--spacing-sm)}.mobile-contacts-nav .btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:11px}.notification{left:var(--spacing-md);right:var(--spacing-md);top:auto;bottom:var(--spacing-md)}.search-tab{padding:var(--spacing-md)}.search-input-group,.btn-search{padding:var(--spacing-sm) var(--spacing-md)}.result-card{padding:var(--spacing-md)}.result-avatar,.result-avatar-placeholder{width:48px;height:48px;font-size:var(--text-lg)}.result-name{font-size:var(--text-base)}.detail-header{padding:var(--spacing-md)}.btn-back-mobile{width:32px;height:32px}.detail-content{padding:var(--spacing-md)}.detail-avatar-section{padding-bottom:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.detail-avatar,.detail-avatar-placeholder{width:72px;height:72px;font-size:28px;margin-bottom:var(--spacing-md)}.action-btn{padding:var(--spacing-md);font-size:var(--text-xs)}.info-row{padding:var(--spacing-sm) 0}.danger-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-xs)}.bulk-actions-bar{flex-direction:column;gap:var(--spacing-sm);align-items:stretch}.btn-select-all,.bulk-buttons{justify-content:center}.btn-bulk{flex:1;justify-content:center}.bulk-modal{max-width:100%;margin:var(--spacing-md)}}.qr-generator-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--spacing-lg)}.qr-generator-content{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-xl);max-width:500px;width:100%;text-align:center;animation:slideIn var(--transition-slow)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.input-group{margin-bottom:var(--spacing-xl);text-align:left}.input-group label{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.input-group .input{width:100%}.btn-generate{width:100%;padding:14px 24px;font-size:var(--text-base)}.icon-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.qr-display{animation:fadeIn var(--transition-slow)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-display h3{color:var(--color-text-primary);font-size:var(--text-2xl);font-weight:var(--font-bold);margin-bottom:var(--spacing-sm)}.qr-account-name{color:var(--color-text-secondary);font-size:var(--text-base);font-weight:var(--font-semibold);margin-bottom:var(--spacing-xl);font-family:var(--font-mono)}.qr-code-wrapper{margin:var(--spacing-xl) 0}.qr-code-image{max-width:320px;width:100%;height:auto;border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);background:var(--color-white);box-shadow:var(--shadow-md)}.qr-instruction{color:var(--color-text-secondary);font-size:var(--text-sm);margin-top:var(--spacing-md);line-height:1.6}.qr-console-message{margin:var(--spacing-xl) 0;padding:var(--spacing-lg);background:var(--color-warning-bg);border:1px solid var(--color-border-dark);border-radius:var(--radius-lg)}.console-warning{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.console-instruction{color:var(--color-text-secondary);font-size:var(--text-sm);line-height:1.6}.success-message{animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.success-icon{width:80px;height:80px;margin:0 auto var(--spacing-lg);background:var(--color-gray-900);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--color-white);animation:pulse 1s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.success-message h3{color:var(--color-text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--spacing-sm)}.success-message p{color:var(--color-text-secondary);font-size:var(--text-base)}@media (max-width: 600px){.qr-generator-container{padding:var(--spacing-md);align-items:flex-start;padding-top:var(--spacing-2xl)}.qr-generator-content{padding:var(--spacing-lg)}.btn-generate{font-size:var(--text-sm);padding:12px 20px}.qr-display h3{font-size:var(--text-xl)}.qr-code-image{max-width:250px}.success-icon{width:60px;height:60px;font-size:36px}.success-message h3{font-size:var(--text-2xl)}}@media (max-width: 400px){.qr-generator-content{padding:var(--spacing-md)}.input-group label{font-size:var(--text-xs)}.qr-display h3{font-size:var(--text-lg)}.qr-account-name{font-size:var(--text-sm)}.qr-code-image{max-width:200px}.qr-instruction{font-size:var(--text-xs)}.console-warning{font-size:var(--text-base)}.console-instruction{font-size:var(--text-xs)}}.proxies-page{padding:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{margin:0;color:#333}.proxies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.proxy-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;border:1px solid #e1e5e9}.proxy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.proxy-header h3{margin:0;color:#333;font-size:18px}.status-icon{flex-shrink:0}.status-icon.active{color:#28a745}.status-icon.inactive{color:#dc3545}.proxy-details p{margin:8px 0;color:#666;font-size:14px}.proxy-details strong{color:#333}.proxy-actions{display:flex;gap:10px;margin-top:20px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:30px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 20px;color:#333}.form-group{margin-bottom:15px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-group label{display:block;margin-bottom:5px;color:#333;font-weight:500}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.loading{text-align:center;padding:40px;color:#666;font-size:16px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border:none;border-radius:4px;font-size:14px;cursor:pointer;text-decoration:none;transition:all .2s}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-sm{padding:6px 12px;font-size:12px}@media (max-width: 992px){.proxies-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.proxies-page{padding:var(--spacing-md, 16px)}.page-header{flex-direction:column;align-items:stretch;gap:16px}.page-header h1{text-align:center;font-size:24px}.page-header .btn{width:100%;justify-content:center}.proxies-grid{grid-template-columns:1fr;gap:16px}.proxy-card{padding:16px}.proxy-header h3{font-size:16px}.proxy-actions{flex-direction:column}.proxy-actions .btn{width:100%;justify-content:center}.modal-content{width:calc(100% - 32px);padding:20px;margin:16px}.form-row{grid-template-columns:1fr;gap:12px}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}@media (max-width: 480px){.proxies-page{padding:12px}.page-header h1{font-size:20px}.proxy-card{padding:12px}.proxy-details p{font-size:13px}.modal-content{padding:16px}.modal-content h2{font-size:18px}.form-group input,.form-group select{padding:8px;font-size:14px}}.settings-page{max-width:900px;margin:0 auto}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.header-content{display:flex;align-items:flex-start;gap:var(--spacing-md)}.header-content svg{color:var(--color-gray-700);flex-shrink:0;margin-top:4px}.header-content h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.header-content p{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0}.header-actions{display:flex;gap:var(--spacing-sm)}.header-actions .btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base)}.header-actions .btn-secondary{background:var(--color-white);border:1px solid var(--color-border);color:var(--color-text-secondary)}.header-actions .btn-secondary:hover{background:var(--color-gray-100);border-color:var(--color-gray-300)}.header-actions .btn-primary{background:var(--color-gray-700);border:1px solid var(--color-gray-700);color:var(--color-white)}.header-actions .btn-primary:hover:not(:disabled){background:var(--color-gray-800)}.header-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.header-actions .btn-primary.saved{background:#16a34a;border-color:#16a34a}.settings-content{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.settings-section{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.section-header{margin-bottom:var(--spacing-lg)}.section-header h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.section-header p{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0}.menu-items-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.menu-item-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base)}.menu-item-card:hover{border-color:var(--color-gray-400);box-shadow:var(--shadow-md)}.menu-item-card.enabled{border-color:var(--color-gray-700);background:var(--color-white)}.menu-item-card.disabled{opacity:.7}.card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-200);border-radius:var(--radius-lg);color:var(--color-gray-600);flex-shrink:0}.menu-item-card.enabled .card-icon{background:var(--color-gray-700);color:var(--color-white)}.card-info{flex:1}.card-info h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.card-info .status{font-size:var(--text-xs);color:var(--color-text-tertiary)}.menu-item-card.enabled .card-info .status{color:#16a34a}.card-toggle{flex-shrink:0}.card-toggle .icon-visible{color:var(--color-gray-700)}.card-toggle .icon-hidden{color:var(--color-gray-400)}.preview-navbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-gray-900);border-radius:var(--radius-xl)}.preview-brand{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-white);font-weight:var(--font-semibold);font-size:var(--text-sm)}.preview-menu{display:flex;align-items:center;gap:var(--spacing-sm)}.preview-item{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-gray-400);font-size:var(--text-xs);border-radius:var(--radius-md)}.preview-item svg{width:14px;height:14px}.preview-profile{margin-left:var(--spacing-sm)}.preview-avatar{width:28px;height:28px;background:var(--color-gray-600);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-size:var(--text-xs);font-weight:var(--font-semibold)}@media (max-width: 768px){.settings-header{flex-direction:column;gap:var(--spacing-lg)}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center}.menu-items-grid{grid-template-columns:1fr}.preview-navbar{flex-direction:column;gap:var(--spacing-md)}.preview-menu{flex-wrap:wrap;justify-content:center}}@media (max-width: 480px){.settings-page{padding:0}.settings-section{padding:var(--spacing-lg);border-radius:var(--radius-lg)}.menu-item-card{padding:var(--spacing-md)}.card-icon{width:40px;height:40px}.card-info h3{font-size:var(--text-sm)}.header-content h1{font-size:var(--text-xl)}.header-actions .btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-xs)}.header-actions .btn span{display:none}}.app{min-height:100vh;background:var(--color-bg)}.navbar{background:var(--color-gray-900);border-bottom:1px solid var(--color-black);box-shadow:var(--shadow-md);padding:0;margin-bottom:var(--spacing-xl);position:sticky;top:0;z-index:100}.navbar .container{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-sm)}.navbar-brand h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-white);margin:0;letter-spacing:-.5px}.navbar-brand h1:before{content:"📱";margin-right:var(--spacing-sm);filter:brightness(1.2)}.navbar-menu{display:flex;gap:var(--spacing-xs);align-items:center}.nav-link:hover{background:#ffffff1a;color:var(--color-white)}.nav-link.active{color:var(--color-white);background:#ffffff26}.nav-link.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-white)}.main-content{min-height:calc(100vh - 100px);animation:fadeIn var(--transition-slow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:var(--color-gray-900)}.login-form{background:var(--color-bg);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;border:1px solid var(--color-border)}.login-form h2{text-align:center;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-medium)}.form-group input{width:100%}.error-message{color:var(--color-red-500);text-align:center;margin-bottom:var(--spacing-md)}.profile-dropdown{position:relative;margin-left:var(--spacing-sm)}.profile-trigger{display:flex;align-items:center;gap:var(--spacing-xs);background:transparent;border:none;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-full);transition:all var(--transition-base)}.profile-trigger:hover{background:#ffffff1a}.profile-avatar{width:36px;height:36px;background:var(--color-gray-600);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-size:var(--text-sm);font-weight:var(--font-semibold);border:2px solid var(--color-gray-500)}.profile-trigger .chevron{color:var(--color-gray-400);transition:transform var(--transition-base)}.profile-trigger .chevron.open{transform:rotate(180deg)}.dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.dropdown-menu{position:absolute;top:calc(100% + var(--spacing-sm));right:0;min-width:240px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:100;overflow:hidden;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg)}.dropdown-avatar{width:44px;height:44px;background:var(--color-gray-700);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-size:var(--text-base);font-weight:var(--font-bold);flex-shrink:0}.dropdown-user-info{display:flex;flex-direction:column;min-width:0}.dropdown-username{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-role{font-size:var(--text-xs);color:var(--color-text-tertiary)}.dropdown-divider{height:1px;background:var(--color-border)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;cursor:pointer;font-size:var(--text-sm);color:var(--color-text-primary);transition:all var(--transition-base);text-align:left}.dropdown-item:hover{background:var(--color-gray-100)}.dropdown-item svg{color:var(--color-text-tertiary);flex-shrink:0}.dropdown-item.danger{color:#dc2626}.dropdown-item.danger svg{color:#dc2626}.dropdown-item.danger:hover{background:#fef2f2}.nav-link{position:relative;text-decoration:none;color:var(--color-gray-400);font-weight:var(--font-medium);font-size:var(--text-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--spacing-xs)}.nav-link svg{width:18px;height:18px}.mobile-menu-toggle{display:none;background:transparent;border:none;color:var(--color-white);padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md)}.mobile-menu-toggle:hover{background:#ffffff1a}.hamburger{display:flex;flex-direction:column;gap:4px}.hamburger span{display:block;width:24px;height:2px;background:var(--color-white);transition:all var(--transition-base)}@media (max-width: 768px){.navbar .container{flex-wrap:wrap}.navbar-brand h1{font-size:var(--text-lg)}.navbar-brand h1:before{display:none}.mobile-menu-toggle{display:block}.navbar-menu{display:none;width:100%;flex-direction:column;gap:var(--spacing-xs);padding-top:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1);margin-top:var(--spacing-md)}.navbar-menu.open{display:flex}.nav-link{width:100%;justify-content:center;padding:var(--spacing-md)}.nav-link.active:after{display:none}.profile-dropdown{width:100%;margin-left:0;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid rgba(255,255,255,.1)}.profile-trigger{width:100%;justify-content:center;padding:var(--spacing-md)}.dropdown-menu{position:fixed;left:var(--spacing-md);right:var(--spacing-md);top:auto;bottom:var(--spacing-md);border-radius:var(--radius-xl)}}@media (max-width: 480px){.navbar-brand h1{font-size:var(--text-base)}}@media (max-width: 480px){.login-form{padding:var(--spacing-lg);margin:var(--spacing-md)}.login-form h2{font-size:var(--text-xl)}}:root{--color-white: #FFFFFF;--color-bg: #F8F9FA;--color-bg-secondary: #F1F3F5;--color-border: #E9ECEF;--color-border-dark: #DEE2E6;--color-text-primary: #212529;--color-text-secondary: #495057;--color-text-tertiary: #6C757D;--color-text-muted: #ADB5BD;--color-gray-100: #F8F9FA;--color-gray-200: #E9ECEF;--color-gray-300: #DEE2E6;--color-gray-400: #CED4DA;--color-gray-500: #ADB5BD;--color-gray-600: #6C757D;--color-gray-700: #495057;--color-gray-800: #343A40;--color-gray-900: #212529;--color-black: #000000;--color-accent: #1A1A1A;--color-accent-hover: #2C2C2C;--color-accent-active: #404040;--color-success: #16a34a;--color-success-bg: #dcfce7;--color-warning: #ca8a04;--color-warning-bg: #fef9c3;--color-danger: #dc2626;--color-danger-bg: #fee2e2;--color-red-300: #fca5a5;--color-red-400: #f87171;--color-red-500: #ef4444;--color-gray-50: #f9fafb;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text-primary);font-size:var(--text-base);line-height:1.5}code{font-family:var(--font-mono)}#root{min-height:100vh}.container{max-width:1400px;margin:0 auto;padding:var(--spacing-lg)}@media (max-width: 768px){.container{padding:var(--spacing-md)}}@media (max-width: 480px){.container{padding:var(--spacing-sm)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:10px 20px;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);font-family:inherit;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){background:var(--color-accent-active);transform:translateY(0)}.btn-secondary{background:var(--color-white);color:var(--color-text-primary);border-color:var(--color-border-dark)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-100);border-color:var(--color-gray-400)}.btn-danger{background:var(--color-danger);color:var(--color-white);border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-gray-900);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-success{background:var(--color-success);color:var(--color-white);border-color:var(--color-success)}.btn-success:hover:not(:disabled){background:var(--color-gray-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-text-primary)}.card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.input{width:100%;padding:10px 14px;border:1px solid var(--color-border-dark);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:inherit;color:var(--color-text-primary);background:var(--color-white);transition:all var(--transition-base)}.input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #1a1a1a1a}.input::placeholder{color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);white-space:nowrap}.badge-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-gray-300)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-gray-300)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-gray-300)}.badge-secondary{background:var(--color-gray-200);color:var(--color-gray-700);border:1px solid var(--color-gray-300)}
