mirror of
https://github.com/dat515-2025/Group-8.git
synced 2026-03-22 06:57:47 +01:00
86 lines
3.5 KiB
CSS
86 lines
3.5 KiB
CSS
:root {
|
|
--bg: #f7f7fb;
|
|
--panel: #ffffff;
|
|
--text: #9aa3b2;
|
|
--muted: #6b7280;
|
|
--primary: #6f49fe;
|
|
--primary-600: #5a37fb;
|
|
--border: #e5e7eb;
|
|
--radius: 12px;
|
|
--shadow: 0 1px 2px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.08);
|
|
|
|
font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
|
|
color: var(--text);
|
|
}
|
|
|
|
* { box-sizing: border-box; }
|
|
|
|
html, body, #root { height: 100%; }
|
|
|
|
body { background: var(--bg); margin: 0; display: block; }
|
|
|
|
/* Dark theme variables */
|
|
body[data-theme="dark"] {
|
|
--bg: #161a2b;
|
|
--panel: #283046;
|
|
--text: #283046;
|
|
--muted: #cbd5e1;
|
|
--primary: #8b7bff;
|
|
--primary-600: #7b69ff;
|
|
--border: #283046;
|
|
}
|
|
|
|
/* Layout */
|
|
.app-layout { display: grid; grid-template-columns: 260px 1fr; height: 100%; }
|
|
.sidebar { background: #15172a; color: #e5e7eb; display: flex; flex-direction: column; padding: 20px 12px; }
|
|
.sidebar .logo { color: #fff; font-weight: 700; font-size: 18px; padding: 12px 14px; display: flex; align-items: center; gap: 10px; }
|
|
.nav { margin-top: 12px; display: grid; gap: 4px; }
|
|
.nav a, .nav button { color: #cbd5e1; text-align: left; background: transparent; border: 0; padding: 10px 12px; border-radius: 8px; cursor: pointer; }
|
|
.nav a.active, .nav a:hover, .nav button:hover { background: rgba(255,255,255,0.08); color: #fff; }
|
|
|
|
.content { display: flex; flex-direction: column; height: 100%; }
|
|
.topbar { height: 64px; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; background: var(--panel); border-bottom: 1px solid var(--border); }
|
|
.topbar .user { color: var(--muted); }
|
|
.page { padding: 24px; max-width: 1100px; margin: auto; }
|
|
|
|
/* Cards */
|
|
.card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); padding: 16px; }
|
|
.card h3 { margin: 0 0 12px; }
|
|
|
|
/* Forms */
|
|
.input, select, textarea { width: 100%; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--border); background: #fff; color: var(--text); }
|
|
.input:focus, select:focus, textarea:focus { outline: 2px solid var(--primary); border-color: var(--primary); }
|
|
.form-row { display: grid; gap: 8px; grid-template-columns: repeat(4, minmax(0,1fr)); }
|
|
.form-row > * { min-width: 140px; }
|
|
.actions { display: flex; align-items: center; gap: 8px; }
|
|
|
|
/* Buttons */
|
|
.btn { border: 1px solid var(--border); background: #fff; color: var(--text); padding: 10px 14px; border-radius: 10px; cursor: pointer; }
|
|
.btn.primary { background: var(--primary); border-color: var(--primary); color: #fff; }
|
|
.btn.primary:hover { background: var(--primary-600); }
|
|
.btn.ghost { background: transparent; color: var(--muted); }
|
|
|
|
/* Tables */
|
|
.table { width: 100%; border-collapse: collapse; }
|
|
.table th, .table td { padding: 10px; border-bottom: 1px solid var(--border); }
|
|
.table th { text-align: left; color: var(--muted); font-weight: 600; }
|
|
.table td.amount { text-align: right; font-variant-numeric: tabular-nums; }
|
|
|
|
/* Segmented control */
|
|
.segmented { display: inline-flex; background: #f1f5f9; border-radius: 10px; padding: 4px; border: 1px solid var(--border); }
|
|
.segmented button { border: 0; background: transparent; padding: 8px 12px; border-radius: 8px; color: var(--muted); cursor: pointer; }
|
|
.segmented button.active { background: #fff; color: var(--text); box-shadow: var(--shadow); }
|
|
|
|
/* Auth layout */
|
|
body.auth-page #root {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
min-height: 100vh;
|
|
width: 100%;
|
|
}
|
|
|
|
/* Utility */
|
|
.muted { color: var(--muted); }
|
|
.space-y > * + * { margin-top: 12px; }
|