@charset "utf-8";
/* @import url('https://fonts.googleapis.com/css2?family=Architects+Daughter&family=Luckiest+Guy&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Outfit:wght@100..900&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap'); */
/*--------------------------------------------------------*/

/*リセット*/
html{margin:0px;padding:0px;border:0px;}
*{margin:0px;padding:0px;border:0px;}
body{line-height:1;background-color: ;}
body,h1,h2,h3,h4,h5,h6,p,span,table,a,img,dl,dt,dd,ul,li,ol,iframe,nav{
	margin:0px;
	padding:0px;	
	word-break: break-word;
	vertical-align: baseline;
	text-decoration: none;
	list-style: none;
}
* {
	border: 0;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
ol, ul{list-style:none; list-style-type:none;}
.cleartext{
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}
.clearfix:after {
	visibility: hidden;
	display: block;
	content: " ";
	clear: both;
	height: 0;
}
img {
	vertical-align: bottom;
	width: 100%;
}
svg,
img {
  transform: translateZ(0);
}
.mx_menu_all{margin-bottom:0px !important;min-width: initial !important;min-width: auto !important;}
.pc_ad_head{text-align:center;}
.banner_bg{margin-bottom:0px !important;}
/*--------------------------------------------------------*/
:root {
	--base-color-blue: #229eb2;
	--base-color-yellow: #8C6F35;
	--base-color-white: #FFFFFF;
	--accents-color-yellow: #FFDF3D;
	--tx_base-color-black: #4f4f51;
	--btn-color: #229eb2;
	--bg_main_color:#D1EFF2;
	--bg_main_wt_color:#fdfff3;
	/* --font_main_sans-serif:"Zen Kaku Gothic New", sans-serif; */
	--font_main_sans-serif:"Noto Sans JP", sans-serif;
	--font_main_serif:"Noto Serif JP", serif;
	--font_ttl_suruga:"ab-suruga-u", sans-serif;
	--font-weight-regular:400;
	--font-weight-midium:500;
	--font-weight-bold:700;
	--font-weight-black:900;
	--font-size-16px:clamp(0.938rem, 0.917rem + 0.09vw, 1rem);/* 15px-16px */
	--font-size-20px:clamp(0.938rem, 0.833rem + 0.45vw, 1.25rem);/* 15px-20px */
	--font-size-24px:clamp(0.938rem, 0.75rem + 0.81vw, 1.5rem);/* 15px-24px */
	--font-size-30px:clamp(1rem, 0.708rem + 1.26vw, 1.875rem);/* 16px-30px */
	--font-size-main-ttl-en:clamp(2rem, 1.208rem + 3.42vw, 4.375rem);/* 32px-70px */
	--font-size-main-ttl-jp:clamp(0.8rem, 0.542rem + 0.9vw, 1.375rem);/* 12px-22px */
}
/*--------------------------------------------------------*/
.span{
	display: inline-block;
}
small {
	line-height: 1.2em;
	font-size: min(2vw, 18px);
	display: block;
	margin-top: 3em;
	text-align: center;
}
body{
	background-image: url(../img/1.png);
	background-repeat: repeat;
	/* background-color: var(--bg_main_color); */
	text-align:center;
	font-family: var(--font_main_sans-serif);
	font-weight: var(--font-weight-midium);
	color: var(--tx_base-color-black);
	line-height: min(6vw, 1.5em);
}

a:link{text-decoration:none;}
/* a:visited{color:#039bdd; text-decoration:none;}
a:hover{color:#000; text-decoration:none;transition-duration: 0.2s;} */
#page_all {
	text-align: left;
	word-wrap: break-word;
	/* line-height: 160%; */
	/* border-bottom: solid 12vw #ffffff; */
}
/* -----カーソル画像表示----- */
* {
  cursor: none !important;
}
body {
  cursor: none;
}
#cursor{
  position: fixed;
  z-index: 99999;
  pointer-events: none;
}
#cursor img {
  width: 25px;
  height: auto;
}
html, body, a, button, input, textarea, select, *:active {
  cursor: none !important;
}
a, a:hover, a:active, a:focus {
  cursor: none !important;
}
@media (hover: hover) and (pointer: fine) {
  html, body, a, button {
    cursor: none !important;
  }
}
@media (max-width: 768px) {
  #cursor {
    display: none !important;
  }
}


