@charset "UTF-8";
/* CSS Document */

/* 基本-モバイルファースト ======================================================================================================== */
/* 印刷時の余白幅指定 */
@page {
	margin: 12.7mm 9.7mm;
}
html {
-webkit-font-smoothing: antialiased;
}
body{
text-align: center;
width: 100%;
font-family: sans-serif;
line-height: 1.8;
color: #111;
background-image: url("../images/header_bg.svg"), url("../images/bg.svg");
background-repeat: no-repeat, no-repeat;
background-position: 5vw top, center top;
background-size: 50% auto, 200% auto;
word-break: break-all;
}
body,
table,
input,
textarea{
	font-size: 14px;
}

/* テキスト選択時のハイライト */
::selection {
    background: #DDD;
}
::-moz-selection {
    background: #DDD;
}

a,
a:link,
a:visited {
	color: #111;
}

img{
vertical-align: middle;
max-width: 100%;
height: auto;
}

input[type="text"],
input[type="email"],
input[type="tel"],
textarea{
	background-color: #FFF;
	padding: 5px;
	margin: 0px;
	box-sizing: border-box;
	border: 1px solid #AAA;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
}
input[type="text"]:hover,
input[type="email"]:hover,
input[type="tel"]:hover,
textarea:hover{
	border: 1px solid #666;
}
input[type="text"]:focus,
input[type="text"]:focus,
input[type="text"]:focus,
textarea:focus{
	background-color: #F3F3F3;
}
input[type="radio"],
input[type="checkbox"]{
	-webkit-appearance: none;
	background-color: #FFF;
	background-image: url(../images/checkbox_bg_off.svg);
	background-repeat: no-repeat;
	background-position: center center;
	width: 20px;
	height: 20px;
	margin: 0 5px 0 0;
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	border-radius: 20px;
	display: inline-block;
	vertical-align: middle;
	border: solid 1px #CCC;
	box-sizing: border-box;
}
input[type="checkbox"]{
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}
input[type="radio"]:checked,
input[type="checkbox"]:checked{
	background-image: url(../images/checkbox_bg_on.svg);
	background-color: #ffd403;
	border: none;
}
label:hover{
	cursor: pointer;
}

.opct{}

/* googleリマーケティングタグの隙間回避 */
iframe[name="google_conversion_frame"] { position:absolute; top: 0; left: 0; }

.mt05{ margin-top: 5px; }
.mt10{ margin-top: 10px; }
.mt15{ margin-top: 15px; }
.mt20{ margin-top: 20px; }
.mt30{ margin-top: 30px; }
.mt40{ margin-top: 40px; }
.mr05{ margin-right: 5px; }
.mr10{ margin-right: 10px; }
.mr15{ margin-right: 15px; }
.mr20{ margin-right: 20px; }
.mr30{ margin-right: 30px; }
.mr40{ margin-right: 40px; }
.mb05{ margin-bottom: 5px; }
.mb10{ margin-bottom: 10px; }
.mb15{ margin-bottom: 15px; }
.mb20{ margin-bottom: 20px; }
.mb30{ margin-bottom: 30px; }
.mb40{ margin-bottom: 40px; }
.ml05{ margin-left: 5px; }
.ml10{ margin-left: 10px; }
.ml15{ margin-left: 15px; }
.ml20{ margin-left: 20px; }
.ml30{ margin-left: 30px; }
.ml40{ margin-left: 40px; }
.pt05{ padding-top: 5px; }
.pt10{ padding-top: 10px; }
.pt15{ padding-top: 15px; }
.pt20{ padding-top: 20px; }
.pt30{ padding-top: 30px; }
.pt40{ padding-top: 40px; }
.pr05{ padding-right: 5px; }
.pr10{ padding-right: 10px; }
.pr15{ padding-right: 15px; }
.pr20{ padding-right: 20px; }
.pr30{ padding-right: 30px; }
.pr40{ padding-right: 40px; }
.pb05{ padding-bottom: 5px; }
.pb10{ padding-bottom: 10px; }
.pb15{ padding-bottom: 15px; }
.pb20{ padding-bottom: 20px; }
.pb30{ padding-bottom: 30px; }
.pb40{ padding-bottom: 40px; }
.pl05{ padding-left: 5px; }
.pl10{ padding-left: 10px; }
.pl15{ padding-left: 15px; }
.pl20{ padding-left: 20px; }
.pl30{ padding-left: 30px; }
.pl40{ padding-left: 40px; }

