/*******************************************************************************************************************************/

:root {
	--otsikkofontti: 1em/1.2 "inter", serif;
	--leipateksti: 1em/1.2 "inter", serif;
}

/*******************************************************************************************************************************/

/* ipad ------------------- */
@media only screen 
and (min-device-width: 768px) 
and (max-device-width: 1024px)
and (orientation: landscape){
	html[os="ios"].no-parent,
	html[os="ios"].no-parent body {
		height: 100% !important;
		min-height: 100% !important;
	}
	html[os="ios"].no-parent #container {
		position: fixed !important;
		height: 100% !important;
		min-height: 100% !important;
	}
}


/***/
.material-icons-outlined,
.material-symbols-outlined {
	font-size: 35px;
	color: inherit;
}
.material-icons-outlined:first-child:not(:last-child),
.material-symbols-outlined:first-child:not(:last-child) {
	margin-right: 5px;
}
.material-icons-outlined:last-child:not(:first-child),
.material-symbols-outlined:last-child:not(:first-child) {
	margin-left: 5px;
}


/***/
#container {
	width: 100vw;
	height: 100vh;
}


/***/
#wrapper {
	display: flex;
	width: 100%;
	height: 100%;
}
#wrapper-a {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
}
#wrapper-b {
	flex: 0 0 60px;
	border-left: 1px solid var(--paavari-vaalea);
	max-width: 60px;
}



/***/
#ylapalkki {
	flex: 0 0 60px;
	padding-left: 30px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--harmaa-vaalea);
	background-color: #fff;
	z-index: 1;
}
html.navigaatio-paivanavaus-esilla #ylapalkki-murupolku,
html.navigaatio-paivanavaus-esilla #ylapalkki-materiaali {
	display: none;
}


#ylapalkki-a {
	display: flex;
	align-items: center;
}
#ylapalkki-logo {
	
}
#ylapalkki-logo > img {
	display: block;
	width: auto;
	height: 30px;
}
#ylapalkki-otsikko {
	font-size: 19px;
	font-weight: 600;
	color: var(--paavari);
	margin-left: 40px;
	white-space: nowrap;
	cursor: pointer;
}
#ylapalkki-murupolku {
	font-size: 14px;
	color: var(--harmaa);
	margin-left: 40px;
}
.ylapalkki-murupolku-erotin {
	display: inline-block;
	transform: scaleX(.5);
}


#ylapalkki-b {
	display: flex;
	height: 100%;
}
html:not(.materiaalipankki-kaytossa) #materiaalipankki-toggle {
	display: none;
}
#materiaalipankki-toggle {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	font-size: 17px;
	padding: 0 15px;
	margin-left: 5px;
	white-space: nowrap;
	color: var(--editavari);
	cursor: pointer;
}
html.materiaalipankki-esilla #materiaalipankki-toggle {
	box-sizing: content-box;
	border-bottom: 1px solid var(--harmaa-vaalea);
	background-color: var(--harmaa-vaalea);
}
#materiaalipankki-toggle div {
	font-weight: 500;
}
#materiaalipankki-toggle .material-icons-outlined {
	font-size: 30px;
}
#materiaalipankki-toggle > *:last-child {
	color: inherit;
}
html.materiaalipankki-esilla #materiaalipankki-toggle > *:last-child {
	transform: rotate(180deg);
}
html.no-touch #materiaalipankki-toggle:hover > div {
	text-decoration: underline;
}


/***/
.valikko {
	padding: 20px;
	overflow-y: auto;
	z-index: 0;
	color: var(--editavari);
}
.valikko-wrapper {
	align-items: normal;
	justify-content: normal;
	width: 100%;
	font-size: 17px;
}
.valikko-otsikko {
	justify-content: flex-start;
}
.valikko-otsikko-sisalto {
	flex: 1 1 auto;
}
.valikko-otsikko[data-valikkotaso="0"] {
	font-weight: 600 !important;
	border-bottom: 2px solid var(--paavari) !important;
}
.valikko-linkki {
	justify-content: flex-start;
	cursor: pointer;
}
.valikko-linkki.selected,
.valikko-linkki.disabled {
	pointer-events: none;
}
.valikko-linkki.disabled > * {
	opacity: .5;
}
.valikko-linkki-sisalto {
	flex: 1 1 auto; 
}
html.no-touch .valikko-linkki:not(.selected):hover .valikko-linkki-sisalto {
	text-decoration: underline;
}


