@charset 'utf-8';

/**********************************************
public*/
.equipment,.equipment h5 {
	font-size: 21px;
	color: #757575;
}
.equipment .h1 {
	font-size: 3.81em;
    line-height: 1.3;
	letter-spacing: -0.01em;
}
.equipment .h2 {
	font-size: 1.524em;
}
.equipment p {
	line-height: 1.6;
	word-break: keep-all;
}
.equipment .strong-color {
	color: #1D1D1F;
}
.ts-box > strong {
	display: block;
    margin-bottom: 0.7em;
	line-height: 1.2;
}
.maxframe-absolute {
	position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 1920px;
    margin-left: -960px;
}
.sBox-content {
	position: relative;
	z-index: 10;
}
.sub-txt-box {
	margin-top: 50px;
}
.minframe.large-frame {
	max-width: 1460px;
}
.sticky-wrap {
    top: 0;
    left: 0;
    right: 0;
}
.sticky-wrap.sticky {
    position: fixed;
}
.blue {
	color: #2352C1;
}
/**********************************************
section */
.scroll-section {
	position: relative;
	padding-top: 200px;
	padding-bottom: 200px;
}
#scroll-section-0 {
	height: 1250px;
	padding-top: 150px;
	padding-bottom: 0;
    z-index: 100;
}
#scroll-section-0 .sub-txt {
	max-width: 480px;
	margin: 50px auto 0;
	font-size: 1.714em;
}
#scroll-section-0 .device-img {
    position: absolute;
    width: 1648px;
    height: 1062px;
	bottom: -235px;
    left: 50%;
    background: center / contain url(/assets/img/igraft/device-left.png) no-repeat;
    margin-left: -724px;
	opacity: 0;
}
#scroll-section-0 .logo,
#scroll-section-0 .sub-txt {
    opacity: 0;
    transform: translateY(50px);
}
#scroll-section-0 .logo {
	animation: fade-in 1s ease-out 0s 1 forwards;
}
#scroll-section-0 .sub-txt {
    animation: fade-in 1s ease-out 0.3s 1 forwards;
}
#scroll-section-0 .device-img {
    animation: fade-in 1s ease-out 0.6s 1 forwards;
}
#scroll-section-1 {
    padding-top: 424px;
    background: linear-gradient(to bottom, #F5F5F7, #FFFFFF);
	overflow: hidden;
}
#scroll-section-1 .h1 {
    position: absolute;
    top: -5vh;
    left: 30px;
	text-align: left;
	color: #A4A4A4;
}
#scroll-section-1 .h1 b {
	display: block;
}
#scroll-section-1 .h2 {
	position: absolute;
    bottom: 7vh;
    left: 0;
    right: 0;
	opacity: 0;
    transform: translateY(50px);
}
#scroll-section-1 .h2 b {
	color: #3172C5;
}
#scroll-section-1.on .h2 {
	animation: fade-in 1s ease-out 1.5s 1 forwards;
}
#scroll-section-1 .sticky-wrap .sticky-inner {
	position: relative;
	height: 100vh;
}
#scroll-section-1 .sticky-wrap .sticky-device-item {
    position: absolute;
	width: 100%;
    height: 100%;
    top: 0;
    left: 0;
	opacity: 0;
}
#scroll-section-1 .sticky-wrap .sticky-device-item.active {
	opacity: 1;
}
#scroll-section-1 .size-circle {
	position: relative;
}
#scroll-section-1 .item-a .size-circle figure {
	position: absolute;
	top: 50%;
	left: 50%;
    background-color: rgba(49, 114, 197, 0.25);
	border-radius: 50%;
    text-align: center;
	font-weight: 200;
	color: #fff;
	opacity: 0;
	transform: translate(-50%, -50%) scale(0.7);
	transition-property: all;
    transition-duration: 0.2s;
    transition-timing-function: ease-out;
}
#scroll-section-1 .sticky-device-item.active.item-a .size-circle figure {
	opacity: 1;
	transform: translate(-50%, -50%) scale(1);
}
.item-a.active .size-circle .sc-1 {
	width: 89px;
	height: 89px;
	font-size: 0.9524em;
	z-index: 40;
	transition-delay: 0s;
}
.item-a.active .size-circle .sc-2 {
	width: 225px;
	height: 225px;
	font-size: 1.143em;
	z-index: 30;
	transition-delay: 0.3s;
}
.item-a.active .size-circle .sc-3 {
	width: 383px;
	height: 383px;
	font-size: 1.35em;
	z-index: 20;
	transition-delay: 0.6s;
}
.item-a.active .size-circle .sc-4 {
	width: 543px;
	height: 543px;
	font-size: 1.35em;
	transition-delay: 0.9s;
}
.item-a .size-circle figcaption {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	margin-top: -0.5em;
	line-height: 1em;
}
.item-a .size-circle .sc-2 figcaption {
	left: calc(50% + 44.5px);
}
.item-a .size-circle .sc-3 figcaption {
	left: calc(50% + 112.5px);
}
.item-a .size-circle .sc-4 figcaption {
	left: calc(50% + 191.5px);
}

