﻿:root {
    --admin-nav-header-foreground: #ff88ffcc;
    
    --admin-nav-group-header-foreground: #73e4af99;
    --admin-nav-group-border: #ff88ff88;
    --admin-icon-foreground: #ff88ff;
    
    --admin-table-header-foreground: #73e4af;
    --admin-table-header-background: #1a0421;
    --admin-table-border: #ff88ff88;
    --admin-table-header-border: #ff88ff55;
    --admin-table-header-shadow: #ff88ff33;
    
    --dual-value-container-label-foreground: #ff88ff99;
    --dual-value-container-label-focus-foreground: #ff88ff;
    --dual-value-container-label-background: #0f0213;
    --dual-value-container-label-border: #ff88ff99;
    --dual-value-container-label-focus-border: #ff88ff;
    --dual-value-container-textbox-focus-background: #ff88ff22;
    --dual-value-editor-border: #ff88ff99;

    --link-manager-group-reorder-background: #ff88ff22;
    --link-manager-nav-group-border: #ff88ff99;
}

* {
    box-sizing: border-box;
}

main#admin {
    display: flex;
    flex-direction: row;
    
    height: 100%;
    width: 70%;
    
    padding: 0;
    margin: 0 auto;
    
    text-align: left;
}

@media screen and (max-width: 1450px) {
    main#admin {
        width: 90%;
    }
}

main#admin .admin-content {
    padding: 24px;
}

main#admin nav {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;

    padding: 24px 8px 20px 24px;
}

main#admin nav h1 {
    padding: 0;
    margin: 0 0 18px;

    font-family: "Vermin Vibes V";
    font-size: 1.1rem;
    font-weight: 400;

    text-wrap: nowrap;
    text-transform: uppercase;

    color: var(--admin-nav-header-foreground);
    
    user-select: none;
}

main#admin nav h2 {
    padding: 0;
    margin: 0;

    font-size: 1.5rem;
    font-weight: 400;
    
    text-transform: uppercase;
    
    color: var(--admin-nav-group-header-foreground);
    
    user-select: none;
}

main#admin nav h2::before {
    content: "// ";
}

main#admin nav h2::after {
    content: " _";
}

main#admin nav ul {
    padding: 0;
    margin: 0;

    list-style: none;
}

main#admin nav ul li {
    margin-bottom: 2px;
    
    text-transform: uppercase;
}

main#admin nav ul li i {
    margin-top: -2px;
    
    vertical-align: middle;
    
    font-size: 1.3rem;
    
    color: var(--admin-icon-foreground);
}

main#admin nav ul li a {
    padding-left: 8px;
    margin-left: 3px;
    
    border-left: 6px solid var(--link-normal-foreground);
    
    font-size: 1.4rem;
    font-weight: 300;
    
    transition: 0.15s ease-out;
}

main#admin nav ul li a:hover {
    padding-left: 12px;
    
    border-left: 6px solid var(--link-normal-foreground);
}

main#admin nav .nav-group {
    margin-bottom: 13px;
}

main#admin nav .nav-group.separated {
    border-top: 1px dotted var(--admin-nav-group-border);
    padding-top: 16px;
}

main#admin nav .nav-group:last-of-type {
    margin: 0;
}

main#admin .admin-content {
    width: 100%;
    padding: 17px 20px 20px 20px;
}

main#admin .admin-inner-content {
    padding-left: 16px;
}

main#admin h1.admin-view-title {
    padding: 0;
    margin: 0 0 8px;

    font-size: 2rem;
    font-weight: 300;
    
    text-transform: uppercase;
    text-align: right;
}

main#admin h1.admin-view-title::before {
    content: "// ";
}

main#admin h1.admin-view-title::after {
    content: " _";
}

main#admin table.admin-table {
    display: block;
    
    overflow-y: scroll;
    height: 75%;
    min-height: 75%;

    border: 1px solid var(--admin-table-border);
    border-radius: 4px;
}

main#admin table.admin-table thead {
    top: 0;
    position: sticky;
    z-index: 2;

    text-transform: uppercase;
    
    box-shadow: 0 0 8px var(--admin-table-header-shadow);
    
    color: var(--admin-table-header-foreground);
    background-color: var(--admin-table-header-background);
}

