@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Noto+Sans:ital,wght@0,100..900;1,100..900&family=Zen+Old+Mincho:wght@400;500;600;700&display=swap');
/* CSS Document */
html{
}
body{
	font-family: "Noto Sans", "Yu Gothic", "Hiragino Kaku Gothic ProN","Meiryo", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
	background-color: #EBEBEB;
	color: #433213;
}


/* ---------- common ---------- */

.title-style1{
	justify-content: flex-start;
}
.title-style4{
	position: relative;
}
.title-style4::after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 30px;
	height: 1px;
	background-color: #847D5F;
}
.title-style4 .title{
	margin-bottom: 30px;
}
.txt-vertical2{
    letter-spacing: 0.3em;
    line-height: 2.5;
}
.txt-vertical2 span {
    display: inline-block;
    border-right: 1px solid #847D5F;
    padding-right: 5px;
    margin-right: 5px;
}
.txt-vertical {
    letter-spacing: 0.4em;
}

.news_title_wrap{
	justify-content: space-between;
}
.title-style3{
	flex-direction: column;
}

.news_wrap .webgene-blog {
	display: -webkit-box;
	display: -moz-box;
	display: -ms-box;
	display: -webkit-flexbox;
	display: -moz-flexbox;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-box-lines: multiple;
	-moz-box-lines: multiple;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: row;
	gap: 50px 30px;
}
.news_wrap .webgene-blog .webgene-item h3 {
    display: -webkit-box;  
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
}
.news_wrap .webgene-blog .webgene-item {
	width: calc(100% / 3 - 60px / 3);
	transition: ease 0.3s;
}
.news_wrap .webgene-blog .webgene-item a{display:block}
.news_wrap .webgene-blog .webgene-item:hover {
	opacity: 0.5 !important;
}
.news_wrap .webgene-blog .webgene-item .cate {
	display: inline-block;
}
.news_wrap .webgene-blog .webgene-item .date {
    position: relative;
    padding-right: 15px;
    margin-right: 15px;
}
.news_wrap .webgene-blog .webgene-item .date::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 1px;
    height: 12px; 
    background-color: #fff; 
}
.onlineshop_wrap{
	overflow: hidden;
	position: relative;
}
.onlineshop_wrap .closebox{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 15;
	background-color: rgba(0,0,0,0.8);
	display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
    justify-content: center;
    align-items: center;
	flex-direction: row;
}
.onlineshop_wrap .closebox p{
	font-size: clamp(24px,5vw,40px);
	font-weight: 600;
	color: #fff;
	font-family: "Zen Old Mincho",  sans-serif;
}
.onlineshop_wrap .imgbox {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
	z-index: 10;
}
.onlineshop_wrap .imgbox .img1 {
    position: absolute;
    top: 0;
    left: 0;
    width: 30%;  
    height: auto;
}

.onlineshop_wrap .imgbox .img2 {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 30%;
    height: auto;
}
.onlineshop_wrap .txtbox{
	gap:50px;
	flex-direction: column;
}
.onlineshop_wrap::before,
.onlineshop_wrap::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background-color: #847D5F; 
}
.onlineshop_wrap::before {
  top: 20px;
}
.onlineshop_wrap::after {
  bottom: 20px;
}
.fix_bt{
	position: fixed;
	z-index: 99;
	width: 40%;
	max-width: 240px;
	right: 3%;
	bottom: 5px;
}
/* ---------- more ---------- */
.more_wrap{
	gap: 30px;
}

