@import url("https://fonts.googleapis.com/css?family=M+PLUS+1p:400");
@import url("https://fonts.googleapis.com/css?family=Muli:300,700|Nunito");
/* yakuhanmp */
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@3.4.1/dist/css/yakuhanjp-narrow.min.css");

/* Noto Sans JP */
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP%7CRoboto&display=swap");

/* Yuji Syuku */
/* @import url('https://fonts.googleapis.com/css2?family=Yuji+Syuku&display=swap'); */

/* Kiwi Maru */
/* @import url('https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@300;400;500&display=swap'); */

/* Shippori Mincho */
@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@800&display=swap");

/* Montserrat */
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap");

html {
  font-size: 100%;
  /*16px*/
  margin: 0;
  padding: 0;
}

body {
  background: #ffffff;
  font-family: YakuHanJP_Narrow, "Noto Sans JP", sans-serif;
  line-height: 1.75;
  font-weight: 400 !important;
  overflow-x: hidden;
  letter-spacing: 0.05rem;
  margin: 0;
  padding: 0;
  color: #333;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}

body.appear {
  /* background:#f0f0f0; */
  background-color: #f4f4f2 !important;
  background-image: radial-gradient(#fcfcfc 30%, transparent 33%),
    radial-gradient(#fcfcfc 30%, transparent 33%);
  background-size: 8px 8px;
  background-position: 0 0, 4px 4px;
}

/* 背景固定用のクラス */
.body-fixed {
  overflow: hidden;
}

.shippori-mincho {
  font-family: "Shippori Mincho", serif;
  font-style: normal;
}

p {
  margin-bottom: 1rem;
}

h2,
h3,
h4,
h5 {
  margin: 3rem 0 1.38rem;
  font-family: "M PLUS 1p", "メイリオ", "小塚ゴシック Pro R",
    "ヒラギノ角ゴ Pro W3", "Meiryo", "KozGoPro-Regular",
    "Hiragino Kaku Gothic Pro", sans-serif;
  font-weight: 400;
  line-height: 1.3;
}

h2 {
  font-size: 1.602rem;
}

@media (max-width: 768px) {
  h2 {
    font-size: 1.424rem !important;
  }
}

h3 {
  font-size: clamp(1.063rem, 0.949rem + 0.57vw, 1.375rem);
}

.ssp {
  display: none;
}

.ssp-no {
  display: inline-block;
}

@media (max-width: 400px) {
  .ssp {
    display: inline-block;
  }

  .ssp-no {
    display: none;
  }
}

h4 {
  font-size: 1.266rem;
}

h5 {
  font-size: 1.125rem;
}

small,
.text_small {
  font-size: 0.889rem;
}

.display-4 {
  font-size: 2.5rem;
}

@media (min-width: 768px) {
  .display-4 {
    font-size: 3rem;
  }
}

/*
 * Footer
 */

.footer {
  padding: clamp(0.5rem, -0.227rem + 3.64vw, 2.5rem) 0;
  color: #fff;
  text-align: center;
  background-color: #333;
  border-top: 0.05rem solid #333;
  font-size: clamp(0.8rem, 0.764rem + 0.18vw, 0.9rem);
}

.footer p:last-child {
  margin-bottom: 0;
}

section {
  margin: -125px 0 125px !important;
  padding: 125px 0 !important;
}

@media (max-width: 991px) {
  section {
    margin: -100px 0 100px !important;
    padding: 100px 0 !important;
  }
}

@media (max-width: 576px) {
  section {
    margin: 0 !important;
    padding: 35px 0 35px !important;
  }
}

.section-title {
  text-align: center;
  padding-bottom: 25px;
}

.section-title h2 {
  font-weight: bold;
  margin: 0;
}

.section-title small {
  display: block;
}

h2 {
  color: #333;
  padding-bottom: 25px;
  line-height: 2;
}

h2 {
  position: relative;
  padding-bottom: 0rem;
  text-align: center;
  color: #333;
  font-size: 2em;
  line-height: 1.25;
}

h2:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 45px);
  width: 90px;
  height: 5px;
  content: "";
  border-radius: 3px;
  /* background: #007250; */
  background: #f5c219;
}

.info {
  margin: 0 !important;
  width: 100%;
  padding: 0 25px;
  /* border: 1px solid #ccc; */
  text-align: left;
  line-height: 1.65;
  color: #333;
  overflow: auto;
  font-size: 15px !important;
  /* height: 16em; */
}

.info dl {
  padding: 0.25em 0 !important;
  border-bottom: 1px solid #ccc;
}

.info dt {
  padding-bottom: 0.35rem;
  width: 6em;
}

.info dd {
  /* 折り返しを許可 */
  white-space: normal;

  /* CJK文字同士の途中改行を抑制 */
  word-break: keep-all;

  /* 括弧や句読点前後での改行を厳格に */
  -webkit-line-break: strict;  /* Safari 用 */
  line-break: strict;          /* 標準 */

  /* 英数字や長い語の途中折返し用 */
  overflow-wrap: break-word;
}

.section-title-come {
  text-align: left;
  margin: 45px 0 0;
  padding: 0;
  line-height: 1.65;
}

.section-title-come > span {
  display: inline-block;
}

.section-title-come > span.bgred {
  background: red;
  color: #fff;
  padding: 1px 5px;
}

.section-title-come02 {
  list-style: none;
  text-align: left;
  margin: 15px 0 0;
  padding: 0;
  line-height: 1.65;
}

.section-title-come02 li {
  padding-left: 1rem;
  text-indent: -1rem;
}

.indent-1 {
  padding-left: 1rem;
  text-indent: -1rem;
}

dt,
dd {
  margin: 0;
  padding: 0;
}

.dlTable {
  width: 100%;
  border-top: 1px solid #ddd;
  border-left: 1px solid #ddd;
  display: flex;
  flex-wrap: wrap;
  font-size: 15px;
  margin-top: 5px;
}

.dlTable dt,
.dlTable dd {
  border-bottom: 1px solid #ddd;
  border-right: 1px solid #ddd;
  box-sizing: border-box;
  padding: 12px 15px;
}

.dlTable dt {
  width: 100px;
  text-align-last: justify;
  text-justify: inter-ideograph;
}

.dlTable dd {
  width: calc(100% - 100px);
}

@media (max-width: 468px) {
  .dlTable dt,
  .dlTable dd {
    padding: 12px 7px;
  }

  .dlTable dt {
    width: 70px;
    text-align-last: justify;
    text-justify: inter-ideograph;
  }

  .dlTable dd {
    width: calc(100% - 70px);
  }
}

.bg01 {
  background: -webkit-repeating-linear-gradient(
    -45deg,
    rgb(250, 255, 235),
    rgb(250, 255, 235) 3px,
    rgb(179, 233, 255) 3px,
    rgb(179, 233, 255) 7px
  );
  background: repeating-linear-gradient(
    -45deg,
    rgb(250, 255, 235),
    rgb(250, 255, 235) 3px,
    rgb(179, 233, 255) 3px,
    rgb(179, 233, 255) 7px
  );
}

.bg02 {
  background: -webkit-repeating-linear-gradient(
    -45deg,
    rgb(255, 228, 228),
    rgb(255, 228, 228) 3px,
    rgb(255, 200, 200) 3px,
    rgb(255, 200, 200) 7px
  );
  background: repeating-linear-gradient(
    -45deg,
    rgb(255, 228, 228),
    rgb(255, 228, 228) 3px,
    rgb(255, 200, 200) 3px,
    rgb(255, 205, 205) 7px
  );
}

.bg03 {
  background: -webkit-repeating-linear-gradient(
    -45deg,
    rgb(250, 255, 235),
    rgb(250, 255, 235) 3px,
    rgb(237, 255, 179) 3px,
    rgb(237, 255, 179) 7px
  );
  background: repeating-linear-gradient(
    -45deg,
    rgb(250, 255, 235),
    rgb(250, 255, 235) 3px,
    rgb(237, 255, 179) 3px,
    rgb(237, 255, 179) 7px
  );
}

.bg04 {
  background: -webkit-repeating-linear-gradient(
    -45deg,
    rgb(255, 243, 244),
    rgb(255, 243, 244) 3px,
    rgb(255, 220, 223) 3px,
    rgb(255, 220, 223) 7px
  );
  background: repeating-linear-gradient(
    -45deg,
    rgb(255, 243, 244),
    rgb(255, 243, 244) 3px,
    rgb(255, 220, 223) 3px,
    rgb(255, 220, 223) 7px
  );
}

.guidance_course {
  margin: 0;
  padding: 0;
  list-style: none;
}

.guidance_course li {
  padding-left: 1rem;
  text-indent: -1rem;
  padding-bottom: 10px;
}

.program {
  text-align: left;
  list-style: none;
  margin: 15px 25px 0 25px;
  position: relative;
  border: none;
  padding: 30px 20px;
  background-color: #fff;
  box-shadow: 2px 2px 4px gray;
  overflow: hidden;
}

.etitle,
.etitle-bno {
  font-size: 1.25rem;
  font-weight: bold;
  width: 100%;
  position: relative;
  padding: 0.35rem 0 1rem;
  line-height: 1.25;
}

.gift {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;

  /* 既存のスタイル */
  font-size: 2.2em;
  text-align: left;
  color: #880e4f;
  letter-spacing: 0.01em;
  font-weight: 500;

  /* 親には下線を消す */
  text-decoration: none;
}

.card-body > p > span.gift-text {
  background: none;
  color: #880e4f;
  padding: 0;
  border-radius: none;
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.2rem);
  line-height: 1.45;
  font-weight: 600;
}