/*--------------------------------------------------------*/
/*--パンくず--*/
#pan_box {
	background-color: #000000;
	overflow-x: auto;
	overflow-y: hidden;
}

.panlist{
	padding: 8px;
	font-size: 80%;
	line-height: 120%;
	color: #fff;
	text-align:left;
	width: max-content;
}

#pan_box a {
	color: #fff;
}
.panlist a:link{color:#fff; text-decoration:underline;}
.panlist a:visited{color:#fff; text-decoration:underline;}
.panlist a:hover{color:#fff; text-decoration:underline;}
/*--------------------------------------------------------*/
/*--SNS--*/
#sns_button,
#sns_button_pc,
#sns_button_sp{
	text-align: center!important;
	padding: 0 0 5% 0;
    display: flex;
    gap: 1%;
    justify-content: center;
}
#sns_button img{
	width: 40px !important;
	height: 40px !important;
	margin: 0.5%;
}
#sns_button_pc img{
	height: 50px!important;
    width: 50px!important;
    margin: 0 5px!important;
}

#sns_button_sp img{
	height: 50px!important;
    width: 50px!important;
    margin: 0 5px!important;
}
#sns_button
/*--------------------------------------------------------*/
/*--フッター--*/
#footer{margin:0 auto;padding:1px 0 10px; padding:1%; line-height:200%;text-align:center;}
.mx_copyright{ color:#09397a; line-height:1.5; }
.mx_copyright a:link,
.mx_copyright a:visited{ color:#09397a; text-decoration:none; }
.mx_copyright a:hover{ color:#ffffff; text-decoration:underline; }
/*-----------------------------------*/
/*-- 緊急テキスト ----------------------*/
#rp_textbox .txt_text{
border: rgb(255 255 255 / 50%) solid 0.25em;
border-radius: 0.5em;
background: rgba(255,255,255,0.6);
margin: 20px auto;
padding: 8px;
line-height: 1.6em;
text-align: left;
max-width: 960px;
width: 90%;
}
#rp_textbox .pop_text{
-webkit-border-radius: 2px;-moz-border-radius: 2px;border-radius: 2px;
border: #c9c9c9 solid 1px;
font-size:0.9em;
line-height:1.5em;
margin:0 auto;
padding:20px;
text-align:left;
max-width: 900px;
word-break: break-all;
width:75%;
}
#rp_textbox .pop_text .popup_title{
border-bottom: #999 dotted 1px;
font-size:1.1em;
line-height:1.5em;
font-weight:bold;
margin:0 0 15px 0;
padding-bottom:5px;
text-align:center;
width:100%;
}
#rp_textbox .eme_img {
display: block;
text-align: center;
width: 100%;
}
#rp_textbox .eme_img img{
margin: 0 auto 10px;
max-width: 100%;
}
#rp_textbox a{
color:#d00;
text-decoration:underline;
}
.txt_title {
border-left: solid 0.5em #333333;
font-weight: bold;
font-size: 1.2em;
text-align: left;
padding: 0.3em;
margin-bottom: 0.5em;
}
/*-----------------------------------*/
/*google翻訳*/
.skiptranslate.goog-te-gadget,
a.goog-logo-link,.goog-logo-link:link{color:#09397a;text-align:center;}
/*-----------------
共通
------------------*/
/* loader */

#loader {
  background: #ffffff;
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 100;
  transition: opacity .5s ease;
}

#loader.is-hide {
  opacity: 0;
  pointer-events: none;
}

/*背景*/
.loader,
.loader:before,
.loader:after {
    background: #b4e5e9;
    -webkit-animation: load1 1s infinite ease-in-out;
    animation: load1 1s infinite ease-in-out;
    height: 4em;
    width: 1em;
    top: 50%;
}

