html {
	scroll-behavior: unset;
	font-size: 16px;
}
.tarjeta {
	/* display:  none; */
}
body {
	font-family: "Rubik", sans-serif;
	font-size: 1rem;
	padding: 0;
	position: absolute;
	margin: auto;
	color: #333;
	line-height: 1.5;
	background-color: #fff;
	overflow: hidden;
	width: 100vw;
	height: 100vh;
	left: 0;
	bottom: 0;
	top:  0;
	right:  0;
}
.lector-pantalla {
	width: 1px;
	height: 1px;
	overflow: hidden;
	display: block;
}
:focus {
	outline: 2px dotted #333;
	outline-offset: 2px;

}
h1, h2, h3, h4, h5, h6 {
	font-weight: 500;
}
h1, h2, p, .button{
	text-align: center;
	width: 100%;
}
h2 {
	font-family: "Rubik", sans-serif;
	font-size: 2rem;
	margin: 0 auto;
}
h2.long {
	font-size: 2rem;
}
h3 {
	font-size: 1.1rem;
	font-family: "Rubik", sans-serif;
	margin: 0;

}
figure.icono {
    margin-bottom: 0;
}
main {
	transform: translate3d(0px, 66px, 0px);
}
strong {
	font-family: "Rubik", sans-serif;
}
legend {
	width: 100%;
	text-align: center;
	margin-bottom: 1rem;
}
legend ol {
	max-width: 60ch;
	text-align: left;
}
.second_step {
	display: none;
}
#screen_2 .grid > div {
	width: 100%;
}
.curso .no-curso {
	display: none;
}
.no-curso {
	margin-top: 1rem;
}
.solo-curso {
	display: none;
}