.more1 a {
	position: relative;
    --line: #857E60;
    --stroke: 1px;
    --inset: 8px;
    --tick: 42px;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 48px;
    min-width: 260px;
    color: #FDF7E7;
    text-decoration: none;
    background:
        linear-gradient(var(--line), var(--line)) top center / calc(100% - 2*var(--inset)) var(--stroke) no-repeat,
        linear-gradient(var(--line), var(--line)) bottom center / calc(100% - 2*var(--inset)) var(--stroke) no-repeat,
        linear-gradient(var(--line), var(--line)) left  center / var(--stroke) var(--tick) no-repeat,
        linear-gradient(var(--line), var(--line)) right center / var(--stroke) var(--tick) no-repeat;
    border: none;
	/*
    overflow: hidden;
	*/
    transition: background-size .35s ease, opacity .2s ease;
}
.more1 a::before,.more1 a::after{
}
.more1 a::before{
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - 20px);
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	border-left: 1px solid #857E60;
	border-right: 1px solid #857E60;
	transition: ease 0.3s;
}
.more1 a::after{
	content: "";
	position: absolute;
	width: calc(100% - 20px);
	height: 100%;
	border-top: 1px solid #857E60;
	border-bottom: 1px solid #857E60;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	transition: ease 1.0s;
}
.more1 a:hover::before{
	height: calc(100% + 20px);
}
.more1 a:hover::after{
	width: calc(100% + 20px);
}

/*
.more1 a:hover::before{
	animation-name: more1;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.more1 a:hover::after{
	animation-name: more2;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
@keyframes more1 {
	0% {
		height: 10%;
	}
	100% {
		height: calc(100% + 20px);
	}
}
@keyframes more2 {
	0% {
		width: 10%;
	}
	100% {
		width: calc(100% + 20px);
	}
}

.more1 a:hover {
    background-size:
        calc(100% - 2 * (var(--inset) + 8px)) var(--stroke),
        calc(100% - 2 * (var(--inset) + 8px)) var(--stroke),
        var(--stroke) calc(var(--tick) - 14px),
        var(--stroke) calc(var(--tick) - 14px);
}
*/

.more1-w a{
	--line: #FDF7E7;
}
.more-l{
	justify-content: flex-end;
}
.more-r{
	justify-content: flex-start;
}
.more2 {
  align-items: center;
  justify-content: center;
	margin-bottom: auto;
}
.more2 a {
  display: flex;
  align-items: center;
  text-decoration: none;
}
.more2 .icon {
  display: flex;
  align-items: center;
  margin-left: 10px;
  transition: transform 0.3s ease;
}
.more2 a:hover .icon {
  transform: translateX(5px);
}
.more2 .icon img {
  width: 24px;
  height: auto;
}
.more2_wrap .more2{
	padding: 10px 30px;
	border: #fff solid 1px;
	min-width: 400px;
}
.more-footer a{
	padding: 12px 22px;
    border: #FDF7E7 solid 1px;
    min-width: auto;
    width: 100%;
}
/* ---------- header ---------- */
.header {
  position: fixed;
  width: 100%;
  height: 90px;
  top: 0;
  left: 0;
  justify-content: space-between;
  gap: 20px;
  padding: 0 40px;
  z-index: 9999;
  background-color: transparent;
  transition: background-color 0.3s ease;
}
.header.scrolled {
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(6px);
}
.header {}
.header .logo {
  gap: 20px;
  justify-content: flex-start;
}
.header .logo img {
  max-width: 270px;
}
.header .header_right {
  gap: 40px;
}
.header .header_right .contact-bt {
  background-color: #033792;
  padding: 10px 20px;
  border-radius: 50px;
}
.header .header_right .contact-bt img {
  width: 15px;
}
.header .header_right .menu-bt {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  width: 60px;
  aspect-ratio: 1 / 1;
  cursor: pointer;
  border-radius: 3px;
}
.header .header_right .menu-bt .line {
  position: relative;
  width: 34px;
  height: 12px;
}
.header .header_right .menu-bt .line div {
  position: absolute;
  width: 100%;
  height: 1.2px;
  border-radius: 10px;
  background-color: #fff;
  transition: ease 0.4s;
}
/* -- header_news --*/
.header .header_news {
    display: flex;
    align-items: center;
    max-width: 700px;
    overflow: hidden;
}
.header_news .webgene-blog .webgene-item {
    width: auto;
}
.header_news .webgene-item a {
    display: flex;
    align-items: center;
    gap: 25px;
    text-decoration: none;
    white-space: nowrap;
}
.header_news .webgene-item a .labelbox {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 12px;
    flex: 0 0 auto;
    min-width: 0;
}
.header_news .webgene-item a .labelbox .date {
    display: flex;
    align-items: center;
}

