@charset "utf-8";
html {
	font-size: 62.5%;
}
body {
	min-height: 150%;
	background:#fff;
	/*font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;*/
	font-family: 'Roboto', 'Noto Sans JP', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	color: #000000;
}
input::placeholder {
	color: #989898;
	font-family: 'Roboto', 'Noto Sans JP', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	letter-spacing: 2px;
}
input:-ms-input-placeholder {
	color: #989898;
	font-family: 'Roboto', 'Noto Sans JP', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	letter-spacing: 2px;
}
input::-ms-input-placeholder {
	color: #989898;
	font-family: 'Roboto', 'Noto Sans JP', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	letter-spacing: 2px;
}
a {
	color: #000000;
	text-decoration: none;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
}

a:hover {
	opacity:0.6;
}

a img {
	opacity:1.0;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
}
a:hover img {
	opacity:0.6;
}

.red {
    color: #CA0003;
}

.bghover {
	opacity:1.0;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	outline: none;
}
.bghover:hover {
	opacity:0.6 !important;
}
.fade_in {
    opacity: 0;
	-webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    -o-transition: all 0.3s;
    -ms-transition: all 0.3s;
    transition: all 0.3s;
}
.fade_in.lazyloaded, .fade_on {
    opacity: 1;
}
.fade_in_long {
    opacity: 0;
	-webkit-transition: all 2s;
    -moz-transition: all 2s;
    -o-transition: all 2s;
    -ms-transition: all 2s;
    transition: all 2s;
}
.fade_in_long.lazyloaded, .fade_on_long {
    opacity: 1;
}
.flex_between {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.subbox_inner {
	border-right:1px solid #e4e4e4;
	border-left:1px solid #e4e4e4;
	border-bottom:1px solid #e4e4e4;
	padding: 30px;
}
.subbox_tit {
	background-color: #f6f6f6;
	line-height: 60px;
	padding: 0 20px;
	font-size: 1.2rem;
}
#undercolumn_error .message_area {
	display:flex;
	align-items: center;
	border:1px solid #e4e4e4;
	padding: 30px;
	min-height: 20vh;
	text-align: center;
}
#undercolumn_error .message_area p {
	width: 100%;
	vertical-align: middle;
	text-align: center;
}
.undercolumn_small {
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 40px 40px 40px;
}
#undercolumn_contact,
#undercolumn_entry {
	max-width: 1000px;
	margin: 0 auto;
	padding: 40px 40px 40px 40px;
}
.sp_only {
	display: none;
}
.default_dl_list {
	display: flex;
	flex-wrap: wrap;
}
.default_dl_list dt {
	width: 15%;
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid #f1f1f1;
}
.default_dl_list dd {
	width: 85%;
	padding-left: 30px;
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid #f1f1f1;
}
.faq_dl_list a {
	text-decoration: underline;
}
.faq_dl_list dt {
	width: 100%;
	line-height: 50px;
	font-weight: 700;
	padding: 0 20px;
	margin-bottom: 25px;
	background-color: #f1f1f1;
}
.faq_dl_list dd {
	width: 100%;
	padding-left: 30px;
	padding-right: 30px;
	padding-bottom: 20px;
	margin-bottom: 25px;
}
.undercolumn_message_block {
	padding: 20px;
	background-color: #F7F7F7;
	margin-bottom: 30px;
}
/*flex----------------------------------------------*/
.flex_between {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.flex_center {
	display: flex;
	align-items: center;
}
.flex_center_col {
	display: flex;
	align-items: center;
	justify-content: center;
}
.flex_alignL {
	display: flex;
	align-items: center;
}
.flex_alignL_bottom {
	display: flex;
	align-items:baseline;
}
.flex_alignR {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.flex_alignC {
	display: flex;
	justify-content:center;
	align-items: center;
}
.row_list li {
	display: flex;
	margin-bottom: 5px;
}
.row_list_tit_S {
	font-weight: 700;
	width: 70px;
}

/*swiperテーマ上書き----------------------------------*/
.swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction {
    width: 100%;
	text-align: center;
	margin-top: 40px;
}
.swiper-pagination-bullet {
    width: 25px;
    height: 2px;
    display: inline-block;
    background: #cccccc;
	border-radius: 0;
	transition: all 0.3s ease;
}
.swiper-pagination-bullet-active {
    background: #000;
	width: 50px;
}
.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 5px;
}
.pagination-outside {
	position: relative;
	margin-top: 30px;
	top: 0;
	bottom: auto;
}
.paginatiion-left {
	text-align: left;
}

.swiper-slide img {
	width: 100%;
	vertical-align: bottom;
}
.swiper-button-next, .swiper-button-prev {
    position: absolute;
    top: 50%;
    width: 13px;
    height: 27px;
    margin-top: -22px;
    z-index: 10;
    cursor: pointer;
    background-size: 13px 27px;
    background-position: center;
    background-repeat: no-repeat;
}
/*Title--------------------------------------------------*/
.tit_default {
	font-size: 2rem;
	font-weight: 700;
}
.tit_default span {
	padding-left: 20px;
}
.tit_default_center,
.tit_list {
	font-size: 2rem;
	font-weight: 700;
	text-align: center;
	margin:70px auto; 
}
.bdr_top_bottom {
	padding: 20px 0;
	border-top: 1px solid #EEEEEE;
	border-bottom: 1px solid #EEEEEE;
}
.tit_mini {
	font-size: 1.2rem;
	margin-bottom: 15px;
}
.tit_mini_center_border {
	font-size: 1.4rem;
	text-align: center;
	border-bottom: 1px solid #d6d6d6;
	padding-bottom: 20px;
}
.tit_bg_gray {
	background-color: #f7f7f7;
	padding: 25px;
}
.tit_bdr {
	padding-bottom: 15px;
    border-bottom: 1px solid #e4e4e4;
}
.undercolumn_small .tit_default,
#mypagecolumn .tit_default,
#undercolumn_contact .tit_default{
	margin-bottom: 40px;
}
#mycontentmain_area .tit_default_s {
	font-size: 1.5rem;
	margin-bottom: 20px;
}
.tit_gray_bar {
	background-color: #f3f3f3;
	font-weight: 700;
	padding: 15px;
}
.tit_block_login {
	margin-bottom: 20px;
}
.tit_mini_center_border {
    font-size: 1.4rem;
    text-align: center;
    border-bottom: 1px solid #d6d6d6;
    padding-bottom: 20px;
}
/*ページング------------------------------------------*/
.paging {
	width: 100%;
    margin-top: 60px;
    border-top: 1px solid #d3d6d6;
    padding: 35px 0 20px 0;
    font-size: 1.2rem;
	display: flex;
	justify-content: space-between;
}
.prev_btn, .next_btn {
	width: 20%;
	display: block;
}
.prev_btn {
	text-align: left;
}
.next_btn {
	text-align: right;
}
.page_btn {
	width: 60%;
	text-align: center;
}
.page_btn a ,.page_btn strong {
	display: inline-block;
	padding: 3px 5px;
	margin: 0 10px;
}
.page_btn a {
	border-bottom: 1px solid #d3d6d6;
}
.nav_prev, .nav_next {
	width: 30px;
	height: 30px;
	text-align: center;
	font-size: 1.6rem;
	line-height: 30px;
}
.nav_prev a, .nav_next a {
	width: 100%;
	height: 100%;
	display: block;
}
.list_pageer {
	display: flex;
	gap: 15px;
}
.list_pageer li {
	line-height: 30px;
	width: 15px;
	height: 30px;
}
.list_pageer li a {
	text-align: center;
	width: 100%;
	height: 100%;
	display: block;
	border-bottom: 1px solid #FFF;
}
.list_pageer li strong {
	text-align: center;
	width: 100%;
	height: 100%;
	display: block;
	border-bottom: 1px solid #000;
	font-weight: normal;
}

