html {
    font-size: 62.5%;
    overflow-x: hidden;
}
* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
body {
    line-height: 1.5;
    font-family: "Noto Sans JP", sans-serif;
    letter-spacing: 0.05em;
    max-width: 100%;
    overflow-x: hidden;
}
@media screen and (min-width:768px) { 
body {
    min-width: 1200px;
}
}

/*---------- Text ----------*/
a,p,span,li,th,td {
    font-size: 1.6rem;
}
a {
    text-decoration: none;
    cursor: pointer;
}
h2 {
    letter-spacing: 1px;
}
.en {
    //font-family: "Roboto", sans-serif;
    //font-style: italic;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-style: normal;
}
th, td {
    border: 1px solid;
    vertical-align: middle;
    padding: 0.8rem;
}
th {
    background: #ffe9e1;
    white-space: nowrap;
}
table {
    width: 100%;
}
@media screen and (max-width:767px) { 
    a,p,span,li,th,td {
    font-size: 1.4rem;
}
}
/*---------- Img ----------*/
img {
    width: 100%;
}
.zoom {
    overflow: hidden;
    line-height: 0;
}
a .zoom > img {
    transition: transform 0.5s ease-out;
}
a:hover .zoom > img {
    transform: scale(1.15);
    transition: transform 0.5s cubic-bezier(0, 0.55, 0.45, 1);
}

/*---------- Btn Circle Animation ----------*/
a.link-wrap {
    position: absolute;
    display: flex;
    align-items: center;
}
a.link-wrap .en {
    padding-right: 2rem;
    color: #000;
}
.link {
    display: inline-block;
    min-height: 31px;
    min-width: 31px;
    transform-origin: center;
    position: relative;
    border: 1px solid #707070;
    border-radius: 50%;
    overflow: hidden;
}
.link-wrap .link i {
    display: block;
    position: absolute;
    border-bottom: 1px solid #707070;
    border-right: 1px solid #707070;
    box-sizing: border-box;
    transform-origin: center;
    width: 9px;
    height: 9px;
    top: 50%;
    left: 48%;
    transform: translate(-50%, -50%) rotate(-45deg);
    transition: all .2s cubic-bezier(0.19, 1, 0.22, 1);
}
.link-wrap .link-line {
    height: 1px;
    width: 0%;
    position: absolute;
    top: 50%;
    left: -40%;
    background: #111;
    z-index: 0;
}
.link-wrap .link-line::before {
    width: 100%;
    content: "";
    display: block;
    top: 0;
    left: 1px;
    position: absolute;
    background: #E4E4E4;
    height: 1px;
    z-index: 1;
    transform: scaleX(0);
    transform-origin: right top;
    transition: -webkit-transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1), -webkit-transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
}
.link-wrap .link-line::after {
    width: 100%;
    content: "";
    display: block;
    top: 0;
    left: 1px;
    position: absolute;
    background: #f35a24;
    height: 1px;
    z-index: 1;
    transform: scaleX(0);
    transform-origin: right top;
    transition: -webkit-transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1), -webkit-transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
}
.link-wrap:hover .link {
    overflow: visible;
    transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
    border: 1px solid #f35a24;
}
.link-wrap:hover .link i {
    border-bottom: 1px solid #f35a24;
    border-right: 1px solid #f35a24;
}
.link i {
    border-bottom: 1px solid #f35a24;
    border-right: 1px solid #f35a24;
    transition: all .2s cubic-bezier(0.19, 1, 0.22, 1);
    transform: translate(-50%, -50%) rotate(-45deg);
}
.link-wrap:hover .link-line {
    top: 50%;
    width: 100%;
    animation: linkLine 0.2s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
.link-wrap:hover .link-line:before {
    transform: scaleX(1);
    transform-origin: left top;
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1), -webkit-transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
}
.link-wrap:hover .link-line:after {
    transform: scaleX(1);
    transform-origin: left top;
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition: transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1), -webkit-transform 0.3s cubic-bezier(0.37, 0.16, 0.12, 1);
    transition-delay: 0.35s;
}
@media screen and (max-width:767px) { 
.link-wrap .link i {
    width: 4px;
    height: 4px;
}
.link {
    min-height: 21px;
    min-width: 21px;
}
}
/*---------- Hover Underline ----------*/
.underLine {
    border-bottom: 1px solid #9fa6c5;
}
.underLine a {
    position: relative;
    transition: color 0.5s ease-out;
}
.underLine a:hover {
    color: #0283f7;
}
.underLine a:after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 2px;
    background: #0283f7;
    background-image: #f35a24;
    z-index: 1;
    transform: scaleX(0);
    transform-origin: 100% 0;
    transition: transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.underLine a:hover:after {
    transform: scaleX(1);
    transform-origin: 0 0;
}