.curso .skip {
	display: none !important;
}
.curso .weiter {
	display: block !important;
}
.videoplayer {
	position: absolute;
	width: 100%;
	height: 100%;
	background: #333333f0;
	top: 0;
	z-index: 9;
	text-align: center;
}
.videoplayer label {
	margin: 1rem 1rem 1rem auto;
}
.videoplayer iframe {
	width: 80vw;
	height: 80vh;
	position: relative;
	margin: auto;
	border: none;
}
.video-opener:checked + .videoplayer {
	display: block;
}
.label-video-opener {
	width: auto;
	height: 2rem;
}
.label-video-opener svg { 
	height: 2rem;
	width: 2rem;
}
.label-video-opener:hover svg path {
	fill: #ffe4b5;
} 
.white {
	color: #fff !important;
}
body.curso .solo-curso {
	display: block;
}
p.multiline {
	text-align: left;
	max-width: 100%;
	border-bottom: 0.2px solid #333;
}
p.line1 {
	margin-bottom: 0;
}
p.line2 {
	margin-top: 0;
}
p {
	max-width: 60ch;
	margin: 0 auto;
	position: relative;
	line-height: 1.5;
}
.hidden {
	display: none !important;
}
#headerLink {
	color: #333;
	background-color: #fff;
	text-decoration: none;
	position:fixed; 
	display:flex; 
	top:0;
	left:0; 
	width:100vw; 
	align-items: center;
	z-index: 999999;
	box-shadow: 0 0 3px #ccc;
}
#headerLink small {
	font-size: 0.75rem;
	display: block;
	margin-top: -5px;
	position: absolute;
	margin-left: 3px;
	font-weight: 500;
}
#headerLink span {
	font-size: 2rem;
	margin: 0 0.5rem;
	font-weight: 400;
	font-family: "Rubik", sans-serif;
	padding: 0;
}
#headerLink.curso {
	background-color: #ffe4b5;
	color: #333;
}
#headerLink.curso .cls-1 {
	fill: #fff;
}
#headerLink.herramienta {
	background-color: #333;
	color: #fff;
}
#headerLink.herramienta .cls-1 {
	fill: #fff;
}
#headerLink.herramienta .cls-2 {
	fill: #ffe4b5;
}
#headerLink.examen {
	background-color: #fff;
	color: #333;
}
::-webkit-scrollbar {
	/* width: 3px; */
}
::-webkit-scrollbar:hover {
	width: 6px;
}
::-webkit-scrollbar {
	width: 6px;  
	height: 6px;
	/* width of the entire scrollbar */
}
::-webkit-scrollbar-track {
	background: #e7e7e7;        /* color of the tracking area */
	border-radius: 3px; 
}
::-webkit-scrollbar-thumb {
	background-color: #333;    /* color of the scroll thumb */
	border-radius: 20px;       /* roundness of the scroll thumb */
	border: 0.25px solid #e7e7e7;  /* creates padding around scroll thumb */
}
div#screen_1 .tarjeta {
	/* height: auto !important; */
	border-radius:  10px;
}
/* div#screen_1 {
	display: flex;
	justify-content: center;
} */
.center-container {
	margin: 1rem auto;
	position: relative;
}
.weiter {
	display: none;
}
.icono svg {
	height: 2rem;
	margin: 0.5rem 1rem;
	width: 2rem;
	filter: drop-shadow(1px 1px 0px rgb(51 51 51 / 0.2));
}
label:hover .icono svg{
	filter: drop-shadow(3px 3px 3px rgb(51 51 51 / 0.2));

}
/* label:hover .icono svg *{ 
	stroke:  #ffe4b5; 
}  */
/* .icono {
	height: 4rem;
    margin: 2rem;
    max-width: 4rem;
} */
.flexspan {
	gap: 1rem;
	column-gap: 0.5rem;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.flexspan > label {
	
	grid-column: 1/-1;
}
.hidden {
	display: none;
}
.flexer.full {
	display: grid;
	justify-items: start;
	width: auto;
	justify-content: normal;
	padding: 1rem;
}
.flexer.full label {
	font-size: 1rem;
	width: auto;
	margin-right: 1rem;
}
input[type=text] {
	padding: 0.25rem 2px 0;
	border: none;
	min-width: 100%;
	border-bottom:  0.2px solid #333333;
}
/* .grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
} */
.grid {
	display: grid;
	grid-template-columns: repeat( auto-fit, minmax(130px, 1fr) );
	flex-wrap: wrap;
	justify-content: space-between;
}
.flexer.angulo {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	width: 100%;
}
.teiler {
	width: max-content;
	text-align: center;
	display: grid;
	grid-template-columns: 1fr 1fr;
	padding: 2rem 0;
	margin: 0 auto;
}
.teiler.final form {
	display: flex;
	justify-content: center;
}
.teiler.final,
.teiler.one  {
	grid-template-columns: 1fr;
}
.teiler.final form a,
.teiler.final form button {
	margin: 5px;
}
.button:not(.limpio) {
	border: 1px solid #ffe4b5;
	color: #333;
	text-decoration: none;
	padding: 0.5rem 2rem;
	border-radius: 3rem;
	background-color: #fff;
	font-size: 1rem;
	margin: 0 1rem;
	width: auto;
}
.button:not(.limpio):hover {
	border: 1px solid #ffe4b533;
	background-color: #ffe4b533;
	cursor: pointer;
}

#copiarResumen {
	float: right;
}
.screen {
	display: flex;
	position: relative;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 95vh;
	max-width: 100vw;
	overflow: unset;
	background: rgb(255,255,255);
	background: -moz-linear-gradient(top,  #fff 0%, #fff 30%, rgb(255 228 181) 30%, rgb(255 228 181) 31%, rgb(255 228 181) 69%, rgb(255 228 181) 70%, #fff 70%, #fff 70%, #fff 100%);
	background: -webkit-linear-gradient(top,  #e7e7e7 0%,#fff 30%,rgb(255 228 181) 30%,rgb(255 228 181) 31%,rgb(255 228 181) 69%,rgb(255 228 181) 70%,#fff 70%,#fff 70%,#fff 100%);
	background: linear-gradient(to bottom,  #fff 0%,#fff 30%,rgb(255 228 181) 30%,rgb(255 228 181) 31%,rgb(255 228 181) 69%,rgb(255 228 181) 70%,#fff 70%,#fff 70%,#fff 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ffffff',GradientType=0 );
}
#magico {
	display: flex;
	overflow: hidden; 
	width: 2500vw;
	position: relative;
}
.screen.present .tarjeta{
	margin: 1rem auto;
	transition: all 250ms ease-in-out;
	display: block;
	opacity: 1;
}
/* #screen_sub.screen.present .tarjeta,
#screen_2.screen.present .tarjeta {
	margin-top: 5rem;
} */
#first_magia { 
	display: flex;
	overflow: hidden; 
	width: 300vw;
	position: relative;
}
textarea#sensaciones,
textarea#resumenFIN {
	width: 95%;
	font-family: "Rubik", sans-serif;
	font-size: 1rem;
	color: #333;
	padding: 1rem;
	max-width: 640px;
	position: relative;
	margin: auto;
	height: 9rem;
}
.buttoner label:hover,
.buttoner label:focus {
	box-shadow: 0 1px 5px #ccc;
}
span.data-ejemplo {
	width: 100%;
	height: 0;
	transition: height 150ms ease-in-out;
	overflow: unset;
	margin: -0.5rem -2rem;
	padding: 0;
	display: none;

}
.ejemplo {
	font-size: .75rem;
	font-family: "Rubik", sans-serif;
}
.txt-ejemplo {
	display: none;
	font-size:  14px;
	position: absolute;
}
.cb-ejemplo {
	appearance: none;
	display: block !important;
	width: 1.5rem;
	height: 1.5rem;
	background-color: #ccc;
	color: #333;
	border-radius: 2rem 5px 4px 5px;
	text-align: center;
	position: absolute;
	right: -2px;
	bottom: -2px;
	z-index: 0;
}
.cb-ejemplo:focus,
.cb-ejemplo:hover {
	cursor: pointer;
	background-color: #ffe4b5;
	color: #333;
	transition: all 250ms ease-in-out;
	border: 1px solid #ffe4b5;
	z-index: 10;
}
.cb-ejemplo:checked {
	background-color: #ffe4b5;
	color: #333;
	transition: all 250ms ease-in-out;
	border: 1px solid #333;
	z-index: 11;
}
.cb-ejemplo:active {
	background-color: #333;
	color: #ffe4b5;
	transition: all 250ms ease-in-out;
	border: 1px solid #ffe4b5;
}
.cb-ejemplo::after {
	content: "ℹ";
	font-size: 1rem;
	left: 3px;
	right: 0;
	top: 3px;
	bottom: 0;
	position: absolute;
}
.cb-ejemplo:hover + span,
.cb-ejemplo:focus + span,
.cb-ejemplo:checked + span ,
span.data-ejemplo:hover {
	transition: height 150ms ease-in-out;
	position: absolute;
	z-index: 0;
	display: flex;
	align-items: end;
	right: 0;
	bottom: 0rem;
	margin: 0;
	width: 100%;
	cursor: pointer;
}
.cb-ejemplo:focus + span .txt-ejemplo,
.cb-ejemplo:hover + span .txt-ejemplo,
.cb-ejemplo:checked + span .txt-ejemplo,
span.data-ejemplo:hover .txt-ejemplo {
	display: block;
	color: #333;
	padding: 0.5rem;
	border-radius: 5px;
	box-shadow: 0 0 3px #ccc;
	background: #fafafa;
	text-align: left;
	border: 0.2px solid #ccc;
	width: initial;
	height: initial;
	margin-top: 8px;
	position: absolute;
	z-index: 1;
}
fieldset.buttoner.blocks3 {
	width: 100%;
	margin: 2rem 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	column-gap: 0.5rem;
	row-gap: 1rem;
}
p.left {
	text-align: left;
}
ul.triangulitos {
	margin: 0 0;
	padding: 0 1em;
	list-style: none;
	/*width: max-content;*/
	max-width: 60ch;
	margin: auto;
	text-align: left;
}
ul.triangulitos li::before { 
	content: "";
	border-color: transparent #333;
	border-style: solid;
	border-width: 4px 0 4px 4px;
	display: block;
	height: 0;
	width: 0;
	left: -0.5rem;
	top: 1rem;
	position: relative;
}


