* {
    line-height: 135%;
}

.no-select, br {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    cursor: default;
}

h1, h2, h3, h4, h5, h6, p, a, ul, ol, li {
    margin: clamp(0.25vw, 0.5rem, 2vw) 0;
}

h2, h3 {
    margin-top: clamp(1vw, 2rem, 8vw);
}

.text-display, h1 {
    font-size: clamp(1.372vw, 2.744rem, 10.976vw);
}

.text-subdisplay, h2, h3 {
    font-size: clamp(0.86vw, 1.96rem, 7.84vw);
}

body, .text-body {
    font-size: clamp(0.7vw, 1.4rem, 5.6vw);
}

.text-micro {
    font-size: clamp(0.5vw, 1rem, 4vw);
}

h1, h2, h3, a, button, .sans-serif, .text-display, .text-subdisplay, .text-micro {
    font-family: rosario, -apple-system, Roboto, 'Segoe UI', 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

h1, h2, h3, h4, h5, h6, .text-display {
    font-weight: 700;
}

html, body, .text-body {
    font-weight: 400;
    font-family: adobe-garamond-pro, 'Times New Roman', Times, serif;
}

.text-micro {
    font-weight: 400;
}

input, .monospace {
    font-family: calling-code, 'Cascadia Code', Consolas, 'DejaVu Sans Mono', Menlo, Monaco, monospace;
}

.italic {
    font-style: italic;
}

html, body {
    font-weight: 400;

    margin: 0;
    padding: 0;
}

#main {
    width: clamp(40vw, 40rem, 90vw);
    margin: 0.75em auto;
    padding: 0.25em;
}

#footer {
    display: table;
    text-align: center;
    color: #6a6a6a;

    margin: 1em auto 0.5em auto;
    width: 100%;

    border: solid #6a6a6a;
    border-width: 1px 0 0 0;
    padding-top: clamp(0.25vw, 0.5rem, 2vw);
}

p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
}

a {
    color: rgb(0, 128, 240);
    text-decoration: none;
}

ul, ol {
    margin: 0.3em 1em;
    padding: 0;
}

h1 {
    font-weight: 600;
    padding-top: 0;
}

h2 {
    font-weight: 600;
    padding-top: 0;
}

button {
    font-size: max(1em, calc(2.5 * max(1vh, 1vh)));
    cursor: pointer;
    padding: 0.2em 0.25em 0.1em 0.25em;
}

textarea {
    font-size: max(0.7em, calc(1.75 * max(1vh, 1vh)));
    cursor: text;
    padding: 0.4em 0.4em 0.3em 0.4em;
    margin: 0.1em;
    width: 90%;
    resize: vertical;

    -webkit-hyphens: none;
    -moz-hyphens: none;
    hyphens: none;
}
