@charset "UTF-8";

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;800;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@100;300;400;500;700;900&display=swap");  html {
font-size: 10px;
}
body {
position: relative;
font-size: 1rem;
line-height: 1.8;
font-family:'Hiragino Sans','Hiragino Kaku Gothic ProN','Noto Sans JP', sans-serif;
color: #000000;
padding-top: 60px;
-webkit-font-feature-settings: "palt";
-moz-font-feature-settings: "palt";
-ms-font-feature-settings: "palt";
-o-font-feature-settings: "palt";
font-feature-settings: "palt"; }
@media screen and (max-width: 767px) {
html {
font-size: 2.868vw;
}
body {
font-size: 1rem;
width: 100%;
min-width: 100%;
line-height: 1.7;
padding-top: 16vw;
-webkit-font-feature-settings: "palt";
-moz-font-feature-settings: "palt";
-ms-font-feature-settings: "palt";
-o-font-feature-settings: "palt";
font-feature-settings: "palt";
}
body.fixed {
position: fixed;
width: 100%;
height: 100%;
left: 0;
}
}
* {
font-style: normal;
font-weight: 400;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
-o-box-sizing: border-box;
-ms-box-sizing: border-box;
box-sizing: border-box;
}
a {
color: #000000;
text-decoration: none;
transition: .5s;
}
a:hover {
color: #666666;
text-decoration: none;
transition: .5s;
opacity: 0.65;
}
main a {
color: #000000;
text-decoration: none;
transition: .5s;
}
main a:hover {
color: #666666;
text-decoration: none;
transition: .5s;
opacity: 0.65;
}
a:hover img,
a.opacity:hover,
footer footer_in .f_contents section dl a:hover {
text-decoration: none;
opacity: 0.65;
zoom: 1;
}
header h2 a:hover img,
footer dl dt a:hover img {
opacity: 1.0;
zoom: 1;
}
a:before, a:after,
a:hover:before, a:hover:after {
text-decoration: none !important;
display: inline-block;
}
img {
width: 100%;
height: auto;
backface-visibility: hidden;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
-ms-backface-visibility: hidden;
image-rendering: -webkit-optimize-contrast;
} .sp, .sp_img {
display: none;
}
@media screen and (max-width: 767px) {
img {
max-width: none;
width: 100%;
height: auto;
}
.pc {
display: none;
}
.sp, .sp_img {
display: block;
}
}   h1 {
display: none;
}
header {
position: fixed;
top: 0;
left: 0;
z-index: 20;
width: 100%;
height: 60px;
display: flex;
align-items: center;
padding: 0 60px;
background: rgba(255, 255, 255, .9);
transition: .5s;
}
header h2 {
width: 210px;
margin-right: 40px;
}
header nav {
display: flex;
align-items: center;
flex-wrap: wrap;
margin-left: auto;
}
header nav a ,
header nav a:hover {
text-decoration: none;
}
header nav .nav_box {
display: flex;
align-items: center;
flex-wrap: wrap;
padding-top: 12px;
}
header nav ul {
display: flex;
align-items: center;
flex-wrap: wrap;
margin-right: 35px;
}
header nav ul li {
font-size: 1.6rem;
}
header nav ul li:not(:last-of-type) {
margin-right: 2em;
}
header nav ul li a {
position: relative;
display: block;
font-weight: 500;
transition: .3s;
}
header nav ul li a::after{
position: absolute;
bottom: 0;
left: 50%;
content: '';
width: 0;
height: 2px;
background: #333333;
transition: .3s;
transform: translateX(-50%);
}
header nav ul li a:hover::after{
width: 100%;
}
header nav .sns_icon {
display: flex;
align-items: center;
justify-content: center;
}
header nav p {
width: 24px;
}
header nav p + p {
margin-left: 20px;
}
.openSidebarMenu {
display: none;
}
.sidebarIconToggle > div + span {
display: none;
}
@media screen and (max-width: 1000px) {
header {
padding: 0 20px;
}
}
@media screen and (max-width: 767px) {
input.openSidebarMenu[type="checkbox"]:checked ~ header nav .nav_box {
transform: translateX(0);
}	
.openSidebarMenu {
display: none;
transition: all 0.3s;
}
.sidebarIconToggle {
transition: all 0.3s;
cursor: pointer;
position: fixed;
z-index: 200;
top: 3vw;
right: 5vw;
height: 16vw;
width: 12vw;
}
.sidebarIconToggle > div div {
position: relative;
height: 2px;
width: 100%;
background: #333;
transition: all 0.3s;
}
.sidebarIconToggle > div div:nth-of-type(2) {
margin-top: 2.5vw;
}
.sidebarIconToggle > div div:nth-of-type(3) {
margin-top: 2.5vw;
}
input.openSidebarMenu[type=checkbox]:checked ~ .sidebarIconToggle {
position: fixed;
}
input.openSidebarMenu[type=checkbox]:checked ~ .sidebarIconToggle > div div {
transition: all 0.3s;
background: #333;
}
input.openSidebarMenu[type=checkbox]:checked ~ .sidebarIconToggle > div div:nth-of-type(2) {
transition: all 0.3s;
opacity: 0;
}
input.openSidebarMenu[type=checkbox]:checked ~ .sidebarIconToggle > div div:nth-of-type(1) {
transition: all 0.3s;
transform: rotate(135deg);
margin-top: 3.6vw;
}
input.openSidebarMenu[type=checkbox]:checked ~ .sidebarIconToggle > div div:nth-of-type(3) {
transition: all 0.3s;
transform: rotate(-135deg);
margin-top: -3.6vw;
}
.sidebarIconToggle > div + span {
display: block;
font-size: 1.1rem;
text-align: center;
color: #333;
line-height: 1.1;
padding-top: .4em;
transition: all 0.3s;
letter-spacing: 0;
}
input.openSidebarMenu[type=checkbox]:checked ~ .sidebarIconToggle > div + span {
padding-top: 1.5em;
}
header {
height: 16vw;
padding: 0 4vw;
}
header h2 {
width: 50vw;
margin-right: 0;
}
header nav {    
position: fixed;
top: 0;
right: 0;
margin-left: inherit;
padding-top: inherit;
padding-right: inherit;  
}
header nav .nav_box {
position: fixed;
top: 0;
right: 0;
z-index: 100;
width: 70vw;
height: 100%;
display: flex;
justify-content: flex-start;
align-items: flex-start;
flex-direction: column;
transform: translateX(70vw);
transition: transform 500ms ease-in-out;
background: rgba(255, 255, 255, .9);
-webkit-backdrop-filter: blur(30px);
backdrop-filter: blur(30px);
padding: 10vw 0;
padding-top: 20vw;
padding-left: 5vw;
overflow: auto;
}
header nav ul {
display: flex;
align-items: flex-start;
flex-direction: column;
flex-wrap: wrap;
margin-right: 0;
margin-bottom: 10vw;
width: 100%;
}
header nav ul li {
font-size: 1.6rem;
width: 100%;
}
header nav ul li:not(:last-of-type) {
margin-right: 0;
margin-bottom: 2em;
}
header nav p {
width: 12vw;
}
header nav p + p {
margin-left: 10vw;
}
} footer {
padding: 40px 20px;
}
footer .f_logo {
width: 210px;
margin: 0 auto;
margin-bottom: 20px;
}
footer .copy {
display: block;
text-align: center;
font-size: 1.2rem;
}
.return {
position: fixed;
right: 20px;
bottom: 20px;
width: 40px;
}
@media screen and (max-width: 767px) {
footer {
padding: 10vw 4%;
}
footer .f_logo {
width: 60vw;
margin-bottom: 5vw;
}
footer .copy {
font-size: 1.3rem;
}
.return {
right: 5vw;
bottom: 5vw;
width: 10vw;
}
} .w1240 {
width: 1280px;
margin: 0 auto;
padding-left: 20px;
padding-right: 20px;
}
.mw1240 {
max-width: 1280px;
margin: 0 auto;
padding-left: 20px;
padding-right: 20px;
}
.mw930 {
max-width: 970px;
margin: 0 auto;
padding-left: 20px;
padding-right: 20px;
}
.mw900 {
max-width: 940px;
margin: 0 auto;
padding-left: 20px;
padding-right: 20px;
}
@media screen and (max-width: 1240px) {
.w1240 {
width: 100%;
}
.mw1240 {
max-width: 100%;
}
.mw1040 {
max-width: 100%;
}
}
@media screen and (max-width: 980px) {
.mw930 {
max-width: 100%;
}
}
@media screen and (max-width: 940px) {
.mw900 {
max-width: 100%;
}
}
@media screen and (max-width: 767px) {
.w1240 {
padding-left: 4%;
padding-right: 4%;
}
.mw1240 {
padding-left: 4%;
padding-right: 4%;
}
.mw930 {
padding-left: 4%;
padding-right: 4%;
}
.mw900 {
padding-left: 4%;
padding-right: 4%;
}
} .anc:before {
position: relative;
z-index: -1;
padding-top: 150px;
margin-top: -150px;
display: block;
content: '';
}
@media screen and (max-width: 767px) {
.anc:before {
padding-top: 30vw;
margin-top: -30vw;
content: '';
}
}