@charset "utf-8";


/*全体の設定
---------------------------------------------------------------------------*/
html {
	font-size: 62.5%;
	line-height: 1.5;
}

body {
	background: #ededed;
	color: #292929;
	/*全体の文字色*/
	margin: 0px;
	padding: 0px;
	font-family: 'Noto Sans JP', sans-serif;
}

h1 {
	font-size: 6rem;
	font-feature-settings: "palt";
}

h2 {
	font-size: 5rem;
	font-feature-settings: "palt";
}

h3 {
	font-size: 4rem;
	font-feature-settings: "palt";
}

h4 {
	font-size: 3rem;
	padding-left: 10px;
	margin: 10px 0;
	border-left: 5px solid #11afb2;
	font-feature-settings: "palt";
	color: #223a70;
}

p {
	font-size: 2.4rem;
	line-height: 1.7;
}

.serif {
	font-family: 'Noto serif JP';
}

.sans {
	font-family: 'Noto Sans JP', sans-serif;
}

.dotted {
	border: 1px dotted #b3b3b3;
}

.marker {
	background: linear-gradient(transparent 90%, #ffd000 0%);
	display: inline;
	padding: 0;
}

.img_only {
	width: 100vw;
}

.kg375 {
	display: none;
}

.kg360 {
	display: none;
}

/*詳細-------------------------------------*/
#notice_04 {
	padding: 0px 10px;
	text-align: left;
	margin-bottom: 86px;
}

#notice_04 p {
	margin-bottom: 30px;
}

.box_04 {
	background-color: #f2f2f2;
	padding-top: 0px;
	margin: 40px 30px 10px;
	padding: 20px 0;
	border-radius: 10px;
}

.box4_ml {
	margin-left: 110px;
}

.submit_02 {
	background-color: #223a70;
	box-shadow: 0 3px 0 #00C4D2;
	color: #fff;
	font-size: 1.8rem;
	position: relative;
	text-align: center;
	text-decoration: none;
	text-shadow: 0 -2px #00519a;
	width: 10%;
	margin: 0 20px 20px 20px;
	padding: 5px 15px;
}

.submit_02 p {
	color: #292929;
}

/*文字サイズ*/
.f130_01 {
	font-size: 130%;
}

#main .tokuten05 {
	font-weight: bold;
	text-align: center;
	font-size: 120%;
	color: #C00;
}

#order_01 {
	width: 80%;
	margin: 0 auto;
}

/*ボタン*/

.submit_01 {
	background-color: #004098;
	box-shadow: 0 3px 0 #022240;
	text-shadow: 0px -2px #022240;
	position: relative;
	padding: 25px 100px;
	border-radius: 5px;
	font-size: 250%;
	color: #FFF;
	font-weight: bold;
	text-decoration: none;
	margin: 30px 10px;
	/*display:block;*/
}

.submit_01:active,
.submit_01:hover {
	top: 3px;
	box-shadow: none;
	color: #fff;
}

#s-shosai {
	margin: 20px auto 0 auto;
}

table {
	border-collapse: collapse;
	font-size: 100%;
	border-spacing: 0;
}

user agent stylesheet table {
	display: table;
	border-collapse: separate;
	border-spacing: 2px;
	border-color: grey;
}

#s-shosai th {
	width: 30%;
	background-color: #555;
	font-size: 100%;
	font-weight: bold;
	color: #fff;
	text-align: center;
	border-bottom: 1px solid #fff;
}

#s-shosai td {
	width: 70%;
	padding: 20px;
	border: 1px solid #ddd;
}

.kiyaku {
	overflow-y: scroll;
	height: 35px;
	width: 700px;
	padding: 1em;
	font-size: 80%;
	color: #888;
	margin: 0 auto;
}

.delline {
	text-decoration: line-through;
	text-decoration-color: #ff0000;
}

figure {
	margin: 0px;
	padding: 0px;
}

ul {
	margin-bottom: 30px;
}

img {
	border: none;
	vertical-align: bottom;
}

input,
textarea,
select {
	font-size: 1em;
}

form {
	margin: 0px;
}