.loader {
    color: #87d9df;
    text-indent: -9999em;
    margin: auto;
    position: relative;
    font-size: 11px;
    -webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-animation-delay: -0.16s;
    animation-delay: -0.16s;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.loader:before,
.loader:after {
    position: absolute;
    top: 0;
    content: '';
}

.loader:before {
    left: -1.5em;
    -webkit-animation-delay: -0.32s;
    animation-delay: -0.32s;
}

.loader:after {
    left: 1.5em;
}

@-webkit-keyframes load1 {

    0%,
    80%,
    100% {
        box-shadow: 0 0;
        height: 4em;
    }

    40% {
        box-shadow: 0 -2em;
        height: 5em;
    }
}

@keyframes load1 {

    0%,
    80%,
    100% {
        box-shadow: 0 0;
        height: 4em;
    }

    40% {
        box-shadow: 0 -2em;
        height: 5em;
    }
}

/* loader */




.pconly {
	display: block;
}
.sponly {
	display: none;
}
@media screen and (max-width: 1100px){
	.pconly {
		display: none;
	}
	.sponly {
		display: block;
	}
}

.pcOnly {
	display: block;
}
.spOnly {
	display: none;
}
@media screen and (max-width: 700px){
	.pcOnly {
		display: none;
	}
	.spOnly {
		display: block;
	}
}



/* -----------------
.header
---------------- */
.header {
	height: 80px;
	background:var(--base-color-white);
	display: flex;
	position: fixed;
	width: 100%;
	z-index: 999;
	box-shadow: 0px 3px 6px 0px rgb(165 165 165 / 20%);
	top: 0;
}
.header_inner {
	width: 95%;
	display: flex;	
	align-items: center;
	margin: auto;
	justify-content: space-between;
}
.header h1 {
	width: 160px;
}

.gl-nav {
	display: flex;
	align-items: center;
}

.gl-nav ul {
	display: flex;
	gap: 30px;
}

.gl-nav ul li .en-nav {
	font-size: 20px;
	display: block;
	color: var(--base-color-yellow);
	font-family: var(--font_ttl_suruga);	
	white-space: nowrap;
	letter-spacing: .05rem;
}
.gl-nav ul li .ja-nav {
	font-size: 12px;
	color: var(--tx_base-color-black);
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-black);
	letter-spacing: .01rem;
}

.lg-btn a {
	font-size: 12px;
	padding: 1%;
	border: 1px solid var(--base-color-yellow);
	border-radius: 50px;
	white-space: nowrap;
	display: block;
	width: 40px;
	margin-left: 30px;
	height: 30px;
	color: var(--base-color-yellow);
	line-height: 25px;
	font-weight: var(--font-weight-black);
}

.gl-nav ul li.en-nav,
.gl-nav ul li.ja-nav {    
	transition: .3s;
}
.gl-nav ul li:hover .en-nav,
.gl-nav ul li:hover .ja-nav {
    color: var(--btn-color);
	transition: .3s;	
}

.lg-btn a:hover {
	background-color: var(--base-color-blue);
	color: #fff;
	border: 1px solid #fff;

}

@media screen and (max-width: 1100px){
	.header {
		height: 65px;
	}
	.header h1 {
		width: 130px;

	}
	nav.gl-nav.pconly {
		display: none;
	}
}

/* -------ハンバーガー-------- */
/* overlay-styles.css */
.hamburger-overlay {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 1000;
  width: 65px;
  height: 65px;
  border: none;
  background: var(--base-color-yellow);
  cursor: pointer;
}

.hamburger-overlay__line {
	position: absolute;
	left: 13px;
	width: 40px;
	height: 4px;
	border-radius: 50px;
	background-color: var(--base-color-white);
	transition: all .6s;
}

.hamburger-overlay__line:nth-of-type(1) { top: 22px; }
.hamburger-overlay__line:nth-of-type(2) { top: 31px; }
.hamburger-overlay__line:nth-of-type(3) { top: 40px; }

.hamburger-overlay.active .hamburger-overlay__line {
  background-color: #fff;
}

.hamburger-overlay.active .hamburger-overlay__line:nth-of-type(1) {
  transform: translateY(9px) rotate(-45deg);
}
.hamburger-overlay.active .hamburger-overlay__line:nth-of-type(2) {
  opacity: 0;
}
.hamburger-overlay.active .hamburger-overlay__line:nth-of-type(3) {
  transform: translateY(-9px) rotate(45deg);
}

.nav-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.95);
  visibility: hidden;
  opacity: 0;
  transition: all .6s;
  z-index: 900;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.nav-overlay.active {
  visibility: visible;
  opacity: 1;
}

.nav-overlay__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
}

.nav-overlay__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.nav-overlay__item {
  opacity: 0;
  transform: translateY(20px);
  transition: all .6s;
  color: var(--base-color-yellow);
  font-family: var(--font_ttl_suruga);

}