main#admin table.admin-table thead th {
    width: 100%;
    border-bottom: 1px solid var(--admin-table-header-border);
}

main#admin table.admin-table th,
main#admin table.admin-table td {
    padding: 0.45em 0.5em 0.45em 0.5em;
    text-align: center;

    font-weight: 400;
}

main#admin table.admin-table td.title i {
    margin-right: 0.45em;
}

main#admin table.admin-table th.title {
    text-align: center; 
}

main#admin table.admin-table td.title {
    text-align: left;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 0;
}

main#admin table.admin-table th.category,
main#admin table.admin-table td.category {
    text-align: left;
    text-wrap: nowrap;
}

main#admin table.admin-table td.category.missing {
    opacity: 0.5;
}

main#admin table.admin-table th.author,
main#admin table.admin-table td.author {
    text-align: left;
    text-wrap: nowrap;
}

main#admin table.admin-table th.date-published {
    text-align: left;
    text-wrap: nowrap;
}

main#admin table.admin-table td.date-published {
    text-align: left;
    text-wrap: nowrap;
}

main#admin ul.content-tools-list {
    padding: 0;
    margin: 0 4px 0 0;

    display: flex;
    flex-direction: row;
    justify-content: center;
    gap: 18px;

    font-size: 1.3rem;

    list-style: none;
}

main#admin ul.content-tools-list li {
    display: inline-block;
}

main#admin .editor-toolbar {
    display: flex;
    flex-direction: row-reverse;
    gap: 16px;
    
    margin-top: -2px;
    margin-bottom: 8px;
}

main#admin .editor-toolbar .custom-checkbox {
    display: inline-block;
    margin-top: 4px;
}

.content-editor-container .safe,
.content-editor-container .media {
    height: 30px;
}

