@charset "utf-8";

/* ------------------------------------------------------------ common */
.flow { width: 900px; margin: 0 auto 60px; }
.flow li { float: left; width: 270px; border-bottom: solid 3px #a3a3a3; margin: 0 0 0 45px; padding: 0 0 15px; font-family: 'Noto-Sans-JP-Medium'; color: #a3a3a3; }
.flow li:nth-of-type(3n+1) { clear: both; margin: 0 auto; }
.flow li.active { border-bottom: solid 3px #004bb2; color: #004bb2; }
.flow + p { line-height: 28px; text-align: center; margin: 0 auto 40px; }

/* ------------------------------------------------------------ intro */
#intro { padding: 70px 0; }
#intro h3 { text-align: center; margin: 0 auto 50px; }
#intro h3 span { display: inline-block; *display: inline; *zoom: 1; font-size: 28px; color: #004bb2; text-align: center; position: relative; padding: 0 35px; }
#intro h3 span::before { position: absolute; top: 0; bottom: 0; margin: auto 0; left: 0; display: block; width: 1px; height: 63px; background: #004bb2; -webkit-transform: rotate(-30deg); transform: rotate(-30deg); content: ''; }
#intro h3 span::after { position: absolute; top: 0; bottom: 0; margin: auto 0; right: 0; display: block; width: 1px; height: 63px; background: #004bb2; -webkit-transform: rotate(30deg); transform: rotate(30deg); content: ''; }
#intro ul { width: 620px; margin: 0 auto 30px; }
#intro ul li { width: 180px; float: left; margin: 0 0 0 40px; }
#intro ul li:nth-of-type(3n+1) { clear: both; margin: 0 auto; }
#intro ul li img { width: 100%; height: auto; }
#intro ul li p { text-align: center; font-size: 14px; margin: 10px auto 0; }
#intro .tel { width: 870px; margin: 0 auto; border: solid 1px #e5e5e5; padding: 25px 50px; -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
#intro .tel strong { display: block; float: left; background: #ffe92d; color: #1c5ea7; padding: 15px 30px; border-radius: 100px; -webkit-border-radius: 100px; line-height: 25px; }
#intro .tel a { display: block; float: left; background: url(../images/common/tel.svg) no-repeat left 12px; background-size: 30px; padding: 0 0 0 45px; font-size: 46px; letter-spacing: 2px; margin: 17px 0 0 30px; }
#intro .tel small { display: block; float: left; font-size: 14px; line-height: 20px; margin: 20px 0 0 15px; }

/* ------------------------------------------------------------ contact */
#contact { background: #e5f0f9; padding: 60px 0; margin-bottom: 60px;}
#contact form { width: 1000px; margin: 0 auto; background: #fff; padding: 90px 50px; -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
#contact form table { width: 100%; }
#contact form table tr { border-top: solid 1px #e5e5e5; }
#contact form table tr:first-of-type { border-top: none; }

#contact form table tr.ex th { vertical-align: top; }
#contact form table tr.ex th h3 { margin: 15px auto 0; }
#contact form table th { width: 310px; text-align: left; padding: 20px 0; }
#contact form table th h3 { font-size: 16px; }
#contact form table th h3 span { display: inline-block; *display: inline; *zoom: 1; font-size: 12px; color: #fff; background: #a40035; padding: 5px 8px 6px; margin: 0 0 0 15px; }
#contact form table th small { display: block; font-size: 14px; text-align: left; color: #8c8c8c; margin: 5px auto 0; }

#contact form table td { padding: 20px 0; }
#contact form table td input[type="text"],
#contact form table td input[type="checkbox"],
#contact form table td select,
#contact form table td textarea { width: 100%; padding: 20px; -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; border: solid 1px #dcdcdc; }
#contact form table tr.address td .cfx { margin: 0 auto 10px; }
#contact form table tr.address td .cfx p { float: left; width: 100px; font-size: 14px; line-height: 20px; margin: 25px 0 0; }
#contact form table tr.address td .cfx:last-of-type p { margin: 15px 0 0; }
#contact form table tr.address td .cfx input { float: left; width: calc(100% - 105px); -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
#contact form table tr.radio td label { margin: 0 25px 0 0; }

#contact form .gradation_btn2 { text-align: center; margin: 40px auto; }
#contact form .gradation_btn2 a { border-radius: 100px; -webkit-border-radius: 100px; }
#contact form .gradation_btn2 span { display: block; font-size: 14px; margin: 0 auto 10px; }
#contact form .privacy_policy { text-align: center; }
#contact form .privacy_policy a { background: url(../images/common/tab.svg) no-repeat left center; padding: 0 35px; color: #004bb2; text-decoration: underline; }

#contact .questionnaire { margin: 70px auto; }
#contact .questionnaire h3 { background: #004bb2; padding: 20px; color: #fff; font-family: 'Noto-Sans-JP-Medium'; margin: 0 auto 35px; }
#contact .questionnaire p { margin: 0 auto 20px; }
#contact .questionnaire h4 { margin: 0 auto 20px; text-indent: -1em; }
#contact .questionnaire > div { border-top: solid 1px #e5e5e5; padding: 30px 0; }
#contact .questionnaire > div:first-of-type { border: none; }
#contact .questionnaire .q1 label { display: inline-block; *display: inline; *zoom: 1; margin: 0 0 17px 0px; width: 49%; }
#contact .questionnaire .q1 input[type="text"] { width: 88%; }
#contact .questionnaire .q2 input[type="text"] { width: 88%; }
#contact .questionnaire .q2 label { float: left; width: 50%; margin: 0 auto 10px; text-indent: -1em; padding: 0 1em 0 1em; line-height: 24px; -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
#contact .questionnaire .q2 label:nth-of-type(4n+1) { clear: both; }
#contact .questionnaire .q2 label input { margin: 5px 5px 0 0; }

#contact .questionnaire .q1 .other label { width: inherit; display: inline-block; margin-right: 11px;}
#contact .questionnaire .q2 .other label { width: inherit; display: inline-block;}

#contact .questionnaire label input { margin: 2px 5px 0 0; vertical-align: top; }
#contact .questionnaire textarea { border: solid 1px #e5e5e5; width: 100%; }

#contact .gradation_btn {  }

/* ------------------------------------------------------------ エラー画面 */
.note { padding: 70px 0; margin: 100px auto 0; border-top: solid 1px #e5e5e5; border-bottom: solid 1px #e5e5e5; }
.note h3 { font-size: 27px; text-align: center; font-family: 'Noto-Sans-JP-Medium'; padding: 0 0 25px; }
.note .caution { font-size: 14px; text-align: center; border: solid 1px #000; padding: 20px 0; width: 700px; margin: 0 auto 40px; }
.note .alert { margin: 0 auto 40px; }
.note .alert span { display: block; font-size: 16px; text-align: center; padding: 0 0 20px; }
.note .btn { text-align: center; }
.note .btn a { background: #286fbe; display: inline-block; *display: inline; *zoom: 1; width: 300px; font-size: 16px; text-align: center; color: #fff; line-height: 60px; }

/* ------------------------------------------------------------ 確認画面 */
.note table { min-width: 700px; margin: 0 auto; }
.note table tr { border-bottom: 1px solid #d5d5d5; }
.note table th { width: 200px; padding: 30px 0; text-align: left; font-family: 'Noto-Sans-JP-Bold'; }
.note table td { font-size: 18px; padding: 30px 0 30px 40px; }
.note input[type="submit"] { background: #ef6646; display: inline-block; *display: inline; *zoom: 1; width: 300px; vertical-align: top; color: #fff; line-height: 60px; margin: 0 0 0 10px; }
.note.confirm .btn { margin: 50px auto 0; }

/* ------------------------------------------------------------ サンクス  */
.intro h3 { font-size: 27px; text-align: center; font-family: 'Noto-Sans-JP-Medium'; padding: 0 0 25px; }
.intro .caution { font-size: 14px; line-height: 24px; text-align: center; border: solid 1px #000; padding: 20px 0; width: 700px; margin: 0 auto 40px; }
.intro .gradation_btn { text-align: center;  }



/* ------------------------------------------------------------ about_free_trial */

.table { display: table; }
.table .table_cell { display: table-cell; vertical-align: middle; }
#about_free_trial { }
#about_free_trial h3.title1 + p { text-align: center; padding: 0 0 55px; }
#about_free_trial .articles { background: #e9f0f8; padding: 75px 0; }
#about_free_trial .articles article { background: #fff; padding: 60px; margin: 0 auto 30px; }
#about_free_trial .articles article h4 { text-align: center; padding: 0 0 40px; }
#about_free_trial .articles article h4 span { display: block; font-size: 74px; color: #004bb2; font-family: helvetica, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, sans-serif; font-weight: bold; }
#about_free_trial .articles article h4 strong { font-size: 29px; line-height: 45px; font-family: 'Noto-Sans-JP-Medium'; color: #004bb2; background: linear-gradient(transparent 70%, #fff100 0%); display: inline; }
#about_free_trial .articles article h4 + p { text-align: center; padding: 0 0 50px; }
#about_free_trial .articles article .table { padding: 0 0 40px; }
#about_free_trial .articles article .table .img { width: 450px; vertical-align: top; }
#about_free_trial .articles article .table .img img { width: 100%; height: auto; }
#about_free_trial .articles article .table .textbox { padding: 0 0 0 45px; }
#about_free_trial .articles article .table .textbox ul { padding: 5px 0 10px; }
#about_free_trial .articles article .table .textbox ul li { line-height: 30px; }
#about_free_trial .articles article .table .textbox p { line-height: 32px; }

#about_free_trial .articles article .point { background: #fefaf5; padding: 25px 15px; margin: 0 auto 35px; }
#about_free_trial .articles article .point h5 { width: 140px; text-align: center; background: #fff100; font-size: 18px; line-height: 27px; color: #0f53b5; font-family: 'Noto-Sans-JP-Medium'; padding: 30px 0 29px; border-radius: 50%; -webkit-border-radius: 50%; }
#about_free_trial .articles article .point .table_cell:nth-of-type(2) { padding: 0 35px 0 25px; }
#about_free_trial .articles article .point p { line-height: 32px; padding: 0 0 10px; }
#about_free_trial .articles article .point ul li { float: left; width: 50%; line-height: 36px; }

#about_free_trial .articles article .different { background: #fbf0f5; padding: 35px; }
#about_free_trial .articles article .different .tag { text-align: center; padding: 0 0 20px; }
#about_free_trial .articles article .different .tag span { display: inline-block; *display: inline; *zoom: 1; background: #ea70a5; text-align: center; padding: 10px 25px 12px; color: #fff; font-family: 'Noto-Sans-JP-Medium'; border-radius: 100px; -webkit-border-radius: 100px; }
#about_free_trial .articles article .different h5 { font-size: 36px; text-align: center; color: #ea70a5; font-family: 'Noto-Sans-JP-Medium'; padding: 0 0 25px; }
#about_free_trial .articles article .different p { text-align: center; line-height: 32px; }




/* ------------------------------------------------------------ mobile */
@media only screen and (max-width:640px){
/* ------------------------------------------------------------ common */
.flow { width: 100%; margin: 20px auto; }
.flow li { width: calc(30% - 5px); margin: 0 0 0 5px; padding: 0 0 10px; font-size: 11px; }
.flow li:nth-of-type(3n+1) { clear: inherit; margin: 0 auto; }
.flow li:nth-of-type(2) { width: calc(40% - 5px); }
.flow + p { font-size: 13px; line-height: 22px; text-align: left; margin: 0 auto 20px; }

/* ------------------------------------------------------------ intro */
#intro { padding: 30px 0; }
#intro h3 { margin: 0 auto 20px; }
#intro h3 span { font-size: 16px; line-height: 27px; padding: 0 15px 0 25px; }
#intro h3 span br.SP { line-height: 0; height: 0; }
#intro h3 span::before { width: 1px; height: 50px; -webkit-transform: rotate(-25deg); transform: rotate(-25deg); }
#intro h3 span::after { width: 1px; height: 50px; -webkit-transform: rotate(25deg); transform: rotate(25deg); }

#intro ul { width: 100%; margin: 0 auto 30px; }
#intro ul li { width: 31%; float: left; margin: 0 0 0 3.5%; }
#intro ul li:nth-of-type(3n+1) { clear: both; margin: 0 auto; }
#intro ul li img { width: 100%; height: auto; }
#intro ul li p { font-size: 12px; margin: 10px auto 0; }
#intro .tel { width: 100%; padding: 20px; text-align: center; }
#intro .tel strong { display: inline-block; *display: inline; *zoom: 1; padding: 10px 25px; font-size: 14px; line-height: 20px; float: none; }
#intro .tel a { float: none; display: inline-block; *display: inline; *zoom: 1; background: url(../images/common/tel.svg) no-repeat left center; background-size: 20px; padding: 0 0 0 30px; font-size: 30px; margin: 15px auto 0; }
#intro .tel small { float: none; display: inline-block; *display: inline; *zoom: 1; font-size: 12px; line-height: 20px; margin: 5px auto 0; }

/* ------------------------------------------------------------ contact */
#contact { padding: 40px 0; }
#contact form { width: 90%; padding: 20px 20px 40px; }
#contact form table,
#contact form table tbody { display: block; width: 100%; }
#contact form table tr { display: block; }
#contact form table tr:first-of-type { border-top: none; }
#contact form table tr.ex th { display: block; }
#contact form table tr.ex th h3 { margin: 0 auto; }
#contact form table th { display: block; width: 100%; padding: 20px 0 10px; }
#contact form table th h3 { font-size: 14px; }
#contact form table th h3 span { font-size: 11px; margin: 0 0 0 10px; }
#contact form table th small { font-size: 11px; margin: 5px auto 0; }
#contact form table td { display: block; padding: 0 0 20px; }
#contact form table td input[type="text"],
#contact form table td input[type="checkbox"],
#contact form table td select,
#contact form table td textarea { width: 100%; padding: 12px; font-size: 14px; -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; border: solid 1px #dcdcdc; appearance: none; -webkit-appearance: none; border-radius: 0; }
#contact form table tr.address td .cfx { margin: 0 auto 10px; }
#contact form table tr.address td .cfx p { width: 90px; font-size: 12px; line-height: 18px; margin: 15px 0 0; }
#contact form table tr.address td .cfx:last-of-type p { margin: 0 auto; }
#contact form table tr.address td .cfx input { width: calc(100% - 90px); margin: 0 auto; }
#contact form table tr.radio td label { font-size: 14px; margin: 0 15px 0 0; }

#contact form .gradation_btn2 { margin: 20px auto; }
#contact form .gradation_btn2 a { }
#contact form .gradation_btn2 span { font-size: 11px; margin: 0 auto 10px; }
#contact form .privacy_policy { font-size: 12px; }
#contact form .privacy_policy a { background-size: 15px; padding: 0 25px; }

#contact .questionnaire { margin: 20px auto; }
#contact .questionnaire h3 { font-size: 14px; line-height: 24px; padding: 10px 15px; margin: 0 auto; }
#contact .questionnaire p { font-size: 14px; line-height: 24px; margin: 0 auto 20px; }
#contact .questionnaire h4 { margin: 0 auto 15px; font-size: 14px; line-height: 24px; }

#contact .questionnaire > div { padding: 20px 0; }
#contact .questionnaire > div:first-of-type { border: none; }
#contact .questionnaire .q1 label { display: block; margin: 0 auto 10px; font-size: 12px; width: 100%;}
#contact .questionnaire .q1 label input { margin: 0 5px 0 0; }
#contact .questionnaire .q2 label { width: 100%; margin: 0 0 15px 0; padding: 0 0 0 1.5em; font-size: 12px; line-height: 16px; text-indent: -1.5em; }
#contact .questionnaire .q2 label:nth-of-type(2n+1) { clear: both; margin: 0 auto 15px; }
#contact .questionnaire .q2 label input { margin: 2px 5px 0 0; }
#contact .questionnaire label input { margin: 2px 5px 0 0; vertical-align: top; }
#contact .questionnaire textarea { border: solid 1px #e5e5e5; width: 100%; appearance: none; -webkit-appearance: none; border-radius: 0; }

/* ------------------------------------------------------------ エラー画面 */
.note { padding: 50px 0; margin: 60px auto 0; }
.note h3 { font-size: 24px; padding: 0 0 20px; }
.note .caution { font-size: 14px; padding: 10px 5%; width: 90%; margin: 0 auto 30px; line-height: 24px; }
.note .alert { margin: 0 auto 20px; }
.note .alert span { display: block; font-size: 14px; padding: 0 0 15px; }
.note .btn { padding: 0; }
.note .btn a { width: 240px; font-size: 14px; line-height: 50px; }

/* ------------------------------------------------------------ 確認画面 */
.note.confirm .flow { margin: 0 auto 40px; }
.note table { margin: 0 auto; display: block; width: 100%; min-width: inherit; }
.note table tbody,
.note table tr { display: block; width: 100%; }
.note table th { display: block; width: 100%; padding: 15px 10px 10px; font-size: 14px; }
.note table td { display: block; width: 100%; padding: 0 10px 15px; font-size: 14px; }
.note input[type="submit"] { line-height: 50px; padding: 0; margin: 10px auto 0; width: 240px; }

/* ------------------------------------------------------------ サンクス */
.intro h3 { font-size: 22px; padding: 0 0 25px; }
.intro .caution { width: 100%; font-size: 13px; line-height: 24px; text-align: left; padding: 15px; -webkit-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
.intro .btn { padding: 10px 0 40px; }
.intro .btn a { width: 240px; font-size: 14px; line-height: 50px; }


.table { display: block; }
.table .table_cell { display: block; }
#about_free_trial h3.title1 + p { font-size: 14px; line-height: 27px; padding: 0 0 45px; }
#about_free_trial .articles { padding: 50px 0; }
#about_free_trial .articles article { padding: 9% 5%; margin: 0 auto 30px; }
#about_free_trial .articles article:last-of-type { margin: 0 auto; }
#about_free_trial .articles article h4 { padding: 0 0 20px; }
#about_free_trial .articles article h4 span { font-size: 40px; }
#about_free_trial .articles article h4 strong { font-size: 20px; line-height: 35px; }
#about_free_trial .articles article h4 + p { font-size: 14px; line-height: 27px; padding: 0 0 30px; }

#about_free_trial .articles article .table { padding: 0 0 30px; }
#about_free_trial .articles article .table .img { width: 100%; padding: 0 0 15px; }
#about_free_trial .articles article .table .textbox { padding: 0; }
#about_free_trial .articles article .table .textbox ul { padding: 5px 0 10px; }
#about_free_trial .articles article .table .textbox ul li { font-size: 13px; line-height: 27px; }
#about_free_trial .articles article .table .textbox p { font-size: 14px; line-height: 27px; }

#about_free_trial .articles article .point { padding: 0; margin: 0 auto 20px; }
#about_free_trial .articles article .point h5 { width: 100%; font-size: 16px; line-height: 27px; padding: 10px 0; border-radius: 0; -webkit-border-radius: 0; }
#about_free_trial .articles article .point .table_cell:nth-of-type(2) { padding: 5%; }
#about_free_trial .articles article .point p { font-size: 14px; line-height: 27px; padding: 0 0 10px; }
#about_free_trial .articles article .point ul li { float: none; width: 100%; font-size: 14px; line-height: 27px; }

#about_free_trial .articles article .different { padding: 8% 5%; }
#about_free_trial .articles article .different .tag { padding: 0 0 20px; }
#about_free_trial .articles article .different .tag span { padding: 8px 16px 9px; font-size: 12px;}
#about_free_trial .articles article .different h5 { font-size: 18px; padding: 0 0 15px; }
#about_free_trial .articles article .different p { font-size: 14px; text-align: left; line-height: 27px; }

}