.nav-overlay.active .nav-overlay__item {
  opacity: 1;
  transform: translateY(0);
}

.nav-overlay.active .nav-overlay__item:nth-child(1) { transition-delay: 0.1s; }
.nav-overlay.active .nav-overlay__item:nth-child(2) { transition-delay: 0.2s; }
.nav-overlay.active .nav-overlay__item:nth-child(3) { transition-delay: 0.3s; }
.nav-overlay.active .nav-overlay__item:nth-child(4) { transition-delay: 0.4s; }
.nav-overlay.active .nav-overlay__item:nth-child(5) { transition-delay: 0.5s; }
.nav-overlay.active .nav-overlay__item:nth-child(6) { transition-delay: 0.6s; }
.nav-overlay.active .nav-overlay__item:nth-child(7) { transition-delay: 0.7s; }
.nav-overlay.active .nav-overlay__item:nth-child(8) { transition-delay: 0.8s; }
.nav-overlay.active .nav-overlay__item:nth-child(9) { transition-delay: 0.9s; }

.nav-overlay__link {
  display: inline-block;
  padding: 7px;
  color: #fff;
  font-size: 20px;
  text-decoration: none;
  transition: color .3s;
}

.nav-overlay .ja-nav {
	display: block;
	font-size: 10px;
    color: var(--base-color-white);
    font-family: var(--font_main_serif);
    font-weight: var(--font-weight-black);
    letter-spacing: .05rem;
}

a.nav-overlay__link.lg-btn {
	border: 1px solid #fff;
	border-radius: 50px;
	margin-top: 30px;
	font-family: var(--font_main_sans-serif);
	font-size: 18px;	
}

.nav-overlay__item a:hover,
.nav-overlay__item a:hover span:hover {
  color: #c9962f;
}

a.nav-overlay__link.lg-btn:hover {
	border: 1px solid #c9962f;	
	color: #c9962f;
}

@media screen and (max-width: 1100px){
	.nav-overlay__content {
	position: relative;
	top: auto;
	left: auto;
	transform: none; 
	padding: 100px 0 100px;
}

}

/* -----------------
.kv_wrap
---------------- */

.bgImage2__rayer {
	background-image: url(../img/1.png);
	background-repeat: repeat;
	position: relative;
	z-index: 2;
}
.kv_wrap {
	position: relative;
	width: 100%;
	/* aspect-ratio: 5 / 2.9; */
	overflow: hidden;
	padding-top: 70px;
	z-index: 3;
}
.kv_wrap img {
	max-width: 1450px;
	height: auto;
}

.kv_bg_r {
	position: absolute;
	top: 7%;
    right: 10px;
	width: 30%;
	filter: opacity(0.7);
}

.kv_bg_l {
	position: absolute;
	top: 50%;
    left: -99px;
	width: 20%;
	filter: opacity(0.7);
}

.kv_bgpp {
	position: absolute;
    top: -75%;
    left: -9%;
    width: 112%;
	object-fit: cover;
}

.kv_ill {
	/* position: absolute; */
	top: 80px;
	right: 0;
	left: 0;
	margin: auto;
	padding: 2% 3% 1%;
}
@media screen and (max-width: 900px){
	.kv_wrap {
		aspect-ratio: 5 / 3.1;
	}
}
/* -----KVSP----- */
@media screen and (max-width: 700px){
    .kv_wrap {
        aspect-ratio: 3 / 4.2;
    }
	.kv_bgpp {
		top: 0;
	}
	.kv_bgpp_sp {
        position: absolute;
        width: 130%;
        top: -3%;
        left: -17%;
    }
	.kv_bg_r {
    display: none;
	}
	.kv_bg_l {
	display: none;
	}
}
@media screen and (max-width: 600px){
    .kv_wrap {
        aspect-ratio: 3 / 4.3;
    }
}
@media screen and (max-width: 500px){
    .kv_wrap {
        aspect-ratio: 3 / 4.4;
    }
}
@media screen and (max-width: 400px){
    .kv_wrap {
        aspect-ratio: 3 / 4.5;
    }
}
@media screen and (max-width: 370px){
    .kv_wrap {
        aspect-ratio: 3 / 4.6;
    }
}

/* -----------------
.intro
---------------- */
.inner {
	max-width: 1200px;
	text-align: center;
	margin: auto;
	padding: 2%;
}