.item-b .size-circle figure {
    padding: 0 20px;
	opacity: 0;
    transform: translateY(50px);
}
.item-b.active .size-circle .sc-1 {
	animation: fade-in 1s ease-out 0s 1 forwards;
}
.item-b.active .size-circle .sc-2 {
	animation: fade-in 1s ease-out 0.3s 1 forwards;
}
.item-b.active .size-circle .sc-3 {
	animation: fade-in 1s ease-out 0.6s 1 forwards;
}
.item-b.active .size-circle .sc-4 {
	animation: fade-in 1s ease-out 0.9s 1 forwards;
}
#scroll-section-1 .item-b .size-circle figcaption {
	display: block;
	margin-top: 30px;
	font-size: 1.429em;
	color: #6E6E73;
}

#scroll-section-2 {
	text-align: left;
	height: 1580px;
	background: linear-gradient(to bottom, #EFF6FF, #B6D1F1);
}
#scroll-section-2 .device-img {
	position: absolute;
    bottom: 0;
    left: 50px;
    width: 1714px;
    height: 1129px;
    background: center / contain url(/assets/img/igraft/device-right.png) no-repeat;
    transform: translateY(50px);
    opacity: 0;
}
#scroll-section-2 .device-img .label {
	position: absolute;
    top: 5%;
    right: 28%;
    border-radius: 50em;
    text-align: left;
	font-weight: 500;
	line-height: 1.6;
    opacity: 0;
}
#scroll-section-2 .device-img .label .line {
	content: '';
	position: absolute;
	top: 115%;
    left: 50%;
	width: 1px;
	height: 0;
	bottom: 0;
	background-color: #757575;
	transition: height 1s 0.3s ease-out;
}
#scroll-section-2 .device-img .label .line:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left: -2.5px;
	width: 5px;
	height: 5px;
	border-radius: 50em;
	background-color: #707070;
}
#scroll-section-2.on .device-img {
	animation: fade-in 1s ease-out 0s 1 forwards;
}
#scroll-section-2.on .device-img .label {
	animation: fade-in 1s ease-out 0.3s 1 forwards;
}
#scroll-section-2.on .device-img .label .line  {
	height: 330px;
}
.caution-section {
    position: relative;
    padding-top: 200px;
    padding-bottom: 200px;
    background-color: #fff;
    z-index: 10;
}
.caution-section h3 {
	font-size: 2.571em;
}
.caution-section .cautionS-info-table {
    width: 100%;
    margin: 95px auto 85px;
	table-layout: fixed;
}
.cautionS-info-table tbody th,
.cautionS-info-table tbody td {
	padding: 17px;
	border-top: 2px solid #D6D6D6;
	border-right: 2px solid #D6D6D6;
}
.cautionS-info-table th {
	color: #1D1D1F;
}
.cautionS-info-table tbody th {
	font-weight: 500;
}
.cautionS-info-table tbody tr:nth-child(2n){
	background-color: #F5F5F7;
}
.cautionS-info-table tbody td:last-child {
    padding-left: 100px;
	border-right: 0;
    text-align: left;
}
.cautionS-info-table {
	border-bottom: 2px solid #D6D6D6;
}
.caution-section .caution-content {
    margin: 0 auto;
    background-color: #F5F5F7;
    padding: 65px 30px;
}
.caution-section .caution-content > .inner {
	max-width: 870px;
    margin: 0 auto;
}
.caution-section .caution-content .caution-tit {
	display: block;
	margin-bottom: 45px;
	word-break: keep-all;
}
.caution-section .caution-content p {
	text-align: left;
    padding-left: 0.8rem;
	margin-top: 20px;
}
.caution-section .caution-content p .strong-color {
	display: block;
	margin-bottom: 5px;
}