table {
	border-collapse: collapse;
	font-size: 100%;
	border-spacing: 0;
}

.clearfix:after {
	content: ".";
	/* 新しい要素を作る */
	display: block;
	/* ブロックレベル要素に */
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}


/*コンテナー（HPを囲むブロック）
---------------------------------------------------------------------------*/
#container {
	width: 1002px;
	/*コンテナー幅*/
	background-color: #fff;
	margin: 0 auto;
	border-left: 1px solid #cdcdcd;
	border-right: 1px solid #cdcdcd;
}

#container2 {
	width: 1002px;
	/*コンテナー幅*/
	background-color: #fef7f1;
	margin: 0 auto;
	border-left: 1px solid #cdcdcd;
	border-right: 1px solid #cdcdcd;
}

.body-bg2 {
	background-color: #fff;
}

.cream {
	background-color: #fef7f1;
}

.m-auto img {
	margin: auto;
}

/*リンク（全般）設定
---------------------------------------------------------------------------*/
a {
	color: #006ddc;
	/*リンクテキストの色*/
	text-decoration: none;
}

a:hover {
	color: rgb(255, 0, 179);
	/*マウスオン時の文字色（全体）*/
}

a:hover img {
	position: relative;
	top: 3pt;
	left: 3pt;
}

/*見出し、タイトル----------------------------------------------------------*/
.title {
	background: #223a70;
	box-shadow: 0px 4px 0px 0px rgba(34, 58, 112, 0.5);
	padding: 30px 0;
	margin: 0 auto 30px;
	text-align: center;
}

title h2:after {
	content: "";
	position: absolute;
	right: 0;
	bottom: -50px;
	left: 0;
	width: 0px;
	height: 0px;
	margin: auto;
	border-style: solid;
	border-color: #ffe389 transparent transparent transparent;
	border-width: 60px 25px 0 25px;
}


.title h2 {
	font-family: 'Noto serif JP';
	color: #ff0;
	padding: 0 40px;
}

.title h3 {
	font-family: 'Noto serif JP';
	padding: 0 40px;
	color: white;
}

.title p {
	color: white;
	font-size: 1.6rem;
	padding: 0 40px;
}

.inner {
	width: 92%;
	margin: 0 40px;
}

.flex {
	display: flex;
	text-align: center;
}


/*受講者の声---------------------------------*/
.voice h2 {
	font-family: 'Noto serif JP';
	background-color: #eff;
	box-shadow: 5px 5px 0px 0px rgba(100, 117, 155, 1);
	font-size: 3rem;
	color: #292929;
	padding: 10px 20px;
}

.voice h3 {
	font-size: 2rem;
	margin: 15px 0;
	line-height: 1.5;
	padding-left: 20px;
}

.voice h4 {
	font-size: 3.5rem;
	font-family: 'Noto serif JP';
	font-feature-settings: "palt";
	padding-left: 0;
	margin: 30px 0;
	border-left: none;
	color: #11afb2;
}

.voice p {
	margin: 20px auto 60px;
	color: #444;
}

.voice_width {
	width: 60%;
}

.voice hr {
	margin: 30px 0;
}

/*ファーストビュー---------------------------------------------*/
.first {
	padding: 40px;
	text-align: center;
}

.first h2 {
	font-size: 7rem;
	font-weight: bold;
	color: #C00 !important;
	line-height: 1.7;
	font-feature-settings: "palt";
	font-family: 'Noto serif JP';
}

.first h3 {
	font-size: 4rem;
	line-height: 1.7;
	font-feature-settings: "palt";
	font-family: 'Noto serif JP';
}

.first h3 span {
font-size: 6rem;
}

.first p {
	font-size: 2rem;
	line-height: 1.7;
}

/*内容---------------------------------------------------------------------------*/
.contents {
	width: 920px;
	margin: 0 auto;
	border-radius: 10px;
	box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
}

.contents_inner {
	padding: 20px 40px;

}

.contents_inner h2 {
	color: #11afb2;
	font-size: 3rem;
}

.contents_inner p {
	font-size: 2rem;
	line-height: 1.7;
}

