- Style/category filter panel with active chip display - Dismiss (excluded_ids) support — recipes don't reappear until next fresh search - Load more appends next batch without full re-fetch - Prep notes 'Before you start:' section above directions - Nutrition macro chips (kcal, fat, protein, carbs, fiber, sugar, sodium) - Composables extracted for reuse
251 lines
6 KiB
CSS
251 lines
6 KiB
CSS
:root {
|
|
/* Typography */
|
|
--font-display: 'Fraunces', Georgia, serif;
|
|
--font-mono: 'DM Mono', 'Courier New', monospace;
|
|
--font-body: 'DM Sans', system-ui, sans-serif;
|
|
|
|
font-family: var(--font-body);
|
|
line-height: 1.5;
|
|
font-weight: 400;
|
|
|
|
color-scheme: dark;
|
|
|
|
font-synthesis: none;
|
|
text-rendering: optimizeLegibility;
|
|
-webkit-font-smoothing: antialiased;
|
|
-moz-osx-font-smoothing: grayscale;
|
|
|
|
/* Theme Colors - Dark Mode (Default) */
|
|
--color-text-primary: rgba(255, 248, 235, 0.92);
|
|
--color-text-secondary: rgba(255, 248, 235, 0.60);
|
|
--color-text-muted: rgba(255, 248, 235, 0.38);
|
|
|
|
--color-bg-primary: #1e1c1a;
|
|
--color-bg-secondary: #161412;
|
|
--color-bg-elevated: #2a2724;
|
|
--color-bg-card: #2a2724;
|
|
--color-bg-input: #161412;
|
|
|
|
--color-border: rgba(232, 168, 32, 0.12);
|
|
--color-border-focus: rgba(232, 168, 32, 0.35);
|
|
|
|
/* Brand Colors — Saffron amber + forest green */
|
|
--color-primary: #e8a820;
|
|
--color-primary-dark: #c88c10;
|
|
--color-primary-light: #f0bc48;
|
|
--color-secondary: #2d5a27;
|
|
--color-secondary-light: #3d7a35;
|
|
--color-secondary-dark: #1e3d1a;
|
|
|
|
/* Status Colors */
|
|
--color-success: #4a8c40;
|
|
--color-success-dark: #3a7030;
|
|
--color-success-light: #6aac60;
|
|
--color-success-bg: rgba(74, 140, 64, 0.12);
|
|
--color-success-border: rgba(74, 140, 64, 0.30);
|
|
|
|
--color-warning: #e8a820;
|
|
--color-warning-dark: #c88c10;
|
|
--color-warning-light: #f0bc48;
|
|
--color-warning-bg: rgba(232, 168, 32, 0.12);
|
|
--color-warning-border: rgba(232, 168, 32, 0.30);
|
|
|
|
--color-error: #c0392b;
|
|
--color-error-dark: #96281b;
|
|
--color-error-light: #e74c3c;
|
|
--color-error-bg: rgba(192, 57, 43, 0.12);
|
|
--color-error-border: rgba(192, 57, 43, 0.30);
|
|
|
|
--color-info: #2980b9;
|
|
--color-info-dark: #1a5f8a;
|
|
--color-info-light: #5dade2;
|
|
--color-info-bg: rgba(41, 128, 185, 0.12);
|
|
--color-info-border: rgba(41, 128, 185, 0.30);
|
|
|
|
/* Location dot colors */
|
|
--color-loc-fridge: #5dade2;
|
|
--color-loc-freezer: #48d1cc;
|
|
--color-loc-garage-freezer: #7fb3d3;
|
|
--color-loc-pantry: #e8a820;
|
|
--color-loc-cabinet: #a0855b;
|
|
|
|
/* Gradient */
|
|
--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, #c88c10 100%);
|
|
--gradient-secondary: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-secondary-light) 100%);
|
|
--gradient-header: linear-gradient(160deg, #2a2724 0%, #1e1c1a 100%);
|
|
|
|
/* Shadows */
|
|
--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.4);
|
|
--shadow-md: 0 4px 8px rgba(0, 0, 0, 0.4);
|
|
--shadow-lg: 0 10px 24px rgba(0, 0, 0, 0.5);
|
|
--shadow-xl: 0 20px 48px rgba(0, 0, 0, 0.6);
|
|
--shadow-amber: 0 4px 16px rgba(232, 168, 32, 0.20);
|
|
|
|
/* Typography Scale */
|
|
--font-size-xs: 11px;
|
|
--font-size-sm: 13px;
|
|
--font-size-base: 15px;
|
|
--font-size-lg: 17px;
|
|
--font-size-xl: 22px;
|
|
--font-size-2xl: 30px;
|
|
--font-size-display: 28px;
|
|
|
|
/* Spacing */
|
|
--spacing-xs: 4px;
|
|
--spacing-sm: 8px;
|
|
--spacing-md: 16px;
|
|
--spacing-lg: 24px;
|
|
--spacing-xl: 32px;
|
|
|
|
/* Border Radius */
|
|
--radius-sm: 6px;
|
|
--radius-md: 8px;
|
|
--radius-lg: 12px;
|
|
--radius-xl: 16px;
|
|
--radius-pill: 999px;
|
|
|
|
color: var(--color-text-primary);
|
|
background-color: var(--color-bg-primary);
|
|
}
|
|
|
|
/* Light mode overrides */
|
|
@media (prefers-color-scheme: light) {
|
|
:root {
|
|
--color-text-primary: #2c1a06;
|
|
--color-text-secondary: #6b4c1e;
|
|
--color-text-muted: #a0845a;
|
|
|
|
--color-bg-primary: #fdf8f0;
|
|
--color-bg-secondary: #ffffff;
|
|
--color-bg-elevated: #fff9ed;
|
|
--color-bg-card: #ffffff;
|
|
--color-bg-input: #fef9ef;
|
|
|
|
--color-border: rgba(168, 100, 20, 0.15);
|
|
--color-border-focus: rgba(168, 100, 20, 0.40);
|
|
|
|
--color-success-bg: #e8f5e2;
|
|
--color-success-border: #c3e0bb;
|
|
--color-warning-bg: #fff8e1;
|
|
--color-warning-border: #ffe08a;
|
|
--color-error-bg: #fdecea;
|
|
--color-error-border: #f5c6c2;
|
|
--color-info-bg: #e3f2fd;
|
|
--color-info-border: #b3d8f5;
|
|
|
|
--gradient-header: linear-gradient(160deg, #fff9ed 0%, #fdf8f0 100%);
|
|
|
|
--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
|
|
--shadow-md: 0 4px 8px rgba(0, 0, 0, 0.10);
|
|
--shadow-lg: 0 10px 24px rgba(0, 0, 0, 0.12);
|
|
--shadow-xl: 0 20px 48px rgba(0, 0, 0, 0.16);
|
|
--shadow-amber: 0 4px 16px rgba(168, 100, 20, 0.15);
|
|
}
|
|
}
|
|
|
|
a {
|
|
font-weight: 500;
|
|
color: var(--color-primary);
|
|
text-decoration: inherit;
|
|
}
|
|
a:hover {
|
|
color: var(--color-primary-light);
|
|
}
|
|
|
|
body {
|
|
margin: 0;
|
|
min-width: 320px;
|
|
min-height: 100vh;
|
|
background-color: var(--color-bg-primary);
|
|
color: var(--color-text-primary);
|
|
}
|
|
|
|
h1, h2, h3 {
|
|
font-family: var(--font-display);
|
|
font-weight: 600;
|
|
line-height: 1.2;
|
|
}
|
|
|
|
button {
|
|
border-radius: var(--radius-md);
|
|
border: 1px solid transparent;
|
|
padding: 0.5em 1.1em;
|
|
font-size: var(--font-size-sm);
|
|
font-weight: 500;
|
|
font-family: var(--font-body);
|
|
background-color: var(--color-bg-elevated);
|
|
color: var(--color-text-primary);
|
|
cursor: pointer;
|
|
transition: all 0.2s ease;
|
|
}
|
|
button:hover {
|
|
border-color: var(--color-primary);
|
|
}
|
|
button:focus,
|
|
button:focus-visible {
|
|
outline: 2px solid var(--color-primary);
|
|
outline-offset: 2px;
|
|
}
|
|
|
|
.card {
|
|
padding: var(--spacing-lg);
|
|
}
|
|
|
|
#app {
|
|
max-width: 1280px;
|
|
margin: 0 auto;
|
|
text-align: left;
|
|
}
|
|
|
|
/* Mobile Responsive Typography and Spacing */
|
|
@media (max-width: 480px) {
|
|
:root {
|
|
--font-size-xs: 11px;
|
|
--font-size-sm: 12px;
|
|
--font-size-base: 14px;
|
|
--font-size-lg: 16px;
|
|
--font-size-xl: 19px;
|
|
--font-size-2xl: 24px;
|
|
--font-size-display: 22px;
|
|
|
|
--spacing-xs: 4px;
|
|
--spacing-sm: 6px;
|
|
--spacing-md: 12px;
|
|
--spacing-lg: 16px;
|
|
--spacing-xl: 20px;
|
|
|
|
--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
|
|
--shadow-md: 0 2px 6px rgba(0, 0, 0, 0.35);
|
|
--shadow-lg: 0 6px 12px rgba(0, 0, 0, 0.40);
|
|
--shadow-xl: 0 12px 24px rgba(0, 0, 0, 0.50);
|
|
}
|
|
|
|
.card {
|
|
padding: var(--spacing-md);
|
|
}
|
|
|
|
#app {
|
|
padding: 0;
|
|
}
|
|
}
|
|
|
|
@media (min-width: 481px) and (max-width: 768px) {
|
|
:root {
|
|
--font-size-base: 14px;
|
|
--font-size-lg: 16px;
|
|
--font-size-xl: 20px;
|
|
--font-size-2xl: 26px;
|
|
|
|
--spacing-md: 14px;
|
|
--spacing-lg: 20px;
|
|
--spacing-xl: 28px;
|
|
}
|
|
|
|
.card {
|
|
padding: var(--spacing-md) var(--spacing-lg);
|
|
}
|
|
|
|
#app {
|
|
padding: 0;
|
|
}
|
|
}
|