/*
	GoToSocial
	Copyright (C) GoToSocial Authors admin@gotosocial.org
	SPDX-License-Identifier: AGPL-3.0-or-later

	This program is free software: you can redistribute it and/or modify
	it under the terms of the GNU Affero General Public License as published by
	the Free Software Foundation, either version 3 of the License, or
	(at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU Affero General Public License for more details.

	You should have received a copy of the GNU Affero General Public License
	along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

/***************************************
***** SECTION 0: IMPORTS AND FONTS *****
****************************************/

@import "modern-normalize/modern-normalize.css";
@import "./prism.css";

/* noto-sans-regular - latin */
@font-face {
	font-family: "Noto Sans";
	font-weight: 400;
	font-display: swap;
	font-style: normal;
	src: url('../fonts/noto-sans-v27-latin-regular.woff2') format('woff2'),
		 url('../fonts/noto-sans-v27-latin-regular.woff') format('woff');
}

/* noto-sans-700 - latin */
@font-face {
	font-family: "Noto Sans";
	font-weight: 700;
	font-display: swap;
	font-style: normal;
	src: url('../fonts/noto-sans-v27-latin-700.woff2') format('woff2'),
		 url('../fonts/noto-sans-v27-latin-700.woff') format('woff');
}

/*************************************
***** SECTION 1: HANDY VARIABLES *****
**************************************/

/*
	Standard border radius
	for nice squircles.
*/
$br: 0.4rem;

/*
	Border radius for items that
	are framed/bordered inside
	something with $br, eg avatar,
	header img, etc.
*/
$br-inner: 0.2rem; 

/*
	Fork-Awesome 'fa-fw' fixed icon width;
	keep in sync with https://github.com/ForkAwesome/Fork-Awesome/blob/a99579ae3e735ee70e51ed62dfcee3172b5b2db7/css/fork-awesome.css#L50
*/
$fa-fw: 1.28571429em;

/******************************************
***** SECTION 2: BASIC GLOBAL STYLING *****
*******************************************/

html, body {
	padding: 0;
	margin: 0;
	background: $bg;
	color: $fg;
	font-family: "Noto Sans", sans-serif;
	scrollbar-color: $orange1 $gray3;
}

body {
	line-height: 1.5em;
	position: relative;
}

a {
	color: $link-fg;
}

/*
	Normalize margins of first and last children.
	We generally don't want to open a paragraph or
	paragraph-like element with a top margin or
	close it with a bottom margin.
*/
main {
	p:first-child, ol:first-child, ul:first-child {
		margin-top: 0;
	}

	p:last-child, ol:last-child, ul:last-child {
		margin-bottom: 0;
	}
}

.button, button {
	border-radius: $br-inner;
	color: $button-fg;
	background: $button-bg;
	box-shadow: $boxshadow;
	border: $button-border;
	text-decoration: none;
	font-size: 1.2rem;
	font-weight: bold;
	padding: 0.5rem;
	border: none;
	cursor: pointer;
	text-align: center;
	font-family: 'Noto Sans', sans-serif;

	&.danger {
		color: $button-danger-fg;
		background: $button-danger-bg;

		&:hover {
			background: $button-danger-hover-bg;
		}
	}

	&:disabled,
	&.disabled {
		color: $white2;
		background: $gray2;
		cursor: not-allowed;

		&:hover {
			background: $gray3;
		}
	}

	&:hover {
		background: $button-hover-bg;
	}
}

/*
	Form styling - used in settings frontend as well.
*/
input, select, textarea, .input {
	box-sizing: border-box;
	border: 0.15rem solid $input-border;
	border-radius: 0.1rem;
	color: $fg;
	background: $input-bg;
	width: 100%;
	font-family: 'Noto Sans', sans-serif;
	font-size: 1rem;
	padding: 0.3rem;

	&:focus, &:active {
		border-color: $input-focus-border;
	}

	&:invalid, .invalid & {
		border-color: $input-error-border;
	}

	&:disabled {
		background: transparent;
	}

	&::placeholder {
		opacity: 1;
		color: $fg-reduced
	}
}

