BillTracker/client/index.css

236 lines
5.9 KiB
CSS
Raw Normal View History

2026-05-03 19:51:57 -05:00
/* ============================================================
Bill Tracker Material Design theme via shadcn/studio
:root is the default Material Design light theme.
============================================================ */
/* ── Tailwind base ───────────────────────────────────────── */
@tailwind base;
@tailwind components;
@tailwind utilities;
@layer base {
:root {
2026-05-28 01:30:40 -05:00
--background: 0.97 0.005 250;
--foreground: 0.15 0.008 250;
--card: 1.00 0 0;
--card-foreground: 0.15 0.008 250;
--popover: 1.00 0 0;
--popover-foreground: 0.15 0.008 250;
--primary: 0.55 0.20 276;
--primary-foreground: 0.99 0.003 250;
--secondary: 0.93 0.008 250;
--secondary-foreground: 0.20 0.010 250;
--muted: 0.94 0.006 250;
--muted-foreground: 0.48 0.010 250;
--accent: 0.92 0.012 265;
--accent-foreground: 0.20 0.010 250;
--destructive: 0.55 0.22 25;
--destructive-foreground: 0.99 0.003 250;
--border: 0.88 0.008 250;
--input: 0.88 0.008 250;
--ring: 0.55 0.16 276;
--chart-1: 0.55 0.22 270;
--chart-2: 0.55 0.14 150;
--chart-3: 0.60 0.18 310;
--chart-4: 0.58 0.16 130;
--chart-5: 0.55 0.18 255;
--sidebar: 0.94 0.007 250;
--sidebar-foreground: 0.20 0.008 250;
--sidebar-primary: 0.55 0.20 276;
--sidebar-primary-foreground: 0.99 0.003 250;
--sidebar-accent: 0.90 0.009 250;
--sidebar-accent-foreground: 0.20 0.008 250;
--sidebar-border: 0.88 0.008 250;
--sidebar-ring: 0.55 0.20 276;
2026-05-03 19:51:57 -05:00
--font-sans: Roboto, Inter, ui-sans-serif, system-ui, sans-serif;
--font-serif: Merriweather, Georgia, serif;
--font-mono: "Roboto Mono", ui-monospace, SFMono-Regular, monospace;
--radius: 1rem;
}
.dark {
2026-05-28 01:30:40 -05:00
--background: 0.17 0.008 250;
--foreground: 0.91 0.006 250;
--card: 0.21 0.009 250;
--card-foreground: 0.91 0.006 250;
--popover: 0.24 0.009 250;
--popover-foreground: 0.91 0.006 250;
--primary: 0.62 0.20 276;
--primary-foreground: 0.98 0.004 250;
--secondary: 0.28 0.012 255;
--secondary-foreground: 0.88 0.006 250;
--muted: 0.24 0.008 250;
--muted-foreground: 0.62 0.010 250;
--accent: 0.30 0.015 265;
--accent-foreground: 0.91 0.006 250;
--destructive: 0.65 0.18 22;
--destructive-foreground: 0.98 0.004 250;
--border: 0.30 0.009 250;
--input: 0.30 0.009 250;
--ring: 0.55 0.16 276;
--chart-1: 0.55 0.22 270;
--chart-2: 0.62 0.14 150;
--chart-3: 0.65 0.18 310;
--chart-4: 0.62 0.16 130;
--chart-5: 0.58 0.18 255;
--sidebar: 0.14 0.007 250;
--sidebar-foreground: 0.88 0.006 250;
--sidebar-primary: 0.62 0.20 276;
--sidebar-primary-foreground: 0.98 0.004 250;
--sidebar-accent: 0.22 0.009 250;
--sidebar-accent-foreground: 0.88 0.006 250;
--sidebar-border: 0.26 0.008 250;
--sidebar-ring: 0.62 0.20 276;
2026-05-03 19:51:57 -05:00
}
* {
@apply border-border;
}
html {
@apply scroll-smooth;
}
body {
@apply bg-background font-sans text-foreground antialiased;
letter-spacing: 0;
}
}
/* ── Utilities ───────────────────────────────────────────── */
@layer utilities {
/* Generic surface */
.surface {
2026-05-15 22:45:38 -05:00
@apply rounded-2xl border border-border/70 bg-card shadow-sm;
2026-05-03 19:51:57 -05:00
}
/* Elevated surface */
.surface-elevated {
@apply surface;
box-shadow:
0 1px 2px rgb(0 0 0 / 0.05),
2026-05-15 22:45:38 -05:00
0 6px 18px rgb(0 0 0 / 0.06);
2026-05-03 19:51:57 -05:00
}
.dark .surface-elevated {
box-shadow:
0 0 0 1px oklch(var(--border) / 0.7),
2026-05-15 22:45:38 -05:00
0 8px 22px rgb(0 0 0 / 0.55);
2026-05-03 19:51:57 -05:00
}
/* Stat cards */
.stat-card {
@apply surface-elevated p-6;
}
/* Table */
.table-surface {
@apply surface overflow-hidden shadow-sm;
}
/* Custom Scrollbar */
.scrollbar-thin {
scrollbar-width: thin;
}
.scrollbar-thumb-muted {
scrollbar-color: oklch(var(--muted) / 0.3) transparent;
}
.scrollbar-track-transparent {
scrollbar-color: oklch(var(--muted) / 0.3) transparent;
}
.scrollbar-thumb-muted::-webkit-scrollbar-thumb {
background-color: oklch(var(--muted) / 0.3);
border-radius: 8px;
}
.scrollbar-track-transparent::-webkit-scrollbar-track {
background-color: transparent;
}
.scrollbar-thumb-muted::-webkit-scrollbar-thumb:hover {
background-color: oklch(var(--muted) / 0.5);
}
2026-05-03 19:51:57 -05:00
}
2026-05-04 13:14:32 -05:00
@media print {
body {
background: white !important;
color: #111827 !important;
}
header,
.analytics-screen-header,
.analytics-controls,
2026-05-04 16:38:03 -05:00
.analytics-actions,
.summary-screen-header,
.summary-controls,
.summary-actions,
.summary-edit-actions,
.summary-income-form {
2026-05-04 13:14:32 -05:00
display: none !important;
}
main,
main > div {
max-width: none !important;
padding: 0 !important;
}
2026-05-04 16:38:03 -05:00
.analytics-page,
.summary-page {
2026-05-04 13:14:32 -05:00
color: #111827 !important;
}
.analytics-report-meta,
2026-05-04 16:38:03 -05:00
.analytics-print-footer,
.summary-print-meta,
.summary-print-footer {
2026-05-04 13:14:32 -05:00
display: block !important;
margin-bottom: 1rem;
}
2026-05-04 16:38:03 -05:00
.analytics-report-meta h1,
.summary-print-meta h1 {
2026-05-04 13:14:32 -05:00
font-size: 22px;
font-weight: 700;
margin-bottom: 0.25rem;
}
.analytics-report-meta p,
2026-05-04 16:38:03 -05:00
.analytics-print-footer,
.summary-print-meta p,
.summary-print-footer {
2026-05-04 13:14:32 -05:00
color: #4b5563 !important;
font-size: 12px;
margin: 0.125rem 0;
}
.analytics-range {
margin-bottom: 1rem;
}
2026-05-04 16:38:03 -05:00
.summary-page input {
border: 0 !important;
background: white !important;
box-shadow: none !important;
color: #111827 !important;
padding-left: 0 !important;
}
2026-05-04 13:14:32 -05:00
.analytics-chart-grid {
display: block !important;
}
2026-05-04 16:38:03 -05:00
.analytics-chart,
.summary-card,
.summary-chart-card {
2026-05-04 13:14:32 -05:00
break-inside: avoid;
page-break-inside: avoid;
margin-bottom: 1rem;
border: 1px solid #d1d5db !important;
box-shadow: none !important;
background: white !important;
}
}