:root {
    --color-white: #ffffff;
    --color-black: #333333;
    --color-black-transparent: #00000088;
    --color-theme1: #c4801f;
    --color-theme2: #073949;
    --color-border: #00000022;
    --color-grey: #888888;
    --color-dark-grey: #666666;
    --color-light-grey: #f0f0f0;
    --color-error: #944949;
    --color-success: #468c46;
    --color-light-yellow: #fff8f0;
    --color-new: #468c46;

    --border-radius: .25rem;

    --line-height: 1.6;

    --max-page-width: 40rem;
    --max-width: 20rem;

    --shadow: 0 2px 6px rgba(0, 0, 0, 0.1), 0 4px 12px rgba(0, 0, 0, 0.1);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: inherit;
    line-height: 1;
    min-width: 0;
    min-height: 0;
}

html {
    color: var(--color-black);
    font-family: system-ui, medium-content-sans-serif-font, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
}

body {
    background: var(--color-white);
    hyphens: auto;
}

html,
body {
    height: 100%;
}

a {
    color: inherit;
    line-height: inherit;
    text-decoration-style: dotted;
    text-decoration-thickness: from-font;
}

h1 {
    font-size: 1rem;
    font-weight: normal;
    color: var(--color-theme2);
}

h2 {
    font-size: 1.6rem;
    padding: 1rem 0;
    font-weight: normal;
    color: var(--color-theme1);
}

h3 {
    font-size: 1.6rem;
    color: var(--color-theme2);
    font-weight: normal;
    padding-bottom: 1rem;
}

h4 {
    font-size: 1.2rem;
    color: var(--color-theme1);
    font-weight: normal;
    padding-bottom: 0.5rem;
}

ul,
ol {
    margin-left: 1rem;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
th,
td,
li,
label,
code.block,
blockquote {
    line-height: var(--line-height);
}

p,
ul,
ol {
    margin-bottom: 2rem;
}

li {
    margin-bottom: 0.5rem;
}

li ul,
li ol {
    margin-bottom: 0;
}

table {
    border-collapse: collapse;
    margin-bottom: 1rem;
}

table.alternate tr:nth-child(even) td {
    background: var(--color-light-yellow);
}

table.wide {
    width: 100%;
}

th,
td {
    padding: 0.5rem 1rem;
    text-align: left;
    vertical-align: top;
}

th {
    font-weight: normal;
    color: var(--color-theme1);
    font-size: 0.9rem;
}

table.compact th,
table.compact td {
    padding: 0.25rem 0.5rem;
}

table th:first-child,
table td:first-child {
    padding-left: 0;
}

table th:last-child,
table td:last-child {
    padding-right: 0;
}

label {
    font-style: italic;
    margin-bottom: 1rem;
    display: block;
    max-width: var(--max-width);
    color: var(--color-theme2);
}

label.inline {
    display: inline-block;
    margin-right: 1rem;
    vertical-align: top;
}

label * {
    font-style: normal;
    color: var(--color-black);
}

label > small {
    display: block;
    line-height: inherit;
}

label img.preview {
    display: block;
    width: 100%;
    object-fit: contain;
    max-height: var(--max-width);
    background: var(--color-border);
}

input[type=text],
input[type=password],
input[type=file],
input[type=email],
input[type=tel],
input[type=number],
input[type=date],
input[type=time],
textarea,
select,
[contenteditable] {
    display: block;
    border: 1px solid var(--color-border);
    background: var(--color-white);
    color: var(--color-black);
    padding: 0.5rem;
    margin: 0.25rem 0;
    font-size: 1rem;
    font-family: inherit;
    width: 100%;
    transition: background 0.3s, border-color 0.3s;
    line-height: 1;
    box-shadow: inset 0 2px 10px var(--color-border);
    border-radius: var(--border-radius);
}

textarea,
[contenteditable] {
    max-width: 100%;
    min-width: 100%;
    height: 10rem;
    line-height: var(--line-height);
}

[contenteditable] {
    height: auto;
    min-height: 2.5rem;
}

input[type=text]:focus,
input[type=password]:focus,
input[type=file]:focus,
input[type=email]:focus,
input[type=tel]:focus,
input[type=number]:focus,
input[type=date]:focus,
input[type=time]:focus,
textarea:focus,
select:focus {
    background-color: var(--color-light-yellow);
}

input[type=text]:disabled,
input[type=password]:disabled,
input[type=file]:disabled,
input[type=email]:disabled,
input[type=tel]:disabled,
input[type=number]:disabled,
input[type=date]:disabled,
input[type=time]:disabled,
input[type=checkbox]:disabled,
textarea:disabled,
select:disabled,
button:disabled {
    background-color: var(--color-border);
    cursor: not-allowed;
}

input[type=text]:required:invalid,
input[type=password]:required:invalid,
input[type=file]:required:invalid,
input[type=email]:required:invalid,
input[type=tel]:required:invalid,
input[type=number]:required:invalid,
input[type=date]:required:invalid,
input[type=time]:required:invalid,
textarea:required:invalid,
select:required:invalid {
    border-left: 2px solid var(--color-error);
}

input[type=text]:required:valid,
input[type=password]:required:valid,
input[type=file]:required:valid,
input[type=email]:required:valid,
input[type=tel]:required:valid,
input[type=number]:required:valid,
input[type=date]:required:valid,
input[type=time]:required:valid,
textarea:required:valid,
select:required:valid {
    border-left: 2px solid var(--color-success);
}

input[type=radio]:required:invalid,
input[type=checkbox]:required:invalid {
    box-shadow: -1px 0 0 var(--color-error),
    1px 0 0 var(--color-error),
    0 -1px 0 var(--color-error),
    0 1px 0 var(--color-error);
}

:not(output):-moz-ui-invalid {
    /* Firefox required:invalid glow fix */
    box-shadow: none;
}

:not(output):-moz-ui-invalid:-moz-focusring {
    /* Firefox required:invalid glow fix */
    box-shadow: none;
}

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: var(--color-white) url('images/options_arrow.svg') no-repeat right 50%;
    background-size: contain;
}

