@charset "UTF-8";


/* common
-------------------------------------------------*/
:root {
  font-size: 100px;
}
@media screen and (max-width: 1440px) and (min-width: 751px) {
:root {
    font-size: 6.94444444444vw;
}
}
@media screen and (max-width: 750px) {
:root {
    font-size: 26.66666666666vw;
}
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
dl,
dt,
dd,
table,
tr,
th,
td,
form,
figure,
picture {
	font-size: inherit;
	margin: 0;
	padding: 0;
}
a {
	color: inherit;
	text-decoration: none;
}
summary {
	display: block;
}
table {
	border-collapse: collapse;
	empty-cells: show;
}
th,
td {
	text-align: left;
	vertical-align: top;
}
ul li {
	list-style: none;
}
address {
	font-style: normal;
}
figure,
picture {
	display: block;
}
img {
	vertical-align: top;
    width: 100%;
    max-width: 100%;
	height: auto;
}
input,
textarea,
select {
	color: inherit;
	font-family: inherit;
	-webkit-appearance: none;
	appearance: none;
}
textarea {
	form-sizing: content;
}
button {
	color: inherit;
	font-family: inherit;
}
input, select {
    vertical-align: middle;
}
input[type="button"], input[type="text"], input[type="submit"], input[type="reset"], textarea {
    font-family: YakuHanJP, source-han-sans-jp-variable, sans-serif;
    font-size: 0.18rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
	-webkit-appearance: none;
	border-radius: 0.06rem;
}
::placeholder {
    opacity: 1;
    color: #D1D1D1;
    font-weight: 500;
    font-variation-settings: "wght" 500;
}
@media screen and (max-width:750px){
input[type="button"], input[type="text"], input[type="submit"], input[type="reset"], textarea {
    font-size: 0.15rem;
}
}


/* module
------------------------------------------------- */
.pcon { display: block; }
.spon { display: none; }
@media screen and (max-width:750px){
.pcon { display: none; }
.spon { display: block; }
}


/* a
------------------------------------------------- */
a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
	text-decoration: none;
	outline: none;
    color: #2F3136;
}
@media (hover: hover) and (min-width:751px) {
a {
    transition: 0.2s;
}
a.al:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
}
}
@media screen and (min-width:751px){
.telLink {
	pointer-events: none;
}
}


/* html
------------------------------------------------- */
html {
    font-size: 0.16rem;
    scroll-behavior: smooth;
    scrollbar-gutter: stable;
    overflow-x: hidden;
}


/* body, wrapper
------------------------------------------------- */
body {
    min-height: 100vh;
    background-color: #EDEEEF;
    font-family: YakuHanJP, source-han-sans-jp-variable, sans-serif;
    font-weight: 300;
    font-variation-settings: "wght" 300;
	font-size: 0.16rem;
	line-height: 1.8;
	color: #2F3136;
	-webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    position: relative;
}
.eng {
    font-family: eurostile-extended, sans-serif;
    font-weight: 400;
    font-style: normal;
}
#wrapper {
    transition: 0.4s;
}
@media screen and (min-width:751px){
body.nav-active #wrapper,
body.about-active #wrapper,
body.voice-active #wrapper {
    transform: translateX(-10%);
}
.overlay {
    display: none;
    width: 100%;
    height: 100vh;
    background-color: rgba(47,49,54,0.7);
    position: fixed;
    left: 0;
    top: 0;
    z-index: 95;
    cursor: pointer;
}
}


/* layout
------------------------------------------------- */
.inner {
    max-width: 12.64rem;
    margin: 0 auto;
    position: relative;
}
.d-flex {
    display: flex;
}
.f-wrap {
    flex-wrap: wrap;
}
.f-rev {
    flex-direction: row-reverse;
}
.just-center {
    justify-content: center;
}
.just-between {
    justify-content: space-between;
}
.just-end {
    justify-content: flex-end;
}
.align-center {
    align-items: center;
}
.align-start {
    align-items: flex-start;
}
.align-end {
    align-items: flex-end;
}
@media screen and (max-width:750px){
.inner {
    width: 92.26%;
}
.d-flex {
    display: block;
}
}