.contents_inner p img {
	float: right;
	margin: 0 0 20px 20px;
}

#con3_img {
	float: right;
	border-left: 20px solid white;
	margin: 0 0 20px 20px;
	position: relative;
	z-index: 100;
}

.contents_inner ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.contents_inner ul li {
	font-size: 2rem;
	border-bottom: dashed 1px #b3b3b3;
	position: relative;
	padding: 15px 0 15px 2.5rem;
	background: url(../img/check_mark20px_ao.png) left 0px top 20px no-repeat;
}

.mark30 {
	padding-bottom: 5px;
}


/*期待するなら*/
#kitai {
	padding: 20px 40px;
	position: relative;
}

#kitai h2 {
	color: #11afb2;
	font-size: 3rem;
}

#kitai p {
	font-size: 2rem;
	line-height: 1.7;
}

#kitai ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

#kitai ul li {
	font-size: 3rem;
	border-bottom: dashed 1px #b3b3b3;
	position: relative;
	padding: 15px 0 15px 2.7rem;
	background: url(../img/check_mark20px_aka.png) left 0px top 28px no-repeat;
}

/*悩み------------------------------------*/
#kitto {
	font-size: 4rem;
	font-weight: bold;
	margin: 40px auto;
	text-align: center;
}

#kitto span {
	font-size: 6rem;
}


/*申込の流れ--------------------------*/
.nagare img {
	margin: 100px auto 60px;
}


/*松本塾代表の紹介--------------------------*/
#shoukai_width {
	width: 700px;
	margin: auto;
}

#shoukai img {
	float: right;
	margin: 0 0 20px 20px;
}

#shoukai_tate {
	float: left;
	width: 10px;
	height: 250px;
	background-color: #11afb2;
	box-shadow: 5px 5px 0px 0px rgba(34, 58, 112, 1);
}

#shoukai_title {
	padding-left: 30px;
}

#shoukai_title h2 {
	font-family: 'Noto serif JP';
	margin: 40px auto;
	line-height: 0.6;
}

#shoukai_title h2 span {
	font-size: 2rem;
}

#shoukai_title p {}

/*当日の流れ------------------------------------*/
#toujitsu_tate {
	float: left;
	width: 10px;
	background-color: #11afb2;
	box-shadow: 5px 5px 0px 0px rgba(34, 58, 112, 1);
}

#toujitsu {
	padding-left: 30px;
	margin-bottom: 30px;
}

.toujitsu_hr {

}

/*位置づけ-------------------------*/
.placement {
	width: 920px;
	margin: 0 auto;
	border-radius: 10px;
	box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
}

.placement_inner {
	padding: 20px 40px;

}

.placement_inner ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.placement_inner ul li {
	font-size: 2.2rem;
	border-bottom: dashed 1px #b3b3b3;
	position: relative;
	padding: 15px 0 15px 2.5rem;
	background: url(../img/check_mark20px.png) left 0px top 22px no-repeat;
}

.placement_inner p {
	font-size: 1.6rem;
	padding-bottom: 10px;
	border-bottom: 2px solid #223a70;
	margin: 10px 0 20px 210px;
	display: inline-block;
}

/*代表からのメッセージ*/
#message_img {
	float: right;
	margin-left: 40px;
}

/*プライバシーポリシー*/
#privacy {
	background-color: #eee;
	padding: 40px;
}

#privacy p {
	font-size: 1.6rem;
}

/*メインコンテンツ----------------------*/
.relative {
	position: relative;
}

.absolute p {
	position: absolute;
	font-size: 200%;
	color: #292929;
	font-weight: bold;
	top: 316px;
	left: 97px;
}

.main-btn {
	text-align: center;
	margin: 20px 0;
}

.ika {
	margin-top: 3%;
}

.ika p {
	text-align: center;
	line-height: 1.8;
	font-size: 130%;
}

.hogo {
	margin: 0 auto;
	font-size: 90%;
	background-color: #eee;
	padding: 20px;
	margin-bottom: 20px;
	margin-top: 20px;
}

/*ここまで-------------------*/

