/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New&display=swap");
*, ::before, ::after { box-sizing: border-box; border-style: solid; border-width: 0; min-width: 0; }

/* Document */
/* ============================================ */
/** 1. Correct the line height in all browsers. 2. Prevent adjustments of font size after orientation changes in iOS. 3. Remove gray overlay on links for iOS. */
html { line-height: 1.15; /* 1 */ -webkit-text-size-adjust: 100%; /* 2 */ -webkit-tap-highlight-color: transparent; /* 3*/ }

/* Sections */
/* ============================================ */
/** Remove the margin in all browsers. */
body { margin: 0; }

/** Render the `main` element consistently in IE. */
main { display: block; }

/* Vertical rhythm */
/* ============================================ */
p, table, blockquote, address, pre, iframe, form, figure, dl { margin: 0; }

/* Headings */
/* ============================================ */
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0; }

/* Lists (enumeration) */
/* ============================================ */
ul, ol { margin: 0; padding: 0; list-style: none; }

/* Lists (definition) */
/* ============================================ */
dt { font-weight: bold; }

dd { margin-left: 0; }

/* Grouping content */
/* ============================================ */
/** 1. Add the correct box sizing in Firefox. 2. Show the overflow in Edge and IE. */
hr { box-sizing: content-box; /* 1 */ height: 0; /* 1 */ overflow: visible; /* 2 */ border-top-width: 1px; margin: 0; clear: both; color: inherit; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
pre { font-family: monospace, monospace; /* 1 */ font-size: inherit; /* 2 */ }

address { font-style: inherit; }

/* Text-level semantics */
/* ============================================ */
/** Remove the gray background on active links in IE 10. */
a { background-color: transparent; text-decoration: none; color: inherit; }

/** 1. Remove the bottom border in Chrome 57- 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. */
abbr[title] { text-decoration: underline dotted; /* 2 */ }

/** Add the correct font weight in Chrome, Edge, and Safari. */
b, strong { font-weight: bolder; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
code, kbd, samp { font-family: monospace, monospace; /* 1 */ font-size: inherit; /* 2 */ }

/** Add the correct font size in all browsers. */
small { font-size: 80%; }

/** Prevent `sub` and `sup` elements from affecting the line height in all browsers. */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sub { bottom: -0.25em; }

sup { top: -0.5em; }

/* Replaced content */
/* ============================================ */
/** Prevent vertical alignment issues. */
svg, img, embed, object, iframe { vertical-align: bottom; }

/* Forms */
/* ============================================ */
/** Reset form fields to make them styleable. 1. Make form elements stylable across systems iOS especially. 2. Inherit text-transform from parent. */
button, input, optgroup, select, textarea { -webkit-appearance: none; /* 1 */ appearance: none; vertical-align: middle; color: inherit; font: inherit; background: transparent; padding: 0; margin: 0; border-radius: 0; text-align: inherit; text-transform: inherit; /* 2 */ }

/** Correct cursors for clickable elements. */
button, [type="button"], [type="reset"], [type="submit"] { cursor: pointer; }

button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled { cursor: default; }

/** Improve outlines for Firefox and unify style with input elements & buttons. */
:-moz-focusring { outline: auto; }

select:disabled { opacity: inherit; }

/** Remove padding */
option { padding: 0; }

/** Reset to invisible */
fieldset { margin: 0; padding: 0; min-width: 0; }

legend { padding: 0; }

/** Add the correct vertical alignment in Chrome, Firefox, and Opera. */
progress { vertical-align: baseline; }

/** Remove the default vertical scrollbar in IE 10+. */
textarea { overflow: auto; }

/** Correct the cursor style of increment and decrement buttons in Chrome. */
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; }

/** Correct the outline style in Safari. */
[type="search"] { outline-offset: -2px; /* 1 */ }

/** Remove the inner padding in Chrome and Safari on macOS. */
[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/** 1. Correct the inability to style clickable types in iOS and Safari. 2. Fix font inheritance. */
::-webkit-file-upload-button { -webkit-appearance: button; /* 1 */ font: inherit; /* 2 */ }

/** Fix appearance for Firefox */
[type="number"] { -moz-appearance: textfield; }

/** Clickable labels */
label[for] { cursor: pointer; }

/* Interactive */
/* ============================================ */
/* Add the correct display in Edge, IE 10+, and Firefox. */
details { display: block; }

/* Add the correct display in all browsers. */
summary { display: list-item; }

/* Remove outline for editable content. */
[contenteditable]:focus { outline: auto; }

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table { border-color: inherit; /* 1 */ border-collapse: collapse; }

caption { text-align: left; }

td, th { vertical-align: top; padding: 0; }

th { text-align: left; font-weight: bold; }

@keyframes shine-run { 0% { transform: scale(0) rotate(50deg); opacity: 0; }
  40% { transform: scale(1) rotate(50deg); opacity: 1; }
  100% { transform: scale(250) rotate(50deg); opacity: 0; } }
#mv-area { width: 100%; margin: 0; overflow: hidden; }

.merit { margin: 0; background: #281E1C; padding: 20px 0; text-align: center; }
.merit img { display: block; width: 100%; height: auto; }
@media screen and (max-width: 768px) { .merit { padding-bottom: 5px; }
  .merit img { max-width: 400px; } }

.information-area { padding: 5rem 0; position: relative; z-index: 2; /*.news{
	margin-top: 5rem;
	.info-ttl{
		@include sans;
		font-size: 1.8rem;
		line-height: 1;
		letter-spacing: .4em;
		color: #727171;
	}
	.news-contents{
		@include sans2;
		margin-top: 2rem;
		border-top:  solid 1px rgba(0,0,0,.5);
		border-bottom: solid 1px rgba(0,0,0,.5);
		padding: 3rem 5%;
		font-size: 1.5rem;
		line-height: 1.6;
		p{
			+p{
				margin-top: 2rem;
			}
		}
		.date{
			display: block;
			letter-spacing: .1em;
		}
		.txt{
			display: block;
			margin-top: 1rem;
		}
	}
}*/ }
.information-area .info-copy p { font-size: 1.6rem; line-height: 1.8; letter-spacing: .1em; color: #03415c; text-align: center; }
.information-area .info-copy p .txt-l { display: inline-block; font-size: 200%; letter-spacing: .4em; line-height: 1.2; }
.information-area .info-copy p + p { margin-top: 3rem; }
.information-area .information .information__title { margin-top: 5rem; font-family: "Noto Sans JP", sans-serif; font-size: 1.8rem; line-height: 1; letter-spacing: .4em; color: #727171; }
.information-area .information .information__text { font-family: "Zen Kaku Gothic New", sans-serif; margin-top: 2rem; border-top: solid 1px rgba(0, 0, 0, 0.5); border-bottom: solid 1px rgba(0, 0, 0, 0.5); padding: 3rem 5%; font-size: 1.5rem; line-height: 1.6; }
.information-area .conversion { margin-top: 5rem; }
.information-area .conversion ul li a { border: solid 1px #fff; }
.information-area .conversion ul li a .txt { display: block; }
.information-area .conversion ul li a .txt .en, .information-area .conversion ul li a .txt .ja { display: block; width: 100%; text-align: center; font-size: 2rem; }
.information-area .conversion ul li a .txt .ja { margin-top: 3px; }
.information-area .conversion ul li.line { display: none; }
@media screen and (max-width: 768px) { .information-area .news .news-contents { padding: 2rem 0; font-size: 1.4rem; } }

.top-concept { position: relative; padding: 10rem 0; /*&:after{
	pointer-events: none;
	content: '';
	display: block;
	width: 100%;
	height: 200%;
	background: url('../images/top/concept-bg.png') no-repeat 0% 0%;
	background-size: contain;
	position: absolute;
	top: -20%;
	left: 0;
}*/ }
.top-concept .concept-circle { position: absolute; top: -27.0%; left: 0%; width: 100%; overflow: hidden; }
.top-concept .concept-circle svg { width: 100%; height: auto; }
.top-concept .concept-circle .concept-circle-inner { width: 100%; max-width: 1400px; margin: 0 auto; position: relative; }
.top-concept .concept-circle .concept-circle-inner::before { content: ""; width: 100%; display: block; padding-bottom: 100%; }
.top-concept .concept-circle .circle-cls { position: absolute; }
.top-concept .concept-circle .circle-cls .circle-motion { transform-origin: 50% 50%; transition: stroke-dashoffset 0s ease 0.3s; }
.top-concept .concept-circle #circle-1 { top: 0; left: -9.9%; width: 69%; opacity: 0.55; z-index: 2; }
.top-concept .concept-circle #circle-1 .circle-motion { stroke-dasharray: 2323; stroke-dashoffset: 2760; transform: rotate(15deg); }
.top-concept .concept-circle #circle-2 { position: absolute; top: 11.5%; right: -9.5%; width: 69%; opacity: 0.33; z-index: 1; }
.top-concept .concept-circle #circle-2 .circle-motion { stroke-dasharray: 2323; stroke-dashoffset: 2760; transform: rotate(193deg); }
.top-concept .concept-circle.aos-animate #circle-1 .circle-motion { transition-timing-function: ease-in; transition-duration: 1s; transition-delay: 0s; stroke-dashoffset: 438; }
.top-concept .concept-circle.aos-animate #circle-2 .circle-motion { transition-timing-function: ease-out; transition-duration: 1s; transition-delay: 1s; stroke-dashoffset: 4646; }
.top-concept .inner2 { position: relative; z-index: 2; }
.top-concept img { display: block; width: 100%; height: auto; }
.top-concept .concept-ttl { max-width: 300px; margin: auto; }
.top-concept .concept-copy { margin: 5rem auto 0 auto; max-width: 680px; }
.top-concept .lead { margin-top: 3rem; text-align: center; font-size: 1.5rem; line-height: 2; }
@media screen and (max-width: 768px) { .top-concept { /*&:after{
	top: -5%;
}*/ }
  .top-concept .concept-circle { top: 7%; }
  .top-concept .concept-ttl { max-width: 240px; }
  .top-concept .concept-copy { max-width: 480px; }
  .top-concept .lead { font-size: 1.4rem; } }

.contents-link { position: relative; z-index: 2; padding: 0 0 10rem 0; }
.contents-link img { width: 100%; height: auto; }
.contents-link ul li { position: relative; z-index: 2; width: 100%; max-width: 1400px; margin: 5rem auto 0 auto; }
.contents-link ul li:first-of-type { margin-top: 0; }
.contents-link ul li .txt-box { width: 90%; max-width: 1000px; margin-right: auto; margin-left: auto; position: absolute; top: 0; left: 50%; transform: translateX(-50%); z-index: 3; }
.contents-link ul li .txt-box .contents-ttl, .contents-link ul li .txt-box .contents-txt { display: block; width: 40%; }
.contents-link ul li .contents-ttl { padding-top: 2rem; }
.contents-link ul li .contents-ttl img { width: 150%; }
.contents-link ul li .contents-txt { margin-top: 5rem; font-size: 2.4rem; line-height: 2; letter-spacing: .1em; }
.contents-link ul li .contents-txt a, .contents-link ul li .contents-txt .noreadmore { margin-top: 4rem; display: block; }
.contents-link ul li .contents-txt a:hover .readmore .txt { right: -5px; }
.contents-link ul li .contents-txt .readmore { width: 200px; display: grid; align-items: center; gap: 20px; grid-template-columns: 1fr 40px; }
.contents-link ul li .contents-txt .readmore .txt, .contents-link ul li .contents-txt .readmore .arrow { display: inline-block; align-self: center; }
.contents-link ul li .contents-txt .readmore .txt img, .contents-link ul li .contents-txt .readmore .arrow img { vertical-align: middle; }
.contents-link ul li .contents-txt .readmore .txt { position: relative; right: 0; transition: .4s; }
.contents-link ul li .contetns-img { position: relative; margin: 0 0 0 auto; width: 55%; max-width: 740px; }
.contents-link ul li .contetns-img .note { padding: 5px 5%; }
.contents-link ul li:nth-of-type(even) .txt-box .contents-ttl, .contents-link ul li:nth-of-type(even) .txt-box .contents-txt { margin-right: 0; margin-left: auto; }
.contents-link ul li:nth-of-type(even) .contetns-img { margin: 0 auto 0 0; }
.contents-link ul li.nolink a, .contents-link ul li.nolink .soon { opacity: .3; }
.contents-link ul li.nolink::after { content: ""; display: block; width: 90%; max-width: 300px; height: 50px; background: url("../images/top/comingsoon.png") no-repeat 0% 0%; background-size: contain; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 3; }
.contents-link ul li.nolink .contents-txt .readmore { display: none; }
@media screen and (max-width: 1024px) { .contents-link ul li .contents-txt { font-size: 2.4vw; } }
@media screen and (max-width: 768px) { .contents-link ul li .txt-box { position: relative; top: auto; left: auto; transform: none; }
  .contents-link ul li .txt-box .contents-ttl, .contents-link ul li .txt-box .contents-txt { width: 100%; }
  .contents-link ul li .contents-ttl { padding-top: 0; }
  .contents-link ul li .contents-ttl img { width: 100%; }
  .contents-link ul li .contents-txt { margin-top: 3rem; font-size: 3.5dvw; padding-bottom: 3rem; }
  .contents-link ul li .contents-txt .readmore { margin-top: 3rem; width: 160px; gap: 10px; grid-template-columns: 1fr 30px; }
  .contents-link ul li .contetns-img { margin: auto; width: 100%; }
  .contents-link ul li:nth-of-type(even) .txt-box .contents-ttl, .contents-link ul li:nth-of-type(even) .txt-box .contents-txt { margin-right: auto; }
  .contents-link ul li:nth-of-type(even) .contetns-img { margin: auto; }
  .contents-link ul li.nolink::after { max-width: 200px; } }
@media screen and (max-width: 480px) { .contents-link ul li .contents-txt { font-size: 1.7rem; } }