.f_right{ float: right; }
.f_left{ float: left; }
.pc_float_none{}
.pc_f_right{}
.pc_f_left{}

.table{ display: table; }
.table_cell{ display: table-cell; }
.pc_display_block{}
.pc_table{}
.pc_table_cell{}

.ta_right{ text-align: right; }
.ta_center{ text-align: center; }
.ta_left{ text-align: left; }

.va_top{ vertical-align: top; }
.va_middle{ vertical-align: middle; }
.va_bottom{ vertical-align: bottom; }

.sp_tel{}

.font10px{ font-size: 10px; }
.font11px{ font-size: 11px; }
.font12px{ font-size: 12px; }
.font14px{ font-size: 14px; }
.font16px{ font-size: 16px; }
.font18px{ font-size: 18px; }
.font20px,
.font22px,
.font24px,
.font26px,
.font28px{ font-size: 20px; }
.font30px{ font-size: 22px; }

.font_bold{ font-weight: bold; }

.clear{
	display: block;
	float: none;
	clear: both;
}

.css_arrow{
position: relative;
display: inline-block;
padding: 0 15px 0 0;
vertical-align: middle;
}
.css_arrow::before{
content: "";
vertical-align: middle;
position: absolute;
top: 0;
bottom: 0;
right: 3px;
margin: auto;
border-top: 1px solid #333;
border-right: 1px solid #333;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

.ca_5::before{ 	width: 5px; height: 5px; }
.ca_7::before{ 	width: 7px; height: 7px; }
.ca_10::before{ width: 10px; height: 10px; }
.ca_15::before{ width: 15px; height: 15px; }

/* ヘッダー======================================================================================================== */
h1{
font-size: 10px;
white-space: nowrap;
width: 100%;
overflow: hidden;
text-overflow: ellipsis;
margin-bottom: 5px;
}

#header{
position: relative;
}
#header_logo{
}
#header_logo img{
height: 25px;
}
#header_contents{
width: 100%;
padding: 2vw;
position: fixed;
bottom: 0;
left: 0;
z-index: 10000;
display: flex;
justify-content: space-between;
}

#header_contents .interest_btn{
width: 49%;
}
#header_contents .line_btn{
width: 49%;
}

.interest_btn a,
.line_btn a{
text-decoration: none;
text-align: center;
line-height: 1.4;
font-weight: bold;
background-repeat: no-repeat;
background-position: center center;
background-size: 100% 100%;
padding: 0;
height: 60px;
display: flex;
align-items: center;
justify-content: center;
}
.interest_btn a{
background-image: url("../images/btn_yellow.svg");
}
.line_btn a{
background-image: url("../images/btn_green.svg");
color: #fff;
}
.line_btn a .icon{
display: inline-block;
vertical-align: middle;
width: 30px;
height: 30px;
margin-right: 5px;
}
.line_btn a span{
display: inline-block;
vertical-align: middle;
text-align: left;
}


/* コンテンツ======================================================================================================== */
#container {
}
#contents {
padding-top: 5vw;
padding-bottom: 10vw;
}
.contents_size{
padding-left: 5vw;
padding-right: 5vw;
display: block;
text-align: left;
}

.page_title{
text-align: center;
}
.page_title > *{
font-size: 6vw;
font-weight: bold;
background: linear-gradient(transparent 60%, rgba(255,212,3,0.7) 0%);
display: inline;
padding: 0 2px 4px;
}
#topic_path{
font-size: 10px;
margin-bottom: 20px;
text-align: left;
}
#topic_path a::after{
content: "";
display: inline-block;
vertical-align: middle;
width: 5px;
height: 5px;
margin: 0 5px 0 0;
border-top: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
}

.sub_bar{
}