.subs {
	position:relative;
	width:100%;
	height:100%;
	display: none;
}
.selector {
	position:relative;
	width:100%;
	height:100%;
}
.buttoner input.radiocheck:checked + span .subs {
	display: block;
}
.buttoner input.radiocheck:checked + span .subs.if-otro {
	display: none;
}

.img-frame {
	width: 100%;
	aspect-ratio: 0.666;
	overflow: hidden;
	justify-content: center;
	align-items: end;
}



.img-frame span {
/* 	margin-bottom:  1rem; */
}
.flexer {
	display: flex;
	justify-content: space-evenly;
}
.screen > .flexer {
	width: 50vw;
}
.img-select + label{
	border:  3px solid #fff;
}
.img-select:checked + label {
	border: 3px solid #ffe4b5;
}
.img-select:checked + label span {
	background-color: #ffe4b5;
}
.tarjeta-larga {
	width: auto;
	height: auto;
	border-radius: 10px;
	background-color: #fff;
	padding: 3rem;
	box-shadow: 0 0 5px #ccc;
	overflow: auto;
}
.tarjeta.image {
	width: 25vw;
	min-width: 25vw;
	max-width: 640px;
	height: 36vw;
	max-height: 36vw;
	min-height: 36vw;
	background-color: #fff;
	border: 10px solid #fff;
	border-radius: 20px;
	box-shadow: 0 0 5px #ccc;
	padding: 0;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	position: fixed;
	top: 50vh;
	left: 0;
	transform: translateY(-50%);
	z-index: 999999;
	left: -100%;
	animation: imagein 1s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
	overflow: hidden;
	margin: 0 1rem;
	transition: margin-left 1s ease-out;
}
.tarjeta.image.preview {
	left: -100% !important;
	overflow: hidden;
}
.vete {
	margin-left:  -150% !important;
	transition: margin-left 1s ease-out;
}
.tarjeta.image.enter {
	animation: imagecheck 2s ease-in-out forwards;
	filter: blur(5px) ;
	animation-iteration-count: 10;
	left: 0px !important;
	transform: translate(140%,-50%);
	transition: transform 1s ease-in-out;
}
@keyframes imagecheck {
	0% {
		filter: blur(0) ;
	}
	50% {
		filter: blur(5px) ;
	}
	100% {
		filter: blur(0) ;
	}
}
img#uploadImg {
	object-fit: cover;
	width: 100%;
	height: auto;
}
span.curso-marker {
    border-radius: 5rem;
    height: 2rem;
    width: 2rem;
    position: absolute;
    top: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    left: 0;
    background-color: #ffe4b5;
}