.paging ul {
	display: flex;
	justify-content: space-between;
}

/*ポップアップ*/
#popup_area {
	padding: 55px;
	letter-spacing: 1px;
}
/* 目次 -------------------------------------------------

・リンク設定
・共通クラス
・サイト共通
・ヘッダ ・メニュー ・コンテンツ ・フッタ

------------------------------------------------- */ 
table {
	_line-height:150%;
	font-size:100%;
}
.floatL {
	float: left;
}
.floatR {
	float: right;
}
.clear {
	clear: both;
	font-size: 0px;
	line-height: 0%;
	height: 0px;
	text-indent: -9999px;
}
.clearer {
	clear: both;
}
.v_middle {
	vertical-align:middle;
}

/* clearfixハック */
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
.clearfix {
	display: inline-block;
}

/* Hides from IE-mac \*/
* html .clearfix {
	height: 1%;
}
.clearfix {
	display: block;
}

.fontS {
	font-size: 1.2rem;
}
.fontM {
	font-size: 1.4rem;
}
.fontL {
	font-size: 1.8rem;
}

.fontLL {
	font-size: 2.0rem;
}
.font_gray{
	color: #999999;
}
.font_bold {
	font-weight: bold;
}

a.btn_black {
    display: inline-block;
    width: 100%;
    color: #FFF;
    height: 40px;
    background-color: #000;
    line-height: 4rem;
    text-align: center;
	border-radius: 3px;
}
a.btn_white {
    display: inline-block;
    width: 100%;
    color: #000;
    height: 40px;
    background-color: #FFF;
	border: 1px solid #e4e4e4;
    line-height: 4rem;
    text-align: center;
	border-radius: 3px;
}
a.btn_gray {
	display: inline-block;
	width: 140px;
	color: #FFF;
	height:35px;
	background-color: #686868;
	line-height: 35px;
	text-align: center;
}
a.btn_gray_L {
    display: inline-block;
    width: 240px;
    color: #FFF;
    height: 45px;
    background-color: #686868;
    line-height: 45px;
    text-align: center;
}
.btn_gray_S {
	display: inline-block;
	width: 100%;
	color: #FFF;
	height:30px;
	background-color: #686868;
	line-height: 30px;
	text-align: center;
	cursor: pointer;
}
.btn_gray_norm {
	display: inline-block;
	width: 100%;
	color: #FFF;
	height:53px;
	background-color: #686868;
	line-height: 53px;
	text-align: center;
	cursor: pointer;
}
.btn_white_norm {
	display: inline-block;
	width: 100%;
	color: #000;
	height:53px;
	background-color: #FFF;
	border: 1px solid #e4e4e4;
	line-height: 53px;
	text-align: center;
	cursor: pointer;
}
.btn_gray_mini {
	display: inline-block;
	padding: 0 10px;
	color: #FFF;
	height:25px;
	background-color: #686868;
	line-height: 25px;
	text-align: center;
	letter-spacing: normal;
	font-size: 1rem;
}