.order {
	width: 80%;
	margin: 0 auto 30px;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 100%;
}

h1 {
	text-align: center;
	color: #fff;
	font-size: 42px;
	line-height: 1.2;
	padding: 0.5em;
}

table.day {
	width: 900px;
	margin: 50px auto 10px;
	border: 1px solid #ccc;
}

table.day tr {
	border-bottom: 1px dotted #ccc;

}

table.day th {
	background: #024174;
	color: #fff;
	padding: 2px 30px;
	font-size: 24px;
	font-weight: normal;
}

.day td {
	padding: 15px;
	background: #fff;
	font-size: 23px;

}

.day_box {}

.day_box p {
	margin-bottom: 14px;
	font-size: 16px;
}

.bg_orange {
	background: #024174;
	font-size: 20px;
	color: #fff;
	font-weight: normal;
	text-align: center;
	margin-bottom: 10px;
	line-height: 1.2;
	padding: 10px 15px;
}

h3.green {
	background: #024174;
	font-size: 36px;
	color: #fff;
	font-weight: normal;
	text-align: center;
	margin-bottom: 30px;
	line-height: 1.2;
	padding: 20px 5px;
}

.box1 {
	border: 1px solid #ccc;
	padding: 20px;
	line-height: 1.8;
}

ul.maru {
	list-style: none;
	margin: 0 0 20px;
	padding-left: 30px;
	font-weight: bold;
	color: #393939;
}

.maru li {
	background: url(../img/int.png) no-repeat;
	padding-left: 30px;
	padding-bottom: 15px;
	border-bottom: dotted;
	/*下線を点線にする*/
	border-color: #d2d2d2;
	border-width: 1px;
	margin-bottom: 10px !important;
}

.box1 li p {
	margin: 0;
	padding: 0;
}

/*-- 詳細部分 ---------------------------------*/
#text-box {
	width: 100%;
	margin: 2em auto;
}

#shosai {
	margin: 0 auto;
	border: 1.5px solid #999999;
	width: 90%;
}

#shosai th {
	background-color: #7f7f7f;
	width: 30%;
	color: #fff;
	font-size: 110%;
	padding: 0.1em;
	border-bottom: 1px solid #a9a9a9;
	border-right: 1px solid #999999;
}

#shosai td {
	width: 70%;
	padding: 1em;
	border-bottom: 1px solid #999999;
}

#shosai td p {
	line-height: 1.8;
	text-align: justify;
}

#shosai td span.small {
	font-size: 80%;
}

#shosai td span.red {
	color: red;
}

.order_detail {
	margin-left: 110px;
	margin-top: -50px;
	line-height: 1.4em;
	font-size: 1.2em;
}

/*--- 詳細部分ここまで -------------------------------*/
#catch_inner {
	background-color: #f7f7f7;
	padding: 40px;
	position: relative;
}

#catch_inner p span {
	font-size: 3.6rem;
	font-weight: bold;
	color: #223a70;
}

#catch {
	display: block;
	margin: auto;
	position: absolute;
	right: 20px;
	top: 230px;
	width: 350px;
}

#catch_phrase {
	padding: 100px 0 30px;
	text-align: center;
}

#catch_small {
	background-color: white;
	padding: 10px 20px;
	font-size: 1.6rem;
	text-align: center;
	color: #223a70;
}

.voice2 {
	overflow-y: auto;
	border: 1px solid #504885;
	padding: 1em;
	margin: 1em auto;
}

#send-table {
	width: 90%;
	margin: 0 auto;
	border-left: 1px solid #dcdcc1;
	border-top: 1px solid #dcdcc1;
	font-size: 100%;
}

#send-table th {
	width: 30%;
	background-color: #DBEDFF;
	text-align: right;
	padding: 10px 20px;
	border-right: 1px solid #dcdcc1;
	border-bottom: 1px solid #dcdcc1;
}

#send-table td {
	width: 70%;
	padding: 10px 20px;
	background-color: #fff;
	border-right: 1px solid #dcdcc1;
	border-bottom: 1px solid #dcdcc1;
}