span.curso-titulo {
	background-color: #ffe4b5cc;
    margin: 0;
    padding: 0.25rem;
    border-radius: 0;
    width: 100%;
}

@keyframes imagein {
	0% { left: -100%; }
	100% { left: 0; }
}
.tarjeta {
	background-color: #fff;
	border: 10px solid #fff;
	border-radius: 20px;
	box-shadow: 0 0 5px #ccc;
	padding: 0 2rem;
	margin: 80px 1rem;
	height: calc(100vh - 190px);
	max-width: 50vw;
	width: 40vw;
	overflow: auto;
	z-index: 999;
	padding: 2rem;
}
label {
	position: relative;
	display: block;
}
label:hover {
	cursor: pointer;
}

label[for=sensaciones] span {
	padding: 0;
	border: none;
}

.planos {
	width: 100%;
	align-items: center;
	display: block;
}
.planos > div,
.planos label {
	width: auto;
	aspect-ratio: 4.6;
	height: calc(100% / 4.6);
	background-size: cover;
	text-align: right;
}
.hr {
	margin: 0;
	border-top: 5px dotted #ffe4b5;
	position: absolute;
	width: 100%;
	z-index: 9;
}
label span,
#screen_11 .planos label span,
#screen_10 .planos label span,
.planos > div > span { 
	background-color: #e7e7e7;
	border-radius: 3px;
	padding: 3px;
	text-align: center;
	margin-right: 0.5rem;
	margin-left: 0.5rem;
	border:  0.2px solid #333;
}
.planos > div,
#screen_11 .planos label,
#screen_10 .planos label {
	display: flex;
	justify-content: right;
	align-items: center;
}
fieldset {
	position: relative;
	border:  none;
	padding: 0;
	width: 100%;
	margin: auto;
}
.rechts {
	position: absolute;
	right: 0.5rem;
	left: auto;
	margin-top: 48px;
	z-index: 9;
}
.hr.ani_01.now {
	top: 43%;
	animation: movetop_1 2s ease-in forwards;
}
.hr.ani_02.now {
	top: 43%;
	animation: movetop_2 2s ease-in forwards;
}
@keyframes movetop_1 {
	0% {
		top: 33%;
	};
	100% {
		top: 43%;
	}
}
@keyframes movetop_2 {
	0% {
		top: 33%;
	};
	100% {
		top: 20%;
	}
}
.portrait {
	aspect-ratio: 0.666;
	width: 45%;
}
label,
.planos > div > span {
	justify-content: end;
	display: flex;
	align-items: center;
	font-size: 0.75rem;
	text-align: center;
	width: min-content;
}
[role=list],
ol {
	margin: 1rem auto;
	position: relative;
	width: fit-content;
}
ol {

max-width: 60ch;
}
[role=list] label {
	justify-content: left;
	width: auto;
	font-size: 1rem;
	line-height: 1.5;
}
[role=list].plano-9 {
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(3, 1fr);
	grid-column-gap: 2px;
	grid-row-gap: 0px;
}
label[for=fondo3] {
	height: 200px;
	aspect-ratio: auto;
}
label[for=fondo4],
label[for=fondo6] {
	height: auto;
	aspect-ratio: 3.5;
}
label[for=segundo4],
label[for=segundo6] {
	height: auto;
	aspect-ratio: 2.5;
}
label[for=primer4],
label[for=primer6] {
	height: auto;
	aspect-ratio: 1.25;
}

