Files
muzi/static/style.css
2026-02-28 00:13:37 -08:00

457 lines
7.3 KiB
CSS

body {
display: flex;
flex-direction: column;
background-color: #222;
color: #AFA;
align-content: center;
justify-content: center;
align-items: center;
text-align: center;
max-width: 70vw;
margin: 0 auto;
width: 70vw;
font-family: sans-serif;
padding-top: 80px;
}
/* Hamburger Menu Button - left side */
.menu-button {
position: fixed;
top: 20px;
left: 20px;
width: 40px;
height: 40px;
cursor: pointer;
z-index: 1000;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
gap: 5px;
}
.menu-button span {
display: block;
width: 28px;
height: 3px;
background-color: #AFA;
border-radius: 2px;
transition: all 0.3s ease;
}
.menu-button.active span:nth-child(1) {
transform: rotate(45deg) translate(5px, 6px);
}
.menu-button.active span:nth-child(2) {
opacity: 0;
}
.menu-button.active span:nth-child(3) {
transform: rotate(-45deg) translate(5px, -6px);
}
/* Slide-out Menu */
.side-menu {
position: fixed;
top: 0;
left: -280px;
width: 280px;
height: 100vh;
background-color: #1a1a1a;
z-index: 999;
transition: left 0.3s ease;
display: flex;
flex-direction: column;
padding-top: 60px;
}
.side-menu.active {
left: 0;
}
.menu-header {
padding: 20px;
border-bottom: 1px solid #333;
}
.menu-header h3 {
margin: 0;
color: #AFA;
font-size: 24px;
}
.menu-nav {
display: flex;
flex-direction: column;
padding: 10px 0;
}
.menu-item {
display: flex;
align-items: center;
gap: 15px;
padding: 15px 20px;
color: #EEE;
text-decoration: none;
transition: background-color 0.2s;
}
.menu-item:hover {
background-color: #333;
}
.menu-item .menu-icon {
color: #FFF;
}
.menu-icon {
width: 24px;
height: 24px;
flex-shrink: 0;
filter: invert(1) brightness(1.5);
}
/* Menu Overlay */
.menu-overlay {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.5);
z-index: 998;
opacity: 0;
visibility: hidden;
transition: opacity 0.3s ease, visibility 0.3s ease;
}
.menu-overlay.active {
opacity: 1;
visibility: visible;
}
.page_buttons {
display: flex;
flex-direction: row;
justify-content: center;
a {
margin: 10px;
background-color: #111;
color: #EEE;
text-decoration: none;
padding: 5px;
}
}
.user-stats-top {
display: flex;
flex-direction: column;
justify-content: center;
width: 20%;
h3 {
color: #FFF;
font-size: 25px;
margin: 0;
}
p {
margin: 0;
color: #EEE;
}
}
.username-bio {
display: flex;
flex-direction: column;
justify-content: center;
margin-left: 40px;
}
.profile-top-blank {
width: 50%;
}
.profile-top {
display: flex;
flex-direction: row;
align-content: center;
width: 100%;
h1 {
color: #FFFFFF;
margin: 0;
}
h2 {
color: #777777;
font-size: 15px;
margin: 0;
}
img {
object-fit: cover;
width: 250px;
height: 250px;
border-radius: 100%;
}
}
.login-form {
display: flex;
height: 100vh;
align-items: center;
justify-content: center;
}
.login-error {
color: #AA0000;
}
.history {
display: flex;
flex-direction: column;
justify-content: center;
width: 100%;
table {
width: auto;
}
tr {
display: flex;
flex-direction: row;
justify-content: space-between;
margin: 5px;
}
th, td {
display: flex;
justify-content: center;
margin: 5px;
width: 30%;
}
tr:nth-child(even) {
background-color: #111;
}
}
.import-section {
margin: 20px 0;
padding: 20px;
background: #1a1a1a;
border-radius: 8px;
}
.import-section form {
display: flex;
flex-direction: column;
gap: 10px;
margin-top: 15px;
}
.import-section input {
padding: 8px;
border: 1px solid #333;
border-radius: 4px;
background: #222;
color: #AFA;
}
.import-section button {
padding: 10px 20px;
background: #333;
color: #AFA;
border: 1px solid #444;
border-radius: 4px;
cursor: pointer;
}
.import-section button:hover {
background: #444;
}
/* Settings Tab Navigation */
.settings-tabs {
display: flex;
flex-direction: row;
border-bottom: 1px solid #333;
margin-bottom: 20px;
}
.tab-button {
padding: 12px 24px;
background: none;
border: none;
color: #888;
font-size: 16px;
cursor: pointer;
position: relative;
transition: color 0.2s;
}
.tab-button:hover {
color: #AFA;
}
.tab-button.active {
color: #AFA;
}
.tab-button.active::after {
content: '';
position: absolute;
bottom: -1px;
left: 0;
width: 100%;
height: 2px;
background-color: #AFA;
}
.progress-container {
margin-top: 15px;
padding: 15px;
background: #1a1a1a;
border-radius: 8px;
border: 1px solid #333;
}
.progress-bar-wrapper {
width: 100%;
height: 24px;
background: #2a2a2a;
border-radius: 12px;
overflow: hidden;
position: relative;
margin: 10px 0;
border: 2px solid #444;
}
.progress-bar-fill {
height: 100%;
width: 0%;
background: linear-gradient(90deg, #5a5 0%, #7f7 50%, #5a5 100%);
background-size: 200% 100%;
border-radius: 10px;
transition: width 0.3s ease-out;
box-shadow:
inset 0 2px 4px rgba(255, 255, 255, 0.3),
inset 0 -2px 4px rgba(0, 0, 0, 0.3),
0 0 15px rgba(0, 255, 0, 0.4);
position: absolute;
top: 0;
left: 0;
z-index: 1;
}
.progress-bar-fill.animating {
animation: shimmer 2s linear infinite, pulse-glow 1.5s ease-in-out infinite;
}
@keyframes pulse-glow {
0%, 100% {
box-shadow:
inset 0 2px 4px rgba(255, 255, 255, 0.3),
inset 0 -2px 4px rgba(0, 0, 0, 0.3),
0 0 15px rgba(0, 255, 0, 0.4);
}
50% {
box-shadow:
inset 0 2px 4px rgba(255, 255, 255, 0.3),
inset 0 -2px 4px rgba(0, 0, 0, 0.3),
0 0 25px rgba(0, 255, 0, 0.7);
}
}
@keyframes shimmer {
0% { background-position: 200% 0; }
100% { background-position: -200% 0; }
}
.progress-text {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
color: #fff;
font-weight: bold;
font-size: 12px;
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
z-index: 2;
pointer-events: none;
}
.progress-status {
color: #AFA;
font-size: 14px;
margin-bottom: 5px;
}
.progress-tracks {
color: #888;
font-size: 12px;
margin-bottom: 5px;
}
.progress-error {
color: #F88;
font-size: 14px;
margin-top: 10px;
}
.progress-success {
color: #8F8;
font-size: 14px;
margin-top: 10px;
}
/* Tab Panels */
.tab-panel {
display: none;
}
.tab-panel.active {
display: block;
}
/* API Key Display */
.api-key-display {
margin: 15px 0;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 5px;
}
.api-key-display label {
color: #888;
font-size: 14px;
}
.api-key-display code {
background: #111;
padding: 8px 12px;
border-radius: 4px;
color: #AFA;
font-family: monospace;
word-break: break-all;
}
.success {
color: #8F8;
margin-top: 10px;
}
.info {
color: #888;
font-size: 14px;
margin-top: 10px;
}
a.button {
display: inline-block;
padding: 10px 20px;
background: #1DB954;
color: #fff;
text-decoration: none;
border-radius: 25px;
font-weight: bold;
}
a.button:hover {
background: #1ed760;
}