@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Noto+Sans+JP:wght@100..900&family=Zen+Old+Mincho:wght@400;500;600;700&display=swap');
/* CSS Document */
p span,
h1 span,
h2 span,
h3 span,
h4 span {
  display: inline-block;
}

html{
}
body{
	font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	background-color: #FEFFF7;
	color: #222222;
}

/* ---------- common ---------- */
.spbr br{display: none;}
.fix_bt{
	position: fixed;
	z-index: 99;
	width: 40%;
	max-width: 220px;
	left: 1%;
	bottom: 150px;
}
.br-sp br{
	display: none;
}
.br-tb br{
	display: none;
}
.span-green span{
	color: #1F8C55;
}
.worry-wrap .worry-box {
    position: relative;
    z-index: 2; 
}
.title-style1 h2{
	position: relative;
	padding-bottom: 5px;
}
.title-style1 h2::after{
	content: "";
    position: absolute;
    bottom: -40px; 
    left: 50%;
    transform: translateX(-50%);
    width: 100%; 
    height: 40px;
    background: url("https://lifestage21.jp/system_panel/uploads/images/top-titleline.svg") center/contain no-repeat;
}
.title-style2{
	justify-content: space-between;
}
.title-style2 .leftbox{
	align-items: flex-start;
	gap: 5px;
}
.title-style3 {
	flex-direction: column;
}
.title-style3 .en_title{
	line-height: 1;
    margin-bottom: -3.5vw;
	opacity: 0.15;
	color: #937F70;
	font-weight: 400;
	font-size: 90px;
}
.worry-wrap .worry-box{
	background-color: #fff;
	box-shadow: 0 0px 20px rgba(0,0,0,0.3);
	border-radius: 8px;
	gap :20px 40px;
	padding: 60px 10%;
}
.worry-wrap .worry-box .worry-item{
	width: calc(50% - 20px);
	position: relative;
	justify-content: flex-start;
	padding: 10px;
	background-image: repeating-linear-gradient(
        to right,
        #C4E8D9 0,
        #C4E8D9 2px,
        transparent 2px,
        transparent 6px
    );
    background-repeat: repeat-x;
    background-position: bottom left;
    background-size: 8px 2px;
}
.worry-wrap .titlebox {
    position: relative;
    align-items: center;             
    padding-inline: 140px;                 
}
.worry-wrap .worry-box .worry-item {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 10px;
}
.worry-wrap .worry-box .worry-item img {
    width: 100%;
    max-width: 25px;
    flex: 0 0 10%;
	padding-top: 3px;
    margin-right: 10px;
    align-items: center;
}
.worry-wrap .worry-box .worry-item p {
    flex: 0 0 90%;   
    min-width: 0;
    word-break: break-word;
}
.worry-wrap .titlebox::before {
    content: "";
    position: absolute;
    left: 10%;                         
    top: 60%;
    transform: translateY(-50%);
    width: 160px;                    
    height: 160px;
    background: url("https://lifestage21.jp/system_panel/uploads/images/worry-item1.svg") center/contain no-repeat;
    pointer-events: none;
}
.worry-wrap .titlebox::after {
    content: "";
    position: absolute;
    right: 10%;                      
    top: 60%;
    transform: translateY(-50%);
    width: 160px;
    height: 160px;
    background: url("https://lifestage21.jp/system_panel/uploads/images/worry-item2.svg") center/contain no-repeat;
    pointer-events: none;
}
.morebox_wrap .box{
	padding: 60px 50px;
	border-radius: 20px;
}
.bg-illust1::before,
.bg-illust1::after {
    content: "";
    position: absolute;
    bottom: 0;                    
    height: clamp(140px, 26vh, 260px); 
    width: auto;                  
    aspect-ratio: 3 / 4;        
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: contain;      
    pointer-events: none;
    z-index: 0;                 
}
.bg-illust1::before {
    left: 5%;         
    background-image: url("https://lifestage21.jp/system_panel/uploads/images/bg-illust1-1.svg");
    background-position: bottom left;
}
.bg-illust1::after {
    right: 5%;
    background-image: url("https://lifestage21.jp/system_panel/uploads/images/bg-illust1-2.svg"); 
    background-position: bottom right;
}
.bg-illust1 > * {
    position: relative;
    z-index: 1;
}
.news_b.news_list .contents .webgene-blog .webgene-item h2 {
    line-height: 1.5;
}
.news_b.news_list .contents .webgene-blog .webgene-item a > .default_txt3 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news_b.news_list .contents .webgene-blog .webgene-item {
    width: calc(100% / 3 - 80px / 3); 
}
.news_b .webgene-blog .webgene-item .catename {
    border-radius: 2px;
	background-color: #937F70;
}