/*
	Squeeze emojis so they fit inline in text.
*/
.emoji {
	width: 1.45em;
	height: 1.45em;
	margin: -0.2em 0.02em 0;
	object-fit: contain;
	vertical-align: middle;
	transition: 0.1s;

	/*
		Enlarge emojis on hover to give
		viewer a good look at them.
	*/
	&:hover, &:active {
		transform: scale(2);
		background-color: $bg;
		box-shadow: $boxshadow;
		border: $boxshadow-border;
		border-radius: $br-inner;
	}
}

/*
	Restyle unordered lists; outdent
	and replace dot with orange dot.
*/
ul {
	padding-left: 2.5rem;
	list-style: none;

	li::before {
		content: "\2022";
		color: $border-accent;
		font-weight: bold;
		display: inline-block;
		width: 1.5rem;
		margin-left: -1.5rem;
	}
}

/*
	Mirror the same styling a little bit
	for ordered lists by making marker bold.
*/ 
ol {
	padding-left: 2.5rem;

	li::marker {
		font-weight: bold;
	}
}

/*
	Outdent block quotes a bit; use
	orange strip for left border.
*/
blockquote {
	padding: 0.5rem 0 0.5rem 0.5rem;
	border-left: 0.2rem solid $border-accent;
	margin: 0;
	font-style: normal;

	/*
		Same background color we
		use for code blocks
	*/
	background-color: $gray2;
	border-radius: $br;
}

/*
	Nice dashed orange line
	for horizontal rules.
*/
hr {
	border: 0;
	border-top: 1px dashed $border-accent;
}

/*
	Don't indent definition
	lists and definitions.
*/
dl {
	margin: 0;

	dd {
		margin-left: 0;
	}
}

label {
	cursor: pointer;
}

/*
	Set our own nice background for
	monospace code and pre blocks.
*/
pre, pre[class*="language-"],
code, code[class*="language-"] {
	background-color: $gray2;
}

/*
	Just code on its own inside status
	content, ie, `here is some code`.
*/
code {
	padding: 0.25rem;
	border-radius: $br-inner;
	white-space: pre-wrap;
}

/*
	Restyle Prism code highlighting toolbar
	plugin buttons to our own button style.
	
	We have to use really specific selectors
	because of how specific prism.css is.
*/
div.code-toolbar > div.toolbar {
	margin-right: 0.5rem;
	display: flex;
	gap: 0.25rem;

	> div.toolbar-item {
		> span, > button {
			color: $button-fg;
			background: $button-bg;
			font-weight: bold;
			box-shadow: $boxshadow;

			&:hover, &:focus {
				color: $button-fg;
			}
		}

		.copy-to-clipboard-button:hover {
			background: $button-hover-bg;
		}
	}
}