.card-body > p > span.gift-text > span {
  display: inline-block;
  /* text-decoration: underline;
  text-decoration-color: currentColor;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.25em; */
}

.gift-bg {
  background-color: #fff6f7;
}

h3.kaijyo {
  font-size: clamp(1.3rem, 1.22rem + 0.4vw, 1.7rem);
  font-weight: 900 !important;
  width: 100%;
  position: relative;
  margin: 25px 0 12px;
  padding: 0;
  display: flex;
  align-items: center;
}

h3.kaijyo::before,
h3.kaijyo::after {
  content: "";
  height: 2px;
  background-color: #dbdbdb;
}

h3.kaijyo::before {
  width: clamp(1rem, 0.6rem + 2vw, 3rem);
  margin-right: 0.5em;
}

h3.kaijyo::after {
  flex: 1;
  margin-left: 0.5em;
}

@media (max-width: 768px) {
  .etitle,
  .etitle-bno {
    font-size: 1.15rem;
    letter-spacing: -0.05rem;
  }

  .etitle02 {
    font-size: 1.15rem;
    letter-spacing: -0.05rem;
  }

  .etitle small {
    letter-spacing: -0.05rem;
    display: inline-block;
  }
}

.etitle:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 7px;
  content: "";
  background-image: -webkit-repeating-linear-gradient(
    135deg,
    #000,
    #000 1px,
    transparent 2px,
    transparent 5px
  );
  background-image: repeating-linear-gradient(
    -45deg,
    #000,
    #000 1px,
    transparent 2px,
    transparent 5px
  );
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.etitle small,
.etitle-bno small {
  font-size: 0.8em;
  color: rgb(80, 80, 80);
  font-weight: bold;
  padding-left: 10px;
  font-style: italic;
}