/* header
------------------------------------------------- */
#header::after {
    content: '採用情報';
    width: 0.82rem;
    height: 0.26rem;
    background-color: #fff;
    border: 0.01rem solid #D3D3D3;
    border-radius: 0.04rem;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 0.13rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    letter-spacing: 0.09em;
    text-align: center;
    padding-bottom: 0.02rem;
    box-sizing: border-box;
    position: fixed;
    left: 3.54rem;
    top: 0.23rem;
    z-index: 90;
    transition: 0.4s;
}
#header .logo {
    width: 4.05rem;
    position: fixed;
    left: 0.31rem;
    top: 0.28rem;
    mix-blend-mode: exclusion;
    z-index: 91;
    transition: 0.4s;
}
#header .logo a {
    display: block;
    line-height: 1;
}
#header .logo a img {
    width: 2.9851rem;
}
@media screen and (max-width:750px){
#header::after {
    width: 0.59rem;
    height: 0.21rem;
    font-size: 0.11rem;
    padding-bottom: 0.01rem;
    left: 2.38rem;
    top: 0.27rem;
    z-index: 98;
}
#header .logo {
    width: 2.82rem;
    left: 0.14rem;
    top: 0.3rem;
    z-index: 99;
}
#header .logo a img {
    width: 2.0851rem;
}
}


/* hnav
------------------------------------------------- */
#hnav {
    position: fixed;
    right: 2.86rem;
    top: 0.23rem;
    mix-blend-mode: exclusion;
    z-index: 91;
}
#hnav a {
    display: block;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    line-height: 1.5;
    color: #fff;
    position: relative;
}
#hnav a::after {
    content: '';
    width: 100%;
    height: 0.01rem;
    background-color: #fff;
    position: absolute;
    left: 0;
    bottom: 0;
    transition: 0.3s;
}
@media (hover: hover) and (min-width:751px) {
#hnav a:hover::after {
    transform: scale(0,1);
}
}
@media screen and (max-width:750px){
#hnav {
    width: 35.45vw;
    right: auto;
    left: 0;
    top: auto;
    bottom: 0;
    mix-blend-mode: normal;
}
#hnav a {
    width: 100%;
    height: 0.72rem;
    background-color: #fff;
    font-size: 0.16rem;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #2F3136;
    padding-bottom: 0.05rem;
    box-sizing: border-box;
}
#hnav a::after {
    width: 0.64rem;
    background-color: #2F3136;
    left: 50%;
    bottom: 0.25rem;
    margin-left: -0.32rem;
}
}


/* enav
------------------------------------------------- */
#enav {
    width: 1.36rem;
    height: 0.72rem;
    position: fixed;
    right: 1.13rem;
    top: 0;
    z-index: 91;
}
#enav a {
    width: 100%;
    height: 100%;
    background-color: #2F3136;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    position: relative;
    overflow: hidden;
}
#enav a::after {
    content: '';
    width: 1.7rem;
    height: 1.7rem;
    background-color: #D562FF;
    border-radius: 50%;
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -0.85rem 0 0 -0.85rem;
    transform: scale(0);
    transition: 0.3s;
    z-index: 1;
}
#enav a span {
    font-size: 0.19rem;
    font-weight: 500;
    color: #fff;
    position: relative;
    transition: 0.2s;
    z-index: 2;
}
@media (hover: hover) and (min-width:751px) {
#enav a:hover::after {
    transform: scale(1);
}
#enav a:hover span {
    letter-spacing: 0.1em;
}
}
@media screen and (max-width:750px){
#enav {
    width: 64.55vw;
    right: 0;
    top: auto;
    bottom: 0;
}
#enav a {
    height: 0.72rem;
}
#enav a::after {
    width: 70vw;
    height: 70vw;
    margin: -35vw 0 0 -35vw;
}
#enav a span {
    font-size: 0.22rem;
}
}


/* navtoggle
------------------------------------------------- */
#navtoggle {
    width: 1.13rem;
    height: 0.72rem;
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    right: 0;
    top: 0;
    mix-blend-mode: exclusion;
    cursor: pointer;
    z-index: 98;
}
#navtoggle div {
    width: 0.64rem;
    height: 0.13rem;
    position: relative;
}
#navtoggle span {
    display: block;
    width: 100%;
    height: 0.02rem;
    background-color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    transition: 0.3s ease-in-out;
}
#navtoggle span:nth-child(2) {
    top: 0.12rem;
}
body.nav-active #navtoggle span:nth-child(1) {
    top: 0.07rem;
	transform: rotate(30deg);
}
body.nav-active #navtoggle span:nth-child(2) {
    top: 0.07rem;
	transform: rotate(-30deg);
}
@media screen and (max-width:750px){
#navtoggle {
    width: 0.73rem;
}
#navtoggle div {
    width: 0.44rem;
    height: 0.09rem;
}
#navtoggle span {
    height: 0.01rem;
}
#navtoggle span:nth-child(2) {
    top: 0.08rem;
}
}


