/*@import "colorschemes/catppuccin-macchiato.css";*/

body {
    font-family: sans-serif;
    margin: 0;
    color: var(--foreground);
    background-color: var(--background);
    text-align: left;
}

ul {
    list-style-type: square;
}

hr {
    border: 1px solid var(--foreground);
    border-bottom: none;
}

div.page {
    min-width: 780px;
    max-width: 800px;
    padding-left: 0.5em;
    padding-right: 0.5em;
    margin: auto;
}

h1.inline {
    margin-top: 0;
    clear: none;
    display: inline;
}

h1,
h2,
h3 {
    margin-top: 1em;
    clear: left;
}

img {
    border: none;
    max-width: 100%;
}

img.right {
    float: right;
    margin-left: 0.5em;
}

table.form td {
    border: none;
}

/* -------------------------------------------------------------------------- */

div.code-block {
    background-color: var(--background);
    border: 2px solid var(--foreground);
    padding: 10px;
    display: inline-block;
    text-align: left;
    max-width: 90%;
    min-width: 400px;
    margin: 10px;
}

div.code-block hr {
    margin-top: 5px;
    margin-bottom: 5px;
}

div.code-block h1 {
    margin: 0;
    font-family: monospace;
}

div.code-block h1 small {
    color: var(--foreground);
    font-size: 12px;
}

div.code-block pre hr {
    margin-bottom: 5px;
}

div.code-block pre code {
    background-color: var(--background);
}

pre {
    display: inline;
    max-width: 95%;
    overflow: auto;
}

.header a {
    text-decoration: none;
}

.theme-selector {
    text-align: right;
    vertical-align: middle;
}

.nav-wrapper {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 0;
    grid-row-gap: 0;
}

.nav-wrapper div:nth-child(2) {
    text-align: right;
}

.theme-selector label {
    font-weight: bold;
}

.theme-selector label::after {
    content: ': ';
}

nav {
    margin-bottom: 0.3em;
    text-align: left;
}

nav img {
    width: 32px;
}

nav h1 {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
        Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue",
        sans-serif;
    font-weight: normal;
    font-size: 30px;
    margin: 10px 10px 10px 0;
}

div.date {
    text-align: center;
}

div.note {
    font-style: italic;
}

table {
    border-collapse: collapse;
    border-color: var(--foreground);
}

table.weather th {
    font-weight: normal;
}

table.weather td {
    font-weight: bold;
    text-align: right;
}

div.rss {
    position: absolute;
    top: 1em;
    right: 1em;
}

div.archived {
    margin-top: 0.5em;
}

div.archived span.date {
    font-style: italic;
    margin-right: 0.2em;
}

video {
    max-width: 100%;
}

table td {
    border: 1px solid var(--foreground);
}

td {
    padding: 0;
    vertical-align: top;
}

.header .title {
    color: var(--foreground);
}

.header {
    font-size: 100%;
    font-weight: normal;
    padding-bottom: 0;
    text-align: center;
}

h1 {
    font-size: 150%;
}
h1 {
    font-size: 150%;
}

h2 {
    font-size: 130%;
}

h3 {
    font-size: 115%;
}

table.computers {
    width: 100%;
}

table.computers td:first-child {
    text-align: center;
    font-weight: bold;
}
table.computers td ul {
    margin: 0;
    padding-left: 20px;
}

table.computers .section-title {
    text-decoration: underline;
    font-style: italic;
    font-weight: bold;
}

table.computers p.description {
    font-style: italic;
    margin: 5px 0 2px 0;
}

table.computers th {
    background-color: var(--background-secondary);
}

table.computers td,
table.computers th {
    border: var(--foreground) solid 1px;
    padding: 5px;
}



img.pixel {
    image-rendering: pixelated;
}

div.footer {
    text-align: center;
    margin-bottom: 5px;
}

div.footer a.button {
    text-decoration: none;
}

table.commits tr td {
    border: none;
    padding-right: 5px;
}

a {
    color: var(--links);
    text-decoration: underline dotted;
}

table.form tr td {
    border: none;
}

table.form tr td label {
    padding-right: 5px;
}

table.form tr td span.text-danger {
    padding-left: 5px;
    color: var(--warning);
}

input.file {
    border: 0 !important;
}

table.form tr td textarea,
table.form tr td input,
table.form tr td button,
form.import input::file-selector-button,
form.import button {
    background-color: var(--background);
    border: var(--foreground) solid 1px;
}

table.form label {
    margin: 5px 0;
}

form.import button,
form.import input::file-selector-button,
table.form tr td button {
    color: var(--foreground);
    background-color: var(--background-secondary);
}

form.import button:hover,
form.import input::file-selector-button:hover,
table.form tr td button:hover {
    color: var(--background);
    background-color: var(--foreground);
}

table.gb-entry-form-container {
    width: 100%;
}

table.gb-entry-form-container tr td {
    border: none;
    vertical-align: top;
}

table.gb-entry-form-container tr td p,
table.gb-entry-form-container tr td ul {
    margin: 0;
}

table.form tbody tr td textarea {
    width: 210px;
}

table.gb-entry tr td {
    border: solid var(--foreground) 1px;
    width: 500px;
    vertical-align: top;
    padding: 5px;
}

table.gb-entry {
    margin-bottom: 5px;
}

