@charset "UTF-8";
/**
*
* @authors Your Name (you@example.org)
* @date    2016-12-10 16:57:22
* @version $Id$
*/

/*
purple #B1658B;
red #CA2420;
blue #326295;
orange #F89829;
*/

*, *:before, *:after {
  box-sizing: Border-box;
}

.lihsi-desktop{
	display: block !important;
}

.lihsi-desktop-no-pad{
	display: block !important;
}

.lihsi-pad-mobile{
	display: none !important;
}

.lihsi-mobile{
	display: none !important;
}

.lihsi-mobile-extra{
	display: none !important;
}

.nopadding{
	padding: 0 !important;
}

.txt-left{
	text-align: left;
}

.txt-center{
	text-align: center;
}

.txt-color-pinky{
	color: #ff406e;
}

input:focus,select:focus,textarea:focus {outline:0;}

html,body{
	letter-spacing: 3px;
	font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "微軟正黑體", "新細明體", "蘋果儷黑體", Verdana, sans-serif;
}

html{
  box-sizing: border-box;
  
}

body{
	background: #ffffff;
	/*overflow-x: hidden;*/
}

body.noscroll{
	overflow-y: hidden!important;
}

body,input,button,select,textarea{
	font-family: "微軟正黑體", "微软雅黑","Helvetica Neue", Helvetica, Arial, sans-serif;
}

.wrap{
	position: relative;
	width: 100%;
	height: auto;

	background: #fcfaf1;
	overflow-x: hidden;
}

img{
	display: block;
}

img.img-full{
	width: 100%;
}

.container-full{
	display: block;
	width: 100%;
	padding: 0 15px;
	margin: 0 auto;
}

.container-header{
	display: block;
	max-width: calc(1890px + (15px * 2));
	width: 100%;
	padding: 0px 15px;

	margin: 0 auto;
}

.container-base{
	display: block;
	max-width: calc(1130px + (15px * 2));
	width: 100%;
	padding: 0px 15px;

	margin: 0 auto;
}
	
.container-sub{
	display: block;
	max-width: calc(945px + (15px * 2));
	width: 100%;
	padding: 0 15px;

	margin: 0 auto;
}

.container-small{
	display: block;
	max-width: 860px;
	width: 100%;
	padding: 0 15px;

	margin: 0 auto;
}

.cursor-pointer{
	cursor: pointer;
}


/***** loading start *****/

.loading-mask{
	display: flex;
	position: fixed;
	top: 0;
	left: 0;

	justify-content: center;
	align-items: center;

	width: 100%;
	height: 100%;
	background: #f7f6f0;

	z-index: 999;
}

.loading-mask.complete{
	display: none;
}

@keyframes ldio-5cksq6krpib {
  0% { transform: translate(-50%,-50%) rotate(0deg); }
  100% { transform: translate(-50%,-50%) rotate(360deg); }
}
.ldio-5cksq6krpib div {
  position: absolute;
  width: 120px;
  height: 120px;
  border: 10px solid #e15b64;
  border-top-color: transparent;
  border-radius: 50%;
}
.ldio-5cksq6krpib div {
  animation: ldio-5cksq6krpib 1s linear infinite;
  top: 100px;
  left: 100px
}
.loadingio-spinner-rolling-2an3ew4770t {
  width: 200px;
  height: 200px;
  display: inline-block;
  overflow: hidden;
  /*background: #ffffff;*/
}
.ldio-5cksq6krpib {
  width: 100%;
  height: 100%;
  position: relative;
  transform: translateZ(0) scale(1);
  backface-visibility: hidden;
  transform-origin: 0 0; /* see note above */
}
.ldio-5cksq6krpib div { box-sizing: content-box; }

/***** loading end *****/

header{
	position: relative;
	display: flex;
	width: 100%;
  
  padding: 15px;

	background: #fcfaf1;
	box-sizing: border-box;
	-moz-box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.4);
	-webkit-box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.4);
	box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.4);
	z-index: 1;
}

header .collection{
	display: flex;
	align-items: center;
}

header .collection .logo{
	display: block;
	width: 191px;
}

header .collection .sub-logo{
	display: flex;
	width: calc(140px + 30px);
	align-items: center;
	padding-left: 30px;
}

header .collection .logo a , header .collection .sub-logo img{
	display: block;
	width: 100%;
}

header .collection .logo img, header .collection .sub-logo img{
	display: block;
	width: 100%;
}

header .collection nav{
	flex: 1;
	padding: 0 0 0 0;
}

header .collection nav ul{
	display: flex;
	height: 100%;
	justify-content: center;
	padding: 0;
	margin: 0;
	list-style: none;
}

header .collection nav ul li{
	position: relative;
	display: flex;
	position: relative;
	align-items: stretch;
}


header .collection nav ul li:before{
	content: "";
	position: absolute;
	width: 2px;
	height: 20px;

	background: #c2c2c2;

	top: 50%;
	left: 0;

	transform: translateY(-50%);
}

header .collection nav ul li:first-child::before{
	display: none;
}


header .collection nav ul li a{
	position: relative;
	display: flex;
	align-items: flex-end;

	padding: 15px 20px 15px 80px;

	font-size: 18px;
	font-weight: bold;
	text-decoration: none;

	color: #2c2e2e;
	
	letter-spacing: 0;
}

header .collection nav ul li a:hover{
	color: #d51d47;
}


header .collection nav ul li a.icon{
	background-repeat: no-repeat !important;
	background-position: center left 20px !important;
}

header .collection nav ul li a.icon.spec{
	position: relative;
	display: flex;
	align-items: center;
	background: #d0214a;
	border-radius: 15px;
	padding: 10px 15px 10px calc(30px + 15px + 10px);
	margin: 0 20px 0 2vw;
	color: #FFF;
	background-position: 10px center !important;
}

header .collection nav ul li a.icon.icon-1{
	padding-left: 60px;
	margin-right: 1vw;
	background-image: url("../images/nav_icon_1.png");
	background-position: center left !important;
	background-size: 51px 50px !important;
}

header .collection nav ul li a.icon.icon-2{
	padding-left: 75px;
	margin-left: 1vw;
	margin-right: 1px;
	background-image: url("../images/nav_icon_2.png");
	background-size: 42px 50px !important;
}

header .collection nav ul li a.icon.icon-3{
	padding-left: 75px;
	margin-left: 1vw;
	margin-right: 1vw;
	background-image: url("../images/nav_icon_3.png");
	background-size: 44px 50px !important;
}

header .collection nav ul li a.icon.icon-4{
	background-image: url("../images/nav_icon_4.png");
	background-size: 44px 50px !important;
}

header .collection nav ul li a.icon.icon-5{

	background-image: url("../images/nav_icon_5.png");
	background-size: 36px 36px !important;
}

header .collection nav ul li .hot{
	position: absolute;
	display: inline-block;
	width: 46px;
	right: 0px;
	top: -15px;
}

header .collection nav ul li .hot img{
	width: 100%;
}

header .collection .contact{
	display: flex;
	align-items: center;
	width: 295px;
}


header .collection .contact a{
	display: block;
}

header .collection .contact a img{
	width: 100%;
}

header .collection .product{
	flex: 1;
	text-align: right;
}

header .collection .product a{
	display: inline-block;
	padding-top: 36px;
	letter-spacing: 0;

	color: #FFF;
	text-decoration: none;

	background: url("../images/nav_m_icon_1.png");
	background-size: calc(32px * 1) calc(32px * 1) !important; /*53*61*/
	background-repeat: no-repeat !important;
	background-position: top center !important;
}

header .collection .product a:hover{
	color: #FFF;
	text-decoration: none;
}


header .collection .product a.pd{

	padding-left: 10px;
	padding-right: 10px;
	background: url("../images/nav_m_icon_1.png");
}

header .collection .product a.kn{

	padding-left: 10px;
	background: url("../images/nav_m_icon_2.png");
}

header .collection .product a:first-child{
	border-right: 1px solid #a81336;
}

header .collection .product a:last-child{
}

.kv{
	position: relative;
	display: block;
	width: 100%;
	margin: 0 auto;

	background: url("../images/kv_bg.png");
	background-position: center center;
	background-repeat: repeat;
}

.kv .theater{
	position: relative;
	width: 100%;
	min-height: 700px;
}

.kv .theater .pd-logo{
	display: none;
	position: absolute;
}

.kv .theater .ill-tree{
	position: absolute;
	width: 727px;
	top: -15px;
	left: 0;
	z-index: 2;
}

.kv .theater .ill-tree-right{
	position: absolute;
	display: none;
}

.kv .theater .ill-bridge{
	position: absolute;
	width: 398px;
	bottom: 5px;
	right: 0;
	z-index: 2;
}

.kv .theater .ill-oldman{
	position: absolute;
	width: 576px;
	left: calc(50% - 930px);
	bottom: -50px;
	z-index: 3;
}

.kv .theater .ill-slogan{
	position: absolute;
	width: 778px;
	left: calc(50% - 330px);
	top: 50px;
}

.kv .theater .ill-slogan .rsfull{
	width: 100% !important;
	height: auto !important;
}

.kv .theater .ill-subslogan{
	position: absolute;
	width: 619px;
	left: calc(50% - 320px);
	top: 170px;
}

.kv .theater .ill-feature-1{
	position: absolute;
	width: 358px;
	left: calc(50% - 320px);
	top: 250px;
	z-index: 2;
}

.kv .theater .ill-feature-1:hover{ opacity: 0.9; }

.kv .theater .ill-feature-2{
	position: absolute;
	width: 358px;
	left: calc(50% - 320px);
	top: 350px;
	z-index: 2;
}

.kv .theater .ill-feature-2:hover{ opacity: 0.9; }

.kv .theater .ill-feature-3{
	position: absolute;
	width: 358px;
	left: calc(50% - 320px);
	top: 450px;
	z-index: 2;
}

.kv .theater .ill-feature-3:hover{ opacity: 0.9; }

.kv .theater .ill-cycle{
	position: absolute;
	display: flex;
	width: 364px;
	justify-content: space-between;
	left: calc(50% - 323px);
	top: 550px;
	z-index: 4;
}

.kv .theater .ill-cycle a{
	width: 24%;
}

.kv .theater .ill-cycle a:hover{
	opacity: 0.9;
}

.kv .theater .ill-cloud{
	position: absolute;
	z-index: 1;
}

.kv .theater .ill-leaf{
	display: block;
	position: absolute;
	z-index: 1;

}

.kv .theater .ill-cloud.c1{ width: 208px; top: 190px;left: calc(50% - 1050px); }
.kv .theater .ill-cloud.c2{ width: 208px; top: 80px;left: calc(50% - 650px); }
.kv .theater .ill-cloud.c3{ width: 208px; top: 70px;left: calc(50% + 450px); }
.kv .theater .ill-cloud.c4{ width: 130px; top: 30px;left: calc(50% + 850px); }

.kv .theater .ill-feature{
	display: none;
	position: absolute;
}

.kv .theater p.extra{
	position: absolute;

	bottom: 15px;
	left: calc(50% - 342px);

	font-size: 13px;
	letter-spacing: 0;
	color: #FFF;
	z-index: 2;
}

.kv .theater .clapperboard{
	position: absolute;
	width: 452px;
	bottom: 0;
	left: calc(50% + 75px);
	z-index: 2;
}

.kv .theater .clapperboard .pannel{
	position: relative;
	width: 100%;
}

.kv .theater .clapperboard .group{
	position: absolute;
	top: 0;
	left: 0;
	width: 346px;
	padding: 70px 35px 0 35px;
}

.kv .theater .clapperboard .group .title{
	width: 224px;
	margin: 0 auto;
}

.kv .theater .clapperboard .group hr{
	margin: 6px 10px 15px 10px;
	padding: 0;

	height: 2px;
	background: #d0214a;

	border: 0;
}


