@charset "UTF-8";
/* Scss Document */
/*color*/
/*font*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;600&display=swap");
/*@import url('https://fonts.googleapis.com/css2?family=agenda:wght@600&display=swap');*/
@font-face { font-family: 'Agenda-Light'; font-style: normal; font-weight: normal; src: url(../fonts/ufonts.com_agenda-light.woff) format("woff"); }
/*@font-face {
	font-family: "Agenda-Bold";
	src: url(../fonts/ufonts.com_agenda-bold.woff) format('woff'); font-weight: 400; font-style: normal;
}*/
/*layout*/
html { width: 100% !important; min-height: 100% !important; margin: 0px; padding: 0px; }

body { width: 100% !important; min-height: 100% !important; margin: 0px 0px 0px 0px; padding: 0px 0px 0px 0px; /*本番用*/ }

/*----------------------------------------------------
	楽天パーツ
----------------------------------------------------*/
.rt-header { z-index: 0; }

#htlContents { position: relative; max-width: 2000px; margin-left: auto; margin-right: auto; }
#htlContents.single-column { width: 100% !important; }
#htlContents .hometown-tax__container { margin: 0px auto !important; min-width: 1190px !important; width: 1190px !important; float: none !important; display: block !important; }
#htlContents ._attention__outermost-wrapper_grgv0_1 { max-width: 1190px; min-width: 1190px; margin: 0px auto !important; }
#htlContents #htlBrdCrmbs { margin: 0 auto; max-width: 1190px; width: calc(100% - 30px); }
#htlContents #htlHeader { margin: 0 auto; max-width: 1190px; width: calc(100% - 30px); }

#htlMainContent { width: 100% !important; float: none; margin-left: auto; margin-right: auto; }
#htlMainContent > div:first-child { margin: 0 auto; max-width: 1190px; width: calc(100% - 30px); }

div#RthCustomizeW { clear: both; width: 100%; margin: 0 auto 10px auto; padding: 0; }

#widewrapper { width: 100%; }

/*左カラム*/
#htlSide-A { width: 100%; max-width: 1650px; min-width: 1190px; margin: 0 auto; float: none; display: block; position: relative; z-index: 5; }

#htlRmSrch { margin-top: 0px; position: absolute; left: 20px; z-index: 10; top: 900px; }

#upfrntPlans { position: absolute; left: 20px; top: 1760px; }

#htlSide-A #latest_cstm_review { position: absolute; left: 20px; top: 1700px !important; }

#htlSide-A .module-history-domsearch { position: absolute; left: 20px; text-align: left; display: none; }

/*----------------------------------------------------
	全体
----------------------------------------------------*/
.all { font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; zoom: 100%; width: 100%; font-size: 15px; min-width: 1190px !important; overflow: hidden; background-color: #e8e8e8; }
.all:after { content: ''; display: block; clear: both; }
.all * { box-sizing: border-box; }
.all img { max-width: 100%; }

.ovh { overflow: hidden; }

.ovv { overflow: visible !important; }

.en { font-family: "Agenda-Light", "Agenda-Bold", sans-serif; }

.f_sans { font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; font-weight: 500; }

.lhc::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
.lhc::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }

#contents { background-color: #e8e8e8; }

.wrp { width: 1190px; margin-left: auto; margin-right: auto; }

.lrg_cnt { width: 1780px; margin-left: -295px; }
.lrg_cnt > iframe { width: 100%; }

.wrp.pd { padding-left: 10px; padding-right: 10px; }

.cf:after { content: ''; display: block; clear: both; }

.flex { display: flex; }