#send-table caption {
	background: #296eb7;
	padding: 8px 12px;
	margin: 5px 0;
	color: #fff;
	font-size: 130%;
	font-weight: bold;
}

#main blockquote {
	margin: 0 0 2em 0;
	padding: 20px;
	background: #f2f2f2;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	position: relative;
}

#main blockquote:after {
	content: '"';
	font-style: italic;
	font-size: 30px;
	font-weight: bold;
	text-align: left;
	line-height: 60px;
	width: 30px;
	height: 30px;
	position: absolute;
	bottom: 10px;
	right: 5px;
	color: #999;
}

#main blockquote:before {
	content: '"';
	font-style: italic;
	font-size: 30px;
	font-weight: bold;
	line-height: 40px;
	width: 30px;
	height: 30px;
	position: absolute;
	top: 10px;
	left: 10px;
	color: #999;
}

.youtube {
	width: 853px;
	margin: 0 auto;
	height: auto;
}

#seminar {
	width: 100%;
}

#seminar th {
	padding: 5px 15px;
	font-weight: bold;
	text-align: left;
	background-color: #ddd;
}

#seminar td {
	text-align: left;
	padding: 3px 10px;
	border-bottom: 1px dotted #ddd;
}

.about_box {
	padding-left: 45px;
	padding-right: 30px;
	font-size: 16px;
	line-height: 150%;
}


ul.image {
	list-style: none;
	display: block;
}

ul.image li {
	width: 50%;
	float: left;
}

/*form-original------------------------------------------------------*/
#order_googleform {
	margin: 0 40px 30px;
	padding: 30px;
	background: #e4e7ee;
	border-radius: 10px;
}

.form_label {
	background: #fff;
	padding: 10px 20px;
	border-radius: 10px;
	display: inline-block;
	margin: 30px 0 10px;
	font-weight: bold;
}

.form_radio {
	background: #ffffcc;
	width: 100%;
	padding: 10px 20px;
	box-shadow: 1px 1px 2px inset;
	font-size: 2rem;
	font-feature-settings: "palt";
	line-height: 2;
}

.f-fo {
	font-size: 0.8em;
	color: #FF0000;
}

.table_form {
	margin: 0 auto;
	padding: 0.5em;
	width: 95%;
	border-top: 1px solid #c0c0c0;
}

input.whname {
	width: 100%;
	height: 5rem;
	font-size: 2rem;
	font-feature-settings: "palt";
	border: 1px solid #CCC;
	background-color: #ffffcc;
	box-shadow: 1px 1px 2px inset;
	padding: 10px 20px;
}

/*-左側-*/
.l_cell {

	background-color: #edffdb;
	color: #333333;
	font-size: 0.9em;
	font-weight: bold;
	padding-left: 5%;
	text-align: left;
	border-left: 1px solid #c0c0c0;
	border-bottom: 1px solid #c0c0c0;
}

/*-右側-*/
.r_cell {

	background-color: #fff;
	color: #333333;
	font-size: 0.8em;
	padding-left: 10px;
	border-right: 1px solid #c0c0c0;
	border-bottom: 1px solid #c0c0c0;
}


.subtn:hover {
	position: relative;
	top: 3pt;
	left: 3pt;
}

/*画像設定
---------------------------------------------------------------------------*/
.img-posi {
	padding-top: 30px;
	text-align: center;
	margin-bottom: 30px;
	max-width: 100%;
	max-height: 100%;
}

.img-prof {
	text-align: center;
	max-width: 100%;
	max-height: 100%;
}

.img-gurafu {
	float: right;
	width: 300px;
	margin-right: 30px;

}

.susume {
	padding-top: 20px;
	position: relative;
}


/*説明文
---------------------------------------------------------------------------*/
.contener02 {
	float: right;
	margin-left: 30px;
	margin-right: 30px;
	margin-bottom: 30px;
}

.contener03 {

	margin-left: 30px;
	margin-right: 30px;
	margin-bottom: 30px;
}

.tex08 {
	line-height: 2;
	display: inline-block;
	text-align: left;
}