.btn_lgray_norm {
	display: inline-block;
	width: 100%;
	color: #FFF;
	height:53px;
	background-color: #bababa;
	line-height: 53px;
	text-align: center;
	cursor: pointer;
}
.btn_area_center {
	text-align: center;
}
.w270 {
	width: 270px !important;
}

/*Btn Default--------------------------------------------------*/
.btn_area {
	margin-top: 40px;
}
.btn_area_S {
	margin-top: 20px;
}
.btn_area_wait {
	text-align: center;
	font-weight: 700;
	margin-top: 40px;
	display: none;
}
.btn_area_center {
	text-align: center;
	margin-top: 40px;
}
.btn_area li {
	margin: 0 8px
}
.btn_area ul {
	display: flex;
	align-items: center;
	justify-content: center;
}
.white {
    background-color: #FFF;
    color: #333333;
}
.gray {
    background-color: #333;
    color: #FFF;
}
.light_gray {
    background-color: #b2b2b2;
    color: #FFF;
}
.btn_gray_norm {
    display: inline-block;
    width: 100%;
    color: #FFF;
    height: 48px;
    background-color: #000;
    line-height: 48px;
    text-align: center;
    cursor: pointer;
	font-size: 1.4rem;
}
.btn_orange_norm {
    display: inline-block;
    width: 100%;
    color: #000;
    height: 48px;
    background: #f5d78a;
    background: -moz-linear-gradient(center top, #F6DD9F 5%, #F0C24D 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #F6DD9F),color-stop(1, #F0C24D));
    line-height: 48px;
    text-align: center;
    cursor: pointer;
	font-size: 1.4rem;
}
.btn_lgray_norm {
    display: inline-block;
    width: 100%;
    color: #FFF;
    height: 48px;
    background-color: #bababa;
    line-height: 48px;
    text-align: center;
    cursor: pointer;
	font-size: 1.4rem;
}
.w_mid {
    width: 270px !important;
}
.w_short {
    width: 200px !important;
}
.btn_fix_w {
	width: 200px;
}
.btn_gray_norm_S {
	display: inline-block;
    width: 100%;
    color: #FFF;
    height: 32px;
    background-color: #000;
    line-height: 32px;
    text-align: center;
    cursor: pointer;
    border-radius: 5px;
	font-size: 1.0rem;
}

/*インラインコンテンツ------------------------------------*/
#inline_content {
	padding: 40px;
}
#windowcolumn {
	padding: 15px;
    font-size: 1.2rem;
    line-height: 2.2rem;
}
#popup_area {
    padding: 50px;
}
#window_area {
	padding: 50px;
}
.subbox_tit {
    background-color: #f6f6f6;
    line-height: 60px;
    padding: 0 20px;
    font-size: 1.2rem;
}
.subbox_inner {
    border-right: 1px solid #e4e4e4;
    border-left: 1px solid #e4e4e4;
    border-bottom: 1px solid #e4e4e4;
    padding: 30px;
}
#mail-dialog {
	display: none;
	font-size: 1.2rem;
	line-height: 180%;
	padding: 30px;
}
#mail-dialog-title {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #e4e4e4;
}
.dialog-title {
	display: none;
}

