@charset "utf-8";
/* ===================================================================
  style info : ヘッダーやフッターなどサイト内共通
=================================================================== */

/*----------------------------------------------------
	共通
----------------------------------------------------*/
body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #f3f3f2;
  color: #000000;
  font-size: 1.6rem;
  line-height: 1.6;
  letter-spacing: 0.1em;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
}

/*----------------------------------------------------
  リンク
----------------------------------------------------*/
a:link,
a:visited,
a:hover,
a:active {
  color: #000000;
  text-decoration: none;
  transition: all .5s ease;
}

.link_txt01 {
  color: #ff223d !important;
}

.link_txt01:hover {
  opacity: 0.5;
}

.link_txt02 {
  color: #151515 !important;
}

.link_txt02:hover {
  color: #05a6dd !important;
}

.link_txt03 {
  color: #0073aa !important;
}

.link_txt03:hover {
  color: #05a6dd !important;
}

/* -----------------------------------------------------------
  .txt_deco
----------------------------------------------------------- */
.txt_deco01 {
  text-decoration: underline !important;
}

.txt_deco01:hover {
  text-decoration: none !important;
}

/* -----------------------------------------------------------
  .note
----------------------------------------------------------- */
.note {
  display: flex;
}

.note:before {
  content: "※";
  margin-right: 0.1em;
}

/* -----------------------------------------------------------
  .list
----------------------------------------------------------- */
.list {
  line-height: 1.4;
}

.list > li {
  display: flex;
  margin-top: 0.25em;
}

.list > li:first-of-type {
  margin-top: 0;
}

.list > li:before {
  content: "・";
  margin-right: 0.15em;
  margin-left: -0.05em;
}

/* -----------------------------------------------------------
  .sp_tel
----------------------------------------------------------- */
.sp_tel {
  pointer-events: none;
}

/* -----------------------------------------------------------
  .resp_elt
----------------------------------------------------------- */
.resp_elt01 {
  display: none;
}

/* -----------------------------------------------------------
  .btn
----------------------------------------------------------- */
.btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5em 1em;
  position: relative;
  z-index: 0;
}

.btn01 {
  padding: 0.5em 1.5em;
}

.btn02 {
  display: inline-flex;
}

/* -----------------------------------------------------------
  背景色
----------------------------------------------------------- */
.bg_clr01 {
  background-color: #000000 !important;
}

.bg_clr01:hover {
  background-color: #4d4d4d !important;
}

.bg_clr02 {
  background-color: #123a4b !important;
}

.bg_clr02:hover {
  background-color: #34748f !important;
}

.bg_clr03 {
  background-color: #ffffff !important;
}

.bg_clr03:hover {
  background-color: #000000 !important;
}

.bg_clr04 {
  background-color: #ffffff !important;
}

.bg_clr04:hover {
  background-color: #123a4b !important;
}

.bg_clr05 {
  background-color: transparent !important;
}

.bg_clr05:hover {
  background-color: #ffffff !important;
}

/* -----------------------------------------------------------
  ボーダー色
----------------------------------------------------------- */
.brd_clr01 {
  border: 1px solid #000000 !important;
}

.brd_clr01:hover {
  border: 1px solid #000000 !important;
}

.brd_clr02 {
  border: 1px solid #123a4b !important;
}

.brd_clr02:hover {
  border: 1px solid #123a4b !important;
}

.brd_clr03 {
  border: 1px solid #ffffff !important;
}

.brd_clr03:hover {
  border: 1px solid #ffffff !important;
}

/* -----------------------------------------------------------
  ボーダー角丸
----------------------------------------------------------- */
.brd_rds01 {
  border-radius: 3px;
}

.brd_rds02 {
  border-radius: 5px;
}

.brd_rds03 {
  border-radius: 10px;
}

.brd_rds04 {
  border-radius: 15px;
}

.brd_rds05 {
  border-radius: 20px;
}

.brd_rds06 {
  border-radius: 25px;
}

.brd_rds07 {
  border-radius: 30px;
}

.brd_rds08 {
  border-radius: 35px;
}

.brd_rds09 {
  border-radius: 40px;
}

.brd_rds10 {
  border-radius: 45px;
}

.brd_rds11 {
  border-radius: 50px;
}

.brd_rds12 {
  border-radius: 50%;
}

/* -----------------------------------------------------------
  フォント色
----------------------------------------------------------- */
.clr01 {
  color: #000000 !important;
}

.clr01:hover {
  color: #ffffff !important;
}

.clr02 {
  color: #123a4b !important;
}

.clr02:hover {
  color: #ffffff !important;
}

.clr03 {
  color: #ffffff !important;
}

.clr03:hover {
  color: #000000 !important;
}

.clr04 {
  color: #ffffff !important;
}