select option {
    line-height: 1;
}

select:focus {
    background-image: url('images/options_arrow_active.svg');
}

small,
time {
    color: var(--color-grey);
    font-size: 0.9rem;
}

hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 2rem 0;
}

button {
    background: var(--color-theme1);
    border: none;
    cursor: pointer;
    font-size: 1rem;
    padding: 1rem;
    color: var(--color-white);
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
    text-decoration: none;
    display: inline-block;
    border-radius: var(--border-radius);
}

button.neutral {
    color: var(--color-black);
    background: var(--color-light-grey);
}

button[type=submit] {
    color: var(--color-white);
    background: var(--color-theme2);
}

button.small {
    padding: 0.5rem 1rem;
}

button.tiny {
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
}

button.vote {
    text-align: center;
    padding: 0.5rem;
    font-size: 0.6rem;
    border-radius: 1rem;
    color: var(--color-black);
    background: var(--color-light-grey);
}

progress {
    display: block;
    width: 100%;
}

code {
    font-family: monospace;
    padding: 0.25rem;
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
    background: var(--color-light-grey);
}

code.block {
    padding: 0.5rem;
    display: block;
    white-space: pre-wrap;
    margin: 0.5rem 0;
}

blockquote {
    display: block;
    padding-left: 0.5rem;
    margin: 0.5rem 0;
    border-left: 1px solid var(--color-theme1);
}

#message,
#baseMessage {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    padding: 1rem;
    background: var(--color-success);
    color: var(--color-white);
    font-weight: bold;
    box-shadow: 0 .25em .5em var(--color-border), 0 .5em 1em var(--color-border);
    z-index: 10000;
}

#message.error {
    background: var(--color-error);
}

#baseMessage {
    -webkit-animation: 0.3s 4s message_ani forwards ease-in;
    animation: 0.3s 4s message_ani forwards ease-in;
}

#loader {
    position: fixed;
    background: transparent;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
}

#loader:after {
    content: '';
    width: 4rem;
    height: 4rem;
    display: block;
    position: absolute;
    left: 50%;
    margin-left: -2rem;
    top: 0.5rem;
    background: url('images/spinner.svg') 50% no-repeat;
    background-size: contain;
}

#top {
    border-bottom: 1px solid var(--color-border);
    padding: 1rem 2rem;
    text-align: center;
}

#appName {
    text-decoration: none;
}

#menu {
    padding: 0 2rem;
    border-bottom: 1px solid var(--color-border);
}

#menu nav {
    background: #ffffffcc;
    display: flex;
    justify-content: center;
    align-items: center;
}

#accountName {
    flex-grow: 1;
    text-align: right;
}

#menu nav a {
    display: inline-block;
    padding: 1rem 1rem;
    text-decoration: none;
}

#menu nav a.selected {
    color: var(--color-theme1);
    font-weight: bold;
}

#page {
    padding: 1rem 2rem 4rem 2rem;
    max-width: var(--max-page-width);
    margin: 0 auto;
}

#page.editor {
    max-width: calc(var(--max-page-width) * 2);
}

#splitView {
    display: flex;
    gap: 2rem;
}

#splitView > * {
    width: 50%;
}