.planos:nth-child(1) > div {
    aspect-ratio: 1.25;
}
.planos:nth-child(2) > div {
	
}
.planos:nth-child(3) > div {
	 aspect-ratio: 2.2;
}

.plano-9.vertical {
	aspect-ratio: 0.7;
	grid-gap: 0;
}
.plano-9.vertical label{
	aspect-ratio: 0.7;
}
.plano-9 {
	width: 100%;
	flex-wrap: wrap;
}
.figura {
	display: grid !important;
	grid-template-columns: 2fr 1fr 2fr 1fr;
}
.label-figura-bg {
	aspect-ratio: 0.67;
	padding: 0;
	margin: 0;
	border: none;
	position: relative;
	display: flex;
	background-size: cover;
	background-repeat: no-repeat;
	border-radius: 0;
	border: 2px solid transparent;
	justify-content: center;
	align-items: end;
}
[name=plano_94],
[name=plano_93],
[name=plano_92],
[name=plano_9],
[name=angulo],
[name=angulo2],
[name=prep],
[name=prep2],
[name=prep3],
[name=escala_planos2],
[name=escala_planos] {
	display: none;
}
.plano-9 label {
	width: 98%;
	aspect-ratio: 1.5;
	background-size: cover;
	border:  3px solid #fff;
}
[name=plano_94]:checked + label,
[name=plano_93]:checked + label,
[name=plano_92]:checked + label,
[name=plano_9]:checked + label,
[name=angulo]:checked + label,
[name=angulo2]:checked + label,
[name=prep]:checked + label,
[name=prep2]:checked + label,
[name=prep3]:checked + label,
[name=escala_planos2]:checked + label ,
[name=escala_planos]:checked + label {
	border: 3px solid #ffe4b5 !important;
}
[name=plano_92]:checked + label span,
[name=plano_9]:checked + label span{
	background-color: #ffe4b5 !important;
}
.label-angulo-bg > span,
.label-figura-bg > span,
.label-image-bg > span {
	background: #fff;
	padding: 3px;
	margin: 0.5rem;
	color: #333;
	border-radius: 3px;
	font-size: 0.75rem;
	font-family: "Rubik", sans-serif;
}
.label-angulo-bg {
	aspect-ratio: 1;
	padding: 0;
	margin: 0;
	border: none;
	position: relative;
	width: 24%;
	display: flex;
	background-size: cover;
	background-repeat: no-repeat;
	border-radius: 0;
	border: 2px solid transparent;
	justify-content: center;
	align-items: end;
	justify-content: center;
	text-align: center;
}
input[type=radio] {
	display: none;
}
input.img-select {
	position: absolute;
	margin: 1rem;
}
input[type=radio][name^=prep]:checked + label span,
input[type=radio][name^=angulo]:checked + label span,
input[type=radio][name^=plano]:checked + label span,
input[type=radio][name^=fig]:checked + label span,
input[type=radio][name^=escala_planos]:checked + label span {
	background-color: #ffe4b5;
	color: #333;
}



.top-svg {
	position: relative;
	margin: auto;
	width: 100%;
	height: auto;
}
.top-svg svg {
	max-width: 90px;
}
.buttoner.blocks2,
.buttoner.blocks3 {
	margin: 2rem auto;
	position: relative;
	flex-wrap: wrap;
	display: flex;
	width: fit-content;
	justify-content: space-evenly;
}
.buttoner label { 
}
.planos:nth-child(1) label,
.planos:nth-child(1) > div
{
	border: 3px solid transparent;
	border-bottom:  3px dotted #fff;
}
.planos:nth-child(2) label,
.planos:nth-child(2) > div
{
	border: 3px solid transparent;
}
.planos:nth-child(3) label, 
.planos:nth-child(3) > div
{
	border: 3px solid transparent;
	border-top:  3px dotted #fff;	
}
.planos [type=checkbox],
.buttoner input.radiocheck {
	appearance: none;
	display: none;
}
.planos input[type=checkbox].radiocheck:checked + label {
	border: 3px dotted #ffe4b5;
}
.planos input[type=checkbox].radiocheck:checked + label span {
	background-color: #ffe4b5 !important;
}