.header_news .webgene-item a .labelbox .date::after {
    content: "";
    width: 1px;
    height: 1em;
    background-color: #FDF7E7;
    margin-left: 8px;
}
/* -- --*/
.header .header_right .menu-bt .line div:nth-of-type(1) {
    top: 0;
}
.header .header_right .menu-bt .line div:nth-of-type(2) {
    bottom: 0;
}
.header .header_right .menu-bt.active .line div:nth-of-type(1) {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
}
.header .header_right .menu-bt.active .line div:nth-of-type(2) {
    bottom: 50%;
    transform: translateY(50%) rotate(-45deg);
}
.menu-wrap {
  display: none;
  position: fixed;
  z-index: 999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.menu-wrap::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: 0.9;
  
}
.menu-wrap > div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 2;
  padding-left: 30px;
  padding-right: 30px;
}
.menu-wrap .ul {
  width: 90%;
  gap: 50px 30px;
  overflow: auto;
	background-color: rgba(0, 0, 0, 0.9);
	padding: 50px;
}
.menu-wrap .ul .menu_box {
  width: calc(100% / 3 - 60px / 3);
}
.menu-wrap .ul .menu_box a {
  position: relative;
  display: block;
  padding: 15px 50px;
  box-sizing: border-box;
  text-align: center;
  overflow: hidden;
  border-bottom: 1px solid #fff;
}
.menu-wrap .ul .menu_box a p.en {
  font-size: 26px;
  font-weight: 500;
	letter-spacing: 0.2em;
	color: #847D5F;
}
.menu-wrap .ul .menu_box a p.jp {
  font-size: 14px;
  font-weight: 500;
	color: #FDF7E7;
}

/* ---------- pagetitle ---------- */
.pagetitle{
	position: relative;
	width: 100%;
  	height: clamp(260px, 50vw, 500px);
    display: flex;
 	justify-content: center;
  	align-items: center;
	background-color: #000;
	padding-top: 85px!important;
	padding-bottom: 0!important;
}
body.on .pagetitle::after{
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0; left: 0;
	display: flex;
    background: rgba(0, 0, 0, 0.3);
	z-index: 1;
}
.pagetitle .bg_img_wrap2{
	position: relative;
	overflow: hidden;
}
.pagetitle .title_wrap{
	width: 100%;
	height: 100%;
	position: relative;
}
.pagetitle .titlebox {
   flex-direction: column;
   z-index: 3;
   width: 100%;
}

.header .header_news.swiper-container{
}
.header .header_news.swiper-container{
	height: 20px;
	overflow: hidden;
}
.header .header_news .webgene-blog .webgene-item{
	opacity: 1;
}
.header .header_news .webgene-blog .webgene-item a{
	flex-wrap: nowrap;
	width: auto;
}

/* ---------- footer ---------- */
.footer{
	position: relative;
	z-index: 3;
}
.footer .topbox .footer-menu{
	gap: 40px;
}
.footer .footer-contactbox {
	gap: 40px;
	background-color: #343434;
	margin-top: 60px;
	justify-content: space-around;
	padding: 60px 80px;
}
.footer .footer-contactbox .titlebox{
	flex-direction: column;
	align-items: flex-start;
	width: calc(20% - 20px);
}
.footer .footer-contactbox .rightbox{
	width: calc(80% - 20px);
}
.footer .footer-contactbox .telbox{
	margin-left: 50px;
}
.footer .footer-contactbox .telbox img{
	width: 25px;
	margin-right: 10px;
}
.footer .bottombox{
	flex-direction: column;
	gap:20px;
	margin-top: 80px;
}
.footer .bottombox .txtbox{
	flex-direction: column;
	gap:10px;
}
.footer .copyright{
	color: #848484;
}
/* ---------- font ---------- */
.en_title{
	font-family: "EB Garamond",  sans-serif;
	font-size: 80px;
	letter-spacing: 0.2em;
    font-weight: 400;
}
.en_title2{
	font-family: "EB Garamond",  sans-serif;
	font-size: 60px;
	letter-spacing: 0.2em;
    font-weight: 400;
}
.en_title3{
	font-family: "EB Garamond",  sans-serif;
	font-size: 50px;
	letter-spacing: 0.2em;
    font-weight: 400;
}
.en_title4{
	font-family: "EB Garamond",  sans-serif;
	font-size: 40px;
	letter-spacing: 0.2em;
    font-weight: 400;
}
.en_title5{
	font-family: "EB Garamond",  sans-serif;
	font-size: 30px;
	letter-spacing: 0.2em;
    font-weight: 400;
}
.default_title{ 
	font-size: 28px;
	letter-spacing: 0.1em;
}
.default_title2{
	font-size: 24px;
	letter-spacing: 0.1em;
}
.default_title3{
	font-size: 22px;
	letter-spacing: 0.1em;
}