.submenu_g .box_wrap .box .boxitem {
	width: 100%;
	align-items: center;
}
.submenu_g .box_wrap .box .flex .txtbox {
    align-items: center;
}
.submenu_g .more2{
	position: relative;
}
.submenu_g .more2:not(:last-of-type){
	margin-bottom: 20px;
}
.submenu_g .more2 a{
	display: block;
	padding: 10px 0;
	position: relative;
}
.submenu_g .more2 i{
	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: 22px;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	background-color: #017138;
	color: #fff;
	transition: ease 0.3s;
	margin-left: 15px;
}
.submenu_g .box_wrap a:hover .more2 i {
    transform: translateX(2px);
}
.submenu_g .box_wrap .box .flex .txtbox {
    width: 100%;
}
.property_top .span-26 span{
	font-size: 26px;
}
.property_top.news_list .contents .webgene-blog .webgene-item .box-item{
	justify-content: flex-start;
	gap: 10px;
}
.property_top.news_list .contents .webgene-blog .webgene-item .box-item img{
	width: 17px;
}
.news_top{
	gap: 40px;
	width: 100%;
}
.news_top .title-style2{
	flex-direction: column;
	justify-content: flex-start;
    align-items: flex-start;
}
.news_top .left-box{
	width: calc(30% - 20px)
}
.news_top .contents{
	width: calc(70% - 20px)
}
.news_top .webgene-blog .webgene-item{
}
.news_top .webgene-blog .webgene-item a > .flex{
	gap: 20px;
	padding: 20px 0;
}
.news_top .webgene-blog .webgene-item a .date{
	width: 100px;
	letter-spacing: 0.1em;
}
.news_top .webgene-blog .webgene-item a .catelabel{
	background-color: #fff;
}
.news_top .webgene-blog .webgene-item a .cate_txt{
	width: 85px;
	text-align: center;
	padding: 2px 3px;
	box-sizing: border-box;
	border-radius: 2px;
}
.news_top .webgene-blog .webgene-item a h3{
	width: calc(100% - 240px);
}
.news_top .left-box .more{
	justify-content: flex-start;
}
.contact_j .ca-inner {
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
}
.contact_j .ca-btn-icon img {
    width: 20px;
	padding-bottom: 3px;
}
.contact_j .ca-btn-icon img.img2{
    width: 30px;

}

.contact_j .ca-btn {
    border: 1px solid #4A4446;
    border-radius: 50px;
    color: #4A4446;
}
.contact_j .ca-note p {
    margin: 10px 0 18px;
    text-align: center;
    color: #222222;
    font-size: 16px;
	margin-top: 30px
}
.contact_j .ca-row {
	margin: 0px auto;
    gap: 60px;
}
.contact_j .ca-divider {
    width: 1px;
    height: 70px;
    background: #222222;
    flex: 0 0 auto;
}
.contact_j .bg-illust1::before,
.contact_j .bg-illust1::after {
    top: 0%;                    
    height: clamp(140px, 18vh, 260px);          
}
.contact_j .ca-note p br{
	display: none;
}
.footer_f {
    background-color: #3D7156;
    padding-top: 90px;
    padding-bottom: 80px;
}
.footer_f .topbox .title {
    border-bottom: #B3B3B3 solid 1px;
}
.footer_f p, .footer_f i {
    color: #FFF;
}

