style: refresh shared visual system

This commit is contained in:
Nico 2026-03-30 23:46:38 -07:00
parent 5510401635
commit 74913c3435
3 changed files with 483 additions and 313 deletions

View File

@ -1,73 +1,3 @@
/* :root {
font-family: system-ui, Avenir, Helvetica, Arial, sans-serif;
line-height: 1.5;
font-weight: 400;
color-scheme: light dark;
color: rgba(255, 255, 255, 0.87);
background-color: #242424;
font-synthesis: none;
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
a {
font-weight: 500;
color: #646cff;
text-decoration: inherit;
}
a:hover {
color: #535bf2;
}
body {
margin: 0;
display: flex;
place-items: center;
min-width: 320px;
min-height: 100vh;
}
h1 {
font-size: 3.2em;
line-height: 1.1;
}
button {
border-radius: 8px;
border: 1px solid transparent;
padding: 0.6em 1.2em;
font-size: 1em;
font-weight: 500;
font-family: inherit;
background-color: #1a1a1a;
cursor: pointer;
transition: border-color 0.25s;
}
button:hover {
border-color: #646cff;
}
button:focus,
button:focus-visible {
outline: 4px auto -webkit-focus-ring-color;
}
@media (prefers-color-scheme: light) {
:root {
color: #213547;
background-color: #ffffff;
}
a:hover {
color: #747bff;
}
button {
background-color: #f9f9f9;
}
} */
/** /**
* Global Base Styles * Global Base Styles
* Uses theme variables defined in theme.css * Uses theme variables defined in theme.css
@ -77,12 +7,20 @@ button:focus-visible {
box-sizing: border-box; box-sizing: border-box;
} }
html {
min-width: 320px;
scroll-behavior: smooth;
}
body { body {
font-family: var(--font-family-base); font-family: var(--font-family-base);
font-size: var(--font-size-base); font-size: var(--font-size-base);
line-height: var(--line-height-normal); line-height: var(--line-height-normal);
color: var(--color-text-primary); color: var(--color-text-primary);
background: var(--color-bg-body); background:
radial-gradient(circle at top left, rgba(15, 118, 110, 0.14), transparent 34%),
radial-gradient(circle at top right, rgba(245, 158, 11, 0.14), transparent 28%),
linear-gradient(180deg, #faf8f3 0%, var(--color-bg-body) 42%, #efe8dc 100%);
margin: 0; margin: 0;
padding: 0; padding: 0;
-webkit-font-smoothing: antialiased; -webkit-font-smoothing: antialiased;
@ -90,44 +28,275 @@ body {
transition: background-color 0.3s ease, color 0.3s ease; transition: background-color 0.3s ease, color 0.3s ease;
} }
[data-theme="dark"] body,
body.dark-mode {
background:
radial-gradient(circle at top left, rgba(45, 212, 191, 0.12), transparent 28%),
radial-gradient(circle at top right, rgba(251, 191, 36, 0.08), transparent 24%),
linear-gradient(180deg, #101823 0%, var(--color-bg-body) 44%, #0b1220 100%);
}
#root { #root {
min-height: 100vh; min-height: 100vh;
} }
.container { a {
max-width: var(--container-max-width); color: var(--color-primary);
margin: auto; text-decoration: none;
padding: var(--container-padding); transition: color var(--transition-base), opacity var(--transition-base);
} }
h1 { a:hover {
text-align: center; color: var(--color-primary-hover);
font-size: 1.5em; }
h1,
h2,
h3,
h4,
h5,
h6 {
margin: 0;
font-family: var(--font-family-heading);
line-height: var(--line-height-tight);
letter-spacing: -0.02em;
}
p {
margin: 0;
} }
input, input,
button, select,
select { textarea {
font-size: 1em;
margin: 0.3em 0;
padding: 0.5em;
width: 100%; width: 100%;
box-sizing: border-box; font: inherit;
}
button {
font: inherit;
} }
ul { ul {
list-style: none; list-style: none;
padding: 0; padding: 0;
margin: 0;
} }
li { .page-shell {
padding: 0.5em; width: min(100%, var(--page-max-width));
background: #e9ecef; margin: 0 auto;
margin-bottom: 0.5em; padding: clamp(1rem, 2vw, 1.75rem);
border-radius: 4px; }
.page-shell--narrow {
max-width: 560px;
}
.page-shell--center {
min-height: 100vh;
display: flex;
align-items: center;
justify-content: center;
}
.page-panel {
position: relative;
overflow: hidden;
width: 100%;
border: 1px solid var(--color-border-light);
border-radius: var(--border-radius-xl);
background:
linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.88)),
var(--color-bg-surface);
box-shadow: var(--shadow-xl);
backdrop-filter: blur(18px);
}
[data-theme="dark"] .page-panel,
body.dark-mode .page-panel {
background:
linear-gradient(180deg, rgba(20, 29, 42, 0.96), rgba(15, 23, 34, 0.9)),
var(--color-bg-surface);
}
.page-panel::before {
content: "";
position: absolute;
inset: 0 auto auto 0;
width: 100%;
height: 10px;
background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
opacity: 0.9;
}
.page-panel-inner {
padding: clamp(1.25rem, 3vw, 2.4rem);
}
.page-panel--compact .page-panel-inner {
padding: clamp(1.4rem, 4vw, 2.1rem);
}
.page-hero {
display: flex;
flex-direction: column;
gap: 0.65rem;
margin-bottom: 1.5rem;
}
.page-eyebrow {
display: inline-flex;
align-items: center;
gap: 0.45rem;
width: fit-content;
padding: 0.45rem 0.8rem;
border-radius: var(--border-radius-full);
background: var(--color-primary-light);
color: var(--color-primary-dark);
font-size: 0.78rem;
font-weight: var(--font-weight-bold);
letter-spacing: 0.1em;
text-transform: uppercase;
}
.page-title {
font-size: clamp(2rem, 4vw, 3.2rem);
color: var(--color-text-primary);
}
.page-subtitle {
max-width: 44rem;
color: var(--color-text-secondary);
font-size: 1.02rem;
line-height: 1.7;
}
.page-tabs {
display: inline-flex;
flex-wrap: wrap;
gap: 0.6rem;
padding: 0.45rem;
border: 1px solid var(--color-border-light);
border-radius: var(--border-radius-full);
background: rgba(255, 255, 255, 0.62);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}
[data-theme="dark"] .page-tabs,
body.dark-mode .page-tabs {
background: rgba(15, 23, 34, 0.72);
}
.page-tab {
min-width: 120px;
padding: 0.75rem 1.15rem;
border: none;
border-radius: var(--border-radius-full);
background: transparent;
color: var(--color-text-secondary);
font-size: var(--font-size-sm);
font-weight: var(--font-weight-semibold);
cursor: pointer; cursor: pointer;
transition: background var(--transition-base), color var(--transition-base), transform var(--transition-base);
} }
li:hover { .page-tab:hover {
background: #dee2e6; background: rgba(15, 118, 110, 0.08);
color: var(--color-text-primary);
}
.page-tab.active {
background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
color: var(--color-text-inverse);
box-shadow: var(--shadow-sm);
}
.surface-note {
border: 1px solid var(--color-border-light);
border-radius: var(--border-radius-lg);
background: rgba(255, 255, 255, 0.64);
padding: 1rem 1.1rem;
color: var(--color-text-secondary);
}
[data-theme="dark"] .surface-note,
body.dark-mode .surface-note {
background: rgba(15, 23, 34, 0.72);
}
.error-message,
.success-message {
margin-bottom: 1rem;
padding: 0.9rem 1rem;
border-radius: var(--border-radius-md);
border: 1px solid;
font-size: var(--font-size-sm);
line-height: 1.55;
}
.error-message {
color: var(--color-danger);
background: var(--color-danger-light);
border-color: color-mix(in srgb, var(--color-danger) 35%, transparent);
}
.success-message {
color: var(--color-success);
background: var(--color-success-light);
border-color: color-mix(in srgb, var(--color-success) 35%, transparent);
}
.auth-shell {
min-height: 100vh;
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
}
.auth-card {
width: min(100%, 30rem);
}
.auth-card .page-hero {
margin-bottom: 1.25rem;
}
.auth-subtitle {
color: var(--color-text-secondary);
font-size: var(--font-size-sm);
line-height: 1.7;
}
.auth-form {
display: flex;
flex-direction: column;
gap: 0.9rem;
}
.auth-footer {
margin-top: 1.25rem;
color: var(--color-text-secondary);
font-size: var(--font-size-sm);
text-align: center;
}
@media (max-width: 640px) {
.page-shell {
padding: 0.85rem;
}
.page-tabs {
width: 100%;
}
.page-tab {
flex: 1 1 calc(50% - 0.6rem);
min-width: 0;
}
.page-title {
font-size: clamp(1.8rem, 8vw, 2.4rem);
}
} }

View File

@ -1,9 +1,9 @@
/** /**
* Global Theme Variables * Global Theme Variables
* *
* This file defines the design system for the entire application. * This file defines the design system for the entire application.
* All colors, spacing, typography, and other design tokens are centralized here. * All colors, spacing, typography, and other design tokens are centralized here.
* *
* Usage: var(--variable-name) * Usage: var(--variable-name)
* Example: color: var(--color-primary); * Example: color: var(--color-primary);
*/ */
@ -12,135 +12,139 @@
/* ============================================ /* ============================================
COLOR PALETTE COLOR PALETTE
============================================ */ ============================================ */
/* Primary Colors */ /* Primary Colors */
--color-primary: dodgerblue; --color-primary: dodgerblue;
--color-primary-hover: #0066cc; --color-primary-hover: #1677d2;
--color-primary-light: #e7f3ff; --color-primary-light: #dceeff;
--color-primary-dark: #0056b3; --color-primary-dark: #0f5db4;
/* Secondary Colors */ /* Secondary Colors */
--color-secondary: #6c757d; --color-secondary: #7c5a3c;
--color-secondary-hover: #545b62; --color-secondary-hover: #64462e;
--color-secondary-light: #f8f9fa; --color-secondary-light: #f5ede4;
/* Accent Colors */
--color-accent: #f59e0b;
--color-accent-light: #fff2d8;
/* Semantic Colors */ /* Semantic Colors */
--color-success: #28a745; --color-success: #15803d;
--color-success-hover: #218838; --color-success-hover: #166534;
--color-success-light: #d4edda; --color-success-light: #dcfce7;
--color-danger: #dc3545; --color-danger: #dc2626;
--color-danger-hover: #c82333; --color-danger-hover: #b91c1c;
--color-danger-light: #f8d7da; --color-danger-light: #fee2e2;
--color-warning: #ffc107; --color-warning: #d97706;
--color-warning-hover: #e0a800; --color-warning-hover: #b45309;
--color-warning-light: #fff3cd; --color-warning-light: #ffedd5;
--color-info: #17a2b8; --color-info: #0369a1;
--color-info-hover: #138496; --color-info-hover: #075985;
--color-info-light: #d1ecf1; --color-info-light: #dbeafe;
/* Neutral Colors */ /* Neutral Colors */
--color-white: #ffffff; --color-white: #ffffff;
--color-black: #000000; --color-black: #0f172a;
--color-gray-50: #f9f9f9; --color-gray-50: #fcfbf8;
--color-gray-100: #f8f9fa; --color-gray-100: #f6f3ee;
--color-gray-200: #e9ecef; --color-gray-200: #ebe6dd;
--color-gray-300: #dee2e6; --color-gray-300: #ddd4c7;
--color-gray-400: #ced4da; --color-gray-400: #b6ab9a;
--color-gray-500: #adb5bd; --color-gray-500: #8e8579;
--color-gray-600: #6c757d; --color-gray-600: #6b645b;
--color-gray-700: #495057; --color-gray-700: #47423d;
--color-gray-800: #343a40; --color-gray-800: #2d2a27;
--color-gray-900: #212529; --color-gray-900: #1c1917;
/* Text Colors */ /* Text Colors */
--color-text-primary: #212529; --color-text-primary: #1f2937;
--color-text-secondary: #6c757d; --color-text-secondary: #5b6473;
--color-text-muted: #adb5bd; --color-text-muted: #8e98a8;
--color-text-inverse: #ffffff; --color-text-inverse: #f8fafc;
--color-text-disabled: #6c757d; --color-text-disabled: #9aa4b2;
/* Background Colors */ /* Background Colors */
--color-bg-body: #f8f9fa; --color-bg-body: #f4f1ea;
--color-bg-surface: #ffffff; --color-bg-surface: rgba(255, 255, 255, 0.9);
--color-bg-hover: #f5f5f5; --color-bg-elevated: rgba(255, 255, 255, 0.98);
--color-bg-disabled: #e9ecef; --color-bg-hover: #f2f7f6;
--color-bg-disabled: #ece7de;
--color-bg-hero: linear-gradient(135deg, rgba(15, 118, 110, 0.12), rgba(245, 158, 11, 0.12));
/* Border Colors */ /* Border Colors */
--color-border-light: #e0e0e0; --color-border-light: rgba(119, 107, 91, 0.18);
--color-border-medium: #ccc; --color-border-medium: rgba(119, 107, 91, 0.32);
--color-border-dark: #999; --color-border-dark: rgba(91, 81, 69, 0.55);
--color-border-disabled: #dee2e6; --color-border-disabled: rgba(148, 163, 184, 0.35);
/* ============================================ /* ============================================
SPACING SPACING
============================================ */ ============================================ */
--spacing-xs: 0.25rem; /* 4px */ --spacing-xs: 0.25rem;
--spacing-sm: 0.5rem; /* 8px */ --spacing-sm: 0.5rem;
--spacing-md: 1rem; /* 16px */ --spacing-md: 1rem;
--spacing-lg: 1.5rem; /* 24px */ --spacing-lg: 1.5rem;
--spacing-xl: 2rem; /* 32px */ --spacing-xl: 2rem;
--spacing-2xl: 3rem; /* 48px */ --spacing-2xl: 3rem;
--spacing-3xl: 4rem; /* 64px */ --spacing-3xl: 4rem;
/* ============================================ /* ============================================
TYPOGRAPHY TYPOGRAPHY
============================================ */ ============================================ */
--font-family-base: Arial, sans-serif; --font-family-base: "Aptos", "Segoe UI Variable Text", "Segoe UI", sans-serif;
--font-family-heading: Arial, sans-serif; --font-family-heading: "Aptos Display", "Aptos", "Segoe UI Variable Display", "Segoe UI", sans-serif;
--font-family-mono: 'Courier New', monospace; --font-family-mono: "IBM Plex Mono", "Cascadia Code", "Consolas", monospace;
/* Font Sizes */ --font-size-xs: 0.75rem;
--font-size-xs: 0.75rem; /* 12px */ --font-size-sm: 0.875rem;
--font-size-sm: 0.875rem; /* 14px */ --font-size-base: 1rem;
--font-size-base: 1rem; /* 16px */ --font-size-lg: 1.125rem;
--font-size-lg: 1.125rem; /* 18px */ --font-size-xl: 1.25rem;
--font-size-xl: 1.25rem; /* 20px */ --font-size-2xl: 1.5rem;
--font-size-2xl: 1.5rem; /* 24px */ --font-size-3xl: 2rem;
--font-size-3xl: 2rem; /* 32px */ --font-size-4xl: 2.75rem;
/* Font Weights */
--font-weight-normal: 400; --font-weight-normal: 400;
--font-weight-medium: 500; --font-weight-medium: 500;
--font-weight-semibold: 600; --font-weight-semibold: 600;
--font-weight-bold: 700; --font-weight-bold: 700;
/* Line Heights */ --line-height-tight: 1.15;
--line-height-tight: 1.2;
--line-height-normal: 1.5; --line-height-normal: 1.5;
--line-height-relaxed: 1.75; --line-height-relaxed: 1.75;
/* ============================================ /* ============================================
BORDERS & RADIUS BORDERS & RADIUS
============================================ */ ============================================ */
--border-width-thin: 1px; --border-width-thin: 1px;
--border-width-medium: 2px; --border-width-medium: 2px;
--border-width-thick: 4px; --border-width-thick: 4px;
--border-radius-sm: 4px; --border-radius-sm: 10px;
--border-radius-md: 6px; --border-radius-md: 14px;
--border-radius-lg: 8px; --border-radius-lg: 20px;
--border-radius-xl: 12px; --border-radius-xl: 28px;
--border-radius-full: 50%; --border-radius-full: 999px;
/* ============================================ /* ============================================
SHADOWS SHADOWS
============================================ */ ============================================ */
--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --shadow-sm: 0 8px 20px rgba(36, 33, 28, 0.06);
--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1); --shadow-md: 0 16px 34px rgba(36, 33, 28, 0.1);
--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1); --shadow-lg: 0 24px 56px rgba(36, 33, 28, 0.14);
--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1); --shadow-xl: 0 32px 80px rgba(36, 33, 28, 0.18);
--shadow-card: 0 0 10px rgba(0, 0, 0, 0.08); --shadow-card: 0 14px 36px rgba(36, 33, 28, 0.09);
/* ============================================ /* ============================================
TRANSITIONS TRANSITIONS
============================================ */ ============================================ */
--transition-fast: 0.15s ease; --transition-fast: 0.15s ease;
--transition-base: 0.2s ease; --transition-base: 0.24s ease;
--transition-slow: 0.3s ease; --transition-slow: 0.35s ease;
/* ============================================ /* ============================================
Z-INDEX LAYERS Z-INDEX LAYERS
============================================ */ ============================================ */
@ -150,52 +154,50 @@
--z-modal-backdrop: 900; --z-modal-backdrop: 900;
--z-modal: 1000; --z-modal: 1000;
--z-tooltip: 1100; --z-tooltip: 1100;
/* ============================================ /* ============================================
LAYOUT LAYOUT
============================================ */ ============================================ */
--container-max-width: 480px; --container-max-width: 560px;
--page-max-width: 1180px;
--container-padding: var(--spacing-md); --container-padding: var(--spacing-md);
/* ============================================ /* ============================================
COMPONENT-SPECIFIC COMPONENT-SPECIFIC
============================================ */ ============================================ */
--button-padding-y: 0.8rem;
/* Buttons */ --button-padding-x: 1.25rem;
--button-padding-y: 0.6rem; --button-border-radius: var(--border-radius-full);
--button-padding-x: 1.5rem; --button-font-weight: var(--font-weight-semibold);
--button-border-radius: var(--border-radius-sm);
--button-font-weight: var(--font-weight-medium); --input-padding-y: 0.85rem;
--input-padding-x: 1rem;
/* Inputs */ --input-border-color: var(--color-border-light);
--input-padding-y: 0.6rem; --input-border-radius: var(--border-radius-md);
--input-padding-x: 0.75rem;
--input-border-color: var(--color-border-medium);
--input-border-radius: var(--border-radius-sm);
--input-focus-border-color: var(--color-primary); --input-focus-border-color: var(--color-primary);
--input-focus-shadow: 0 0 0 2px rgba(0, 123, 255, 0.1); --input-focus-shadow: 0 0 0 4px rgba(15, 118, 110, 0.12);
/* Cards */
--card-bg: var(--color-bg-surface); --card-bg: var(--color-bg-surface);
--card-padding: var(--spacing-md); --card-padding: var(--spacing-lg);
--card-border-radius: var(--border-radius-lg); --card-border-radius: var(--border-radius-lg);
--card-shadow: var(--shadow-card); --card-shadow: var(--shadow-card);
/* Modals */ --modal-backdrop-bg: rgba(15, 23, 42, 0.48);
--modal-backdrop-bg: rgba(0, 0, 0, 0.5); --modal-bg: var(--color-bg-elevated);
--modal-bg: var(--color-white);
--modal-border-radius: var(--border-radius-lg); --modal-border-radius: var(--border-radius-lg);
--modal-padding: var(--spacing-lg); --modal-padding: var(--spacing-lg);
--modal-max-width: 500px; --modal-max-width: 500px;
/* ============================================ /* ============================================
SIMPLIFIED ALIASES (for component convenience) SIMPLIFIED ALIASES
============================================ */ ============================================ */
--primary: var(--color-primary); --primary: var(--color-primary);
--primary-dark: var(--color-primary-dark); --primary-dark: var(--color-primary-dark);
--primary-light: var(--color-primary-light); --primary-light: var(--color-primary-light);
--danger: var(--color-danger); --danger: var(--color-danger);
--danger-dark: var(--color-danger-hover); --danger-dark: var(--color-danger-hover);
--success: var(--color-success);
--success-light: var(--color-success-light);
--text-primary: var(--color-text-primary); --text-primary: var(--color-text-primary);
--text-secondary: var(--color-text-secondary); --text-secondary: var(--color-text-secondary);
--background: var(--color-bg-body); --background: var(--color-bg-body);
@ -203,108 +205,92 @@
--card-hover: var(--color-bg-hover); --card-hover: var(--color-bg-hover);
} }
/* ============================================
DARK MODE
============================================ */
[data-theme="dark"] { [data-theme="dark"] {
/* Primary Colors */ --color-primary: #5fb2ff;
--color-primary: #4da3ff; --color-primary-hover: #83c4ff;
--color-primary-hover: #66b3ff; --color-primary-light: rgba(95, 178, 255, 0.14);
--color-primary-light: #1a3a52; --color-primary-dark: #2d8ff0;
--color-primary-dark: #3d8fdb;
--color-secondary: #f4c27a;
--color-secondary-hover: #ffd59e;
--color-secondary-light: rgba(244, 194, 122, 0.12);
--color-accent: #fbbf24;
--color-accent-light: rgba(251, 191, 36, 0.16);
/* Semantic Colors */
--color-success: #4ade80; --color-success: #4ade80;
--color-success-hover: #5fe88d; --color-success-hover: #86efac;
--color-success-light: #1a3a28; --color-success-light: rgba(74, 222, 128, 0.16);
--color-danger: #f87171; --color-danger: #f87171;
--color-danger-hover: #fa8585; --color-danger-hover: #fca5a5;
--color-danger-light: #4a2020; --color-danger-light: rgba(248, 113, 113, 0.16);
--color-warning: #fbbf24; --color-warning: #fbbf24;
--color-warning-hover: #fcd34d; --color-warning-hover: #fcd34d;
--color-warning-light: #3a2f0f; --color-warning-light: rgba(251, 191, 36, 0.16);
--color-info: #38bdf8; --color-info: #38bdf8;
--color-info-hover: #5dc9fc; --color-info-hover: #7dd3fc;
--color-info-light: #1a2f3a; --color-info-light: rgba(56, 189, 248, 0.16);
/* Text Colors */ --color-text-primary: #f4f7fb;
--color-text-primary: #f1f5f9; --color-text-secondary: #b2bccb;
--color-text-secondary: #94a3b8; --color-text-muted: #7f8aa0;
--color-text-muted: #64748b; --color-text-inverse: #0f172a;
--color-text-inverse: #1e293b; --color-text-disabled: #667085;
--color-text-disabled: #475569;
/* Background Colors */ --color-bg-body: #0f1722;
--color-bg-body: #0f172a; --color-bg-surface: rgba(15, 23, 34, 0.84);
--color-bg-surface: #1e293b; --color-bg-elevated: rgba(20, 29, 42, 0.96);
--color-bg-hover: #334155; --color-bg-hover: rgba(30, 41, 59, 0.95);
--color-bg-disabled: #1e293b; --color-bg-disabled: rgba(30, 41, 59, 0.7);
--color-bg-hero: linear-gradient(135deg, rgba(45, 212, 191, 0.18), rgba(251, 191, 36, 0.16));
/* Border Colors */ --color-border-light: rgba(148, 163, 184, 0.18);
--color-border-light: #334155; --color-border-medium: rgba(148, 163, 184, 0.32);
--color-border-medium: #475569; --color-border-dark: rgba(203, 213, 225, 0.48);
--color-border-dark: #64748b; --color-border-disabled: rgba(100, 116, 139, 0.3);
--color-border-disabled: #334155;
/* Neutral Colors - Dark adjusted */ --color-gray-50: #111827;
--color-gray-50: #1e293b; --color-gray-100: #172030;
--color-gray-100: #1e293b; --color-gray-200: #1f2937;
--color-gray-200: #334155; --color-gray-300: #334155;
--color-gray-300: #475569; --color-gray-400: #475569;
--color-gray-400: #64748b; --color-gray-500: #64748b;
--color-gray-500: #94a3b8; --color-gray-600: #94a3b8;
--color-gray-600: #cbd5e1; --color-gray-700: #cbd5e1;
--color-gray-700: #e2e8f0; --color-gray-800: #e2e8f0;
--color-gray-800: #f1f5f9;
--color-gray-900: #f8fafc; --color-gray-900: #f8fafc;
/* Shadows - Lighter for dark mode */ --shadow-sm: 0 10px 24px rgba(2, 6, 23, 0.24);
--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3); --shadow-md: 0 18px 40px rgba(2, 6, 23, 0.34);
--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4); --shadow-lg: 0 28px 60px rgba(2, 6, 23, 0.42);
--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5); --shadow-xl: 0 42px 90px rgba(2, 6, 23, 0.5);
--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.6); --shadow-card: 0 18px 44px rgba(2, 6, 23, 0.34);
--shadow-card: 0 0 10px rgba(0, 0, 0, 0.5);
/* Modals */ --modal-backdrop-bg: rgba(2, 6, 23, 0.72);
--modal-backdrop-bg: rgba(0, 0, 0, 0.8); --modal-bg: var(--color-bg-elevated);
--modal-bg: var(--color-bg-surface); --input-focus-shadow: 0 0 0 4px rgba(45, 212, 191, 0.18);
/* Inputs */
--input-border-color: var(--color-border-medium);
--input-focus-shadow: 0 0 0 2px rgba(77, 163, 255, 0.3);
/* Cards */
--card-bg: var(--color-bg-surface); --card-bg: var(--color-bg-surface);
} }
/* ============================================
DARK MODE SUPPORT (Future Implementation)
============================================ */
@media (prefers-color-scheme: dark) { @media (prefers-color-scheme: dark) {
/* Auto mode will use data-theme attribute set by JS */ /* Auto mode will use data-theme attribute set by JS */
} }
/* Manual dark mode class override (deprecated - use data-theme) */
.dark-mode { .dark-mode {
--color-text-primary: #f8f9fa; --color-text-primary: #f4f7fb;
--color-text-secondary: #adb5bd; --color-text-secondary: #b2bccb;
--color-bg-body: #212529; --color-bg-body: #0f1722;
--color-bg-surface: #343a40; --color-bg-surface: rgba(15, 23, 34, 0.84);
--color-border-light: #495057; --color-border-light: rgba(148, 163, 184, 0.18);
--color-border-medium: #6c757d; --color-border-medium: rgba(148, 163, 184, 0.32);
} }
/* ============================================ /* ============================================
UTILITY CLASSES UTILITY CLASSES
============================================ */ ============================================ */
/* Spacing Utilities */
.m-0 { margin: 0 !important; } .m-0 { margin: 0 !important; }
.mt-1 { margin-top: var(--spacing-xs) !important; } .mt-1 { margin-top: var(--spacing-xs) !important; }
.mt-2 { margin-top: var(--spacing-sm) !important; } .mt-2 { margin-top: var(--spacing-sm) !important; }
@ -322,7 +308,6 @@
.p-3 { padding: var(--spacing-md) !important; } .p-3 { padding: var(--spacing-md) !important; }
.p-4 { padding: var(--spacing-lg) !important; } .p-4 { padding: var(--spacing-lg) !important; }
/* Text Utilities */
.text-center { text-align: center !important; } .text-center { text-align: center !important; }
.text-left { text-align: left !important; } .text-left { text-align: left !important; }
.text-right { text-align: right !important; } .text-right { text-align: right !important; }
@ -338,13 +323,11 @@
.font-weight-semibold { font-weight: var(--font-weight-semibold) !important; } .font-weight-semibold { font-weight: var(--font-weight-semibold) !important; }
.font-weight-bold { font-weight: var(--font-weight-bold) !important; } .font-weight-bold { font-weight: var(--font-weight-bold) !important; }
/* Display Utilities */
.d-none { display: none !important; } .d-none { display: none !important; }
.d-block { display: block !important; } .d-block { display: block !important; }
.d-flex { display: flex !important; } .d-flex { display: flex !important; }
.d-inline-block { display: inline-block !important; } .d-inline-block { display: inline-block !important; }
/* Flex Utilities */
.flex-column { flex-direction: column !important; } .flex-column { flex-direction: column !important; }
.flex-row { flex-direction: row !important; } .flex-row { flex-direction: row !important; }
.justify-center { justify-content: center !important; } .justify-center { justify-content: center !important; }

