@charset "utf-8";


/* ----------------------------------------------------------------------- fv */
#fv{ position: relative; background: url(../images/area/fv_bg_1.jpg) no-repeat center center; background-size: 2607px; padding: 88px 50px 36px;}
#fv .fv_title{max-width: 1250px; margin: 0 auto;}
#fv .fv_title .flex{display: flex; }
#fv .fv_title .fv_top{align-items: center; justify-content: center; }
#fv .fv_title .fv_top p{padding: 0 0 0 44px; line-height: 118.9%; font-size: 37px; font-family: 'Noto-Sans-JP-Bold'; position: relative; margin: 0 55px 0 0;}
#fv .fv_title .fv_top p:before{content: ""; display: block; width: 27px; height: 41px; background: url(../images/area/fv_icn_1.svg) no-repeat center center; background-size: 100%; position: absolute; top: 50%; transform: translateY(-50%); left: 0px;}
#fv .fv_title .fv_bottom{align-items: end; justify-content: space-between; padding: 44px 0 0; gap: 0 25px;}
#fv .fv_title .fv_bottom .data_box{width: 100%;max-width: 601px;}
#fv .fv_title .fv_bottom .data_box p{font-size: 33px; line-height: 130.3%; font-family: 'Noto-Sans-JP-Bold'; }
#fv .fv_title .fv_bottom .data_box p span{color: #F7800B;}
#fv .fv_title .fv_bottom .data_box img{margin: 19px 0 0; width: 98%; height: auto;}
#fv .fv_title .fv_bottom .text_box{max-width: 622px; width: 70%; background: rgba(253,246,228,0.59); border-radius: 14px; padding: 43px 31px 37px 47px; display: flex; align-items: center; gap: 0 39px;}
#fv .fv_title .fv_bottom .text_box p{font-size: 18px; line-height: 183.3%; width: calc(100% - 77px); }
#fv .fv_slider{padding: 41px 0 0; display: flex; gap: 0 24px; max-width: 1492px; margin: 0 auto;}
#fv .fv_slider .img{width: calc(100% / 4); height: auto; overflow: hidden; border-radius: 15px;}
#fv .fv_slider .img img{width: 100%; height: auto;}

.title { background: url(../images/area/logo_bg.svg) no-repeat center center; background-size: 611px;}
.bread { margin: 18px 0 21px;}

/* ----------------------------------------------------------------------- area */
#area{padding: 61px 0 0;}
#area .flex{display: flex; flex-direction: row-reverse; padding: 51px 0 119px;}
#area .flex .text_box{width: 517px; height: auto; padding: 69px 0 0;}
#area .flex .text_box h4{font-size: 33px; line-height: 157.6%; font-family: 'Noto-Sans-JP-Bold'; }
#area .flex .text_box p{line-height: 200%; padding: 20px 0 30px;}
#area .flex .text_box p span{display: inline-block; padding-left: 1rem;line-height: 200%;}
#area .flex .text_box .link_box{display: inline-block;}
#area .flex .text_box .btn{display: inline-block; position: relative; padding: 16px 0 16px 89px; font-size: 18px; line-height: 200%; margin: 42px 0 0;}
#area .flex .text_box .btn span{display: block; position: absolute; left: 0px; top: 50%; transform: translateY(-50%); width: 68px; height: 68px; background: #FFB800; border-radius: 1000px;}
#area .flex .text_box .btn span:before{content: ""; display: block; width: 13px; height: 11px; background: url(../images/area/icn_1.svg) no-repeat center center; background-size: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);}
#area .flex .img{margin: 0 -16px 0 30px;}