.clr04:hover {
  color: #ffffff !important;
}
/* -----------------------------------------------------------
  フォント大きさ
----------------------------------------------------------- */
.fs_00 {
  font-size: 1.0rem;
}

.fs_01 {
  font-size: 1.1rem;
}

.fs_02 {
  font-size: 1.2rem;
}

.fs_03 {
  font-size: 1.3rem;
}

.fs_04 {
  font-size: 1.4rem;
}

.fs_05 {
  font-size: 1.5rem;
}

.fs_06 {
  font-size: 1.6rem;
}

.fs_07 {
  font-size: 1.7rem;
}

.fs_08 {
  font-size: 1.8rem;
}

/* -----------------------------------------------------------
  フォント太さ
----------------------------------------------------------- */
.fw_b00 {
  font-weight: normal;
}

.fw_b01 {
  font-weight: 100;
}

.fw_b02 {
  font-weight: 300;
}

.fw_b03 {
  font-weight: 400;
}

.fw_b04 {
  font-weight: 500;
}

.fw_b05 {
  font-weight: 700;
}

.fw_b06 {
  font-weight: 900;
}

/* -----------------------------------------------------------
  高さ
----------------------------------------------------------- */
.hit_100 {
  height: 100%;
}

.hit_01 {
  height: 30px;
}

.hit_02 {
  height: 35px;
}

.hit_03 {
  height: 40px;
}

.hit_04 {
  height: 45px;
}

.hit_05 {
  height: 50px;
}

.hit_06 {
  height: 55px;
}

.hit_07 {
  height: 60px;
}

.hit_08 {
  height: 65px;
}

.hit_09 {
  height: 70px;
}

.hit_10 {
  height: 75px;
}

.hit_11 {
  height: 80px;
}

.hit_12 {
  height: 85px;
}

.hit_13 {
  height: 90px;
}

.hit_14 {
  height: 95px;
}

.hit_15 {
  height: 100px;
}

.hit_16 {
  height: 110px;
}

.hit_17 {
  height: 120px;
}

.hit_18 {
  height: 130px;
}

.hit_19 {
  height: 140px;
}

.hit_20 {
  height: 150px;
}

/* -----------------------------------------------------------
  幅
----------------------------------------------------------- */
.wid_100 {
  width: 100%;
}

.wid_01 {
  width: 100px;
}

.wid_02 {
  width: 120px;
}

.wid_03 {
  width: 130px;
}

.wid_04 {
  width: 140px;
}

.wid_05 {
  width: 150px;
}

.wid_06 {
  width: 160px;
}

.wid_07 {
  width: 170px;
}

.wid_08 {
  width: 180px;
}

.wid_09 {
  width: 190px;
}

.wid_10 {
  width: 200px;
}

.wid_11 {
  width: 210px;
}

.wid_12 {
  width: 220px;
}

.wid_13 {
  width: 230px;
}

.wid_14 {
  width: 240px;
}

.wid_15 {
  width: 250px;
}

.wid_16 {
  width: 260px;
}

.wid_17 {
  width: 270px;
}

.wid_18 {
  width: 280px;
}

.wid_19 {
  width: 290px;
}

.wid_20 {
  width: 300px;
}

.wid_21 {
  width: 310px;
}

.wid_22 {
  width: 320px;
}

.wid_23 {
  width: 330px;
}

.wid_24 {
  width: 340px;
}

.wid_25 {
  width: 350px;
}

/* -----------------------------------------------------------
  .hd
----------------------------------------------------------- */
.hd_01 {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 4.0rem;
  font-weight: 500;
  text-align: center;
}

.hd_01:after {
  background-color: #123a4b;
  content: "";
  height: 2px;
  width: 50px;
  margin-top: 10px;
}

/* -----------------------------------------------------------
  inner
----------------------------------------------------------- */
.inner01 {
  max-width: 1080px;
  min-width: 810px;
  width: 100%;
  margin: 0 auto;
}

/* -----------------------------------------------------------
  header
----------------------------------------------------------- */
header {
  background-color: #f3f3f2;
  border-bottom: 1px solid #000000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-left: 3vw;
  position: sticky;
  top: 0;
  height: 90px;
  z-index: 30;
}

header .site_id {
  display: flex;
  align-items: center;
}

header .site_id a {
  line-height: 0;
}

header .site_id .site_logo {
  line-height: 0;
  width: 200px;
}

header .site_id .tagline {
  font-size: 1.3rem;
  font-weight: normal;
  line-height: 1.2;
  margin-left: 20px;
}

header .head_rt {
  display: flex;
  align-items: center;
}

header .head_rt .sns_box ul {
  display: flex;
  gap: 10px;
}

header .head_rt .sns_box ul li a {
  display: block;
  height: 35px;
  width: 35px;
}

