Toggle navigation
☰
HTML
CSS
Scripting
Database
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Metrics Dashboard</title> <style> *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } :root { --sidebar-w: 220px; --accent: #6366f1; --bg: #0f172a; --surface: #1e293b; --border: #334155; --text: #e2e8f0; --muted: #94a3b8; } body { font-family: 'Segoe UI', sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; display: flex; } /* ---- SIDEBAR ---- */ .sidebar { width: var(--sidebar-w); background: var(--surface); border-right: 1px solid var(--border); display: flex; flex-direction: column; padding: 24px 0; flex-shrink: 0; } .sidebar-logo { padding: 0 20px 28px; font-size: 1.3em; font-weight: 800; color: var(--accent); } .nav-group-title { padding: 0 20px 8px; font-size: 0.7em; text-transform: uppercase; letter-spacing: 1.5px; color: var(--muted); margin-top: 16px; } .nav-item { display: flex; align-items: center; gap: 12px; padding: 10px 20px; color: var(--muted); cursor: pointer; transition: background 0.15s, color 0.15s; font-size: 0.9em; } .nav-item:hover { background: rgba(255,255,255,0.05); color: var(--text); } .nav-item.active { background: rgba(99,102,241,0.15); color: var(--accent); border-right: 3px solid var(--accent); } .nav-item .icon { font-size: 1.1em; } /* ---- MAIN CONTENT ---- */ .main { flex: 1; display: flex; flex-direction: column; overflow: auto; } .topbar { display: flex; justify-content: space-between; align-items: center; padding: 20px 32px; border-bottom: 1px solid var(--border); background: var(--surface); } .topbar h1 { font-size: 1.2em; } .topbar-actions { display: flex; gap: 12px; align-items: center; } .avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--accent); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.9em; } .content { padding: 28px 32px; flex: 1; } /* ---- STAT CARDS ---- */ .stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 28px; } .stat-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 20px; } .stat-label { font-size: 0.8em; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; } .stat-value { font-size: 2em; font-weight: 800; margin-bottom: 6px; } .stat-change { font-size: 0.8em; } .stat-change.up { color: #4ade80; } .stat-change.down { color: #f87171; } /* ---- DATA TABLE ---- */ .table-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; margin-bottom: 28px; } .table-header { padding: 16px 20px; border-bottom: 1px solid var(--border); font-weight: 600; font-size: 0.95em; } table { width: 100%; border-collapse: collapse; } thead th { padding: 12px 20px; text-align: left; font-size: 0.75em; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); border-bottom: 1px solid var(--border); } tbody td { padding: 12px 20px; font-size: 0.9em; border-bottom: 1px solid rgba(255,255,255,0.04); } tbody tr:last-child td { border-bottom: none; } tbody tr:hover { background: rgba(255,255,255,0.03); } .status-pill { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 0.8em; font-weight: 600; } .status-pill.completed { background: rgba(74,222,128,0.15); color: #4ade80; } .status-pill.pending { background: rgba(251,191,36,0.15); color: #fbbf24; } .status-pill.failed { background: rgba(248,113,113,0.15); color: #f87171; } </style> </head> <body> <aside class="sidebar"> <div class="sidebar-logo">📈 Metrics</div> <div class="nav-group-title">Overview</div> <div class="nav-item active"><span class="icon">🏠</span> Dashboard</div> <div class="nav-item"><span class="icon">📊</span> Analytics</div> <div class="nav-item"><span class="icon">🛒</span> Sales</div> <div class="nav-group-title">Manage</div> <div class="nav-item"><span class="icon">👥</span> Customers</div> <div class="nav-item"><span class="icon">📦</span> Orders</div> <div class="nav-item"><span class="icon">⚙</span> Settings</div> </aside> <div class="main"> <div class="topbar"> <h1>Dashboard</h1> <div class="topbar-actions"> <div>🔔</div> <div class="avatar">AR</div> </div> </div> <div class="content"> <!-- Stat Cards --> <div class="stats-grid"> <div class="stat-card"> <div class="stat-label">💵 Revenue</div> <div class="stat-value">$84,240</div> <div class="stat-change up">▲ 12.5% from last month</div> </div> <div class="stat-card"> <div class="stat-label">🛒 Orders</div> <div class="stat-value">1,420</div> <div class="stat-change up">▲ 8.1%</div> </div> <div class="stat-card"> <div class="stat-label">👥 New Users</div> <div class="stat-value">286</div> <div class="stat-change down">▼ 3.4%</div> </div> <div class="stat-card"> <div class="stat-label">⚡ Conversion</div> <div class="stat-value">3.6%</div> <div class="stat-change up">▲ 0.4%</div> </div> </div> <!-- Recent Orders Table --> <div class="table-card"> <div class="table-header">Recent Orders</div> <table> <thead> <tr> <th>Order ID</th> <th>Customer</th> <th>Product</th> <th>Amount</th> <th>Status</th> </tr> </thead> <tbody> <tr><td>#10821</td><td>James Webb</td><td>ProSolar X9</td><td>$249.00</td><td><span class="status-pill completed">Completed</span></td></tr> <tr><td>#10820</td><td>Sandra Lee</td><td>Widget Pro</td><td>$49.00</td><td><span class="status-pill pending">Pending</span></td></tr> <tr><td>#10819</td><td>Alex Munn</td><td>Dashboard Kit</td><td>$129.00</td><td><span class="status-pill failed">Failed</span></td></tr> <tr><td>#10818</td><td>Priya Nair</td><td>ProSolar X9</td><td>$249.00</td><td><span class="status-pill completed">Completed</span></td></tr> </tbody> </table> </div> </div> </div> </body> </html>