/* ----------------------------------------------------------------------- service */
#service{background: #FFF8E6; padding: 78px 0 65px;}
#service .flex{padding: 22px 0 0; display: flex; justify-content: space-between;}
#service .flex .box{width: 357px; height: auto; background: #fff; border-radius: 20px; padding: 33px 20px 132px; position: relative; box-shadow: 0 3px 16px rgba(0,0,0,0.20);}
#service .flex .box h4{text-align: center; font-size: 13px; font-family: memimas-pro, sans-serif; font-weight: 700; font-style: normal; line-height: 160%; position: relative; padding: 0 0 15px;}
#service .flex .box h4 span {font-size: 30px; font-family: 'Noto-Sans-JP-Medium'; line-height: 150%; color: #000; display: inline-block; padding: 0 0 6px;}
#service .flex .box.box_1 h4 {color: #B8D200;}
#service .flex .box.box_2 h4 {color: #E36D5F;}
#service .flex .box.box_3 h4 {color: #A0D8EF;}
#service .flex .box h4:before{content: ""; display: block; width: 44px; height: 1px; position: absolute; bottom: 0px; left: 50%; transform: translateX(-50%);}

#service .flex .box.box_1 h4:before {background: #B8D200;}
#service .flex .box.box_2 h4:before {background: #E36D5F;}
#service .flex .box.box_3 h4:before {background: #A0D8EF;}

#service .flex .box .text_1{text-align: center; font-size: 18px; line-height: 150%; font-family: 'Noto-Sans-JP-Medium'; padding: 20px 0 0;}
#service .flex .box .service_img{padding: 31px 0 0; text-align: center;}
#service .flex .box .text_2{padding: 20px 0 0; text-align: center; font-size: 16px; line-height: 175%;}
#service .flex .box ul{padding: 15px 0 0;}
#service .flex .box ul li{border-radius: 100px; color: #fff; text-align: left; padding: 14px 12px 15px 30px; font-size: 13px; font-family: "hiragino-kaku-gothic-pron", sans-serif; font-weight: 600; font-style: normal; position: relative;}
#service .flex .box ul li:not(:last-child){margin: 0 0 11px;}
#service .flex .box ul li:before{content: ""; display: block; background: url(../images/area/icn_2.svg) no-repeat center center; background-size: 100%; width: 11px; height: 8px; position: absolute; top: 50%; transform: translateY(-50%); left: 13px;}
#service .flex .box .text_3{ font-size: 16px; line-height: 175%; padding: 26px 0 0;}
#service .flex .box .btn{display: inline-block; position: relative; padding: 15px 0 16px 83px; font-size: 16px; line-height: 200%;  width: 195px; position: absolute; bottom: 42px; left: 50%; transform: translateX(-50%);}
#service .flex .box .btn span{display: block; position: absolute; left: 0px; top: 50%; transform: translateY(-50%); width: 63px; height: 63px; background: #FFB800; border-radius: 1000px;}
#service .flex .box .btn span:before{content: ""; display: block; width: 13px; height: 11px; background: url(../images/area/icn_1.svg) no-repeat center center; background-size: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);}
#service .flex .box.box_1 ul li {background: #B8D200;}
#service .flex .box.box_2 ul li {background: #E36D5F;}
#service .flex .box.box_3 ul li {background: #A0D8EF;}

#service .flex .box.box_1 .btn span{background: #B8D200;}
#service .flex .box.box_2 .btn span{background: #E36D5F;}
#service .flex .box.box_3 .btn span{background: #A0D8EF;}

/* ----------------------------------------------------------------------- reasons */
#reasons{padding: 149px 0 70px;}
#reasons .reasons_bg{position: relative; background: url(../images/area/reasons_bg_1.jpg) no-repeat center center; background-size: cover; border-radius: 20px; padding: 16px;}
#reasons .reasons_bg .white_box{background: #fff; border-radius: 20px; padding: 64px 0 96px;}
#reasons .reasons_bg .white_box .title{position: absolute; top: -79px; left: 50%; transform: translateX(-50%); width: 100%;}
#reasons .reasons_bg .white_box p.big_tt{text-align: center; font-size: 34px; font-family: 'Noto-Sans-JP-Medium'; line-height: 160%; letter-spacing: 0.01em;}
#reasons .reasons_bg .white_box .flex{display: flex; flex-wrap: wrap; justify-content: space-between; padding: 66px 49px 0; gap: 80px 0; margin: 0 auto;}
#reasons .reasons_bg .white_box .flex .box{width: 50%; }
#reasons .reasons_bg .white_box .flex .box:nth-child(2n){width: 431px; }
#reasons .reasons_bg .white_box .flex .box img{vertical-align: top; }
#reasons .reasons_bg .white_box .flex .box .text_box{display: inline-block; padding: 35px 0 0 20px; text-align: center; vertical-align: top;}
#reasons .reasons_bg .white_box .flex .box .text_box p{font-family: 'Noto-Sans-JP-Medium'; font-size: 23px; background-image: linear-gradient(90deg, #FFDC19); background-repeat: no-repeat; background-position: bottom; background-size: 100% 30%; line-height: 160%; padding: 10px 0 4px;}