.etitle02 {
  font-size: 1.25rem;
  font-weight: bold;
  width: 100%;
  position: relative;
  padding: 0;
}

.program_data {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.program_data dt {
  white-space: nowrap;
  position: relative;
  color: #fff;
  font-weight: normal;
  padding: 2px 12px;
  background-color: #585858;
  min-width: 6rem;
  text-align-last: justify;
}

.program_data dt::after {
  left: 98%;
  top: 50%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
  border-color: rgba(136, 183, 213, 0);
  border-width: 10px;
  margin-top: -10px;
  border-left-color: #585858;
}

.program_data dd {
  margin: 0;
  padding-left: 1.25rem;
  width: calc(100% - 6rem);
  /* 折り返しを許可 */
  white-space: normal;
  /* CJK 文字間での途中改行はさせない */
  word-break: keep-all;
  /* 括弧や句読点前後での改行を厳格に */
  -webkit-line-break: strict; /* Safari 用プレフィックス */
  line-break: strict; /* 標準版 */
  /* 念のため、長い単語の途中ででも折り返せるように */
  overflow-wrap: break-word;
}

.program_data dt.wdt75rem {
  width: 7.25rem !important;
}

.program_data dd.wdd75rem {
  width: calc(100% - 7.25rem) !important;
}

.program_data dd > span {
  display: inline-block;
  margin-right: 0.75rem;
}

@media (max-width: 991px) {
  .program_data dd.wdd75rem {
    width: 100% !important;
  }
}

.mt-25 {
  margin-top: 25px !important;
}

dt.green {
  background-color: #00a945;
}

dt.green::after {
  border-left-color: #00a945;
}

dt.blue {
  background-color: #0094d6;
}

dt.blue::after {
  border-left-color: #0094d6;
}

dt.purple {
  background-color: #111;
}

dt.purple::after {
  border-left-color: #111;
}

dt.pink {
  background-color: #cd5b58;
}

dt.pink::after {
  border-left-color: #cd5b58;
}

dt.yellow {
  background-color: #968c00;
}

dt.yellow::after {
  border-left-color: #968c00;
}

/*---------------------------------------
      TEAM              
  -----------------------------------------*/

.team-thumb {
  background: #ffffff;
  position: relative;
  overflow: hidden;
  text-align: left;
  margin-bottom: 0 !important;
  border-radius: 5px;
}

.team-info {
  padding: 0 15px 10px;
}

.team-image img {
  width: 100%;
  padding: 10px;
}

.team-info h4 {
  font-size: 1.05rem;
  font-weight: bold;
  margin: 0;
  padding: 0 0 0 10px;
}

.team-info h4 span {
  font-size: 0.85rem;
  margin: 0;
  font-weight: normal;
  padding-left: 0.35rem;
  /* letter-spacing: -0.1em; */
}

@media (min-width: 1200px) and (max-width: 1290px) {
  .team-info h4 {
    font-size: 1rem;
    letter-spacing: -0.05em;
  }

  .team-info h4 span {
    font-size: 0.8rem;
    letter-spacing: -0.05em;
  }
}

@media (max-width: 991px) {
  .team-info h4 {
    font-size: 0.9rem;
  }

  .team-info h4 span {
    font-size: 0.8rem;
  }
}

@media (max-width: 576px) {
  .team-info h4 {
    font-size: 0.875rem;
    letter-spacing: -0.02em;
  }

  .team-info h4 span {
    font-size: 0.7rem;
    letter-spacing: -0.02em;
    padding-left: 0.1rem;
  }
}

.venue {
  font-size: 1.15em;
  font-weight: bold !important;
  color: #333 !important;
  margin-bottom: 0;
}

.vacs {
  list-style-type: none !important;
  margin: 0;
  padding: 0 0 25px 15px;
  color: #333 !important;
}

.vacs li {
  line-height: 1.75;
}

.traffic {
  font-size: 1.1em;
  text-transform: uppercase;
  color: #111;
  clear: left;
  border-left-width: 3px;
  border-left-style: solid;
  border-left-color: #111;
  text-indent: 8px;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0.5em;
  margin-left: 0;
}

.btn-outline-info {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

/* -- div#pagetop-scroll -------------------------------------------------------------------------------------------- */

div#pagetop-scroll {
  display: none;
  position: fixed;
  right: 25px;
  bottom: 25px;
  /* color: #333; */
  color: #f5c219;
}

div#pagetop-scroll:hover {
  cursor: pointer;
  opacity: 0.9;
}

