|
|
|
|
|
.glass { |
|
|
background: var(--glass-color); |
|
|
|
|
|
backdrop-filter: blur(8px); |
|
|
-webkit-backdrop-filter: blur(8px); |
|
|
border: 1px solid var(--border-color); |
|
|
box-shadow: |
|
|
0 4px 6px -1px rgba(0, 0, 0, 0.1), |
|
|
0 2px 4px -1px rgba(0, 0, 0, 0.06); |
|
|
} |
|
|
|
|
|
.glass-strong { |
|
|
background: var(--surface-color); |
|
|
|
|
|
backdrop-filter: blur(10px); |
|
|
-webkit-backdrop-filter: blur(10px); |
|
|
border: 1px solid rgba(255, 255, 255, 0.2); |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(0, 0, 0, 0.1), |
|
|
0 4px 6px -2px rgba(0, 0, 0, 0.05); |
|
|
} |
|
|
|
|
|
|
|
|
.tab-btn { |
|
|
position: relative; |
|
|
overflow: hidden; |
|
|
border-radius: 12px; |
|
|
font-weight: 500; |
|
|
letter-spacing: 0.025em; |
|
|
} |
|
|
|
|
|
.tab-btn::before { |
|
|
content: ''; |
|
|
position: absolute; |
|
|
top: 0; |
|
|
left: -100%; |
|
|
width: 100%; |
|
|
height: 100%; |
|
|
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent); |
|
|
transition: left 0.5s; |
|
|
} |
|
|
|
|
|
.tab-btn:hover::before { |
|
|
left: 100%; |
|
|
} |
|
|
|
|
|
.tab-btn.active { |
|
|
background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%); |
|
|
color: white; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(102, 126, 234, 0.3), |
|
|
0 4px 6px -2px rgba(102, 126, 234, 0.05); |
|
|
transform: translateY(-1px); |
|
|
} |
|
|
|
|
|
|
|
|
.card { |
|
|
background: var(--surface-color); |
|
|
border-radius: 16px; |
|
|
border: 1px solid rgba(255, 255, 255, 0.2); |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(0, 0, 0, 0.1), |
|
|
0 4px 6px -2px rgba(0, 0, 0, 0.05); |
|
|
overflow: hidden; |
|
|
position: relative; |
|
|
} |
|
|
|
|
|
.card::before { |
|
|
content: ''; |
|
|
position: absolute; |
|
|
top: 0; |
|
|
left: 0; |
|
|
right: 0; |
|
|
height: 1px; |
|
|
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent); |
|
|
} |
|
|
|
|
|
|
|
|
.stat-card { |
|
|
background: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.8) 100%); |
|
|
border-radius: 20px; |
|
|
border: 1px solid rgba(255, 255, 255, 0.3); |
|
|
padding: 24px; |
|
|
position: relative; |
|
|
overflow: hidden; |
|
|
transition: all 0.3s ease; |
|
|
} |
|
|
|
|
|
.stat-card::before { |
|
|
content: ''; |
|
|
position: absolute; |
|
|
top: -50%; |
|
|
left: -50%; |
|
|
width: 200%; |
|
|
height: 200%; |
|
|
background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%); |
|
|
opacity: 0; |
|
|
transition: opacity 0.3s ease; |
|
|
} |
|
|
|
|
|
.stat-card:hover { |
|
|
transform: translateY(-4px); |
|
|
box-shadow: |
|
|
0 20px 25px -5px rgba(0, 0, 0, 0.1), |
|
|
0 10px 10px -5px rgba(0, 0, 0, 0.04); |
|
|
} |
|
|
|
|
|
.stat-card:hover::before { |
|
|
opacity: 1; |
|
|
} |
|
|
|
|
|
.stat-icon { |
|
|
width: 56px; |
|
|
height: 56px; |
|
|
border-radius: 16px; |
|
|
display: flex; |
|
|
align-items: center; |
|
|
justify-content: center; |
|
|
font-size: 24px; |
|
|
color: white; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(0, 0, 0, 0.1), |
|
|
0 4px 6px -2px rgba(0, 0, 0, 0.05); |
|
|
} |
|
|
|
|
|
|
|
|
.btn { |
|
|
font-weight: 500; |
|
|
border-radius: 12px; |
|
|
border: none; |
|
|
cursor: pointer; |
|
|
transition: all 0.3s ease; |
|
|
position: relative; |
|
|
overflow: hidden; |
|
|
letter-spacing: 0.025em; |
|
|
} |
|
|
|
|
|
.btn::before { |
|
|
content: ''; |
|
|
position: absolute; |
|
|
top: 50%; |
|
|
left: 50%; |
|
|
width: 0; |
|
|
height: 0; |
|
|
background: rgba(255, 255, 255, 0.2); |
|
|
border-radius: 50%; |
|
|
transform: translate(-50%, -50%); |
|
|
transition: |
|
|
width 0.3s ease, |
|
|
height 0.3s ease; |
|
|
} |
|
|
|
|
|
.btn:active::before { |
|
|
width: 300px; |
|
|
height: 300px; |
|
|
} |
|
|
|
|
|
.btn-primary { |
|
|
background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%); |
|
|
color: white; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(102, 126, 234, 0.3), |
|
|
0 4px 6px -2px rgba(102, 126, 234, 0.05); |
|
|
} |
|
|
|
|
|
.btn-primary:hover { |
|
|
transform: translateY(-1px); |
|
|
box-shadow: |
|
|
0 20px 25px -5px rgba(102, 126, 234, 0.3), |
|
|
0 10px 10px -5px rgba(102, 126, 234, 0.1); |
|
|
} |
|
|
|
|
|
.btn-success { |
|
|
background: linear-gradient(135deg, var(--success-color) 0%, #059669 100%); |
|
|
color: white; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(16, 185, 129, 0.3), |
|
|
0 4px 6px -2px rgba(16, 185, 129, 0.05); |
|
|
} |
|
|
|
|
|
.btn-success:hover { |
|
|
transform: translateY(-1px); |
|
|
box-shadow: |
|
|
0 20px 25px -5px rgba(16, 185, 129, 0.3), |
|
|
0 10px 10px -5px rgba(16, 185, 129, 0.1); |
|
|
} |
|
|
|
|
|
.btn-danger { |
|
|
background: linear-gradient(135deg, var(--error-color) 0%, #dc2626 100%); |
|
|
color: white; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(239, 68, 68, 0.3), |
|
|
0 4px 6px -2px rgba(239, 68, 68, 0.05); |
|
|
} |
|
|
|
|
|
.btn-danger:hover { |
|
|
transform: translateY(-1px); |
|
|
box-shadow: |
|
|
0 20px 25px -5px rgba(239, 68, 68, 0.3), |
|
|
0 10px 10px -5px rgba(239, 68, 68, 0.1); |
|
|
} |
|
|
|
|
|
.btn-secondary { |
|
|
background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%); |
|
|
color: white; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(107, 114, 128, 0.3), |
|
|
0 4px 6px -2px rgba(107, 114, 128, 0.05); |
|
|
} |
|
|
|
|
|
.btn-secondary:hover { |
|
|
transform: translateY(-1px); |
|
|
box-shadow: |
|
|
0 20px 25px -5px rgba(107, 114, 128, 0.3), |
|
|
0 10px 10px -5px rgba(107, 114, 128, 0.1); |
|
|
} |
|
|
|
|
|
|
|
|
.form-input { |
|
|
background: rgba(255, 255, 255, 0.95); |
|
|
border: 2px solid rgba(255, 255, 255, 0.3); |
|
|
border-radius: 12px; |
|
|
padding: 8px 12px; |
|
|
font-size: 14px; |
|
|
transition: all 0.2s ease; |
|
|
|
|
|
} |
|
|
|
|
|
.form-input:focus { |
|
|
outline: none; |
|
|
border-color: var(--primary-color); |
|
|
box-shadow: |
|
|
0 0 0 3px rgba(102, 126, 234, 0.1), |
|
|
0 10px 15px -3px rgba(0, 0, 0, 0.1); |
|
|
background: rgba(255, 255, 255, 0.95); |
|
|
} |
|
|
|
|
|
|
|
|
.table-container { |
|
|
background: rgba(255, 255, 255, 0.95); |
|
|
border-radius: 16px; |
|
|
overflow: hidden; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(0, 0, 0, 0.1), |
|
|
0 4px 6px -2px rgba(0, 0, 0, 0.05); |
|
|
} |
|
|
|
|
|
.table-row { |
|
|
transition: all 0.2s ease; |
|
|
} |
|
|
|
|
|
.table-row:hover { |
|
|
background: rgba(102, 126, 234, 0.05); |
|
|
transform: scale(1.005); |
|
|
} |
|
|
|
|
|
|
|
|
.modal { |
|
|
|
|
|
background: rgba(0, 0, 0, 0.6); |
|
|
} |
|
|
|
|
|
.dark .modal { |
|
|
background: rgba(0, 0, 0, 0.75); |
|
|
} |
|
|
|
|
|
.modal-content { |
|
|
background: rgba(255, 255, 255, 0.98); |
|
|
border-radius: 24px; |
|
|
border: 1px solid rgba(255, 255, 255, 0.3); |
|
|
box-shadow: |
|
|
0 10px 25px -5px rgba(0, 0, 0, 0.15), |
|
|
0 0 0 1px rgba(255, 255, 255, 0.05); |
|
|
|
|
|
} |
|
|
|
|
|
.dark .modal-content { |
|
|
background: rgba(17, 24, 39, 0.95); |
|
|
border: 1px solid rgba(75, 85, 99, 0.3); |
|
|
box-shadow: |
|
|
0 10px 25px -5px rgba(0, 0, 0, 0.3), |
|
|
0 0 0 1px rgba(255, 255, 255, 0.05); |
|
|
} |
|
|
|
|
|
|
|
|
.modal-scroll-content { |
|
|
max-height: calc(90vh - 160px); |
|
|
overflow-y: auto; |
|
|
padding-right: 8px; |
|
|
} |
|
|
|
|
|
|
|
|
.header-title { |
|
|
background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%); |
|
|
-webkit-background-clip: text; |
|
|
-webkit-text-fill-color: transparent; |
|
|
background-clip: text; |
|
|
font-weight: 700; |
|
|
letter-spacing: -0.025em; |
|
|
} |
|
|
|
|
|
|
|
|
.loading-spinner { |
|
|
display: inline-block; |
|
|
width: 20px; |
|
|
height: 20px; |
|
|
border: 2px solid rgba(255, 255, 255, 0.3); |
|
|
border-radius: 50%; |
|
|
border-top: 2px solid white; |
|
|
animation: spin 1s linear infinite; |
|
|
} |
|
|
|
|
|
@keyframes spin { |
|
|
0% { |
|
|
transform: rotate(0deg); |
|
|
} |
|
|
100% { |
|
|
transform: rotate(360deg); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
.toast { |
|
|
position: fixed; |
|
|
top: 80px; |
|
|
right: 20px; |
|
|
z-index: 1000; |
|
|
min-width: 320px; |
|
|
max-width: 500px; |
|
|
transform: translateX(100%); |
|
|
transition: transform 0.3s ease-in-out; |
|
|
} |
|
|
|
|
|
|
|
|
@media (max-width: 640px) { |
|
|
|
|
|
.glass, |
|
|
.glass-strong { |
|
|
margin: 12px; |
|
|
border-radius: 16px; |
|
|
padding: 16px; |
|
|
} |
|
|
|
|
|
|
|
|
.stat-card { |
|
|
padding: 12px; |
|
|
border-radius: 12px; |
|
|
} |
|
|
|
|
|
.stat-icon { |
|
|
width: 40px; |
|
|
height: 40px; |
|
|
font-size: 16px; |
|
|
} |
|
|
|
|
|
|
|
|
.tab-btn { |
|
|
font-size: 12px; |
|
|
padding: 10px 6px; |
|
|
} |
|
|
|
|
|
|
|
|
.modal-content { |
|
|
margin: 8px; |
|
|
max-width: calc(100vw - 24px); |
|
|
padding: 16px; |
|
|
} |
|
|
|
|
|
.modal-scroll-content { |
|
|
max-height: calc(90vh - 100px); |
|
|
} |
|
|
|
|
|
|
|
|
.card { |
|
|
border-radius: 12px; |
|
|
} |
|
|
|
|
|
|
|
|
.form-input, |
|
|
.form-select, |
|
|
.form-textarea { |
|
|
font-size: 14px; |
|
|
padding: 8px 12px; |
|
|
} |
|
|
|
|
|
|
|
|
.btn { |
|
|
font-size: 14px; |
|
|
padding: 8px 16px; |
|
|
} |
|
|
|
|
|
|
|
|
.table-container table { |
|
|
font-size: 12px; |
|
|
} |
|
|
|
|
|
.table-container th, |
|
|
.table-container td { |
|
|
padding: 8px 12px; |
|
|
} |
|
|
|
|
|
|
|
|
.toast { |
|
|
min-width: 280px; |
|
|
max-width: calc(100vw - 40px); |
|
|
right: 12px; |
|
|
top: 60px; |
|
|
} |
|
|
|
|
|
|
|
|
.loading-spinner { |
|
|
width: 16px; |
|
|
height: 16px; |
|
|
} |
|
|
} |
|
|
|
|
|
@media (max-width: 768px) { |
|
|
|
|
|
.glass, |
|
|
.glass-strong { |
|
|
margin: 16px; |
|
|
border-radius: 20px; |
|
|
} |
|
|
|
|
|
|
|
|
.stat-card { |
|
|
padding: 16px; |
|
|
} |
|
|
|
|
|
|
|
|
.tab-btn { |
|
|
font-size: 14px; |
|
|
padding: 12px 8px; |
|
|
} |
|
|
|
|
|
|
|
|
.modal-scroll-content { |
|
|
max-height: calc(85vh - 120px); |
|
|
} |
|
|
} |
|
|
|
|
|
.toast.show { |
|
|
transform: translateX(0); |
|
|
} |
|
|
|
|
|
.toast-success { |
|
|
background: linear-gradient(135deg, #10b981 0%, #059669 100%); |
|
|
color: white; |
|
|
border: 1px solid rgba(16, 185, 129, 0.3); |
|
|
} |
|
|
|
|
|
.toast-error { |
|
|
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%); |
|
|
color: white; |
|
|
border: 1px solid rgba(239, 68, 68, 0.3); |
|
|
} |
|
|
|
|
|
.toast-info { |
|
|
background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%); |
|
|
color: white; |
|
|
border: 1px solid rgba(59, 130, 246, 0.3); |
|
|
} |
|
|
|
|
|
.toast-warning { |
|
|
background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%); |
|
|
color: white; |
|
|
border: 1px solid rgba(245, 158, 11, 0.3); |
|
|
} |
|
|
|
|
|
|
|
|
@keyframes pulse { |
|
|
0% { |
|
|
transform: scale(1); |
|
|
opacity: 1; |
|
|
} |
|
|
50% { |
|
|
transform: scale(1.1); |
|
|
opacity: 0.8; |
|
|
} |
|
|
100% { |
|
|
transform: scale(1); |
|
|
opacity: 1; |
|
|
} |
|
|
} |
|
|
|
|
|
.animate-pulse { |
|
|
animation: pulse 2s infinite; |
|
|
} |
|
|
|
|
|
|
|
|
.user-menu-dropdown { |
|
|
min-width: 240px; |
|
|
box-shadow: |
|
|
0 10px 15px -3px rgba(0, 0, 0, 0.1), |
|
|
0 4px 6px -2px rgba(0, 0, 0, 0.05); |
|
|
} |
|
|
|
|
|
.fa-openai { |
|
|
width: 16px; |
|
|
height: 16px; |
|
|
background: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2NDAgNjQwIj48IS0tIUZvbnQgQXdlc29tZSBGcmVlIHY3LjAuMCBieSBAZm9udGF3ZXNvbWUgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbSBMaWNlbnNlIC0gaHR0cHM6Ly9mb250YXdlc29tZS5jb20vbGljZW5zZS9mcmVlIENvcHlyaWdodCAyMDI1IEZvbnRpY29ucywgSW5jLi0tPjxwYXRoIGQ9Ik0yNjAuNCAyNDkuOHYtNDguNmMwLTQuMSAxLjUtNy4yIDUuMS05LjJsOTcuOC01Ni4zYzEzLjMtNy43IDI5LjItMTEuMyA0NS42LTExLjMgNjEuNCAwIDEwMC40IDQ3LjYgMTAwLjQgOTguMyAwIDMuNiAwIDcuNy0uNSAxMS44bC0xMDEuNS01OS40Yy02LjEtMy42LTEyLjMtMy42LTE4LjQgMGwtMTI4LjUgNzQuN3ptMjI4LjMgMTg5LjRWMzIzYzAtNy4yLTMuMS0xMi4zLTkuMi0xNS45TDM1MSAyMzIuNGw0Mi0yNC4xYzMuNi0yIDYuNy0yIDEwLjIgMGw5Ny44IDU2LjRjMjguMiAxNi40IDQ3LjEgNTEuMiA0Ny4xIDg1IDAgMzguOS0yMyA3NC44LTU5LjQgODkuNnpNMjMwLjIgMzM2LjhsLTQyLTI0LjZjLTMuNi0yLTUuMS01LjEtNS4xLTkuMlYxOTAuNGMwLTU0LjggNDItOTYuMyA5OC44LTk2LjMgMjEuNSAwIDQxLjUgNy4yIDU4LjQgMjBsLTEwMC45IDU4LjRjLTYuMSAzLjYtOS4yIDguNy05LjIgMTUuOXYxNDguNXptOTAuNCA1Mi4ybC02MC4yLTMzLjh2LTcxLjdsNjAuMi0zMy44IDYwLjIgMzMuOHY3MS43TDMyMC42IDM4OXptMzguNyAxNTUuN2MtMjEuNSAwLTQxLjUtNy4yLTU4LjQtMjBsMTAwLjktNTguNGM2LjEtMy42IDkuMi04LjcgOS4yLTE1LjlWMzAxLjlsNDIuNSAyNC42YzMuNiAyIDUuMSA1LjEgNS4xIDkuMnYxMTIuNmMwIDU0LjgtNDIuNSA5Ni4zLTk5LjMgOTYuM3pNMjM3LjggNDMwLjVsLTk3LjctNTYuM0MxMTEuOSAzNTcuOCA5MyAzMjMgOTMgMjg5LjJjMC0zOS40IDIzLjYtNzQuOCA1OS45LTg5LjZ2MTE2LjdjMCA3LjIgMy4xIDEyLjMgOS4yIDE1LjlsMTI4IDc0LjItNDIgMjQuMWMtMy42IDItNi43IDItMTAuMiAwem0tNS42IDg0Yy01Ny45IDAtMTAwLjQtNDMuNS0xMDAuNC05Ny4zIDAtNC4xLjUtOC4yIDEtMTIuM2wxMDAuOSA1OC40YzYuMSAzLjYgMTIuMyAzLjYgMTguNCAwbDEyOC41LTc0LjJ2NDguNmMwIDQuMS0xLjUgNy4yLTUuMSA5LjJsLTk3LjggNTYuM2MtMTMuMyA3LjctMjkuMiAxMS4zLTQ1LjYgMTEuM3ptMTI3IDYwLjljNjIgMCAxMTMuNy00NCAxMjUuNC0xMDIuNCA1Ny4zLTE0LjkgOTQuMi02OC42IDk0LjItMTIzLjQgMC0zNS44LTE1LjQtNzAuNy00My05NS43IDIuNi0xMC44IDQuMS0yMS41IDQuMS0zMi4zIDAtNzMuMi01OS40LTEyOC0xMjgtMTI4LTEzLjggMC0yNy4xIDItNDAuNCA2LjctMjMtMjIuNS01NC44LTM2LjktODkuNi0zNi45LTYyIDAtMTEzLjcgNDQtMTI1LjQgMTAyLjQtNTcuMyAxNC44LTk0LjIgNjguNi05NC4yIDEyMy40IDAgMzUuOCAxNS40IDcwLjcgNDMgOTUuNy0yLjYgMTAuOC00LjEgMjEuNS00LjEgMzIuMyAwIDczLjIgNTkuNCAxMjggMTI4IDEyOCAxMy44IDAgMjcuMS0yIDQwLjQtNi43IDIzIDIyLjUgNTQuOCAzNi45IDg5LjYgMzYuOXoiLz48L3N2Zz4=) |
|
|
no-repeat center/100%; |
|
|
} |
|
|
|