.footer_f .topbox .item img {
    width: 20px;
	margin-right: 10px;
}
.comparison_wrap .box_wrap{
	gap: 50px;
	align-items: flex-start;
}
.comparison_wrap .box_wrap .box-item{
	gap: 20px;
	width: calc((100% - 100px) /3);
}
.comparison_wrap .box_wrap .box-item .topbox h3{
	background-color: #F6F6F6;
	padding: 20px 40px;
	border-radius: 50px;
}
.comparison_wrap .box_wrap .box-item img{
	width: 150px;
}
.comparison_wrap .box_wrap .box-item .topbox{
	position: relative;
}
.comparison_wrap .box_wrap .box-item .topbox .num {
    position: absolute;
    top: -15px;
    left: 50%;
	transform: translateX(-50%); 
    z-index: 2;
    font-family: "EB Garamond", sans-serif;
    font-size: 28px;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #017138;
    line-height: 1;
}
.empty-wrap .title-style1 h2 span {
    background-color: rgba(249, 198, 99, 0.6);
    border-radius: 20px;
    padding: 0 10px;
}
.price_wrap .span-16 span{
	font-size: 16px;
	font-weight: 400;
}
.price_wrap .box_wrap{
	gap: 10px;
}
.price_wrap .box_wrap .box-item{
    align-items: stretch;
    width: 100%;
    border-radius: 10px;
    overflow: hidden; 
    background: transparent; 
}
.price_wrap .box_wrap .box-item h3{
    flex: 1 1 auto;         
    margin: 0;
    background: #FFFFFF;
    padding: 18px 24px 18px 50px;
}
.price_wrap .box_wrap .box-item p{
    flex: 0 0 220px; 
    align-items: center;
    justify-content: center;
    margin: 0;
    background: #FADD9D; 
}
.swiper_a {
    --band-h: 400px;
    height: var(--band-h);
}
.swiper_a img {
    display: block;
    height: var(--band-h);  
    width: auto;
}
.swiper_a .swiper-wrapper {
    transition-timing-function: linear !important;
}

.swiper_a .swiper-slide {
    opacity: 1 !important;
    width: auto;
}
.swiper_a .swiper-slide { 
    opacity: 1 !important;
}
.swiper_a .swiper-slide { margin-right: 0 !important; }
.swiper-container.swiper_a .swiper-slide img {
    display: block;
    border-radius: 4px;
}
.swiper-container.swiper_a { overflow: hidden; }
.swiper-container.swiper_a .swiper-slide { 
    width: auto;
    margin-right: 10px;           
}
/* ---------- more ---------- */
.more a{
	position: relative;
	min-width: 260px;
	border-radius: 200px;
	justify-content: space-between;
	padding: 10px 20px;
	background-color: #F6F6F6;
	border: 1px solid #C4E8D9;
}
.more a > div{
	position: relative;
	z-index: 2;
	border-radius: 10px;
	padding: 10px;
	gap: 15px;
	justify-content: space-between;
    width: 100%;
}
.more a .icon{
	width: 30px;
	aspect-ratio: 1 / 1;
	background-color: #017138;
	border-radius: 50%;
	transition: ease 0.3s;
}
.more a:hover .icon{
	transform: translateX(3px);
}
.more a .icon i{
	color: #FAF9F5;
	font-size: 15px;
}
.more a p{
	font-family: "Noto Sans JP",  sans-serif;
	line-height: 1;
	font-weight: 500;
}
.more2 img{
	width: 60px;
	height: 60px;
}
.more2 a{
	min-width: 390px;
	border-radius: 10px;
	background-color: #017138;
}
.more2 a > div{
	padding: 5px 10px;
}
.more2 a .icon{
	background-color: #F6F6F6;
}
.more2 a .icon i{
	color: #017138;
}
.empty-wrap .morebox{
	gap: 30px;
}
.more3 a{
	mix-width: 700px;
	background-color: #017138;
	padding: 10px 50px;
}
.more3 a .icon{
	background-color: #F6F6F6;
}
.more3 a .icon i{
	color: #017138;
}
/* ---------- header ---------- */
.header_b .head_menu .menu-bt .line div {
    height: 3px;
    background-color: #017138;
	border-radius: 3px;
}
.menu-wrap.burgermenu_e .mene_box .nav_box {
    background-color: #3D7156;
}

/* ---------- pagetitle ---------- */
.pagetitle{
	gap: 50px;
	flex-wrap: nowrap;
	padding: 50px 30px 80px 30px;
}
.pagetitle .leftbox{
width: calc(50% - 25px);
	padding-left: 10%;
	padding-bottom: 5%;
	align-items: flex-start;
	margin-top: auto;
}
.pagetitle .rightbox{
	position: relative;
	width: calc(50% - 25px);
}
.pagetitle .leftbox h1{
	font-size: 28px;
	font-weight: 600;
	padding-top: 8px;
}
.pagetitle .en_title {
	position: absolute;
	top:15%;
	left:10%;
    opacity: 0.15;
    color: #937F70;
    font-weight: 400;
	z-index: 3;
}
body:not(.on) .pagetitle .en_title {
	position: static;
}
.pagetitle_e .pagetitle .titlebox p {
    font-family: "EB Garamond", sans-serif;
    font-size: 14px;
    font-weight: 400;
    color: #fff;
}
.pagetitle_e .pagetitle .titlebox h1 {
    color: #fff;
    font-family: "Zen Old Mincho", sans-serif;
    text-align: center;
    font-size: 30px;
    font-weight: 500;
	letter-spacing: 0.1em
}

