/* SmolWeb Grade A Compliant Stylesheet - Permanent Dark Theme */
.skip-link:not(:focus) {
    display: block;
    height: 1px;
    width: 1px;
    text-indent: -999px;
    white-space: nowrap;
}
.skip-link:focus {
    display: block;
    padding: 10px;
    background-color: #ffff00;
    color: #1a1a1a;
    font-weight: bold;
    text-align: center;
    text-indent: 0;
    height: auto;
    width: auto;
}
body {
    font-family: system-ui, -apple-system, sans-serif;
    font-size: 18px; /* Slightly larger base for mobile readability */
    line-height: 1.5;
    margin: 15px;
    background-color: #1a1a1a;
    color: #eeeeee;
}

header,
main,
footer {
    margin-bottom: 25px;
}

nav {
    border-bottom: 1px solid #444444;
    padding-bottom: 10px;
    margin-bottom: 20px;
}

footer {
    border-top: 1px solid #444444;
    padding-top: 10px;
    font-size: 0.8em;
    color: #aaaaaa;
}

pre {
    font-family: monospace;
    font-size: 0.7em;
    background-color: #2a2a2a;
    padding: 10px;
    border: 1px solid #444444;
    white-space: pre;
}

.logo {
    font-family: fantasy;
    font-size: 2em;
    font-weight: normal;
    text-transform: uppercase;
    margin: 20px 0;
    line-height: 1.2;
    color: #ffffff;
}

.logo-highlight {
    background-color: #ffff00; /* Classic Yellow */
    color: #1a1a1a;
    padding: 2px 6px;
    margin-right: 5px;
}

a {
    color: #88ccff;
    text-decoration: underline;
}

a:hover {
    text-decoration: none;
}

h1,
h2,
h3 {
    line-height: 1.2;
}

cite {
    display: block;
    border-left: 3px solid #444444;
    padding-left: 15px;
    font-style: italic;
    margin: 15px 0;
}
