450 lines
13 KiB
CSS
450 lines
13 KiB
CSS
|
|
:root {
|
|
--color-white: #FFFFFF;
|
|
--color-black: #000000;
|
|
|
|
--color-primary: #22C55E;
|
|
--color-primary-dark: #16A34A;
|
|
--color-primary-light: #86EFAC;
|
|
--color-primary-bright: #4ADE80;
|
|
--color-primary-border: #15803D;
|
|
|
|
--color-aqua: #06B6D4;
|
|
--color-aqua-dark: #0E7490;
|
|
--color-aqua-light: #67E8F9;
|
|
|
|
--color-sky: #7DD3FC;
|
|
--color-sky-light: #BAE6FD;
|
|
|
|
--color-white-glass: rgba(255, 255, 255, 0.75);
|
|
--color-surface: rgba(255, 255, 255, 0.85);
|
|
--color-border-glass: rgba(255, 255, 255, 0.8);
|
|
|
|
--color-text: #1E293B;
|
|
--color-text-secondary: #64748B;
|
|
|
|
--color-bg-start: #E0F2FE;
|
|
--color-bg-mid: #DCFCE7;
|
|
|
|
--color-error: #EF4444;
|
|
--color-error-dark: #DC2626;
|
|
--color-error-border: #B91C1C;
|
|
|
|
--color-success: #22C55E;
|
|
--color-success-text: #166534;
|
|
|
|
--color-warning: #F59E0B;
|
|
--color-warning-text: #92400E;
|
|
--color-warning-border: #FDE68A;
|
|
|
|
--color-brown-dark: #78350F;
|
|
--color-danger-text: #991B1B;
|
|
--color-danger-light: #FCA5A5;
|
|
--color-danger-pale: #FECACA;
|
|
--color-info-text: #1E40AF;
|
|
--color-info-border: #93C5FD;
|
|
|
|
--color-orange: #FB923C;
|
|
--color-orange-deep: #EA580C;
|
|
--color-orange-dark: #C2410C;
|
|
--color-yellow: #FCD34D;
|
|
|
|
--color-purple: #A78BFA;
|
|
--color-purple-light: #C4B5FD;
|
|
--color-purple-dark: #6D28D9;
|
|
|
|
--color-gray-400: #9CA3AF;
|
|
--color-star: #FBBF24;
|
|
|
|
--color-white-a10: rgba(255,255,255,0.1);
|
|
--color-white-a30: rgba(255,255,255,0.3);
|
|
--color-white-a40: rgba(255,255,255,0.4);
|
|
--color-white-a50: rgba(255,255,255,0.5);
|
|
--color-white-a60: rgba(255,255,255,0.6);
|
|
--color-white-a70: rgba(255,255,255,0.7);
|
|
--color-white-a72: rgba(255,255,255,0.72);
|
|
--color-white-a80: rgba(255,255,255,0.8);
|
|
--color-white-a82: rgba(255,255,255,0.82);
|
|
--color-white-a86: rgba(255,255,255,0.86);
|
|
--color-white-a90: rgba(255,255,255,0.9);
|
|
--color-white-a96: rgba(255,255,255,0.96);
|
|
|
|
--color-black-a04: rgba(0,0,0,0.04);
|
|
--color-black-a05: rgba(0,0,0,0.05);
|
|
--color-black-a06: rgba(0,0,0,0.06);
|
|
--color-black-a08: rgba(0,0,0,0.08);
|
|
--color-black-a12: rgba(0,0,0,0.12);
|
|
--color-black-a15: rgba(0,0,0,0.15);
|
|
--color-black-a20: rgba(0,0,0,0.2);
|
|
--color-black-a35: rgba(0,0,0,0.35);
|
|
|
|
--color-slate-900-a08: rgba(15,23,42,0.08);
|
|
--color-slate-900-a14: rgba(15,23,42,0.14);
|
|
--color-slate-500-a10: rgba(100,116,139,0.1);
|
|
--color-slate-500-a20: rgba(100,116,139,0.2);
|
|
|
|
--color-primary-a05: rgba(34,197,94,0.05);
|
|
--color-primary-a08: rgba(34,197,94,0.08);
|
|
--color-primary-a10: rgba(34,197,94,0.1);
|
|
--color-primary-a12: rgba(34,197,94,0.12);
|
|
--color-primary-a15: rgba(34,197,94,0.15);
|
|
--color-primary-a18: rgba(34,197,94,0.18);
|
|
--color-primary-a20: rgba(34,197,94,0.2);
|
|
--color-primary-a25: rgba(34,197,94,0.25);
|
|
--color-primary-a30: rgba(34,197,94,0.3);
|
|
--color-primary-a40: rgba(34,197,94,0.4);
|
|
--color-primary-a45: rgba(34,197,94,0.45);
|
|
--color-primary-a50: rgba(34,197,94,0.5);
|
|
--color-primary-light-a12: rgba(134,239,172,0.12);
|
|
|
|
--color-error-a10: rgba(239,68,68,0.1);
|
|
--color-error-a12: rgba(239,68,68,0.12);
|
|
--color-error-a20: rgba(239,68,68,0.2);
|
|
--color-error-a24: rgba(239,68,68,0.24);
|
|
--color-error-a30: rgba(239,68,68,0.3);
|
|
--color-error-a40: rgba(239,68,68,0.4);
|
|
|
|
--color-aqua-a15: rgba(6,182,212,0.15);
|
|
--color-aqua-a30: rgba(6,182,212,0.3);
|
|
--color-orange-a15: rgba(251,146,60,0.15);
|
|
--color-orange-a30: rgba(251,146,60,0.3);
|
|
--color-purple-a12: rgba(139,92,246,0.12);
|
|
--color-purple-a20: rgba(139,92,246,0.2);
|
|
--color-star-a15: rgba(251,191,36,0.15);
|
|
--color-star-a20: rgba(251,191,36,0.2);
|
|
--color-star-a30: rgba(251,191,36,0.3);
|
|
--color-warning-a15: rgba(245,158,11,0.15);
|
|
--color-warning-a25: rgba(245,158,11,0.25);
|
|
--color-warning-a40: rgba(245,158,11,0.4);
|
|
|
|
--color-success-bg-a90: rgba(220,252,231,0.9);
|
|
--color-success-bg-a95: rgba(220,252,231,0.95);
|
|
--color-info-bg-a90: rgba(224,242,254,0.9);
|
|
--color-info-bg-a95: rgba(224,242,254,0.95);
|
|
--color-danger-bg-a68: rgba(254,242,242,0.68);
|
|
--color-danger-bg-a90: rgba(254,226,226,0.9);
|
|
--color-danger-bg-a95: rgba(254,226,226,0.95);
|
|
--color-warning-bg-a90: rgba(254,243,199,0.9);
|
|
|
|
--gradient-bg: linear-gradient(135deg, var(--color-bg-start) 0%, var(--color-bg-mid) 50%, var(--color-bg-start) 100%);
|
|
--gradient-brand: linear-gradient(135deg, var(--color-primary) 0%, var(--color-aqua) 60%, var(--color-sky) 100%);
|
|
--gradient-progress-success: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
|
|
--gradient-progress-neutral: linear-gradient(90deg, var(--color-sky), var(--color-sky-light));
|
|
--gradient-progress-danger: linear-gradient(90deg, var(--color-danger-light), var(--color-danger-pale));
|
|
--gradient-bar-success-vertical: linear-gradient(180deg, var(--color-primary), var(--color-primary-light));
|
|
--gradient-bar-neutral-vertical: linear-gradient(180deg, var(--color-sky), var(--color-sky-light));
|
|
--gradient-nav-active: linear-gradient(135deg, var(--color-primary-a18), var(--color-primary-light-a12));
|
|
--gradient-btn-primary: linear-gradient(180deg, var(--color-primary-bright) 0%, var(--color-primary) 50%, var(--color-primary-dark) 100%);
|
|
--gradient-btn-danger: linear-gradient(180deg, var(--color-danger-light) 0%, var(--color-error) 50%, var(--color-error-dark) 100%);
|
|
--gradient-btn-shine: linear-gradient(180deg, var(--color-white-a40) 0%, var(--color-white-a10) 100%);
|
|
--gradient-stats-green: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
|
|
--gradient-stats-aqua: linear-gradient(90deg, var(--color-aqua), var(--color-aqua-light));
|
|
--gradient-stats-orange: linear-gradient(90deg, var(--color-orange), var(--color-yellow));
|
|
--gradient-stats-purple: linear-gradient(90deg, var(--color-purple), var(--color-purple-light));
|
|
--gradient-coin-chip: linear-gradient(135deg, var(--color-star-a20), var(--color-warning-a15));
|
|
--gradient-coin-chip-hover: linear-gradient(135deg, var(--color-star-a30), var(--color-warning-a25));
|
|
|
|
--radius-sm: 8px;
|
|
--radius-md: 12px;
|
|
--radius-lg: 16px;
|
|
--shadow-glass: 0 8px 32px var(--color-black-a08), inset 0 1px 0 var(--color-white-a90);
|
|
--shadow-card: 0 4px 16px var(--color-black-a06);
|
|
--sidebar-width: 240px;
|
|
--topbar-height: 60px;
|
|
}
|
|
|
|
*, *::before, *::after {
|
|
box-sizing: border-box;
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
html, body {
|
|
height: 100%;
|
|
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
|
|
font-size: 14px;
|
|
color: var(--color-text);
|
|
-webkit-font-smoothing: antialiased;
|
|
}
|
|
|
|
body {
|
|
background: var(--gradient-bg);
|
|
background-attachment: fixed;
|
|
min-height: 100vh;
|
|
}
|
|
|
|
|
|
a {
|
|
color: var(--color-primary-dark);
|
|
text-decoration: none;
|
|
}
|
|
|
|
button {
|
|
font-family: inherit;
|
|
cursor: pointer;
|
|
border: none;
|
|
outline: none;
|
|
}
|
|
|
|
input, textarea, select {
|
|
font-family: inherit;
|
|
outline: none;
|
|
}
|
|
|
|
/* Scrollbar */
|
|
::-webkit-scrollbar { width: 6px; height: 6px; }
|
|
::-webkit-scrollbar-track { background: var(--color-black-a04); border-radius: 3px; }
|
|
::-webkit-scrollbar-thumb { background: var(--color-primary-a30); border-radius: 3px; }
|
|
::-webkit-scrollbar-thumb:hover { background: var(--color-primary-a50); }
|
|
|
|
/* Glass panel utility */
|
|
.glass-panel {
|
|
background: var(--color-white-glass);
|
|
backdrop-filter: blur(12px);
|
|
-webkit-backdrop-filter: blur(12px);
|
|
border: 1px solid var(--color-border-glass);
|
|
border-radius: var(--radius-md);
|
|
box-shadow: var(--shadow-glass);
|
|
}
|
|
|
|
/* Primary glossy button */
|
|
.btn-primary {
|
|
background: var(--gradient-btn-primary);
|
|
border: 1px solid var(--color-primary-border);
|
|
border-radius: var(--radius-sm);
|
|
color: var(--color-white);
|
|
padding: 10px 20px;
|
|
font-weight: 600;
|
|
font-size: 14px;
|
|
position: relative;
|
|
overflow: hidden;
|
|
cursor: pointer;
|
|
transition: all 0.2s;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
}
|
|
.btn-primary::before {
|
|
content: '';
|
|
position: absolute;
|
|
top: 0; left: 0; right: 0;
|
|
height: 50%;
|
|
background: var(--gradient-btn-shine);
|
|
border-radius: 8px 8px 0 0;
|
|
pointer-events: none;
|
|
}
|
|
.btn-primary:hover {
|
|
transform: translateY(-1px);
|
|
box-shadow: 0 6px 20px var(--color-primary-a40);
|
|
}
|
|
.btn-primary:active {
|
|
transform: translateY(0);
|
|
}
|
|
.btn-primary:disabled {
|
|
opacity: 0.5;
|
|
cursor: not-allowed;
|
|
transform: none;
|
|
}
|
|
|
|
.btn-sm {
|
|
padding: 6px 12px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
/* Secondary button */
|
|
.btn-secondary {
|
|
background: var(--color-white-a70);
|
|
border: 1px solid var(--color-primary-a40);
|
|
border-radius: var(--radius-sm);
|
|
color: var(--color-primary-dark);
|
|
padding: 10px 20px;
|
|
font-weight: 600;
|
|
font-size: 14px;
|
|
cursor: pointer;
|
|
transition: all 0.2s;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
backdrop-filter: blur(8px);
|
|
}
|
|
.btn-secondary:hover {
|
|
background: var(--color-primary-a10);
|
|
border-color: var(--color-primary);
|
|
}
|
|
|
|
/* Danger button */
|
|
.btn-danger {
|
|
background: var(--gradient-btn-danger);
|
|
border: 1px solid var(--color-error-border);
|
|
border-radius: var(--radius-sm);
|
|
color: var(--color-white);
|
|
padding: 10px 20px;
|
|
font-weight: 600;
|
|
font-size: 14px;
|
|
cursor: pointer;
|
|
transition: all 0.2s;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
}
|
|
.btn-danger:hover {
|
|
transform: translateY(-1px);
|
|
box-shadow: 0 6px 20px var(--color-error-a40);
|
|
}
|
|
|
|
/* Ghost button */
|
|
.btn-ghost {
|
|
background: transparent;
|
|
border: 1px solid transparent;
|
|
border-radius: var(--radius-sm);
|
|
color: var(--color-text-secondary);
|
|
padding: 8px 14px;
|
|
font-weight: 500;
|
|
font-size: 14px;
|
|
cursor: pointer;
|
|
transition: all 0.2s;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
}
|
|
.btn-ghost:hover {
|
|
background: var(--color-black-a05);
|
|
color: var(--color-text);
|
|
}
|
|
|
|
/* Glass input */
|
|
.glass-input {
|
|
background: var(--color-white-a60);
|
|
border: 1px solid var(--color-border-glass);
|
|
border-radius: var(--radius-sm);
|
|
padding: 10px 14px;
|
|
font-size: 14px;
|
|
color: var(--color-text);
|
|
width: 100%;
|
|
transition: all 0.2s;
|
|
backdrop-filter: blur(8px);
|
|
}
|
|
.glass-input:focus {
|
|
background: var(--color-surface);
|
|
border-color: var(--color-primary);
|
|
box-shadow: 0 0 0 3px var(--color-primary-a15);
|
|
}
|
|
.glass-input::placeholder {
|
|
color: var(--color-text-secondary);
|
|
}
|
|
|
|
/* Badge */
|
|
.badge {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
padding: 3px 10px;
|
|
border-radius: 20px;
|
|
font-size: 12px;
|
|
font-weight: 600;
|
|
white-space: nowrap;
|
|
}
|
|
.badge-green { color: var(--color-primary-border); border: 1.3px solid var(--color-primary-a30); }
|
|
.badge-blue { background: var(--color-aqua-a15); color: var(--color-aqua-dark); border: 1px solid var(--color-aqua-a30); }
|
|
.badge-orange { background: var(--color-orange-a15); color: var(--color-orange-dark); border: 1px solid var(--color-orange-a30); }
|
|
.badge-gray { background: var(--color-slate-500-a10); color: var(--color-text-secondary); border: 1px solid var(--color-slate-500-a20); }
|
|
.badge-red { background: var(--color-error-a12); color: var(--color-error-border); border: 1px solid var(--color-error-a20); }
|
|
.badge-purple { background: var(--color-purple-a12); color: var(--color-purple-dark); border: 1px solid var(--color-purple-a20); }
|
|
|
|
/* Tag chip */
|
|
.tag-chip {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
padding: 3px 10px;
|
|
background: var(--color-primary-a10);
|
|
border: 1px solid var(--color-primary-a25);
|
|
border-radius: 20px;
|
|
font-size: 12px;
|
|
color: var(--color-primary-dark);
|
|
font-weight: 500;
|
|
cursor: pointer;
|
|
transition: all 0.15s;
|
|
white-space: nowrap;
|
|
}
|
|
.tag-chip:hover,
|
|
.tag-chip.active {
|
|
background: var(--color-primary-a20);
|
|
border-color: var(--color-primary);
|
|
}
|
|
|
|
/* Page layout helpers */
|
|
.page-content {
|
|
padding: 24px;
|
|
max-width: 1200px;
|
|
margin: 0 auto;
|
|
}
|
|
|
|
.page-title {
|
|
font-size: 22px;
|
|
font-weight: 700;
|
|
color: var(--color-text);
|
|
margin-bottom: 20px;
|
|
}
|
|
|
|
.section-title {
|
|
font-size: 16px;
|
|
font-weight: 700;
|
|
color: var(--color-text);
|
|
margin-bottom: 14px;
|
|
}
|
|
|
|
/* Grid helpers */
|
|
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
|
|
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
|
|
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
|
|
|
|
@media (max-width: 768px) {
|
|
.grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
|
|
.page-content { padding: 16px; }
|
|
}
|
|
|
|
/* Flex helpers */
|
|
.flex { display: flex; }
|
|
.flex-col { display: flex; flex-direction: column; }
|
|
.items-center { align-items: center; }
|
|
.justify-between { justify-content: space-between; }
|
|
.gap-2 { gap: 8px; }
|
|
.gap-3 { gap: 12px; }
|
|
.gap-4 { gap: 16px; }
|
|
|
|
/* Text helpers */
|
|
.text-sm { font-size: 12px; }
|
|
.text-secondary { color: var(--color-text-secondary); }
|
|
.font-bold { font-weight: 700; }
|
|
.font-semibold { font-weight: 600; }
|
|
|
|
/* Stars rating */
|
|
.stars { color: var(--color-star); font-size: 14px; letter-spacing: 1px; }
|
|
|
|
/* Animations */
|
|
@keyframes fadeIn {
|
|
from { opacity: 0; transform: translateY(8px); }
|
|
to { opacity: 1; transform: translateY(0); }
|
|
}
|
|
.fade-in { animation: fadeIn 0.3s ease; }
|
|
|
|
@keyframes spin {
|
|
to { transform: rotate(360deg); }
|
|
}
|
|
.spinner {
|
|
width: 20px; height: 20px;
|
|
border: 2px solid var(--color-white-a30);
|
|
border-top-color: var(--color-white);
|
|
border-radius: 50%;
|
|
animation: spin 0.8s linear infinite;
|
|
display: inline-block;
|
|
}
|
|
.spinner-green {
|
|
border-color: var(--color-primary-a20);
|
|
border-top-color: var(--color-primary);
|
|
}
|
|
|
|
|
|
#app {
|
|
min-height: 100vh;
|
|
}
|