/* ---------- footer ---------- */

/* ---------- font ---------- */
.en_title{
	font-family: "EB Garamond",  sans-serif;
	font-size: 100px;
	letter-spacing: 0.15em;
    font-weight: 500;
}
.en_title2{
	font-family: "EB Garamond",  sans-serif;
	font-size: 40px;
}
.default_title{ 
	font-size: 38px;
	letter-spacing: 0.1em;
}
.default_title2{
	font-size: 30px;
	letter-spacing: 0.1em;
}
.default_title3{
	font-size: 26px;
	letter-spacing: 0.05em;
}
.default_txt{
	font-size: 20px;
	letter-spacing: 0.05em;
}
.default_txt2{
	font-size: 18px;
	letter-spacing: 0.05em;
}
.default_txt3{
	font-size: 16px;
	letter-spacing: 0.05em;
}

.lh-2{
	line-height: 2;
}

.font-eb{
	font-family: "EB Garamond",  sans-serif;
}
.font-zen{
	font-family: "Zen Old Mincho",  sans-serif;
}
.font-noto{
	font-family: "Noto Sans JP",  sans-serif;
}

/* ---------- 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: #000000;}
.txt-white{color: #ffffff;}
.txt-red{color: red;}
.txt-color1{color: #1F8C55}
.txt-color2{color: #846C5B}
.txt-color3{color: #146583}
.txt-color4{color: #EBF5E5}
.bg-white{background-color: #ffffff;}
.bg-black{background-color: black}
.bg-color1{background-color: #F0F7DF}
.bg-color2{background-color: #BEE7E2}
.bg-color3{background-color: #937F70}
.bg-color4{background-color: #D8E0C3}
.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 ---------- */
.comparison_wrap .box_wrap .box-item .topbox h3{
  font-size: 16px;
  }
  .title-style3 .en_title{
		font-size: 70px;
	}
	.worry-wrap .worry-box .worry-item{
		width: 100%;
	}
	.worry-wrap .worry-box {
		gap: 15px;
		padding: 40px 20%;
	}
	.worry-wrap .titlebox::before,
	.worry-wrap .titlebox::after {
		width: 120px;
		height: 120px;
		top: 75%;
	}
	.worry-wrap .worry-box .worry-item img {
		max-width: 18px;
		flex: 0 0 10%;
		padding-top: 7px;
		margin-right: 10px;
		align-items: center;
	}
	.news_b.news_list .contents .webgene-blog .webgene-item {
		width: calc(100% / 2 - 80px / 2); 
	}
	.news_top > .flex {
		flex-direction: column;
	}
	.news_top .left-box {
		width: 100%;
		justify-content: space-between;
	}
	.news_top .contents {
		width: 100%;
	}

/* ---------- header ---------- */
/* ---------- pagetitle ---------- */
	.pagetitle .leftbox {
		padding-left: 5%;
		padding-bottom: 5%;
	}
	.pagetitle .en_title {
		top: 10%;
		left: 5%;
	}
/* ---------- footer ---------- */
/* ---------- font ---------- */
	.en_title{
		font-size: 70px;
	}
	.en_title2{
		font-size: 30px;
	}
	.default_title{ 
		font-size: 28px;
	}
	.default_title2{
		font-size: 26px;
	}
	.default_title3{
		font-size: 24px;
	}
	.default_txt{
		font-size: 20px;
	}
	.default_txt2{
		font-size: 18px;
	}
	.default_txt3{
		font-size: 16px;
	}
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
/* ---------- common ---------- */
        .fix_bt {
        width: 40%;
        bottom: 20px;
    }
	.title-style3 .en_title{
		font-size: 50px;
	}
	.worry-wrap .worry-box {
        padding: 40px 60px;
    }
	.worry-wrap .titlebox::before {
		left: 0%;
	}

	.worry-wrap .titlebox::after {
		right: 0%;             
	}
	.worry-wrap .titlebox {          
		padding-inline: 90px;                 
	}
	.bg-illust1::before,
	.bg-illust1::after {                  
		height: clamp(100px, 16vh, 260px);              
	}
	.contact_j .bg-illust1::before,
	.contact_j .bg-illust1::after {
		top: 10%;                    
		height: clamp(100px, 12vh, 260px);          
	}
	.comparison_wrap .box_wrap {
		gap: 100px 50px;
	}
	.comparison_wrap .box_wrap .box-item{
		gap: 20px;
		width: calc((100% - 50px) /2);
	}
	.empty-wrap .morebox{
		flex-direction: column;
	}
	.empty-wrap .morebox {
		gap: 10px;
	}
	.price_wrap .box_wrap .box-item {
		flex-direction: column;
	}
	.price_wrap .box_wrap .box-item h3 {
        padding: 16px 18px;
    }
    .price_wrap .box_wrap .box-item p {
        flex: 0 0 auto;
        width: 100%; 
		padding: 10px 18px;
    }
	.swiper_a {
    --band-h: 300px;
	}
