ui styling fixed

This commit is contained in:
Auto
2025-12-30 13:29:38 +02:00
parent a2efec159d
commit 38b1c03c23

View File

@@ -33,213 +33,256 @@
--transition-neo-normal: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); --transition-neo-normal: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
} }
/* Base styles */ /* ============================================================================
body { Base Layer - Foundation styles
font-family: var(--font-neo-sans); ============================================================================ */
background-color: var(--color-neo-bg);
color: var(--color-neo-text); @layer base {
/* Ensure CSS variables are available globally */
:root {
--color-neo-bg: #fffef5;
--color-neo-card: #ffffff;
--color-neo-pending: #ffd60a;
--color-neo-progress: #00b4d8;
--color-neo-done: #70e000;
--color-neo-accent: #ff006e;
--color-neo-danger: #ff5400;
--color-neo-border: #1a1a1a;
--color-neo-text: #1a1a1a;
--color-neo-text-secondary: #4a4a4a;
--font-neo-display: 'Space Grotesk', sans-serif;
--font-neo-sans: 'DM Sans', sans-serif;
--font-neo-mono: 'JetBrains Mono', monospace;
--shadow-neo-sm: 2px 2px 0px rgba(0, 0, 0, 1);
--shadow-neo-md: 4px 4px 0px rgba(0, 0, 0, 1);
--shadow-neo-lg: 6px 6px 0px rgba(0, 0, 0, 1);
--shadow-neo-xl: 8px 8px 0px rgba(0, 0, 0, 1);
}
body {
font-family: var(--font-neo-sans);
background-color: var(--color-neo-bg);
color: var(--color-neo-text);
}
/* Force form elements to inherit colors properly */
button,
input,
textarea,
select {
color: inherit;
font-family: inherit;
}
} }
/* ============================================================================ /* ============================================================================
Component Classes Component Layer - Reusable component styles
============================================================================ */ ============================================================================ */
/* Cards */ @layer components {
.neo-card { /* Cards */
background: var(--color-neo-card); .neo-card {
border: 3px solid var(--color-neo-border); background: var(--color-neo-card);
box-shadow: var(--shadow-neo-md); border: 3px solid var(--color-neo-border);
transition: transform var(--transition-neo-fast), box-shadow var(--transition-neo-fast); box-shadow: var(--shadow-neo-md);
} transition: transform var(--transition-neo-fast), box-shadow var(--transition-neo-fast);
}
.neo-card:hover { .neo-card:hover {
transform: translate(-2px, -2px); transform: translate(-2px, -2px);
box-shadow: var(--shadow-neo-lg); box-shadow: var(--shadow-neo-lg);
} }
/* Buttons */ /* Buttons */
.neo-btn { .neo-btn {
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
gap: 0.5rem; gap: 0.5rem;
padding: 0.75rem 1.5rem; padding: 0.75rem 1.5rem;
font-family: var(--font-neo-display); font-family: var(--font-neo-display);
font-weight: 700; font-weight: 700;
text-transform: uppercase; font-size: 0.875rem;
letter-spacing: 0.025em; text-transform: uppercase;
color: var(--color-neo-text); letter-spacing: 0.025em;
background: white; color: #1a1a1a;
border: 3px solid var(--color-neo-border); background-color: #ffffff;
box-shadow: var(--shadow-neo-md); border: 3px solid #1a1a1a;
transition: transform var(--transition-neo-fast), box-shadow var(--transition-neo-fast); box-shadow: var(--shadow-neo-md);
cursor: pointer; transition: transform var(--transition-neo-fast), box-shadow var(--transition-neo-fast);
} cursor: pointer;
}
.neo-btn:hover { .neo-btn:hover {
transform: translate(-2px, -2px); transform: translate(-2px, -2px);
box-shadow: var(--shadow-neo-lg); box-shadow: var(--shadow-neo-lg);
} }
.neo-btn:active { .neo-btn:active {
transform: translate(2px, 2px); transform: translate(2px, 2px);
box-shadow: var(--shadow-neo-sm); box-shadow: var(--shadow-neo-sm);
} }
.neo-btn:disabled { .neo-btn:disabled {
opacity: 0.5; opacity: 0.5;
cursor: not-allowed; cursor: not-allowed;
transform: none; transform: none;
box-shadow: var(--shadow-neo-sm); box-shadow: var(--shadow-neo-sm);
} }
.neo-btn-primary { .neo-btn-primary {
background: var(--color-neo-accent); background-color: #ff006e;
color: white; color: #ffffff;
} }
.neo-btn-success { .neo-btn-success {
background: var(--color-neo-done); background-color: #70e000;
color: var(--color-neo-text); color: #1a1a1a;
} }
.neo-btn-warning { .neo-btn-warning {
background: var(--color-neo-pending); background-color: #ffd60a;
color: var(--color-neo-text); color: #1a1a1a;
} }
.neo-btn-danger { .neo-btn-danger {
background: var(--color-neo-danger); background-color: #ff5400;
color: white; color: #ffffff;
} }
.neo-btn-ghost { .neo-btn-ghost {
background: transparent; background-color: transparent;
color: var(--color-neo-text); color: #1a1a1a;
box-shadow: none; box-shadow: none;
} }
.neo-btn-ghost:hover { .neo-btn-ghost:hover {
background: rgba(0, 0, 0, 0.05); background-color: rgba(0, 0, 0, 0.05);
color: var(--color-neo-text); color: #1a1a1a;
box-shadow: none; box-shadow: none;
transform: none; transform: none;
} }
/* Inputs */ /* Inputs */
.neo-input { .neo-input {
width: 100%; width: 100%;
padding: 0.75rem 1rem; padding: 0.75rem 1rem;
font-family: var(--font-neo-sans); font-family: var(--font-neo-sans);
font-size: 1rem; font-size: 1rem;
color: var(--color-neo-text); color: #1a1a1a;
background: white; background-color: #ffffff;
border: 3px solid var(--color-neo-border); border: 3px solid #1a1a1a;
box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1); box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
transition: transform var(--transition-neo-fast), box-shadow var(--transition-neo-fast); transition: transform var(--transition-neo-fast), box-shadow var(--transition-neo-fast);
} }
.neo-input::placeholder { .neo-input::placeholder {
color: var(--color-neo-text-secondary); color: #4a4a4a;
opacity: 0.7; opacity: 0.7;
} }
.neo-input:focus { .neo-input:focus {
outline: none; outline: none;
transform: translate(-1px, -1px); transform: translate(-1px, -1px);
box-shadow: var(--shadow-neo-md); box-shadow: var(--shadow-neo-md);
border-color: var(--color-neo-accent); border-color: #ff006e;
} }
/* Badge */ /* Badge */
.neo-badge { .neo-badge {
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
padding: 0.25rem 0.75rem; padding: 0.25rem 0.75rem;
font-family: var(--font-neo-display); font-family: var(--font-neo-display);
font-size: 0.75rem; font-size: 0.75rem;
font-weight: 700; font-weight: 700;
text-transform: uppercase; text-transform: uppercase;
color: var(--color-neo-text); color: #1a1a1a;
border: 2px solid var(--color-neo-border); border: 2px solid #1a1a1a;
} }
/* Progress Bar */ /* Progress Bar */
.neo-progress { .neo-progress {
width: 100%; width: 100%;
height: 2rem; height: 2rem;
background: white; background-color: #ffffff;
border: 3px solid var(--color-neo-border); border: 3px solid #1a1a1a;
box-shadow: var(--shadow-neo-sm); box-shadow: var(--shadow-neo-sm);
overflow: hidden; overflow: hidden;
} }
.neo-progress-fill { .neo-progress-fill {
height: 100%; height: 100%;
background: var(--color-neo-done); background-color: #70e000;
transition: width 0.5s ease-out; transition: width 0.5s ease-out;
} }
/* Modal */ /* Modal */
.neo-modal-backdrop { .neo-modal-backdrop {
position: fixed; position: fixed;
inset: 0; inset: 0;
background: rgba(0, 0, 0, 0.4); background: rgba(0, 0, 0, 0.4);
backdrop-filter: blur(2px); backdrop-filter: blur(2px);
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
z-index: 50; z-index: 50;
} }
.neo-modal { .neo-modal {
background: white; background-color: #ffffff;
border: 4px solid var(--color-neo-border); border: 4px solid #1a1a1a;
box-shadow: var(--shadow-neo-xl); box-shadow: var(--shadow-neo-xl);
animation: popIn 0.3s var(--transition-neo-fast); animation: popIn 0.3s var(--transition-neo-fast);
max-width: 90vw; max-width: 90vw;
max-height: 90vh; max-height: 90vh;
overflow: auto; overflow: auto;
} }
/* Dropdown */ /* Dropdown */
.neo-dropdown { .neo-dropdown {
background: white; background-color: #ffffff;
border: 3px solid var(--color-neo-border); border: 3px solid #1a1a1a;
box-shadow: var(--shadow-neo-lg); box-shadow: var(--shadow-neo-lg);
} }
.neo-dropdown-item { .neo-dropdown-item {
padding: 0.75rem 1rem; display: block;
cursor: pointer; width: 100%;
color: var(--color-neo-text); padding: 0.75rem 1rem;
background: transparent; cursor: pointer;
transition: background var(--transition-neo-fast), color var(--transition-neo-fast); color: #1a1a1a;
} background-color: transparent;
text-align: left;
border: none;
font-size: 0.875rem;
transition: background-color var(--transition-neo-fast);
}
.neo-dropdown-item:hover { .neo-dropdown-item:hover {
background: var(--color-neo-pending); background-color: #ffd60a;
color: var(--color-neo-text); color: #1a1a1a;
} }
/* Tooltip */ /* Tooltip */
.neo-tooltip { .neo-tooltip {
background: var(--color-neo-text); background-color: #1a1a1a;
color: white; color: #ffffff;
padding: 0.5rem 0.75rem; padding: 0.5rem 0.75rem;
font-size: 0.75rem; font-size: 0.75rem;
font-weight: 700; font-weight: 700;
text-transform: uppercase; text-transform: uppercase;
border: 2px solid var(--color-neo-border); border: 2px solid #1a1a1a;
box-shadow: var(--shadow-neo-sm); box-shadow: var(--shadow-neo-sm);
} }
/* Empty State */ /* Empty State */
.neo-empty-state { .neo-empty-state {
background: var(--color-neo-bg); background-color: var(--color-neo-bg);
border: 4px dashed var(--color-neo-border); border: 4px dashed #1a1a1a;
padding: 2rem; padding: 2rem;
text-align: center; text-align: center;
}
} }
/* ============================================================================ /* ============================================================================
@@ -289,54 +332,59 @@ body {
} }
} }
.animate-slide-in { /* ============================================================================
animation: slideIn 0.3s ease-out; Utilities Layer
} ============================================================================ */
.animate-pop-in { @layer utilities {
animation: popIn 0.3s var(--transition-neo-fast); .animate-slide-in {
} animation: slideIn 0.3s ease-out;
}
.animate-pulse-neo { .animate-pop-in {
animation: neoPulse 2s infinite; animation: popIn 0.3s var(--transition-neo-fast);
} }
.animate-complete { .animate-pulse-neo {
animation: completePop 0.5s var(--transition-neo-fast); animation: neoPulse 2s infinite;
}
.animate-complete {
animation: completePop 0.5s var(--transition-neo-fast);
}
.font-display {
font-family: var(--font-neo-display);
}
.font-sans {
font-family: var(--font-neo-sans);
}
.font-mono {
font-family: var(--font-neo-mono);
}
} }
/* ============================================================================ /* ============================================================================
Utilities Scrollbar Styling (outside layers for broad compatibility)
============================================================================ */ ============================================================================ */
.font-display {
font-family: var(--font-neo-display);
}
.font-sans {
font-family: var(--font-neo-sans);
}
.font-mono {
font-family: var(--font-neo-mono);
}
/* Scrollbar styling */
::-webkit-scrollbar { ::-webkit-scrollbar {
width: 12px; width: 12px;
height: 12px; height: 12px;
} }
::-webkit-scrollbar-track { ::-webkit-scrollbar-track {
background: var(--color-neo-bg); background: #fffef5;
border: 2px solid var(--color-neo-border); border: 2px solid #1a1a1a;
} }
::-webkit-scrollbar-thumb { ::-webkit-scrollbar-thumb {
background: var(--color-neo-border); background: #1a1a1a;
border: 2px solid var(--color-neo-border); border: 2px solid #1a1a1a;
} }
::-webkit-scrollbar-thumb:hover { ::-webkit-scrollbar-thumb:hover {
background: var(--color-neo-text-secondary); background: #4a4a4a;
} }