@charset "UTF-8";
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝　初期設定　＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

*{
	margin: 0px;
	padding: 0px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;

font-family:  "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;}

h1 { font-size: 40px; }
h2 { font-size: 24px; }
h3 { font-size: 22px; }
h4 { font-size: 20px; }
h5 { font-size: 18px; }
h6 { font-size: 16px; }
@media(max-width:767px) {
h1 { font-size: 2rem; }
h2 { font-size: 1.2rem; }
h3 { font-size: 1.8rem; }
h4 { font-size: 1.7rem; }
h5 { font-size: 1.4rem; }
h6 { font-size: 1.2rem; }
p { font-size: 1.1rem; }
}
@media(max-width:576px) {
h1 { font-size: 1.8rem; }
h5 { font-size: 1rem; }
h6 { font-size: 1.4rem; }
p { font-size: 0.9rem;}
}

body {
color:#3e3e4a;
}
footer {
background:#2a090b;
color:#FFF;
text-align:center;
font-size: 0.9rem;
}
.wrapper {
overflow:hidden;
}

.formInput05 { width: 5em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput10 { width: 10em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput15 { width: 15em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput20 { width: 20em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput25 { width: 25em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput30 { width: 30em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput40 { width: 40em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}


/* link style
---------------------------- */
a:link {
	/*color:#7cba7e;*/
	text-decoration: none;
}
a:hover {
	color:#ff0000;
	/*text-decoration:underline;*/
}
a:visited {
	color: #000;
	text-decoration: none;
}

/* other
--------------------------- */
@media screen and (min-width: 579px) {
	.br-sp { display:none; }
}

@media screen and (max-width: 579px) {
	.br-sp2 { display:none; }
}

a:focus, *:focus {
	outline:none;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　common　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.maincontainer {
	max-width:1200px !important;
  margin: 0 auto;
  padding-left: 7px;
  padding-right: 7px;
}
.maincontainer2 {
	max-width:1000px !important;
	margin-left:auto;
	margin-right:auto;
}
.maincontainer-wide {
	max-width:1400px !important;
	margin-left:auto;
	margin-right:auto;
}
.rl15-container {
  max-width: 900px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl80-container {
  max-width: 800px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl60-container {
  max-width: 600px;
  position: relative;
  margin: 0 auto;
  padding-left: 45px;
  padding-right: 45px;
}

.maincontainer_wide {
max-width:1200px !important;
  margin: 0 auto;
  padding-left: 5px;
  padding-right: 5px;
}


p.lead {
text-align:center;
font-size:1em;
line-height:1.9em;
}
@media screen and (max-width: 579px) {
p.lead {
text-align:left;
font-size:0.9em;
padding:0 1em;
}
}
p.lead2 {
margin:1.2em 1em;
font-size:1em;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　footer navi　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.copyright {
color:#FFF;
font-size:0.7em;
}

.sns_icon ul {
text-align:center;
font-size:0;
}

.sns_icon li {
display: inline-block;
vertical-align: middle;

}
.sns_icon li a {
color:#FFF;
}
/*-------------------------------------------------- */
p.linksaki {
	margin-top:10px;
}
p.linksaki a {
padding:9px;
border:solid 1px #7cba7e;
border-radius:20px;
color:#7cba7e;
font-size:14px;

text-decoration:none;
}
.linksaki a:hover {
background:#7cba7e;
color:#FFF;
}
.bg-gray {
background:#f5f4ea;
padding:3% 0;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　ナビゲーション　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#head_wrap {
position:fixed;
width:100%;
z-index:9999;
   top: 0;
    padding: 0;
background:rgba(255,255,255, 0.3);
}

.header-in {
 display: -webkit-box;
 display: -webkit-flex;
 display: -ms-flexbox;
 display: flex;
 align-items: center;
/*justify-content:space-between;*/
justify-content:flex-end;
height:80px;
}
.header-in >:first-child {
  margin-right: auto;
}

@media (max-width: 992px) {
.header-in {
height:60px;
}
}
/*-------------------------- navi ------------------------------*/
#global-nav {
position:relative;/*垂直に中央揃えにするため★*/
}

#global-nav ul {
  list-style: none;
  font-size: 14px;
 display: flex;
flex-wrap:wrap;
justify-content:end;
align-items:center;
position:aboslute;/*★*/
top:0;/*★*/
bottom:0;/*★*/
margin:auto;/*★*/
}
#global-nav ul li {
height:20px;
}
#global-nav ul li a {
color:#000;
  padding: 0px 15px;
  box-sizing: border-box;
  font-weight: bold;
  transition: all .5s ease 0s;
}
#global-nav ul li a:hover {
color:green;
}

@media (max-width: 992px) {
  #global-nav ul {
    display: block;
  }
#global-nav ul li {
margin:20px 0;
}
}

#head_wrap.fixed {
background:#7cba7e;
box-shadow:0 .4em .8em rgba(0, 0, 0, 0.6);
}
#head_wrap.fixed #global-nav ul li a {
  color: #FFF;
  padding: 0 11px;
}
#head_wrap.fixed #global-nav ul li a:hover {
  color: green; 
}

#head_wrap.fixed .slogo {
margin-left:3%;
    display: block;
filter: brightness(0) invert(1);
}
.slogo {
margin-left:1%;
filter: brightness(0);
width:260px;
font-size:2rem;
font-family:"Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
.slogo a {
text-decoration:none;
}

@media (max-width: 992px) {
#head_wrap.fixed #global-nav ul li a {
  color: #3e3e4a;
}
.slogo {
width:160px;
}
}
/*-------------------------- Toggle Button -----------------------------*/
#nav-toggle {
  display: none;
  position: absolute;
  right: 20px;
  top: 18px;
  width: 34px;
  height: 36px;
  cursor: pointer;
  z-index: 9999;
}