#preview {
}

#comments .comment {
    padding-top: 1rem;
}

#comments .comment header {
    font-size: 0.8rem;
    line-height: var(--line-height);
    color: var(--color-grey);
    margin-bottom: 0.5rem;
}

#comments .comment p {
    margin-bottom: 0.5rem;
}

#comments .comment .vote {
    padding: 0.25rem;
}

#comments .comment .comment {
    margin-left: 2rem;
}

#markdownHints {
    margin-top: 2rem;
    font-size: 0.8rem;
    padding: 1rem 1rem 0 1rem;
    background: var(--color-light-yellow);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
}

.posts {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.posts .post {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: column;
    border-bottom: 1px solid var(--color-border);
    text-decoration: none;
}

.posts .post > img,
.post-image {
    flex-grow: 1;
    width: 100%;
    height: var(--max-width);
    object-fit: cover;
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
    transition: height 1s;
}

.posts .post > p {
    margin-bottom: 0;
}

.post .post-image {
    margin-bottom: 1rem;
}

.posts .post header {
    font-size: 0.8rem;
    padding: 1rem 0;
    display: flex;
    gap: 1rem;
    align-items: center;
    justify-content: space-between;
}

.profile-display {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    font-weight: bold;
    text-decoration: none;
}

.profile-img {
    width: 2rem;
    height: 2rem;
    object-fit: cover;
    border-radius: var(--border-radius);
}

.post-meta {
    font-size: 0.8rem;
    text-align: right;
    line-height: var(--line-height);
}

.tar {
    text-align: right;
}

.right {
    float: right;
}

.mb0 {
    margin-bottom: 0;
}

.call2action {
    display: inline-block;
    padding: 1rem;
    margin: 1rem 0;
    background: var(--color-theme2);
    color: var(--color-white);
    font-weight: bold;
    text-decoration: none;
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
}

.new {
    color: var(--color-new);
}

.next:after {
    content: ' ➙';
}

.modal {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: var(--color-black-transparent);
    z-index: 10000;
}

.modal .panel {
    position: fixed;
    left: 4rem;
    top: 4rem;
    bottom: 4rem;
    right: 4rem;
    padding: 1rem;
    background: var(--color-white);
    box-shadow: 0 .5rem 1rem var(--color-border);
    overflow: auto;
}

.modal .popup {
    position: absolute;
    left: 50%;
    top: 3rem;
    width: 600px;
    max-height: calc(100vh - 6rem);
    overflow: auto;
    margin-left: -300px;
    background: var(--color-white);
    padding: 1rem;
    box-shadow: 0 .5rem 1rem var(--color-border);
}

.modal .close {
    float: right;
}

.loader {
    display: inline-block;
    width: 2em;
    height: 2em;
    margin-top: -0.5rem;
    margin-bottom: -0.5rem;
    background: url('images/spinner.svg') 50% no-repeat;
    background-size: contain;
}

.error {
    color: var(--color-error);
    font-weight: bold;
    line-height: var(--line-height);
}

.page-header {
    margin-bottom: 1rem;
    padding: 1rem 0 0.5rem 0;
    border-bottom: 1px solid var(--color-border);
    display: flex;
    gap: 1rem;
    justify-content: flex-end;
    align-items: baseline;
}

.page-header h2 {
    padding: 0;
}

.page-header *:first-child {
    flex-grow: 1;
}

.tabs {
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--color-border);
    display: flex;
}

.tabs > * {
    display: inline-block;
    padding: 1rem;
    text-decoration: none;
    background: var(--color-light-grey);
    border: 1px solid var(--color-border);
    margin: 0 -1px -1px 0;
    cursor: pointer;
}

.tabs > *.selected {
    background: var(--color-white);
    border-bottom: 1px solid var(--color-white);
}

.flex {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.flex > * {
    width: var(--max-width);
}

.content-editor {
    margin: 2rem 0;
    font-weight: bold;
    line-height: var(--line-height);
}

.content-editor * {
    font-weight: normal;
}

.content-editor .list-item {
    height: auto;
}

.edit-image-container {
    position: relative; overflow: hidden;
}

.edit-image-container .image {
    width: 100%;
    height: auto;
    cursor: pointer;
    border-radius: var(--border-radius);
}

.edit-image-container .focus-point {
    position: absolute;
    z-index: 1;
    border: 4px solid var(--color-white);
    width: 4rem;
    height: 4rem;
    border-radius: 2rem;
    margin-left: -2rem;
    margin-top: -2rem;
    box-shadow: var(--shadow), inset var(--shadow);
}

[v-cloak] {
    display: none;
}

@keyframes message_ani {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(-110%);
    }
}