.bg-light {
  background-color: #f4f4f2 !important;
  background-image: radial-gradient(#fcfcfc 30%, transparent 33%),
    radial-gradient(#fcfcfc 30%, transparent 33%);
  background-size: 8px 8px;
  background-position: 0 0, 4px 4px;
}

span.num {
  background: #3f51b5;
  border-radius: 50px;
  color: #ffffff;
  font-size: 20px;
  font-weight: bold;
  /* display: inline-block; */
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  margin-bottom: 5px;
  float: left;
  padding-bottom: 25px !important;
}

span.numttl {
  line-height: 50px;
  padding-left: 0.45rem;
}

.priceicon {
  margin-top: -10px !important;
}

.management_office {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: center;
}

.management_office li {
  list-style: none;
  line-height: 1.45;
  word-break: keep-all;
  line-break: strict;
}

.management_office li:first-child {
  font-size: 1.15em;
  font-weight: bold;
  padding-bottom: 10px;
}

/* .navbar-brand {
  font-weight: bold;
  font-size: 1.15rem;
  line-height: 1.35;
} */

header {
  height: 75px !important;
}

header a:hover {
  text-decoration: none !important;
}

a > h1 {
  font-weight: bold !important;
  font-size: clamp(1rem, 0.727rem + 1.36vw, 1.75rem) !important;
  margin: 0 !important;
  padding: 10px 0 0 5px !important;
  color: #000 !important;
  line-height: 1;
  text-decoration: none;
}

a > h1 > span {
  font-size: clamp(1rem, 0.864rem + 0.68vw, 1.375rem) !important;
  margin-right: 0.15rem;
}

@media (min-width: 991px) and (max-width: 1200px) {
  a > h1 {
    letter-spacing: -0.075rem;
  }
}

@media (max-width: 576px) {
a > h1 {
  padding: 0 0 0 10px !important;
}

  a > h1 {
    line-height: 1.35;
    letter-spacing: -0.01rem;
  }

    a > h1 >span{
    display: block;
  }
}

.tooltip-inner {
  background-color: #f3ba00;
}

.tooltip.bs-tooltip-right .arrow:before {
  border-right-color: #f3ba00 !important;
}

.tooltip.bs-tooltip-left .arrow:before {
  border-right-color: #f3ba00 !important;
}

.tooltip.bs-tooltip-bottom .arrow:before {
  border-right-color: #f3ba00 !important;
}

.tooltip.bs-tooltip-top .arrow:before {
  border-right-color: #f3ba00 !important;
}

.chui {
  list-style: none;
  text-align: left;
  margin: 0;
  padding: 15px 0;
  line-height: 1.65;
}

.chui li {
  padding-left: 1rem;
  text-indent: -0.5rem;
  line-height: 1.65;
  margin-bottom: 7px;
}

.chui li:first-child {
  font-size: 1.1rem;
  padding-left: 0rem !important;
  text-indent: 0rem !important;
}

ul.entry {
  margin: 0;
  padding: 0;
}
ul.entry li {
  list-style: none;
  margin: 7px 0;
}
ul.entry li a {
  display: block;
}

.bg-white01 {
  background: #f8fafc !important;
}

.spanstyle01 {
  background: #696969;
  color: #fff;
  padding: 4px 8px;
  border-radius: 5px;
  font-size: 14px;
}

.spanstyle02 {
  background: #696969;
  color: #fff;
  padding: 4px 8px;
  border-radius: 2px;
  font-size: 17px;
}

.dstyle01 {
  white-space: nowrap;
  margin-bottom: 7px;
}

.mx-420 {
  max-width: 420px !important;
}

.mx-660 {
  max-width: 655px !important;
}

.team-area {
  width: 98% !important;
  max-width: 1440px !important;
}

.address {
  margin-top: 0x;
  margin-bottom: 15px;
  color: #333 !important;
  line-height: 1.35;
  font-size: 0.9rem;
}

.fs28px {
  font-size: 28px !important;
}

.top-view {
  padding-top: 92px;
  padding-bottom: calc(7.552083333333333vw + 15px) !important;
}

@media (max-width: 1800px) {
.top-view {
  padding-top: 92px;
  padding-bottom: calc(7.552083333333333vw + 25px) !important;
}
}

@media (max-width: 1600px) {
.top-view {
  padding-top: 92px;
  padding-bottom: calc(7.552083333333333vw + 45px) !important;
}
}

@media (max-width: 1400px) {
.top-view {
  padding-top: 92px;
  padding-bottom: calc(7.552083333333333vw + 55px) !important;
}
}

@media (max-width: 991px) {
.top-view {
  padding-top: 92px;
  padding-bottom: calc(1vw + 110px) !important;
}
}

@media (max-width: 576px) {
.top-view {
  padding-bottom: calc(1vw + 5px) !important;
}
}

@media (max-width: 991px) {
  .top-view {
    padding-top: 75px;
  }
}

.date-location-display {
  display: flex;
  justify-content: space-between;
  align-items: flex-end; /* 下揃え */
  margin-top: 45px;
  margin-bottom: 10px;
}

@media (max-width: 576px) {
  .date-location-display {
    display: block;
  }
}

.date-display {
  display: flex;
  align-items: flex-end; /* 下揃え */
  font-size: clamp(1.875rem, 1.33rem + 2.73vw, 3.375rem);
  font-weight: 700;
  font-family: "Lato", sans-serif;
}
.date-display .date {
  margin-right: 0.5rem;
  line-height: 1; /* 日付の高さを調整 */
  display: flex;
  align-items: flex-end; /* 下揃え */
  letter-spacing: -0.01em;
}
.date-display .day {
  display: flex;
  align-items: flex-end; /* 下揃え */
  font-size: clamp(1rem, 0.864rem + 0.68vw, 1.375rem);
  font-weight: normal;
  line-height: 1; /* 曜日の高さを調整 */
  padding-bottom: 0.5rem;
}
.date-display .day span {
  margin-left: 0.25rem;
}

.location-display {
  display: flex;
  align-items: flex-end; /* 下揃え */
  font-size: clamp(1rem, 0.909rem + 0.45vw, 1.25rem);
  padding: 0.5rem 1rem 0;
  font-weight: bold;
}
@media (max-width: 576px) {
  .location-display {
    padding: 0.5rem 0 0;
  }
}
.location-display .badge {
  background-color: #6c757d;
  margin-top: 0.35em;
  margin-right: 0.5rem;
  font-weight: normal;
  align-self: center; /* バッジを上揃え */
}

.mt-65px {
  margin-top: 2.34375vw !important;
}

/*-- Menu ----------------------------------------*/

.topmenu {
  margin: 0;
  padding: 0;
  font-size: 0.95rem;
}

.topmenu li {
  margin: 0;
  background: #fff !important;
  border-right: solid 0.7px #111 !important;
  border-top: solid 0.7px #111 !important;
  border-bottom: solid 0.7px #111 !important;
  padding: 8px 0.2vw !important;
}
.topmenu li.nav-item > a {
  color: #111;
  font-weight: 600;
  white-space: nowrap;
}
@media (max-width: 1200px) {
  .topmenu li {
    padding: 8px 0.05vw !important;
  }
  .topmenu li.nav-item > a {
    font-size: 13.5px !important;
  }
}

.topmenu li:first-child {
  border-left: solid 0.7px #111 !important;
}

.topmenu li a {
  color: #111 !important;
  padding: 0;
  margin: 0;
}

.topmenu li:hover {
  background: #111 !important;
  color: #fff !important;
}

.topmenu li:hover a {
  color: #fff !important;
}

.navbar-toggler {
  border: none;
}

.navbar-toggler:active {
  outline: none;
}

button:focus {
  outline: none;
}

@media (max-width: 991px) {
  .topmenu {
    /* background: #007250; */
    background: #111;
    width: 100vw;
    height: calc(100vh + 50px);
    margin-top: -65px !important;
    padding-top: 100px;
    padding-bottom: 100px;
    overflow-y: scroll;
  }
  .topmenu li {
    text-align: center !important;
    padding: 12px 0 !important;
    margin: 0;
    background: none !important;
    border-right: none !important;
    border-top: none !important;
    border-bottom: none !important;
    color: #fff !important;
  }
  .topmenu li.nav-item > a {
    color: #fff !important;
    font-weight: 600;
  }
  .topmenu li:first-child {
    border-top: none !important;
    border-left: none !important;
  }
  .topmenu li:hover {
    background: #333 !important;
    color: #fff !important;
  }
}

/*-- ハンバーガーメニュー ----------------------------------------*/

.openbtn {
  display: none;
}

@media screen and (max-width: 991px) {
  .openbtn {
    display: block;
    position: fixed;
    z-index: 9999;
    cursor: pointer;
    top: 10px;
    right: 10px;
    width: 55px;
    height: 55px;
    border: 1px solid #fff;
    /* background: #007250; */
    background: #111;
  }

  .openbtn span {
    display: inline-block;
    transition: all 0.4s;
    position: absolute;
  }

  .openbtn span:nth-of-type(1),
  .openbtn span:nth-of-type(3) {
    height: 1px;
    background: #fff;
    width: 62%;
    left: 10px;
  }

  .openbtn span:nth-of-type(1) {
    top: 13px;
  }

  .openbtn span:nth-of-type(2) {
    top: 25px;
    left: 14px;
    font-size: 0.55rem;
    text-transform: uppercase;
    color: #fff;
  }

  .openbtn span:nth-of-type(3) {
    top: 41px;
  }

  .openbtn.active span:nth-of-type(1) {
    top: 22px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
  }

  .openbtn.active span:nth-of-type(2) {
    opacity: 0;
  }

  .openbtn.active span:nth-of-type(3) {
    top: 34px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
  }
}

p.text-indent {
  text-indent: -1em;
  padding-left: 1em;
  line-height: 1.45;
}


.no-break {
  white-space: nowrap;
}

.shadow-down {
  /* 下向きのシャドウ例 */
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
}