#reasons .btn{ padding-top: 55px; }
#reasons .btn--border{ margin: 0 auto; width: 362px; }
#reasons .btn--border .btn-linktxt{margin: 0px 66px 0 0;}
/* ----------------------------------------------------------------------- price */
#price{ padding: 181px 0 96px; background: #F8F7F1;}
#price .title{ position: absolute; top: -101px; left: 50%; transform: translateX(-50%); width: 100%;}

.price-box { background: #fff; border-radius: 20px; padding: 66px 30px 60px; margin: 0 auto; position: relative; }
.price-title { padding: 0 0 28px; text-align: center; font-size: 30px; font-family: 'Noto-Sans-JP-Bold'; }
.price-lead { margin: 0 0 35px; text-align: center; font-size: 18px; font-family: "hiragino-kaku-gothic-pron", sans-serif; font-weight: 600; font-style: normal; }
.price-flex { width: 77.22%; margin: 0 auto; display: flex; gap: 7% 33px; align-items: flex-start; padding: 51px 0 0;}
.visit_tt{display: flex; align-items: center; border-bottom: 7px solid #FFE200; width: 445px; margin: 0 auto;}
.visit_tt .price-tag{height: 51px; width: 163px; padding: 5px; font-size: 19px; margin-right: 16px;}
.visit_tt .price-amount__num { font-size: 70px; letter-spacing: -0.042em;}
.visit_tt .price-amount__yen {font-size: 40px; font-family: 'Noto-Sans-JP-Bold'; margin: 0 10px 0 7px;}


/* ---------- left ---------- */
.price-left { width: 442px; }
.price-summary { display: flex; flex-direction: column; gap: 34px; }
.price-row { display: flex; align-items: center; gap: 15px; }
.price-row.sp{display: none;}
.price-tag { display: inline-flex; align-items: center; justify-content: center; height: 40px; width: 131px; padding: 5px; border-radius: 100px; color: #fff; font-family: 'Noto-Sans-JP-Bold'; font-size: 16px; }
.price-tag--01 { background: var(--orange); }
.price-tag--02 { background: var(--green); }
.price-tag--03 { background: var(--blue); }
.price-tag--04 { background: #F08035; }

.price-amount { }
.price-amount__num { font-size: 35px; font-family: 'Noto-Sans-JP-Regular'; letter-spacing: -0.042em;}
.price-amount__yen { font-size: 20px; font-family: 'Noto-Sans-JP-Medium'; }

/* ---------- right ---------- */
.price-right { width: 339px; }
.price-menu { padding: 32px 0 0; display: flex; flex-wrap: wrap; gap: 5px; }
.price-menu span { display: flex; align-items: center; justify-content: center; width: 108px; height: 43px; border-radius: 6px; font-size: 20px; background: #D4D5D5; color: #8E8E8F; }
.price-menu span.color { background: var(--orange); color: #fff; }


.price-notes { margin: 30px 0 0; }
.price-notes__item { width: 100%; margin: 0 auto; font-size: 13px; line-height: 1.9; }
.price-notes__item:first-child { margin-top: 0; }

.btns{ display: flex; align-items: center; justify-content: center; gap: 10px; padding: 47px 0 0; }

.btns .btn{ width: calc(100% / 3 - 5px); }
.btns .btn__link{ padding: 9px; background: #fff; border-radius: 100px; }
.btns .btn .btn__arrow{width: 60px; height: 60px;}
.btns .btn.btn_1 .btn__arrow{background: #B8D201; border: 1px solid #B8D201;}
.btns .btn.btn_2 .btn__arrow{background: #E36D5F; border: 1px solid #E36D5F;}
.btns .btn.btn_3 .btn__arrow{background: #A0D8EF; border: 1px solid #A0D8EF;}


/* ----------------------------------------------------------------------- blog */
#blog{ position: relative; padding: 70px 0 96px; }
#blog .title{ margin: 0 0 25px; }
#blog .desc{ padding: 0 0 27px; }

.blog-wrapper{ padding: 0 5%; }
.blog-text{ width: 100%; }
.blog-list { display: flex; align-items: stretch; gap: 25px;justify-content: center; }

.blog-card { width: 400px; background: #fff; box-shadow: 0 0 26px rgba(0,0,0,0.16); overflow: hidden; transition: all .3s ease; }
.blog-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.12); }
.blog-card__link { display: block; color: inherit; text-decoration: none; }
.blog-card__photo { overflow: hidden; }
.blog-card__photo img { width: 100%; height: auto; display: block; object-fit: cover; }

.blog-card__body { padding: 30px 20px 40px; }
.blog-card__cat { font-size: 11px; font-family: 'Noto-Sans-JP-Bold'; color: var(--main-color); margin-bottom: 10px; }
.blog-card__title { font-size: 22px; font-family: 'Noto-Sans-JP-Medium'; line-height: 1.5; margin-bottom: 17px; }
.blog-card__desc { font-size: 16px; line-height: 2; margin-bottom: 29px; }
.blog-card__meta { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: #A3A3A3; }
.blog-card__author { display: flex; align-items: center; gap: 6px; }
.blog-card__icon { display: block; width: 10px; height: auto; }

#blog .btn{padding: 44px 0 0;}
#blog .btn .btn__link{margin: 0 auto; width: 407px; }
#blog .btn .btn__link .btn-linktxt{width: calc(100% - 137px); display: block; margin: 0 50px 0 0;}

/* ----------------------------------------------------------------------- faq */
#faq{ padding: 63px 0 95px; background: #F8F7F1;}

#faq ul{padding: 29px 0 0;}
#faq ul li{background: #fff; border-radius: 10px;}
#faq ul li.clos{padding: 33px 36px 30px 44px;}
#faq ul li:not(:last-child){margin: 0 0 18px;}
#faq ul li .tt{display: flex; gap:17px; position: relative; width: 100%;}
#faq ul li .tt .icn{text-align: center; font-size: 45px; font-family: "memimas-pro", sans-serif; font-weight: 900; font-style: normal; line-height: 100%;display: inline-block; width: 32px;}
#faq ul li h4.tt{ font-size: 29px; font-family: 'Noto-Sans-JP-Bold'; line-height: 142%; }
#faq ul li h4.tt .icn{color: #74AFC7;}
#faq ul li h4.tt .clos_box{position: absolute; width: 36px; height: 36px; display: block; right: 0px; top: 5px;}
#faq ul li h4.tt .clos_box:before{content: ""; display: block; width: 100%; height: 1px; transform: translate(-50%,-50%); top: 50%; left: 50%; position: absolute; background: #FEA100;}
#faq ul li h4.tt .clos_box:after{content: ""; display: block; width: 100%; height: 1px; transform: translate(-50%,-50%) rotateZ(90deg); top: 50%; left: 50%; position: absolute; transition: 0.5s; background: #FEA100;}
#faq ul li.clos.open .clos_box:after{transform: translate(-50%,-50%) rotateZ(0deg); transition: 0.5s;}
#faq ul li p.tt{font-size: 20px; line-height: 170%; padding: 28px 0 0; }
#faq ul li .tt_box{display: none;}
#faq ul li p.tt .icn{color: #F39801;}

/* ----------------------------------------------------------------------- access */
#access{padding: 69px 0 84px;}
#access .flex{padding: 46px 0 0; display: flex; justify-content: space-between;}
#access .flex .map_box{width: 490px; height: auto; position: relative; padding: 32% 0 0px;}
#access .flex .map_box iframe{position: absolute; top: 0px; left: 0px; width: 100%; height: 100%;}
#access .flex .text_box{width: 550px;}
#access .flex .text_box h4{font-size: 20px; line-height: 160%; font-family: 'Noto-Sans-JP-Bold'; padding: 39px 0 0;}
#access .flex .text_box ul{width: 100%; height: auto; margin: 22px 0 0;}
#access .flex .text_box ul li{display: flex; }
#access .flex .text_box ul li p.tt_1{background: #F8F7F1; padding: 19px 20px 21px; line-height: 150%; width: 125px; text-align: left;}
#access .flex .text_box ul li p.tt_2{background: #F8F7F1; padding: 19px 0 21px; line-height: 150%; width: calc(100% - 125px);}
#access .flex .text_box ul li:not(:last-child){padding-bottom: 2px;}


@media only screen and (max-width: 768px) {

/* ----------------------------------------------------------------------- fv */
	#fv{background: url(../images/area/fv_bg_1_sp.jpg) no-repeat center top; background-size: 100%; padding: 45px 0 16px; }
	#fv .fv_title{max-width: 1250px; margin: 0 auto;}
	#fv .fv_title .flex{display: block; }
	#fv .fv_title .fv_top{padding: 0 5%; text-align: center;}
	#fv .fv_title .fv_top h2{text-align: center;}
	#fv .fv_title .fv_top h2 .fv_logo_2{ display: inline-block; width: 64.5%; height: auto; margin: 16px 0 0 10%;}
	#fv .fv_title .fv_top h2 .fv_logo_3{ display: inline-block; width: 86.95%; height: auto; margin: 14px 0 0;}
	#fv .fv_title .fv_top p{padding: 0 0 0 24px; line-height: 160%; font-size: 20px; margin: 0 0 0;display: inline-block;}
	#fv .fv_title .fv_top p:before{ width: 16px; height: 24px; }
	#fv .fv_title .fv_bottom{padding: 20px 5% 0;}
	#fv .fv_title .fv_bottom .data_box{width: 100%;max-width: 601px;}
	#fv .fv_title .fv_bottom .data_box p{font-size: 19px; text-align: center; }
	#fv .fv_title .fv_bottom .data_box img{margin: 10px 0 0; width: 100%; height: auto;}
	#fv .fv_title .fv_bottom .text_box{max-width: 100%; width: 100%; padding: 21px 10px 17px 18px; gap: 0; margin: 20px 0 0; border-radius: 10px;}
	#fv .fv_title .fv_bottom .text_box img{ display: block; width: 45px; height: auto;}
	#fv .fv_title .fv_bottom .text_box p{font-size: 13px; line-height: 160%; width: calc(100% - 65px); margin: 0 0 0 auto; }
	#fv .fv_slider{padding: 20px 0 0; }
	#fv .fv_slider .img{margin: 0 15px 0 0;border-radius: 10px;}

	.title { background: url(../images/area/logo_bg.svg) no-repeat center center; background-size: 339px;}
	.bread { margin: 0; background: none;}

	/* ----------------------------------------------------------------------- area */
	#area{padding: 30px 0 0;}
	#area .flex{display: block; padding: 25px 0 60px;}
	#area .flex .text_box{width: 100%; height: auto; padding: 30px 0 0; text-align: center;}
	#area .flex .text_box h4{font-size: 26px; text-align: center;}
	#area .flex .text_box p{line-height: 180%; padding: 10px 0 20px; font-size: 14px; text-align: left;}
	#area .flex .text_box p span{display: inline-block; padding-left: 1rem;line-height: 180%;}
	#area .flex .text_box .btn{padding: 9px 0 9px 62px; font-size: 16px; margin: 20px 0 0;}
	#area .flex .text_box .btn span{width: 50px; height: 50px; }
	#area .flex .text_box .btn span:before{width: 10px; height: 8px;}
	#area .flex .img{margin: 0 auto; width: 80%; height: auto;}
	#area .flex .img img{width: 100%; height: auto;}


	/* ----------------------------------------------------------------------- service */
	#service{padding: 39px 0 32px;}
	#service .flex{padding: 14px 0 0; display: block; }
	#service .flex .box{width: 100%; border-radius: 10px; padding: 22px 5% 110px; }
	#service .flex .box:not(:last-child){margin: 0 0 2.5%;}
	#service .flex .box h4{font-size: 11px; padding: 0 0 10px;}
	#service .flex .box h4 span {font-size: 25px; padding: 0 0 6px;}

	#service .flex .box h4:before{width: 33px; height: 1px;}
	
	#service .flex .box .text_1{font-size: 16px; padding: 13px 0 0;}
	#service .flex .box .service_img{padding:20px 0 0; }
	#service .flex .box .text_2{padding: 20px 0 0; font-size: 14px;}
	#service .flex .box ul{padding: 15px 0 0;}
	#service .flex .box ul li{ line-height: 150%; }
	#service .flex .box ul li:not(:last-child){margin: 0 0 11px;}
	#service .flex .box ul li:before{width: 11px; height: 8px; left: 13px;}
	#service .flex .box .text_3{ font-size: 14px; line-height: 175%; padding: 18px 0 0;}
	#service .flex .box .btn{padding: 9px 0 9px 62px; font-size: 16px; bottom: 35px;}
	#service .flex .box .btn span{width: 50px; height: 50px; }
	#service .flex .box .btn span:before{width: 10px; height: 8px;}
	
	/* ----------------------------------------------------------------------- reasons */
	#reasons{padding: 75px 0 35px;}
	#reasons .reasons_bg{border-radius: 10px; padding: 2.5%;}
	#reasons .reasons_bg .white_box{border-radius: 10px; padding: 34px 2.5% 30px;}
	#reasons .reasons_bg .white_box .title{top: -45px; }
	#reasons .reasons_bg .white_box p.big_tt{font-size: 23px;}

	#reasons .reasons_bg .white_box .flex{display: block; padding: 25px 0% 0px; }
	#reasons .reasons_bg .white_box .flex .box{width: auto; text-align: center; display: flex; align-items: center;justify-content: center;}
	#reasons .reasons_bg .white_box .flex .box:nth-child(2n){width: auto; }
	#reasons .reasons_bg .white_box .flex .box:not(:last-child){margin: 0px 0 20px}
	#reasons .reasons_bg .white_box .flex .box img.main_img{vertical-align: top; display: block; width: calc(95% - 168px); height: auto;}
	#reasons .reasons_bg .white_box .flex .box .text_box{display: block; padding:0 0 0 10px; width: 164px; }
	#reasons .reasons_bg .white_box .flex .box .text_box img{width: 60px; height: auto;}
	#reasons .reasons_bg .white_box .flex .box .text_box p {font-size: 16px; padding: 5px 0 2px; display: inline-block;}
	
	#reasons .btn{ padding-top: 30px; }
	#reasons .btn--border{ width: 100%; }
	
/* ----------------------------------------------------------------------- price */
	#price { padding: 71px 0 42px; }
	#price .title {top: -41px;}
	#price .inner {width: 95%;}
	
	.price-box { border-radius: 10px; padding: 46px 7.5% 30px; margin: 0 auto; }
	.price-row.sp{display: flex;}
	.price-title { padding: 0 0 18px; font-size: 20px; }
	.price-lead { margin: 0 0 25px; font-size: 15px; line-height: 1.5; }
	.price-flex { width: 100%; gap: 0; flex-direction: column; padding: 32px 0 0;}
	
	.price-left { width: 100%; padding: 0; }
	.price-tag { height: 40px; width: 120px; font-size: 14px; }
	.price-amount__num { font-size: 25px; margin-right: 8px; }
	.price-amount__yen { font-size: 15px; }
	.price-summary { gap: 11px; }
	
	.price-right { width: 100%; padding: 34px 0 0;}
	.price-menu span { width: calc(100% / 3 - 3px); height: 40px; font-size: 16px; }
	.price-menu { padding: 0; gap: 4px; }
	.price-notes { margin: 23px 0 0; }
	.price-notes__item { width: 100%; font-size: 12px; line-height: 1.5; }
	
	.btns{ flex-direction: column; padding: 33px 0 0; width: 90%; margin: 0 auto;}
	.btns .btn{ width: 100%; }
	.btns .btn__link{ justify-content: flex-start; }
	
	.visit_tt{ border-bottom: 4.35px solid #FFE200; width: 100%; padding: 0 0 12px;}
	.visit_tt .price-tag{height: 35px; width: 113px; padding: 5px; font-size: 12px; margin-right: 14px;}
	.visit_tt .price-amount__num { font-size: 45px;}
	.visit_tt .price-amount__yen {font-size: 25px; margin: 0;}


	
	/* ----------------------------------------------------------------------- blog */
	#blog{ padding: 62px 0 71px; }
	#blog .title{ margin: 0 0 25px; }
	#blog .desc{ padding: 0 0 27px; }
	
	.blog-wrapper{ padding: 0 5%; }
	.blog-text{ width: 100%; }
	.blog-list { display: block;  }
	
	.blog-card { width: 100%; box-shadow: 0 0 26px rgba(0,0,0,0.16); }
	.blog-card:not(:last-child){margin: 0 0 16px;}
	.blog-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.12); }
	.blog-card__link { display: block; color: inherit; text-decoration: none; }
	.blog-card__photo { overflow: hidden; }
	.blog-card__photo img { width: 100%; height: auto; display: block; object-fit: cover; }
	
	.blog-card__body { padding: 14px 18px 23px; }
	.blog-card__cat { font-size: 13px; margin-bottom: 10px; }
	.blog-card__title { font-size: 22px; line-height: 141%; margin-bottom: 11px;}
	.blog-card__desc { font-size: 14px; line-height: 2; margin-bottom: 15px; }
	.blog-card__meta { display: flex; align-items: center; justify-content: space-between; font-size: 14px; }
	.blog-card__author { display: flex; align-items: center; gap: 6px; }
	.blog-card__icon { display: block; width: 10px; height: auto; }
	
	#blog .btn{padding: 30px 0 0;}
	#blog .btn .btn__link{margin: 0 auto; width: 95%; }
	#blog .btn .btn__link .btn-linktxt{width: calc(100% - 137px); display: block; margin: 0 50px 0 0;}

	/* ----------------------------------------------------------------------- faq */
	#faq{ padding: 27px 0;}
	#faq .inner{width: 95%;}
	#faq ul{padding: 29px 0 0;}
	#faq ul li{border-radius: 10px;}
	#faq ul li.clos{padding: 21px 16px 25px;}
	#faq ul li:not(:last-child){margin: 0 0 11px;}
	#faq ul li .tt{display: flex; gap: 6px; }
	#faq ul li .tt .icn{font-size: 21px; width: 21px; margin: 3px 0 0;}
	#faq ul li p.tt .icn {margin: 3px 3px 0 5px;}
	#faq ul li h4.tt{ font-size: 16px; line-height: 150%; padding: 0 31px 0 0; }
	#faq ul li h4.tt .clos_box{width: 18px; height: 18px;}
	#faq ul li p.tt{font-size: 14px; line-height: 172%; padding: 17px 31px 0 0; }
	
	/* ----------------------------------------------------------------------- access */
	#access{padding: 35px 0 42px;}
	#access .flex{padding: 23px 0 0; display: block;}
	#access .flex .map_box{width: 100%; padding: 65% 0 0px;}
	#access .flex .text_box{width: 100%;}
	#access .flex .text_box h4{font-size: 20px; padding: 39px 0 0;}
	#access .flex .text_box ul {margin: 15px 0 0;}
	#access .flex .text_box ul li{display: flex; }
	#access .flex .text_box ul li p{font-size: 14px;}
	#access .flex .text_box ul li p.tt_1{padding: 19px 10px 20px; width: 90px;}
	#access .flex .text_box ul li p.tt_2{padding: 19px 0 20px; width: calc(100% - 90px);}
	#access .flex .text_box ul li:not(:last-child){padding-bottom: 2px;}

}