.link-manager {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.link-manager .nav-group {
    display: flex;
    flex-direction: row;
    align-items: center;
}

.nav-group-move-buttons {
    display: flex;
    flex-direction: column;
    align-content: space-between;
    margin-right: -40px;
    padding-left: 10px;
    padding-right: 11px;
    
    background-color: var(--link-manager-group-reorder-background);
    border-radius: 0 4px 4px 0;
}

.nav-group-name {
    display: flex;
    flex-direction: row;
    align-items: center;
    
    padding: 0;
    margin-top: -8px;
    margin-bottom: -12px;
}

.nav-group-name input[type="text"] {
    border: none;
    background: none;
    box-shadow: none;
    
    padding: 0;
    padding-left: 6px;
    
    font-size: 1.6rem;
    border-left: 1px solid var(--textbox-border);
    border-right: 1px solid var(--textbox-border);
}

.nav-group-name input[type="text"]:focus {
    box-shadow: none;
    background-color: var(--dual-value-container-textbox-focus-background);
    border-left: 4px solid var(--textbox-focus-border);
    border-right: 4px solid var(--textbox-focus-border);
}

.nav-group-name input[type="text"]:hover {
    border-left: 4px solid var(--textbox-border);
}

.nav-group-name a.add-new-link {
    cursor: default;

    align-self: center;

    margin-top: 7px;
    margin-left: 0;
    margin-right: 10px;
    font-size: 2rem;

    text-transform: uppercase;

    user-select: none;
}

.nav-group-name a.nav-group-delete {
    cursor: default;

    align-self: center;

    padding: 5px 0 5px 8px;
    margin-top: 6px;
    font-size: 2rem;

    text-transform: uppercase;

    user-select: none;
}

.nav-group-editor {
    display: flex;
    flex-direction: column;
    gap: 16px;
    
    width: 100%;
    
    overflow-y: scroll;
    max-height: 360px;

    border-radius: 4px;

    border-left: 1px solid var(--link-manager-nav-group-border);
    border-right: 1px solid var(--link-manager-nav-group-border);
    border-bottom: 6px solid var(--link-manager-nav-group-border);
    border-top: 6px solid var(--link-manager-nav-group-border);
    
    padding: 0.5rem;
}

.editor-toolbar .add {
    margin-right: auto;
}

.nav-group-move {
    padding-top: 3px;
    padding-bottom: 3px;
    
    text-align: center;
    transition: 0.15s ease-in-out;
}

.nav-group-row {
    display: flex;
    flex-direction: row;
}

.nav-group-row .dual-value-row {
    width: 100%;
}

.dashboard-header {
    display: flex;
    justify-content: flex-start;
    
    flex-direction: row;
    margin-right: auto;
    
    margin-top: -22px;
}

.dashboard-logo {
    align-self: center;
    opacity: 0;
    border: none;
    transition: 0.6s ease-in-out;
}

.dashboard-logo.visible {
    opacity: 0.8;
}

.dashboard-logo.visible:hover {
    border: none;
    opacity: 1;
}

.welcome-message {
    text-align: center;
    align-self: center;

    padding-top: 16px;
    padding-bottom: 16px;
    
    padding-left: 12px;
    border-right: 6px solid #cfaee9;
    
    margin-left: 24px;
        
    width: 0;
    overflow: hidden;
    text-wrap: nowrap;
    
    opacity: 0;
    
    font-family: "Vermin Vibes V";
    font-size: 1.4rem;
    
    color: #ff88ff;
    
    transition: 2s ease-in-out,
                border 0.3s ease-in-out,
                width 2s cubic-bezier(0.9, 0, 0.1, 1);
    
    user-select: none;
}

.welcome-message.visible {
    opacity: 0.8;
    width: 100%;
}

.stat-entry {
    display: flex;
    flex-direction: row;
    align-items: center;
    
    font-size: 1.5rem;
    border-left: 4px solid #ff88ff;
    border-right: 1px solid #ff88ff;
    background: #ff88ff11;
    
    padding-left: 12px;
    padding-right: 12px;
    
    transition: 0.3s ease-in-out;
    opacity: 0;
    
    margin-top: 1px;
}

.stat-name {
    width: 100%;
    
    color: #ff88ff;
    font-size: 1.6rem;
    text-transform: uppercase;
}

.stat-value {
    color: #73e4af;
    font-size: 2.5rem;
    font-weight: 300;
}

.stat-entry.visible {
    opacity: 1;
}


.modal-backdrop {
    display: flex;
    justify-content: center;
    align-items: center;

    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;

    opacity: 0;
    z-index: 3;

    background: none;
    backdrop-filter: blur(10px);
    transition: opacity 0.2s ease-in;

    pointer-events: none;
}

.modal-backdrop.open {
    background-color: var(--modal-backdrop-background);
    opacity: 1;
    pointer-events: all;
}

.modal-box {
    opacity: 0;
    width: 40%;

    transition: opacity 0.1s ease-in-out,
    transform 0.2s ease-in-out;
    transform: scale(1.3, 1.3);
}

.modal-box.open {
    opacity: 1;

    background-color: var(--modal-dialog-background);
    transform: scale(1, 1);
}

.modal-box-content {
    display: flex;
    flex-direction: column;

    padding-top: 6px;
}

.modal-box .modal-title {
    margin: 0 0 2px 10px;
    padding: 0;

    font-weight: 300;
    text-transform: uppercase;

    user-select: none;
}

.modal-box p {
    margin: 0 10px 24px 11px;

    padding: 0;

    word-break: break-word;

    user-select: none;
}

.modal-box .modal-actions {
    display: flex;
    flex-direction: row;
    gap: 24px;

    align-self: flex-end;
    padding-bottom: 20px;
    padding-right: 20px;
}

.modal-box .modal-caution-tape {
    height: 36px;
    margin: 1px 1px 0 1px;

    animation: slide-tape 0.85s linear infinite;

    background-repeat: repeat-x;
}

.modal-box.modal-danger .modal-caution-tape {
    background: repeating-linear-gradient(
            45deg,
            var(--modal-dialog-danger-tape-foreground),
            var(--modal-dialog-danger-tape-foreground) 18px,
            var(--modal-dialog-danger-tape-foreground2) 18px,
            var(--modal-dialog-danger-tape-foreground2) 36px
    );

    background-size: 51px 100%;
}

.modal-box.modal-danger {
    border: 1px solid var(--modal-dialog-danger-border);
    box-shadow: 0 0 8px var(--modal-dialog-danger-shadow);
}

.modal-box.modal-danger .modal-title {
    color: var(--modal-dialog-danger-title-foreground);
}

.modal-box.modal-danger .modal-message {
    color: var(--modal-dialog-danger-content-foreground);
}

.modal-box.modal-danger button {
    border-color: var(--modal-dialog-danger-button-border);
    color: var(--modal-dialog-danger-button-foreground);
}

.modal-box.modal-danger button:hover {
    border-color: var(--modal-dialog-danger-button-hover-border);
    color: var(--modal-dialog-danger-button-hover-foreground);

    text-shadow: 0 0 8px var(--modal-dialog-danger-button-hover-shadow);
}

.modal-box.modal-danger button:active {
    border-color: var(--modal-dialog-danger-button-active-border);
    color: var(--modal-dialog-danger-button-active-foreground);
}

.modal-box.modal-danger button:disabled {
    border-color: var(--modal-dialog-danger-button-disabled-border);
    color: var(--modal-dialog-danger-button-disabled-foreground);
}

.modal-box.modal-warning .modal-caution-tape {
    background: repeating-linear-gradient(
            45deg,
            var(--modal-dialog-warning-tape-foreground),
            var(--modal-dialog-warning-tape-foreground) 18px,
            var(--modal-dialog-warning-tape-foreground2) 18px,
            var(--modal-dialog-warning-tape-foreground2) 36px
    );

    background-size: 51px 100%;
}

.modal-box.modal-warning {
    border: 1px solid var(--modal-dialog-warning-border);
    box-shadow: 0 0 8px var(--modal-dialog-warning-shadow);
}

.modal-box.modal-warning .modal-title {
    color: var(--modal-dialog-warning-title-foreground);
}

.modal-box.modal-warning .modal-message {
    color: var(--modal-dialog-warning-content-foreground);
}

.modal-box.modal-warning button {
    border-color: var(--modal-dialog-warning-button-border);
    color: var(--modal-dialog-warning-button-foreground);
}

.modal-box.modal-warning button:hover {
    border-color: var(--modal-dialog-warning-button-hover-border);
    color: var(--modal-dialog-warning-button-hover-foreground);

    text-shadow: 0 0 8px var(--modal-dialog-warning-button-hover-shadow);
}

.modal-box.modal-warning button:active {
    border-color: var(--modal-dialog-warning-button-active-border);
    color: var(--modal-dialog-warning-button-active-foreground);
}

.modal-box.modal-warning button:disabled {
    border-color: var(--modal-dialog-warning-button-disabled-border);
    color: var(--modal-dialog-warning-button-disabled-foreground);
}

.modal-box.modal-information .modal-caution-tape {
    background: repeating-linear-gradient(
            45deg,
            var(--modal-dialog-information-tape-foreground),
            var(--modal-dialog-information-tape-foreground) 18px,
            var(--modal-dialog-information-tape-foreground2) 18px,
            var(--modal-dialog-information-tape-foreground2) 36px
    );

    background-size: 51px 100%;
}

.modal-box.modal-information {
    border: 1px solid var(--modal-dialog-information-border);
    box-shadow: 0 0 8px var(--modal-dialog-information-shadow);
}

.modal-box.modal-information .modal-title {
    color: var(--modal-dialog-information-title-foreground);
}

.modal-box.modal-information .modal-message {
    color: var(--modal-dialog-information-content-foreground);
}

@keyframes slide-tape {
    from {
        background-position: 0 0;
    }

    to {
        background-position: 51px 0;
    }
}

.error-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    margin: 0 auto;
    height: 100%;
}