/* gnav
------------------------------------------------- */
#gnav {
    width: 8.07rem;
    height: 100vh;
    background-color: #fff;
    display: flex;
    align-items: center;
    padding: 1.2rem 0 1.2rem 1.1rem;
    position: fixed;
    right: -9rem;
    top: 0;
    box-sizing: border-box;
    z-index: 97;
    transition: 0.3s;
    overflow-x: hidden;
}
#gnav::after {
    content: '';
    width: 9.233rem;
    height: 8.7348rem;
    background: url("../img/recruit/common/gnav_shape.svg") center center no-repeat;
    background-size: cover;
    position: absolute;
    right: -7rem;
    top: 50%;
    margin-top: -4.3674rem;
    z-index: 1;
    animation: footerShape 40s linear infinite;
}
#gnav ul {
    transform: translateY(0.2rem);
    opacity: 0;
    position: relative;
    z-index: 2;
}
#gnav ul li {
    line-height: 1.5;
    margin-bottom: 0.5rem;
}
#gnav ul li a {
    display: block;
}
#gnav ul li a span {
    display: block;
    height: 0.4rem;
    font-size: 0.4rem;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.04em;
}
#gnav p {
    font-size: 0.14rem;
    line-height: 1.45;
    text-align: right;
    position: absolute;
    right: 0.4rem;
    bottom: 0.65rem;
    z-index: 2;
}
#gnav p a {
    background: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_86645%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2086645%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2212%22%20height%3D%2212%22%20viewBox%3D%220%200%2012%2012%22%3E%20%3Cg%20id%3D%22%E6%96%B0%E3%81%97%E3%81%84%E3%82%A6%E3%82%A3%E3%83%B3%E3%83%89%E3%82%A6%E3%81%A7%E9%96%8B%E3%81%8F%E3%83%9C%E3%82%BF%E3%83%B3_2%22%20data-name%3D%22%E6%96%B0%E3%81%97%E3%81%84%E3%82%A6%E3%82%A3%E3%83%B3%E3%83%89%E3%82%A6%E3%81%A7%E9%96%8B%E3%81%8F%E3%83%9C%E3%82%BF%E3%83%B3%202%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_196%22%20data-name%3D%22%E3%83%91%E3%82%B9%20196%22%20d%3D%22M95.75%2C0V9.493h9.493V0Zm8.544%2C8.544H96.7v-5.7h7.594Z%22%20transform%3D%22translate(-93.243)%22%20fill%3D%22%23d562ff%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_197%22%20data-name%3D%22%E3%83%91%E3%82%B9%20197%22%20d%3D%22M.949%2C104.294V95.75H0v9.493H9.493v-.949H.949Z%22%20transform%3D%22translate(0%20-93.243)%22%20fill%3D%22%23d562ff%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E') right center no-repeat;
    background-size: 0.12rem auto;
    padding-right: 0.18rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    position: relative;
}
#gnav p a::after {
    content: '';
    width: calc(100% - 0.18rem);
    height: 0.01rem;
    background-color: #2F3136;
    position: absolute;
    left: 0;
    bottom: 0;
    transform: scale(1, 1);
    transform-origin: left top;
    transition: transform 0.3s;
}
#gnav small {
    display: block;
    font-size: 0.11rem;
    line-height: 1.1;
    text-align: right;
    color: #8D8D8D;
    letter-spacing: 0.01em;
    position: absolute;
    right: 0.4rem;
    bottom: 0.4rem;
    z-index: 2;
}
body.nav-active #gnav {
    right: 0;
}
body.nav-active #gnav ul{
    animation: fadeLeft 0.5s ease 0.3s 1 forwards;
}
@media screen and (max-height:650px){
#gnav {
    display: block;
    padding: 0.8rem 0.4rem 0.4rem 1.1rem;
    overflow-y: auto;
}
#gnav p {
    position: static;
    margin-bottom: 0.15rem;
}
#gnav small {
    position: static;
}
}
@media (hover: hover) and (min-width:751px) {
#gnav p a:hover::after {
    transform-origin: right top;
    transform: scale(0, 1);
}
}
@media screen and (max-width:750px){
#gnav {
    width: 100vw;
    display: block;
    padding: 1.15rem 0 30vw 0.14rem;
    right: -105vw;
    overflow-y: auto;
}
#gnav::after {
    width: 5.7816rem;
    height: 5.4697rem;
    background-image: url("../img/recruit/common/gnav_shape.svg");
    right: -4.14rem;
    margin-top: -3rem;
}    
#gnav ul {
    transform: translateY(0.1rem);
}
#gnav ul li {
    font-size: 0.15rem;
    margin-bottom: 0.34rem;
}
#gnav ul li a span {
    height: 0.3rem;
    font-size: 0.3rem;
    margin-bottom: 0.06rem;
    overflow: hidden;
}
#gnav p {
    text-align: left;
    position: static;
    margin: 0.625rem 0 0.25rem;
}
#gnav small {
    font-size: 0.1rem;
    text-align: left;
    position: static;
}
}


