body,html {
	-webkit-tap-highlight-color: rgba(255, 255, 255, 0); 
	user-select: none;
	-webkit-user-select: none;
    -ms-user-select: none;
	-ms-content-zooming: none;
    -ms-scroll-limit: 0px;
    -ms-touch-action: none;
	touch-action: none;
	margin: 0px;
	padding: 0px;
	height: 100%;
	width: 100%;
	font-family: 'Gudea', sans-serif;
    overflow: hidden;
	-webkit-touch-callout: none;
}

* {
	user-select: none;
}

iframe {
	user-select: initial;
}

body {
    background-color: #111111;
    color: #ff0000;
    margin: 0px;
}

#wrapper {
    background-color: #111111;
    overflow: hidden;
    position: fixed;
    top: 0px;
    left: 0px;
    height: 100%;
	width: 100%;
	background-size: cover;
	background-position: center;
	font-family: 'Gudea', sans-serif;
    display: grid;
    grid-template-rows: 1fr auto;
}

#scannerArea {
    text-align: center;
	display: grid;
	grid-template-rows: 1fr auto auto auto auto 1fr auto;
	position: relative;
}

#genReadoutArea {
	grid-row: 2;
	background-color: rgba(0,0,0,0.6);
	padding: 12px 0px;
	font-size: 1.5em;
	color: #ffffff;
	position: relative;
}

#genReadoutText {
	text-align: center;
	text-transform: uppercase;
}

#btnPowerLight {
	position: absolute;
	top: -2px;
	left: 0px;
	height: 60px;
	width: 60px;
    transition: 0.3s;
}

#instructionsPanel {
    grid-row: 3;
    height: 160px;
    text-align: center;
    width: 100%;
	color: #ffffff;
	position: relative;
}

#instructionsText {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 90%;
	max-width: 480px;
    text-align: left;
    font-size: 1.3em;
	font-weight: 100;
	text-shadow: 0px 6px 6px rgba(0,0,0,.2);
	margin: 0px;
	padding: 0px;
    text-align: center;
}

#canvasHolder{
	grid-row: 4;
	border-radius: 18px;
	border-color: rgba(0,0,0,.4);
	border-width: 1px;
	border-style: solid;
	margin: 0px auto;
	box-shadow: 0px 3px 20px rgba(0,0,0,.6) inset, 0px 3px 80px rgba(0,0,0,.8) inset;
	height: 190px;
	width: 150px;
}

#mainCanvas {
	border-style: none;
	margin: 0px;
	border-radius: 18px;
	cursor: pointer;
	-webkit-user-select: none;
	user-select: none;
	-webkit-touch-callout: none;
}

#resultsHolder {
	grid-row: 5;
	grid-template-columns: 1fr auto auto 1fr;
	display: none;
	background-color: rgba(0,0,0,.6);
	color: #ffffff;
}

#resultPringImg {
	grid-column: 2;
	height: 192px;
}

#readoutResultListing {
	grid-column: 3;
	display: grid;
	grid-template-rows: 1fr auto auto auto 1fr;
	text-align: left;
}

#readoutResultListingText {
	grid-row: 2;
}

#readoutResultListingMeterHolder {
	grid-row: 3;
	position: relative;
	margin: 8px 0px;
	height: 18px;
	background-color: rgba(0,0,0,0.6);
	border: 1px solid #222222;
	width: 170px;
}

#readoutResultListingMeter {
	position: absolute;
	top: 0px;
	left: 0px;
	height: 100%;
	width: 0px;
}

#readoutResultListingButtons {
	grid-row: 4;
	text-align: right;
	display: none;
}

.rescanButton{
	font-size: 1.1em;
	font-weight: bold;
	cursor: pointer;
	margin-bottom: 8px;
}

#featureAndSettingsHolder {
	grid-row: 7;
	display: grid;
	grid-template-columns: auto 1fr auto;
}

.premium #featureAndSettingsHolder {
	padding-bottom: env(safe-area-inset-bottom);
}

#featuredApp {
    user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	-moz-user-select: none;
	margin: 8px;
	height: 52px;
	width: 52px;
	cursor: pointer;
	grid-column: 3;
}

#settingsButton {
	cursor: pointer;
	user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	-moz-user-select: none;
	width: 52px;
	height: 52px;
	margin: 8px;
	grid-column: 1;
}

#settingsDiv {
	z-index: 4;
	position: absolute;
	top: 0px;
	left: 0px;
	width: calc(100% - 24px);
	color: #333333;
	background-color: rgba(255,255,255,.8);
	box-shadow: 0px 6px 6px rgba(0,0,0,.2);
	padding: 12px;
	display: none;
}

.speedButton {
	cursor: pointer;
	height: 52px;
	width: 52px;
}

#adUnit {
    grid-row: 2;
    color: #ffffff;
	background-color: #000000;
}

#adUnit iframe {
    width: 100%;
    height: 90px;
    margin-bottom: env(safe-area-inset-bottom);
}

@media screen and (max-width: 728px) {
    #adUnit iframe {
        height: 60px;
    }
}

@media screen and (max-width: 468px) {
    #adUnit iframe {
        height: 50px;
    }
}

@media screen and (max-height: 500px) {
    #scannerArea {
		grid-template-columns: 1fr 1fr;
	}

	#genReadoutArea {
		grid-column: 1 / span 2;
	}

	#canvasHolder{
		grid-row: 3;
		grid-column: 2;
		margin-top: 12px;
	}

	#resultsHolder {
		grid-row: 3;
		grid-column: 2;
		background: transparent;
	}

	#resultPringImg {
		height: 142px;
	}

	#featureAndSettingsHolder {
		grid-column: 1 / span 2;
	}
}

/* refer here: https://web.dev/learn/design/screen-configurations/ */
@media (horizontal-viewport-segments: 2) and (vertical-viewport-segments: 1) {
	#scannerArea {
		grid-template-columns: 1fr 1fr;
		gap: 0px calc(env(viewport-segment-left 1 0) - env(viewport-segment-right 0 0));
	}

	#canvasHolder {
		grid-column: 2;
	}

	#featureAndSettingsHolder {
		grid-column: 2;
		/*padding: 0px 24px;*/
	}

	#resultsHolder {
		grid-column: 2;
	}

	.adlDialog:not(.adlFlyoutRight):not(.adlFLyoutLeft) {
		max-width: calc(env(viewport-segment-right 0 0) - 120px);
		left: calc(env(viewport-segment-right 0 0) + 27vw);
	}

	.adl-toast {
		left: initial;
		transform: initial;
		right: 48px;
	}

	#settingsDiv {
		width: env(viewport-segment-right 0 0);
		left: initial;
		right: 0px;
	}
}

@media (horizontal-viewport-segments: 1) and (vertical-viewport-segments: 2) {
	#scannerArea {
		grid-template-rows: 1fr auto auto 1fr auto auto 1fr auto;
	}

	#canvasHolder {
		grid-row: 5;

	}

	#resultsHolder {
		grid-row: 6;
	}

	#featureAndSettingsHolder {
		grid-row: 8;
	}

	.adlDialog:not(.adlFlyoutRight):not(.adlFLyoutLeft) {
		top: calc(env(viewport-segment-right 0 0) - 40vh);
	}

	.adlFlyoutRight, .adlFLyoutLeft {
		height: calc(env(viewport-segment-bottom 0 0) - 48px);
		bottom: 0px;
		top: initial;
	}
}