* { box-sizing: border-box; }
body {
	margin: 0;
	padding: 0;
	margin-left: 10vw;
	margin-right: 10vw;
	text-align: center;
	background-color: var(--sl-color-neutral-0);
	color: var(--sl-color-gray-800);
	font-family: var(--sl-font-sans);
	font-size: var(--sl-font-size-2x-large);
	font-weight: var(--sl-font-weight-normal);
	letter-spacing: var(--sl-letter-spacing-normal);
	line-height: var(--sl-line-height-normal);
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 { font-weight: var(--sl-font-weight-light); }
h1 { font-size: var(--sl-font-size-4x-large); margin-bottom: 1.5rem; }
h2 { font-size: var(--sl-font-size-3x-large); margin-bottom: 1.5rem; }
h3 { margin-bottom: 1.5rem; }
h4 { margin-top: 0; margin-bottom: 0.5rem; }
a {
	text-decoration: none;
	color: var(--sl-color-pink-600);
}
a:hover { text-decoration: underline; }
#title > a { color: inherit; }
main {
	margin-bottom: 6rem;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	justify-content: center;
	align-content: center;
}
#title {
	margin-top: 1rem;
	font-size: var(--sl-font-size-3x-large);
	font-style: italic;
}
#service {
	margin-top: 0;
	line-height: 1.25em;
}
#service sl-icon {
	display: inline-block;
	margin-left: var(--sl-spacing-x-small);
	vertical-align: -6px;
}
#answer {
	display: grid;
	grid-template-columns: 1.5fr 0.5fr;
	grid-template-rows: 1fr;
	gap: 0em 1em;
	grid-template-areas:
	"a b"
	"c c";
	justify-content: center;
	justify-items: start;
	align-content: center;
	align-items: center;
	/* text-decoration-line: underline;
	text-decoration-style: dotted;
	text-decoration-color: var(--sl-color-neutral-500); */
}
.result {
	grid-area: a;
	justify-self: center;
	font-size: var(--sl-font-size-3x-large);
	line-height: 1.25em;
}
.result > a {
	color: inherit;
	text-decoration-line: underline;
	text-decoration-style: dotted;
	text-decoration-color: var(--sl-color-gray-500);
	cursor: alias;
}
.reaction {
	grid-area: b;
	color: var(--sl-color-gray-500);
	font-size: var(--sl-font-size-x-small);
}
.reaction > a:first-of-type { cursor: help; }
.reaction > a:last-of-type { cursor: alias; }
.reaction > a {
	color: inherit;
	text-decoration-line: underline;
	text-decoration-style: dotted;
	text-decoration-color: var(--sl-color-gray-500);
	/* cursor: alias; */
}
.reaction > a:hover {
	color: var(--sl-color-pink-400);
	text-decoration-style: solid;
	text-decoration-color: var(--sl-color-pink-400);
}
.nextbest {
	grid-area: c;
	justify-self: center;
	font-weight: var(--sl-font-weight-light);
	font-size: var(--sl-font-size-x-large);
}
nav {
	margin: 10rem 0 3rem 0;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: center;
	font-size: var(--sl-font-size-large);
	color: var(--sl-color-neutral-500);
}
nav > sl-button::part(base) {
	font-size: var(--sl-font-size-large);
	color: var(--sl-color-neutral-500);
}
footer {
	position: relative;
	width: 100%;
	/*min-height: 10rem;*/
	bottom: 0;
	font-size: var(--sl-font-size-x-small);
	font-weight: var(--sl-font-weight-light);
}
.heart { color: var(--sl-color-pink-400); }
.hint {
	text-decoration-line: underline;
	text-decoration-style: dotted;
	text-decoration-color: var(--sl-color-neutral-500);
	cursor: help;
}
.emphasize { font-weight: 600; }
.no-wrap { white-space: nowrap; }
.wrap-words { overflow-wrap: anywhere; }
.stay-together { display: inline-block; }
.force-line-break { display: block; }
.line-break-on-desktop { display: block; }
.pad-xxxs-r { margin-right: 0.1em; }
.pad-xxs-r { margin-right: 0.25em; }
.pad-xs-l { margin-left: 0.5em; }
.pad-xs-r { margin-right: 0.5em; }
.pad-s-l { margin-left: 1em; }
.pad-s-r { margin-right: 1em; }
.space-xxs-l { padding-left: 0.25em; }
.space-xs-l { padding-left: 0.5em; }
.space-s-l { padding-left: 1em; }

sl-icon.valign-middle { vertical-align: -0.13em; }
sl-button { margin-top: 0.25em; }
sl-button.layout-switch::part(base) {
	color: var(--sl-color-neutral-600);
	border-width: var(--sl-input-border-width);
	border-color: var(--sl-color-neutral-0);
}
/*sl-button.other-service::part(base) { color: var(--sl-color-pink-400); }*/
sl-button.btn-twitter::part(base) {
	margin-top: 0;
	color: var(--sl-color-pink-500);
	border-top-color: var(--sl-color-pink-500);
	border-left-color: var(--sl-color-pink-500);
	border-bottom-color: var(--sl-color-pink-500);
	border-right-color: var(--sl-color-pink-500);
}
sl-button.btn-twitter::part(base):hover, sl-button.twitter::part(base):active {
	background-color: var(--sl-color-pink-400);
	color: white;
}

.bad { color: var(--sl-color-orange-500); }
.bad.hint { text-decoration-color: var(--sl-color-orange-500); }
.good { color: var(--sl-color-success-400); }
.good.hint { text-decoration-color: var(--sl-color-success-400); }
.neutral { color: var(--sl-color-primary-400); }
.neutral.hint { text-decoration-color: var(--sl-color-primary-400); }

/**
 * Special Viewport settings
 */
@media (max-width: 768px) { /* Landscape mobile */
	body {
		margin-left: 2vw;
		margin-right: 2vw;
		font-size: var(--sl-font-size-large);
	}
	main { margin: 1rem 0; flex-direction: column; }
	main h1 {
		margin-bottom: 2.5rem;
		line-height: 0.5em;
	}
	#title { font-size: var(--sl-font-size-x-large); }
	#service {
		flex-direction: row;
		font-size: var(--sl-font-size-2x-large);
	}
	#answer {
		grid-template-columns: 1.5fr;
		grid-template-rows: 1fr;
		grid-template-areas:
		"a"
		"c"
		"b";
		justify-items: center;
		align-items: start;
	}
	.result { font-size: var(--sl-font-size-2x-large); }
	.nextbest { font-size: var(--sl-font-size-large); }
	.reaction { font-size: var(--sl-font-size-small); }
	nav {
		margin: 4rem 0 3rem 0;
		font-size: var(--sl-font-size-medium);
	}
	nav > sl-button::part(base) { font-size: var(--sl-font-size-small); }
	footer > p:first-of-type {
		display: flex;
		flex-wrap: wrap;
		flex-direction: column-reverse;
		align-content: center;
		justify-content: center;
	}
	footer > p:first-of-type > sl-button { margin: 0.5em; }
	#layout-buttons { align-self: center; }
	.hide-in-small-vp { display: none; }
	.line-break-on-mobile { display: block; }
	.line-break-on-desktop { display: inline; }
}