.kv .theater .clapperboard .group .team{
	display: flex;
	padding-bottom: 15px;
}

.kv .theater .clapperboard .group .team span.team-title{
	white-space: nowrap;
	width: 58px;
	font-size: 16px;
	font-weight: 500;
	color: #FFF;
	letter-spacing: 0;
}

.kv .theater .clapperboard .group .team span.team-title.short{
	width: 40px;
}


.kv .theater .clapperboard .group .team .forname{
	display: flex;
	width: 160px;
	align-items: center;
}

.kv .theater .clapperboard .group .team .forname input[type='text']{
	width: 100%;
	height: 30px;
	flex: 1;
	padding: 3px;
	font-size: 14px;
	border-radius: 5px;
	border: 1px solid #9f9d9d;
	background: #FFF;
}

.kv .theater .clapperboard .group .team .forage{
	flex: 1;
	display: flex;
	align-items: center;
	padding-left: 12px;
}

.kv .theater .clapperboard .group .team .forage select{
	display: inline-block;
	position: relative;
	flex: 1;
	height: 30px;
	padding: 3px 3px 3px 6px;
	
	border: 1px solid #9f9d9d;
	border-radius: 0;

	font-size: 16px;

	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;

	flex-grow: 1;

	background: #FFF;
	background-image: url("../images/calculate_select_icon.png");
	background-position: right 5% center;
	background-size: 8px 6px;
	background-repeat: no-repeat;
	background-position: center right 10px;

	border-radius: 5px;
}

.kv .theater .clapperboard .group .team .forsex{
	display: flex;
	align-items: center;
}

.kv .theater .clapperboard .group .team .forsex label{
	display: inline-flex;
	font-size: 16px;
	font-weight: bold;
	padding-right: 5px;
	align-items: center;
	color: #FFF;
}

.kv .theater .clapperboard .group .team .forsex label input[type='radio']{
	position: relative;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	width: 20px;
	height: 20px;
	margin-right: 6px;
	border-radius: 50%;
	border: 1px solid #9f9d9d;
	cursor: pointer;
	background: #FFF;
}

.kv .theater .clapperboard .group .team .forsex label input[type='radio']:checked::after{
	content: "";
	display: inline-block;
	position: absolute;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	top: 50%;
	left: 50%;transform: translate(-50%, -50%);
	background: #d0214a;
	border: 1px solid #000;
}

.kv .theater .clapperboard .group .team .formobile{
	display: flex;
	align-items: center;
	width: 100%;
}

.kv .theater .clapperboard .group .team .formobile input[type='text']{
	width: 1px;
	height: 30px;
	padding: 3px;
	flex: 1;
	font-size: 14px;

	border-radius: 5px;
	border: 1px solid #9f9d9d;
	background: #fff;
}

.kv .theater .clapperboard .group .team .fortel{
	display: flex;
	align-items: center;
	width: 100%;
}

.kv .theater .clapperboard .group .team .fortel input[type='text']{
	flex: 1;
	width: 100%;
	height: 30px;
	padding: 3px;
	font-size: 14px;

	border-radius: 5px;
	border: 1px solid #9f9d9d;
	background: #fff;
}

.kv .theater .clapperboard .group .team .fortel input[type='text'].zip{
	flex: none;
	width: 40px;
}

.kv .theater .clapperboard .group .team .fortel span.dash{
	display: inline-block;
	padding: 0 5px;
	color: #FFF;
}

.kv .theater .clapperboard .group .team .formail{
	display: flex;
	align-items: center;
	width: 100%;
}

.kv .theater .clapperboard .group .team .formail input[type='text']{
	width: 1px;
	height: 30px;
	padding: 3px;
	flex: 1;
	font-size: 14px;

	border-radius: 5px;
	border: 1px solid #9f9d9d;
	background: #fff;
}