View File

@ -61,17 +61,21 @@
============================================ */ ============================================ */
.card { .card {
background: var(--color-bg-surface); background: var(--card-bg);
border: 1px solid var(--color-border-light);
border-radius: var(--card-border-radius); border-radius: var(--card-border-radius);
padding: var(--card-padding); padding: var(--card-padding);
box-shadow: var(--shadow-card); box-shadow: var(--shadow-card);
backdrop-filter: blur(14px);
} }
.card-elevated { .card-elevated {
background: var(--color-bg-surface); background: var(--color-bg-elevated);
border-radius: var(--card-border-radius); border: 1px solid var(--color-border-light);
padding: var(--spacing-lg); border-radius: var(--border-radius-xl);
box-shadow: var(--shadow-lg); padding: clamp(1.5rem, 3vw, 2.25rem);
box-shadow: var(--shadow-xl);
backdrop-filter: blur(18px);
} }
.card-title { .card-title {
@ -87,67 +91,76 @@
.btn { .btn {
padding: var(--button-padding-y) var(--button-padding-x); padding: var(--button-padding-y) var(--button-padding-x);
border: none; border: 1px solid transparent;
border-radius: var(--button-border-radius); border-radius: var(--button-border-radius);
font-size: var(--font-size-base); font-size: var(--font-size-base);
font-weight: var(--button-font-weight); font-weight: var(--button-font-weight);
cursor: pointer; cursor: pointer;
transition: var(--transition-base); transition: transform var(--transition-base), box-shadow var(--transition-base), background var(--transition-base), color var(--transition-base), border-color var(--transition-base);
text-align: center; text-align: center;
display: inline-block; display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.45rem;
min-height: 46px;
} }
.btn-primary { .btn-primary {
background: var(--color-primary); background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
color: var(--color-text-inverse); color: var(--color-text-inverse);
box-shadow: 0 14px 30px rgba(15, 118, 110, 0.18);
} }
.btn-primary:hover:not(:disabled) { .btn-primary:hover:not(:disabled) {
background: var(--color-primary-hover); transform: translateY(-2px);
transform: translateY(-1px); box-shadow: 0 18px 34px rgba(15, 118, 110, 0.24);
box-shadow: var(--shadow-md);
} }
.btn-secondary { .btn-secondary {
background: var(--color-primary); background: rgba(255, 255, 255, 0.72);
color: var(--color-text-inverse); color: var(--color-text-primary);
border-color: var(--color-border-light);
} }
.btn-secondary:hover:not(:disabled) { .btn-secondary:hover:not(:disabled) {
background: var(--color-primary-hover); background: var(--color-bg-hover);
border-color: var(--color-border-medium);
transform: translateY(-1px);
} }
.btn-danger { .btn-danger {
background: var(--color-danger); background: linear-gradient(135deg, var(--color-danger), var(--color-danger-hover));
color: var(--color-text-inverse); color: var(--color-text-inverse);
} }
.btn-danger:hover:not(:disabled) { .btn-danger:hover:not(:disabled) {
background: var(--color-danger-hover); transform: translateY(-1px);
box-shadow: 0 16px 30px rgba(220, 38, 38, 0.18);
} }
.btn-success { .btn-success {
background: var(--color-success); background: linear-gradient(135deg, var(--color-success), var(--color-success-hover));
color: var(--color-text-inverse); color: var(--color-text-inverse);
} }
.btn-success:hover:not(:disabled) { .btn-success:hover:not(:disabled) {
background: var(--color-success-hover); transform: translateY(-1px);
box-shadow: 0 16px 30px rgba(21, 128, 61, 0.18);
} }
.btn-outline { .btn-outline {
background: transparent; background: rgba(255, 255, 255, 0.28);
color: var(--color-primary); color: var(--color-primary);
border: var(--border-width-thin) solid var(--color-primary); border: var(--border-width-thin) solid var(--color-primary);
} }
.btn-outline:hover:not(:disabled) { .btn-outline:hover:not(:disabled) {
background: var(--color-primary); background: var(--color-primary-light);
color: var(--color-text-inverse); transform: translateY(-1px);
} }
.btn-ghost { .btn-ghost {
background: var(--color-bg-surface); background: rgba(255, 255, 255, 0.62);
color: var(--color-text-primary); color: var(--color-text-primary);
border: var(--border-width-thin) solid var(--color-border-medium); border: var(--border-width-thin) solid var(--color-border-medium);
} }
@ -175,6 +188,8 @@
.btn:disabled { .btn:disabled {
opacity: 0.6; opacity: 0.6;
cursor: not-allowed; cursor: not-allowed;
box-shadow: none;
transform: none;
} }
/* ============================================ /* ============================================
@ -200,8 +215,8 @@
border-radius: var(--input-border-radius); border-radius: var(--input-border-radius);
font-size: var(--font-size-base); font-size: var(--font-size-base);
color: var(--color-text-primary); color: var(--color-text-primary);
background: var(--color-bg-surface); background: rgba(255, 255, 255, 0.72);
transition: var(--transition-base); transition: border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base), transform var(--transition-base);
box-sizing: border-box; box-sizing: border-box;
} }
@ -209,6 +224,8 @@
outline: none; outline: none;
border-color: var(--input-focus-border-color); border-color: var(--input-focus-border-color);
box-shadow: var(--input-focus-shadow); box-shadow: var(--input-focus-shadow);
background: var(--color-bg-elevated);
transform: translateY(-1px);
} }
.form-input::placeholder { .form-input::placeholder {
@ -222,7 +239,7 @@
border-radius: var(--input-border-radius); border-radius: var(--input-border-radius);
font-size: var(--font-size-base); font-size: var(--font-size-base);
color: var(--color-text-primary); color: var(--color-text-primary);
background: var(--color-bg-surface); background: rgba(255, 255, 255, 0.72);
cursor: pointer; cursor: pointer;
transition: var(--transition-base); transition: var(--transition-base);
} }
@ -231,6 +248,7 @@
outline: none; outline: none;
border-color: var(--input-focus-border-color); border-color: var(--input-focus-border-color);
box-shadow: var(--input-focus-shadow); box-shadow: var(--input-focus-shadow);
background: var(--color-bg-elevated);
} }
/* ============================================ /* ============================================