/***/
#sisallysluettelo {
	position: absolute;
	right: 60px;
	top: 60px;
	width: 420px;
	max-width: 100vw;
	height: calc(100% - 60px);
	background-color: var(--paavari-vaalea);
}
html:not(.sisallysluettelo-esilla) #sisallysluettelo {
	display: none;
}
#sisallysluettelo .valikko-wrapper {
	gap: 17px;
}
#sisallysluettelo .valikko-wrapper2.closed > *:not(:first-child) {
	display: none;
}
#sisallysluettelo .valikko-otsikko[data-valikkotaso="0"] {
	padding: 5px 0;
	background-color: transparent;
	cursor: pointer;
}
#sisallysluettelo .valikko-otsikko-toggle {
	flex: 0 0 auto;
	width: 20px;
	height: 0;
}
#sisallysluettelo .valikko-otsikko-toggle > * {
	font-size: 30px;
	color: inherit;
}
#sisallysluettelo .valikko-wrapper2 {
	
}
#sisallysluettelo .valikko-wrapper2.closed .valikko-otsikko-toggle > * {
	transform: rotate(180deg);
}
html.no-touch #sisallysluettelo .valikko-otsikko[data-valikkotaso="0"]:hover .valikko-otsikko-sisalto {
	text-decoration: underline;
}
#sisallysluettelo .valikko-linkki {
	padding: 20px;
	border-bottom: 1px solid var(--paavari-vaalea);
	background-color: #FFF;
}
#sisallysluettelo .valikko-linkki.selected {
	font-weight: 600;
	background-color: rgba(255,255,255,.6);
}
#sisallysluettelo .valikko-wrapper3 {
	padding-left: 52px;
	margin-bottom: -1px;
}
#sisallysluettelo .valikko-wrapper3::before {
	content: '';
	position: absolute;
	top: -1px;
	left: 0;
	right: 0;
	border-top: 2px solid var(--harmaa-vaalea2);
	z-index: 2;
}
#sisallysluettelo .valikko-wrapper3::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	border-bottom: 2px solid var(--harmaa-vaalea2);
	z-index: 2;
}
#sisallysluettelo .valikko-wrapper3 > .valikko-otsikko[data-valikkotaso="1"] {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 52px;
	border-right: 1px solid var(--paavari-vaalea);
	border-bottom: 1px solid var(--paavari-vaalea);
	background-color: var(--harmaa-vaalea);
	font-weight: 600;
	padding-top: 20px;
	z-index: 1;
}


#sisallysluettelo-tasot {
	margin-bottom: 20px;
}
#sisallysluettelo-tasot .valilehti {
	font-family: "inter", sans-serif;
	color: var(--paavari);
	background-color: #FFFFFF;
}
#sisallysluettelo-tasot .valilehti.selected,
html.no-touch #sisallysluettelo-tasot .valilehti:not(.selected):hover {
	color: #fff;
	background-color: var(--paavari);
}


#sisallysluettelo-tasot-valittu {
	font-size: 20px;
	margin: 0 0 17px;
	font-weight: 600;
}


/***/
#materiaalipankki {
	position: absolute;
	top: 60px;
	left: 0;
	width: 100%;
	max-height: calc(100% - 60px);
	background-color: var(--harmaa-vaalea);
	z-index: 1;
}
html:not(.materiaalipankki-esilla) #materiaalipankki {
	display: none;
}
#materiaalipankki .valikko-wrapper {
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: 20px;
}
#materiaalipankki .valikko-wrapper > * {
	flex: 0 1 250px;
}
#materiaalipankki .valikko-otsikko[data-valikkotaso="0"] {
	color: var(--paavari);

	padding: 8px 0 7px 32px;
	background-color: unset;
	background-position: left top;
	background-repeat: no-repeat;
	background-size: 32px auto;
}
#materiaalipankki .valikko-otsikko,
#materiaalipankki .valikko-linkki {
	padding: 0 0 0;
	background-color: unset;
}
#materiaalipankki [data-valikkotaso="1"] {
	margin: 16px 8px 8px;
	font-weight: 500;
}
#materiaalipankki [data-valikkotaso="2"] {
	margin: 8px 0 8px 32px;
}
#materiaalipankki .valikko-linkki.selected {
	text-decoration: underline;
}
#materiaalipankki .valikko-otsikko[data-valikkotaso="0"][data-otsikko="Pedagogista taustatietoa"]{
	background-image: url(ikonit/pedagogista_taustatietoa.svg);
}
#materiaalipankki .valikko-otsikko[data-valikkotaso="0"][data-otsikko="Ideoita opetukseen"]{
	background-image: url(ikonit/ideoita_opetukseen.svg);
}
#materiaalipankki .valikko-otsikko[data-valikkotaso="0"][data-otsikko="Tulostettavat materiaalit"]{
	background-image: url(ikonit/tulostettavat_materiaalit.svg);
}
#materiaalipankki .valikko-otsikko[data-valikkotaso="0"][data-otsikko="Esitettävät materiaalit"]{
	background-image: url(ikonit/luokassa_esitettavat_materiaalit.svg);
}


/***/
#navigaatio {
	
}
.navigaatio-nappi {
	width: 100%;
	height: 60px;
	cursor: pointer;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 80% auto;
	color: var(--paavari);
}
.navigaatio-nappi {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 60px;
	cursor: pointer;
}
.navigaatio-nappi > * {
	font-size: 40px;
}
html.no-touch .navigaatio-nappi:hover {
	color: var(--editavari);
}
#navigaatio-nappi-koti,
#sisallysluettelo-toggle {
	color: #FFFFFF;
	background-color: var(--editavari);
}
html.no-touch #navigaatio-nappi-koti:hover,
html.no-touch #sisallysluettelo-toggle:hover {
	color: var(--paavari-vaalea);
}
#navigaatio-nappi-kokoruutu > * {
	font-size: 47px;
}
#navigaatio-nappi-merkintatyokalut > * {
	font-size: 37px;
}