.emp {
	background: linear-gradient(transparent 30%, #fbd 30%);
	font-weight: bold;
}

.about-bn {
	background-color: #024174;
	color: #ffffff;
	margin-left: 30px;
	margin-right: 30px;
	margin-top: 10px;
	margin-bottom: 20px;
	padding: 15px;

}

.text-box {
	width: 100%;
	margin: 1em auto;
}

.text-boxw {
	width: 90%;
	margin: 1em auto;
}

.tex05 {
	margin-top: 13px;
	background: url(../img/int.png) no-repeat;
	padding-left: 30px;
	padding-top: px;
	border-bottom: 1px dotted #ccc;
	padding-bottom: 10px;
	margin-bottom: 0px;
}

/*吹き出し--------------------*/


/*ボタン設定
---------------------------------------------------------------------------*/
.btn {

	border-radius: 15px;
	color: #ffffff;
	font-size: 3rem;
	padding: 10px 20px 10px 20px;
	text-decoration: none;
	margin: 10px 0;
}

.btn:hover {

	text-decoration: none;
	color: #ffffff;
}

a.img-link:hover {
	filter: alpha(opacity=80);
	-moz-opacity: 0.8;
	opacity: 0.8;
}

/*ボタン*/

.submit {
	background-color: #ff9900;
	box-shadow: 0 3px 0 #ff6600;
	text-shadow: 0px -2px #ff6600;
	position: relative;
	padding: 25px 120px;
	border-radius: 5px;
	font-size: 3rem;
	color: #FFF;
	font-weight: bold;
	text-decoration: none;
	/*display:block;*/
}

.submit:active,
.submit:hover {
	top: 3px;
	box-shadow: none;
	color: #fff;
}

/*フッター設定
---------------------------------------------------------------------------*/
footer {
	width: 100%;
	height: auto;
	color: #fff;
	background: #223a70;
	padding-top: 20px;
}

.footer-inner {
	text-align: center;
}

.footer-inner a {
	padding: 5px;
	margin: 10px 20px;
	color: #fff;
}

.footer-inner a:hover {
	text-decoration: underline;
}

.footer-inner ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: center;

}

.footer-inner li {
	padding: 8px 0;
	font-size: 1.8rem;
	border-right: 1px solid white;
}

.footer-inner li:hover {
	opacity: 0.5;
	background: #89daeb;
}

.footer-inner li:last-child {
	border-right: none;
}

.fotter-inner li:last-child::after {
	content: none;
}

.footer-inner span.copy {
	font-size: 1.6rem;
}

footer p.copy {
	text-align: center;
	padding: 20px 0;
	font-size: 1.4rem;
}


/*その他
---------------------------------------------------------------------------*/
.clear {
	clear: both;
}

.center {
	text-align: center;
}

.left {
	text-align: left;
}

.right {
	text-align: right;
}

.alignleft {
	float: left;
}

.alignright {
	float: right;
	margin-right: 30px;
}

/*リンク透明設定*/
a.img-link:hover {
	filter: alpha(opacity=80);
	-moz-opacity: 0.8;
	opacity: 0.8;
}


#qa {
	margin: 0 40px;
}

#qa dt {
	font-size: 2.4rem;
	font-weight: bold;
	background: url(../img/ph-icon-q.png) no-repeat 0px 14px;
	padding: 15px 10px 10px 50px;
}


#qa dt:hover {
	opacity: 80%;
}


#qa dd {
	display: none;
	margin-bottom: 5px;
	padding: 15px 4px 15px 50px;
	background: url(../img/ph-icon-a.png) no-repeat 0px 9px;
	border-bottom: 1px dashed #ccc;
	font-size: 2rem;
}

#qa dt.open {
	background: url(../img/ph-icon-q2.png) no-repeat 0px 14px;
}


.border1 {
	border: 0;
	border-bottom: 1px dashed #666;
	margin: 1em 0;
}

.border2 {
	border: 0;
	border-bottom: 3px double #0075a9;
	margin-bottom: 1em;
}

#offer_title {
	text-align: center;
	background-color: #f2f3f5;
}