.buttoner input.radiocheck + span label,
.buttoner input.radiocheck + label {
	border:  0.25px solid #333;
	padding: 3px;
	border-radius:  5px;
	margin:  0.5rem 0;
	animation: blinkout 0.25s ease-in-out;
}
.buttoner.blocks3 input.radiocheck + span label,
.buttoner.blocks3 input.radiocheck + label {
	height: 100%;
	justify-content: center;
	align-items: center;
}
.buttoner.blocks2 input.radiocheck + span label,
.buttoner.blocks2 input.radiocheck + label {
	width: 33%;
	margin-right: auto;
	margin-left: auto;
}
.buttoner input.radiocheck:checked + span > label,
.buttoner input.radiocheck:checked + label {
	background-color: #ffe4b533;
	animation: blinkin 0.25s ease-in-out;
	border-color: #ffe4b5;
}
.buttoner input.radiocheck:disabled + label:hover {
	cursor: not-allowed;
}

.buttoner input.radiocheck:checked + span > label::before,
.buttoner input.radiocheck:checked + label::before {
	content: "";
	/*background-image: url(imagen/check.svg);*/
	background-image: url("data:image/svg+xml,%3Csvg id='svg839' width='80' height='80' version='1.1' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='g837' transform='matrix(4.0933 0 0 4.0933 -.93264 -.93264)' fill='%23fff' stroke='%232ca02c' stroke-width='2.3'%3E%3Ccircle id='circle833' cx='10' cy='10' r='8.5'/%3E%3Cpath id='path835' d='m5.2 10 3.3 3.4 6.3-6.2'/%3E%3C/g%3E%3C/svg%3E%0A");
	width: 1rem;
	height: 1rem;
	background-size: cover;
	margin-left: 0.25rem;
	position: absolute;
	left: -0.1rem;
	top: 0.2rem;
	z-index: 0;
}
label[for=inputuploadImg].warning {
	background-color: #fff;
	color: #333;
	animation: warning .75s ease-in-out forwards;
	animation-iteration-count: 2;
}
@keyframes warning {
	50% {
		background-color: #cc0000;
		color: #fff;
	} 
}
.button.seguir {
	animation: seguirani .5s ease-in-out forwards 1s;
}
@keyframes seguirani {
	50% {
		background-color: #ffe4b533;
		border-color: #ffe4b533;
	}
}
.admin-form {
	text-align: center;
}	
.admin-form label {
	width: fit-content;
	position: relative;
	margin: auto;
	font-size:  1rem;
	justify-content: center;
}
.admin-form #inputuploadImg {
	overflow: hidden;
	width: 0;
	height: 0;
}
@keyframes blinkin {
	0% {
		background-color: #fff;
	}
	50% {
		background-color: #ffe4b5;
	}
	70% {
		background-color: #fff;	
	}
	100% {
		background-color: #ffe4b5;
	}
}
@keyframes blinkout {
	0% {
		background-color: #ffe4b5;
	}
	/* 50% {
		background-color: #fff;
	}
	70% {
		background-color: #ffe4b5;
	} */
	100% {
		background-color: #fff;
	}
}
.typewriter{
	background: #fff; 
	padding: 10px;
	border: 1px solid #ddd;
	box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.3);
	/* max-width: 640px; */
	margin: auto;
}
.type {
	text-align: left;
	border-bottom: 0.2px solid #333;
	margin-top: 1rem;
	max-width: 100%;
}