.intro {	
	padding: min(13vw, 6.5em) 0;
	background: url(../img/bg.webp);
	background-size: cover;
	z-index: 2;
    position: relative;
}



h2 {
	display: grid;
	font-family: var(--font_ttl_suruga);
	font-size: var(--font-size-main-ttl-en);
	color: var(--base-color-white);
	letter-spacing: clamp(0.3rem, 0.233rem + 0.29vw, 0.5rem);
	margin-bottom: clamp(1.875rem, 1.25rem + 2.7vw, 5rem);
}
h2 span {
	font-family: var(--font_main_serif);
	font-size: var(--font-size-main-ttl-jp);
	font-weight: var(--font-weight-black);
	background-color: var(--base-color-white);
	color: var(--base-color-blue);
	padding: .5px 3px 1.4px 3px;
	letter-spacing: .05rem;
	width: max-content;
    margin: auto;
	margin-top: min(3vw, 1.5em);
}

.h2_v2 {
	color: var(--base-color-yellow);
	max-width: 1200px;
	/* display: flex;  */
	align-items: center;
	gap: 0.1em;
	margin-bottom: clamp(1rem, 0.667rem + 1.44vw, 2rem);
	text-shadow:
    1px 2px 0 #FDFFF3,
   -1px 2px 0 #FDFFF3,
    1px -2px 0 #FDFFF3,
   -1px -2px 0 #FDFFF3;
}
.h2_span_v2 {
	background-color: var(--base-color-yellow);
	color: var(--bg_main_wt_color);
	padding: 1px 5px 3px 5px;
	margin-bottom: 1.1%;
	/* margin-left: 0; */
	text-shadow: none;
}

.sub_main .h2_v2 {
	text-shadow:none;
}


@media screen and (max-width: 600px){
	h2 span {
	padding: .5px 5px 1px 5px;
	}
	.h2_v2 {
	color: var(--base-color-yellow);
	display: grid;
	margin: auto;
	margin-bottom: clamp(1rem, 0.667rem + 1.44vw, 2rem);
	}
	.h2_span_v2 {
	margin: min(2vw, 1em) auto;
	}
}
@media screen and (max-width: 400px){
	h2 span {
	padding: .5px 4px 0px 5px;
	}
	.h2_span_v2 {
	margin: min(2vw, 1em) auto;
	padding: .5px 4px 0px 5px;
	}
}

.intro_tx_a {
	color: var(--base-color-white);
	font-weight: var(--font-weight-bold);
	font-size: var(--font-size-30px);
	line-height: clamp(1.7rem, 1.267rem + 1.87vw, 3rem);
	margin-bottom: clamp(1.875rem, 1.25rem + 2.7vw, 3.75rem);
}
.intro_tx_a .accent_a {
	font-family: var(--font_main_serif);
	color: var(--accents-color-yellow);
	font-size: clamp(1.5rem, 0.958rem + 2.34vw, 3.125rem);
}

.intro_tx_b {
	font-size: var(--font-size-20px);
	color: var(--base-color-white);
	line-height: clamp(1.4rem, 1.033rem + 1.59vw, 2.5rem);
	    margin-bottom: clamp(1.875rem, 1.25rem + 2.7vw, 3.75rem);
}

.intro_tx_b .accent_b {
	font-size: clamp(0.75rem, 0.417rem + 1.44vw, 1.75rem);
	font-family: var(--font_main_serif);
	color: var(--accents-color-yellow);
	font-weight: var(--font-weight-black);
}

@media screen and (max-width: 600px){
	.intro_tx_b { 
		text-align: left;
	}
	.intro_tx_b .accent_b {
		font-size: clamp(0.938rem, 0.833rem + 0.45vw, 1.25rem);
	}
	.inner {
		padding: 4%;
	}
}
.comment h3 {
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-black);
	font-size: var(--font-size-24px);
	color: var(--base-color-white);
	display: inline-block;
	border-radius: 50px;
	padding: 0 min(4vw, .5em);
	display: flex;
	align-items: center;
	display: inline-flex;
	margin-bottom: min(2vw, 3em);
	background-color: var(--base-color-yellow);	
	display: inline-flex;
	align-items: center;
	gap: clamp(4px, 1vw, 12px);
	margin-bottom: min(2.5vw, 2em);
}