#nav-toggle div {
  position: relative;
}


@media (min-width: 992px) {
/* Toggle Button */
#nav-toggle {
  display: none;
}
}

@media (max-width: 992px) {
  #global-nav {
position:fixed;
right:-992px;
height:100vh;
top:0;
width:100%;
background: rgba(225, 225, 225, 0.8);
text-align:center;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
transition:all 0.5s;
  }

  #global-nav ul {
    list-style: none;
    position: static;
    right: 0;
    bottom: 0;
    font-size: 14px;
padding-top:120px;
  }
  #global-nav ul li {
    float: none;
    position: static;
padding: 15px;
  }
  #head_wrap #global-nav ul li a,
  #head_wrap.fixed #global-nav ul li a {
    width: 100%;
    display: block;
  }
  #head_wrap #global-nav ul li a:hover,
  #head_wrap.fixed #global-nav ul li a:hover {
color:green;
}



  #nav-toggle {
    display: block;
  }
  /* #nav-toggle MENU_CLOSE */
  #nav-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #333;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
  }
  #nav-toggle span:nth-child(1) {
    top: 0;
  }
  #nav-toggle span:nth-child(2) {
    top: 11px;
  }
  #nav-toggle span:nth-child(3) {
    top: 22px;
  }
  .open #nav-toggle span:nth-child(1) {
    top: 11px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
  }
  .open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open #nav-toggle span:nth-child(3) {
    top: 11px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }


  /* #global-nav MENU_OPEN */
  .open #global-nav {
     /*#global-nav top + #mobile-head height */
z-index:999;
    -moz-transform: translateX(-992px);
    -webkit-transform: translateX(-992px);
    transform: translateX(-992px);
  }
}

#head_wrap.fixed #nav-toggle span {
background:#FFF;
}

@media (min-width: 993px) {
.br_online { display:none; }
}
.top_online a {
  display: flex;
  align-items: center;
  width: 130px;
  height: 80px;
  text-align: center;
  padding: 0 20px; 
  background:#2a090b;
  color:#fff;
}
.top_online span {
  flex: 1;
font-size:0.8em;
}
.top_online a:hover {
background:#634b33;
}

@media (max-width: 992px) {
.top_online a {
margin-right:80px;
width:90px;
height:60px;
}
.top_online span {
line-height:1;
}
}




/*-------------------------- Button -----------------------------*/
.button2025 a {
    border:solid 1px #7cba7e;
    border-radius: 9999px;
color:#7cba7e;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: auto;
    max-width: 250px;
    padding: 10px 25px;
    font-family: "Noto Sans Japanese";
    line-height: 1.8;
    transition: 0.3s ease-in-out;
    font-weight: 500;

}
.button2025 a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
color:#7cba7e;
}
.button2025 a:hover {
  background: #7cba7e;
  color: #FFF;
text-decoration:none;
}
.button2025 a:hover:after {
  right: 1.4rem;
color:#FFF;
}

/*------------------------- top_instagram -----------------------------*/

.top_instagram ul{
list-style-type: none;
margin:0 1em 0 0;
padding:0;
}
.top_instagram li {
line-height:1.1;
}
.top_instagram li a{
font-size:1.4rem;
font-weight: 900;
color:#1a1a1a;
}
.top_instagram li a:hover{
  /*押したとき*/
color:green;
}
#head_wrap.fixed .top_instagram li a{
color:#FFF;
}
#head_wrap.fixed .top_instagram li a:hover{
color:green;
}

@media only screen and (max-width: 992px) {
.top_instagram ul{
margin:0 10px 0 0;
}
}

/*=======================================================*/
section.first__section {
padding:50px 0;
}
section.first__section2 {
padding:80px 0 0;
}
section.first__section3 {
margin-top:200px;
}
section + section {
  padding-top: 130px;
}

section.last__section {
  padding-bottom: 20vh;
}
@media (max-width: 768px) {
section + section {
  padding-top: 80px;
}
}
/*------------------------- title -----------------------------*/
.heading05 {
	position: relative;
	padding-bottom: 50px;
	font-size: 26px;
	text-align: center;
}

.heading05::before {
	content: attr(data-en);
	display: block;
	color: #7cba7e;
	font-size: 20px;
	font-style: italic;
	text-transform: uppercase;
}

.heading05::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%) rotate(0deg);
	width: 1px;
	height: 40px;
	background-color: #7cba7e;
}


.heading08 {
	font-size: 26px;
}

.heading08 span {
	display: flex;
	align-items: center;
	color: #7cba7e;
	font-size: 18px;
	text-transform: uppercase;
}

.heading08 span::before {
	content: '';
	display: inline-block;
	margin-right: 20px;
	width: 40px;
	height: 1px;
	background-color: #7cba7e;
}

.red {
color:#FF0000;
}