table.gb-entry hr {
    border: 1px dotted var(--foreground);
    border-bottom: none;
}

table.gb-entry address {
    font-size: 0.8pc;
}

table.gb-admin {
    margin-bottom: 5px;
    width: 500px;
    border: var(--foreground) solid;
}

table.gb-admin tr td {
    border-right: none;
    border-bottom: none;
    vertical-align: top;
    padding: 5px;
}

table.gb-admin tr td.gb-del {
    border-left: none;
    vertical-align: top;
    padding: 5px;
    width: 32px;
}

table.gb-admin tr td.gb-message {
    border-top: none;
    vertical-align: top;
    padding: 5px;
}

table.info-table tr td {
    border: none;
    padding-right: 5px;
}

table.info-table {
    width: 100%;
}

table.info-table tr td h1,
table.info-table tr td h2,
table.info-table tr td small {
    margin: 0;
}

caption h1,
caption h2 {
    margin: 0;
}

caption {
    text-align: left;
}

table.info-table tr td small {
    margin-bottom: 5px;
}
.me img {
    float: right;
    margin: 5px;
}

.me p {
    text-align: justify;
}

a:hover {
    text-decoration: underline;
}

.spec {
    padding-left: 20px;
}

.spec-title {
    font-weight: bold;
}

.project-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(0, 1fr);
    grid-column-gap: 0;
    grid-row-gap: 0;
    height: 100%;
}

.project-grid div {
    padding: 5px;
}

.project-section-title,
.project-grid div h1,
.project-grid div p {
    margin: 5px 0;
}

.project-section-title {
    margin-top: 20px;
    padding-bottom: 5px;
    border-bottom: 1px solid var(--foreground);
}

.project-grid div h1 {
    margin-top: 10px;
}

.project-grid div a {
    text-decoration: underline dotted;
    padding: 2px 2px 0 2px;
    margin: 0;
    font-size: 10pt;
}

.project-grid .project-links a {
    color: var(--links);
    border: 1px solid var(--foreground);
    border-left: none;
}

.project-grid .project-links a:first-child {
    border: 1px solid var(--foreground);
}

.project-grid .project-links a:hover {
    background-color: var(--foreground);
    color: var(--background);
}

.error-box {
    width: 500px;
    border: 5px solid var(--warning-box-border);
    background-color: var(--warning-box-bg);
    padding: 5px;
}
.error-box a,
.error-box p {
    margin: 0;
    color: var(--foreground)
}

label[for="scheme-selector"] {
    font-weight: bold;
}

#scheme-selector {
    border: var(--foreground) solid 1px;
    background-color: var(--background-secondary);
    color: var(--foreground)
}


.music-top10 td,
.music-top10 th {
    border: none;
    border-left: 1px dotted var(--foreground);
    padding: 2px 5px
}

.music-top10 tr:nth-child(1) th {
    border-bottom: 1px dotted var(--foreground);
}

.music-top10 tr:nth-child(2) td {
    padding-top: 5px;
}

.music-top10 td:first-child,
.music-top10 th:first-child {
    border: none;
}

.music-top10 tr th:first-child {
    text-align: right;
}

.music-top10 td {
    white-space: nowrap; text-overflow:ellipsis; overflow: hidden;
}

.music-top10 tr td:first-child {
    text-align: right;
}

.music-top10 tr td:nth-child(2),
.music-top10 tr td:nth-child(3) {
    width: 50%;
}

.current-track {
    width: 100%;
}

.current-track h2 {
    margin: 0;
}

.info-section ul {
    list-style-position: inside;
    list-style-type: none;
    padding-left: 0;
    margin: 0;
}

.info-section ul li:before {
    content: "◆ ";
}

.info-section h2 {
    margin: 0;
}

.info-section p {
    margin-top: 10px;
}

.contact-section {
    display: grid;
    grid-template-rows: 1fr 1fr;
}

.banner {
    padding: 5px;
    margin-top: 10px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 0;
    grid-row-gap: 0;
}

.banner div:nth-child(1) {
    text-align: left;
}

.banner div:nth-child(2) {
    text-align: right;
}

.red-banner {
    border: 3px solid var(--foreground);
    background-color: var(--background-secondary);
}

.info-admin td,
.info-admin th {
    border: 1px solid var(--foreground);
    padding: 5px;
}

.info-admin th {
    background-color: var(--background-secondary);
}

.info-admin th.blank {
    border: none;
    background-color: var(--background);
}

.info-admin button {
    border: 1px solid var(--foreground);
    background-color: var(--background);
    color: var(--foreground);
}

.info-admin button:hover {
    background-color: var(--foreground);
    color: var(--background);
}

.info-admin button:active {
    background-color: var(--background-secondary);
    color: var(--foreground);
}

.info-admin-section h2 {
    margin-bottom: 5px;
}

.fullwidth {
    width: 100%;
}

.fullwidth td:last-child {
    width: 0;
}

.guestbook-message {
    text-wrap: wrap;
    width: 100%;
}

td.diagonal-line {
    background: linear-gradient(to right bottom, var(--background) 0%,var(--background) 49.9%,var(--foreground) 50%,var(--foreground) 51%,var(--background) 51.1%,var(--background) 100%);
}

form.import h2 {
    margin: 10px 0 5px 0;
}