/* with gratitude to http://lea.verou.me/2012/02/simpler-css-typing-animation-with-the-ch-unit/*/
/* @keyframes letters {
	from {
		left: 0;
	}
	to {
		left: 50ch;
	}
}
@keyframes lines {
	from {
		top: 0;
	}
	to {
		top: 100%;
	}
}
@keyframes cursor-type {
	50% {
		border-color: #000;
	}
}
@keyframes cursor-wait {
	0% {
		box-shadow: inset 2px 0 0 0 rgba(0, 0, 0, 0);
	}
	1% {
		box-shadow: inset 2px 0 0 0 black;
	}
	40% {
		box-shadow: inset 2px 0 0 0 black;
	}
}
.test {
	display: none;
	animation-name: cursor-wait;
	animation-duration: 0.8s;
	animation-timing-function: ease;
	animation-iteration-count: 2;
	animation-fill-mode: backward;
	animation-delay: 0s;
	padding-left: 10px;
	text-align: left;
}
.type {
	position: relative;
	width: 100%;
	min-width: 25ch;
	line-height: 1.2;
	word-break: break-all;
	overflow: hidden;
	text-align: left;
	font-size: 1rem;
	border-bottom: 0.2px solid #333;
} */
.herramienta .type,
.examen .type {
	display: none;
}
/* @supports (width: 1ch) {
	.type::before, .type::after {
		box-sizing: border-box;
		content: '';
		position: absolute;
		z-index: 1;
		display: block;
		height: 1.2em;
		width: 100%;
		background-color: #fff;
	}
	.type::before {
		border-left: 2px solid transparent;
		top: 100%;
		animation-name: letters, lines, cursor-type, cursor-wait;
		animation-fill-mode: both, both, both, backwards;
	}
	.type::after {
		content: '';
		height: 100%;
		top: 100%;
		left: 0;
		margin-top: 1.2em;
	}
}
.type::before {
	animation-duration: 1.4285714286s, 1.4285714286s, 0.0285714286s, 0.8s;
	animation-timing-function: steps(50, end), steps(1, end), step-end, ease-out;
	animation-iteration-count: 1, 1, 35, 2;
	animation-delay: 1.6s, 1.6s, 1.6s, 0s;
}
.type::after {
	animation: lines 1.4285714286s steps(1, end) 1;
	animation-fill-mode: both;
	animation-delay: 1.6s;
}
.type + .type::before {
	animation-duration: 1.4285714286s, 5.7142857143s, 0.0285714286s, 0.8s;
	animation-timing-function: steps(50, end), steps(4, end), step-end, ease-out;
	animation-iteration-count: 4, 1, 181, 2;
	animation-delay: 4.2s, 4.2s, 4.2s, 2.6s;
}
.type + .type::after {
	animation: lines 5.7142857143s steps(4, end) 1;
	animation-fill-mode: both;
	animation-delay: 4.2s;
}
.type + .type + .type::before {
	animation-duration: 1.4285714286s, 4.2857142857s, 0.0285714286s, 0.8s;
	animation-timing-function: steps(50, end), steps(3, end), step-end, ease-out;
	animation-iteration-count: 3, 1, 120, 2;
	animation-delay: 10.9714285714s, 10.9714285714s, 10.9714285714s, 9.3714285714s;
}
.type + .type + .type::after {
	animation: lines 4.2857142857s steps(3, end) 1;
	animation-fill-mode: both;
	animation-delay: 10.9714285714s;
}
.type + .type + .type + .type::before {
	animation-duration: 1.4285714286s, 7.1428571429s, 0.0285714286s, 0.8s;
	animation-timing-function: steps(50, end), steps(5, end), step-end, ease-out;
	animation-iteration-count: 5, 1, 215, 2;
	animation-delay: 16s, 16s, 16s, 14.4s;
}
.type + .type + .type + .type::after {
	animation: lines 7.1428571429s steps(5, end) 1;
	animation-fill-mode: both;
	animation-delay: 16s;
} */
.fieldset {
	display: flex;
}
.grids {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	width: 100%;
}
.text-label {
	border: none !important;
	box-shadow: none!important;
	padding: 0 !important;
	margin: 1rem 0 0!important;
	display: block;
	text-align: left;
	height: 2rem !important;
}
/* Tablet */
@media(max-width: 768px){
	.screen {
		background: #ffe4b5;
	}
	#screen_2 .grid > div {
		width: 49.5%;
	}
	#first_magia { 
		width: 100vw !important;
	}
	.screen.present .tarjeta{
		margin: auto;
		transition: all 250ms ease-in-out;
		width: 100%;
		max-width: 80%;
		display: block ;
		border-radius: 0;
	}
	.buttoner.blocks2, .buttoner.blocks3 {
		grid-template-columns: 1fr 1fr !important;
		margin: 0 auto;
		width: 100%;
	}
	.screen {
		display: none;
	}
	.screen.present {
		display: block;
	}
	#magico{
		display: block;
		overflow: hidden; 
		width: 100% !important; 
		position: relative;
	}
	#first_magia {
		display: block;
		overflow: hidden; 
		width: 100% !important; 
	}
	.portrait:first-child {
		margin-bottom:  2rem;
	}
	div#tarjetaImg {
		right: 0;
		top: 30px;
		margin: 2px 2px 0 auto;
		border-width: 2px;
		border-radius: 10px;
		min-width: 25px;
		width: 56px;
		height: 56px !important;
		min-height: 56px;
		float: right;
		position: fixed;
		z-index: 999999;
		padding: 0 !important;
		display: none;
	}
	#screen_sub #tarjetaImg {
		display: none;
	}
	.button {
		margin: 0.5rem;
	}

	.screen.present .tarjeta,
	.tarjeta-larga, 
	.tarjeta {
		padding: 1.5rem !important;
		height: calc(100vh - 105px - 2rem) !important;
		display: block;
		flex-direction: column;
		justify-content: center;
		align-items: center;
	}
	.buttoner.blocks2 input.radiocheck + label {
		width: 90%;
	}
	.portrait {
		width: 100%;
	}
	.flexer {
		display: block;
	}
	.fieldset {
		display: block;
	}
	div#tarjetaImg {
		transition: all 250ms ease-in-out;
	}
	div#tarjetaImg.full-view {