.kv .theater .clapperboard .group label.agreement{
	display: flex;
	position: relative;
	line-height: 1.5;
	cursor: pointer;
	font-size: 13px;
	font-weight: bold;

	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.kv .theater .clapperboard .group label.agreement input[type='checkbox']{
	position: relative;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	width: 20px;
	height: 20px;

	border: 1px solid #808080;
	cursor: pointer;

	background: #FFF;
}

.kv .theater .clapperboard .group label.agreement input[type='checkbox']:checked::after{
	content: "";
	display: inline-block;
	position: absolute;
	
	width: 16px;
	height: 16px;
	top: 50%;
	left: 50%;

	border: 1px solid #000;

	transform: translate(-50%, -50%);

	background: #d0214a;
}

.kv .theater .clapperboard .group label.agreement .memo{
	flex: 1;
	padding-left: 10px;
	letter-spacing: 0;
	color: #FFF;
}

.kv .theater .clapperboard .group label.agreement .memo a{
	color: #FFF;
	text-decoration: underline;
}

.kv .theater .clapperboard .group .sendbtn{
	text-align: center;
}

.kv .theater .clapperboard .group .sendbtn a{
	display: inline-block;

	width: 180px;
	height: 50px;

	margin: 20px auto 0 auto;

	font-size: 22px;
	text-align: center;

	font-weight: bold;
	letter-spacing: 0;
	
	text-decoration: none;

	color: #FFF;

	background: url(../images/kv_form_btn.png) !important;
	background-size: cover !important;
	background-repeat: no-repeat !important;

	text-indent: -999999px;
}

.kv .summary{
	padding: 30px 0;
	background: #fdfaf2;
}

.kv .summary .tel{
	display: none;
}

.kv .summary .collection{
	display: flex;
	align-items: center;
	justify-content: center;
}

.kv .summary .day{
	position: relative;
	width: 224px;
}

.kv .summary .day a.calculate_btn{
	position: absolute;
	width: 175px;
	left: calc(50% - 86px);
	bottom: 10px;
}

.kv .summary .furture{
	width: 421px;
	margin-left: 30px;
}

.kv .summary .tel{
	display: none;
	width: 80vw;
	margin: 0 auto;
}

.kv .leaf-bg{
	position: absolute;
	top: 0px;
	width: 100%;
	left: 0;
	height: 100%;
	z-index: 0;
	pointer-events: none;
}

/*****************/

.mainpoint{
	position: relative;
	z-index: 1;

	border-top: 20px solid #ff6671;

}

.mainpoint .unit-title{
	display: block;
	width: 544px;
	margin: 0 auto;
	padding-top: 60px;
}

.mainpoint p.unit-title-memo{
	color: #363634;
	font-size: 16px;
	text-align: center;
	letter-spacing: 0;
}

.mainpoint .scenario{
	padding: 0 0px;
}

.mainpoint .scenario .item{
	position: relative;
	margin-bottom: 30px;
}

.mainpoint .scenario .item .role{
	position: relative;
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
}

.mainpoint .scenario .item .cover{
	width: 98px;
	margin-left: 30px;
}

.mainpoint .scenario .item .title{
	width: 700px;
	margin-left: 20px;
}

.mainpoint .scenario .item.spec{
	margin-top: -30px;
}

.mainpoint .scenario .item .role{
	margin-bottom: -30px;
}





.mainpoint .scenario .item .detail{
	display: block;
	padding: 40px 46px 15px 46px;
	border-radius: 30px;
	border: 2px solid #7e6840;

	border-top: 5px solid #ff6974;
	border-bottom: 10px solid #ff6974;
	border-left: 5px solid #ff6974;
	border-right: 5px solid #ff6974;

	background: #FFF;
}

.mainpoint .scenario .item .detail .research{
	display: block;
	padding-top: 10px;
	padding-bottom: 15px;

	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0;
	line-height: 1.5;
	color: #4a3f40;
}

.mainpoint .scenario .item .detail .research span.highlight{
	color: #d51d47;
}

.mainpoint .scenario .item .detail .research span.extra{
	font-size: 11px;
}

.mainpoint .scenario .item .detail{
	display: block;
}




.mainpoint .scenario .item .detail .commentary{
	display: flex;
	align-items: center;
}

.mainpoint .scenario .item .detail .commentary .memo{
	position: relative;
	flex: 1;
	padding: 10px 0 10px 50px;

	font-size: 17px;
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: 0;
	color: #3f8ab1;
}

.mainpoint .scenario .item .detail .commentary .memo::before{
	content: "";
	position: absolute;
	width: 32px;
	height: 32px;
	top: 5px;
	left: 6px;
	background: url("../images/mainpoint_scenario_check.png");
	background-size: cover !important;
	background-repeat: no-repeat !important;
	background-position: top center !important;
}

.mainpoint .scenario .item .detail .commentary .memo span.extra{
	font-size: 11px;
}

.mainpoint .scenario .item .detail hr{

	width: 100%;
	height: 2px;

	padding: 0;
	margin: 15px 0;

	border-top: 3px dashed #ff6666;
	border-right: 0;
	border-bottom: 0;
	border-left: 0;
}

.mainpoint .scenario .item .detail .nervous{
	display: flex;
	align-items: center;
	justify-content: flex-start;
}

.mainpoint .scenario .item .detail .nervous .icon{
	width: 102px;
}

.mainpoint .scenario .item .detail .nervous .memo{
	flex: 1;
	padding-left: 15px;
	padding-bottom: 3px;
	font-size: 22px;
	font-weight: bold;
	line-height: 1;
	color: #333333;
	letter-spacing: 0;
}

.mainpoint .scenario .item .detail .nervous.spec .memo{
	flex: none;
}

.mainpoint .scenario .item .detail .nervous .memo span.highlight{
	color: #d51d47;
}

.mainpoint .scenario .item .detail .nervous .memo span.heavy{
	font-size: 32px;
}

.mainpoint .scenario .item .detail .nervous .memo span.extra{
	font-size: 11px;
	color: #333333;
}

.mainpoint .scenario .item .detail .nervous .chart{
	position: relative;
	width: 239px;
	margin-left: 50px;
}

.mainpoint .scenario .item .detail .nervous .chart .dialog{
	position: absolute;
	width: 75px;

	top: 0;
	right: -66px;
}

.mainpoint .scenario .item .detail .cosplay{
	position: relative;
	display: flex;
	margin: 0 -46px;
	padding-bottom: 15px;
	align-items: flex-end;
}

.mainpoint .scenario .item .detail .cosplay .cover{
	width: 98px;
	margin-left: 30px;
}

.mainpoint .scenario .item .detail .cosplay .title{
	width: 700px;
	margin-left: 20px;
}

.mainpoint .scenario .item .detail .auxiliary{
	padding: 10px 0;
	text-align: center;
}

.mainpoint .scenario .item .detail .auxiliary a{
	position: relative;
	display: inline-block;

	padding: 10px 50px;

	border-radius: 30px;
	background: #ec6670;

	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0;
	color: #FFF;
	

	text-decoration: none;
}

.mainpoint .scenario .item .detail .auxiliary a:hover{
	background: #cc3366;
}

.mainpoint .scenario .item .detail .auxiliary a::before{
	content: "+";
	position: absolute;
	top: 50%;
	left: 25px;
	transform: translateY(-50%);
}

.mainpoint .scenario .item .detail .auxiliary a::after{
	content: "+";
	position: absolute;
	top: 50%;
	right: 25px;
	transform: translateY(-50%);
}

.mainpoint .scenario .item .detail .human{
	width: 100%;
	max-width: 741px;
	padding: 30px 0;
	margin: 0 auto;
}


.calculate{
	position: relative;
	padding: 80px 0 0 0;
	z-index: 2;
}

.calculate .maincontent{
	border-radius: 30px;
	border: 6px solid #ff6974;
	overflow: hidden;
}

.calculate .maincontent .headline{
	position: relative;
	padding: 15px 0;
	background: #ff6974;
}

.calculate .maincontent .headline .calculate-title{
	width: 260px;
	margin: 0 auto;
}

.calculate .maincontent .headline .icon{
	position: absolute;
	width: 60px;
}

.calculate .maincontent .headline .icon.icon-1{
	top: 10px;
	left: calc(50% - 400px);
}

.calculate .maincontent .headline .icon.icon-2{
	top: 10px;
	left: calc(50% + 200px);
}

.calculate .step{
	width: 530px;
	margin: 50px auto;
}

.calculate .step.close{
	display: none;
}

.calculate .step .milestone{

	padding: 0px;
	margin-bottom: 30px;

	text-align: center;
}

.calculate .step .milestone.spec{

	margin-bottom: 50px;
}

.calculate .step span.title{
	display: inline-block;
	padding: 0 0 10px 0;

	font-size: 22px;
	font-weight: bold;
	letter-spacing: 0;
	color: #000;

	border-bottom: 1px solid #000;
}

.calculate .step .formobj{
	display: flex;
	padding-bottom: 20px;
	align-items: center;
}

.calculate .step .formobj .formtitle{
	padding-right: 0px;
	font-size: 22px;
	font-weight: bold;
	letter-spacing: 0;

	color: #000000;
}

.calculate .step .formobj .formtitle.long{
	padding-right: 0px;
}

.calculate .step .formobj .formdetail{
	flex: 1;
}


.calculate .step .formobj .formdetail.spare-age{
	flex: none;
	width: 120px;
	padding-right: 15px;
}

.calculate .step .formobj .formdetail.spare-zip{
	flex: none;
	width: 80px;
}


.calculate .step .formobj .formdetail .sex{
	display: flex;

	align-items: center;
	justify-content: center;
}

.calculate .step .formobj .formdetail .sex .item{
	position: relative;

	width: 180px;
	padding: 20px;
	border-radius: 30px;

	font-size: 24px;
	font-weight: bold;
	text-align: right;
	letter-spacing: 0;
	background: #FFF;

	border: 3px solid #ff6262;

	cursor: pointer;
}

.calculate .step .formobj .formdetail .sex .item:first-child{
	margin-right: 10px;
	border-color: #74b7da;
}

.calculate .step .formobj .formdetail .sex .item:last-child{
	margin-left: 10px;
	border-color: #ff736c;
}

.calculate .step .formobj .formdetail .sex .item.chs{
	background: #ff6262;
	color: #FFF;
}

.calculate .step .formobj .formdetail .sex .item:first-child.chs{
	background: #74b7da;
}

.calculate .step .formobj .formdetail .sex .item:last-child.chs{
	background: #ff736c;
}

.calculate .step .formobj .formdetail .item.male:after{
	content: "";
	position: absolute;

	width: 68px;
	height: 68px;

	left: 20px;
	bottom: 0;

	background: url("../images/calculate_sex_male.png") no-repeat;
	background-size: 100% 100%;
}

.calculate .step .formobj .formdetail .item.female:after{
	content: "";
	position: absolute;

	width: 68px;
	height: 68px;

	left: 20px;
	bottom: 0;

	background: url("../images/calculate_sex_female.png") no-repeat;
	background-size: 100% 100%;
}

.calculate .step .formobj .formdetail .age{
	display: inline-block;
	width: 100%;
}

.calculate .step .formobj .formdetail .age select{
	display: inline-block;
	position: relative;
	width: 100%;

	padding: 12px 8px;
	
	border: 1px solid #dcdcdc;
	border-radius: 5px;

	font-size: 20px;

	color: #000;

	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;

	background: #FFF;
	background-image: url("../images/calculate_select_icon.png");
	background-position: right 5% center;
	background-size: 16px 14px;
	background-repeat: no-repeat;
	background-position: center right 10px;
}

.calculate .step .formobj .formdetail input[type='text']{
	width: 100%;
	padding: 8px;
	border-radius: 5px;
	border: 1px solid #dcdcdc;
	font-size: 22px;

	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
}

.calculate .step .formobj .formdetail label.agreement{
	display: flex;
	position: relative;
	
	align-items: center;
	line-height: 1.5;
	cursor: pointer;
	font-size: 14px;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.calculate .step .formobj .formdetail label.agreement input[type='checkbox']{
	position: relative;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	width: 30px;
	height: 30px;

	border: 1px solid #808080;
	cursor: pointer;

	background: #FFF;
}

.calculate .step .formobj .formdetail label.agreement input[type='checkbox']:checked::after{
	content: "";
	display: inline-block;
	position: absolute;
	
	width: 20px;
	height: 20px;
	top: 50%;
	left: 50%;

	transform: translate(-50%, -50%);

	background: #d0214a;
}

.calculate .step .formobj .formdetail label.agreement .memo{
	flex: 1;
	padding-left: 10px;
	font-size: 15px;
	letter-spacing: 0;
}

.calculate .step .formobj .formdetail label.agreement .memo a{
	color: #000;
	font-weight: bold;
	text-decoration: underline;
}

.calculate .step .formobj .dash{
	display: inline-block;
	padding: 0 5px;
}

.calculate .step .formbtn{
	display: block;
	padding-top: 20px;
	text-align: center;
}

.calculate .step .formbtn a{
	display: inline-block;
	width: 206px;
}

.calculate .step .formobj .plan{
	display: flex;
	align-items: center;
	justify-content: space-around;
}

.calculate .step .formobj .plan .item{
	width: 33.3333%;
	text-align: center;
}

.calculate .step .formobj .plan .item label{
	display: block;
	cursor: pointer;
	letter-spacing: 0;

	padding-bottom: 20px;
}

.calculate .step .formobj .plan .item label .cover{
	padding-bottom: 10px;
}

.calculate .step .formobj .plan .item label .cover img{
	margin: 0 auto;
	width: 100%;
	max-width: 95px;
}

.calculate .step .formobj .plan .item label span{
	position: relative;
	color: #000000;

	padding-left: 30px;

	font-size: 22px;
	font-weight: bold;
	letter-spacing: 0;
}

.calculate .step .formobj .plan .item label span:before{
	content: "";
	position: absolute;
	top: 50%;
	left: 0%;

	transform: translateY(-50%);

	width: 26px;
	height: 26px;
	border: 1px solid #808080;
	border-radius: 50%;
	background: #FFF;
}

.calculate .step .formobj .plan .item label.chs span:after{
	content: "";
	position: absolute;
	top: 50%;
	left: calc((26px - 18px) / 2);

	transform: translateY(-50%);

	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #ff406e;
}

.calculate .step .formobj .formdetail .result{
	display: flex;
	align-items: center;
}

.calculate .step .formobj .formdetail .result span.showtitle{
	display: inline-block;
	padding: 20px 30px;

	font-size: 22px;
	font-weight: bold;
	line-height: 1.3;

	color: #000;

	border-radius: 15px;

	background: #ffddde;

	text-align: center;
	letter-spacing: 0;
}

.calculate .step .formobj .formdetail .result .detail{
	flex: 1;
	padding-left: 20px;
	flex-wrap: wrap;
}

.calculate .step .formobj .formdetail .result .detail .monthpay{
	display: flex;

	align-items: center;
	padding: 5px 0;
	letter-spacing: 0;
}

.calculate .step .formobj .formdetail .result .detail .monthpay span.memo{
	display: inline-block;
	font-size: 22px;
	font-weight: bold;
}

.calculate .step .formobj .formdetail .result .detail .monthpay span.money{
	flex: 1;

	padding: 10px 10px;
	font-size: 22px;
	font-weight: bold;

	background: #ffddde;

	color: #404040;

	text-align: right;
}

.calculate .step .formbtnfinall{
	display: block;
	padding-top: 10px;
	text-align: center;
}

.calculate .step .formbtnfinall a{
	display: inline-block;
	width: 340px;
}

.calculate .step .formbtnfinall a img{
	width: 100%;
}


.guideline{
	position: relative;
	padding: 80px 0 0 0;
	z-index: 2;
}

.guideline .unit-title{
	position: relative;

	width: 100%;
	max-width: 345px;
	margin: 0 auto;
	padding-bottom: 20px;
}

.guideline .pannel{
	position: relative;
	width: 100%;
	margin-top: 15px;
}

.guideline .pannel .headtitle{
	position: absolute;
	top: 46px;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0;
	color: #605656;
}

.guideline .pannel .headtitle.spec{
	color: #FFF;
}

.guideline .pannel .headtitle span.heavy{
	font-size: 26px;
}

.guideline .pannel .headtitle.t1{ left: 154px;  line-height: 1.6;}
.guideline .pannel .headtitle.t2{ left: 432px; }
.guideline .pannel .headtitle.t3{ left: 674px; }
.guideline .pannel .headtitle.t4{ left: 918px; }

.guideline .pannel .subtitle{
	position: absolute;
	left: 25px;
	width: 96px;
	font-size: 18px;
	font-weight: bold;
	color: #292927;
	text-align: center;
	letter-spacing: 0;
}

.guideline .pannel .subtitle.s1{ top: 208px; }
.guideline .pannel .subtitle.s2{ top: 456px; }
.guideline .pannel .subtitle.s3{ top: 632px; }

.guideline .pannel .subtitle span.extra{
	font-size: 13px;
	font-weight: normal;
	letter-spacing: 0;
	color: #292927;
}

.guideline .pannel .subintro{
	position: absolute;

	left: 136px;

	width: 240px;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0;
	text-align: left;
	color: #292927;
}

.guideline .pannel .subintro.i1{ top: 120px; }
.guideline .pannel .subintro.i2{ top: 186px; }
.guideline .pannel .subintro.i3{ top: 258px; }
.guideline .pannel .subintro.i4{ top: 324px; width: 222px; text-align: center; }
.guideline .pannel .subintro.i5{ top: 396px; }
.guideline .pannel .subintro.i6{ top: 462px; }
.guideline .pannel .subintro.i7{ top: 530px; }
.guideline .pannel .subintro.i8{ top: 600px; }
.guideline .pannel .subintro.i9{ top: 666px; }

.guideline .pannel .subintro span.extra{
	font-size: 13px;
	font-weight: normal;
	letter-spacing: 0;
	color: #292927;
}

.guideline .pannel .enunciation{
	position: absolute;
	left: 0;
	width: 240px;
	font-size: 22px;
	font-weight: bold;
	letter-spacing: 0;
	text-align: center;
	color: #d51d47;
}

.guideline .pannel .enunciation.e1{ left: 382px; }

.guideline .pannel .enunciation.e1.e1-1{ top: 120px; }
.guideline .pannel .enunciation.e1.e1-2{ top: 186px; }
.guideline .pannel .enunciation.e1.e1-3{ top: 258px; }
.guideline .pannel .enunciation.e1.e1-4{ top: 324px; }
.guideline .pannel .enunciation.e1.e1-5{ top: 396px; }
.guideline .pannel .enunciation.e1.e1-6{ top: 462px; }
.guideline .pannel .enunciation.e1.e1-7{ top: 530px; }
.guideline .pannel .enunciation.e1.e1-8{ top: 600px; }
.guideline .pannel .enunciation.e1.e1-9{ top: 666px; }

.guideline .pannel .enunciation.e2{ left: 630px; }

.guideline .pannel .enunciation.e2.e2-1{ top: 120px; }
.guideline .pannel .enunciation.e2.e2-2{ top: 186px; }
.guideline .pannel .enunciation.e2.e2-3{ top: 258px; }
.guideline .pannel .enunciation.e2.e2-4{ top: 324px; }
.guideline .pannel .enunciation.e2.e2-5{ top: 396px; }
.guideline .pannel .enunciation.e2.e2-6{ top: 462px; }
.guideline .pannel .enunciation.e2.e2-7{ top: 530px; }
.guideline .pannel .enunciation.e2.e2-8{ top: 600px; }
.guideline .pannel .enunciation.e2.e2-9{ top: 666px; }

.guideline .pannel .enunciation.e3{ left: 870px; }

.guideline .pannel .enunciation.e3.e3-1{ top: 120px; }
.guideline .pannel .enunciation.e3.e3-2{ top: 186px; }
.guideline .pannel .enunciation.e3.e3-3{ top: 258px; }
.guideline .pannel .enunciation.e3.e3-4{ top: 324px; }
.guideline .pannel .enunciation.e3.e3-5{ top: 396px; }
.guideline .pannel .enunciation.e3.e3-6{ top: 462px; }
.guideline .pannel .enunciation.e3.e3-7{ top: 530px; }
.guideline .pannel .enunciation.e3.e3-8{ top: 600px; }
.guideline .pannel .enunciation.e3.e3-9{ top: 666px; }

.guideline .pannel .explain{
	position: absolute;
	top: 676px;
	left: 388px;
	width: 720px;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0;
	text-align: center;
	color: #292927;
}

.guideline .pannel .explain span.extra{
	font-size: 13px;
	font-weight: normal;
	letter-spacing: 0;
	color: #292927;
}

.guideline .pannel .dialog{
	position: absolute;
	width: 96px;
	top: -42px;
	left: 786px;
}

.guideline .nt{
	width: 100%;
	text-align: right;
	padding-top: 5px;
	letter-spacing: 0;
	font-size: 16px;
}

.guideline .memo{
	padding-top: 10px;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0;
	line-height: 1.5;
	color: #292927;
}

.paradigm{
	position: relative;
	padding: 80px 0 0px 0;
}

.paradigm .unit-title{
	display: block;
	width: 100%;
	max-width: 345px;
	margin: 0 auto;
	padding-bottom: 20px;
}

.paradigm .unit-title{
	display: block;
	width: 100%;
	max-width: 345px;
	margin: 0 auto;
	padding-bottom: 20px;
}

.paradigm .foreword{
	padding-bottom: 30px;
	text-align: center;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0;
	color: #363634;
}

.paradigm .pannel{
	position: relative;
	width: 100%;
}

.paradigm .pannel .item{
	position: relative;
	width: 100%;
}

.paradigm .pannel .item .carte{
	position: absolute;
	display: flex;
	width: 100%;
	top: 52px;
	align-items: center;
	justify-content: center;
}

.paradigm .pannel .item .carte .ex{
	width: 101px;
}

.paradigm .pannel .item .carte .alias{
	width: 282px;
	margin-left: 15px;
}

.paradigm .pannel .item .intro{
	position: absolute;
	width: 860px;
	top: 170px;
	left: 40px;

	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0;
	line-height: 1.5;
	color: #704136;
}

.paradigm .pannel .item .intro span.highlight{
	color: #d02149;
}

.paradigm .pannel .item .menu{
	position: absolute;

	top: 270px;
	left: 0;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0;
	color: #704136;
}

.paradigm .pannel .item .menu.m1-1{ left: 40px; }
.paradigm .pannel .item .menu.m1-2{ left: 400px; }
.paradigm .pannel .item .menu.m1-3{ left: 722px; }

.paradigm .pannel .item .menu.m2-1{ left: 40px; }
.paradigm .pannel .item .menu.m2-2{ left: 400px; }
.paradigm .pannel .item .menu.m2-3{ left: 722px; }

.paradigm .pannel .item .introduce{
	position: absolute;
	top: 0;
	left: 0;
	width: 250px;
	line-height: 1.5;
	font-size: 14px;
	letter-spacing: 0;
	font-weight: bold;
	color: #704136;
}

.paradigm .pannel .item .introduce span.heavy{
	font-size: 20px;
}

.paradigm .pannel .item .introduce.i1-1{ top: 422px;left: 40px; }

.paradigm .pannel .item .introduce.i2-1{ top: 324px;left: 40px; }
.paradigm .pannel .item .introduce.i2-2{ top: 388px;left: 40px; }
.paradigm .pannel .item .introduce.i2-3{ top: 584px;left: 40px; }
.paradigm .pannel .item .introduce.i2-4{ top: 790px;left: 40px; }

.paradigm .pannel .item .benefit{
	position: absolute;
	top: 0;
	left: 370px;
	width: 200px;
	font-size: 18px;
	letter-spacing: 0;
	font-weight: bold;
	text-align: left;
	color: #704136;
}

.paradigm .pannel .item .benefit.b1-1{ top: 328px; }
.paradigm .pannel .item .benefit.b1-2{ top: 388px; }
.paradigm .pannel .item .benefit.b1-3{ top: 446px; }
.paradigm .pannel .item .benefit.b1-4{ top: 504px; }
.paradigm .pannel .item .benefit.b1-5{ top: 562px; }

.paradigm .pannel .item .benefit.b2-1{ top: 328px; }
.paradigm .pannel .item .benefit.b2-2{ top: 388px; }
.paradigm .pannel .item .benefit.b2-3{ top: 446px; }
.paradigm .pannel .item .benefit.b2-4{ top: 504px; }
.paradigm .pannel .item .benefit.b2-5{ top: 566px; }
.paradigm .pannel .item .benefit.b2-6{ top: 622px; }
.paradigm .pannel .item .benefit.b2-7{ top: 682px; }
.paradigm .pannel .item .benefit.b2-8{ top: 740px; }
.paradigm .pannel .item .benefit.b2-9{ top: 810px; }

.paradigm .pannel .item .money{
	position: absolute;
	top: 0;
	left: 710px;
	width: 100px;
	font-size: 20px;
	letter-spacing: 0;
	font-weight: bold;
	text-align: left;
	color: #d02149;
	text-align: center;
}

.paradigm .pannel .item .money.m1-1{ top: 328px; }
.paradigm .pannel .item .money.m1-2{ top: 388px; }
.paradigm .pannel .item .money.m1-3{ top: 446px; }
.paradigm .pannel .item .money.m1-4{ top: 504px; }
.paradigm .pannel .item .money.m1-5{ top: 562px; }

.paradigm .pannel .item .money.m2-1{ top: 328px; }
.paradigm .pannel .item .money.m2-2{ top: 388px; }
.paradigm .pannel .item .money.m2-3{ top: 446px; }
.paradigm .pannel .item .money.m2-4{ top: 504px; }
.paradigm .pannel .item .money.m2-5{ top: 566px; }
.paradigm .pannel .item .money.m2-6{ top: 622px; }
.paradigm .pannel .item .money.m2-7{ top: 682px; }
.paradigm .pannel .item .money.m2-8{ top: 740px; }
.paradigm .pannel .item .money.m2-9{ top: 810px; }

.paradigm .pannel .item .result{
	position: absolute;
	top: 0;
	left: 400px;
	font-size: 20px;
	letter-spacing: 0;
	font-weight: bold;
	text-align: left;
	color: #704136;
	text-align: center;
}

.paradigm .pannel .item .result.r1{ top: 616px; }

.paradigm .pannel .item .result.r2{ top: 876px; }

.paradigm .pannel .item .settlement{
	position: absolute;
	top: 0;
	left: 726px;
	font-size: 24px;
	letter-spacing: 0;
	font-weight: bold;
	text-align: left;
	color: #d02149;
	text-align: center;
}

.paradigm .pannel .item .settlement.s1{ top: 614px; }

.paradigm .pannel .item .settlement.s2{ top: 876px; }

.paradigm .pannel a.arrow-paradigm{
	position: absolute;
	top: 300px;
	width: 60px;
	z-index: 2;
}

.paradigm .pannel a.arrow-paradigm.arrow-left{
	left: -80px;
}
.paradigm .pannel a.arrow-paradigm.arrow-right{
	right: -80px;
}

.paradigm .nt{
	width: 100%;
	text-align: right;
	padding-top: 5px;
	letter-spacing: 0;
	font-size: 16px;
}

.global-bg{
	position: absolute;
}

.global-bg.cloud-1{ width: 194px; top: 1180px; left: calc(50% + 650px); }
.global-bg.cloud-2{ width: 194px; top: 1850px; left: calc(50% - 900px); }
.global-bg.cloud-3{ width: 194px; top: 2800px; left: calc(50% + 650px); }
.global-bg.cloud-4{ width: 194px; top: 3400px; left: calc(50% - 900px); }
.global-bg.cloud-5{ width: 194px; top: 3900px; left: calc(50% + 800px); }
.global-bg.cloud-6{ width: 194px; top: 4550px; left: calc(50% - 1050px); }
.global-bg.cloud-7{ width: 194px; top: 4600px; left: calc(50% + 800px); }
.global-bg.cloud-8{ width: 194px; top: 5400px; left: calc(50% + 800px); }
.global-bg.cloud-9{ width: 194px; top: 5850px; left: calc(50% - 1050px); }

.global-bg.tree-left{ width: 652px; top: 4900px; left: calc(50% - 1150px); }
.global-bg.tree-right{ width: 625px; top: 4800px; left: calc(50% + 600px); }

.demand{
	position: relative;
	display: none;

	padding: 100px 0 30px 0;
}

.demand .pannel{
	width: calc(1096px * 0.64);
	height: calc(1383px * 0.64);
	padding: 180px 70px 0 70px;
	margin: 0 auto;
	background: url("../images/demand_m_pannel.png") no-repeat top center;
	background-size: cover;
}

.demand .pannel .group{
	display: flex;
	align-items: center;
	padding-bottom: 40px;

	font-size: 26px;
}

.demand .pannel .group span.title{
	display: inline-block;
	min-width: 100px;
	padding-right: 10px;
	font-size: 26px;
	font-weight: bold;
	color: #FFF;
	letter-spacing: 0;
}

.demand .pannel .group span.title.spec{
	min-width: auto;
}


.demand .pannel .group .item{
	display: flex;
	align-items: center;
}

.demand .pannel .group .item:first-child{
	flex: 1;
	padding-right: 20px;
}

.demand .pannel .group label.forsex{
	display: flex;
	padding-right: 30px;
	align-items: center;

	font-size: 26px;
	font-weight: bold;
	color: #FFF;
}

.demand .pannel .group input[type='text']{
	width: 0;
	flex: 1;

	font-size: 26px;

	border: 1px solid #808080;
}

.demand .pannel .group select{
	display: inline-block;
	position: relative;
	width: 100px;
	height: 43px;
	padding: 3px 3px 3px 6px;

	color: #000;
	
	border: 1px solid #808080;
	border-radius: 0;

	font-size: 26px;

	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;

	background: #FFF;
	background-image: url("../images/calculate_select_icon.png");
	background-position: right 5% center;
	background-size: 8px 6px;
	background-repeat: no-repeat;
	background-position: center right 10px;
}


.demand .pannel .group input[type='radio']{
	position: relative;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	width: 40px;
	height: 40px;
	margin-right: 15px;
	border-radius: 50%;
	border: 1px solid #808080;
	cursor: pointer;
	background: #FFF;
}

.demand .pannel .group input[type='radio']:checked::after{
	content: "";
	display: inline-block;
	position: absolute;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #d02149;
	border: 1px solid #000;
}

.demand .pannel .group .zip{
	width: 100px;
}

.demand .pannel .group span.dash{
	padding: 0 5px;
}

.demand .pannel .group .tel{
	flex: 1;
}

.demand .pannel .group .zip input[type='text'], .demand .pannel .group .tel input[type='text']{
	width: 100%;
}


.demand .pannel .group label.agreement{
	display: flex;
	position: relative;
	margin-bottom: 12px;
	line-height: 1.5;
	cursor: pointer;
	font-size: 26px;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.demand .pannel .group label.agreement input[type='checkbox']{
	position: relative;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	width: 40px;
	height: 40px;
	margin-top: 5px;
	border: 1px solid #808080;
	cursor: pointer;
	background: #FFF;
}

.demand .pannel .group label.agreement input[type='checkbox']:checked::after{
	content: "";
	display: inline-block;
	position: absolute;
	width: 36px;
	height: 36px;
	top: 50%;
	left: 50%;transform: translate(-50%, -50%);
	background: #fff000;
	border: 1px solid #000;
}

.demand .pannel .group label.agreement .memo{
	flex: 1;
	padding-left: 20px;
	line-height: 32px;
	letter-spacing: 1px;
	color: #FFF;
}

.demand .pannel .group label.agreement .memo a, demand .pannel .group label.agreement .memo a:hover{
	color: #FFF;
}

.demand .pannel .sendbtn{
	width: 100%;
	text-align: center;
}

.demand .pannel .sendbtn a{
	display: inline-block;

	padding: 0;

	width: 307px;
	height: 93px;
	text-align: center;
	font-weight: bold;
	letter-spacing: 0;

	text-indent: 0;
	
	text-decoration: none;

	background: url("../images/demand_send_btn.png");
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center left;
}

.demand .warning{
	margin: 0 auto;
	padding-top: 30px;
	width: 520px;
	font-size: 36px;
	text-align: center;
	letter-spacing: 0;
	line-height: 1.2;
	color: #FFF;
}

.demand .illbgleft{
	position: absolute;
	width: 33%;
	max-width: 287px;
	bottom: 0;
	left: 0;
}

.demand .illbgright{
	position: absolute;
	width: 35%;
	max-width: 300px;
	bottom: 0;
	right: 0;
}

.pagebottom{
	position: relative;
	width: 1920px;
	margin: 0 calc(50% - 960px);
	padding-top: 30px;
	border-bottom: 5px solid #d51d47;
}

.pagebottom h1{
	position: absolute;
	top: 20px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 28px;
	font-weight: normal;
	letter-spacing: 0;
	color: #999999;
}

.pagebottom .bgicon{
	position: absolute;
	width: 59px;
}

.pagebottom .bgicon.i1{ top: -190px; left: calc(50% + 650px); }
.pagebottom .bgicon.i2{ top: -90px; left: calc(50% - 700px); }

.poplayout{
	position: relative;
	width: 100%;
	max-width: 800px;

	margin: 30px auto;

	padding: 50px 50px 50px 0;
}

.poplayout a.closebtn{
	position: absolute;
	width: 50px;
	height: 50px;
	top: 0;
	right: 0;
	opacity: 1;
}

.poplayout a.closebtn img{
	width: 100%;
}

.popinner{
	border-radius: 15px;

	max-width: 726px;

	background: #FFF;

	margin: 0 auto;
	overflow: hidden;

	border: 2px solid #d0214a;
}

.popinner span.title{
	display: inline-block;
	width: 100%;
	padding: 10px 15px;
	font-size: 32px;
	font-weight: bold;

	text-align: center;
	color: #FFF;
	background: #ff406e;
}

.popinner .info{
	display: flex;
	align-items: center;

	padding: 30px 50px;
	letter-spacing: 0;

	font-weight: bold;
}

.popinner .info .content{
	flex: 1;

	font-size: 26px;
	line-height: 34px;
}

.popinner .info .content span.light{
	color: #ff406e;
	display: inline-block;
	width: 100%;
	padding-top: 10px;
	font-weight: bold;
}

.popinner .info .people{
	width: 175px;
	text-align: center;
}

.popinner .info .people img{
	width: 95%;
	margin: 0 0 0 auto;
}

.popinner .sharegroup{
	display: flex;
	width: 100%;

	justify-content: center;
	align-items: center;
}

.popinner .sharegroup .item{
	flex: 1;
	text-align: center;
}

.popinner .sharegroup .item img{
	width: 80px;
	margin: 0 auto;
}

.popinner .sharegroup .item a span.sharetxt, .popinner .sharegroup .item a span.sharetxt:hover{
	display: inline-block;
	color: #000;
	text-decoration: none;
}

.popinner .btn{
	width: 220px;
	margin: 0 auto;
}

.popinner .btn a{
	display: flex;
	align-items: center;
	justify-content: center;

	padding: 15px;

	background: #d0214a;

	border: 2px solid #000;

	font-size: 26px;
	font-weight: bold;
	letter-spacing: 0;

	color: #FFF;
	text-decoration: none;
}

.popinner .btn a:hover{
	color: #000;
	background: #68e8ff;
	text-decoration: none;
}

.popinner .btn a img{
	width: 30px;
}

.popinner .memo{
	display: inline-block;
	width: 100%;
	padding: 30px 60px;

	letter-spacing: 0;
}

/********/

.benefitpop{
	position: relative;
	width: 100%;
}

.benefitpop .headtitle{
	position: absolute;
	left: 26px;
	top: 22px;
	font-size: 18px;
	font-weight: bold;
	color: #4a3f40;
	letter-spacing: 0;
}

.benefitpop .subtitle{
	position: absolute;
	width: 254px;
	padding-left: 20px;
	font-size: 16px;
	font-weight: bold;
	color: #4a3f40;
	letter-spacing: 0;
}

.benefitpop .subtitle.spec{
	color: #d0214a;
}

.benefitpop .subtitle span.extra{
	font-size: 13px;
}

.benefitpop .subtitle.i1{ top: 64px;left: 15px }
.benefitpop .subtitle.i1:before{ content:"1."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i2{ top: 64px;left: 282px; }
.benefitpop .subtitle.i2:before{ content:"2."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i3{ top: 64px;left: 476px; }
.benefitpop .subtitle.i3:before{ content:"3."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i4{ top: 108px;left: 15px; }
.benefitpop .subtitle.i4:before{ content:"4."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i5{ top: 108px;left: 282px; }
.benefitpop .subtitle.i5:before{ content:"5."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i6{ top: 108px;left: 476px; }
.benefitpop .subtitle.i6:before{ content:"6."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i7{ top: 154px;left: 15px; }
.benefitpop .subtitle.i7:before{ content:"7."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i8{ top: 154px;left: 282px; }
.benefitpop .subtitle.i8:before{ content:"8."; position:absolute; top: 0px; left:5px; }

.benefitpop .subtitle.i9{ top: 154px;left: 476px; }
.benefitpop .subtitle.i9:before{ content:"9."; position:absolute; top: 0px; left:5px; }


/*******/

footer{
	position: relative;
	display: block;
	background: #FFF;
	z-index: 1;
}

footer .specmemo{
	width: 100%;
	padding: 30px 0;
	margin: 0 auto;
	text-align: center;
}

footer .specmemo a{
	display: inline-block;
	color: #FFF;
	background: #808080;
	width: 80%;
	max-width: 250px;

	padding: 15px 30px;

	font-size: 22px;
	font-weight: bold;

	border-radius: 5px;

	text-decoration: none;
	margin: 0 auto;
}

footer .specmemo a:hover{
	text-decoration: none;
}

footer .memo{
	position: relative;
	padding: 15px 15px;
	text-align: center;

	border-top: 2px solid #d1d1d1;
	border-bottom: 2px solid #d1d1d1;

	margin: 0 auto;
}

footer .memo a.tel{
	display: inline-block;
	width: calc(608px * 0.85);
	margin: 0 auto;
}

footer .memo a.open{
	position: absolute;
	width: calc(220px * 0.85);
	top: 15px;
	left: calc(50% + 400px);

	display: inline-block;

	padding: 0;
	margin-left: 15px;
}

footer .memo a.open img{
	width: 100%;
}

footer .memo .askrelax{
	position: relative;
	display: flex;

	justify-content: center;
	align-items: flex-end;

	padding: 20px 15px;
}

footer .memo .askrelax a{
	margin: 0 15px;
}

footer .memo .askrelax a img.ask{
	width: 220px;
}

footer .memo .askrelax a img.relax{
	width: 220px;
}

footer .memo .askrelax{
	position: relative;
	display: flex;

	justify-content: center;
	align-items: flex-end;

	padding: 20px 15px;
}

footer .memo .extra-logo{
	max-width: 198px;
	width: 50%;
	margin: 10px auto;
}

footer .detail{
	padding: 15px 15px;
	background: #f5f5f5;
	text-align: center;

	font-size: 15px;
	color: #333;

	letter-spacing: 0;

	font-weight: normal;
}

footer .detail .extra{
	display: inline-block;
	padding-right: 10px;
}

footer .detail .extra a{
	color: #333;
	text-decoration: none;
}

footer .detail .extra a:hover{
	color: #dc164b;
}

.stickybottom a{
	display: flex !important;
	align-items: center;
	justify-content: center;
	position: relative;
	border: 1px solid #000;
}

.stickybottom a img{
	display: inline-block;
	width: 36px;
	margin-right: 5px;
}

.stickydog{
	position: fixed;
	bottom: 10%;
	right: 1%;
	width: calc(174px * 0.6);
	z-index: 5;
}

.stickydog img{
	width: 100%;
}

.stickycat{
	position: fixed;
	top: 100px;
	right: 0;
	max-width: 109px;
	width: 16vw;
	z-index: 5 !important;
}

.stickycat img{
	width: 100%;
}

.mirrorman{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-indent: -9999999px;
}


/*大於等於1921*/
@media (min-width: 1921px) {
}


/*小於等於1920*/
@media (max-width: 1920px) {

	.kv .theater .ill-tree{
		left: calc(50% - 1070px);
	}

	.kv .theater .ill-bridge{
		left: calc(50% + 580px);
	}

}

/*小於等於1800*/
@media (max-width: 1800px) {

	.jogging-road{
		position: absolute;
		width: 2000px;

		top: 360px;
		left: calc(50% - 1000px);
	}

	.jogging-people{
		position: absolute;
		width: 200px;

		top: 190px;
		left: calc(50% - 800px);
	}
}

/*小於等於1600*/
@media (max-width: 1600px) {

	header .collection nav ul li:before, header .collection nav ul li:after, header .collection nav ul li:last-child a:before, header .collection nav ul li:last-child a:after{
		height: 20px;
	}

	header .collection .logo{
		width: 160px;
	}

	header .collection .sub-logo{
		width: 140px;
	}

	header .collection .contact{
		width: 260px;
	}

	header .collection nav ul li a{
		padding: 10px 15px 10px 50px;
	}

	header .collection nav ul li a.icon{
		background-size: 29px 30px !important;
		background-position: center left 15px !important;
	}

	header .collection nav ul li a.icon.icon-1{
		padding-left: 50px;
		background-size: calc(51px * 0.8) calc(50px * 0.8) !important;
	}

	header .collection nav ul li a.icon.icon-2{
		padding-left: 60px;
		background-size: calc(42px * 0.8) calc(50px * 0.8) !important;
	}

	header .collection nav ul li a.icon.icon-3{
		padding-left: 60px;
		background-size: calc(44px * 0.8) calc(50px * 0.8) !important;
	}

	header .collection nav ul li a.icon.icon-5{
		margin-right: 0;
		padding-left: 40px;
		background-size: calc(36px * 0.8) calc(36px * 0.8) !important;
	}

	header .collection nav ul li .hot{
		width: 32px;
		top: -10px;
		left: calc(50% + 34px);
	}
}

/*小於等於1441*/
@media (max-width: 1441px) {


}

/*小於等於1280*/
@media (max-width: 1280px) {

	.lihsi-desktop-no-pad{
		display: none !important;
	}

	.lihsi-pad-mobile{
		display: block !important;
	}

	.container-base{
		width: calc(700px + (15px * 2));
	}

	.container-sub{
		width: calc(700px + (15px * 2));
	}

	header .collection nav ul li:before, header .collection nav ul li:after, header .collection nav ul li:last-child a:before, header .collection nav ul li:last-child a:after{
		height: 20px;
	}


	header .collection .logo{
		width: 146px;
		padding-top: 5px;
	}

	header .collection .sub-logo{
		width: 120px;
		padding-left: 15px;
		padding-top: 5px;
	}

	header .collection .contact{
		width: 200px;
	}

	header .collection nav{
		padding: 0 10px 0 0;
	}

	header .collection nav ul li a{
		padding: 10px 10px;
	}

	header .collection nav ul li:last-child a{
		padding: 10px 18px;
	}

	header .collection nav ul li a.icon.icon-1{
		margin-right: 0;
		padding-left: 30px;
		background-size: calc(51px * 0.55) calc(50px * 0.55) !important;
	}

	header .collection nav ul li a.icon.icon-2{
		margin-right: 0;
		margin-left: 0;
		padding-left: 40px;
		background-size: calc(42px * 0.55) calc(50px * 0.55) !important;
	}

	header .collection nav ul li a.icon.icon-3{
		margin-right: 0;
		margin-left: 0;
		padding-left: 40px;
		background-size: calc(44px * 0.55) calc(50px * 0.55) !important
	}

	header .collection nav ul li a.icon.icon-5{
		margin-left: 15px;
		padding-left: 30px;
		background-size: calc(36px * 0.55) calc(36px * 0.55) !important;
	}

	header .collection nav ul li .hot{
		width: 32px;
	}

	.kv .theater{
		min-height: 590px;
	}

	.kv .theater .ill-slogan{
		top: 40px;
		width: calc(778px * 0.8);
	}

	.kv .theater .ill-subslogan{
		top: 130px;
		width: calc(619px * 0.8);
	}

	.kv .theater .ill-feature-1{
		width: calc(358px * 0.8);
		top: 200px;
	}

	.kv .theater .ill-feature-2{
		width: calc(358px * 0.8);
		top: 280px;
	}

	.kv .theater .ill-feature-3{
		width: calc(358px * 0.8);
		top: 360px;
	}

	.kv .theater .ill-cycle{
		width: calc(364px * 0.8);
		top: 440px;
	}

	.kv .theater .ill-oldman{
		width: calc(576px * 0.8);
		left: calc(50% - 790px);
	}

	.kv .theater p.extra{
		width: 304px;
		left: calc(50% - 320px);
		line-height: 1.3;
		bottom: 0px;
	}

	.kv .theater .clapperboard{
		width: calc(452px * 0.88);
		left: calc(50% - 8px);
	}

	.kv .theater .clapperboard .group{
		width: 320px;
		padding: 60px 35px 0 15px;
	}

	.kv .theater .clapperboard .group .team{
		padding-bottom: 10px;
	}

	.kv .theater .clapperboard .group .sendbtn a{
		margin-top: 10px
	}

	.kv .theater .ill-bridge{
		width: calc(398px * 0.7);
		left: calc(50% + 380px);
	}

	.kv .theater .theater .ill-feature{
		display: block;
	}


	.mainpoint .scenario .item .cover{
		width: calc(207px * 0.7);
		margin-left: 20px;
	}

	.mainpoint .scenario .item.i1{
		margin-top: -20px;
	}

	.mainpoint .scenario .item .title{
		width: 650px;
	}

	.mainpoint .scenario .item .detail{
		padding: 20px 30px 15px 30px;
		border: 1px solid #806b4b;
	}

	.mainpoint .scenario .item .detail .research{
		font-size: 22px;
		padding-top: 30px;
		padding-left: 0px;
		background-size: calc(50px * 0.7) calc(62px * 0.7) !important;
	}

	.mainpoint .scenario .item .detail .research span.extra{
		font-size: 13px;
	}

	.mainpoint .scenario .item .detail hr{
		margin: 10px 0;
	}

	.mainpoint .scenario .item .detail .commentary .memo{
		padding-left: 30px;
		font-size: 22px;
	}

	.mainpoint .scenario .item .detail .commentary .memo:before{
		width: calc(31px * 0.7);
		height: calc(30px * 0.7);
		top: 13px;
		left: 0px;
	}

	.mainpoint .scenario .item .detail .cosplay .cover{
		width: calc(207px * 0.7);
	}

	.mainpoint .scenario .item .detail .cosplay .title{
		width: 650px;
		margin: 20px;
	}

	.mainpoint .scenario .item .detail .nervous.spec{
		flex-wrap: wrap;
	}

	.mainpoint .scenario .item .detail .nervous .chart{
		width: 70%;
		padding-top: 30px;
		margin: 0 auto;
	}

	.mainpoint .scenario .item .detail .nervous .chart img{
		max-width: 320px;
		margin: 0 auto;
	}

	.mainpoint .scenario .item .detail .nervous .chart .dialog{
		right: auto;
		top: 29px;
		left: calc(50% + 66px);
	}


	.mainpoint .scenario .item .detail hr{
		height: 2px;
		border-top: 2px dashed #dc6d01;
	}


	.calculate .maincontent .headline .icon.icon-1{
		left: calc(50% - 300px);
	}

	.calculate .step{
		width: 510px;
		margin: 30px auto 20px auto;
	}

	.calculate .step span.title{
		font-size: 18px;
	}

	.calculate .step .milestone.spec{
		margin-bottom: 40px;
	}

	.calculate .step .formobj .formtitle{
		font-size: 18px;
		padding-bottom: 5px;
	}

	.calculate .step .formobj .formdetail .sex .item{
		width: 160px;
		padding: 15px;
		font-size: 18px;
	}



	.calculate .step .formobj .formdetail .item.male:after{
		width: calc(68px * 0.8);
		height: calc(68px * 0.8);
	}

	.calculate .step .formobj .formdetail .item.female:after{
		width: calc(68px * 0.8);
		height: calc(68px * 0.8);
	}

	.calculate .step .formobj{
		padding-bottom: 15px;
	}

	.calculate .step .formobj .formdetail .age select{
		font-size: 18px;
	}

	.calculate .step .formobj .formdetail input[type='text']{
		font-size: 18px;
	}

	.calculate .step .formobj .formdetail label.agreement input[type='checkbox']{
		width: 25px;
		height: 25px;
	}

	.calculate .step .formobj .formdetail label.agreement input[type='checkbox']:checked::after{
		width: 18px;
		height: 18px;
	}

	.calculate .step .formobj .formdetail label.agreement .memo{
		padding-left: 4px;
	}

	.calculate .step .formbtn a{
		width: 230px;
	}

	.calculate .step .formbtnfinall a{
		width: 220px;
	}

	.calculate .step .formobj .plan .item label span{
		font-size: 18px;
	}

	.calculate .step .formobj .plan .item label{
		width: 100%;
	}

	.calculate .step .formobj .plan .item label .cover{
		width: 100%;
	}

	.calculate .step .formobj .plan .item label .cover img{
		width: 100%;
	}

	.calculate .step .formobj .formdetail .result span.showtitle{
		padding: 10px 15px;
		font-size: 18px;
	}

	.calculate .step .formobj .formdetail .result span.showtitle i{
		font-size: 26px;
	}

	.calculate .step .formobj .formdetail .result .detail .monthpay span.memo{
		font-size: 18px;
	}

	.calculate .step .formobj .formdetail .result .detail .monthpay span.money{
		font-size: 18px;
	}

	.guideline .pannel{
		padding: 0;
	}

	.guideline .pannel .dialog{
		left: 628px;
		top: -30px;
	}

	.guideline .pannel .headtitle{
		top: 54px;
	}

	.guideline .pannel .headtitle.t1{
		left: 202px;
	}

	.guideline .pannel .headtitle.t2,.guideline .pannel .enunciation.e1.e1-1, .guideline .pannel .enunciation.e1.e1-2, .guideline .pannel .enunciation.e1.e1-3,
	.guideline .pannel .enunciation.e1.e1-4, .guideline .pannel .enunciation.e1.e1-5, .guideline .pannel .enunciation.e1.e1-6,
	.guideline .pannel .enunciation.e1.e1-7, .guideline .pannel .enunciation.e1.e1-8{
		display: none;
	}

	.guideline .pannel .headtitle.t3{
		left: 494px;
	}

	.guideline .pannel .headtitle.t4,.guideline .pannel .enunciation.e1.e3-1, .guideline .pannel .enunciation.e1.e3-2, .guideline .pannel .enunciation.e1.e3-3,
	.guideline .pannel .enunciation.e1.e3-4, .guideline .pannel .enunciation.e1.e3-5, .guideline .pannel .enunciation.e1.e3-6,
	.guideline .pannel .enunciation.e1.e3-7, .guideline .pannel .enunciation.e1.e3-8{
		display: none;
	}

	.guideline .pannel .subtitle{
		width: 90px;
		left: 22px;
	}

	.guideline .pannel .subtitle.s1{ top:226px; }
	.guideline .pannel .subtitle.s2{ top:486px; }
	.guideline .pannel .subtitle.s3{ top:674px; }

	.guideline .pannel .subintro.i1{ top: 130px; }
	.guideline .pannel .subintro.i2{ top: 200px; }
	.guideline .pannel .subintro.i3{ top: 275px; }
	.guideline .pannel .subintro.i4{ top: 350px; }
	.guideline .pannel .subintro.i5{ top: 420px; }
	.guideline .pannel .subintro.i6{ top: 495px; }
	.guideline .pannel .subintro.i7{ top: 565px; }
	.guideline .pannel .subintro.i8{ top: 640px; }
	.guideline .pannel .subintro.i9{ top: 715px; }

	.guideline .pannel .enunciation{
		width: 210px;
	}

	.guideline .pannel .enunciation.e2{
		left: 462px;
	}

	.guideline .pannel .enunciation.e2.e2-1{ top: 130px;  }
	.guideline .pannel .enunciation.e2.e2-2{ top: 200px;  }
	.guideline .pannel .enunciation.e2.e2-3{ top: 275px;  }
	.guideline .pannel .enunciation.e2.e2-4{ top: 350px;  }
	.guideline .pannel .enunciation.e2.e2-5{ top: 420px;  }
	.guideline .pannel .enunciation.e2.e2-6{ top: 495px;  }
	.guideline .pannel .enunciation.e2.e2-7{ top: 565px;  }
	.guideline .pannel .enunciation.e2.e2-8{ top: 640px;  }
	.guideline .pannel .enunciation.e2.e2-9{ top: 715px;  }

	.guideline .pannel .enunciation.e3{
		display: none;
	}

	.guideline .pannel .explain{
		width: 140px;
		left: 494px;
		top: 710px;
	}

	.paradigm .pannel .item .intro{
		width: 618px;
		top: 150px;
	}

	.paradigm .pannel .item .menu{
		top: 286px;
	}

	.paradigm .pannel .item .introduce{
		width: 170px;
		line-height: 1.3;
	}

	.paradigm .pannel .item .menu.m1-1{
		left: 36px;
	}
	.paradigm .pannel .item .introduce.i1-1{ left:36px; top: 466px; }

	.paradigm .pannel .item .menu.m1-2{ left: 250px; }

	.paradigm .pannel .item .menu.m1-3{
		left: 568px;
	}

	.paradigm .pannel .item .benefit{
		left: 250px;
	}

	.paradigm .pannel .item .benefit.b1-1{ top: 356px; }
	.paradigm .pannel .item .benefit.b1-2{ top: 426px; }
	.paradigm .pannel .item .benefit.b1-3{ top: 500px; }
	.paradigm .pannel .item .benefit.b1-4{ top: 576px; }
	.paradigm .pannel .item .benefit.b1-5{ top: 644px; }

	.paradigm .pannel .item .result{
		left: 350px;
	}

	.paradigm .pannel .item .result.r1{
		top: 716px;
	}

	.paradigm .pannel .item .money{
		left: 556px;
	}

	.paradigm .pannel .item .money.m1-1{ top: 356px; }
	.paradigm .pannel .item .money.m1-2{ top: 426px; }
	.paradigm .pannel .item .money.m1-3{ top: 500px; }
	.paradigm .pannel .item .money.m1-4{ top: 576px; }
	.paradigm .pannel .item .money.m1-5{ top: 644px; }

	.paradigm .pannel .item .settlement{
		left: 570px;
	}

	.paradigm .pannel .item .settlement.s1{ top: 710px; }

	.paradigm .pannel .item .menu.m2-2{ left: 250px; }
	.paradigm .pannel .item .menu.m2-3{ left: 568px }

	.paradigm .pannel .item .introduce.i2-1{ top: 340px; }
	.paradigm .pannel .item .introduce.i2-2{ top: 420px; }
	.paradigm .pannel .item .introduce.i2-3 { top: 670px; }
	.paradigm .pannel .item .introduce.i2-4 { top: 934px; }

	.paradigm .pannel .item .benefit.b2-1{ top: 352px; }
	.paradigm .pannel .item .benefit.b2-2{ top: 424px; }
	.paradigm .pannel .item .benefit.b2-3{ top: 500px; }
	.paradigm .pannel .item .benefit.b2-4{ top: 572px; }
	.paradigm .pannel .item .benefit.b2-5{ top: 646px; }
	.paradigm .pannel .item .benefit.b2-6{ top: 720px; }
	.paradigm .pannel .item .benefit.b2-7{ top: 796px; }
	.paradigm .pannel .item .benefit.b2-8{ top: 868px; }
	.paradigm .pannel .item .benefit.b2-9{ top: 958px; }

	.paradigm .pannel .item .result.r2{ top: 1048px; }

	.paradigm .pannel .item .money.m2-1{ top: 352px; }
	.paradigm .pannel .item .money.m2-2{ top: 424px; }
	.paradigm .pannel .item .money.m2-3{ top: 500px; }
	.paradigm .pannel .item .money.m2-4{ top: 572px; }
	.paradigm .pannel .item .money.m2-5{ top: 646px; }
	.paradigm .pannel .item .money.m2-6{ top: 720px; }
	.paradigm .pannel .item .money.m2-7{ top: 796px; }
	.paradigm .pannel .item .money.m2-8{ top: 868px; }
	.paradigm .pannel .item .money.m2-9{ top: 958px; }

	.paradigm .pannel .item .settlement.s2{ top: 1048px; }




	.pagebottom{
		width: 1400px;
		padding-top: 120px;
		margin: 0 calc(50% - 700px);
	}

	.pagebottom h1{
		font-size: 24px;
	}


	footer .memo a.tel{
		width: calc(491px * 0.8);
	}

	footer .memo .askrelax a{
		margin: 0 10px;
	}

	footer .memo .askrelax a img.ask{
		width: calc(220px * 0.8);
	}

	footer .memo .askrelax a img.relax{
		width: calc(220px * 0.8);
	}

	footer .memo a.open{
		left: calc(50% + 200px);
	}
}

/*小於等於1160*/
@media (max-width: 1160px) {

	
}

/*小於等於1024*/
/* pad default */
@media (max-width: 1024px) {

	.lihsi-desktop{
		display: none !important;
	}

	.lihsi-mobile{
		display: block !important;
	}

	header .collection{
		align-items: center;
	}

	header .collection .sub-logo{
		display: none;
	}

	header .collection .product{
		display: flex !important;
		justify-content: flex-end;
		align-items: center;
	}

	header .collection .product a{
		color: #db0f46;
	}

	.kv .theater{
		min-height: 165vw;
	}

	.kv .theater .pd-logo{
		display: block;
		position: absolute;
		width: 30vw;
		top: 4vw;
		left: 5.5vw;
	}

	.kv .theater .ill-tree{
		display: none;
	}

	.kv .theater .ill-tree-right{
		display: block;
		right: -10px;
		width: 50vw;
	}

	.kv .theater .ill-slogan{
		width: 90vw;
		top: 17vw;
		left: 5vw;
		margin: 0 auto;
	}

	.kv .theater .ill-subslogan{
		width: 85vw;
		top: 30vw;
		left: 5vw;
	}

	.kv .theater .ill-feature-1{
		width: 65vw;
		left: 30vw;
		top: 47vw;
	}

	.kv .theater .ill-feature-2{
		width: 65vw;
		left: 30vw;
		top: 65vw;
	}

	.kv .theater .ill-feature-3{
		width: 65vw;
		left: 30vw;
		top: 83vw;
	}

	.kv .theater .ill-cycle{
		width: 86vw;
		top: 105vw;
		left: 7vw;
	}

	.kv .theater .ill-oldman{
		width: 60vw;
		left: -26vw;
		top: 39vw;
	}

	.kv .theater .ill-cloud{
		display: none;
	}

	.kv .theater .ill-feature{
		display: block;
		width: 80vw;
		top: 130vw;
		left: 10vw;
	}

	.kv .theater .ill-leaf{
		display: block;
		width: 29%;
		top: 40vw;
		left: 3vw;
	}

	.kv .theater p.extra{
		width: 100%;
		left: 0;
		top: 150vw;
		bottom: auto;
		text-align: center;
		font-size: 3vw;
	}

	.kv .summary .day{
		display: none;
	}

	.kv .summary .furture{
		display: none;
	}

	.kv .theater .clapperboard{
		display: none;
	}

	.kv .theater .ill-bridge{
		display: none;
	}

	.kv .summary{
		padding: 15px 0;
	}

	.kv .summary .tel{
		display: block;
	}

	.pagebottom h1{
		font-size: 36px;
		text-align: center;
	}

	.demand{
		display: block;
	}

	.poplayout{
		width: 90%;
		padding: 50px 0px 50px 0;
	}

	.poplayout a.closebtn{
		width: 35px;
		height: 35px;
	}

}

/*小於等於992*/
@media (max-width: 992px) {

}

/*小於等於960*/
@media (max-width: 960px) {

	.popinner{
		max-width: auto;
		width: 100%;
	}

	.popinner span.title{
		padding: 10px 15px;
		font-size: 28px;
	}

	.popinner .info{
		display: block;

		padding: 30px 25px;
	}

	.popinner .info .content{
		width: 100%;
		flex: none;

		font-size: 26px;
		line-height: 34px;
		text-align: center;
	}

	.popinner .info .people{
		display: inline-block;
		width: 100%;
		text-align: center;
	}

	.popinner .info .people img{
		width: auto;
		margin: 0 auto;
	}

	.popinner .btn{
		width: 320px;
		margin: 0 auto;
	}

	.popinner .btn a{
		font-size: 24px;
	}

	.popinner .btn a img{
		width: 30px;
	}

	.popinner .memo{
		padding: 30px;
	}

	footer .memo a.tel{
		width: calc(491px * 0.65);
	}

	footer .memo a.open{
		width: 140px;
		left: calc(50% + 180px);
	}

	footer .memo .askrelax a{
		margin: 0 8px;
	}

	footer .memo .askrelax a img.ask{
		width: calc(220px * 0.7);
	}

	footer .memo .askrelax a img.relax{
		width: calc(220px * 0.7);
	}

	footer .detail .extra{
		display: inline-block;
		width: 100%;
		padding-right: 0;
		padding-bottom: 5px;
	}
}

/*小於等於768*/
@media (max-width: 768px) {

	.mobile-nopadding{
		padding: 0 !important;
	}

	.kv .theater .product-logo{
		width: calc(177px * 0.9);
		top: 40px;
		left: calc(50% - 275px);
	}

	.kv .theater img.main-bg{
		width: 768px;
		margin-top: 0;
	}

	.kv .theater .slogan-sub{
		top: 50px;
	}

	.kv .theater .slogan-dash{
		top: 136px;
	}

	.kv .theater .slogan-main{
		width: calc(644px * 0.9);
		top: 145px;
		left: calc(50% - 280px);
	}

	.kv .theater .outline{
		top: 262px;
		width: calc(452px * 0.9);
		left: calc(50% - 280px);
	}

	.kv .theater .woman{
		top: 520px;
	}

	.kv .theater .man{
		top: 500px;
	}

	.kv .theater .heart1{
		bottom: 0px;
		top: 425px;
		left: calc(50% + 246px);
	}

	.kv .theater .heart2{
		bottom: 0px;
		top: 445px;
		left: calc(50% + 260px);
	}

	.kv .theater .heart3{
		bottom: 0px;
		top: 465px;
		left: calc(50% + 242px);
	}

	.kv .theater .talk{
		top: 580px;
	}

	.kv .theater .clapperboard{
		bottom: 100px;
	}

	/*
	.kv .leaf-bg{
		display: none;
	}
	*/

	.paradigm{
		z-index: 2;
	}

	footer .memo{
		border-bottom: 0px;
	}

	footer .detail{
		margin-bottom: 80px;
		line-height: 22px;
	}

	

}

/*小於等於575*/
/*mobile*/
@media (max-width: 575px) {

	.lihsi-mobile-extra{
		display: block !important;
	}

	.lihsi-no-mobile-extra{
		display: none !important;
	}

	.demand{
		padding: 50px 0 40px 0;
	}

	.demand .pannel{
		width: 360px;
		height: 460px;
		padding: 80px 30px 0 30px;
		background: url("../images/demand_m_pannel.png") no-repeat top center;
		background-size: 100% auto;
	}

	.demand .pannel .group{
		padding-bottom: 13px;

		font-size: 18px;
	}

	.demand .pannel .group span.title{
		padding-right: 10px;
		font-size: 18px;
		min-width: 60px;
	}

	.demand .pannel .group .item:first-child{
		padding-right: 10px;
	}

	.demand .pannel .group label.forsex{
		padding-right: 15px;
		font-size: 18px;
	}

	.demand .pannel .group input[type='text']{
		font-size: 18px;
		/*height: 28px;*/
		height: 34px;
	}

	.demand .pannel .group select{
		width: 80px;
		/*height: 28px;*/
		height: 34px;

		font-size: 18px;
	}


	.demand .pannel .group input[type='radio']{
		width: 30px;
		height: 30px;
		margin-right: 5px;
	}

	.demand .pannel .group input[type='radio']:checked::after{
		width: 26px;
		height: 26px;
	}

	.demand .pannel .group label.agreement{
		margin-bottom: 0px;
		line-height: 20px;
		cursor: pointer;
		font-size: 18px;
		-webkit-user-select: none;
		-moz-user-select: none;
		-ms-user-select: none;
		user-select: none;
	}

	.demand .pannel .group label.agreement input[type='checkbox']{
		width: 30px;
		height: 30px;

		margin-top: 0px;
	}

	.demand .pannel .group label.agreement input[type='checkbox']:checked::after{
		width: 26px;
		height: 26px;
	}

	.demand .pannel .group .zip{
		width: 40px;
	}

	.demand .pannel .group label.agreement .memo{
		padding-left: 10px;
		line-height: 22px;
		letter-spacing: 2px;
		font-size: 14px;
		letter-spacing: 0;
	}

	.demand .pannel .sendbtn a{
		width: calc(307px * 0.6);
		height: calc(93px * 0.6);
		
	}

	.demand .warning{
		padding-top: 20px;
		width: 360px;
		font-size: 18px;
	}

	.popinner span.title{
		padding: 10px 15px;
		font-size: 22px;
	}

	.popinner .info{
		display: block;

		padding: 20px 20px;
	}

	.popinner .info .content{

		padding-top: 20px;

		font-size: 18px;
		line-height: 26px;
		text-align: left;
	}

	.popinner .info .people img{
		max-width: 160px;
	}

	.popinner .sharegroup .item img{
		width: 60px;
		margin: 0 auto;
	}

	.popinner .btn{
		width: 240px;
	}

	.popinner .btn a{
		font-size: 22px;
	}

	.popinner .btn a img{
		width: 20px;
	}

	.popinner .memo{
		padding: 20px;
		line-height: 22px;
	}
}

@media (max-width: 480px) {

	.container-sub{
		width: 100%;
	}

	.container-base{
		width: 100%;
	}

	.container-header{
		padding: 0;
	}

	header .collection .logo{
		padding-top: 0px;
		margin-top: -2px;
		margin-bottom: -2px;
	}

	header .collection .product a{
		background-position: top 15% center !important;
	}

	header .collection .product a.pd{
		background-size: 28px 28px !important;
	}

	header .collection .product a.kn{
		background-size: 28px 28px !important;
	}

	.mainpoint .unit-title{
		padding-top: 30px;
		width: 80vw;
	}

	.mainpoint p.unit-title-memo{
		margin-bottom: 5px;
		font-size: 12px;
		font-weight: bold;
		text-align: left;
		letter-spacing: 0;
	}

	.mainpoint .scenario{
		padding-top: 30px;
	}

	.mainpoint .scenario .item{
		margin-bottom: 10px;
	}

	.mainpoint .scenario .item .role{
		margin-bottom: -6vw;
	}

	.mainpoint .scenario .item .cover{
		width: 14vw;
		margin-left: 3vw;
	}

	.mainpoint .scenario .item .title{
		width: 72vw;
		margin-left: 2vw;
	}

	.mainpoint .scenario .item .detail{
		padding: 20px 15px 10px 15px
	}

	.mainpoint .scenario .item .detail .research{
		line-height: 1.5;
		font-size: 18px;
		padding-top: 15px;
		padding-bottom: 0px;
	}

	.mainpoint .scenario .item .detail .research.spec{
		padding-top: 0px;
	}


	.mainpoint .scenario .item .detail .commentary .memo{
		display: none;
		padding-bottom: 10px;
		line-height: 1.3;
		font-size: 18px;
	}

	.mainpoint .scenario .item .detail .nervous .icon{
		width: 80px;
	}

	.mainpoint .scenario .item .detail .nervous .memo{
		padding-left: 5px;
		font-size: 18px;
	}

	.mainpoint .scenario .item .detail .nervous .memo span.heavy{
		font-size: 26px;
	}

	.mainpoint .scenario .item .detail .cosplay{
		align-items: center;
		padding-bottom: 0;
	}

	.mainpoint .scenario .item .detail .cosplay .cover{
		width: 14vw;
		margin-left: 9.5vw;
	}

	.mainpoint .scenario .item .detail .cosplay .title{
		width: 72vw;
		margin-left: 2vw;
	}

	.calculate{
		padding-top: 40px;
	}

	.calculate .maincontent .headline .calculate-title{
		width: 200px;
	}

	.calculate .maincontent .headline .icon.icon-1{
		width: 30px;
		top: 20px;
		left: calc(50% - 140px);
	}

	.calculate .maincontent .headline .icon.icon-2{
		width: 30px;
		top: 18px;
		left: calc(50% + 110px);
	}

	.calculate .step{
		width: 330px;
	}

	.calculate .step .formobj .formdetail .sex .item{
		width: 140px;
		padding: 10px 20px 10px 5px;
	}

	.calculate .step .formobj .formdetail .item.male:after{
		width: calc(68px * 0.7);
		height: calc(68px * 0.7);
	}

	.calculate .step .formobj .formdetail .item.female:after{
		width: calc(68px * 0.7);
		height: calc(68px * 0.7);
	}

	.calculate .step .formobj .plan .item label .cover{
		width: 70px;
		margin: 0 auto;
	}

	.guideline{
		padding-top: 40px;
	}

	.guideline .unit-title{
		max-width: 220px;
		padding-bottom: 10px;
	}

	.guideline .pannel .dialog{
		left: 304px;
		top: -34px;
		width: 60px;
	}

	.guideline .pannel .headtitle.t1{
		left: 92px;
		top: 20px;
		font-size: 16px;
	}

	.guideline .pannel .headtitle.t3{
		font-size: 13px;
		left: 234px;
		top: 20px;
	}

	.guideline .pannel .headtitle span.heavy{
		font-size: 18px;
	}

	.guideline .pannel .subtitle{
		width: 40px;
		left: 13px;
		font-size: 16px;
	}

	.guideline .pannel .subtitle.s1{ top: 110px; }
	.guideline .pannel .subtitle.s2{ top: 235px; }
	.guideline .pannel .subtitle.s3{ top: 334px; }

	.guideline .pannel .subintro{
		left: 60px;
		font-size: 14px;
	}

	.guideline .pannel .subintro span.extra{
		font-size: 11px;
	}

	.guideline .pannel .subintro.i1{ top: 60px; }
	.guideline .pannel .subintro.i2{ top: 95px; }
	.guideline .pannel .subintro.i3{ top: 134px; }
	.guideline .pannel .subintro.i4{ top: 170px; width: 164px; }
	.guideline .pannel .subintro.i5{ top: 208px; }
	.guideline .pannel .subintro.i6{ top: 244px; }
	.guideline .pannel .subintro.i7{ top: 280px; }
	.guideline .pannel .subintro.i8{ top: 316px; }
	.guideline .pannel .subintro.i9{ top: 350px; }

	.guideline .pannel .enunciation.e2{
		left: 232px;
		width: 102px;

		font-size: 16px;
	}

	.guideline .pannel .enunciation.e2.e2-1{ top:60px; }
	.guideline .pannel .enunciation.e2.e2-2{ top:96px; }
	.guideline .pannel .enunciation.e2.e2-3{ top:134px; }
	.guideline .pannel .enunciation.e2.e2-4{ top:170px; }
	.guideline .pannel .enunciation.e2.e2-5{ top:208px; }
	.guideline .pannel .enunciation.e2.e2-6{ top:244px; }
	.guideline .pannel .enunciation.e2.e2-7{ top:280px; }
	.guideline .pannel .enunciation.e2.e2-8{ top:316px; }
	.guideline .pannel .enunciation.e2.e2-9{ top:350px; }

	.guideline .pannel .explain{
		left: 231px;
		top: 350px;
		width: 102px;
		font-size: 14px;
	}

	.guideline .pannel .explain span.extra{
		font-size: 11px;
	}

	.guideline .memo{
		font-size: 11px;
	}


	.paradigm{
		padding-top: 40px;
	}

	.guideline .pannel{
		width: 350px;
		margin: 0 auto;
	}

	.guideline .nt{
		width: 350px;
		margin: 0 auto;
		font-size: 11px;
	}

	.paradigm .unit-title{
		max-width: 220px;
		padding-bottom: 10px;
	}

	.paradigm .foreword{
		font-size: 14px;
		padding-bottom: 10px;
	}

	.paradigm .pannel{
		width: 350px;
		margin: 0 auto;
	}

	.paradigm .pannel .item .carte{
		top: 20px;
	}

	.paradigm .pannel .item .carte .ex{
		width: 80px;
	}

	.paradigm .pannel .item .carte .alias{
		width: 210px;
	}

	.paradigm .pannel .item .intro{
		top: 68px;
		width: 332px;
		left: 10px;
		font-size: 13px;
	}

	.paradigm .pannel .item .menu{
		top: 138px;
		font-size: 14px;
	}

	.paradigm .pannel .item .menu.m1-1{
		left: 12px;
	}

	.paradigm .pannel .item .menu.m1-2{
		left: 120px
	}

	.paradigm .pannel .item .menu.m1-3{
		left: 272px
	}

	.paradigm .pannel .item .menu.m2-2{
		left: 272px;
	}

	.paradigm .pannel .item .introduce{
		width: 102px;
		font-size: 10px;
	}

	.paradigm .pannel .item .introduce span.heavy{
		font-size: 12px;
	}

	.paradigm .pannel .item .introduce.i1-1{ top: 228px; left: 12px; }

	.paradigm .pannel .item .introduce.i2-1{ top: 168px; left: 12px; }
	.paradigm .pannel .item .introduce.i2-2{ top: 202px; left: 12px; }
	.paradigm .pannel .item .introduce.i2-3{ top: 324px; left: 12px; }

	.paradigm .pannel .item .introduce.i2-4{ top: 464px; left: 12px; }

	.paradigm .pannel .item .benefit{
		left: 120px;
		font-size: 15px;
	}

	.paradigm .pannel .item .benefit.b1-1{ top: 174px; }
	.paradigm .pannel .item .benefit.b1-2{ top: 210px; }
	.paradigm .pannel .item .benefit.b1-3{ top: 248px; }
	.paradigm .pannel .item .benefit.b1-4{ top: 284px; }
	.paradigm .pannel .item .benefit.b1-5{ top: 320px; }

	.paradigm .pannel .item .benefit.b2-1{ top: 174px; }
	.paradigm .pannel .item .benefit.b2-2{ top: 210px; }
	.paradigm .pannel .item .benefit.b2-3{ top: 248px; }
	.paradigm .pannel .item .benefit.b2-4{ top: 284px; }
	.paradigm .pannel .item .benefit.b2-5{ top: 320px; }
	.paradigm .pannel .item .benefit.b2-6{ top: 356px; }
	.paradigm .pannel .item .benefit.b2-7{ top: 394px; }
	.paradigm .pannel .item .benefit.b2-8{ top: 430px; }
	.paradigm .pannel .item .benefit.b2-9{ top: 476px; }


	.paradigm .pannel .item .money{
		left: 250px;
		font-size: 16px;
	}

	.paradigm .pannel .item .money.m1-1{ top: 174px; }
	.paradigm .pannel .item .money.m1-2{ top: 210px; }
	.paradigm .pannel .item .money.m1-3{ top: 248px; }
	.paradigm .pannel .item .money.m1-4{ top: 284px; }
	.paradigm .pannel .item .money.m1-5{ top: 320px; }

	.paradigm .pannel .item .money.m2-1{ top: 174px; }
	.paradigm .pannel .item .money.m2-2{ top: 210px; }
	.paradigm .pannel .item .money.m2-3{ top: 248px; }
	.paradigm .pannel .item .money.m2-4{ top: 284px; }
	.paradigm .pannel .item .money.m2-5{ top: 320px; }
	.paradigm .pannel .item .money.m2-6{ top: 356px; }
	.paradigm .pannel .item .money.m2-7{ top: 394px; }
	.paradigm .pannel .item .money.m2-8{ top: 430px; }
	.paradigm .pannel .item .money.m2-9{ top: 476px; }

	.paradigm .pannel .item .result{
		left: 162px;
		font-size: 14px;
	}

	.paradigm .pannel .item .result.r1{ top: 352px; }
	.paradigm .pannel .item .result.r2{ top: 522px; }

	.paradigm .pannel .item .settlement{
		left: 276px;
		font-size: 16px;
	}

	.paradigm .pannel .item .settlement.s1{ top: 352px; }
	.paradigm .pannel .item .settlement.s2{ top: 522px; }

	.paradigm .pannel a.arrow-paradigm{
		width: 30px;
		top: 150px;
	}

	.paradigm .pannel a.arrow-paradigm.arrow-left{ left: -20px; }
	.paradigm .pannel a.arrow-paradigm.arrow-right{ right: -20px; }

	.paradigm .nt{
		width: 350px;
		margin: 0 auto;
		font-size: 11px;
	}

	.pagebottom{
		width: 500px;
		margin: 0 calc(50% - 250px);
		padding-top: 100px;
		text-align: center;
	}

	.calculate .step .formobj .formtitle{
		font-size: 16px;
	}

	.calculate .step .formobj .formdetail.spare-age{
		width: 80px;
		padding-right: 10px;
	}

	.calculate .step .formobj .formdetail input[type='text']{
		font-size: 16px;
		padding: 5px;
	}

	.calculate .step .formobj .formdetail .age select{
		font-size: 16px;
		padding: 7px 10px 7px 5px;
		background-size: 10px 8px;
	}

	.calculate .step .formbtn a{
		width: 180px;
	}

	.demand{
		padding-bottom: 0;
	}

	.pagebottom h1{
		font-size: 18px;
	}

	.stickybottom.sci a{
		width: 40%;
		padding: 10px;
		margin: 0 5px;
		font-size: 22px;
	}

	.stickybottom a img{
		width: 26px;
		margin-right: 3px;
	}

}

/*小於等於414*/
@media (max-width: 414px) {

}

/*小於等於350*/
@media (max-width: 350px) {

	.quick a{
		padding: 10px 10px;
	}

}