@media screen and (max-width: 600px){
	.comment h3 {		
		padding: 0 min(4vw, .8em);
		margin-bottom: min(4.5vw, 2em);
	}
}

.comment h3::before,
.comment h3::after {
    content: "";
    display: inline-block;
    width: clamp(12px, 3vw, 22px); 
    height: clamp(12px, 3vw, 22px);
    background-image: url(../img/deco.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.comment {
	background-color: var(--bg_main_wt_color);	
	color: var(--tx_base-color-black);
	line-height: 2.5rem;
	border-radius: 34px;
	max-width: 900px;
    margin: auto;
}
.comment p {
	line-height: clamp(1.3rem, 1.033rem + 1.15vw, 2.1rem);
	font-size: var(--font-size-20px);
}
.thick {
    position: relative;
    /* border: 4px solid var(--base-color-yellow); */
    padding: min(2vw, 9rem) 3% min(6vw, 3rem);
    color: var(--tx_base-color-black);
	font-family: var(--font_main_serif);
    font-weight: 600;
    text-align: center;
	border-radius: 34px;
}

.over {
    overflow: hidden;
}
.thin {
    position: absolute;
    top: 3px;
    right: 3px;
    bottom: 3px;
    left: 3px;
    /* border: 6px solid #ca4; */
    z-index: 1;
	border-radius: 30px;
	/* border: min(1vw, 0.4em) solid var(--base-color-blue); */
}

/*introふわっ*/
.fadein {
  opacity: 0;  
  transition: all 1s ease-out; /
}

.fadein.show {
  opacity: 1;
  transform: translateY(0);
}
/* news,sns下からふわっ */
.fadein-up {
  opacity: .8;
  transform: translateY(30px); 
  transition: all 1s ease-out;
}

.fadein-up.show {
  opacity: 1;
  transform: translateY(0);
}

.sns.fadein-up.show {
  transition-delay: 0.2s;
}

@media screen and (max-width: 600px){
	.thick {
		border-radius: 4vw;
		padding: min(5vw, 8rem) 4% min(5vw, 3rem);
	}
	.comment {
		border-radius: 4vw;
	}
	.thin {
		border-radius: 3vw;
		/* border: min(1vw, 0.4em) solid var(--base-color-blue); */
	}
	.comment p {
	text-align: left;
}
}

/* -----------------
.news
---------------- */
.news {
	padding-top: min(13vw, 6.5em);
}
.news_box {
	max-width: 650px;
	background-color: #ffffffed;
	border-radius: min(6vw, 2em);
	padding: min(1.2vw, 5rem) min(2.8vw, 6rem) min(2vw, 5rem);
	border: min(1vw, .3em) solid var(--base-color-blue);
	margin: auto;
	box-shadow: rgb(60 113 99 / 25%) 0px 2px 5px -1px, rgb(60 113 99 / 25%) 0px 1px 3px -1px;
}

.news_unit {
	text-align: center;	
}
.news_date {
	margin-bottom: min(2.8vw, .5em);
	color: var(--base-color-blue);
	font-family: "Outfit", sans-serif;
}

.news_box li {
	padding: min(2vw, 1em) 0;
	background-image: repeating-linear-gradient(90deg, var(--base-color-blue), var(--base-color-blue) 2px, transparent 2px, transparent 5px);
	background-position: left bottom;
	background-repeat: repeat-x;
	background-size: 100% 1px;
	text-align: left;
}
.news_box li a {
	font-size: var(--font-size-16px);
	color: var(--tx_base-color-black);
	/* text-decoration: underline; */
}
.news_box li a:hover {	
	color: var(--base-color-blue);
}

.buttun a {
	display: flex;
    justify-content: center;
    align-items: center;
    max-width: 300px;
    margin: 0 auto;
    padding: min(4vw, 1rem) 1%;
    border: 2px solid #fff;    
    box-shadow: 0 0 0 3px var(--base-color-blue);
    background-color: var(--base-color-blue);
    color: #fff;
    font-weight: 600;
    font-size: 1rem;
	border-radius: 50px;
	margin-top: clamp(1.25rem, 0.729rem + 2.25vw, 2.813rem);
	transition: background-color .25s ease;
}

.buttun a:hover {
    background-color: #33b1c4;
	box-shadow: 0 0 0 3px #33b1c4;
}

@media screen and (max-width: 600px){
	.news_box {
		padding: min(6vw, 9rem) 6%;
		/* border-radius: 4vw; */
	}
	.news_box li:last-child {
		margin-bottom: 11%;
	}
	
}

@media screen and (max-width: 700px){
	main .h2_v2 {
		display: grid;
	}
	.h2_span_v2 {
		margin: auto;
		margin-top: min(3vw, 1.5em);
	}
	.news_box {
		margin: auto;
	}
	.x_bnr {
		margin: auto;
	}
}
@media screen and (max-width: 600px){
	main .h2_v2 {
		display: grid;
	}
	.h2_span_v2 {
		margin: auto;
		margin-top: min(3vw, 1.5em);
	}
	.news_box {
		margin: auto;
	}
	.x_bnr {
		margin: auto;
	}
}
@media screen and (max-width: 400px){	
	.news_box {
		margin: auto;
	}
	.x_bnr {
		margin: auto;
	}
}

/* -----------------
.sns
---------------- */
.sns {
	margin-top: min(13vw, 6.5em);
}
.sns_unit {
	/* max-width: 700px; */
	text-align: center;
}
.x_bnr {
	max-width: 400px;
	margin: auto;
	box-shadow: rgb(60 113 99 / 25%) 0px 2px 5px -1px, rgb(60 113 99 / 25%) 0px 1px 3px -1px;
	
}

.x_bnr a {
	pointer-events: auto!important;
}
	

/* -----------------
.footer
---------------- */
.footer {
	background-image: url(../img/bg.webp);
	background-size: cover;
	padding: min(8vw, 5em) 4%;
	z-index: 1;
	position: relative;
}

.other_bnr {
	display: flex;
	gap: 30px;
	justify-content: center;
	margin-bottom: 5%;
}
.other_bnr div {
	max-width: 300px;
}

.sns_icon img {
	width: 100%;
	height: auto;
}
.sns_icon {
	display: flex;
	gap: 20px;
	max-height: 40px;
	justify-content: center;
}

.speechBubble {
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  padding: .23% 1.5% .4% 1.5%;
  border-radius: 9999px;
  background-color: #ffffff;
  text-align: left;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--base-color-blue);
  font-weight: var(--font-weight-bold);
}

.speechBubble::after {
  content: "";
  position: absolute;
  bottom: 9px;
  left: 50%;
  border-style: solid;
  border-width: 20px 10px 0 10px;
  border-color: #ffffff transparent transparent;
  translate: -50% 100%;
}
small {
	font-size:clamp(0.563rem, 0.5rem + 0.27vw, 0.75rem);
	color: var(--base-color-white);
}


@media screen and (max-width: 600px){
	.other_bnr {
		display: block;
		margin: auto;
		margin-bottom: 10%
	}
	.other_bnr div {
		margin: auto;
		margin-bottom: 4%;
	}
	.speechBubble {
		padding: .23% 3% .4% 3%;
		font-size: 14px;
	}
	.speechBubble::after {
		bottom: 5px;
		border-width: 15px 8px 0 8px;
	}
}



/* -----------------
原画調整
------------------- */
.bg {
	position: relative;
	z-index: 1;
	background-image: url(../img/p_shougou.webp),url(../img/kv_bg_r2.svg),url(../img/bg_deco_b.svg),url(../img/bg_deco_b.svg);
	background-size: 98%, 35%, 36%, 24%;
	overflow: hidden;
	padding-bottom: min(19vw, 9em);
	background-repeat: no-repeat;
	background-position: 15% 53%, 105% 0%, -10% 126%, 103% 132%;
	background-attachment: fixed;
}

@media screen and (max-width:700px){
	.bg {
		background-attachment: unset;
		background-image: none;
	}
	.bg::before  {	
	background-image: url(../img/p_shougou_sp.webp);
	background-size: 151%;
	overflow: hidden;
	padding-bottom: min(19vw, 9em);
	background-repeat: no-repeat;
	content:"";
	display:block;
	position:fixed;
	top:0;
	left:0;
	z-index:-1;
	width:100%;
	height:100vh;
	background-repeat:no-repeat;
	background-position:50% 70%;
	/* background-size:cover; */
}
}
/* -------- */
.italic {
	font-style: italic;
}