/* stylelint-disable property-no-vendor-prefix */
:root {
	--image-size: 70vh;
}

html,
body {
	width: 100%;
	height: 100%;
	min-height: 100vh;
	margin: 0;
	padding: 0;

	color: var(--color-secondary);

	background: var(--color-primary);
}

body {
	font-family: arial, sans-serif;

	box-sizing: border-box;
	padding: 2em;

    transition: background 300ms ease;
}

body.remix {
	background: white;
}

.buttons {
	position: absolute;
	z-index:9999;
	top: 0;
	right: 0;

	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: end;
	gap: 1em;

	filter: blur(1px);

	padding: 1em;
}

.buttons input {
	display: block;

	width: 2rem;
	height: 2rem;
    margin:0;
    padding:0;

    cursor: pointer;

    transition: background 300ms ease;
	
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;

	box-shadow: 0 0 0 1px rgb(0 0 0 / 50%);
}

.button-set {
	position: relative;
}

input#open-color {
	border:1px solid var(--color-secondary-custom);
	border-radius: 1rem;
	background: var(--color-primary-custom);
}

input#switch {
	border: 0;
	border-radius: 6px;
	outline: 0;

	background: var(--color-next);
}

.buttons fieldset {
	position: relative;
}

span.indicator {
	width:2rem;
	position: absolute;
	font-size: 1.75em;
	top:0.25em;
	display:block;
	pointer-events: none;
}

span.indicator::after {
	content: 'a';
	width:100%;
	text-align:center;
	color: transparent;
	display: block;
}

.next-tarb span.indicator::after {
	-moz-transform: scaleX(-1);
	-o-transform: scaleX(-1);
	-webkit-transform: scaleX(-1);
	transform: scaleX(-1);
	filter: FlipH;
	-ms-filter: "FlipH";
}

.custom .custom-picker span.indicator::after {
	color:var(--color-secondary-custom);
}

.preset .custom-picker span.indicator::after {
	display: none;
}

.preset .preset-picker span.indicator::after{
	color: var(--color-next-secondary);
}

.next-remix .preset-picker span.indicator::after {
	text-shadow:none;
	font-family: monospace;
}

.close-menu {
	font-weight: bold;

	position: absolute;
	top:-2em;
	left:0;

	box-sizing: border-box;

	width: 2.5em;
	height: 2em;
	padding: 0.5em;

	cursor:pointer;

	border-radius: 6px 6px 0 0;
	background: rgb(255 251 15 / 90%);
}

.color-customizer {
	position: fixed;
	z-index:99;

	right:-100vw;
	bottom:1em;

	box-sizing: border-box;

	width: calc(100vw - 2em);

	height:33vh;

	padding: 1rem;

	transition: right 300ms ease;

	text-align: center;

	border-radius: 0 6px 6px;

	background: rgb(255 251 15 / 90%);
}

.color-customizer.open {
	right:1em;

	transition: right 300ms ease;
}

.color-customizer fieldset.text-align {
	display: flex;
	flex-direction: row;
}

.color-customizer fieldset.color-field {
	text-align: left;
}

.color-field input {
	display:inline;

	width: 2rem;
	height:2rem;

	vertical-align: middle;
}

.text-align input {
	display: none;
}

.text-align input[type="radio"]:checked + label {
	font-weight: bold;

	color: var(--color-primary);
	background: var(--color-secondary);
}

.text-align label {
	flex-grow:1;

	padding: 0.75em 0.5em;

	cursor: pointer;

	color: var(--color-secondary);

	border: 1px solid var(--color-secondary);
	background: var(--color-primary);
}

.image {
	position: relative;

	display: grid;
	align-items: center;
	justify-content: center;

	box-sizing: border-box;
	width: var(--image-size);
	max-width: var(--image-size);
	height: 100%;
	max-height: var(--image-size);
	margin: 2em auto;

	text-align: left;
}

.remix .image {
	background: gray;
}

.output {
	position: absolute;
	inset: 0;

	width: 100%;
	height: 100%;

	border: 0;
	object-fit: cover;
}

.deluxe img {
	opacity: 0.7;
	outline: 0;
}

.brat img {
    filter:none;
}

img {
    display:none;
}

img[src] {
    display: block;
}

.text-output {
	position: relative;

	display: block;

	box-sizing: border-box;
	width: var(--image-size);
	max-width: var(--image-size);
	max-height: calc(var(--image-size) / 1.21);
	padding: 10px;

	transform: scaleY(121%);

	text-align: var(--text-align);
	text-align-last: var(--text-align);
}

.remix .text-output {
	line-height:0;

	position: absolute;

	right:0;

	width: 40%;
	height: 2.5rem;
	padding: 0.5rem 0.75rem;

	transform: translateX(50%) rotate(-90deg) translateY(-50%);
	transform-origin: center;

	text-align: left;
	text-align-last: left;

	border-radius: 0.25rem 0.25rem 0 0;
	background: var(--color-primary);
}

.brat .text-output {
    text-align:center;
    text-wrap: wrap;
    word-break: break-all;
}

.deluxe .text-output {
	text-align: justify;
	text-align-last: justify;
}

.text {
    display: inline;

    width: 100%;

    color: transparent;
    text-shadow: 0 0 0.03em var(--color-secondary);
}

.remix .text {
	font-family: monospace;
	font-size: 0.5rem!important;
	line-height:1.2!important;

	display: block;

	color: var(--color-secondary);
	text-shadow: none
}

input[type="file"] {
	display: block;

	box-sizing: border-box;
	width: 100%;

	max-width: 30rem;
	margin: auto;
	padding: 0.5rem;

	text-align: left;
}

.tarb .image {
	-moz-transform: scaleX(-1);
	-o-transform: scaleX(-1);
	-webkit-transform: scaleX(-1);
	transform: scaleX(-1);
	filter: FlipH;
	-ms-filter: "FlipH";
}

fieldset {
	box-sizing: border-box;
	max-width: 30rem;
	margin: 0 auto;
	padding: 0.5rem;

	border: 0;
	outline: 0;
}

.options input[type="checkbox"] {
	display: inline;

	width: auto;
	margin-right: 1em;
}

input#color-picker {
	position: absolute;
	top:1em;
	right:4rem;

	width: 2rem;
	height: 2rem;
	padding:0;

	cursor: pointer;

	border:0;
	background:transparent;
	
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

input#color-picker::-webkit-color-swatch {
	display:block;

	width: 2em;
	height: 2em;
	margin:0;
	padding:0;

	border: none;
	border-radius: 1rem;
}

input#color-picker::-moz-color-swatch {
	display: block;

	width: 2em;
	height: 2em;
	margin:0;
	padding:0;

	border: none;
	border-radius: 1rem;
}

label {
	display: inline;
}

.greenfilter {
  position: absolute;
  top:0;
  left:0;

  display: none;

  width:100%;
  height:100%;

  background: var(--color-primary);
  mix-blend-mode: color;
}

.filter.visible .greenfilter {
    display: block;
}

.deluxe .filter.visible,
.remix .filter.visible .output {
	filter: grayscale(100%);
}

.deluxe .filter.visible .greenfilter,
.remix .filter.visible .greenfilter {
	display: none;
}

/* Portrait */
@media screen and (orientation: portrait) {
	:root {
		--image-size: 100vw;
	}

	body {
		padding: 2em 0;
	}

	.image {
		width: 100vw;
		max-width: 100vw;
		max-height: 100vw;
	}
}
