@charset "utf-8";

html, body                 {width:100%;margin:0 auto;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}
body                       {-webkit-text-size-adjust:100%;}
div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
table, caption, tbody, tfoot, thead, tr, th, td, p,
fieldset, form, label, legend, input,
article, aside, canvas, figure, figcaption,
footer, header, nav, section,
b, u, i                    {margin:0;padding:0;list-style:none;font-style:normal;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}
main                       {display: block;}
a                          {outline:none;}
img                        {border:0 none;vertical-align:top;max-width:100%;height:auto;}
em                         {font-style:normal;font-weight:bold;}
nav ul, nav li             {list-style:none;}
.h a, .f a,
nav a, nav span            {text-decoration:none;}
table                      {border-collapse:collapse;}
p, li                      {line-height: 1.6;}

/* ----------------------------------------------- font */
@font-face                 {font-family:'Yu Gothic M';src:local("Yu Gothic Medium"),local("Yu Gothic");font-weight:500;}
@font-face                 {font-family:'entypo';src:url('fonts/entypo.eot?ac19je');src:url('fonts/entypo.eot?#iefixac19je') format('embedded-opentype'),url('fonts/entypo.woff?ac19je') format('woff'),url('fonts/entypo.ttf?ac19je') format('truetype'),url('fonts/entypo.svg?ac19je#entypo') format('svg');font-weight: normal;font-style: normal;}
html                       {font-size:62.5%;}
body                       {font-size:16px;font-size:1.6rem;font-family: "YuGothic M", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;}
h1, h2,  h3                {font-weight:normal;}
.mincho                    {font-family: "游明朝 Medium", "YuMincho Medium", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Times New Roman", Times, serif;}

/* ============================================================== base */
html, body                 {height:100%;}
body                       {-webkit-text-size-adjust:100%;}
.bg_fixed                  {background-size:cover;background-repeat:no-repeat;background-position:50% 50%;}
.no-br                     {display:none;}
@media (min-width: 751px){
	a[href*="tel:"]            {pointer-events: none;cursor: default;text-decoration: none;}
}
@media screen and (min-width: 1000px){
	.bg_fixed                  {background-attachment:fixed;background-position:50% 100%;}
	_:-ms-fullscreen, :root .bg_fixed {background-attachment:scroll;}
	.no-br                     {display:inline;}
}
a                          {color: #831D64;}
a:visited                  {}
a:hover                    {color: #C32C97;}
a > img                    {vertical-align:top;transition:0.3s;}
a:hover > img              {opacity:0.75;}

/* ============================================================== common */
.sct {
	position: relative;
	font-size: 4vw;
	padding: 2em 1em 1em;
}
@media screen and (min-width: 500px){
	.sct {
		font-size: 20px;
	}
}
@media screen and (min-width: 1000px){
	.sct {
		padding: 3em 1em 4em;
	}
}
.sct_inr {
	position: relative;
	margin: 0 auto;
	max-width: 1000px;
}
.sct_sct {
	position: relative;
	margin: 0 auto 1.5em;
}
.sct_ttl {
	font-size: 175%;
	line-height: 1.4;
	font-weight: bold;
	text-align: center;
	position: relative;
	color: #373737;
	padding-bottom: 0.6em;
	margin-bottom: 1.5em;
}
.sct_ttl:after {
	content: "";
	display: block;
	position: absolute;
	width: 3.6em;
	height: 0.1em;
	bottom: 0;
	left: calc(50% - 1.8em);
	background-color: #831D64;
}
.sct_ttl i {
	display: inline-block;
}
.sct_hdg {
	text-align: center;
	font-size: 120%;
	margin-bottom :1em;
	position: relative;
	font-weight: bold;
	color: #831D64;
}
.sct_hdg span {
	display: inline-block;
	padding: 0.3em 1em;
	position: relative;
	border: 1px solid #831D64;
	z-index: 3;
	background: #fff;
	border-radius: 2em;
}
.sct_hdg:before,
.sct_hdg:after {
	content: "";
	display: block;
	position: absolute;
	top: calc(50% - 0.5px);
	height: 1px;
	width: calc(50% - 3em);
}
.sct_hdg:before {
	left: 0;
	background-image: linear-gradient(to left, #831D64 0, transparent 100%);
}
.sct_hdg:after {
	right: 0;
	background-image: linear-gradient(to right, #831D64 0, transparent 100%);
}
.sct_hdg i {
	font-size: 75%;
	margin-left: 0.5em;
}
.sct_hdg2 {
	font-size: 113%;
}
.sct_lst li {
	padding-left: 1.2em;
	position: relative;
}
.sct_lst li:before {
	content: "\e677";
	font-family: "entypo";
	position: absolute;
	left: 0;
	top: 0;
	color: #831D64;
}
.fadein {
	opacity : 0;
	transform : translate(0, 3vh);
	transition : all 1s;
}
 
.fadein.active{
	opacity : 1;
	transform : translate(0, 0);
}

.side {
	position: fixed;
	z-index: 999;
	right: 0;
	top: 5em;
	padding: 0;
	overflow: hidden;
}
.side a {
	display: block;
	background: #831D64;
	padding: 0.5em;
	text-align: center;
	border-radius: 0.5em 0 0 0.5em;
	border:2px solid #fff;
	border-right: 0;
	overflow: hidden;
	transition: 0.5s;
	transform : translate(3em, 0);
}
.side.show a {
	transform : translate(0, 0);
}
.side a:hover {
	background: #a38;
}
.side a i {
	color: #fff;
	display: block;
	width: 1em;
	line-height: 1.1;
	font-weight: bold;
}
.cv {
	padding: 1em;
	text-align: center;
}

/* ============================================================== kv */
.sct_kv {
	position: relative;
	background-color: rgba(131,129,100,0.1);
	background-image: url("../img/kv_cloud.png");
	background-size: auto 100%;
	opacity: 0;
	transition: 1s;
	overflow: hidden;
	padding: 0;
/*
	text-shadow: 2px 2px 0 #fff, 1px 1px 0 #fff;
*/
}
.sct_kv.show {
	opacity: 1;
}
.kv_logo {
	position: relative;
	background-color: rgba(195,44,151,1);
	padding: 1em;
}
.kv_logo span {
	display: block;
	position: relative;
	width: 10em;
/*
	max-width: 270px;
*/
}
.kv_c:before {
	content: "";
	display: block;
	position: absolute;
	width: 24vw;
	height: 24vw;
	top: 2vw;
	left: 2vw;
	background-repeat: no-repeat;
	background-image: url("../img/kv_arrow.png");
	background-size: 100% auto;
	display: none;
}
.kv_ttl {
	position: relative;
	z-index: 3;
	opacity: 0;
	transform : translate(0, 3vh);
	transition: 1s;
	font-size: 5vw;
	font-weight: bold;
	color: rgba(131,29,100,1);
	padding: 2em 1em;
}
.kv_ttl.show {
	opacity: 1;
	transform : translate(0, 0);
}
.kv_ttl span {
	display: block;
	width: 100%;
	text-shadow: 2px 2px 0 #fff, 2px 0 0 #fff, 0 2px 0 #fff, -2px 0 0 #fff, 0 -2px 0 #fff, -2px -2px 0 #fff; 
}
.kv_ttl i {
	font-size: 120%;
}
.kv_ttl em {
	background-image: linear-gradient(to bottom, transparent 0, transparent 60%, #fff900 60%, #fff900 100%);
}
.kv_fig {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	bottom: 0;
	right: 0;
	background-repeat: no-repeat;
	background-image: url("../img/kv_bg.png");
	background-size: 80%  auto;
	background-position: calc(100% + 30vw) 10vw;
	opacity : 0;
	transform : translate(0, 3vh);
	transition : all 1s;
}
.kv_fig.show {
	opacity : 1;
	transform : translate(0, 0);
}
@media screen and (min-width: 900px){
	.kv_c:before {
		width: 216px;
		height: 216px;
		top: 18px;
		left: 18px;
	}
	.kv_ttl {
		font-size: 40px;
		padding-left: 5vw;
	}
	.kv_fig {
		width: 800px;
		right: auto;
		left: calc(50% - 100px);
		background-position: 100% 0;
	}
}
@media screen and (min-width: 1200px){
	.kv_c:before {
		top: 30px;
		left: -10px;
	}
	.kv_ttl {
		padding-left: 100px;
	}
	.kv_ttl i {
		font-size: 130%;
	}
}

/* ============================================================== gn */
.gn_set {
	position: absolute;
	z-index: 9999;
	top: 0;
	right: 0;
	transition: 0.5s;
	opacity: 0;
}
.gn_set.show {
	opacity: 1;
}

/* ----------------------------------------------- hamburger */
.gn_btn                    {font-size:124%;border:1px solid transparent;width:3em;height:3em;right:0;top:0;position:absolute;line-height:1em;text-align:center;z-index:3;cursor:pointer;}
.gn_btn i                  {position:relative;display:block;text-align:center;vertical-align:bottom;}
.gn_btn:before,
.gn_btn:after,
.gn_btn i:after            {background:#fff;position:absolute;content:"";display:block;width:1.6em;height:2px;left:calc(50% - 0.8em);transition:0.2s;}
.gn_btn i:after            {top:calc(1.5em - 2px);}
.gn_btn:before             {top:calc(0.8em - 2px);}
.gn_btn:after              {top:calc(2.2em - 2px);}
.gn_show .gn_btn           {border-color:transparent;}
.gn_show .gn_btn:before,
.gn_show .gn_btn:after     {top:1.5em;height:2px;background:#fff;}
.gn_show .gn_btn:before    {transform:rotate(45deg);}
.gn_show .gn_btn:after     {transform:rotate(-45deg);}
.gn_show .gn_btn i:after   {display:none;}

/* ----------------------------------------------- navigation */
.gn                        {background:#831D64;height:100%;width:0;top:0;right:-20px;position:fixed;z-index:2;overflow:scroll;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;transition:0.2s;background-repeat:no-repeat;background-position:100% 100%;background-size:100% auto;}
.gn_bg                     {top:0;left:0;position:fixed;z-index:1;background:rgba(255,255,255,0.8);width:100%;height:100%;transition:0.2s;display:none;}
.gn_show                   {overflow-y:hidden;position:fixed;}
.gn_show .c                {-webkit-filter:blur(5px);filter:blur(5px);}
.gn_show .gn               {width:18em;}
.gn_show .gn_bg            {background:rgba(255,255,255,0.8);display:block;}
.gn ul                     {padding:4em 1em 1em;}
.gn ul li                  {margin-bottom:0.5em;padding-bottom:0.5em;padding-right:1em;border-bottom:1px solid rgba(255,255,255,0.5);position:relative;}
.gn ul li:last-child       {border-bottom:0 none;}
.gn ul li a                {color:#fff;position:relative;line-height:1.6em;padding:0.5em;display:block;}
.gn ul .crt a              {font-weight:bold;}

@media screen and (min-width: 900px){
	.gn_set {
		width: 100%;
		height:1px;
		padding: 0;
	}
	.gn_inr {
		position: relative;
		margin: 0 auto;
		max-width: 1200px;
	}
	.gn_show .gn_bg,
	.gn_bg,
	.gn_btn                    {display:none;}
	.gn_show .gn,
	.gn                        {width:auto;height:auto;overflow:visible;overflow-y:visible;position:absolute;right:0;top:0;clear:both;background-color:transparent;}
	.gn ul                     {padding:0.8em 1em 0 0;display:flex;justify-content:flex-end;position:relative;margin:0 auto;}
	.gn ul li                  {margin:0 0 0 1.5em;padding:0 0.5em;margin:0;border-bottom:0 none;position:relative;}
	.gn ul li.hdn              {display: none;}
	.gn ul li a                {font-size:82.5%;color:#831D64;background: #fff;font-weight:bold;text-align:center;display:block;padding:0.5em 1em;white-space:nowrap;border-radius:2em;transition:0.3s;}
	.gn ul li a:hover          {box-shadow: 0 0 1em rgba(255,255,255,1);}
}


/* ============================================================== merit */
.sct_merit {
	transition: 1s;
	opacity: 0;
	transform: translate(0, 10px);
}
.sct_merit.show {
	opacity: 1;
	transform: translate(0, 0);
}
.sct_merit .sct_lst {
	margin-bottom: 2em;
}
.merit_box {
	position: relative;
	margin-bottom: 2em;
}
.merit_ttl {
	margin-bottom: 0.6em;
}
.merit_ttl span {
	display: block;
}
.merit_ttl .nbr {
	margin-bottom:  0.3em;
	position: relative;
}
.merit_ttl .nbr:before {
	content: "";
	display: block;
	position: absolute;
	width: calc(100% - 6.5em);
	height: 1px;
	right: 0;
	top: calc(50% - 1px);
	background: #831D64;
}
.merit_ttl .nbr i {
	display: block;
	color: #831D64;
	font-weight: bold;
	border: 1px solid #831D64;
	border-radius: 2em;
	padding: 0 0.5em;
	width: 6em;
	text-align: center;
}
.merit_ttl .nbr em {
	margin-left: 0.5em;
	font-size: 120%;
}
.merit_ttl .txt {
	font-size: 118%;
	font-weight: bold;
	line-height: 1.4;
}
.merit_ttl .txt i {
	display: inline-block;
	margin-left: 0.5em;
}
.merit_ttl .txt i.mini {
	font-size: 75%;
	color: #831D64;
}
.merit_inr {
	margin-left: 1em;
}
.merit_box .sct_lst li {
	font-size: 110%;
	margin-bottom: 0.4em;
}
@media screen and (min-width: 900px){
	.merit_box {
		margin-bottom: 3em;
	}
	.merit_ttl {
		display: flex;
		align-items: center;
		margin-bottom: 1em;
	}
	.merit_ttl .txt {
		width: 6em;
	}
	.merit_ttl .txt:before {
		display: none;
	}
	.merit_ttl .txt {
		flex: 1;
		margin-left: 1em;
	}
	.merit_ttl .txt i:not(.mini) {
		margin-left: 0;
	}
	.merit_inr {
		margin-left: 2em;
	}
}
.merit_cvt {
	margin-bottom: 2em;
}
.merit_cvt_txt {
	position: relative;
	text-align: center;
	border: 1px solid #831D64;
	border-radius: 1em;
	padding: 2em 1em 0.8em;
	margin-bottom: 1.8em;
}
.merit_cvt_ttl {
	position: absolute;
	width: 100%;
	top: -1.2em;
}
.merit_cvt_ttl span {
	display: inline-block;
	padding: 0 1em;
	background: #fff;
	line-height: 1.3;
}
.merit_cvt_ttl span i {
	display: block;
}
.merit_cvt_cmp li {
	font-size: 67.5%;
	margin: 0 1em 0.5em;
	white-space: nowrap;
	display: inline-block;
}
.merit_cvt_ant {
	position: absolute;
	font-size: 75%;
	width: 100%;
	bottom: -2em;
	left: 0;
	text-align: right;
	padding: 0.3em 1em 0 0;
}
.merit_cvt_bugyo {
	padding: 100px 0 0;
	background-repeat: no-repeat;
	background-image: url("../img/mrt_arrow.png");
	background-size: 90px auto;
	background-position: 50% 0;
}
.merit_cvt_bugyo p span {
	display: block;
	color: #831D64;
	font-weight: bold;
	font-size: 140%;
	text-align: center;
	border-radius: 2em;
	line-height: 1;
	padding: 0.5em 0;
	border: 2px solid #831D64;
	background: #fff;
}
@media screen and (min-width: 900px){
	.merit_cvt {
		display: flex;
		align-items: center;
		margin-bottom: 0.5em;
	}
	.merit_cvt_txt {
		flex: 1;
	}
	.merit_cvt_bugyo {
		width: 30%;
		padding: 200px 0 0;
		background-image: url("../img/kv_arrow.png");
		background-size: 60% auto;
		background-position: 0 0;
		margin-left: 2em;
	}
}

.merit_note {
	font-size: 82.5%;
}
.merit_note li {
	margin-left: 0.5em;
	padding-left: 1.5em;
	position: relative;
}
.merit_note li:before {
	content: "※";
	color: #831D64;
	position: absolute;
	display: block;
	top: 0;
	left: 0;
}

/* ============================================================== intro */
.sct_intro {
}
.sct_intro .sct_lead {
	margin-bottom: 2em;
}
.sct_intro .sct_lead div {
	width: 60%;
	max-width: 360px;
	margin: 0 auto 2em;
}
.sct_intro .sct_lead p {
	font-size: 120%;
	font-weight: bold;
	text-align: center;
}
.sct_intro .sct_lead p span {
	display: inline-block;
}
.sct_intro .sct_lead p span i {
	font-size: 120%;
}
.sct_intro .sct_lead p span em {
	font-size: 140%;
}
.sct_intro .em_1 {
	color: #005BAC;
}
.sct_intro .em_2 {
	color: #C32C97;
}
@media screen and (min-width: 750px){
	.sct_intro .sct_lead {
		display: flex;
		align-items: center;
		margin-bottom: 4em;
	}
	.sct_intro .sct_lead div {
		width: 40%;
		margin-bottom: 0;
	}
	.sct_intro .sct_lead p {
		flex: 1;
		margin-left: 4em;
	}
}
.intro_lst dl {
	margin: 0 auto 2em;
	width: 75%;
	max-width: 320px;
}
.intro_lst dt {
	font-size: 120%;
	width: 8em;
	height: 8em;
	margin: 0 auto 1em;
	border-radius: 50%;
	background: #0BB4CC;
	color: #fff;
	font-weight: bold;
	line-height: 1.4;
	display: flex;
	align-items: center;
	position: relative;
}
.intro_lst dt span {
	padding-top: 3em;
	display: block;
	width: 100%;
	text-align: center;
}
.intro_lst dt span:before {
	content: "";
	display: block;
	position: absolute;
	top: 0.3em;
	left: calc(50% - 1.8em);
	width: 3.6em;
	height: 3.6em;
	background-repeat: no-repeat;
	background-size: cover;
}
.intro_lst dl:nth-of-type(1) dt span:before {
	background-image: url("../img/intro_lst_fig_01.png");
}
.intro_lst dl:nth-of-type(2) dt span:before {
	background-image: url("../img/intro_lst_fig_02.png");
}
.intro_lst dl:nth-of-type(3) dt span:before {
	background-image: url("../img/intro_lst_fig_03.png");
}
.intro_lst dl:nth-of-type(4) dt span:before {
	background-image: url("../img/intro_lst_fig_04.png");
}
.intro_lst dl:nth-of-type(5) dt span:before {
	background-image: url("../img/intro_lst_fig_05.png");
}
.intro_lst dt span i {
	position: relative;
	z-index: 3;
	display: block;
}
@media screen and (min-width: 750px){
	.intro_lst {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.intro_lst dl {
		padding: 0 1em;
	}
}

/* ============================================================== plan */
.sct_plan {
	background: #F9EEF4;
}
.sct_plan p {
	margin-bottom: 0.5em;
}
.sct_plan .sct_hdg {
	margin-top: 2em;
}
.sct_plan .sct_hdg span {
	background: #F9EEF4;
}
.sct_plan table {
	background: #fff;
	width: 100%;
	border :1px solid #831D64;
}
.sct_plan th,
.sct_plan td {
	padding: 1em;
	border :1px solid #831D64;
}
.sct_plan td:last-child {
	text-align: right;
	width: 9em;
	background: #c35Da4;
	color: #fff;
	font-weight: bold;
}


/* ============================================================== lineup */
.sct_lineup {
}
.sct_lineup .sct_sct {
	margin: 0 auto 3em;
}
.sct_lineup .sct_sct p {
	font-size: 87.5%;
	margin-bottom: 0.5em;
}
.sct_lineup table {
	background: #fff;
	width: 100%;
	border :1px solid #831D64;
}
.sct_lineup th,
.sct_lineup td {
	border :1px solid #831D64;
	background: #F9EEF4;
}
.sct_lineup th,
.sct_lineup td {
	font-size: 87.5%;
	padding: 0.5em;
}
.sct_lineup td {
	white-space: nowrap;
}
.sct_lineup thead td {
	text-align: center;
}
.sct_lineup tbody th {
	text-align: left;
	line-height: 1.3;
}
.sct_lineup tbody th i {
	display: inline-block;
	margin-right: 0.3em;
}
.sct_lineup tbody td {
	text-align: right;
	background: #fff;
}
.sct_lineup tbody td i {
	font-size: 82.5%;
	margin-left: 0.3em;
}
.sct_lineup .sct_lst li {
	font-size: 87.5%;
	margin-bottom: 0.7em;
}

/* ============================================================== contact */
.sct_contact {
	overflow:hidden;
	background: rgba(218,190,209,0.2);
}
.sct_contact .sct_inr {
	max-width: 950px;
}

/* ----------------------------------------------- button */
button::-moz-focus-inner   {
	border: 0;
	padding: 0;
	margin-top: -2px;
}
a.btn, a:link.btn, a:visited.btn, .btn {
	font-size: 110%;
	font-weight: bold;
	padding: 0 2.6em;
	line-height: 2.8em;
	border: 0 none;
	border-radius: 2em;
	display: inline-block;
	text-align: center;
	text-decoration: none;
	vertical-align: top;
	cursor: pointer;
	-webkit-appearance: none;
	transition: all 0.2s;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
a.btn_posi, a:link.btn_posi, a:visited.btn_posi, .btn_posi {
	background-color: #831D64;
	color: #fff;
}
a.btn_posi:hover, a:link.btn_posi:hover, a:visited.btn_posi:hover, .btn_posi:hover {
	background-color: #a38;
}
a.btn_nega, a:link.btn_nega, a:visited.btn_nega, .btn_nega {
	background-color: #999;
	color :#fff;
}
a.btn_nega:hover, a:link.btn_nega:hover, a:visited.btn_nega:hover, .btn_nega:hover {
	background-color: #aaa;
}
.btns {
	padding: 1em 0;
	clear: both;
	text-align: center;
}
.frm button {
	outline: 0;
}

/* ------------------------------------- elements */
.frm_message {
	margin-bottom: 1em;
}
.frm.frm_confirm dt {
	font-size: 87.5%;
}
.frm.frm_confirm dd {
	border: 1px dashed #ccc;
	padding: 0.5em;
	font-size: 87.5%;
}

/* ------------------------------------- field */
.frm dl {
	margin-bottom: 0.8em;
}
.frm dt {
	font-weight: bold;
	font-size: 16px;
}
.frm dt label {
	margin-right: 0.5em;
}
.frm dt i {
	font-weight: normal;
	display: inline-block;
	font-size: 75%;
	color: #831D64;
}
.frm dl dl dt {
	font-weight: normal;
}
.frm_check > div {
	margin-bottom: 0.5em;
}

.ipt_short {
	max-width: 230px;
}
.ipt_middle {
	max-width: 360px;
}

.frm input[type=text]:focus,
.frm input[type=password]:focus,
.frm input[type=date]:focus,
.frm input[type=time]:focus,
.frm select:focus,
.frm textarea:focus {
	border:2px solid #831D64;
}
.frm select {
	background-position: calc(100% - 0.5em) 50%;
}
.frm .btn_next:disabled,
.frm .btn_next:disabled:hover {
	background:#ccc;
	cursor:default;
	border:0 none;
	color:#fff;
}

.privacy_check {
	border-top: 1px solid #831D64;
	margin: 2em 0;
	padding-top: 1em;
	font-size: 16px;
}
.privacy_check a {
	display: inline-block;
	color: #831D64;
	text-decoration: none;
	border-bottom: 1px solid #831D64;
}
.privacy_check .frm_check input + i {
	cursor: pointer;
	padding-left:0.8em;
}
.privacy_check .frm_check input[type=checkbox] + i:before {
	width: 1.2em;
	height: 1.2em;
}
.privacy_check .frm_check input[type=checkbox]:checked + i:after {
	border-color: #831D64;
}

@media screen and (min-width: 750px){
	.frm dl {
		display: flex;
	}
	.frm > dl > dt {
		width: 12em;
		padding-top: 0.5em;
	}
	.frm dd {
		flex: 1;
	}
	.privacy_check {
		text-align: center;
	}
}

.modal {
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 0.5em;
	display: none;
}
.modal_bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.5);
}
.modal_inr {
	position: relative;
	background: #f3f3f3;
	z-index: 3;
	margin: 0 auto;
	max-width: 720px;
	padding: 3em 0.5em 0.5em;
	height: calc(100% - 0.5em);
	height: 100%;
}
.modal_inr .rule {
	max-height: calc(100vh - 7em);
	overflow-y: scroll;
	background: #fff;
	padding: 1em;
}
.modal_close {
	position: absolute;
	top: 0;
	right: 0.5em;
}
.modal_close .modal_btn {
	display: inline-block;
	padding: 0.5em;
	font-weight: bold;
	cursor: pointer;
}

.rule h3                   {margin-top:2em;font-weight:bold;font-size:100%;margin-bottom:0.5em;}
.rule p,
.rule ol                   {margin-bottom:1em;font-size:87.5%;}
.rule ol li                {margin-bottom:0.5em;list-style:lower-latin;margin-left:1em;}

/* ============================================================== footer */
.f {
	padding: 2em 0;
}

.f_inr {
	background:#fff;
	text-align: center;
	padding: 1em;
	border-radius: 0.5em;
	margin: 0 auto;
	max-width: 360px;
}
.f .logo {
	margin: 0 auto 1em;
}
.f_mail {
	max-width: 320px;
	margin: 0 auto 0.5em;
}
.f_mail a {
	display: block;
	background: #831D64;
	color: #fff;
	line-height: 3em;
	border-radius:2em;
	transition: 0.3s;
}
.f_mail a:before {
	content: '\e604';
	font-family: 'entypo';
	vertical-align: middle;
	margin-right: 0.5em;
}
.f_mail a:hover {
	opacity: 0.7;
}
.f_tel {
	max-width: 320px;
	margin: 0 auto 0.5em;
}
.f_tel a {
	display: block;
	font-size:170%;
	color: #831D64;
	font-weight: bold;
}
.f_tel a:before {
	content: '\e600';
	font-family: 'entypo';
	vertical-align: middle;
	margin-right:0.5em;
}
.f_comp {
	max-width: 320px;
	margin: 0 auto;
	margin: 0 auto 0.5em;
}
.f_copy {
	font-size: 80%;
	color: #999;
	text-align: center;
}
.ptop                      {font-size:5vw;background:#831D64;color:#fff;width:3em;height:3em;line-height:3em;text-align:center;position:fixed;z-index:99;right:0;bottom:-20px;cursor:pointer;border-radius:0;transition:0.2s;opacity:0;display:block;}
.ptop:before               {font-size:150%;content:"\e6d7";font-family:"entypo";display:block;}
.ptop i                    {display:none;}
.scrl_bgn .ptop            {opacity:1;bottom:0;}
@media screen and (min-width: 400px){
	.ptop                      {font-size:20px;}
}