.marker{
background: linear-gradient(transparent 60%, #ffd403 0%);
display: inline;
padding: 0 2px 4px;
}

.accordion_title{
padding-right: 15px;
position: relative;
cursor: pointer;
}
.accordion_title::after{
content: "";
display: inline-block;
vertical-align: middle;
width: 10px;
height: 10px;
position: absolute;
top: 0;
bottom: 0;
right: 3px;
margin: auto;
border-bottom: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
transition: all 0.2s ease;
}
.accordion_title.open::after{
transform: rotate(-135deg);
}
.accordion_title + *{
display: none;
}

form{
	margin: 0px;
	padding: 0px;
}
/* 通常テーブルパターン */
table.normal{
	width: 100%;
	border-collapse:collapse;
	border-spacing: 0;
}
table.normal th,
table.normal td{
	border-bottom: 1px solid #DDD;
	box-sizing: border-box;
}
table.normal th{
	padding: 15px 0px;
	font-weight: bold;
	text-align: center;
	white-space: nowrap;
}
form table.normal th{
	text-align: left;
	vertical-align: top;
}
table.normal td{
	padding: 15px 0px 15px 15px;
}
table.sp_tableflat{}
form .must{
	display: block;
	background-color: #C00;
	padding: 5px;
	font-size: 10px;
	line-height: 10px;
	color: #FFF;
	float: right;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
	border-radius: 5px;
}
form .cap{
	font-size: 10px;
	color: #C00;
}
.form_address li{
	margin: 5px 0 0;
}
.form_address li.post{
	margin: 0;
}
form #submit_box{
	margin-top: 30px;
	text-align: center;
}
form #submit_box p{
	margin: 0 0 10px;
}
form #submit_box button,
.mfp_buttons button{
	font-size: 20px;
	margin: 0 10px;
	padding: 15px 40px;
	cursor:pointer;
	display: inline-block;
	-webkit-appearance: none;
	border: none;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}
form #submit_box button[type="reset"]{ background-color: #CCC; }
form #submit_box button[type="submit"]{ background-color: #C00; color: #FFF; }
form #submit_box button[type="reset"]:hover{ background-color: #BBB; }
form #submit_box button[type="submit"]:hover{ background-color: #9A0002; }
.mfp_buttons button#mfp_button_send{ background-color: #C00; color: #FFF; }
.mfp_buttons button#mfp_button_cancel{ background-color: #CCC; }
.mfp_buttons button#mfp_button_send:hover{ background-color: #9A0002; }
.mfp_buttons button#mfp_button_cancel:hover{ background-color: #BBB; }

#mfp_phase_confirm{
	clear: both;
	padding-top: 40px;
}
#mfp_phase_confirm h4{
	font-weight: bold;
	margin-bottom: 10px;
}

#thanks_page{
	padding: 60px 0;
	text-align: center;
}
#thanks_page h3{
	font-weight: bold;
	font-size: 18px;
}


/* フッター======================================================================================================== */
#footer {
background-color: #ffd403;
padding: 10vw 0;
margin-bottom: 80px;
}
#footer #footer_link ul{
display: flex;
justify-content: center;
margin-bottom: 20px;
}
#footer #footer_link li{
border-left: solid 1px #111;
margin: 0 0 0 5px;
padding: 0 0 0 5px;
}
#footer #footer_link li:first-child{
border-left: none;
margin: 0;
padding: 0;
}
#footer #footer_link li a{
display: block;
text-decoration: none;
line-height: 1.2;
}

#footer #copy_right{
font-size: 10px;
}





/* スマホのみ======================================================================================================== */
@media screen and (max-width: 750px){

.pc_only{ display: none; }
.sp_only{ }

.sp_float_reset{ float: none; }
.sp_block{ display: block; }

.mt50,.mt60,.mt70,.mt80,.mt90{ margin-top: 40px; } .mt100,.mt150{ margin-top: 60px; }
.mr50,.mr60,.mr70,.mr80,.mr90{ margin-right: 40px; } .mr100,.mr150{ margin-right: 60px; }
.mb50,.mb60,.mb70,.mb80,.mb90{ margin-bottom: 40px; } .mb100,.mb150{ margin-bottom: 60px; }
.ml50,.ml60,.ml70,.ml80,.ml90{ margin-left: 40px; } .ml100,.ml150{ margin-left: 60px; }

.pt30,.pt40,.pt50,.pt60{ padding-top: 20px; }
.pr30,.pr40,.pr50,.pr60{ padding-right: 20px; }
.pb30,.pb40,.pb50,.pb60{ padding-bottom: 20px; }
.pl30,.pl40,.pl50,.pl60{ padding-left: 20px; }

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
textarea {
	width: 100%;
}
.form_sp_half{
	display: flex;
	justify-content: space-between;
}
.form_sp_half input{
	width: 49%;
}
input.form_sp_90{
	width: 90%;
}
.form_address li{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
}
.form_address li.post{
	display: block;
}
.form_address li span{
	width: 5em;
}
.form_address li select,
.form_address li input{
	flex: 1;
	text-align: left;
}
.form_address li .mfp_err{
	width: 100%;
}

input.input_sp_auto{
	width: auto !important;
}
form #submit_box button{
	padding: 15px 30px;
	margin: 0 5px;
}