/* End hide from IE-mac */ /*配置設定クラス*/
.alignL {
	text-align: left !important;
}
.alignC {
	text-align: center !important;
}
.alignR {
	text-align: right !important;
}
.mg_5 {
	margin:5px !important;
}
.mg_lr5 {
	margin:0px 5px !important;
}
.mg_t5 {
	margin-top:5px !important;
}
.mg_b5 {
	margin-bottom:5px !important;
}
.mg_l5 {
	margin-left:5px !important;
}
.mg_r5 {
	margin-right:5px !important;
}
.mg_10 {
	margin:10px !important;
}
.mg_lr10 {
	margin:0px 10px !important;
}
.mg_t10 {
	margin-top:10px !important;
}
.mg_b10 {
	margin-bottom:10px !important;
}
.mg_l10 {
	margin-left:10px !important;
}
.mg_r10 {
	margin-right:10px !important;
}
.mg_12 {
	margin:12px !important;
}
.mg_lr12 {
	margin:0px 12px !important;
}
.mg_t12 {
	margin-top:12px !important;
}
.mg_b12 {
	margin-bottom:12px !important;
}
.mg_l12 {
	margin-left:12px !important;
}
.mg_r12 {
	margin-right:12px !important;
}
.mg_15 {
	margin:15px !important;
}
.mg_lr15 {
	margin:0px 15px !important;
}
.mg_t15 {
	margin-top:15px !important;
}
.mg_b15 {
	margin-bottom:15px !important;
}
.mg_l15 {
	margin-left:15px !important;
}
.mg_r15 {
	margin-right:15px !important;
}
.mg_20 {
	margin:20px !important;
}
.mg_lr20 {
	margin:0px 20px !important;
}
.mg_t20 {
	margin-top:20px !important;
}
.mg_b20 {
	margin-bottom:20px !important;
}
.mg_l20 {
	margin-left:20px !important;
}
.mg_r20 {
	margin-right:20px !important;
}
.mg_25 {
	margin:25px !important;
}
.mg_lr25 {
	margin:0px 25px !important;
}
.mg_t25 {
	margin-top:25px !important;
}
.mg_b25 {
	margin-bottom:25px !important;
}
.mg_l25 {
	margin-left:25px !important;
}
.mg_r25 {
	margin-right:25px !important;
}
.mg_30 {
	margin:30px !important;
}
.mg_lr30 {
	margin:0px 30px !important;
}
.mg_t30 {
	margin-top:30px !important;
}
.mg_b30 {
	margin-bottom:30px !important;
}
.mg_l30 {
	margin-left:30px !important;
}
.mg_r30 {
	margin-right:30px !important;
}
.mg_40 {
	margin:40px !important;
}
.mg_lr40 {
	margin:0px 40px !important;
}
.mg_t40 {
	margin-top:40px !important;
}
.mg_b40 {
	margin-bottom:40px !important;
}
.mg_l40 {
	margin-left:40px !important;
}
.mg_r40 {
	margin-right:40px !important;
}
.mg_t50 {
	margin-top:50px !important;
}
.mg_b50 {
	margin-bottom:50px !important;
}
.mg_l50 {
	margin-left:50px !important;
}
.mg_r50 {
	margin-right:50px !important;
}
.mg_t60 {
	margin-top:60px !important;
}
.mg_b60 {
	margin-bottom:60px !important;
}
.mg_l60 {
	margin-left:60px !important;
}
.mg_r60 {
	margin-right:60px !important;
}
.mg_t70 {
	margin-top:70px !important;
}
.mg_b70 {
	margin-bottom:70px !important;
}
.mg_l70 {
	margin-left:70px !important;
}
.mg_r70 {
	margin-right:70px !important;
}
.mg_t80 {
	margin-top:80px !important;
}
.mg_b80 {
	margin-bottom:80px !important;
}
.mg_l80 {
	margin-left:80px !important;
}
.mg_r80 {
	margin-right:80px !important;
}
.mg_t90 {
	margin-top:90px !important;
}
.mg_b90 {
	margin-bottom:90px !important;
}
.mg_l90 {
	margin-left:90px !important;
}
.mg_r90 {
	margin-right:90px !important;
}
.mg_t100 {
	margin-top:100px !important;
}
.mg_b100 {
	margin-bottom:100px !important;
}
.mg_l100 {
	margin-left:100px !important;
}
.mg_r100 {
	margin-right:100px !important;
}
.pd_5 {
	padding:5px !important;
}
.pd_lr5 {
	padding:0px 5px !important;
}
.pd_t5 {
	padding-top:5px !important;
}
.pd_b5 {
	padding-bottom:5px !important;
}
.pd_l5 {
	padding-left:5px !important;
}
.pd_r5 {
	padding-right:5px !important;
}
.pd_10 {
	padding:10px !important;
}
.pd_lr10 {
	padding:0px 10px !important;
}
.pd_t10 {
	padding-top:10px !important;
}
.pd_b10 {
	padding-bottom:10px !important;
}
.pd_l10 {
	padding-left:10px !important;
}
.pd_r10 {
	padding-right:10px !important;
}
.pd_15 {
	padding:15px !important;
}
.pd_lr15 {
	padding:0px 15px !important;
}
.pd_t15 {
	padding-top:15px !important;
}
.pd_b15 {
	padding-bottom:15px !important;
}
.pd_l15 {
	padding-left:15px !important;
}
.pd_r15 {
	padding-right:15px !important;
}
.pd_20 {
	padding:20px !important;
}
.pd_lr20 {
	padding:0px 20px !important;
}
.pd_t20 {
	padding-top:20px !important;
}
.pd_b20 {
	padding-bottom:20px !important;
}
.pd_l20 {
	padding-left:20px !important;
}
.pd_r20 {
	padding-right:20px !important;
}
.pd_0 {
	padding: 0 !important;
}
.last_item {
	margin-right: 0px !important;
}
.img100 {
	width: 100%;
}

#color_tip_1 a{background-color:#FFF;}
#color_tip_2 a{background-color:#000;}
#color_tip_3 a{background-color:#999999;}
#color_tip_4 a{background-color:#5C3418;}
#color_tip_5 a{background-color:#e1c68a;}
#color_tip_6 a{background-color:#68833d;}
#color_tip_7 a{background-color:#153eed;}
#color_tip_8 a{background-color:#800080;}
#color_tip_9 a{background-color:#F4D500;}
#color_tip_10 a{background-color:#FF69B4;}
#color_tip_11 a{background-color:#FF0000;}
#color_tip_12 a{background-color:#EF810F;}
#color_tip_13 a{background-color:#C0C0C0;}
#color_tip_14 a{background-color:#D3B95E;}