/*交互にFAQの色を変える------------------------------

#qa dd:nth-child(4n) {
	background-color:#f2f3f5;
	}

#qa dt:nth-child(4n-1) {
		background-color:#f2f3f5;
		}

#qa dt {
	background-image: url(../img/img_btn_plus.png);
	background-position: 95% center;
	background-repeat: no-repeat;
}

*/

/*テーブルの設定
---------------------------------------------------------------------------*/

.apply_title {
	font-size: 140%;
	font-weight: bold;
}

.apply_table {
	width: 940px;
	margin: auto;

}

table {
	border-collapse: collapse;
	margin: 30px auto;
	width: 89%;
	box-shadow: 0 0 15px -6px rgba(0, 0, 0, 0.7);
}

table tr {
	background-color: #f2f2f2;
}

table th,
table td {
	border-bottom: 1px solid #f2f2f2;
}

table thead th {
	font-size: .85em;
	padding: 1em;
}

table thead tr {
	background-color: #036;
	color: #fff;
}

table tbody th {
	width: 20%;
	padding: 15px 0;
	vertical-align: top;
}

table tbody td {
	padding: 20px 20px 15px 0;
	vertical-align: top;
}

table tbody th p span {
	font-size: 1.8rem;
	color: white;
	padding: 5px 10px;
	text-align: center;
	background: #223a70;
	box-shadow: 0 3px 0 #00c4d2;
	margin: 10px 20px;
}

table tbody td p {
	padding: 10px 0;
	font-size: 1.8rem;
}

.period {
	text-align: left;
	font-size: .75em;
	width: 17%;
}

.txt {
	text-align: left;
	font-size: .75em;
}

.price {
	text-align: right;
	color: #292929;
	font-weight: bold;
	width: 15%;
}

.Apply_btn {
	text-align: right;
	margin: 10px auto;
	width: 29%;
}

.small {
	font-size: small;
	text-align: right;
	font-weight: normal;
}

/*フォント設定
---------------------------------------------------------------------------*/
.under {
	text-decoration: underline;
}

.aka {
	color: #cc0000;
}

.green {
	color: #11afb2;
}

.ao {
	color: #223a70;
}

.kiro {
	color: #FF0;
}

.gray {
	color: #666;
}

.shiro {
	color: #fff;
}

.bold {
	font-weight: bold;
}

.through {
	text-decoration: line-through;
}

.yellow {
	background-color: #FF6;
}

.justify {
	text-align: justify;
}

.size10 {
	font-size: 10px;
}

.size12 {
	font-size: 12px;
}

.size14 {
	font-size: 14px;
}

.size105 {
	font-size: 105%;
}

.size110 {
	font-size: 110%;
}

.size130 {
	font-size: 130%;
}

.size150 {
	font-size: 150%;
}

.size200 {
	font-size: 200%;
}

.fnt18 {
	font-size: 18px;
}

.voice_text {
	font-size: 14px;
	color: #aaa;
	text-align: right;
}

.bg-gray {
	background: #f5f5f5;
	padding: 1em;
}

.bg-white {
	background: #fff;
	padding: 1em;
}

.bg-white p {
	border-bottom: 1px dashed #ccc;
}

.pk {
	text-align: center;
	font-size: 16px;
	padding: 3px;
	color: #fff;
	background-color: #313131;
	margin-top: 5px;
	margin-bottom: 3px;
}

input {
	padding: 8px;
	font-size: 140%;
}

.send {
	padding: 10px;
	font-size: 140%;
}

select {
	padding: 8px;
}

.tokutei_tbl,
.about_tbl {
	width: 80%;
	margin: 20px auto;
}

.tokutei_tbl th,
.about_tbl th {
	background: #eee;
	text-align: center;
	font-weight: normal;
	border: 1px solid #ccc;
	padding: 10px;
}

.tokutei_tbl td,
.about_tbl td {
	border: 1px solid #ccc;
	padding: 10px;
}

ul.half {
	list-style: none;
	width: 920px;
	margin: 0 auto;
	padding: 0;

}

ul.half li {
	float: left;
	max-width: 455px;
	margin-right: 7px;
	padding: 0;


}