.sp_tableflat th,
.sp_tableflat td{
	display: block;
}
.sp_tableflat th{
	border-bottom: none !important;
	padding: 8px 0px 0px !important;
	text-align: left !important;
}
.sp_tableflat td{
	padding: 0px 0px 8px !important;
}



}

/* PCのみ======================================================================================================== */
@media print, screen and (min-width: 751px){
body{
font-family: Arial, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
font-weight:500;
background-position: 10% top, center top;
background-size: 335px auto, 2000px auto;
}
/* IEで游ゴシックはバグるのでメイリオに */
_:lang(x)::-ms-backdrop, body {
    font-family: "メイリオ", Meiryo, sans-serif;
}
body,
table,
input,
textarea{
font-size: 16px;
}
a,
a:link,
a:visited {
transition: all 0.2s ease;
}
a:hover {
color: #111;
}
a:active {
color: #111;
}
.opct a:hover,
a.opct:hover,
a:hover img.opct{
opacity: 0.8;
}

.pc_only{ }
.sp_only{ display: none; }

.sp_tel:visited,
.sp_tel:link,
.sp_tel{ pointer-events: none; text-decoration: none; }

.pc_float_none{ float: none; }
.pc_f_right{ float: right; }
.pc_f_left{ float: left; }

.pc_display_block{ display: block; }
.pc_table{ display: table; }
.pc_table_cell{ display: table-cell; }

.mt50{ margin-top: 50px; }
.mt60{ margin-top: 60px; }
.mt70{ margin-top: 70px; }
.mt80{ margin-top: 80px; }
.mt90{ margin-top: 90px; }
.mt100{ margin-top: 100px; }
.mt150{ margin-top: 150px; }

.mr50{ margin-right: 50px; }
.mr60{ margin-right: 60px; }
.mr70{ margin-right: 70px; }
.mr80{ margin-right: 80px; }
.mr90{ margin-right: 90px; }
.mr100{ margin-right: 100px; }
.mr150{ margin-right: 150px; }

.mb50{ margin-bottom: 50px; }
.mb60{ margin-bottom: 60px; } 
.mb70{ margin-bottom: 70px; } 
.mb80{ margin-bottom: 80px; } 
.mb90{ margin-bottom: 90px; } 
.mb100{ margin-bottom: 100px; } 
.mb150{ margin-bottom: 150px; } 

.ml50{ margin-left: 50px; }
.ml60{ margin-left: 60px; }
.ml70{ margin-left: 70px; }
.ml80{ margin-left: 80px; }
.ml90{ margin-left: 90px; }
.ml100{ margin-left: 100px; }
.ml150{ margin-left: 150px; }

.pt50{ padding-top: 50px; }
.pt60{ padding-top: 60px; }

.pr50{ padding-right: 50px; }
.pr60{ padding-right: 60px; }

.pb50{ padding-bottom: 50px; }
.pb60{ padding-bottom: 60px; } 

.pl50{ padding-left: 50px; }
.pl60{ padding-left: 60px; }

.font20px{ font-size: 20px; }
.font22px{ font-size: 22px; }
.font24px{ font-size: 24px; }
.font26px{ font-size: 26px; }
.font28px{ font-size: 28px; }
.font30px{ font-size: 30px; }

/* 中身 */
h1{
margin-bottom: 20px;
}
#header{
display: flex;
align-items: center;
justify-content: space-between;
}
#header_logo img{
height: 45px;
}
#header_contents{
width: 510px;
padding: 0;
position: inherit;
bottom: inherit;
left: inherit;
}
#header_contents .interest_btn,
#header_contents .line_btn{
width: 250px;
font-size: 14px;
}
.line_btn a:hover{
color: #fff;
}


/* コンテンツ */
#container {
}
#contents {
padding-top: 40px;
padding-bottom: 100px;
}
.contents_size{
	width: 1200px;
	padding-left: 0px;
	padding-right: 0px;
	margin-left: auto;
	margin-right: auto;
}
.page_title > *{
font-size: 40px;
}


/* フッター */
#footer {
padding: 40px 0;
margin-bottom: 0px;
}

#footer #footer_link li a:hover{
text-decoration: underline;
}






}