/* headline
------------------------------------------------- */
.headline1 {
    font-size: 0.18rem;
    font-weight: 300;
    font-variation-settings: "wght" 300;
    line-height: 1.45;
    letter-spacing: -0.07em;
    margin-bottom: 0.5rem;
}
.headline1 span {
    display: block;
    font-size: 0.54rem;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.04em;
    margin-bottom: 0.1rem;
    opacity: 0;
}
.headline2 {
    font-size: 0.44rem;
    font-weight: 100;
    font-variation-settings: "wght" 250;
    line-height: 1.4;
}
.headline2 span {
    display: block;
    font-size: 0.18rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    line-height: 1.5;
    letter-spacing: -0.07em;
    padding-left: 0.3rem;
    margin-bottom: 0.25rem;
    position: relative;
}
.headline2 span::before {
    content: '';
    width: 0.11rem;
    height: 0.11rem;
    background-color: #D562FF;
    border-radius: 0.03rem;
    position: absolute;
    left: 0;
    top: 50%;
    margin-top: -0.055rem;
}
@media screen and (max-width:750px){
.headline1 {
    font-size: 0.16rem;
    line-height: 1.5;
    letter-spacing: normal;
    margin-bottom: 0.4rem;
}
.headline1 span {
    font-size: 0.34rem;
    margin-bottom: 0.08rem;
}
.headline2 {
    font-size: 0.32rem;
}
.headline2 span {
    font-size: 0.15rem;
    letter-spacing: normal;
    padding-left: 0.25rem;
    margin-bottom: 0.25rem;
}
}