pre, pre[class*="language-"] {
	border-radius: $br;
	padding: 0.5rem;
	white-space: pre;
	overflow-x: auto;

	/* 
		Code inside a pre block, ie.,
		
		```
		here is some code
		```
	*/
	code {
		width: 100%;
		padding: 0;
		white-space: pre;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}

/*************************************
***** SECTION 3: UTILITY CLASSES *****
**************************************/

/*
	Column header that appears at the top
	of threads, at the top of sections of
	profiles (About, Pinned Posts, etc).
*/
.col-header {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1rem;

	justify-content: start;
	align-items: center; 

	margin: 0;
	background: $profile-bg;
	border-top-left-radius: $br;
	border-top-right-radius: $br;
	padding: 0.75rem;

	a {
		justify-self: end;
	}

	h1, h2, h3, h4 {
		font-size: 1.2rem;
		line-height: 1.3rem;
		margin: 0;
	}
}

.hidden {
	display: none;
}

.nounderline {
	text-decoration: none;
}

.accent {
	color: $acc1;
}

.text-cutoff {
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
}

/* 
	Class for lists that don't
	want the orange dot.
*/
.nodot {
	li::before {
		content: initial;
	}
}

/*
	Forms and sign-in / sign-up / confirm pages.
*/
section.with-form {
	form {
		display: flex;
		flex-direction: column;
		gap: 1rem;

		padding-bottom: 1rem;
		padding-top: 1rem;

		p {
			/*
				We use gap so we don't
				need top + bottom margins.
			*/
			margin-top: 0;
			margin-bottom: 0;
		}

		label, input {
			padding-left: 0.2rem;
		}

		.labelinput {
			display: flex;
			flex-direction: column;
			gap: 0.4rem;
		}

		.checkbox {
			display: flex;
			flex-direction: row-reverse;
			gap: 0.4rem;

			& > input {
				height: 100%;
				width: 5%;
				min-width: 1.2rem;
				align-self: center;
			}
		}

		.btn {
			/* Visually separate buttons a bit */
			margin-top: 1rem;
		}
	}
}

/***********************************
***** SECTION 4: SHAMEFUL MESS *****
************************************/

/*
	EVERYTHING BELOW THIS POINT:
	Should be moved somewhere else
	to avoid cluttering up this file.
*/

/*
	Below section stylings are used
	in transient pages + error templates.
*/

section.error {
	word-break: break-word;
	margin-bottom: 0.5rem;

	pre {
		border: 1px solid #ff000080;
		padding: 0.5rem;
		border-radius: 0.5em;
		background-color: #ff000010;
		font-size: 1.3em;
		white-space: pre-wrap;
	}
}

section.oob-token {
	code {
		background: $gray1;
		padding: 0.5rem;
		margin: 0;
		border-radius: 0.3rem;
	}
}

/*
	TODO: list and blocklist are only used
	in settings panel and on blocklist page;
	consider moving them somewhere else.
*/
.list {
	display: flex;
	flex-direction: column;

	.header, .entry {
		padding: 0.5rem;
	}

	.header {
		border: 0.1rem solid transparent !important; /* for alignment with .entry border padding */
		background: $gray1 !important;
		display: flex;
		font-weight: bold;
	}

	.entries {
		display: flex;
		flex-direction: column;

		&.scrolling {
			height: 20rem;
			max-height: 20rem;
			overflow: auto;
		}
	}

	input[type=checkbox] {
		margin-left: 0.5rem;
	}

	.entry {
		display: flex;
		flex-wrap: wrap;
		background: $list-entry-bg;
		border: 0.1rem solid transparent;

		&:nth-child(even) {
			background: $list-entry-alternate-bg;
		}
	
		&:hover {
			background: $list-entry-hover-bg;
		}
	
		&:active, &:focus, &:hover, &:target {
			border-color: $fg-accent;
		}
	}
}

.domain-blocklist {
	box-shadow: $boxshadow;

	.entry {
		display: grid;
		grid-template-columns: max(30%, 10rem) 1fr;
		gap: 0.5rem;
		align-items: start;
		border: $boxshadow-border;
		border-top-color: transparent;

		& > div {
			display: flex;
			align-items: center
		}

		.domain a {
			font-weight: bold;
			text-decoration: none;
			display: inline-block; /* so it wraps properly */
		}

		.public_comment p {
			margin: 0;
		}
	}

	.header .domain {
		color: $fg;
	}
}

@media screen and (max-width: 30rem) {
	.domain-blocklist .entry {
		grid-template-columns: 1fr;
		gap: 0;
	}
}

/*
	TODO: this is only used on About
	page and in settings application;
	consider moving it somewhere else.
*/
.account-card {
	display: inline-grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto;
	text-decoration: none;
	gap: 0.5rem 1rem;
	border-radius: $br;
	padding: 0.5rem;
	min-width: 40%;
	margin-bottom: 0.3rem;

	background: $list-entry-bg;

	&:hover {
		background: $list-entry-alternate-bg;
	}

	h3 {
		align-self: end;
		margin: 0;
		color: $fg;
	}

	img.avatar {
		border-radius: 0.5rem;
		width: 5rem;
		height: 5rem;
		object-fit: cover;
		grid-row: 1 / span 2;
	}
}