header .head_rt .sns_box ul li a.instagram:hover svg path {
  fill: #4c64d3;
}

header .head_rt .sns_box ul li a.line:hover svg path {
  fill: #00b900;
}

header .head_rt .tel_box {
  margin-left: 30px;
}

header .head_rt .tel_box .tel {
  font-size: 1.8rem;
  font-weight: 700;
}

header .head_rt .tel_box .tel span:nth-of-type(1):after {
  content: "：";
  margin: 0 0.15em;
}

header .head_rt .btns_box {
  margin-left: 30px;
}

header .head_rt .btns_box ul {
  display: flex;
  gap: 20px;
}

/* -----------------------------------------------------------
    toggle-panel
----------------------------------------------------------- */
#panel-btn {
  background-color: #000000;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 90px;
  width: 90px;
  margin-left: 30px;
  transform: translateX(0);
  transition: all .5s ease;
  z-index: 10000;
}

#panel-btn:hover {
  background-color: #4d4d4d;
}

#panel-btn-icon {
  background-color: #ffffff;
  display: block;
  width: 40px;
  height: 2px;
  transition: .2s;
}

#panel-btn-icon:before,
#panel-btn-icon:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  width: 40px;
  height: 2px;
  margin-left: 0;
  transition: .3s;
}

#panel-btn-icon:before {
  background-color: #ffffff;
  margin-top: -12px;
}

#panel-btn-icon:after {
  background-color: #ffffff;
  margin-top: 10px;
}

#panel-btn .close {
  background-color: transparent;
}

#panel-btn .close:before,
#panel-btn .close:after {
  background-color: #ffffff;
  margin-top: 0;
  width: 40px;
}

#panel-btn .close:before {
  transform: rotate(-45deg);
}

#panel-btn .close:after {
  transform: rotate(-135deg);
}

.overlay {
  background-color: rgba(0, 0, 0, 0);
  content: "";
  display: block;
  height: 0;
  width: 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0;
  transition: opacity .5s;
}

.overlay.open {
  opacity: 1;
  height: 100vh;
  width: 100%;
}

#panel-btn.active {
  background-color: transparent;
  xtransform: translateX(-350px);
}

/* -----------------------------------------------------------
  .nav_box
----------------------------------------------------------- */
.nav_box {
  background-color: rgba(0, 0, 0, 0.9);
  color: #ffffff;
  display: block;
  height: auto;
  width: 100%;
  overflow-y: auto;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 10;
  transform: translateY(-100%);
  transition: all .5s;
}

.nav_box.open {
  transform: translateZ(0);
}

.nav_box .nav_inner {
  border-top: 1px solid #ffffff;
  margin-top: 90px;
  padding: 2.5vw 10vw;
}

.nav_box .nav_inner .nav_head .g_nav ul {
  display: flex;
  gap: 50px;
}

.nav_box .nav_inner .nav_head .g_nav ul li a {
  color: #ffffff;
}

.nav_box .nav_inner .nav_head .g_nav ul li a:hover {
  opacity: 0.5;
}