/* footer
------------------------------------------------- */
#footer {
    padding: 1rem 0 0.55rem;
    color: #fff;
    position: relative;
}
#footer::after {
    content: '';
    width: 100%;
    height: 100%;
    background-color: #2F3136;
    border-radius: 1.2rem 1.2rem 0 0;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 1;
}
#footer .inner {
    z-index: 2;
}
#footer .box {
    position: absolute;
    right: -0.35rem;
    top: -2.8rem;
}
#footer .box p {
    font-family: source-han-sans-jp-variable, sans-serif;
    font-size: 0.55rem;
    line-height: 1.6;
    font-weight: 100;
    font-variation-settings: "wght" 250;
    text-align: right;
}
#footer .box p i {
    font-style: normal;
    letter-spacing: -0.07em;
}
#footer .box p span {
    display: block;
    height: 0.2rem;
    font-size: 0.12rem;
    font-weight: 400;
    color: #8D8D8D;
    padding-right: 0.35rem;
    opacity: 0;
}
#footer .box ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin: 0.13rem 0.35rem 0 0;
}
#footer .box ul li {
    width: 0.71rem;
    animation: footerShape 10s linear infinite;
}
#footer .box ul li:nth-child(2) {
    width: 0.87rem;
    margin-left: 0.2rem;
}
#footer .box ul li:nth-child(3) {
    width: 0.67rem;
    margin-left: 0.2rem;
}
#footer .box ul li:nth-child(4) {
    width: 0.88rem;
    margin-left: 0.21rem;
}
#footer .box ul li:nth-child(5) {
    width: 0.81rem;
    margin-left: 0.1rem;
}
#footer .box ul li:nth-child(6) {
    width: 0.75rem;
    margin-left: 0.2rem;
}
#footer h3 {
    width: 3.64rem;
    margin: 2.72rem 0 0.35rem;
    mix-blend-mode: exclusion;
}
#footer h3 a {
    display: block;
    line-height: 1;
    position: relative;
}
#footer h3 a::after {
    content: '採用情報';
    width: 0.82rem;
    height: 0.26rem;
    background-color: #fff;
    border: 0.01rem solid #D3D3D3;
    border-radius: 0.04rem;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 0.13rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    letter-spacing: 0.09em;
    text-align: center;
    color: #1D1D1D;
    padding-bottom: 0.02rem;
    box-sizing: border-box;
    position: absolute;
    left: 3.85rem;
    top: 0;
}
#footer h3 span {
    display: block;
    line-height: 1.5;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    color: #fff;
    padding-top: 0.11rem;
}
#footer .add {
    margin-bottom: 0.63rem;
    position: relative;
}
#footer .add::after {
    content: '';
    width: 0.01rem;
    height: 100%;
    background-color: #CECECE;
    position: absolute;
    left: 3.38rem;
    top: 0;
}
#footer .add .con {
    width: 3.8rem;
}
#footer .add .con h4 {
    font-weight: 400;
    font-variation-settings: "wght" 400;
    line-height: 1.5;
    margin-bottom: 0.08rem;
}
#footer .add .con address {
    display: block;
    font-size: 0.15rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    line-height: 1.5;
    margin-bottom: 0.08rem;
}
#footer .add .con p {
    font-size: 0.13rem;
    line-height: 1.45;
}
#footer .add .con p a {
    background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.566%22%20height%3D%2213.961%22%20viewBox%3D%220%200%2011.566%2013.961%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_267%22%20data-name%3D%22%E3%83%91%E3%82%B9%20267%22%20d%3D%22M53.793%2C1.7a5.783%2C5.783%2C0%2C0%2C0-8.179%2C8.178L49.7%2C13.963l4.089-4.089A5.783%2C5.783%2C0%2C0%2C0%2C53.793%2C1.7ZM49.7%2C8a2.212%2C2.212%2C0%2C1%2C1%2C2.212-2.212A2.212%2C2.212%2C0%2C0%2C1%2C49.7%2C8Z%22%20transform%3D%22translate(-43.921%20-0.002)%22%20fill%3D%22%23cddeda%22%2F%3E%3C%2Fsvg%3E') left center no-repeat;
    background-size: 0.1157rem auto;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    color: #fff;
    text-decoration: underline;
    padding-left: 0.17rem;
}
#footer .btn {
    width: 2.97rem;
    height: 0.59rem;
    position: absolute;
    right: 0;
    top: 1.4rem;
}
#footer .btn a {
    width: 100%;
    height: 100%;
    background: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_86599%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2086599%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215.368%22%20height%3D%2215.368%22%20viewBox%3D%220%200%2015.368%2015.368%22%3E%20%3Cg%20id%3D%22%E6%96%B0%E3%81%97%E3%81%84%E3%82%A6%E3%82%A3%E3%83%B3%E3%83%89%E3%82%A6%E3%81%A7%E9%96%8B%E3%81%8F%E3%83%9C%E3%82%BF%E3%83%B3_2%22%20data-name%3D%22%E6%96%B0%E3%81%97%E3%81%84%E3%82%A6%E3%82%A3%E3%83%B3%E3%83%89%E3%82%A6%E3%81%A7%E9%96%8B%E3%81%8F%E3%83%9C%E3%82%BF%E3%83%B3%202%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_196%22%20data-name%3D%22%E3%83%91%E3%82%B9%20196%22%20d%3D%22M95.75%2C0V12.158h12.158V0Zm10.942%2C10.942H96.966V3.647h9.726Z%22%20transform%3D%22translate(-92.539)%22%20fill%3D%22%23fff%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_197%22%20data-name%3D%22%E3%83%91%E3%82%B9%20197%22%20d%3D%22M1.216%2C106.692V95.75H0v12.158H12.158v-1.216H1.216Z%22%20transform%3D%22translate(0%20-92.539)%22%20fill%3D%22%23fff%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E') 91% center no-repeat #484a4e;
    background-size: 0.1537rem auto;
    border-radius: 0.08rem;
    font-weight: 400;
    font-variation-settings: "wght" 400;
    color: #fff;
    display: flex;
    align-items: center;
    padding: 0 0 0.02rem 0.24rem;
    box-sizing: border-box;
}
#footer .pagetop {
    width: 0.96rem;
    position: absolute;
    left: 0;
    top: -2.2rem;
}
#footer .pagetop a {
    display: block;
    font-size: 0.14rem;
    font-weight: 500;
    line-height: 1;
    color: #fff;
    text-align: center;
}
#footer .pagetop a span {
    display: block;
    width: 0.96rem;
    height: 0.96rem;
    background-color: #484a4e;
    border-radius: 50%;
    margin-bottom: 0.09rem;
    position: relative;
    transition: 0.2s;
}
#footer .pagetop a span::before {
    content: '';
    width: 0.2086rem;
    height: 0.2683rem;
    background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220.869%22%20height%3D%2226.832%22%20viewBox%3D%220%200%2020.869%2026.832%22%3E%20%3Cpath%20id%3D%22reply_24dp_E8EAED_FILL0_wght400_GRAD0_opsz24%22%20d%3D%22M23.85%2C0V5.963a4.313%2C4.313%2C0%2C0%2C1-1.3%2C3.168%2C4.313%2C4.313%2C0%2C0%2C1-3.168%2C1.3H5.7l5.366-5.366L8.944%2C2.981%2C0%2C11.925l8.944%2C8.944%2C2.124-2.087L5.7%2C13.416H19.378a7.183%2C7.183%2C0%2C0%2C0%2C5.273-2.18%2C7.183%2C7.183%2C0%2C0%2C0%2C2.18-5.273V0Z%22%20transform%3D%22translate(20.869)%20rotate(90)%22%20fill%3D%22%23e8eaed%22%2F%3E%3C%2Fsvg%3E') center center no-repeat;
    background-size: 100% auto;
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -0.13415rem 0 0 -0.1043rem;
    transition: 0.2s;
}
#footer small {
    display: block;
    font-size: 0.11rem;
    line-height: 1.1;
    letter-spacing: 0.01em;
    color: #8D8D8D;
}
@media (hover: hover) and (min-width:751px) {
#footer .add .con p a:hover {
    text-decoration: none;
}
#footer .btn a:hover {
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_86599%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2086599%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215.368%22%20height%3D%2215.368%22%20viewBox%3D%220%200%2015.368%2015.368%22%3E%20%3Cg%20id%3D%22%E6%96%B0%E3%81%97%E3%81%84%E3%82%A6%E3%82%A3%E3%83%B3%E3%83%89%E3%82%A6%E3%81%A7%E9%96%8B%E3%81%8F%E3%83%9C%E3%82%BF%E3%83%B3_2%22%20data-name%3D%22%E6%96%B0%E3%81%97%E3%81%84%E3%82%A6%E3%82%A3%E3%83%B3%E3%83%89%E3%82%A6%E3%81%A7%E9%96%8B%E3%81%8F%E3%83%9C%E3%82%BF%E3%83%B3%202%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_196%22%20data-name%3D%22%E3%83%91%E3%82%B9%20196%22%20d%3D%22M95.75%2C0V12.158h12.158V0Zm10.942%2C10.942H96.966V3.647h9.726Z%22%20transform%3D%22translate(-92.539)%22%20fill%3D%22%232f3136%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_197%22%20data-name%3D%22%E3%83%91%E3%82%B9%20197%22%20d%3D%22M1.216%2C106.692V95.75H0v12.158H12.158v-1.216H1.216Z%22%20transform%3D%22translate(0%20-92.539)%22%20fill%3D%22%232f3136%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
    background-color: #fff;
    color: #1B2945;
}
#footer .pagetop a:hover span {
    background-color: #D562FF;
}
#footer .pagetop a:hover span::before {
    margin-top: -0.2rem;
}
}
@media screen and (max-width:750px){
#footer {
    padding: 0.55rem 0 1.05rem;
}
#footer::after {
    border-radius: 0.4rem 0.4rem 0 0;
}
#footer .box {
    position: static;
}
#footer .box p {
    font-size: 0.33rem;
    line-height: 1.45;
    text-align: left;
    white-space: nowrap;
}
#footer .box p span {
    height: 0.07rem;
    font-size: 0.07rem;
    padding: 0.02rem 0 0;
    text-align: center;
}
#footer .box ul {
    justify-content: space-between;
    margin: 0.25rem 0 0 0;
}
#footer .box ul li {
    width: 0.43rem;
}
#footer .box ul li:nth-child(2) {
    width: 0.53rem;
    margin: 0;
}
#footer .box ul li:nth-child(3) {
    width: 0.41rem;
    margin: 0;
}
#footer .box ul li:nth-child(4) {
    width: 0.54rem;
    margin: 0;
}
#footer .box ul li:nth-child(5) {
    width: 0.5rem;
    margin: 0;
}
#footer .box ul li:nth-child(6) {
    width: 0.46rem;
    margin: 0;
}
#footer h3 {
    width: 2.92rem;
    margin: 0.625rem 0 0.3rem;
}
#footer h3 a {
    display: block;
    line-height: 1;
    position: relative;
}
#footer h3 a::after {
    width: 0.59rem;
    height: 0.21rem;
    font-size: 0.11rem;
    padding-bottom: 0.01rem;
    left: 0;
    top: 0.28rem;
}
#footer h3 span {
    font-size: 0.15rem;
    padding-top: 0.45rem;
}
#footer .add {
    margin-bottom: 0;
    position: relative;
}
#footer .add::after {
    width: 100%;
    height: 0.01rem;
    left: 0;
    top: 1.3rem;
}
#footer .add .con {
    width: 100%;
    margin-bottom: 0.45rem;
}
#footer .add .con.last {
    margin-bottom: 0.25rem;
}
#footer .add .con h4 {
    font-size: 0.15rem;
    margin-bottom: 0.05rem;
}
#footer .add .con address {
    font-size: 0.14rem;
    line-height: 1.8;
}
#footer .btn {
    width: 100%;
    height: 0.72rem;
    position: static;
}
#footer .btn a {
    background-position: 92% center;
    background-size: 0.18rem auto;
    padding: 0 0 0.01rem 0.24rem;
}
#footer .pagetop {
    width: 1.3rem;
    position: static;
    margin: 0.7rem 0 0.2rem;
}
#footer .pagetop a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.11rem;
    text-align: right;
}
#footer .pagetop a span {
    width: 0.66rem;
    height: 0.66rem;
    margin: 0;
}
#footer .pagetop a span::before {
    content: '';
    width: 0.1451rem;
    height: 0.1866rem;
    margin: -0.0933rem 0 0 -0.07255rem;
}
#footer small {
    font-size: 0.1rem;
}
}