html.sisallysluettelo-esilla #sisallysluettelo-toggle {
	color: var(--paavari);
	background-color: var(--paavari-vaalea);
}
html.sisallysluettelo-esilla.no-touch #sisallysluettelo-toggle:hover {
	color: var(--editavari);
}
html.sisallysluettelo-esilla #sisallysluettelo-toggle::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	border-left: 1px solid var(--paavari-vaalea);
}


#navigaatio-merkintatyokalut-valikko {
	position: absolute;
	width: 60px;
	right: 60px;
	top: 60px;
	bottom: 0;
	padding: 0;
	color: var(--editavari);
	background-color: var(--paavari-vaalea);
	overflow-x: hidden;
}
#navigaatio-merkintatyokalut-valikko::-webkit-scrollbar {
	width: 2px;
	height: 2px;
	border-radius: 1px;
}
#navigaatio-merkintatyokalut-valikko::-webkit-scrollbar-track {
	background: #FFFFFF;
}
#navigaatio-merkintatyokalut-valikko::-webkit-scrollbar-thumb {
	background: var(--editavari);
}
#navigaatio-merkintatyokalut-valikko::-webkit-scrollbar-thumb:hover {
	background: var(--editavari);
} 
#navigaatio-merkintatyokalut-valikko .valikko-wrapper {
	width: 60px;
}
html:not(.merkintatyokalut-esilla) #navigaatio-merkintatyokalut-valikko {
	display: none;
}
html.merkintatyokalut-esilla #navigaatio-nappi-merkintatyokalut {
	background-color: var(--paavari-vaalea);
}
.navigaatio-merkintatyokalut-nappi {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 60px;
	cursor: pointer;
}
html.no-touch .navigaatio-merkintatyokalut-nappi:hover {
	color: var(--paavari);
}
.navigaatio-merkintatyokalut-nappi.valittu::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 80%;
	height: 80%;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	background-color: #FFFFFF;
}


html[data-luokka="välineet"] #navigaatio-nappi-valineet {
	background-color: var(--paavari-vaalea);
}
html[data-luokka="välineet"].merkintatyokalut-esilla #navigaatio-nappi-valineet::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
}


html[data-luokka="päivänavaus"] #navigaatio-nappi-paivanavaus {
	background-color: var(--paavari-vaalea);
}
html[data-luokka="päivänavaus"].merkintatyokalut-esilla #navigaatio-nappi-paivanavaus::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	border-left: 1px solid #fff;
}



/***/
#sisalto {
	flex: 1 1 auto;
	z-index: 0;
	display: flex;
	flex-direction: row-reverse;
}
.iframe-container {
	position: relative;
	width: 100%;
	height: 100%;
	flex: 1 1 100%;
}
.iframe-container.preloader iframe {
	opacity: 0;
}
.iframe-container iframe,
.iframe-container embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}
.iframe-container:not(:last-child) {
	position: absolute;
	left: 0;
	top: 0;
	visibility: hidden;
}
#sisalto .iframe-container:not(:last-child) {
	pointer-events: none;
}
html.merkintatyokalut-esilla #sisalto {
	margin-right: 60px;
}

.tehtavapolku-devaus {
	position: absolute;
	left: 0;
	top: 0;
	right: 200px;
	padding: 10px 0 10px 30px;
	justify-content: flex-start;
	pointer-events: none;
}
.tehtavapolku-devaus > * {
	font-size: 15px;
	text-shadow: 1px 1px 0 #FFF;
	pointer-events: all;
}
.tehtavapolku-devaus > *:last-child {
	cursor: text;
	-webkit-user-select: text;
	user-select: text;
}


html:not(.merkintatyokalut-esilla) #merkinnat {
	display: none;
}


.nappi.sulje.sulje-extraB {
	position: absolute;
	top: .8em;
	right: .8em;
	z-index: 100;
	color: var(--harmaa) !important;
}
.nappi.sulje.sulje-extraB.piilotettu {
	visibility: hidden;
}
html.no-touch .nappi.sulje.sulje-extraB:not(.disabled):not(.selected):hover {
	color: #000 !important;
}


/***/
#valilehdet {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	/* flex: 0 0 60px; */
	height: 60px;
	justify-content: center;
	z-index: 1;
}
#valilehdet .valilehti {
	color: var(--paavari);
}
#valilehdet .valilehti.selected,
html.no-touch #valilehdet .valilehti:not(.selected):hover {
	color: #fff;
	background-color: var(--paavari);
}


/***/
/*#extravalikko {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}*/


/***/
/*html[data-luokka="päivänavaus"] #wrapper-a {
	background-image: url(kuvat/vinkkeli_kesa.jpg);
	background-attachment: fixed;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}*/
html[data-luokka="välineet"] #wrapper-a,
html[data-luokka="päivänavaus"] #wrapper-a {
	background-image: var(--taustapattern);
	background-attachment: fixed;
	background-position: top left;
	background-repeat: repeat;
	background-size: 300px auto;
}