html, body {
    margin: 0;
    padding: 0;
    /* height: 100%; */
}
.mainleft-text-frame {
	border: none;
 	margin: 0px;
    padding: 0px;
    padding-top:1.0em;
    padding-left:1.0em;
    /* min-width: 360px; */
    min-height: 640px;
    max-height: 100%;
    width:400px;
    min-width: 270px;
    overflow-wrap: break-word;
    background-color: #ffe;

}
/* 
.mainbody {
    height:100%;
    .mainleft-text-frame {
    height:100%;
    iframe{ 
        height:100%;
    }
    }

} */

.search-result-frame {
	border: none;
 	margin: 0px;
    padding: 0px;
    /* min-width: 640px; */
    min-height: 640px;
    max-height: 100%;
    overflow-wrap: break-word;
    /* background-color: #ffe; */
    width: calc(98% - 300px);
	min-width: 630px;
	max-width: 1000px;
	text-align: center;
	background-color: #FFFFFF;
}

.search-result {
    padding-right: 1.0em;
    width: 250px;

}

.mainright-text-frame {
	width: 100%;
    padding-top: 10px;
    padding-left: 10px;
    padding-right: 10px;
    background-color: #ffe;
    overflow-wrap: break-word;
}
.result-line{
    border: dashed 1px #777; 
    height: 1px;
    color: white;
}
.highlight {
   background-color: yellow;
}
.serach-result-text {
    font-size:15px;
    line-height: 1.6em;
    padding-top: 10px;
    padding-bottom: 10px;
    display: inline-block;
}
.result-number-display{
    margin: 0px;
    padding: 0px;
    font-size:15px;
    line-height: 1.6em;
    padding-top: 10px;
    padding-bottom: 10px;
    display: inline-block;
}
.search-text-box{
    margin-bottom: 0px;
    width: 200px;
    height: 15px;
    font-size: 10pt;
    border: double 1px #777;
}
.keyword {
    font-size: 15px;
    line-height: 1.6em;
    padding-top:1.0em;
}
.keyword li {
    font-size: 15px;
    line-height: 1.6em;
    margin-top:6px;
    margin-bottom:4px;
}
dl {
    font-size: 1.2em;
}
dt a{
    font-weight: bold;
    font-size: 1.2em;
}
dd {
    font-size: 1.2em;
    line-height: 1.4em;
    margin-bottom:10px;
}

.result-hit-word{
    background-color: #afa;
    color: #000;
}
.search-commentary{
    padding-top:0;
    padding-right: 1.0em;;
    margin-bottom: 10px;
    font-size: 15px;
    line-height: 1.6em;
    width:250px;
}
.search-text-box-all{
    vertical-align: middle;
    width: 190px;
    height: 26px;
    font-size: 14pt;
    border: double 1px #777;
}
.search-button{
    padding-right: 5px;
    padding-left: 5px;
    vertical-align: middle;
    text-align: center;
    height: 26px;
    font-size: 12pt;
    border: double 1px #000;
}
.Qtext {
	background-color: #eee;
	background-image: url(/img/icon_q.gif);
	background-repeat: no-repeat;
	background-position: left 1px top 6px;
	padding: 10px 6px 6px 30px;
	/* page-break-before: auto;
	page-break-after: avoid; */
    font-size:15px;
    line-height: 1.6em;
    margin: 20px 30px 10px;
    text-align: left;
}
.QtextQ a {
	background-color: #eee;
	display: block;
	background-image: url(/img/icon_q.gif);
	background-repeat: no-repeat;
	background-position: left 1px top 6px;
	padding: 10px 6px 6px 30px;
	text-decoration: none;
	color: #000000;
}

.QtextQ a:hover {
	background-color: #99CCFF;
	text-decoration: none;
	color: #003399;
}

.Atext {
	padding: 10px 6px 30px 30px;
	color: #204962;
	background-image: url(/img/icon_a.gif);
	background-repeat: no-repeat;
	background-position: left 1px top 6px;
	/* page-break-before: auto;
	page-break-after: avoid; */
    font-size:15px;
    line-height: 1.6em;
    margin: 10px 30px;
    text-align: left;
}

/*  レイアウト調整用  */

.common-mainTxt-area {
    text-align: center;
}
.common-mainTxt-area p {
    font-size: 15px;
    line-height: 1.6em;
}
.to-top-navi p {
    margin:0;
    padding:0;
}
div.maintext {
    background-color: #fff !important;

}



/*-------------------------- レスポンシブ 調整用CSS ここから -----------------------------------------*/

@media screen and (max-width:640px) {
	/* ↓ここに個別のスマホ用スタイルを指定 */

.mainbody{
    display: flex;
    flex-direction: column;

}
.mainleft-text-frame {
	border: none;
 	margin: 0px;
    padding:1.0em;
    padding-right:2.0em;
    min-height: 250px;
    max-height: 50%;
    /* width:100%; */
    overflow-wrap: break-word;
    background-color: #ffe;
	border-bottom: 1px solid #777;
}
.search-commentary{
    padding-top:0;
    padding-right: 0em;
    padding-left: 0em;
    margin-bottom: 10px;
    font-size: 15px;
    line-height: 1.6em;
    /* width:100%; */
}
.search-result {
    padding-right: 1.0em;
    width: 100%;

}

.search-result-frame {
    min-height: 640px;
    max-height: 100%;
    width: 100%;
	min-width: 100%;
	max-width: 100%;
}
.common-mainTxt-area {

width:100%;

}

.Qtext {

    margin: 20px 10px 10px;
}

.Atext {
    margin: 10px 10px;
}


	/* ↑ここまでに個別のスマホ用スタイルを指定 */
}


/*-------------------------- レスポンシブ用CSS ここまで ----------------------*/