.default_txt{
	font-size: 20px;
	letter-spacing: 0.1em;
}
.default_txt2{
	font-size: 18px;
	letter-spacing: 0.1em;
}
.default_txt3{
	font-size: 16px;
	letter-spacing: 0.1em;
}
.default_txt4{
	font-size: 14px;
	letter-spacing: 0.1em;
}


.font-eb{
	font-family: "EB Garamond",  sans-serif;
}
.font-mincho{
	font-family: "Zen Old Mincho",  sans-serif;
}
.font-noto{
	font-family: "Noto Sans",  sans-serif;
}
.lh-2{
	line-height: 2;
}
.lh-3{
	line-height: 3;
}
/* ---------- default ---------- */
body .bg_img_wrap {
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
body.on .bg_img_wrap .bg_img{
	display: none;
}
body .bg_img_wrap2 {
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
body.on .bg_img_wrap2 > img{
	display: none;
}

a{
	display: inline-block;
	transition: ease 0.3s;
}
a:hover{
	opacity: 0.5;
}
a p,a,a i{
	color: #000000;
}
.font-medium{font-weight: 500;}
.font-semibold{font-weight: 600;}
.font-black{font-weight: 900;}

.pd_wrap{
	padding: 150px 80px 0;
}
.pd_wrap_all{
	padding: 150px 80px 150px;
}
.pd_wrap_side{
	padding-left: 80px;
	padding-right: 80px;
}

.cate_wrap > .cate{
	padding-top: 150px;
}


/* ANIME */
.sc-anime.topin.on{
	opacity:0;
	transform: translateY(-50px);
}
.sc-anime.topin.on.active{
	animation-name: topin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.bottomin.on{
	opacity:0;
	transform: translateY(50px);
}
.sc-anime.bottomin.on.active{
	animation-name: bottomin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.leftin.on{
	opacity:0;
	transform: translateX(-50px);
}
.sc-anime.leftin.on.active{
	animation-name: leftin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.rightin.on{
	opacity:0;
	transform: translateX(50px);
}
.sc-anime.rightin.on.active{
	animation-name: rightin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.fadein.on{
	opacity:0;
}
.sc-anime.fadein.on.active{
	animation-name: fadein;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.blurin.on{
	opacity:0;
	-ms-filter: blur(6px);
	filter: blur(6px);
}
.sc-anime.blurin.on.active{
	animation-name: blurin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.blurin2.on{
	opacity:0;
	transform: translateY(50px);
	-ms-filter: blur(6px);
	filter: blur(6px);
}
.sc-anime.blurin2.on.active{
	animation-name: blurin2;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}

@keyframes topin {
	0% {
		opacity:0;
		transform: translateY(-50px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
	}
}
@keyframes bottomin {
	0% {
		opacity:0;
		transform: translateY(50px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
	}
}
@keyframes leftin {
	0% {
		opacity:0;
		transform: translateX(-50px);
	}
	100% {
		opacity:1;
		transform: translateX(0px);
	}
}
@keyframes rightin {
	0% {
		opacity:0;
		transform: translateX(50px);
	}
	100% {
		opacity:1;
		transform: translateX(0px);
	}
}
@keyframes upin {
	0% {
		transform: translateY(100%);
	}
	100% {
		transform: translateY(0);
	}
}
@keyframes fadein {
	0% {
		opacity:0;
	}
	100% {
		opacity:1;
	}
}
@keyframes fadeout {
	0% {
		opacity:1;
	}
	100% {
		opacity:0;
	}
}
@keyframes blurin {
	0% {
		opacity: 0;
		-ms-filter: blur(6px);
		filter: blur(6px);
	}
	100% {
		opacity:1;
		-ms-filter: blur(0px);
		filter: blur(0px);
	}
}
@keyframes blurin2 {
	0% {
		opacity: 0;
		transform: translateY(50px);
		-ms-filter: blur(6px);
		filter: blur(6px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
		-ms-filter: blur(0px);
		filter: blur(0px);
	}
}
/* color */
.txt-color-normal{color: #433213;}
.txt-white{color: #ffffff;}
.txt-red{color: red;}
.txt-color1{color: #847D5F}
.txt-color2{color: #FDF7E7}
.txt-color3{color: #1A1A1A}

.txt-color4{color: #EBF5E5}
.bg-white{background-color: #ffffff;}
.bg-black{background-color: black}
.bg-color1{background-color: #000000}
.bg-color2{background-color: #847D5F}
.bg-color3{background-color: #343434}
.bg-color4{background-color: #E2E2E2}

.border-color1{border-color: #FFE93C}
.border-color2{border-color: #F1F1E9}
.border-color3{border-color: #021745}  
.border-color4{border-color: #EBF5E5}

.hvr-txt-color-normal:hover{color: #000000;}
.hvr-txt-white:hover{color: #ffffff;}
.hvr-txt-red:hover{color: red;}
.hvr-txt-color1:hover{color: #FFE93C}
.hvr-txt-color2:hover{color: #F1F1E9}
.hvr-txt-color3:hover{color: #021745}
.hvr-txt-color4:hover{color: #EBF5E5} 
.hvr-bg-white:hover{background-color: #ffffff;}
.hvr-bg-black:hover{background-color: black}
.hvr-bg-color1:hover{background-color: #FFE93C}
.hvr-bg-color2:hover{background-color: #F1F1E9}
.hvr-bg-color3:hover{background-color: #021745}
.hvr-bg-color4:hover{background-color: #EBF5E5}
.hvr-border-color1:hover{border-color: #FFE93C}
.hvr-border-color2:hover{border-color: #F1F1E9}
.hvr-border-color3:hover{border-color: #021745}
.hvr-border-color4:hover{border-color: #EBF5E5}

/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}

/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
	.pd_wrap{
		padding: 150px 60px 0;
	}
	.pd_wrap_all{
		padding: 150px 60px 150px;
	}
	.pd_wrap_side{
		padding-left: 60px;
		padding-right: 60px;
	}
/* ---------- common ---------- */
	.onnlineshop_wrap .txtbox{
		gap:30px;
	}
/* ---------- header ---------- */

	.header .header_news {
		display: none;
	}
	.header{
		padding: 0 30px;
	}
	.header .logo img{
		max-width: 220px;
	}
	.header .header_right{
		gap: 20px;
	}
	.menu-wrap .ul{
		gap: 30px 30px;
	}
	.menu-wrap .ul .menu_box{
		width: calc(100% / 3 - 60px / 3);
	}
	.menu-wrap .ul .menu_box a p{
		font-size: 18px;
	}
	.pagetitle {
		height: 450px;
	  }
/* ---------- footer ---------- */
    .footer .topbox .footer-menu {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr)); 
        gap: 40px; 
        width: 100%;
    }
    .footer .topbox .footer-menu .menu_box {
        display: flex;
        justify-content: center; 
        align-items: center;
    }
	.footer .footer-contactbox .telbox img {
		width: 22px;
	}
/* ---------- font ---------- */
	.en_title{
		font-family: "EB Garamond",  sans-serif;
		font-size: 68px;
		letter-spacing: 0.2em;
		font-weight: 400;
	}
	.en_title2{
		font-family: "EB Garamond",  sans-serif;
		font-size: 50px;
		letter-spacing: 0.2em;
		font-weight: 400;
	}
	.en_title3{
		font-family: "EB Garamond",  sans-serif;
		font-size: 40px;
		letter-spacing: 0.2em;
		font-weight: 400;
	}
	.en_title4{
		font-family: "EB Garamond",  sans-serif;
		font-size: 30px;
		letter-spacing: 0.2em;
		font-weight: 400;
	}

	.default_title{ 
		font-size: 24px;
		letter-spacing: 0.1em;
	}
	.default_title2{
		font-size: 20px;
		letter-spacing: 0.1em;
	}
	.default_title3{
		font-size: 18px;
		letter-spacing: 0.1em;
	}

	.default_txt{
		font-size: 20px;
		letter-spacing: 0.1em;
	}
	.default_txt2{
		font-size: 18px;
		letter-spacing: 0.1em;
	}
	.default_txt3{
		font-size: 16px;
		letter-spacing: 0.1em;
	}
	.default_txt4{
		font-size: 14px;
		letter-spacing: 0.1em;
	}
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
/* ---------- common ---------- */

	.more1 a {
		min-width: 180px;
		padding: 14px 30px;
	}
	.news_wrap .webgene-blog{
		gap: 50px;
	}
	.news_wrap .webgene-blog .webgene-item {
		width: calc(100% / 2 - 50px / 2);
	}
/* ---------- header ---------- */
	.header {
	  height: 80px;
	  padding: 0 30px;
	}
	.header .header_right > a{
		display: none;
	}
	.header .logo{
		max-width: 50%;
	}
	.menu-wrap .ul{
		gap: 30px 50px;
	}
	.menu-wrap .ul .menu_box{
		width: calc(100% / 2 - 50px / 2);
	}
	.menu-wrap .ul .menu_box a p{
		font-size: 16px;
	}
    .pagetitle {
		height: 400px;
	  }
/* ---------- font ---------- */
	.en_title{
		font-size: 54px;
	}
	.en_title2{
		font-size: 44px;
	}
	.en_title3{
		font-size: 34px;
	}
	.en_title4{
		font-size: 28px;
	}

	.default_title{ 
		font-size: 22px;
		letter-spacing: 0.1em;
	}
	.default_title2{
		font-size: 20px;
		letter-spacing: 0.1em;
	}
	.default_title3{
		font-size: 18px;
		letter-spacing: 0.1em;
	}

	.default_txt{
		font-size: 18px;
		letter-spacing: 0.1em;
	}
	.default_txt2{
		font-size: 16px;
		letter-spacing: 0.1em;
	}
	.default_txt3{
		font-size: 14px;
		letter-spacing: 0.1em;
	}
	.default_txt4{
		font-size: 14px;
		letter-spacing: 0.1em;
	}
/* ---------- footer ---------- */
    .footer .topbox .footer-menu {
        grid-template-columns: repeat(3, minmax(0, 1fr)); 
    }
	.footer .footer-contactbox {
		flex-direction: column;
		padding: 30px 40px;
	}
	.footer .footer-contactbox .titlebox{
		align-items: center;
		width: 100%;
	}
	.footer .footer-contactbox .rightbox{
		width: 100%;
	}
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
	.pd_wrap{
		padding: 100px 50px 0;
	}
	.pd_wrap_all{
		padding: 100px 50px 100px;
	}
	.pd_wrap_side{
		padding-left: 50px;
		padding-right: 50px;
	}
	.cate_wrap > .cate{
		padding-top: 100px;
	}
/* ---------- common ---------- */
    .flex-tb {
        display: -webkit-box;
        display: -moz-box;
        display: -ms-box;
        display: -webkit-flexbox;
        display: -moz-flexbox;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: flex;
        -webkit-box-lines: multiple;
        -moz-box-lines: multiple;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        justify-content: flex-end;
        align-items: center;
        flex-direction: row;
    }
	.onnlineshop_wrap .txtbox p span{
		display: inline-block;
	}
	.onnlineshop_wrap .txtbox p{
		line-height: 2em;
	}
	.onnlineshop_wrap .txtbox{
		gap:20px;
	}
	.txt-vertical2 span {
		padding-right: 0px;
		margin-right: 0px;
	}
/* ---------- header ---------- */
	.header{
		padding: 0 20px;
		height: 70px;
	}
	.header .logo{
		gap: 10px;
	}
	.header .header_right{
		gap: 15px
	}
	.header .header_right .menu-bt{
		width: 50px;
	}
	.header .logo img{
		max-width: 180px;
	}
	.header .header_right .menu-bt{
		width: 50px;
	}
	.menu-wrap .ul{
		gap: 30px;
	}
	.menu-wrap .ul .menu_box{
		width: calc(100% / 2 - 30px / 2);
	}
	.menu-wrap .ul {
		padding: 30px;
	}
    .pagetitle {
		height: 300px;
	  }
   .menu-wrap .ul .menu_box a p.en {
      font-size: 22px;
  }
/* ---------- footer ---------- */
	.footer .footer-contactbox {
		gap: 40px;
		margin-top: 40px;
	}
	.footer .footer-contactbox .rightbox {
		flex-direction: column;
	}
	.footer .footer-contactbox .telbox {
		margin-left: 0px;
		margin-top: 20px;
	}
    .footer .footer-contactbox {
        gap: 20px;
    }
}
/* ---------- スマートフォン ---------- */
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	.pd_wrap{
		padding: 80px 20px 0;
	}
	.pd_wrap_all{
		padding: 80px 20px 80px;
	}
	.pd_wrap_side{
		padding-left: 20px;
		padding-right: 20px;
	}
	.cate_wrap > .cate{
		padding-top: 80px;
	}
/* ---------- common ---------- */
	.title-style1{
		flex-direction: column;
		align-items: flex-start; 
	}
	.title-style1 h2{
		padding-left: 0px;
	}
	.news_wrap .webgene-blog{
		gap: 40px;
		justify-content: center;
	}
	.news_wrap .webgene-blog .webgene-item {
		width: 90%;
	}
    .more1 a {
        min-width: 180px;
        padding: 10px 22px;
    }
	.more1 a {
		--inset: 9px;
		--tick: 36px;
	}
	.onlineshop_wrap .default_txt3 span{
		display: inline-block;
	}
/* ---------- header ---------- */
	.header{
		height: 60px;
		padding: 0 10px;
	}
	.header .logo{
		max-width: 66%;
	}
	.header .header_right{
		gap: 10px;
	}
	.header .logo img{
		max-width: 150px;
	}
	.header .header_right .menu-bt{
		width: 40px;
	}
	.header .header_right .menu-bt .line{
		width: 30px;
		height: 10 px;
	}
	.header .header_right .menu-bt .line div{
		height: 2px;
	}
	.menu-wrap > div{
		padding: 120px 0 50px;
	}
	.menu-wrap .ul{
		gap: 0 10px;
	}
	.menu-wrap .ul .menu_box{
		width: calc(50% - 5px);
	}
	.menu-wrap .ul .menu_box a{
		padding: 20px 0;
	}
	.menu-wrap .ul .menu_box a p.en{font-size: 16px;}
	.menu-wrap .ul .menu_box a p.jp{font-size: 13px;}
    .pagetitle {
		height: 270px;
	  }
	.menu-wrap .ul {
		padding: 20px;
	}
/* ---------- font ---------- */
	.en_title{
		font-size: 36px;
	}
	.en_title2{
		font-size: 30px;
	}
	.en_title3{
		font-size: 26px;
	}
	.en_title4{
		font-size: 24px;
	}

	.default_title{ 
		font-size: 18px;
		letter-spacing: 0.1em;
	}
	.default_title2{
		font-size: 18px;

		letter-spacing: 0.1em;
	}
	.default_title3{
		font-size: 16px;
		letter-spacing: 0.1em;
	}

	.default_txt{
		font-size: 16px;
		letter-spacing: 0.1em;
	}
	.default_txt2{
		font-size: 15px;
		letter-spacing: 0.1em;
	}
	.default_txt3{
		font-size: 14px;
		letter-spacing: 0.1em;
	}
	.default_txt4{
		font-size: 12px;
		letter-spacing: 0.1em;
	}
	.lh-3{
		line-height: 2;
	}
	
/* ---------- footer ---------- */
    .footer .topbox .footer-menu {
        grid-template-columns: repeat(2, minmax(0, 1fr)); 
    }
	.footer .bottombox {
		margin-top: 50px;
	}

}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}
