/* style.css 180919 */

/* init. */
html,body,div,h1,h2,h3,h4,h5,h6,p,ul,ol,li,dl,dt,dd,table,th,td,address {
	margin: 0;
	padding: 0;
}
header,main,aside,footer,section,nav,article {
	display: block;
}
html {
	overflow-y: scroll;
}
body {
	overflow: hidden;
	font-size: 13px;
	font-family: sans-serif;
	line-height: 1.5;
	background: #fff;
	color: #1A1311;
	text-align: justify;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
}
ul,ol {
	list-style: none;
}
ul.disc {
	list-style: disc;
	padding-left: 20px;
}
ol.decimal {
	list-style: decimal;
	padding-left: 20px;
}
table {
	border-spacing: 0;
}
address {
	font-style: normal;
}
a[href] {
	color: #00f;
}
a:hover img {
	transition: all 0.5s linear;
	opacity: 0.7;
}
strong {
	font-weight: inherit;
}
p {
	margin-top: 1em;
}
section {
	margin-top: 20px;
}

/* util. */
.in { padding-left: 3% !important; padding-right: 3% !important; }
.bb { box-sizing: border-box; }
.oh { overflow: hidden; }
.relative { position: relative; }
.cf:after { content: ""; display: block; clear: both; }
.serif { font-family: serif; }
p.ti,ul.ti li { text-indent: -1em; padding-left: 1em; }
.red { color: #f00;	font-weight: bold; }
.blue { color: #00f;	font-weight: bold; }
.pink { color: #f0f;	font-weight: bold; }
.brown { color: #900; font-weight: bold; }
.green { color: #2b8200; }
.yellow { background: #ff0; }
.orange { background: #FFD83C; }

.btn {
	width: 80%;
	max-width: 340px;
	display: inline-block;
	background: #40a6fa;
	color: #fff !important;
	padding: 10px;
	text-align: center;
	text-decoration: none;
	box-sizing: border-box;
	border: none;
	cursor: pointer;
	line-height: 1.2;
}
.btn:hover {
	transition: all 0.5s linear;
	opacity: 0.8;
}
.se {
	opacity: 0;
	transform: translateY(100px);
	transition: all 1s cubic-bezier(0.48, 0.18, 0, 0.98);
}
.se.active {
	opacity: 1;
	transform: translateY(0);
}
.tr { text-align: right; }
.tc { text-align: center; }
.tl { text-align: left; }

.none { display: none !important; }
.block { display: block !important; }
.inline { display: inline !important; }
.ib { display: inline-block !important; }
.table { display: table !important; }
.cell { display: table-cell !important; }
.li { display: list-item!important; }

.mt0 { margin-top: 0 !important; }

.p0 { padding: 0 !important; }
.p5 { padding: 5px !important; }
.p10 { padding: 10px !important; }
.p15 { padding: 15px !important; }
.p20 { padding: 20px !important; }
.p25 { padding: 25px !important; }
.p30 { padding: 30px !important; }

.pt3p { padding-top: 3% !important; }
.pt0 { padding-top: 0 !important; }
.pt5 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt45 { padding-top: 45px !important; }
.pt50 { padding-top: 50px !important; }
.pt55 { padding-top: 55px !important; }
.pt60 { padding-top: 60px !important; }

.pb3p { padding-bottom: 3% !important; }
.pb0 { padding-bottom: 0 !important; }
.pb5 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb45 { padding-bottom: 45px !important; }
.pb50 { padding-bottom: 50px !important; }
.pb55 { padding-bottom: 55px !important; }
.pb60 { padding-bottom: 60px !important; }

.px10 { padding-left: 10px !important; padding-right: 10px !important; }
.px15 { padding-left: 15px !important; padding-right: 15px !important; }
.px20 { padding-left: 20px !important; padding-right: 20px !important; }

.py0 { padding-top: 0 !important; padding-bottom: 0 !important; }
.py3 { padding-top: 3px !important; padding-bottom: 3px !important; }
.py5 { padding-top: 5px !important; padding-bottom: 5px !important; }
.py10 { padding-top: 10px !important; padding-bottom: 10px !important; }
.py15 { padding-top: 15px !important; padding-bottom: 15px !important; }
.py20 { padding-top: 20px !important; padding-bottom: 20px !important; }
.py25 { padding-top: 25px !important; padding-bottom: 25px !important; }
.py30 { padding-top: 30px !important; padding-bottom: 30px !important; }

.w100p { width: 100% !important; }

/**/
img.right {
	width: 120px;
	float: right;
	margin: 0 0 10px 10px;
}
img.left {
	width: 120px;
	float: left;
	margin: 0 10px 10px 0;
}
.h-1 {
	font-size: 16px;
	color: #f00;
	border-bottom: 1px solid #000;
	margin-bottom: 10px;
}
.red-border-wp {
	margin-top: 15px;
	border: 3px solid #900;
	padding: 3%;
}
.banner-wp {
	margin-top: 15px;
	text-align: center;
}
.btn-favorite {
	margin-top: 5px;
	font-size: 12px;
	border: 1px solid #ff9b06;
	background: #fffcf7;
}
header .h {
	padding-top: 5px;
	font-size: 12px;
	font-weight: normal;
	line-height: 1.2;
}
header .favorite-wp {
	margin: 5px 0;
	text-align: center;
}
header .p-1 {
	text-align: center;
}
header .main-img {
	margin-top: 5px;
}
.shoten-wp {
	margin-top: 10px;
}
.shoten-wp .big {
	font-size: 15px;
}
.shoten-wp .title {
	margin-top: 1em;
	font-size: 17px;
	font-weight: bold;
	display: inline-block;
	text-align: left;
	color: #f00;
	line-height: 1.2;
	border-bottom: 1px solid #000;
}
.shoten-wp .red-border-wp .ill-1 {
	width: 50%;
	max-width: 170px;
}
.shoten-wp .p-1 {
	margin-top: 15px;
}
.shoten-wp .attention {
	width: 30%;
	max-width: 95px;
}
.shoten-wp .brown-wp {
	margin-top: 15px;
	padding: 3%;
	background: #f1e2cb;
}
.shoten-wp .brown-wp .h {
	font-size: 15px;
	margin-bottom: 10px;
}
.shoten-wp .brown-wp .character-list>li {
	text-indent: -1em;
	padding-left: 1em;
	text-align: justify;
}
.shoten-wp .brown-wp .character-list>li:before {
	content: "●";
	color: #cfbb9c;
}
.shoten-wp .img-wp {
	margin: 20px 0;
}
.amino-sec .youtube-wp {
	width: 100%;
	height: 0;
	padding-top: 56.2%;
	position: relative;
}
.amino-sec .youtube-wp iframe {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 100%;
	height: 100%;
	border: none;
}
.amino-sec .prof-list>li {
	text-indent: -1em;
	padding-left: 1em;
}
.amino-sec .prof-list>li:before {
	content: "■";
	color: #900;
}
.amino-sec .intro {
	background: #f8f8f8 url(../img/kansouback.jpg) no-repeat right top;
}
.genkai-sec .h {
	margin: 15px 0;
	font-size: 16px;
	color: #f00;
	text-align: center;
}
.keiyoushi-sec .img-wp {
	margin: 15px 0;
	text-align: center;
}
.keiyoushi-sec .img-wp img {
	border: 3px solid #900;
	box-sizing: border-box;
}
.point-sec .sekai-list {
	color: #900;
}
.point-sec .sekai-list>li {
	text-indent: -1em;
	padding-left: 1em;
}
.point-sec .sekai-list>li:before {
	content: "●";
}
.point-sec .point-list {
	margin-top: 15px;
	font-weight: bold;
	color: #f00;
}
.point-sec .red-border-wp .h {
	font-size: 15px;
	color: #900;
}
.point-sec .red-border-wp .h:not(:first-of-type) {
	margin-top: 1em;
}
.point-sec .red-border-wp p {
    padding: 0 9%;
}
.point-sec .img-wp {
	margin-top: 1em;
}
.point-sec .img-wp img {
	border: 2px solid #900;
}
.point-sec .merit-list {
	margin-top: 1em;
}
.point-sec .merit-list>li {
	text-indent: -1em;
	padding-left: 1em;
}
.point-sec .merit-list>li:before {
	content: "■";
	color: #f0f;
}
.cost-sec .h {
	margin-top: 1em;
	font-size: 14px;
}
.cost-sec .orange strong {
	font-size: 16px;
	font-weight: bold;
}
.expensive-sec .img-wp {
	margin-top: 15px;
	text-align: center;
}
.expensive-sec .img-product {
	margin-top: 15px;
	border: 3px solid #900;
}
.expensive-sec .big-1 {
	font-size: 20px;
}
.expensive-sec .big-2 {
	font-size: 16px;
}
.expensive-sec .big-2 .orange {
	font-size: inherit;
}
.expensive-sec .banner-wp {
	margin-top: 15px;
	text-align: center;
}
.expensive-sec .yellow-border-wp {
	margin-top: 15px;
	border: 2px dashed #cc0;
	text-align: center;
	padding: 3%;
}
.expensive-sec .if {
	margin-top: 1em;
	width: 250px;
	height: 100px;
	border: none;
}
.expensive-sec .big,.expensive-sec .orange {
	font-size: 15px;
}
.expensive-sec .sarani {
	display: none;
}
.free-sec .red-border-wp {
	padding: 0;
}
.free-sec .red-border-wp .inner {
	padding: 0 3% 3%;
}
.free-sec .shiharai-wp .big {
	font-size: 16px;
	margin-bottom: 1em;
}
.free-sec .shiharai-wp .left {
	width: 55px;
}
.free-sec .shiharai-wp .shiharai-list {
	margin: 1em 0;
}
.free-sec .shiharai-wp .shiharai-list>li {
	text-indent: -1em;
	padding-left: 1em;
}
.free-sec .shiharai-wp .img-koe {
	margin-top: 15px;
	border: 3px solid #d8822b;
}
.free-sec .img-wp {
	margin-top: 15px;
	text-align: center;
}
.free-sec .img-wp img:not(:first-of-type) {
	margin-top: 1em;
}
.faq-sec .yellow-border-wp {
	margin-top: 15px;
	border: 3px solid #990;
	padding: 3%;
}
.faq-sec .question,.faq-sec .answer {
	font-size: 15px;
	font-weight: bold;
	background: url(../img/question.gif) no-repeat left top;
	padding: 0 0 5px 50px;
	color: #00f;
}
.faq-sec .answer {
	background: url(../img/answer.gif) no-repeat left top;
	color: #f00;
}
.faq-sec .form {
	padding-left: 50px;
}
.last-sec .signature-wp {
	margin-top: 15px;
	text-align: right;
}
.last-sec a .ib {
	text-decoration: underline;
}
.voice-sec .h {
	font-size: 15px;
	color: #f00;
	line-height: 1.2;
}
.voice-sec .name {
	text-align: right;
	font-weight: bold;
}
.voice-sec .red-border-wp.v1 {
	text-align: center;
}
.voice-sec .red-border-wp.v1>div {
	text-align: left;
	max-width: 480px;
	margin: auto;
}
.tsuishin-sec .right {
	width: 100%;
}
.tsuishin-sec .img-wp {
	margin-top: 15px;
}
.footer-wp {
	margin-top: 20px;
	border-top: 3px solid #900;
	padding: 10px 0;
}
.footer-wp nav {
	text-align: center;
	font-size: 12px;
}
.footer-wp input[type="button"] {
	
}
.footer-wp .copyright {
	text-align: center;
	line-height: 1.2;
}
.footer-wp .copyright small {
	font-size: 12px;
}

@media screen and (min-width: 550px) {
	
	/* util. */
	.tb-tr { text-align: right; }
	.tb-tc { text-align: center; }
	.tb-tl { text-align: left; }

	.tb-none { display: none !important; }
	.tb-block { display: block !important; }
	.tb-inline { display: inline !important; }
	.tb-ib { display: inline-block !important; }
	.tb-table { display: table !important; }
	.tb-cell { display: table-cell !important; }
	.tb-li { display: list-item!important; }
	
	.tb-p0 { padding: 0 !important; }
	.tb-p5 { padding: 5px !important; }
	.tb-p10 { padding: 10px !important; }
	.tb-p15 { padding: 15px !important; }
	.tb-p20 { padding: 20px !important; }
	.tb-p25 { padding: 25px !important; }
	.tb-p30 { padding: 30px !important; }

	.tb-pt0 { padding-top: 0 !important; }
	.tb-pt5 { padding-top: 5px !important; }
	.tb-pt10 { padding-top: 10px !important; }
	.tb-pt15 { padding-top: 15px !important; }
	.tb-pt20 { padding-top: 20px !important; }
	.tb-pt25 { padding-top: 25px !important; }
	.tb-pt30 { padding-top: 30px !important; }

	.tb-pb0 { padding-bottom: 0 !important; }
	.tb-pb5 { padding-bottom: 5px !important; }
	.tb-pb10 { padding-bottom: 10px !important; }
	.tb-pb15 { padding-bottom: 15px !important; }
	.tb-pb20 { padding-bottom: 20px !important; }
	.tb-pb25 { padding-bottom: 25px !important; }
	.tb-pb30 { padding-bottom: 30px !important; }

	.tb-px10 { padding-left: 10px !important; padding-right: 10px !important; }
	.tb-px15 { padding-left: 15px !important; padding-right: 15px !important; }
	.tb-px20 { padding-left: 15px !important; padding-right: 15px !important; }
	
	.tb-py0 { padding-top: 0 !important; padding-bottom: 0 !important; }
	.tb-py5 { padding-top: 5px !important; padding-bottom: 5px !important; }
	.tb-py10 { padding-top: 10px !important; padding-bottom: 10px !important; }
	.tb-py15 { padding-top: 15px !important; padding-bottom: 15px !important; }
	.tb-py20 { padding-top: 20px !important; padding-bottom: 20px !important; }
	.tb-py25 { padding-top: 25px !important; padding-bottom: 25px !important; }
	.tb-py30 { padding-top: 30px !important; padding-bottom: 30px !important; }
	
	body {
		font-size: 15px;
	}
	
	/**/
	.in {
		padding-left: 8% !important;
    	padding-right: 8% !important;
	}
	img.right {
		width: 27%;
		max-width: 140px;
	}
	img.left {
		width: 27%;
	}
	header .h {
		text-align: center;
	}
	header .main-img-wp {
		margin: 0 -30% 0 -30%;
	}
	header .main-img-wp img {
		width: 100%;
	}
	.shoten-wp {
    	margin-top: 20px;
	}
	.red-border-wp {
		border-width: 5px;
		margin-top: 20px;
	}
	.shoten-wp .p-1 {
    	margin-top: 20px;
	}
	.amino-sec .youtube-2-wp {
		margin-top: 20px;
		position: relative;
	}
	.amino-sec .youtube-2-wp .inner {
		position: absolute;
		left: 22%;
		top: 0;
		width: 56%;
	}
	.uso-sec .right {
		width: 30%;
		max-width: 195px;
	}
	.genkai-sec .h {
    	margin: 22px 0;
    	font-size: 20px;
	}
	.seibutsu-sec .right {
		width: 30%;
		max-width: 190px;
	}
	.point-sec .red-border-wp .h {
    	background: url(../img/h4.gif) no-repeat left bottom;
		background-size: 105%;
		padding: 5px 0 3px 5%;
	}
	cost-sec .h {
		font-size: 15px;
	}
	.cost-sec .orange strong {
    	font-size: 18px;
	}
	.expensive-sec .bold {
		font-weight: bold;
	}
	.expensive-sec .img-product {
		border-width: 5px;
		box-sizing: border-box;
	}
	.expensive-sec .saisei {
		margin-top: 92px;
		width: 45%;
	}
	.free-sec .red-border-wp .inner {
		padding: 0 6% 3%;
	}
	.free-sec .img-1 {
		width: 200px;
		max-width: none;
	}
	.faq-sec .yellow-border-wp {
		border-width: 5px;
	}
	.voice-sec .h {
    	font-size: 17px;
	}
	.voice-sec .red-border-wp.v1 {
		border-width: 3px;
	}
	.tsuishin-sec .right {
		width: 250px;
		max-width: none;
	}

}

@media screen and (min-width: 800px) {
	/* init. */
	body {
		font-size: 16px;
		font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック",osaka,sans-serif;
	}
	
	/* util. */
	.serif { font-family: "游明朝",YuMincho,"ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","HGS明朝E","ＭＳ Ｐ明朝","ＭＳ 明朝",serif !important; }
	
	.btn {
		font-size: 22px;
		padding: 15px;
	}
	
	.pc-mw1600 { max-width: 1600px; margin: auto; }
	.pc-mw1500 { max-width: 1500px; margin: auto; }
	.pc-mw1400 { max-width: 1400px; margin: auto; }
	.pc-mw1300 { max-width: 1300px; margin: auto; }
	.pc-mw1200 { max-width: 1200px; margin: auto; }
	.pc-mw1120 { max-width: 1120px; margin: auto; }
	.pc-mw1100 { max-width: 1100px; margin: auto; }
	.pc-mw1000 { max-width: 1000px; margin: auto; }
	.pc-mw900 { max-width: 900px; margin: auto; }
	.pc-mw800 { max-width: 800px; margin: auto; }
	.pc-mw790 { max-width: 790px; margin: auto; }
	
	.pc-tr { text-align: right; }
	.pc-tc { text-align: center; }
	.pc-tl { text-align: left; }
	
	.pc-none { display: none !important; }
	.pc-block { display: block !important; }
	.pc-inline { display: inline !important; }
	.pc-ib { display: inline-block !important; }
	.pc-table { display: table !important; }
	.pc-li { display: list-item!important; }
	
	.pc-p0 { padding: 0 !important; }
	.pc-p5 { padding: 5px !important; }
	.pc-p10 { padding: 10px !important; }
	.pc-p15 { padding: 15px !important; }
	.pc-p20 { padding: 20px !important; }
	.pc-p25 { padding: 25px !important; }
	.pc-p30 { padding: 30px !important; }
	
	.pc-pt20 { padding-top: 20px !important; }
	.pc-pt30 { padding-top: 30px !important; }
	.pc-pt40 { padding-top: 40px !important; }
	.pc-pt50 { padding-top: 50px !important; }
	.pc-pt60 { padding-top: 60px !important; }
	.pc-pt70 { padding-top: 70px !important; }
	.pc-pt80 { padding-top: 80px !important; }
	.pc-pt90 { padding-top: 90px !important; }
	.pc-pt100 { padding-top: 100px !important; }

	.pc-pb20 { padding-bottom: 20px !important; }
	.pc-pb30 { padding-bottom: 30px !important; }
	.pc-pb40 { padding-bottom: 40px !important; }
	.pc-pb50 { padding-bottom: 50px !important; }
	.pc-pb60 { padding-bottom: 60px !important; }
	.pc-pb70 { padding-bottom: 70px !important; }
	.pc-pb80 { padding-bottom: 80px !important; }
	.pc-pb90 { padding-bottom: 90px !important; }
	.pc-pb100 { padding-bottom: 100px !important; }

	.pc-px20 { padding-left: 20px !important; padding-right: 20px !important; }
	.pc-px25 { padding-left: 25px !important; padding-right: 25px !important; }
	
	.pc-py20 { padding-top: 20px !important; padding-bottom: 20px !important; }
	.pc-py30 { padding-top: 30px !important; padding-bottom: 30px !important; }
	.pc-py40 { padding-top: 40px !important; padding-bottom: 40px !important; }
	.pc-py50 { padding-top: 50px !important; padding-bottom: 50px !important; }
	.pc-py60 { padding-top: 60px !important; padding-bottom: 60px !important; }
	.pc-py70 { padding-top: 70px !important; padding-bottom: 70px !important; }
	.pc-py80 { padding-top: 80px !important; padding-bottom: 80px !important; }
	.pc-py90 { padding-top: 90px !important; padding-bottom: 90px !important; }
	.pc-py100 { padding-top: 100px !important; padding-bottom: 100px !important; }
	
	body {
		font-size: 15px;
	}
	
	/**/
	.in {
    	padding-left: 0 !important;
    	padding-right: 0 !important;
		background: url(../img/bodyb.jpg) repeat-y center top;
	}
	.pc-mw790.shadow {
		box-shadow: 0 0 12px #666;
		padding-left: 50px !important;
    	padding-right: 50px !important;
		box-sizing: border-box;
	}
	section {
    	margin-top: 35px;
	}
	.red-border-wp {
    	border-width: 5px;
	}
	.h-1 + img {
		margin-bottom: 25px;
	}
	.banner-tel {
		margin-top: 15px;
	}
	header .main-img-wp {
		margin: 0;
	}
	header .main-img {
		width: 1200px;
		height: 488px;
		object-fit: cover;
	}
	.shoten-wp {
    	margin-top: 0;
	}
	.shoten-wp .img-wp {
    	margin: 50px 0;
	}
	.shoten-wp .right {
		width: 120px;
	}
	.language-sec .right {
		max-width: 185px;
	}
	.otoshiana-sec .right {
		max-width: 185px;
	}
	.keiyoushi-sec .img-wp img {
    	border-width: 4px;
	}
	.keiyoushi-sec .right {
		max-width: 185px;
	}
	.point-sec .red-border-wp .h {
    	font-size: 20px;
	}
	.point-sec .red-border-wp {
		margin-bottom: 50px;
	}
	.cost-sec .h {
    	font-size: 15px;
	}
	.cost-sec .red-border-wp {
		margin-bottom: 50px;
	}
	.expensive-sec .img-product {
    	border-width: 8px;
	}
	.expensive-sec .big-1 {
    	font-size: 26px;
	}
	.expensive-sec .big-2 {
    	font-size: 19px;
	}
	.expensive-sec .sarani {
		display: inline-block;
		position: absolute;
		right: 0;
		top: -90px;
	}
	.free-sec .mail {
		width: 190px;
    	max-width: none;
	}
	.faq-sec .h-1 + img {
    	margin-bottom: 0;
	}
	.voice-sec .h-1 + img {
    	margin-bottom: 0;
	}
	.voice-sec .red-border-wp.v1 {
    	margin: 20px 30px;
	}
	.tsuishin-sec {
		padding-bottom: 20px;
	}
	.footer-wp {
    	margin: 0 -40px;
		padding: 40px 40px 10px;
	}
	.footer-wp .copyright {
		margin-top: 25px;
	}
}
@media screen and (min-width: 1000px) {
	header .favorite-wp {
		position: absolute;
		right: -100px;
		top: 0;
		margin-top: -3px;
	}
}
@media screen and (min-width: 1200px) {
	header .main-img {
		width: auto;
		height: auto;
	}
}