.nav_box .nav_inner .nav_main {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: 100px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_tel a {
  color: #ffffff;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_tel a:hover {
  opacity: 0.5;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_tel span:nth-of-type(1) {
  font-size: 1.8rem;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_tel span:nth-of-type(2) {
  font-size: 2.6rem;
  font-weight: 700;
  margin: 0 0.25em;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn {
  display: flex;
  align-items: center;
  margin-top: 30px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .button_box ul {
  display: flex;
  gap: 20px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .sns_box {
  margin-left: 30px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .sns_box ul {
  display: flex;
  gap: 10px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .sns_box ul li a {
  display: block;
  height: 45px;
  width: 45px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .sns_box ul li a:hover svg path {
  fill: #ffffff;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .sns_box ul li a.instagram:hover svg path.st0 {
  fill: #4c64d3;
}

.nav_box .nav_inner .nav_main .nav_main_lt .nav_btn .sns_box ul li a.line:hover svg path.st0 {
  fill: #00b900;
}

.nav_box .nav_inner .nav_main .nav_main_lt .u_nav {
  font-size: 1.4rem;
  margin-top: 30px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .u_nav ul li:not(:first-of-type) {
  margin-top: 5px;
}

.nav_box .nav_inner .nav_main .nav_main_lt .u_nav ul li a {
  color: #ffffff;
}

.nav_box .nav_inner .nav_main .nav_main_lt .u_nav ul li a:hover {
  opacity: 0.5;
}

.nav_box .nav_inner .nav_main .nav_main_rt .nav_logo .tagline {
  font-size: 1.3rem;
}

.nav_box .nav_inner .nav_main .nav_main_rt .nav_logo .logo {
  line-height: 0;
  margin-top: 15px;
  width: 200px;
}

.nav_box .nav_inner .nav_main .nav_main_rt .nav_logo .logo svg path {
  fill: #ffffff !important;
}

/* -----------------------------------------------------------
  main
----------------------------------------------------------- */
main {
  xmargin-top: 90px;
}

/* -----------------------------------------------------------
  .main
----------------------------------------------------------- */
#lower .main {
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 30vh;
  position: relative;
  z-index: 0;
}

#lower .main:before {
  background-color: rgba(0, 0, 0, 0.2);
  content: "";
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

#lower .main .headline {
  color: #ffffff;
  text-align: center;
}

#lower .main .headline .main_ttl {
  font-size: 3.4rem;
  margin-top: 10px;
}

/* -----------------------------------------------------------
  .ttl_en
----------------------------------------------------------- */
.ttl_en {
  position: absolute;
  top: 5vw;
  left: 2vw;
}

/* -----------------------------------------------------------
  .container
----------------------------------------------------------- */
.container > section {
  position: relative;
}

/* -----------------------------------------------------------
  .contents
----------------------------------------------------------- */
.contents {
  margin-top: 5vw;
}

/* -----------------------------------------------------------
  footer
----------------------------------------------------------- */
footer {
  background-color: #000000;
  color: #ffffff;
  padding: 5vw 10vw;
}

footer a {
  color: #ffffff !important;
}

footer .upside {
  display: flex;
  justify-content: space-between;
}

footer .upside .left_box {
  flex: 1 1;
}

footer .upside .left_box .top_box {
  display: flex;
  justify-content: space-between;
}

footer .upside .left_box .top_box .foot_box .logo_box span {
  display: block;
}

footer .upside .left_box .top_box .foot_box .logo_box .tagline {
  font-size: 1.3rem;
}

footer .upside .left_box .top_box .foot_box .logo_box .logo {
  line-height: 0;
  margin-bottom: 5px;
  margin-top: 15px;
  width: 200px;
}

footer .upside .left_box .top_box .foot_box .logo_box .logo svg path {
  fill: #ffffff !important;
}

footer .upside .left_box .top_box .foot_box .logo_box .jp {
  font-size: 1.5rem;
}

footer .upside .left_box .top_box .foot_box .sns_box {
  margin-top: 30px;
}

footer .upside .left_box .top_box .foot_box .sns_box ul {
  display: flex;
  gap: 10px;
}

footer .upside .left_box .top_box .foot_box .sns_box ul li a {
  display: block;
  height: 45px;
  width: 45px;
}

footer .upside .left_box .top_box .foot_box .sns_box ul li a:hover svg path {
  fill: #ffffff;
}

footer .upside .left_box .top_box .foot_box .sns_box ul li a.instagram:hover svg path.st0 {
  fill: #4c64d3;
}

footer .upside .left_box .top_box .foot_box .sns_box ul li a.line:hover svg path.st0 {
  fill: #00b900;
}

footer .upside .left_box .top_box .f_nav_box {
  margin-left: 3vw;
}

footer .upside .left_box .top_box .f_nav_box .f_nav ul {
  display: flex;
  gap: 50px;
}

footer .upside .left_box .top_box .f_nav_box .f_nav ul li a:hover {
  opacity: 0.5;
}

footer .upside .left_box .bottom_box {
  margin-top: 20px;
}

footer .upside .left_box .bottom_box address .tel span:nth-of-type(1) {
  font-size: 1.8rem;
}

footer .upside .left_box .bottom_box address .tel span:nth-of-type(2) {
  font-size: 2.6rem;
  font-weight: 700;
  margin: 0 0.25em;
}

footer .upside .left_box .bottom_box address .add {
  margin-top: 10px;
}

footer .upside .left_box .bottom_box address .add span:nth-of-type(1) {
  margin-right: 0.5em;
}

footer .upside .right_box {
  margin-left: 10vw;
}

footer .upside .right_box .btn_nav ul li:not(:first-of-type) {
  margin-top: 20px;
}

footer .upside .right_box .txt_nav {
  margin-top: 30px;
}

footer .upside .right_box .txt_nav ul {
  font-size: 1.4rem;
}

footer .upside .right_box .txt_nav ul li:not(:first-of-type) {
  margin-top: 5px;
}

footer .upside .right_box .txt_nav ul li a:hover {
  opacity: 0.5;
}

footer .downside {
  margin-top: 50px;
}

/* -----------------------------------------------------------
  aside
----------------------------------------------------------- */
aside {
  position: fixed;
  top: 50vh;
  right: 0;
  z-index: 20;
}

aside ul li a {
  border-radius: 10px 0 0 10px;
}

aside.done {
  transform: translateX(0);
  opacity: 0;
  visibility: hidden;
}