arimelody-web/admin/static/admin.css

486 lines
8.8 KiB
CSS
Raw Normal View History

@import url("/style/prideflag.css");
@import url("/font/inter/inter.css");
2025-10-19 05:01:55 +01:00
:root {
--bg-0: #101010;
--bg-1: #181818;
--bg-2: #282828;
--bg-3: #404040;
2025-10-19 05:01:55 +01:00
--fg-0: #b0b0b0;
--fg-1: #c0c0c0;
--fg-2: #d0d0d0;
--fg-3: #e0e0e0;
--col-shadow-0: #0002;
--col-shadow-1: #0004;
--col-shadow-2: #0006;
--col-highlight-0: #ffffff08;
--col-highlight-1: #fff1;
--col-highlight-2: #fff2;
--col-new: #b3ee5b;
--col-on-new: #1b2013;
--col-save: #6fd7ff;
--col-on-save: #283f48;
--col-delete: #ff7171;
--col-on-delete: #371919;
--col-warn: #ffe86a;
--col-on-warn: var(--bg-0);
--col-warn-hover: #ffec81;
--shadow-sm:
0 1px 2px var(--col-shadow-2),
inset 0 1px 1px var(--col-highlight-2);
--shadow-md:
0 2px 4px var(--col-shadow-1),
inset 0 2px 2px var(--col-highlight-1);
--shadow-lg:
0 4px 8px var(--col-shadow-0),
inset 0 4px 4px var(--col-highlight-0);
}
@media (prefers-color-scheme: light) {
:root {
--bg-0: #e8e8e8;
--bg-1: #f0f0f0;
--bg-2: #f8f8f8;
--bg-3: #ffffff;
--fg-0: #606060;
--fg-1: #404040;
--fg-2: #303030;
--fg-3: #202020;
--col-shadow-0: #0002;
--col-shadow-1: #0004;
--col-shadow-2: #0008;
--col-highlight-0: #fff2;
--col-highlight-1: #fff4;
--col-highlight-2: #fff8;
--col-warn: #ffe86a;
--col-on-warn: var(--fg-3);
--col-warn-hover: #ffec81;
}
}
@media (prefers-color-scheme: green) {
:root {
--bg-0: #d0d9c7;
--bg-1: #e2e5de;
--bg-2: #f1f1f1;
--bg-3: #ffffff;
--fg-0: #626f54;
--fg-1: #505c43;
--fg-2: #49523e;
--fg-3: #2c3522;
}
}
@media (prefers-color-scheme: purple) {
:root {
--bg-0: #15121c;
--bg-1: #1e1a27;
--bg-2: #302a3d;
--bg-3: #4a4358;
--fg-0: #9e8fbf;
--fg-1: #a29bb3;
--fg-2: #b9b0cd;
--fg-3: #dcd5ec;
}
}
2025-10-21 15:57:12 +01:00
@media (prefers-color-scheme: dark) {
img.icon {
-webkit-filter: invert(1);
filter: invert(1);
}
}
body {
width: calc(100% - 180px);
height: calc(100vh - 1em);
margin: 0 0 0 180px;
padding: 0;
display: flex;
flex-direction: row;
font-family: "Inter", sans-serif;
font-size: 16px;
2025-10-19 05:01:55 +01:00
color: var(--fg-0);
background: var(--bg-0);
transition: background .1s ease-out, color .1s ease-out;
2025-10-19 05:01:55 +01:00
}
h1, h2, h3, h4, h5, h6 {
color: var(--fg-3);
}
header {
display: flex;
justify-content: space-between;
align-items: center;
}
nav {
position: fixed;
top: 0;
left: 0;
width: 180px;
height: calc(100vh - 2em);
margin: 0;
padding: 1em 0;
display: flex;
flex-direction: column;
justify-content: left;
background-color: var(--bg-1);
box-shadow: var(--shadow-md);
transition: background .1s ease-out, color .1s ease-out;
2025-10-19 05:01:55 +01:00
user-select: none;
}
nav .icon {
width: fit-content;
height: fit-content;
padding: 0;
margin: 0 auto 1em auto;
display: flex;
2025-10-19 05:01:55 +01:00
border-radius: 100%;
box-shadow: var(--shadow-sm);
overflow: clip;
}
2025-10-19 05:01:55 +01:00
nav .icon img {
width: 3em;
height: 3em;
}
.nav-item {
display: flex;
2025-10-19 05:01:55 +01:00
color: var(--fg-2);
line-height: 2em;
2025-10-19 05:01:55 +01:00
font-weight: 500;
transition: color .1s ease-out, background-color .1s ease-out;
}
.nav-item:hover {
color: var(--bg-2);
background-color: var(--fg-2);
text-decoration: none;
}
.nav-item.active {
border-left: 4px solid var(--fg-2);
}
.nav-item.active a {
padding-left: calc(1em - 3.5px);
}
nav a {
padding: .2em 1em;
text-decoration: none;
color: inherit;
width: 100%;
}
nav a.active {
border-left: 5px solid var(--fg-0);
padding-left: calc(1em - 5px);
}
nav hr {
width: calc(100% - 2em);
margin: .5em auto;
border: none;
border-bottom: 1px solid var(--fg-0);
2025-10-20 08:31:36 +01:00
}
nav .section-label {
2025-10-21 23:22:57 +01:00
margin: .6em 0 .1em 1.6em;
font-size: .6em;
text-transform: uppercase;
font-weight: 600;
}
2025-10-21 23:22:57 +01:00
#toggle-nav {
position: fixed;
top: 16px;
left: 16px;
padding: 8px;
width: 48px;
height: 48px;
display: none;
justify-content: center;
align-items: center;
z-index: 1;
}
#toggle-nav img {
width: 100%;
height: 100%;
object-fit: cover;
transform: translate(1px, 1px);
}
#toggle-nav img:hover {
filter: invert(.9);
}
@media (prefers-color-scheme: dark) {
#toggle-nav img {
filter: invert(.9);
}
#toggle-nav img:hover {
filter: none;
}
}
main {
2025-10-21 23:22:57 +01:00
width: 720px;
max-width: calc(100% - 2em);
height: fit-content;
min-height: calc(100vh - 2em);
margin: 0 auto;
padding: 1em;
}
main.dashboard {
width: 100%;
}
a {
color: inherit;
text-decoration: none;
2025-10-21 23:22:57 +01:00
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
transition: color .1s ease-out, background-color .1s ease-out;
}
2025-10-19 05:01:55 +01:00
/*
a:hover {
text-decoration: underline;
}
2025-10-19 05:01:55 +01:00
*/
2025-10-21 15:57:12 +01:00
img.icon {
2024-08-31 19:29:57 +01:00
height: .8em;
2025-10-21 15:57:12 +01:00
transition: filter .1s ease-out;
}
code {
background: #303030;
color: #f0f0f0;
padding: .23em .3em;
border-radius: 4px;
}
.cards {
width: 100%;
height: fit-content;
display: flex;
gap: 2em;
flex-wrap: wrap;
}
.card {
flex-basis: 40em;
padding: 1em;
background: var(--bg-1);
border-radius: 16px;
box-shadow: var(--shadow-lg);
transition: background .1s ease-out, color .1s ease-out;
}
main:not(.dashboard) .card {
margin-bottom: 1em;
}
.card h2 {
margin: 0 0 .5em 0;
}
.card-header {
margin-bottom: 1em;
display: flex;
gap: 1em;
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.card-header h1,
.card-header h2,
.card-header h3 {
margin: 0;
}
.card-header a:hover {
text-decoration: underline;
}
header :is(h1, h2, h3) small,
.card-header :is(h1, h2, h3) small {
display: inline-block;
font-size: .6em;
transform: translateY(-0.1em);
color: var(--fg-0);
}
.flex-fill {
flex-grow: 1;
}
.artists-group {
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: 1em;
}
#message,
#error {
margin: 0 0 1em 0;
padding: 1em;
2025-10-19 05:01:55 +01:00
border-radius: 8px;
2025-10-21 21:00:54 +01:00
color: #101010;
background: #ffffff;
}
#message {
background: #a9dfff;
}
#error {
background: #ffa9b8;
}
a.delete:not(.button) {
color: #d22828;
}
2025-10-19 05:01:55 +01:00
.button, button {
padding: .5em .8em;
font-family: inherit;
font-size: inherit;
2025-10-19 05:01:55 +01:00
color: inherit;
2025-10-19 05:01:55 +01:00
background: var(--bg-2);
border: none;
border-radius: 10em;
box-shadow: var(--shadow-sm);
font-weight: 500;
transition: background .1s ease-out, color .1s ease-out;
cursor: pointer;
user-select: none;
}
button:hover, .button:hover {
background: #fff;
}
button:active, .button:active {
background: #d0d0d0;
}
.button.new, button.new {
2025-10-19 05:01:55 +01:00
color: var(--col-on-new);
background: var(--col-new);
}
.button.save, button.save {
2025-10-19 05:01:55 +01:00
color: var(--col-on-save);
background: var(--col-save);
}
.button.delete, button.delete {
2025-10-19 05:01:55 +01:00
color: var(--col-on-delete);
background: var(--col-delete);
}
.button:hover, button:hover {
2025-10-19 05:01:55 +01:00
color: var(--bg-3);
background: var(--fg-3);
}
.button:active, button:active {
2025-10-19 05:01:55 +01:00
color: var(--bg-2);
background: var(--fg-0);
}
.button[disabled], button[disabled] {
2025-10-19 05:01:55 +01:00
color: var(--fg-0) !important;
background: var(--bg-3) !important;
opacity: .5;
2025-10-19 05:01:55 +01:00
cursor: default !important;
}
form {
width: 100%;
display: block;
2025-10-21 21:00:54 +01:00
color: var(--fg-0);
}
form label {
width: 100%;
margin: 1rem 0 .5rem 0;
display: block;
}
2025-10-21 23:22:57 +01:00
form input[type="text"],
form input[type="password"] {
width: 16em;
max-width: 100%;
2025-10-21 21:00:54 +01:00
margin: .5em 0;
padding: .3em .5em;
display: block;
border-radius: 4px;
2025-10-21 21:00:54 +01:00
border: 1px solid #808080;
font-size: inherit;
font-family: inherit;
color: inherit;
2025-10-21 21:00:54 +01:00
background-color: var(--bg-0);
}
input[disabled] {
opacity: .5;
cursor: not-allowed;
}
2025-10-21 23:22:57 +01:00
@media screen and (max-width: 720px) {
main {
padding-top: 0;
}
body {
width: 100%;
margin: 0;
font-size: 16px;
}
nav {
width: 100%;
left: -100%;
font-size: 24px;
z-index: 1;
transition: transform .2s cubic-bezier(.2,0,.5,1);
}
nav.open {
transform: translateX(100%);
}
#toggle-nav {
display: flex;
}
main > h1:first-of-type {
margin-left: 68px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
main > header {
margin-left: 68px;
}
main > header h1 {
display: flex;
flex-direction: column;
font-size: 1.5em;
}
.card {
flex-basis: 100%;
max-width: calc(100vw - 4em);
}
.artists-group {
grid-template-columns: repeat(3, 1fr);
}
}