/*----------------------------------------------------
	リンク
----------------------------------------------------*/
.all a { cursor: pointer; color: #000000; text-decoration: none; }
.all a:hover img { opacity: 0.6; }
.all a.underline { text-decoration: underline; }
.all a.underline:hover { text-decoration: none; }

.all { font-feature-settings: "palt"; }
.all h2, .all h3, .all h4, .all h5 { color: #000000; font-weight: normal; }
.all p { color: #000000; font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; font-size: 15px; line-height: 2; }

/*.btn_arw { position: relative; line-height: 1; display: inline-flex; align-items: center; padding-right: 45px;
	height: 40px;
	font-size: 20px;
	font-weight: bold;
	position: relative;
	letter-spacing: 2px;
	
	span{
		flex-shrink: 0;
		flex-grow: 0;
		color: #666666;
	}
 span:first-of-type {
		line-height: 0;
		position: relative;
		display: inline-block;
		overflow: hidden;
		width: 13px;
		height: 9px;
		top: 0px;
		left: 9px;
		margin-right: 45px;

		&:after, &:before {
			content: "";
			background: url(../com/btn_arrow01.png) no-repeat center center;
			display: inline-block;
			position: absolute;
			left: 0;
			width: 13px;
			height: 9px;
			transition: transform .5s;
			transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
		}

		&:after {
			transform: translate3d(0, 0, 0);
		}

		&:before {
			transform: translate3d(-12rem, 0, 0);
		} }
 &:after {
		content: "";
		display: inline-block;
		position: absolute;
		border: 1px solid $accent-color;
		top: 4;
		width: 30px;
		height: 30px;
		border-radius: 20px;
		transition: width 350ms;
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1); }
	
	&:hover { span:first-of-type { &:before { transform: translate3d(0, 0, 0); }
 &:after { transform: translate3d(13px, 0, 0); } }
 &:after { width: 100%; } }
}*/
.btn_01 { font-size: 20px; font-weight: bold; text-align: center; position: relative; letter-spacing: 2px; }
.btn_01 a { color: #666666; transition: all 0.5s; }
.btn_01 a:after { content: ''; display: block; background: url(../com/btn_arrow01.png) no-repeat center center; position: absolute; top: -3px; left: 655px; transition: all 0.5s; }
.btn_01 a:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; border: 1px solid #861a54; transition: all 0.5s; }
.btn_01 a span { position: relative; }
.btn_01 a span:before { content: ''; display: block; position: absolute; width: 0; height: 1px; background-color: #666666; left: 0; bottom: -3px; transition: all 0.5s; }
.btn_01 a:hover { color: #666666; }
.btn_01 a:hover:after { content: ''; display: block; background: url(../com/btn_arrow02.png) no-repeat center center; position: absolute; top: -3px; left: 655px; }
.btn_01 a:hover:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; background-color: #861a54; }
.btn_01 a:hover span:before { width: 100%; }

.btn_02 { font-size: 20px; font-weight: bold; text-align: center; position: relative; letter-spacing: 2px; }
.btn_02 a { color: #666666; transition: all 0.5s; }
.btn_02 a:after { content: ''; display: block; background: url(../com/btn_arrow01.png) no-repeat center center; position: absolute; top: -3px; left: 700px; transition: all 0.5s; }
.btn_02 a:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; border: 1px solid #861a54; transition: all 0.5s; }
.btn_02 a span { position: relative; }
.btn_02 a span:before { content: ''; display: block; position: absolute; width: 0; height: 1px; background-color: #666666; left: 0; bottom: -3px; transition: all 0.5s; }
.btn_02 a:hover { color: #666666; }
.btn_02 a:hover:after { content: ''; display: block; background: url(../com/btn_arrow02.png) no-repeat center center; position: absolute; top: -3px; left: 700px; }
.btn_02 a:hover:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; background-color: #861a54; }
.btn_02 a:hover span:before { width: 100%; }

.btn_03 { font-size: 20px; font-weight: bold; text-align: center; position: relative; letter-spacing: 2px; }
.btn_03 a { color: #666666; transition: all 0.5s; }
.btn_03 a:after { content: ''; display: block; background: url(../com/btn_arrow01.png) no-repeat center center; position: absolute; top: -3px; left: 270px; transition: all 0.5s; }
.btn_03 a:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; border: 1px solid #861a54; transition: all 0.5s; }
.btn_03 a span { position: relative; }
.btn_03 a span:before { content: ''; display: block; position: absolute; width: 0; height: 1px; background-color: #666666; left: 0; bottom: -3px; transition: all 0.5s; }
.btn_03 a:hover { color: #666666; }
.btn_03 a:hover:after { content: ''; display: block; background: url(../com/btn_arrow02.png) no-repeat center center; position: absolute; top: -3px; left: 270px; }
.btn_03 a:hover:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; background-color: #861a54; }
.btn_03 a:hover span:before { width: 100%; }

.btn_r { font-size: 20px; font-weight: bold; text-align: right; position: relative; letter-spacing: 2px; }
.btn_r a { color: #666666; transition: all 0.5s; }
.btn_r a:after { content: ''; display: block; background: url(../com/btn_arrow01.png) no-repeat center center; position: absolute; top: -3px; right: 0; transition: all 0.5s; }
.btn_r a:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; border: 1px solid #861a54; transition: all 0.5s; }
.btn_r a span { position: relative; margin-right: 46px; }
.btn_r a span:before { content: ''; display: block; position: absolute; width: 0; height: 1px; background-color: #666666; left: 0; bottom: -3px; transition: all 0.5s; }
.btn_r a:hover { color: #666666; }
.btn_r a:hover:after { content: ''; display: block; background: url(../com/btn_arrow02.png) no-repeat center center; position: absolute; top: -3px; right: 0; }
.btn_r a:hover:after { content: ''; display: block; width: 26px; height: 26px; border-radius: 15px; background-color: #861a54; }
.btn_r a:hover span:before { width: 100%; }

.p_link { max-width: 950px; margin-left: auto; margin-right: auto; display: flex; justify-content: center; flex-wrap: wrap; align-items: center; }
.p_link li { height: 40px; width: 207px; flex-shrink: 1; flex-grow: 0; margin-left: 40px; }
.p_link li:first-child { margin-left: 0; }
.p_link li a { display: flex; justify-content: center; align-items: center; text-align: center; height: 100%; width: 100%; padding-left: 10px; padding-right: 10px; color: #000000 !important; border: 1px solid #d3d2d2; border-radius: 20px 20px 20px 20px; color: #666666 !important; }
.p_link li a:after { content: ''; display: block; width: 9px; height: 13px; background: url("../com/p_link_arrow.gif") no-repeat center center/contain; transition: transform .5s; margin-left: 15px; }
.p_link li a:hover:after { transform: translateY(5px); }

.i_link { display: flex; flex-wrap: wrap; justify-content: center; width: 1190px; box-sizing: content-box; margin-left: auto; margin-right: auto; margin-top: -35px; }
.i_link li { height: auto; width: 282px; border-right: none; margin-left: 20px; margin-top: 35px; }
.i_link li:nth-child(4n+1) { margin-left: 0; }
.i_link li:nth-of-type(-n+4) { margin-top: 0; }
.i_link li a { display: flex; flex-direction: column; padding-left: 0; padding-right: 0; font-size: 15px; line-height: 2; color: #000000; font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; }
.i_link li a:after { display: none; }
.i_link li a > span { position: relative; width: 100%; text-align: left; padding-right: 10px; }
.i_link li a > span:after { content: ''; display: block; width: 7px; height: 7px; border-right: 1px solid #000000; border-bottom: 1px solid #000000; transform: rotate(45deg); margin-left: auto; margin-right: auto; transition: transform .5s; position: absolute; right: 0; top: 50%; margin-top: -5px; }
.i_link li a > span .name:after { content: '￨'; display: inline-block; color: #861a54; margin-left: .5em; margin-right: .5em; }
.i_link li a > span .type { color: #a3a2a2; }

.lb { position: relative; padding-left: 20px; }
.lb:before { content: ''; display: block; background: #000000; position: absolute; top: calc((2 - 1) * .5em); left: 0; width: 4px; height: calc(100% - ((2 - 1) * 1em)); }
.lb.bw1 { position: relative; padding-left: 25px; }
.lb.bw1:before { content: ''; display: block; background: #000000; position: absolute; top: calc((2 - 1) * .5em); left: 0; width: 1px; height: calc(100% - ((2 - 1) * 1em)); }

/*----------------------------------------------------
	画像
----------------------------------------------------*/
img { border: 0; margin: 0px 0px 0px 0px; padding: 0px 0px 0px 0px; vertical-align: bottom; /* [disabled]margin: 0px 0px 0px 0px; */ }

/*----------------------------------------------------
	メインコンテンツ
----------------------------------------------------*/
#main:after { content: "."; display: block; clear: both; height: 0; max-height: 0; visibility: hidden; }

.cont01 { padding-top: 90px; padding-bottom: 90px; }
header.large + .cont01 { padding-top: 0; }

.cont02 { padding-top: 50px; padding-bottom: 50px; }
.column + .cont02 { padding-top: 100px; }
header.large + .cont02 { padding-top: 0; }

/*----------------------------------------------------
	タブ
----------------------------------------------------*/
/*タブ切り替え全体のスタイル*/
.tabs { /*background-color: #fff;*/ width: 1190px; margin-left: auto; margin-right: auto; /*タブのスタイル*/ /*ラジオボタンを全て消す*/ /*タブ切り替えの中身のスタイル*/ }
.tabs .tab_item { width: calc(100%/3); height: 45px; border-bottom: 1px solid #861a54; line-height: 50px; font-size: 20px; text-align: center; color: #9e9e9e; display: block; float: left; text-align: center; transition: all 0.5s ease; }
.tabs .tab_item:hover { opacity: 0.5; }
.tabs input[name="tab_item"] { display: none; }
.tabs .tab_content { display: none; clear: both; overflow: hidden; padding-top: 20px; }
.tabs .tab_content h3 { text-align: center; font-size: 24px; margin-top: 20px; margin-bottom: 20px; }
.tabs .tab_content img { border: 10px solid #fff; }
.tabs .tab_content p { width: 980px; margin-left: auto; margin-right: auto; font-size: 20px; font-weight: 300; line-height: 1.5; margin-top: 20px; }

/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content, #programming:checked ~ #programming_content, #design:checked ~ #design_content { display: block; }

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item { border-top: 1px solid #861a54; border-left: 1px solid #861a54; border-right: 1px solid #861a54; color: #000000; }

/*----------------------------------------------------
	メインビジュアル
----------------------------------------------------*/
#mv { width: 1190px; margin-left: auto; margin-right: auto; position: relative; }
#mv h2 { width: 100%; color: #FFF; text-shadow: 0 0 10px #000; text-align: center; position: absolute; top: 50%; left: 0; transform: translateY(-50%); font-size: 30px; }
#mv h2 span { font-size: 15px; margin-top: 10px; display: block; }
#mv .mv_img { width: 2000px; margin-left: -405px; }

/*----------------------------------------------------
	#header
----------------------------------------------------*/
#header { margin-top: 40px; margin-bottom: 40px; text-align: center; }

/*----------------------------------------------------
	#gnav	ナビ
----------------------------------------------------*/
#gnav { width: 100%; }
#gnav ul { display: flex; justify-content: center; flex-grow: 0; height: 90px; }
#gnav ul li { position: relative; flex: 1; width: 100%; }
#gnav ul li a { display: flex; text-align: center; width: 100%; height: 100%; flex-direction: column; align-items: center; justify-content: center; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; color: #000000; font-size: 25px; }
#gnav ul li a.change { /*テキストの基点とするためrelativeを指定*/ position: relative; /*アニメーションの指定*/ /*transition: all .2s;*/ /*hoverした際の変化*/ /*hoverするとテキストが入れ替わる設定*/ }
#gnav ul li a.change.change:hover { font-size: 18px; }
#gnav ul li a.change span { /*絶対配置でテキストの位置を決める*/ position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); /*アニメーションの指定*/ /*transition: all .5s;*/ /*ブロック要素にしてテキスト折り返しなし*/ display: block; white-space: nowrap; /*差し替わるテキストの設定*/ }
#gnav ul li a.change span:nth-child(2) { opacity: 0; /*透過0に*/ }
#gnav ul li a.change span:after { content: ''; display: block; position: absolute; width: 0; height: 1px; background-color: #000000; left: 0; bottom: -10px; transition: .5s; }
#gnav ul li a.change:hover span:nth-child(1) { opacity: 0; /*透過0に*/ }
#gnav ul li a.change:hover span:nth-child(2) { opacity: 1; /*不透明に*/ }
#gnav ul li a.change:hover span:after { width: 100%; }

/*----------------------------------------------------
	検索
----------------------------------------------------*/
#search iframe { width: 100%; height: 386px; position: relative; z-index: 1; }

/*----------------------------------------------------
	右固定
----------------------------------------------------*/
#right_fixed_2 { position: fixed; right: 60px; bottom: 180px; z-index: 3; display: flex; flex-direction: column; align-items: center; height: 291px; justify-content: space-between; }
#right_fixed_2 a img { transition: .5s; }

#right_fixed { position: fixed; right: 60px; bottom: 180px; z-index: 3; display: flex; flex-direction: column; align-items: center; height: 435px; justify-content: space-between; }
#right_fixed a img { transition: .5s; }

@-webkit-keyframes circle-over { 0% { -webkit-transform: rotate(-90deg); transform: rotate(-90deg); }
  to { -webkit-transform: rotate(90deg); transform: rotate(90deg); stroke-dashoffset: 0; } }
@keyframes circle-over { 0% { -webkit-transform: rotate(-90deg); transform: rotate(-90deg); }
  to { -webkit-transform: rotate(90deg); transform: rotate(90deg); stroke-dashoffset: 0; } }
@-webkit-keyframes circle-out { 0% { -webkit-transform: rotate(90deg); transform: rotate(90deg); stroke-dashoffset: 0; }
  to { -webkit-transform: rotate(450deg); transform: rotate(450deg); stroke-dashoffset: -440px; } }
@keyframes circle-out { 0% { -webkit-transform: rotate(90deg); transform: rotate(90deg); stroke-dashoffset: 0; }
  to { -webkit-transform: rotate(450deg); transform: rotate(450deg); stroke-dashoffset: -440px; } }
/*----------------------------------------------------
	共通ヘッダー
----------------------------------------------------*/
header.large { margin-bottom: 50px; text-align: center; }
header.large h3 { font-size: 50px; line-height: 1; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; font-weight: 400; line-height: 1.2857142857; }
header.large h3::before { display: block; width: 0; height: 0; margin-top: calc((1 - 1.2857142857) * .5em); content: ""; }
header.large h3::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 1.2857142857) * .5em); content: ""; }
header.large .tit01 { margin-top: 25px; margin-bottom: 0; }
header.large.gold h3 { color: #861a54; }
header.large.left { text-align: left; }

header.middle { margin-bottom: 50px; text-align: center; }
header.middle h3 { font-size: 35px; line-height: 1; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; font-weight: 400; }
header.middle.black h3 { color: #000000; }
header.middle p { margin-top: 10px; margin-bottom: -30px; }
header.middle p::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
header.middle p::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }

header.small { margin-bottom: 40px; font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; text-align: center; }
header.small h3 { font-size: 40px; line-height: 1; letter-spacing: -.01em; font-weight: 200; }
header.small h3 span { font-style: italic; font-size: 46px; }

/*----------------------------------------------------
	見出し単品
----------------------------------------------------*/
.tit01 { font-size: 22px; font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif; margin-bottom: 35px; line-height: 2.0454545455; }
.tit01::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2.0454545455) * .5em); content: ""; }
.tit01::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2.0454545455) * .5em); content: ""; }

.tit02 { font-size: 22px; font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; margin-bottom: 20px; line-height: 1.3636363636; }
.tit02::before { display: block; width: 0; height: 0; margin-top: calc((1 - 1.3636363636) * .5em); content: ""; }
.tit02::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 1.3636363636) * .5em); content: ""; }
.boxes > div > .tit02:first-child { padding: 0 20px; }

/*----------------------------------------------------
	カラム配置箇所
----------------------------------------------------*/
.column { width: 100%; max-width: 1025px; margin-left: auto; margin-right: auto; /*padding-left: 230px;
padding-right: 230px;*/ }
@media (max-width: 1650px) { .column { /*padding-right: 0;*/ } }
.column .wrp { width: 100%; padding-left: 20px; padding-right: 20px; /*@media (max-width:1650px){
	max-width: 100%;
	margin-left: 0;
	padding-right: 0;
}*/ }

/*----------------------------------------------------
	導入
----------------------------------------------------*/
.lead_bg { position: relative; background: url("../com/lead_bg.png") no-repeat top center; }

#lead:not(.top) { padding-top: 75px; }
#lead:not(.top) .flex { width: 100%; }
#lead:not(.top) .flex .text { width: 100%; padding: 0 115px 0 0px; position: relative; display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; flex-direction: column; justify-content: center; }
#lead:not(.top) .flex .text .lead_t { font-size: 55px; line-height: 1; margin-bottom: 5px; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; }
#lead:not(.top) .flex .text .lead_t_ja { color: #717171; margin-bottom: 25px; }
#lead:not(.top) .flex .text p { max-width: 350px; }
#lead:not(.top) .flex .text p::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
#lead:not(.top) .flex .text p::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }
#lead:not(.top) .flex .text .bg { position: absolute; z-index: -1; }
#lead:not(.top) .flex figure { width: 550px; /*margin-right: -20px;*/ flex-shrink: 0; flex-grow: 0; }

/*----------------------------------------------------
	左右
----------------------------------------------------*/
.cont_lr { display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; justify-content: space-between; align-items: center; }
.cont_lr.img_r .text { order: 1; }
.cont_lr.img_r figure, .cont_lr.img_r iframe { order: 2; }

.text_lr { display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; justify-content: space-between; }
.text_lr > div { flex-grow: 0; flex-shrink: 0; }
.text_lr > p::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
.text_lr > p::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }
.text_lr .btn { align-self: center; margin-left: 35px; margin-right: 0; }
.text_lr .text { flex-basis: 700px; max-width: 700px; margin-left: 10px; }
.text_lr .text p::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
.text_lr .text p::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }
.text_lr .detail { flex-basis: 420px; margin-right: 10px; }

/*----------------------------------------------------
	横並びBOX
----------------------------------------------------*/
.boxes { display: flex; flex-wrap: wrap; margin-left: -30px; margin-top: -50px; }
.boxes + .boxes { margin-top: 50px; }
.boxes > div { padding-left: 30px; margin-top: 50px; }
.boxes > div .text { margin-top: 20px; padding: 0 10px; }
.boxes > div .text h4 { font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif; font-size: 20px; line-height: 1.5; margin-bottom: 20px; }
.boxes > div .text h4::before { display: block; width: 0; height: 0; margin-top: calc((1 - 1.5) * .5em); content: ""; }
.boxes > div .text h4::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 1.5) * .5em); content: ""; }
.boxes > div .text h4:last-child { margin-bottom: 0; }
.boxes > div .text h4.en { font-weight: 500; }
.boxes > div .text p::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
.boxes > div .text p::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }
.boxes > div .text .info { margin-top: 35px; padding-left: .5em; position: relative; }
.boxes > div .text .info:before { content: ''; display: block; width: 1px; height: calc(100% - 1em); position: absolute; top: .5em; left: 0; background-color: #000000; }
.boxes > div .text .info .detail::before { display: block; width: 0; height: 0; margin-top: calc((1 - 2) * .5em); content: ""; }
.boxes > div .text .info .detail::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 2) * .5em); content: ""; }
.boxes.box2 { margin-left: -50px; margin-top: -100px; }
.boxes.box2 > div { padding-left: 50px; margin-top: 100px; width: 50%; }
.boxes.box3 > div { width: calc(100% / 3.001); }
.boxes.box4 > div { width: 25%; }
.boxes.box4 > div .text { padding: 0 0; }

/*----------------------------------------------------
	詳細リスト
----------------------------------------------------*/
.detail { display: flex; flex-wrap: wrap; font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; flex-grow: 1; font-size: 15px; line-height: 2; font-feature-settings: "palt"; }
.detail dt { width: 120px; margin-right: 1em; position: relative; padding-right: 1em; }
.detail dd { width: calc(100% - 120px - 1em); }
.detail.dt90 dt { width: 90px !important; }
.detail.dt90 dd { width: calc(100% - 90px - 1em) !important; }
.detail.dt100 dt { width: 100px !important; }
.detail.dt100 dd { width: calc(100% - 100px - 1em) !important; }
.detail.dt110 dt { width: 110px !important; }
.detail.dt110 dd { width: calc(100% - 110px - 1em) !important; }
.detail.dt130 dt { width: 130px !important; }
.detail.dt130 dd { width: calc(100% - 130px - 1em) !important; }
.detail.dt150 dt { width: 150px !important; }
.detail.dt150 dd { width: calc(100% - 150px - 1em) !important; }
.detail.dt165 dt { width: 165px !important; }
.detail.dt165 dd { width: calc(100% - 165px - 1em) !important; }

/*----------------------------------------------------
	バナー
----------------------------------------------------*/
.bn_set { width: 950px; margin: 80px 0px 0px 0px; }

.bn_set .bn { width: 220px; margin-right: 23px; margin-bottom: 16.5px; float: left; }

/*----------------------------------------------------
	ページトップ
----------------------------------------------------*/
/* pagetop
========================================================= */
#pagetop { position: fixed; right: 112px; bottom: 20px; height: 45px; cursor: pointer; }
#pagetop a { display: block; color: #000000 !important; }
#pagetop span { writing-mode: vertical-rl; -ms-writing-mode: tb-rl; -webkit-writing-mode: vertical-rl; padding-top: 60px; font-size: 11px; width: 20px; line-height: 20px; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; }
#pagetop::before { position: absolute; bottom: 45px; left: 50%; width: 1px; height: 50px; background: #861a54; content: ''; animation: pagetop-line 2s ease-in-out infinite; }

@keyframes pagetop-line { 0% { height: 50px; bottom: 45px; }
  100% { height: 0; bottom: 100px; } }
/*----------------------------------------------------
	フッター
----------------------------------------------------*/
#footer { padding-top: 130px; }
#footer .info { text-align: center; }
#footer .info h3 { font-size: 50px; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; margin-bottom: 10px; }
#footer .info p { margin-top: 40px; }
#footer .bnr { padding-top: 80px; display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; justify-content: space-between; }
#footer .bnr .bnrs { width: 100%; display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; justify-content: space-between; }
#footer .address { margin-top: 170px; border-top: 1px solid #861a54; border-bottom: 1px solid #861a54; padding-top: 100px; padding-bottom: 100px; text-align: center; }
#footer .address h2 { font-size: 0; margin-bottom: 80px; }
#footer .address h2 img { width: 319px; }
#footer .address p { color: #861a54; font-size: 14px; line-height: 1.7857142857; }
#footer .address p::before { display: block; width: 0; height: 0; margin-top: calc((1 - 1.7857142857) * .5em); content: ""; }
#footer .address p::after { display: block; width: 0; height: 0; margin-bottom: calc((1 - 1.7857142857) * .5em); content: ""; }
#footer .address p.tel { margin-top: 30px; font-size: 16px; }
#footer .address p.tel a { display: inline-block; color: #861a54 !important; font-size: 22px; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; margin-left: 1em; line-height: 1; }
#footer .address .bnr_cor { margin-top: 45px; }
#footer .copy { padding: 80px 0; font-size: 13px; text-align: center; line-height: 1; color: #861a54; font-family: "Agenda-Light", "Agenda-Bold", sans-serif; }

/*----------------------------------------------------
	ページトップ
----------------------------------------------------*/
.spt { width: 930px; text-align: right; margin: 15px 20px 20px 0px; }

.sptl { width: 100px; float: right; margin: 15px 20px 20px 0px; }

/*----------------------------------------------------
	共通
----------------------------------------------------*/
/*背景*/
.bg01 { background: #861a54; }

.bg02 { background: #000000; }

.bg03 { background: #FFF; }

/* リスト */
ul.dots li { position: relative; padding-left: 1em; line-height: 2; }
ul.dots li:before { content: '\0025aa'; display: block; position: absolute; top: 0; left: 0; }

ul.square li { position: relative; padding-left: 1em; line-height: 2; }
ul.square li:before { content: '■'; display: block; position: absolute; top: 0; left: 0; }

/*----------------------------------------------------
	共通　table　テーブル設定
----------------------------------------------------*/
.table { font-size: 15px; line-height: 2; }
.table div { display: flex; }
.table div dt, .table div dd { display: flex; justify-content: center; flex-direction: column; }
.table div > dt { padding: 30px 10px; width: 125px; flex-shrink: 0; flex-grow: 0; text-align: center; background-color: #FFF; border-bottom: 1px solid #ebebea; align-items: center; }
.table div > dd { padding: 30px 10px 30px 50px; width: 100%; background-color: #ebebea; border-bottom: 1px solid #FFF; }
.table div > dd.has-table { padding: 0; }
.table div > dd .table_inner div { border-bottom: 1px solid #f4f4f4; }
.table div > dd .table_inner div:last-child { border-bottom: 0; }
.table div > dd .table_inner div > dd { border-bottom: 0; }
.table div > dd .table_inner dt { background: transparent; text-align: left; }
.table div:last-of-type > dt, .table div:last-of-type > dd:last-of-type { border-bottom: none; }

.table_cont { border: 1px solid #e8e8e8; padding-left: 50px; padding-right: 50px; }
.table_cont .tr { display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; align-items: center; border-bottom: 1px solid rgba(232, 232, 232, 0.3); padding-top: 50px; padding-bottom: 50px; }
.table_cont .tr h4 { font-weight: bold; flex-basis: 240px; max-width: 240px; font-family: "Noto Sans", "Noto Sans JP", "Open Sans", sans-serif; }
.table_cont .tr p { flex-basis: calc(100% - 240px); max-width: calc(100% - 240px); }

/*----------------------------------------------------
	汎用
----------------------------------------------------*/
/* 余白 */
.mar3 { margin: 3px; }

.mar5 { margin: 5px; }

.mar7 { margin: 7px; }

.mar10 { margin: 10px; }

.mt4 { margin-top: 4px; }

.mt5 { margin-top: 5px; }

.mt10 { margin-top: 10px; }

.mt15 { margin-top: 15px; }

.mt20 { margin-top: 20px; }

.mt25 { margin-top: 25px; }

.mt30 { margin-top: 30px; }

.mt35 { margin-top: 35px; }

.mt40 { margin-top: 40px; }

.mt45 { margin-top: 45px; }

.mt50 { margin-top: 50px; }

.mt60 { margin-top: 60px; }

.mt70 { margin-top: 70px; }

.mt80 { margin-top: 80px; }

.mt90 { margin-top: 90px; }

.mt100 { margin-top: 100px; }

.mt120 { margin-top: 120px; }

.mt150 { margin-top: 150px; }

.mb0 { margin-bottom: 0px !important; }

.mb5 { margin-bottom: 5px; }

.mb10 { margin-bottom: 10px; }

.mb15 { margin-bottom: 15px; }

.mb20 { margin-bottom: 20px; }

.mb30 { margin-bottom: 30px; }

.mb40 { margin-bottom: 40px; }

.mb50 { margin-bottom: 50px; }

.mb70 { margin-bottom: 70px; }

.ml1 { margin-left: 1px; }

.ml2 { margin-left: 2px; }

.ml5 { margin-left: 5px; }

.ml8 { margin-left: 8px; }

.ml10 { margin-left: 10px; }

.ml12 { margin-left: 12px; }

.ml15 { margin-left: 15px; }

.ml20 { margin-left: 20px; }

.ml22 { margin-left: 22px; }

.ml25 { margin-left: 25px; }

.ml30 { margin-left: 30px; }

.ml35 { margin-left: 35px; }

.ml40 { margin-left: 40px; }

.ml45 { margin-left: 45px; }

.ml50 { margin-left: 50px; }

.ml53 { margin-left: 53px; }

.ml60 { margin-left: 60px; }

.ml65 { margin-left: 65px; }

.ml70 { margin-left: 70px; }

.ml80 { margin-left: 80px; }

.ml100 { margin-left: 100px; }

.ml120 { margin-left: 120px; }

.ml130 { margin-left: 130px; }

.ml150 { margin-left: 150px; }

.ml170 { margin-left: 170px; }

.ml180 { margin-left: 180px; }

.ml200 { margin-left: 200px; }

.ml250 { margin-left: 250px; }

.ml300 { margin-left: 300px; }

.mr0 { margin-right: 0 !important; }

.mr5 { margin-right: 5px; }

.mr10 { margin-right: 10px; }

.mr12 { margin-right: 12px; }

.mr15 { margin-right: 15px; }

.mr20 { margin-right: 20px; }

.mr25 { margin-right: 25px; }

.mr30 { margin-right: 30px; }

.mr35 { margin-right: 35px; }

.mr40 { margin-right: 40px; }

.pad5 { padding: 5px; }

.pad10 { padding: 10px; }

.pt0 { padding-top: 0 !important; }

.pt10 { padding-top: 10px; }

.pt15 { padding-top: 15px; }

.pt20 { padding-top: 20px; }

.pt25 { padding-top: 25px; }

.pb0 { padding-bottom: 0 !important; }

.pb150 { padding-bottom: 150px; }

.pl10 { padding-left: 10px; }

.pl20 { padding-left: 20px; }

.pr10 { padding-right: 10px; }

.pr20 { padding-right: 20px; }

/* 横幅 */
.w100 { width: 100px; }

.w120 { width: 120px; }

.w130 { width: 130px; }

.w150 { width: 150px; }

.w160 { width: 160px; }

.w170 { width: 170px; }

.w175 { width: 175px; }

.w177 { width: 177px; }

.w190 { width: 190px; }

.w193 { width: 193px; }

.w200 { width: 200px; }

.w202 { width: 202px; }

.w205 { width: 205px; }

.w220 { width: 220px; }

.w230 { width: 230px; }

.w250 { width: 250px; }

.w260 { width: 260px; }

.w270 { width: 270px; }

.w280 { width: 280px; }

.w300 { width: 300px; }

.w305 { width: 305px; }

.w315 { width: 315px; }

.w320 { width: 320px; }

.w350 { width: 350px; }

.w360 { width: 360px; }

.w370 { width: 370px; }

.w380 { width: 380px; }

.w390 { width: 390px; }

.w400 { width: 400px; }

.w410 { width: 410px; }

.w415 { width: 415px; }

.w420 { width: 420px; }

.w430 { width: 430px; }

.w440 { width: 440px; }

.w450 { width: 450px; }

.w480 { width: 480px; }

.w500 { width: 500px; }

.w522 { width: 522px; }

.w545 { width: 545px; }

.w620 { width: 620px; }

.w720 { width: 720px; }

.w735 { width: 735px; }

.w800 { width: 800px; }

.w850 { width: 850px; }

.w860 { width: 860px; }

.w950 { width: 950px; }

/* テキスト */
.chu { font-size: 13px !important; line-height: 1.5384615385 !important; }

.txt_c { text-align: center !important; }

.txt_r { text-align: right !important; }

.ls-1 { letter-spacing: -1px; }

.ls-2 { letter-spacing: -2px; }

.txt_clm2 { columns: 2; }

.color-01 { color: #861a54 !important; }

.t_white h2, .t_white h3, .t_white h4, .t_white h5, .t_white p, .t_white a, .t_white * { color: #FFF; }

/*======================================

	hack - 各種cssハック - for IE7

=======================================*/
/*======================================

	hack - 各種cssハック - for IE6

=======================================*/

/*# sourceMappingURL=common.css.map */