/*    right: 0;
    left: 0;
    width: 100%;
    min-width: unset;
    max-width: unset;
    height: 100vh !important;
    max-height: 100%;
    margin: 0;
    border: none;
    border-radius: 0;*/
    position: fixed;
    max-width: 100%;
    width: 100%;
    display: block;
    height: 100vh !important;
    max-height: 100%;
    margin: 0;
    top: 0;
    border: none;
    border-radius: 0;
    background-size: contain;
    transform: translateY(0);
    /*transition: all 250ms ease-in-out;*/
}
div#tarjetaImg.full-view::after {
	content: "⨂";
	background-color: #fff;
	top: 1rem;
	right: 1rem;
	width: 1rem;
	height: 1rem;
	position: absolute;
	border-radius: 2rem;
	text-align: center;
	padding: 0.5rem;
	line-height: 0.85;
}
.flexer.angulo {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	width: 100%;
}
.grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.grids {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	width: 100%;
}
[role=list] label {
	justify-content: center;
	align-items: flex-end;
}
.figura {
	grid-template-columns: 2fr 1fr;
}
.teiler.fix {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background: #fff;
	border-top: 0.2px solid #333;
	margin: 0;
	width: 100vw;
	padding: 0.5rem 0;
	display: flex;
	justify-content: space-evenly;
}
}
/* Movil */
@media(max-width: 480px){
	.buttoner.blocks2, .buttoner.blocks3 {
		grid-template-columns: 1fr !important;
	}
	#screen_2 .grid > div {
		width: 99%;
	}
	div#screen_1 .tarjeta {
		border-radius: 0;
	}
}
/* --- */
.img-select:checked + label::before {
	content: "";
	width: 100%;
	height: 100%;
	/*background-image: url(imagen/check.svg);*/
	background-image: url("data:image/svg+xml,%3Csvg id='svg839' width='80' height='80' version='1.1' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='g837' transform='matrix(4.0933 0 0 4.0933 -.93264 -.93264)' fill='%23fff' stroke='%232ca02c' stroke-width='2.3'%3E%3Ccircle id='circle833' cx='10' cy='10' r='8.5'/%3E%3Cpath id='path835' d='m5.2 10 3.3 3.4 6.3-6.2'/%3E%3C/g%3E%3C/svg%3E%0A");
	animation: render 150ms linear both;
	background-size: 80px;
	background-position: center;
	background-repeat: no-repeat;
	position: absolute;
}
@keyframes render {
	0% {
		background-size:  0;
	}
	70% {
		background-size: 100px;
	}
	80% {
		background-size: 80px;
	}
	90% {
		background-size: 100px;
	}
	100% {
		background-size: 80px;
	}
}

        @media (pointer:coarse) {
fieldset.emergente,
	fieldset.emergente .typewriter{
		position: static;
	}
	fieldset.emergente .flexer.inthewin{
		background: #ffe4b5;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		padding: 2rem;
		display: flex;
		flex-direction: column;
		justify-content: center;
		z-index: 999;

	}
		fieldset.emergente .flexer label{
			display: block;
			text-align: left;
}
}