/* ---------- header ---------- */
/* ---------- pagetitle ---------- */
	.pagetitle {
		gap: 30px;
		flex-wrap: nowrap;
		padding: 30px 60px 50px 60px;
	}
	.pagetitle .leftbox h1 {
		font-size: 24px;
		padding-top: 5px;
	}
	.pagetitle .en_title {
		top: 5%;
		left: 5%;
	}
/* ---------- footer ---------- */
/* ---------- font ---------- */
	.en_title{
		font-size: 60px;
	}
	.en_title2{
		font-size: 28px;
	}
	.default_title{ 
		font-size: 24px;
	}
	.default_title2{
		font-size: 22px;
	}
	.default_title3{
		font-size: 20px;
	}
	.default_txt{
		font-size: 18px;
	}
	.default_txt2{
		font-size: 18px;
	}
	.default_txt3{
		font-size: 16px;
	}
}
/* ---------- 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 ---------- */
      .fix_bt {
        width: 35%;
        bottom: 10px;
    }
	.worry-wrap .titlebox::before,
	.worry-wrap .titlebox::after {
		width: 100px;
		height: 100px;
		top: 100px;
	}
	.worry-wrap .titlebox {
        padding-inline: 0px;
		width: 100%;
		margin-bottom: 80px;
    }
    .worry-wrap .worry-box {
        gap: 10px;
        padding: 40px 30px;
    }
	.worry-wrap .worry-box .worry-item img {
		padding-top: 5px;
	}
	.bg-illust1::before,
	.bg-illust1::after {                  
		height: clamp(100px, 14vh, 260px);              
	}
	.morebox_wrap .box {
		padding: 40px 30px;
	}
	.submenu_g {
		gap: 20px;
	}
	.submenu_g .titlebox {
		gap: 10px;
	}
    .title-style3 .en_title {
        font-size: 40px;
    }
	.title-style3 .en_title {
		margin-bottom: -4vw;
	}
	.contact_j .ca-row {
		gap: 20px;
	}
	.contact_j .ca-divider {
		height: 30px;
	}
    .contact_j .ca-divider {
		display: none;
	}
	.contact_j .bg-illust1::before {
		left: -3%;         
	}
	.contact_j .bg-illust1::after {
		right: -3%;
	}
	.contact_j .bg-illust1::before,
	.contact_j .bg-illust1::after {
		top: 5%;                    
		height: clamp(100px, 12vh, 260px);          
	}
	.contact_j .ca-note p {
		font-size: 12px;
	}
	.comparison_wrap .box_wrap {
		gap: 80px;
	}
	.comparison_wrap .box_wrap .box-item{
		width: 100%;
	}
	.comparison_wrap .box_wrap .box-item p.default_txt3{
		width: 60%;
	}
	.br-tb br{
		display: inline-block;
	}
	.swiper_a {
    --band-h: 200px;
	}
/* ---------- header ---------- */
/* ---------- pagetitle ---------- */
	.pagetitle {
		flex-direction: column-reverse;
		padding: 30px 50px 100px 50px;
	}
	.pagetitle .rightbox {
		width: 100%;
		height: 100px;
		overflow: hidden;
	}
	.pagetitle .rightbox img{
		height: 100%;
		object-fit: cover;  
    	display: block;
	}
    .pagetitle .en_title {
        top: 8%;
        left: 3%;
    }
	.pagetitle .leftbox {
		width: 100%;
		padding-left: 0%;
		padding-bottom: 0%;
	}
	.pagetitle .thumb img { object-position: 50% 20%; }