/**********************************************
responsibiliy*/
@media (max-width: 1024px){
	.equipment,.equipment h5 {
		font-size: 20px;
	}
	.equipment .h1 {
		font-size: 3.2em;
	}
	.equipment .h2 {
		font-size: 1.4em;
	}
	.scroll-section {
		padding-top: 180px;
	    padding-bottom: 180px;
	}
	.sub-txt-box {
		margin-top: 30px;
	}
	#scroll-section-1 .h1 {
	    top: 13vh;
	}
	#scroll-section-1 .h2 {
		bottom: 11vh;
	}
}
@media (max-width: 767px){
	.minframe,
	.minframe.large-frame {
		max-width: 500px;
	}
	.equipment,.equipment h5 {
		font-size: 16px;
	}
	.equipment .h1 {
		font-size: 2.188em;
	}
	.equipment .h2 {
		font-size: 1.344em;
	}
	.scroll-section {
		padding-top: 100px;
	    padding-bottom: 100px;
	}
	.sub-txt-box {
		margin-top: 10px;
	}
	.maxframe-absolute {
		width: 100%;
		margin: 0;
		left: 0;
	}
	.br {
		display: inline-block;
	}
	#scroll-section-0 {
		height: 550px;
		padding-top: 60px;
	}
	#scroll-section-0 .logo img {
		max-height: 72px;
	}
	#scroll-section-0 .sub-txt {
		margin-top: 30px;
		font-size: 1.344em;
	}
	#scroll-section-0 .device-img {
		width: 600px;
		height: 386.6px;
		left: 50%;
		bottom: -100px;
		margin-left: -310px;
	}
	#scroll-section-1,
	#scroll-section-1 .sticky-wrap .sticky-inner,
	#scroll-section-1 .sticky-wrap .sticky-device-item {
		min-height: 600px;
	}
	#scroll-section-1 {
		padding-top: 200px;
	}
	#scroll-section-1 .h1 {
	    top: 5vh;
	}
	#scroll-section-1 .sticky-wrap .sticky-device-item {
		max-width: 500px;
		left: 50%;
		transform: translateX(-50%);
	}
	.item-a.active .size-circle .sc-1 {
		width: 45px;
		height: 45px;
	}
	.item-a.active .size-circle .sc-2 {
		width: 112px;
		height: 112px;
	}
	.item-a.active .size-circle .sc-3 {
		width: 190px;
		height: 190px;
	}
	.item-a.active .size-circle .sc-4 {
		width: 270px;
		height: 270px;
	}
	.item-a .size-circle figcaption {
		font-size: 0.8em;
	}
	.item-a .size-circle .sc-2 figcaption {
		left: calc(50% + 22.5px);
	}
	.item-a .size-circle .sc-3 figcaption {
		left: calc(50% + 56px);
	}
	.item-a .size-circle .sc-4 figcaption {
		left: calc(50% + 95px);
	}
	#scroll-section-1 .item-b .size-circle {
		padding: 0 15px;
	}
	.item-b .size-circle figure {
	    padding: 0 5px;
	}
	.item-b .size-circle figure.sc-1 img {
		max-height: 40px;
	}
	#scroll-section-1 .item-b .size-circle figcaption {
		margin-top: 20px;
		font-size: 0.8em;
	}

	#scroll-section-2 {
		height: auto;
	}
	#scroll-section-2 .maxframe-absolute {
		position: relative;
		top: auto;
		padding-bottom: 150%;
	}
	#scroll-section-2 .device-img {
		width: 180%;
		height: 0;
		padding-bottom: 118.5%;
		bottom: 60px;
		right: auto;
		left: 50%;
		margin-left: -82%;
	}
	#scroll-section-2 .device-img .label {
		top: 40%;
		right: 30%;
		text-align: right;
		margin-top: 220px;
	}
	#scroll-section-2 .device-img .label:after {
		content: '';
		top: 100%;
		left: 50%;
		width: 2px;
		transition: height 1s 0.3s ease-out;
	}
	#scroll-section-2 .device-img .label .line {
		top: auto;
		bottom: 100%;
	    left: auto;
		right: 20%;
	}
	#scroll-section-2.on .device-img .label .line {
		height: 220px;
	}
	#scroll-section-2 .device-img .label .line:after {
		top: 0;
		bottom: auto;
	}
	
	.caution-section {
		padding-top: 100px;
	    padding-bottom: 100px;
	}
	.caution-section h3 {
		 font-size: 1.842em;
		margin-bottom: 45px;
	}
	.caution-section .cautionS-info-table {
		margin-top: 0px;
	    margin-bottom: 45px;
	}
	.cautionS-info-table thead th,
	.cautionS-info-table tbody th, 
	.cautionS-info-table tbody td {
		border-top-width: 1px;
		border-right-width: 1px;
		font-size: 14px;
		text-align: left;
	}
	.cautionS-info-table {
		border-bottom-width: 1px;
	}
	.cautionS-info-table thead th {
		padding: 17px;
		background-color: #F5F5F7;
		border-top: 1px solid #D6D6D6;
		text-align: center;
	    font-size: 1.15em;
		color: #1D1D1F;
	}
	.cautionS-info-table tbody tr td:last-child {
		padding-left: 14px;
	}
	.caution-section .caution-content {
		padding: 40px 20px;
		font-size: 16px;
		text-align: left;
	}
	.caution-section .caution-content .caution-tit {
		margin-bottom: 40px;
	    line-height: 1.6;
	}
	.caution-section .caution-content p {
		padding-left: 0;
	}
	.caution-section .caution-content p .txt-small {
		font-size: 0.87em;
	}
}
@media only screen and (max-width: 767px) and (orientation: landscape) {
	#scroll-section-2 .maxframe-absolute {
		padding-bottom: 130%;
	}
	#scroll-section-2 .device-img .label .line {
	    right: 40%;
	}
}
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
}