/* Dashboard CSS */ :root { --primary: #667eea; --primary-dark: #5a67d8; --secondary: #764ba2; --accent: #f093fb; --success: #48bb78; --warning: #ed8936; --danger: #f56565; --dark: #1a202c; --gray-900: #1a202c; --gray-800: #2d3748; --gray-700: #4a5568; --gray-600: #718096; --gray-500: #a0aec0; --gray-400: #cbd5e0; --gray-300: #e2e8f0; --gray-200: #edf2f7; --gray-100: #f7fafc; --white: #ffffff; --sidebar-width: 260px; --header-height: 60px; } * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif; background: var(--gray-100); color: var(--gray-800); line-height: 1.6; } /* Dashboard Container */ .dashboard-container { display: flex; min-height: 100vh; } /* Sidebar */ .sidebar { width: var(--sidebar-width); background: linear-gradient(180deg, var(--gray-900) 0%, var(--gray-800) 100%); color: var(--white); display: flex; flex-direction: column; position: fixed; height: 100vh; z-index: 100; } .sidebar-header { padding: 1.5rem; border-bottom: 1px solid var(--gray-700); } .sidebar-header h2 { font-size: 1.25rem; font-weight: 600; margin-bottom: 0.25rem; } .role-badge { font-size: 0.75rem; background: var(--primary); padding: 0.125rem 0.5rem; border-radius: 9999px; text-transform: capitalize; } /* Navigation */ .sidebar-nav { flex: 1; padding: 1rem 0; overflow-y: auto; } .nav-item { display: flex; align-items: center; gap: 0.75rem; padding: 0.75rem 1.5rem; color: var(--gray-400); text-decoration: none; transition: all 0.2s; } .nav-item:hover { background: var(--gray-700); color: var(--white); } .nav-item.active { background: linear-gradient(90deg, var(--primary) 0%, var(--secondary) 100%); color: var(--white); } .nav-icon { font-size: 1.25rem; width: 1.5rem; text-align: center; } .nav-divider { height: 1px; background: var(--gray-700); margin: 1rem 0; } .nav-label { display: block; padding: 0.5rem 1.5rem; font-size: 0.75rem; text-transform: uppercase; color: var(--gray-500); letter-spacing: 0.05em; } .sidebar-footer { border-top: 1px solid var(--gray-700); padding: 0.5rem 0; } .nav-item.logout:hover { background: var(--danger); } /* Main Content */ .main-content { flex: 1; margin-left: var(--sidebar-width); min-height: 100vh; } .main-header { height: var(--header-height); background: var(--white); border-bottom: 1px solid var(--gray-300); display: flex; align-items: center; justify-content: space-between; padding: 0 2rem; position: sticky; top: 0; z-index: 50; } .main-header h1 { font-size: 1.5rem; font-weight: 600; } .user-info { color: var(--gray-600); font-size: 0.875rem; } .content-wrapper { padding: 2rem; } /* Cards */ .card { background: var(--white); border-radius: 0.5rem; box-shadow: 0 1px 3px rgba(0,0,0,0.1); margin-bottom: 1.5rem; } .card-header { padding: 1rem 1.5rem; border-bottom: 1px solid var(--gray-200); display: flex; align-items: center; justify-content: space-between; } .card-title { font-size: 1rem; font-weight: 600; } .card-body { padding: 1.5rem; } /* Stats Grid */ .stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; margin-bottom: 2rem; } .stat-card { background: var(--white); border-radius: 0.5rem; padding: 1.5rem; box-shadow: 0 1px 3px rgba(0,0,0,0.1); } .stat-icon { font-size: 2rem; margin-bottom: 0.5rem; } .stat-value { font-size: 2rem; font-weight: 700; color: var(--gray-900); } .stat-label { color: var(--gray-600); font-size: 0.875rem; } .stat-change { font-size: 0.875rem; margin-top: 0.25rem; } .stat-change.positive { color: var(--success); } .stat-change.negative { color: var(--danger); } /* Forms */ .form-group { margin-bottom: 1.5rem; } .form-label { display: block; font-weight: 500; margin-bottom: 0.5rem; color: var(--gray-700); } .form-input, .form-select, .form-textarea { width: 100%; padding: 0.75rem 1rem; border: 1px solid var(--gray-300); border-radius: 0.375rem; font-size: 1rem; transition: border-color 0.2s, box-shadow 0.2s; } .form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.2); } .form-help { font-size: 0.875rem; color: var(--gray-500); margin-top: 0.25rem; } .form-textarea { min-height: 100px; resize: vertical; } /* Buttons */ .btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.75rem 1.5rem; border: none; border-radius: 0.375rem; font-size: 1rem; font-weight: 500; cursor: pointer; transition: all 0.2s; text-decoration: none; } .btn-primary { background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%); color: var(--white); } .btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4); } .btn-secondary { background: var(--gray-200); color: var(--gray-700); } .btn-secondary:hover { background: var(--gray-300); } .btn-danger { background: var(--danger); color: var(--white); } .btn-success { background: var(--success); color: var(--white); } .btn-sm { padding: 0.5rem 1rem; font-size: 0.875rem; } /* Alerts */ .alert { padding: 1rem 1.5rem; border-radius: 0.375rem; margin-bottom: 1.5rem; } .alert-success { background: #c6f6d5; color: #22543d; border: 1px solid #9ae6b4; } .alert-error { background: #fed7d7; color: #742a2a; border: 1px solid #feb2b2; } .alert-warning { background: #feebc8; color: #744210; border: 1px solid #fbd38d; } .alert-info { background: #bee3f8; color: #2a4365; border: 1px solid #90cdf4; } /* Tables */ .table { width: 100%; border-collapse: collapse; } .table th, .table td { padding: 1rem; text-align: left; border-bottom: 1px solid var(--gray-200); } .table th { font-weight: 600; color: var(--gray-600); font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.05em; } .table tbody tr:hover { background: var(--gray-50); } /* Status Badges */ .badge { display: inline-block; padding: 0.25rem 0.75rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 500; } .badge-success { background: #c6f6d5; color: #22543d; } .badge-warning { background: #feebc8; color: #744210; } .badge-danger { background: #fed7d7; color: #742a2a; } .badge-info { background: #bee3f8; color: #2a4365; } /* Grid */ .grid { display: grid; gap: 1.5rem; } .grid-2 { grid-template-columns: repeat(2, 1fr); } .grid-3 { grid-template-columns: repeat(3, 1fr); } /* Color Picker */ .color-picker-wrapper { display: flex; align-items: center; gap: 1rem; } .color-picker { width: 50px; height: 40px; border: none; border-radius: 0.375rem; cursor: pointer; } .color-value { font-family: monospace; color: var(--gray-600); } /* Preview Box */ .preview-box { border: 2px dashed var(--gray-300); border-radius: 0.5rem; padding: 2rem; text-align: center; background: var(--gray-50); } /* Toggle Switch */ .toggle-wrapper { display: flex; align-items: center; gap: 0.75rem; } .toggle { position: relative; width: 48px; height: 24px; } .toggle input { opacity: 0; width: 0; height: 0; } .toggle-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background: var(--gray-300); border-radius: 24px; transition: 0.3s; } .toggle-slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background: white; border-radius: 50%; transition: 0.3s; } .toggle input:checked + .toggle-slider { background: var(--primary); } .toggle input:checked + .toggle-slider:before { transform: translateX(24px); } /* Login Page */ .login-container { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%); } .login-box { background: var(--white); padding: 2.5rem; border-radius: 1rem; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25); width: 100%; max-width: 400px; } .login-title { text-align: center; margin-bottom: 2rem; } .login-title h1 { font-size: 1.5rem; margin-bottom: 0.5rem; } .login-title p { color: var(--gray-500); } /* Responsive */ @media (max-width: 768px) { .sidebar { transform: translateX(-100%); transition: transform 0.3s; } .sidebar.open { transform: translateX(0); } .main-content { margin-left: 0; } .stats-grid { grid-template-columns: 1fr; } .grid-2, .grid-3 { grid-template-columns: 1fr; } }