/* ---------- footer ---------- */
/* ---------- font ---------- */
	.en_title{
		font-size: 40px;
	}
	.en_title2{
		font-size: 28px;
	}
	.default_title{ 
		font-size: 26px;
	}
	.default_title2{
		font-size: 24px;
	}
	.default_title3{
		font-size: 22px;
	}
	.default_txt{
		font-size: 18px;
	}
	.default_txt2{
		font-size: 16px;
	}
	.default_txt3{
		font-size: 15px;
	}
}
/* ---------- スマートフォン ---------- */
/* ---------- 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 ---------- */
  .spbr br{display: block;}
	.fix_bt{
		width: 35%;
		bottom: 10px;
	}
	.br-sp br{
		display: inline-block;
	}
	
    .worry-wrap .worry-box {
        gap: 10px;
        padding: 30px 20px;
    }
	.worry-wrap .bottombox h3{
        font-size: 16px;
    }
	.worry-wrap .titlebox::before,
	.worry-wrap .titlebox::after {
		width: 75px;
		height: 75px;
		top: 85px;
	}
    .worry-wrap .titlebox {
        margin-bottom: 60px;
    }
    .worry-wrap .titlebox h2{
        font-size: 20px;
    }	
    .worry-wrap .worry-box .worry-item {
        align-items: flex-start;
    }
    .worry-wrap .worry-box .worry-item img {
        max-width: 15px;
		padding-top: 5px;
        margin-right: 8px;
		align-items: center;
    }
    .worry-wrap .worry-box .worry-item p {
        flex: 0 0 90%;
		line-height: 1.5;
    }
	.bg-illust1::before,
	.bg-illust1::after {                  
		height: clamp(100px, 12vh, 260px);              
	}
	.news_b.news_list .contents .webgene-blog .webgene-item {
		width: 100%; 
	}

	.submenu_g .box_wrap .box .flex .en {
		font-size: 12px;
	}
    .submenu_g .box_wrap .box .flex h3 {
        font-size: 20px;
    }
    .submenu_g .titlebox p {
        font-size: 16px;
    }
    .title-style3 .en_title {
        font-size: 28px;
    }
	.contact_j .bg-illust1::before {
		left: -0%;         
	}
	.contact_j .bg-illust1::after {
		right: -0%;
	}
	.contact_j .bg-illust1::before,
	.contact_j .bg-illust1::after {
		top: 23%;                    
		height: clamp(80px, 10vh, 260px);          
	}
	.contact_j .ca-note p br{
		display: inline-block;
	}
	.contact_j .ca-note p {
		margin-top: 20px;
	}
	.news_top .webgene-blog .webgene-item a h3 {
		width: 100%;
	}
	.news_top .webgene-blog .webgene-item a .cate_txt {
		width: 70px;
		padding: 2px 5px;
	}
	.news_top .webgene-blog .webgene-item a > .flex {
		gap: 10px;
	}
	.comparison_wrap .box_wrap {
		gap: 50px;
	}
	.comparison_wrap .box_wrap .box-item{
		width: 100%;
	}
	.comparison_wrap .box_wrap .box-item p.default_txt3{
		width: 80%;
	}
	.comparison_wrap .box_wrap .box-item img {
		width: 100px;
	}
	.comparison_wrap .box_wrap .box-item .topbox h3 {
		padding: 10px 30px;
	}
	.comparison_wrap .box_wrap .box-item .topbox .num {
		font-size: 22px;
	}
/* ---------- more ---------- */
	.more a{
		min-width: 200px;
		padding: 5px 15px;
	}
	.more a .icon {
		width: 24px;
	}
	.more2 a{
		min-width: 280px;
	}
	.more2 img {
		width: 30px;
		height: 30px;
	}
	.more3 a p{
		font-size: 14px;
		line-height: 1.5;
	}
/* ---------- header ---------- */
	
    .pagetitle .en_title {
        top: 9%;
        left: 5%;
    }
    .pagetitle {
        gap: 20px;
        padding: 20px 20px 80px 20px;
    }
/* ---------- footer ---------- */
/* ---------- font ---------- */
	.en_title{
		font-size: 30px;
	}
	.en_title2{
		font-size: 26px;
	}
	.default_title{ 
		font-size: 22px;
	}
	.default_title2{
		font-size: 20px;
	}
	.default_title3{
		font-size: 18px;
	}
	.default_txt{
		font-size: 18px;
	}
	.default_txt2{
		font-size: 16px;
	}
	.default_txt3{
		font-size: 14px;
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}