/* anchor
------------------------------------------------- */
.anchor {
    padding-top: 0.72rem;
    margin-top: -0.72rem;
}


/* animation
------------------------------------------------- */
.fadeUp {
    opacity: 0;
}
.fadeUp.isAnimate {
    animation: fadeUp 0.5s ease 0.1s 1 forwards;
}
@keyframes fadeUp {
    0% {
        opacity: 0;
        transform: translateY(0.2rem);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes fadeLeft {
    0% {
        opacity: 0;
        transform: translateX(-0.2rem);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes cultureAnimation {
    0% {
        stroke-dashoffset: 2700;
        opacity: 0;
    }
    30% {
        opacity: 0;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 1;
    }
}
@keyframes boxAnimation {
    0% {
        width: 96vw;
        height: 9.2rem;
        position: absolute;
        left: 2vw;
        top: 0.2rem;
    }
    70% {
        width: 81.6vw;
        height: 7.82rem;
        position: absolute;
        left: 9.2vw;
        top: 0.89rem;
    }
    100% {
        width: 96vw;
        height: 9.2rem;
        position: absolute;
        left: 2vw;
        top: 0.2rem;
    }
}
@keyframes boxAnimationSp {
    0% {
        width: 120vw;
        height: 6.4rem;
        position: absolute;
        left: -5vw;
        top: 0.2rem;
    }
    70% {
        width: 102vw;
        height: 5.44rem;
        position: absolute;
        left: -5vw;
        top: 0.48rem;
    }
    100% {
        width: 120vw;
        height: 6.4rem;
        position: absolute;
        left: -5vw;
        top: 0.2rem;
    }
}
@keyframes infinity-right {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(100%);
    }
}
@keyframes shapeAnimation {
    0% {
        transform: scale(1) rotate(0);
        
    }
    100% {
        transform: scale(0.9) rotate(20deg);
    }
}
@keyframes logoAnimation {
    0% {
        stroke-dashoffset: 2000;
        fill: transparent;
    }
    50% {
        fill: transparent;
    }
    100% {
        stroke-dashoffset: 0;
        fill: #2A323C;
    }
}
@keyframes footerShape {
    0% { 
        transform: rotate(0);
    }
    100% {
        transform: rotate(-360deg);
    }
}