@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";.properties-manager{max-width:100%}.pm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.pm-header h2{font-family:Outfit,sans-serif;font-weight:700;color:var(--text)}.pm-subtitle{color:var(--text-light);font-size:.9rem;margin-top:4px}.pm-filters{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.pm-search{display:flex;flex:1;min-width:250px}.pm-search input{flex:1;padding:.6rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm) 0 0 var(--radius-sm);font-size:.85rem;outline:none}.pm-search input:focus{border-color:var(--primary)}.pm-search button{padding:.6rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;cursor:pointer}.pm-filters select{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;background:#fff;cursor:pointer}.pm-table-wrapper{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto;border:1px solid var(--border)}.pm-table{width:100%;border-collapse:collapse;min-width:800px}.pm-table thead{background:#f8fafc}.pm-table th{padding:.8rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em}.pm-table td{padding:.75rem 1rem;border-top:1px solid var(--border);font-size:.85rem}.pm-table tbody tr:hover{background:#f8fafc}.td-id{font-family:monospace;font-size:.75rem;color:var(--text-lighter);max-width:80px;overflow:hidden;text-overflow:ellipsis}.td-title{max-width:300px}.property-info{display:flex;align-items:center;gap:10px}.property-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0}.property-title{display:block;font-weight:500;color:var(--text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.property-address{font-size:.75rem;color:var(--text-lighter)}.td-price{font-weight:600;color:var(--primary);white-space:nowrap}.td-empty{text-align:center;padding:3rem!important;color:var(--text-lighter)}.badge-type{background:var(--primary-lighter);color:var(--primary);padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.badge-status{padding:3px 10px;border-radius:9999px;font-size:.7rem;font-weight:600}.badge-đang-bán{background:#dcfce7;color:#16a34a}.badge-đã-bán{background:#fee2e2;color:#dc2626}.badge-tạm-ngưng{background:#fef3c7;color:#d97706}.action-btns{display:flex;gap:4px}.action-btn{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:.8rem}.action-btn.edit{background:#dbeafe;color:#2563eb}.action-btn.edit:hover{background:#2563eb;color:#fff}.action-btn.delete{background:#fee2e2;color:#dc2626}.action-btn.delete:hover{background:#dc2626;color:#fff}.action-btn.verify{background:#dcfce7;color:#16a34a}.action-btn.verify:hover{background:#16a34a;color:#fff}.pm-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;padding:1rem}.pm-pagination button{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;transition:all .2s}.pm-pagination button:hover:not(:disabled){background:var(--primary-lighter);border-color:var(--primary)}.pm-pagination button:disabled{opacity:.4;cursor:not-allowed}.pm-pagination span{font-size:.85rem;color:var(--text-light)}.pm-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:1rem;color:var(--text-light)}.property-editor{max-width:100%}.pe-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.pe-header h2{font-family:Outfit,sans-serif;font-weight:700;color:var(--text);font-size:1.1rem}.btn-back{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;cursor:pointer;color:var(--text-light);transition:all .2s}.btn-back:hover{background:var(--primary-lighter);border-color:var(--primary);color:var(--primary)}.pe-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}.pe-section{background:var(--bg-white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border)}.pe-section h3{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:1.25rem;display:flex;align-items:center;gap:8px}.pe-section h3 i{color:var(--primary)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-light);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.85rem;outline:none;transition:border .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0d5a2e1a}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.pe-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.btn-ghost{background:none;border:1px solid var(--border);color:var(--text);padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;cursor:pointer}.btn-ghost:hover{background:#f8fafc}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:9999}.toast{padding:.75rem 1.25rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.toast-success{background:#dcfce7;color:#166534}.toast-error{background:#fee2e2;color:#991b1b}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.users-manager{max-width:100%}.um-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.um-header h2{font-family:Outfit,sans-serif;font-weight:700;color:var(--text)}.um-subtitle{color:var(--text-light);font-size:.9rem;margin-top:4px}.um-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.um-stat-card{background:var(--bg-white);padding:1rem;border-radius:var(--radius-sm);text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.um-stat-num{display:block;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700;color:var(--text)}.um-stat-num.green{color:var(--success)}.um-stat-num.orange{color:var(--warning)}.um-stat-num.blue{color:var(--info)}.um-stat-label{font-size:.75rem;color:var(--text-lighter);font-weight:500}.um-search{display:flex;align-items:center;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 1rem;margin-bottom:1.25rem}.um-search i{color:var(--text-lighter);margin-right:.5rem}.um-search input{flex:1;border:none;padding:.7rem 0;font-size:.85rem;outline:none;background:transparent}.um-table-wrapper{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto;border:1px solid var(--border)}.um-table{width:100%;border-collapse:collapse;min-width:900px}.um-table thead{background:#f8fafc}.um-table th{padding:.8rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em}.um-table td{padding:.75rem 1rem;border-top:1px solid var(--border);font-size:.85rem}.um-table tbody tr:hover{background:#f8fafc}.user-cell{display:flex;align-items:center;gap:8px}.user-avatar-sm{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;font-weight:700;flex-shrink:0}.badge-role{padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:capitalize}.badge-admin{background:#fee2e2;color:#dc2626}.badge-member{background:#e0e7ff;color:#4338ca}.badge-agent{background:#dcfce7;color:#16a34a}.badge-trial_member{background:#fef3c7;color:#d97706}.badge-verified{color:var(--success);font-size:.8rem}.badge-unverified{color:var(--warning);font-size:.8rem}@media(max-width:768px){.um-stats{grid-template-columns:repeat(2,1fr)}}.fb-tool{padding:0}.fb-header{margin-bottom:1.5rem}.fb-header h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.fb-subtitle{color:#64748b;margin:.25rem 0 0;font-size:.9rem}.fb-tabs{display:flex;gap:4px;padding:4px;background:#f1f5f9;border-radius:12px;margin-bottom:1.5rem;flex-wrap:wrap}.fb-tab{padding:10px 20px;border-radius:8px;border:none;background:transparent;font-weight:500;cursor:pointer;color:#64748b;font-size:.9rem;transition:all .2s}.fb-tab:hover{color:#1e293b;background:#ffffff80}.fb-tab.active{background:#fff;color:#1877f2;box-shadow:0 1px 3px #0000001a;font-weight:600}.fb-filters{display:flex;gap:12px;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}.fb-search{display:flex;flex:1;min-width:200px}.fb-search input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px 0 0 8px;font-size:.9rem;outline:none}.fb-search input:focus{border-color:#1877f2}.fb-search button{padding:10px 16px;background:#1877f2;color:#fff;border:none;border-radius:0 8px 8px 0;cursor:pointer}.fb-filters select{padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer}.fb-count{font-size:.85rem;color:#94a3b8;font-weight:500}.fb-properties-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1.5rem}.fb-property-card{border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;transition:all .2s;background:#fff}.fb-property-card:hover{border-color:#1877f2;box-shadow:0 4px 12px #1877f21a}.fb-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.fb-card-id{font-size:.8rem;font-weight:700;color:#1877f2;background:#eff6ff;padding:2px 8px;border-radius:4px}.fb-card-title{font-size:.95rem;font-weight:600;color:#1e293b;margin:0 0 .5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fb-card-address{font-size:.85rem;color:#64748b;margin:0 0 .25rem}.fb-card-price{font-size:.9rem;color:#0d5a2e;font-weight:600;margin:0 0 1rem}.fb-card-actions{display:flex;gap:8px}.fb-btn{padding:8px 16px;border:none;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.fb-btn-post{background:linear-gradient(135deg,#1877f2,#0a5dc2);color:#fff;flex:1;justify-content:center}.fb-btn-post:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1877f24d}.fb-btn-post:disabled{opacity:.6;cursor:not-allowed;transform:none}.fb-btn-schedule{background:#f5f3ff;color:#7c3aed;flex:1;justify-content:center}.fb-btn-schedule:hover{background:#ede9fe}.fb-btn-primary{background:#1e293b;color:#fff}.fb-btn-primary:hover{background:#334155}.fb-btn-primary:disabled{opacity:.6;cursor:not-allowed}.fb-btn-ghost{background:#f1f5f9;color:#475569}.fb-btn-ghost:hover{background:#e2e8f0}.fb-btn-sm{padding:5px 12px;font-size:.8rem;border:none;border-radius:6px;cursor:pointer;font-weight:500}.fb-btn-cancel{background:#fee2e2;color:#991b1b}.fb-btn-cancel:hover{background:#fecaca}.fb-btn-copy{background:#f0fdf4;color:#166534}.fb-btn-copy:hover{background:#dcfce7}.fb-badge{padding:4px 10px;border-radius:16px;font-size:.8rem;font-weight:500}.fb-badge-pending{background:#fef3c7;color:#92400e}.fb-badge-posted{background:#dcfce7;color:#166534}.fb-badge-failed{background:#fee2e2;color:#991b1b}.fb-badge-cancelled{background:#f3f4f6;color:#6b7280}.fb-table-wrapper{overflow-x:auto}.fb-table{width:100%;border-collapse:collapse;font-size:.9rem}.fb-table th{text-align:left;padding:12px 16px;background:#f8fafc;color:#475569;font-weight:600;border-bottom:2px solid #e2e8f0}.fb-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#334155}.fb-table tbody tr:hover{background:#f8fafc}.fb-empty{text-align:center;color:#94a3b8;padding:2rem!important}.fb-link{color:#1877f2;text-decoration:none;font-weight:500}.fb-link:hover{text-decoration:underline}.fb-schedule-header{margin-bottom:1rem;padding:1.25rem;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:12px;border:1px solid #ddd6fe}.fb-schedule-header h3{margin:0;color:#5b21b6;font-size:1.15rem}.fb-schedule-note{font-size:.85rem;color:#7c3aed}.fb-config-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.fb-config-card label{font-weight:600;color:#1e293b;display:block;margin-bottom:.25rem}.fb-config-hint{font-size:.8rem;color:#94a3b8;margin:0 0 .75rem}.fb-config-card textarea,.fb-config-card input[type=text]{width:100%;padding:12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-family:inherit;resize:vertical;margin-bottom:1rem;box-sizing:border-box}.fb-config-card textarea:focus,.fb-config-card input:focus{outline:none;border-color:#1877f2}.fb-config-actions{display:flex;gap:8px}.fb-token-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.fb-config-card h4{margin:0 0 1rem;color:#1e293b;font-size:1.05rem}.fb-token-result{margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;font-size:.9rem}.fb-token-result p{margin:.25rem 0;color:#475569}.fb-page-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#fff;border-radius:6px;margin-top:8px;border:1px solid #e2e8f0}.fb-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fb-modal{background:#fff;border-radius:16px;padding:2rem;max-width:420px;width:90%;text-align:center;box-shadow:0 25px 50px -12px #00000040;animation:fbPopIn .3s ease-out}.fb-modal h3{margin:0 0 1rem;font-size:1.25rem;color:#1e293b}.fb-modal p{color:#6b7280;margin:.5rem 0}.fb-modal-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:1.5rem}.fb-icon-blue{background:linear-gradient(135deg,#1877f2,#0a5dc2);color:#fff}.fb-icon-green{background:#dcfce7}.fb-icon-red{background:#fee2e2}.fb-modal-info{background:#f8fafc;border-radius:10px;padding:1rem;margin-bottom:1.5rem;text-align:left}.fb-modal-info p{margin:.25rem 0;font-size:.9rem}.fb-modal-actions{display:flex;gap:12px;justify-content:center;margin-top:1.5rem}.fb-schedule-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0;text-align:left}.fb-schedule-inputs label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem}.fb-schedule-inputs input{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;box-sizing:border-box}.fb-pagination{display:flex;justify-content:center;align-items:center;gap:12px;padding:1rem 0}.fb-pagination button{padding:8px 14px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center}.fb-pagination button:disabled{opacity:.4;cursor:not-allowed}.fb-pagination span{font-size:.9rem;color:#64748b}.fb-loading{display:flex;justify-content:center;padding:3rem}@keyframes fbPopIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.noti-tool{padding:0}.noti-header{margin-bottom:1.5rem}.noti-header h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.noti-subtitle{color:#64748b;margin:.25rem 0 0;font-size:.9rem}.noti-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.noti-stat-card{flex:1;padding:1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;text-align:center;display:flex;flex-direction:column;gap:4px}.noti-stat-number{font-size:2rem;font-weight:700;color:#1e293b}.noti-stat-label{font-size:.85rem;color:#94a3b8;font-weight:500}.noti-grid{display:grid;grid-template-columns:1fr 320px;gap:1.5rem}@media(max-width:900px){.noti-grid{grid-template-columns:1fr}}.noti-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.noti-card h3{margin:0 0 1.25rem;font-size:1.1rem;color:#1e293b}.noti-field{margin-bottom:1rem}.noti-field label{display:block;font-weight:600;color:#374151;margin-bottom:.4rem;font-size:.9rem}.noti-field input,.noti-field textarea,.noti-field select{width:100%;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-family:inherit;box-sizing:border-box}.noti-field input:focus,.noti-field textarea:focus{outline:none;border-color:#6366f1}.noti-field textarea{resize:vertical}.noti-quick{margin-bottom:1rem}.noti-quick label{font-weight:600;color:#374151;font-size:.9rem;display:block;margin-bottom:.4rem}.noti-quick-btns{display:flex;gap:8px;flex-wrap:wrap}.noti-quick-btn{padding:6px 14px;border:1px solid #e2e8f0;border-radius:20px;background:#f8fafc;font-size:.8rem;cursor:pointer;transition:all .2s}.noti-quick-btn:hover{border-color:#6366f1;background:#eef2ff;color:#4338ca}.noti-target-options{display:flex;gap:12px;flex-wrap:wrap}.noti-radio{padding:10px 16px;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;font-size:.9rem;transition:all .2s;display:flex;align-items:center;gap:6px}.noti-radio input{display:none}.noti-radio.active{border-color:#6366f1;background:#eef2ff;color:#4338ca;font-weight:600}.noti-send-btn{width:100%;padding:14px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:.5rem}.noti-send-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f14d}.noti-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.noti-result{margin-top:1rem;padding:12px 16px;border-radius:10px;font-size:.9rem;font-weight:500}.noti-result.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.noti-result.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.noti-preview{display:flex;justify-content:center}.noti-preview-phone{width:280px;min-height:200px;background:#1e293b;border-radius:24px;padding:16px;position:relative}.noti-preview-notch{width:100px;height:20px;background:#0f172a;border-radius:0 0 12px 12px;margin:-16px auto 20px;position:relative}.noti-preview-notification{background:#fffffff2;border-radius:14px;padding:12px;display:flex;gap:10px;align-items:flex-start;box-shadow:0 2px 8px #0000001a}.noti-preview-icon{width:36px;height:36px;background:#064e3b;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.noti-preview-content{flex:1;min-width:0}.noti-preview-app{font-size:.7rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.noti-preview-title{font-size:.85rem;font-weight:700;color:#1e293b;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.noti-preview-body{font-size:.8rem;color:#64748b;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.noti-preview-time{font-size:.7rem;color:#94a3b8;flex-shrink:0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#f0f2f5;color:#1a1a2e;-webkit-font-smoothing:antialiased}:root{--primary: #0D5A2E;--primary-light: #1A7A45;--primary-lighter: #E8F5EE;--accent: #C9A067;--accent-light: #D4B896;--bg: #f0f2f5;--bg-white: #ffffff;--text: #1a1a2e;--text-light: #64748b;--text-lighter: #94a3b8;--border: #e2e8f0;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--info: #3b82f6;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--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);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px}.admin-page-wrapper{display:flex;height:100vh;overflow:hidden}.admin-sidebar{width:260px;background:var(--bg-white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;box-shadow:2px 0 8px #00000008}.sidebar-brand{padding:1.5rem;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem}.brand-text h2{font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:700;color:var(--primary);margin:0}.brand-subtitle{font-size:.7rem;color:var(--text-lighter);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.admin-nav{flex:1;display:flex;flex-direction:column;padding:1rem .75rem;gap:2px}.admin-nav-item{padding:.75rem 1rem;background:transparent;border:none;text-align:left;font-size:.9rem;font-weight:500;color:var(--text-light);cursor:pointer;transition:all .2s ease;border-radius:var(--radius-sm);display:flex;align-items:center;gap:10px}.admin-nav-item i{font-size:1rem;width:20px;text-align:center}.admin-nav-item:hover{background:var(--primary-lighter);color:var(--primary)}.admin-nav-item.active{background:var(--primary-lighter);color:var(--primary);font-weight:600}.admin-nav-item.nav-logout{color:var(--danger)}.admin-nav-item.nav-logout:hover{background:#fef2f2}.admin-nav-item.nav-link-external{color:var(--text-lighter);font-size:.85rem}.nav-separator{height:1px;background:var(--border);margin:.5rem 1rem}.sidebar-user{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent),var(--accent-light));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem}.user-info{display:flex;flex-direction:column}.user-name{font-size:.85rem;font-weight:600;color:var(--text)}.user-role{font-size:.7rem;color:var(--text-lighter);text-transform:capitalize}.admin-content{flex:1;overflow-y:auto;padding:1.5rem;background:var(--bg)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dashboard-header h2{font-family:Outfit,sans-serif;font-weight:700;color:var(--text)}.dashboard-subtitle{color:var(--text-light);margin-top:4px;font-size:.9rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-white);padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem;transition:all .3s ease;border:1px solid var(--border)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon-wrapper{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.stat-icon-wrapper.green{background:#dcfce7;color:#16a34a}.stat-icon-wrapper.blue{background:#dbeafe;color:#2563eb}.stat-icon-wrapper.orange{background:#ffedd5;color:#ea580c}.stat-icon-wrapper.purple{background:#f3e8ff;color:#9333ea}.stat-label{font-size:.8rem;color:var(--text-light);font-weight:500}.stat-value-group{display:flex;align-items:baseline;gap:4px}.stat-number{font-family:Outfit,sans-serif;font-size:1.75rem;font-weight:700;color:var(--text)}.stat-unit{font-size:.8rem;color:var(--text-lighter)}.section-title-wrapper{margin-bottom:1rem}.section-title{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:600;color:var(--text)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.25rem}.chart-card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:all .3s ease;border:1px solid var(--border)}.chart-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.chart-card-wide{grid-column:span 2}.chart-header{padding:1.25rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.chart-header h4{font-size:.95rem;font-weight:600;color:var(--text);margin:0}.chart-header p{font-size:.8rem;color:var(--text-light);margin:2px 0 0}.chart-body{padding:1rem;width:100%}.chart-badge{padding:.2rem .6rem;border-radius:9999px;font-size:.7rem;font-weight:600}.chart-badge.hot{background:#fef2f2;color:#ef4444}.btn{display:inline-flex;align-items:center;gap:6px;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d5a2e,#1a7a45,#2e9b5e);padding:1rem}.login-card{background:#fff;border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;margin:0 auto 1rem}.login-header h1{font-family:Outfit,sans-serif;font-size:1.5rem;color:var(--primary);font-weight:700}.login-header p{color:var(--text-light);font-size:.9rem}.login-error{background:#fef2f2;color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:1rem;display:flex;align-items:center;gap:8px}.login-card .form-group{margin-bottom:1.25rem}.login-card label{display:block;font-size:.85rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.input-wrapper{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:all .2s}.input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #0d5a2e1a}.input-wrapper i{padding:0 .75rem;color:var(--text-lighter);font-size:.9rem}.input-wrapper input{flex:1;border:none;padding:.7rem .75rem .7rem 0;font-size:.9rem;outline:none;background:transparent}.btn-login{width:100%;padding:.8rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-login:hover{background:var(--primary-light)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.spinner,.spinner-lg{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:40px;height:40px;border-color:#0d5a2e33;border-top-color:var(--primary)}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem;color:var(--text-light)}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem;color:var(--text-lighter)}.coming-soon i{font-size:3rem}.coming-soon h3{font-family:Outfit,sans-serif;color:var(--text)}@media(max-width:1024px){.chart-card-wide{grid-column:span 1}.charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-page-wrapper{flex-direction:column}.admin-sidebar{width:100%;flex-direction:row;height:auto;border-right:none;border-bottom:1px solid var(--border)}.sidebar-brand,.sidebar-user{display:none}.admin-nav{flex-direction:row;overflow-x:auto;padding:.5rem;gap:4px}.admin-nav-item{white-space:nowrap;padding:.6rem .8rem;font-size:.8rem}.nav-separator{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}}