.error-content {
    margin-top: -20px;
    align-self: center;
}

.error-container .icon {
    margin: 0 auto;

    text-align: center;
    font-size: 20rem;

    opacity: 0;
    color: var(--404-icon-foreground);

    transition: 2s ease-in-out;
}

.error-container .message {
    margin-top: -6.2rem;

    text-align: center;
}

.error-container .message-title {
    margin-bottom: 1rem;

    height: 0;

    font-size: 6rem;

    opacity: 0;

    transition: opacity 0.2s ease-in-out,
    height 0.3s cubic-bezier(0.9, 0, 0.1, 1);

    color: var(--404-title-foreground);
}

.error-container .message-subtitle {
    margin-top: -20px;

    opacity: 0;
    height: 0;
    font-size: 2rem;

    text-transform: uppercase;

    transition: opacity 0.2s ease-in-out,
    height 0.3s cubic-bezier(0.9, 0, 0.1, 1);

    color: var(--404-subtitle-foreground);
}

.error-container a {
    display: block;

    height: 0;

    margin-top: 2rem;

    text-align: center;

    font-size: 1.8rem;

    text-transform: uppercase;

    opacity: 0;

    transition: 0.15s ease-in-out,
    opacity 0.2s ease-in-out,
    height 0.3s cubic-bezier(0.9, 0, 0.1, 1);
}