ul.half li:nth-child(2) {
	margin-right: 0;
}

dl.tbl_form dl,
dt,
dd {
	margin: 0;
	padding: 0;
}

dl.tbl_form {
	background: #eee;

	border: 1px solid #ccc;
	border-top: none;
	width: 80%;
	margin: 20px auto;
}

dl.tbl_form dt,
dd {
	padding: 6px;
}

dl.tbl_form dt {
	border-top: 1px solid #ccc;
	clear: left;
	float: left;
	width: 26%;
	text-align: center;
	line-height: 2.5em;
}

dl.tbl_form dd {
	background: #fff;
	border-left: 1px solid #ccc;
	border-top: 1px solid #ccc;
	margin-left: 27%;
}

form h3 {
	width: 80%;
	background: #eee;
	text-align: center;
	margin: 0 auto;
	padding: 6px;
	font-weight: normal;
}

/* margin
---------------------------------------------------------------------------*/
.mt10 {
	margin-top: 10px;
}

.mt20 {
	margin-top: 20px;
}

.mt30 {
	margin-top: 30px;
}

.mt40 {
	margin-top: 40px;
}

.ml10 {
	margin-left: 10px;
}

.ml20 {
	margin-left: 20px;
}

.ml40 {
	margin-left: 40px;
}

.ml60 {
	margin-left: 60px;
}

.ml75 {
	margin-left: 75px;
}

.ml80 {
	margin-left: 80px;
}

.mr20 {
	margin-right: 20px;
}

.mr400 {
	margin-right: 400px;
}

.mb10 {
	margin-bottom: 10px;
}

.mb20 {
	margin-bottom: 20px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb60 {
	margin-bottom: 60px;
}

.mb80 {
	margin-bottom: 80px;
}

.pt20 {
	padding-top: 20px;
}

.pt40 {
	padding-top: 40px;
}

.pb10 {
	padding-bottom: 10px;
}

.pb40 {
	padding-bottom: 40px;
}

.pb60 {
	padding-bottom: 60px;
}

.pl10 {
	padding-left: 10px;
}

.pl30 {
	padding-left: 30px;
}

.pl40 {
	padding-left: 40px;
}

.pr10 {
	padding-right: 10px;
}

.pd20 {
	padding: 20px;
}

.pd30 {
	padding: 30px;
}

.SPnone {
	display: block;
}

.PCnone {
	display: none;
}


/*=============================
 　　　　　　新しいフォーム
 =============================*/
.main-btn-iframe {
	text-align: center;
	margin: 50px 0;
}

.main-btn-iframe input {
	padding: 8px;
	font-size: 140%;
	width: 50%;
	margin: 20px;
}

.main-btn-iframe select {
	width: 52%;
}

.main-btn-iframe .input-group-btn {
	width: 100%;
}

/*ここからボタンアニメーション*/

.box {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.btn:link,
.btn:visited {
	text-decoration: none;
	text-transform: uppercase;
	position: relative;
	top: 0;
	left: 0;
	padding: 30px 90px;
	border-radius: 100px;
	display: inline-block;
	transition: all .5s;
}

.btn-white {
	background: #56c6c8;
	color: #fff;
	font-weight: bold;
}

.btn:hover {
	box-shadow: 0px 10px 10px rgba(0, 0, 0, 0.2);
	transform: translateY(-3px);
}

.btn:active {
	box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2) transform:translateY(-1px);
}

.btn-bottom-animation-1 {
	animation: comeFromBottom 1s ease-out .8s;
}

.btn::after {
	content: "";
	text-decoration: none;
	text-transform: uppercase;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	border-radius: 100px;
	display: inline-block;
	z-index: -1;
	transition: all .5s;
}

.btn-white::after {
	background: #56c6c8;
}

.btn-animation-1:hover::after {
	transform: scaleX(1.4) scaleY(1.6);
	opacity: 0;
}

@keyframes comeFromBottom {
	0% {
		opacity: 0;
		transform: translateY(40px);
	}

	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

/*ここまでボタンアニメーション*/