body, html {
	margin: 0px; padding: 0px; width: 100%; height: 100%;
}

/* modify these on other pages to change colors */
.chatbox {
	--bg: var(--l-blue);
	--borders: var(--blue);
	--header: var(--green);
	--header-text: var(--d-blue);
	--header-hover: var(--white);
	--header-popup: var(--l-green);
	--bubble-bg: var(--white);
	--bubble-shadow: var(--blue);
	--bubble-text: var(--blue);
	--username: var(--d-blue);
	--mod: var(--pink);
	--mod-border: var(--l-pink);
	--admin: var(--orange);
	--admin-border: var(--yellow);
	--input-box-bg: var(--yellow);
	--input-box-focus: var(--l-green);
	--input-box-text: var(--d-blue);
	--send-bg: var(--green);
	--send: var(--d-blue);
	--send-hover: var(--white);
	--font: 'Yet R', sans-serif;
}

.chatbox {
	background: var(--bg);
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	font-family: var(--font);
}

.chatbox > header {
	position: relative;
	background: var(--header);
	border-bottom: 4px var(--borders) solid;
	padding: .3rem .75rem;
	font-size: 1.25rem;
	text-align: right;
	a, a:link, a:visited, button {
		color: var(--header-text);
		&:hover, &:focus, &:focus-visible {
			color: var(--header-hover);
		}
	}
	#page-settings-contents { font-size: 1.15rem; }
}
button.open-page-settings, #page-settings-contents {
	--open-button-fill: var(--header-text);
	--open-button-background: none;
	--open-button-border: none;
	--color: inherit;
	--accent: var(--d-blue);
}
button.open-page-settings:hover * { fill: var(--header-hover); stroke: var(--header-hover); }
button.open-page-settings {
  position: relative;
	padding: .25em;
	margin: -.3em;
	top: .1em; right: 0;
	display: inline-block;
  color: var(--open-button-fill);
  background: var(--open-button-background);
  border: var(--open-button-border);
  font-size: 1em;
  line-height: 0;
  border-radius: 50%;
}
#page-settings-contents {
	position: absolute;
	top: 100%;
	margin: 0;
	border-radius: 0 0 0 1rem;
	z-index: 1000;
	box-shadow: 5px 5px var(--borders);
	moz-box-sizing: border-box; webkit-box-sizing: border-box; box-sizing: border-box;
	right: 0;
	max-width: min(100%, 22rem);
	background: var(--header-popup);
}

.messages {
	display: flex;
	flex-flow: column-reverse nowrap;
	flex-grow: 1;
	overflow-y: auto;
	gap: .75rem;
	padding: 1rem .75rem;
	moz-box-sizing: border-box; webkit-box-sizing: border-box; box-sizing: border-box;
	color: var(--bubble-text);
}

.message {
	width: min(90%, 40rem);
	display: flex;
	gap: .5rem;
	font-size: 1rem;
	padding: .5em .85em .75em .75em;
	moz-box-sizing: border-box; webkit-box-sizing: border-box; box-sizing: border-box;
	background: var(--bubble-bg);
	box-shadow: 4px 6px var(--bubble-shadow);
	margin-bottom: 4px;
	border-radius: 1rem 1rem 1rem 0;
}
.message.self {
	border-radius: 1rem 1rem 0 1rem;
	margin-left: auto;
}

.message .bubble { width: 100%; }
.message .bubble header {
	margin-bottom: .15rem;
	width: 100%;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	@media screen and (width < 450px) {
		flex-direction: column;
		align-items: flex-start;
	}
}

.message .icon {
	width: 3rem;
	height: 3rem;
	flex-shrink: 0;
}

.message .username {
	font-weight: bold;
	font-size: 1.25em;
	color: var(--username);
}
.message.admin .username { color: var(--admin); }
.message.admin { border: 4px var(--admin-border) solid; }
.message.moderator .username { color: var(--mod); }
.message.moderator { border: 4px var(--mod-border) solid; }

.message .date {
	font-style: italic;
	opacity: 0.75;
}

#new-message {
	display: flex;
	background: var(--input-box-bg);
	color: var(--input-box-text);
	border-top: 4px var(--borders) solid;
}
#new-message button[type=submit] {
	background: var(--send-bg);
	color: var(--send);
	padding: .25rem .5rem;
	&:hover, &:focus, &:focus-visible {
		color: var(--send-hover);
	}
}
#message-input {
	flex-grow: 1;
	background: none;
	color: inherit;
	font-size: .85em;
	padding: .5rem .75rem;
	moz-box-sizing: border-box; webkit-box-sizing: border-box; box-sizing: border-box;
	border: none;
}
#message-input:focus, #message-input:focus-visible {
	background: var(--input-box-focus);
	outline: none;
}

/***********************************************/
/*   BBCODE & MESSAGE CONTENTS   */

/* spoiler text */
.bbcode_spoiler:not(:hover) {
	background: var(--blue);
	color: var(--blue);
}
.bbcode_spoiler::selection { background: var(--blue); color: var(--white); }

/* quotes */
.bbcode_quote {
	margin: .25em 0;
}
.bbcode_quote_head {
	background: var(--l-blue);
	padding: .25em .5em;
	border-radius: .5em .5em 0 0;
}
.bbcode_quote_body {
	padding: .3em .5em;
	border: 2px var(--l-blue) solid;
	border-top: none;
	border-radius: 0 0 .5em .5em;
}

.bbcode_smiley {
	max-height: 1em;
	margin: 0 -.1em -.1em -.1em;
}
img + .bbcode_smiley { margin-left: 0; }
.bbcode_smiley:has(+ img) { margin-right: 0; }

.message .content img {
	max-width: 100%;
}