.error-container .visible {
    opacity: 1;
}

.error-container .message-title.visible {
    height: 6rem;
}

.error-container .message-subtitle.visible {
    height: 2rem;
}

.error-container a.visible {
    height: 1.8rem;
}

.modal-box.modal-media {
    border: 1px solid var(--modal-media-border);
    padding: 0.75rem;

    width: 80%;
    max-height: 60%;

    overflow-y: scroll;
}

.modal-box.modal-media h1 {
    font-weight: 300;
    padding: 0 0 0.5rem 0;
    margin: 0;
    text-transform: uppercase;
}

.modal-media .media-list {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: stretch;
    gap: 4px;
}

.modal-media .media-list .media-entry {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 1rem;

    width: 100%;

    padding: 0 0.25rem 0.25rem 0.25rem;
    border-bottom: 1px dotted var(--modal-media-border);
}

.modal-media .media-list .media-entry:last-of-type {
    border-bottom: none;
}

.modal-media .media-list .media-filename {
    width: 100%;
    text-wrap: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.modal-media .media-list .media-thumbnail {
    display: block;

    overflow: clip;

    width: 15%;
    min-width: 15%;
    max-width: 15%;

    background: var(--thumbnail-background);
}

.modal-media .media-file-not-image {
    display: flex;
    justify-content: center;
    align-items: center;

    padding: 0.25rem;
    padding-top: 0.35rem;

    text-align: center;
    font-size: 1.8rem;

    border-radius: 4px;
    border: 1px solid var(--image-border);
}

.modal-media .media-list .media-actions {
    display: flex;
    gap: 0.75rem;
    font-size: 1.2rem;
}

.modal-media .media-list .media-actions a {
    display: flex;
    flex-direction: row;
    align-items: center;
    text-wrap: nowrap;
}

.modal-media .media-list .media-actions i {
    margin-top: -2px;
    margin-right: 0.25rem;
}

.modal-media .modal-media-titlebar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;

    padding-left: 4px;
    padding-right: 4px;
    padding-bottom: 0.75rem;
}

.modal-media .modal-media-uploader {
    display: flex;
    gap: 1rem;
}

.modal-media label.file-input::before {
    content: none !important;
}

.modal-media-uploader label.file-input {
    display: block;

    margin: 0;
    padding: 0;
    padding-top: 4px;
    padding-bottom: 4px;
    padding-left: 8px;

    font-size: 1.5rem;

    border-left: 8px solid var(--button-border);

    color: var(--button-foreground);

    transition: 0.15s ease-in-out;
}

.modal-media-uploader label.file-input:hover {
    display: block;

    font-size: 1.5rem;

    border-left-color: var(--button-hover-border);

    color: var(--button-hover-foreground);
}

.modal-media-uploader label.file-input:active {
    display: block;

    font-size: 1.5rem;

    border-left-color: var(--button-active-border);

    color: var(--button-active-foreground);
}

.user-edit-list {
    display: flex;
    flex-direction: column;
    
    gap: 1rem;
}

.user-editor-entry {
    padding: 0.5rem 0.75rem 0.25rem 0.75rem;
    
    border-radius: 4px;
    border: 1px solid var(--user-editor-border);
    border-top: 6px solid var(--user-editor-border);
    border-bottom: 6px solid var(--user-editor-border);
}

.user-entry-toolbar {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
}

#custom-pattern-match-edit-field,
#custom-pattern-replace-edit-field {
    font-family: "NK57 Monospace", monospace;
    font-size: 14px;
    font-weight: 300;
}