@charset "UTF-8";
/*******************************************
	@共通項目
********************************************/
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-repeat: no-repeat;
}

html {
  overflow-y: scroll;
  scroll-behavior: smooth;
  height: 100%;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  letter-spacing: 0.035em;
  line-height: 1.8;
  font-size: clamp(0.875rem, 1.25vw, 1rem);
  color: #231815;
  background-color: #fff;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}
@media screen and (min-width: 1200px), print {
  body {
    letter-spacing: 0.075em;
  }
}

footer {
  position: sticky;
  top: 100vh;
  height: 35px;
}
@media screen and (min-width: 768px), print {
  footer {
    height: 60px;
  }
}

.noto-sans {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

main {
  width: 100%;
  margin: auto;
  padding: 0 5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 880px), print {
  main {
    max-width: 1280px;
    padding: 0 40px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}

a {
  text-decoration: none;
  color: #04c;
}
@media screen and (min-width: 768px), print {
  a {
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
  a:hover {
    color: #f00;
  }
}

a[href*="tel:"] {
  color: inherit;
  text-decoration: none;
  pointer-events: none;
}
@media screen and (min-width: 768px), print {
  a[href*="tel:"] {
    color: #231815;
    pointer-events: none;
  }
}

.outoflink {
  font-weight: 400;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

img[src$=".svg"] {
  width: 100%;
  height: auto;
}

.clr_red {
  color: #e73828;
}

.sp-only {
  display: block;
}
@media screen and (min-width: 768px), print {
  .sp-only {
    display: none;
  }
}

.pc-only {
  display: none;
}
@media screen and (min-width: 768px), print {
  .pc-only {
    display: block;
  }
}

ul {
  padding: 0;
  list-style: none;
}

.post-date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(0.875rem, 1.25vw, 1rem);
  font-weight: 500;
  color: rgba(35, 24, 21, 0.8);
  letter-spacing: 0.02em;
  border-bottom: 1px dotted #00a600;
}
.post-date .new {
  width: 3em;
  margin-bottom: 0.35em;
  margin-right: 0.5em;
  padding: 0.175em 0;
  font-size: clamp(0.6875rem, 1.015625vw, 0.8125rem);
  font-weight: 700;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  line-height: 1;
  border-radius: 4px;
  background-color: #f00;
}
.post-date-date {
  margin-right: 1.5em;
  margin-bottom: 0.35em;
}
.post-date-cat {
  width: auto;
  padding: 0.3em 1.5em !important;
  /*cursor: pointer;*/
  font-size: clamp(0.75rem, 1.09375vw, 0.875rem);
  font-weight: 500;
  color: #006837 !important;
  text-align: center;
  line-height: 1;
  border-radius: 10px;
  background-color: #cef726;
  /*&:hover{
  	color:#fff!important;
  	background-color:#231815;
  }*/
}
.post-date-tax {
  width: auto;
  display: inline-block;
  margin-bottom: 0.2em;
  padding: 0.35em 1em !important;
  /*cursor: pointer;*/
  font-size: clamp(0.6875rem, 1.015625vw, 0.8125rem);
  font-weight: 500;
  color: #333 !important;
  text-align: center;
  line-height: 1;
  border-radius: 3px;
  border: 1px solid #333;
  background-color: #fff;
}

.post-box {
  padding: 1em 1em 0.75em;
  background-color: #f8f8f3;
  word-break: break-word;
}
.post-box-title {
  position: relative;
  margin-top: 0.35em;
  margin-bottom: 0.2em;
  font-size: clamp(1.125rem, 2.03125vw, 1.625rem);
  font-weight: 600;
  line-height: 1.35;
}
.post-box-title.with-body {
  margin-top: 0.25em;
  margin-bottom: 0.35em;
  padding-bottom: 0.35em;
  font-size: clamp(1rem, 1.5625vw, 1.25rem);
  border-bottom: 1px dotted #aaa;
}
.post-box-acf-choice {
  color: #fff;
  font-size: clamp(0.75rem, 1.25vw, 1rem);
  font-weight: 500;
  text-align: center;
}
.post-box-acf-choice .募集中,
.post-box-acf-choice .受付終了,
.post-box-acf-choice .研修中止,
.post-box-acf-choice .研修終了 {
  display: block;
  width: 6em;
  padding: 0.4em 0;
  line-height: 1;
  border-radius: 3em;
}
.post-box-acf-choice .募集中 {
  background-color: #f5a;
}
.post-box-acf-choice .受付終了 {
  color: #231815;
  background-color: #ddd;
}
.post-box-acf-choice .研修中止 {
  color: #231815;
  background-color: #fee103;
}
.post-box-acf-choice .研修終了 {
  background-color: #777;
}
.post-box-acf-choice .消す {
  display: none;
}
.post-box-body {
  margin-top: 0.25em;
  margin-bottom: 1em;
  padding-left: 0;
  font-size: clamp(0.875rem, 1.25vw, 1rem);
}
.post-box-body ul, .post-box-body ol {
  padding-left: 1.75em;
}
.post-box-detail {
  margin-top: 2em;
}
.post-box-detail .title {
  margin-bottom: 0.5em;
  font-size: clamp(1rem, 1.5625vw, 1.25rem);
  border-bottom: 2px solid #00a600;
}
.post-box-detail-box {
  padding-bottom: 0.75em;
  margin-bottom: 0.75em;
  border-bottom: 1px solid #00a600;
}
.post-box-detail-box .head {
  font-weight: 600;
}
.post-box-detail-box .body {
  padding-left: 1em;
}
.post-box-detail-box .body.btns {
  margin: 0.5em;
  padding-left: 0.5em;
}
.post-box.news, .post-box.info {
  margin-bottom: 1em;
  padding: 0 1em 1em;
  background-color: transparent;
}
@media screen and (min-width: 880px), print {
  .post-box {
    margin-bottom: 1.5em;
    padding: 1.25em 2em 1em;
  }
  .post-box a:hover {
    color: #f00;
  }
  .post-box-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0.5em;
  }
  .post-box-body {
    margin-top: 0.35em;
    margin-bottom: 1.5em;
  }
  .post-box-body ul, .post-box-body ol {
    padding-left: 1.5em;
  }
  .post-box.news, .post-box.info {
    margin-bottom: 2em;
  }
}

.txt-up {
  text-transform: uppercase;
}

.txt-cap {
  text-transform: capitalize;
}

.txt-non {
  text-transform: non;
}

.mt1 {
  margin-top: 1em;
}

.mt2 {
  margin-top: 2em;
}

.mt3 {
  margin-top: 3em;
}

.mt4 {
  margin-top: 4em;
}

.mb1 {
  margin-bottom: 1em;
}

.mb2 {
  margin-bottom: 2em;
}

.mb3 {
  margin-bottom: 3em;
}

.mb4 {
  margin-bottom: 4em;
}

.fadein {
  opacity: 0;
  -webkit-transform: translate(0, 35px);
          transform: translate(0, 35px);
  -webkit-transition: all 1500ms;
  transition: all 1500ms;
}

.fadein.scrollin {
  opacity: 1;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}

.separator-line {
  width: 100%;
  /*margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);*/
  margin-top: 4em;
  padding-top: 1.5em;
  border-top: 1px solid #9e9e9e;
}
@media screen and (min-width: 1200px), print {
  .separator-line {
    margin-top: 8em;
  }
}

.bg-area {
  background-color: #f8f8f3;
}

/* リンク集ページのBOX */
.link-box {
  margin-bottom: 3em;
  padding: 1em 2em;
  background-color: #f8f8f3;
}

/*******************************************
	@HEADER
********************************************/
@media screen and (min-width: 1260px), print {
  .sp-head {
    display: none;
  }
}
@media screen and (max-width: 1259px), print {
  .sp-head {
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    right: 0;
    height: 58px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    background-color: #fff;
    border-bottom: 2px solid #e9e9e9;
  }
  .sp-head-logo {
    padding-left: 1%;
  }
  .sp-head-logo a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: inherit;
  }
  .sp-head-logo a .logo-image {
    width: 45px;
    margin-top: 3px;
    margin-right: 3px;
  }
  .sp-head-logo a .logo-txt {
    font-size: clamp(1.125rem, 1.40625vw, 1.125rem);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.075em;
  }
  .sp-head-logo a .logo-txt span {
    display: block;
  }
  .sp-head-logo a .logo-txt span.jp {
    margin-bottom: 3px;
    font-size: clamp(0.625rem, 0.78125vw, 0.625rem);
    letter-spacing: 0.03em;
  }
  .sp-head-logo a .logo-txt span.en {
    margin-top: 4px;
    font-size: clamp(0.5625rem, 0.703125vw, 0.5625rem);
    font-weight: 400;
    color: #808080;
    letter-spacing: -0.01em;
  }
}

/* ハンバーガー用 */
button {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  vertical-align: middle;
  text-align: inherit;
  font: inherit;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

@media screen and (min-width: 1260px), print {
  .h-btn {
    display: none;
  }
}

@media screen and (max-width: 1259px), print {
  .h-btn {
    position: fixed;
    top: 0;
    right: 2%;
    width: 50px;
    height: 50px;
    z-index: 200;
  }
  .h-btn .btn-line {
    display: block;
    position: relative;
    width: 45px;
    height: 4px;
    margin: auto;
    border-radius: 2px;
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  .h-btn .btn-line::before, .h-btn .btn-line::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 2px;
    background-color: #6ec300;
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  .h-btn .btn-line::before {
    -webkit-transform: translateY(-8px);
            transform: translateY(-8px);
  }
  .h-btn .btn-line::after {
    -webkit-transform: translateY(3px);
            transform: translateY(3px);
  }
  .h-btn .btn-line.open {
    background-color: transparent;
  }
  .h-btn .btn-line.open::before,
  .h-btn .btn-line.open::after {
    content: "";
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  .h-btn .btn-line.open::before {
    -webkit-transform: translateY(-2px) rotate(160deg);
            transform: translateY(-2px) rotate(160deg);
  }
  .h-btn .btn-line.open::after {
    -webkit-transform: translateY(-2px) rotate(-160deg);
            transform: translateY(-2px) rotate(-160deg);
  }
  .h-btn p.txt {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    font-size: clamp(0.75rem, 0.9375vw, 0.75rem);
    font-weight: 500;
    color: #1a1a1a;
    letter-spacing: 0.15em;
    line-height: 1;
    text-align: center;
  }
  .headerSp.open {
    right: 0;
    background-color: #fff;
  }
  .headerSp {
    position: fixed;
    top: 58px;
    right: -120%;
    z-index: 100;
    width: 100%;
    height: 100vh;
    margin-left: auto;
    padding-bottom: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    font-size: clamp(1.125rem, 1.40625vw, 1.125rem);
    font-weight: 500;
    color: #fff;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    overflow-y: auto;
  }
  .headerSp-menu {
    padding: 0.5em 0 0;
    width: 100%;
    background-color: #00a600;
  }
  .headerSp-menu .link {
    width: 85%;
    margin: auto;
    padding: 0;
    font-weight: 400;
    line-height: 1;
    border-top: 1px dotted #fff;
  }
  .headerSp-menu .link.first {
    border-top: none;
  }
  .headerSp-menu .link a {
    color: #fff;
    font-weight: 400;
    text-decoration: none;
    display: block;
    padding: 1.2em 0;
  }
}
@media screen and (max-width: 1259px) and (min-width: 540px) and (max-width: 1259px) {
  .headerSp-menu .link {
    width: 50%;
  }
}
@media screen and (max-width: 1259px), print {
  .headerSp .subbtn {
    position: relative;
    padding: 1.2em 0;
    color: #fff;
    cursor: pointer;
  }
  .headerSp .subbtn::before {
    content: "";
    position: absolute;
    top: 44%;
    right: 0.5em;
    -webkit-transform: translateY(-50%) rotate(135deg);
            transform: translateY(-50%) rotate(135deg);
    width: 9px;
    height: 9px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .headerSp .subbtn::after {
    content: "";
    position: absolute;
    top: 54%;
    right: 0.5em;
    -webkit-transform: translateY(-50%) rotate(135deg);
            transform: translateY(-50%) rotate(135deg);
    width: 9px;
    height: 9px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .headerSp .subbtn.open {
    text-decoration: none;
  }
  .headerSp .subbtn.open::before {
    -webkit-transform: translateY(0%) rotate(-45deg);
            transform: translateY(0%) rotate(-45deg);
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
  .headerSp .subbtn.open::after {
    -webkit-transform: translateY(0%) rotate(-45deg);
            transform: translateY(0%) rotate(-45deg);
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
  .headerSp .subbtn-menus {
    position: relative;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
    background-color: #f9f9f4;
    display: none;
  }
  .headerSp .subbtn-menus-box {
    padding: 0.3em 1em;
  }
  .headerSp .subbtn-menus a {
    display: none;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0.65em;
    text-align: left;
    font-size: clamp(1rem, 1.25vw, 1rem);
    font-weight: 500;
    color: #1a1a1a;
    line-height: 1.3;
    letter-spacing: -0.05em;
  }
  .headerSp .subbtn-menus a::before {
    content: "・";
    position: absolute;
    left: -5px;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .headerSp .subbtn .open {
    display: block;
  }
  .headerSp-btns {
    padding: 1.25em 0 1.75em;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 1.25em;
    background-color: white;
  }
  .headerSp-btns .btn-contact,
  .headerSp-btns .btn-login {
    width: 6.5em;
    height: 45px;
    text-align: center;
    line-height: 45px;
    letter-spacing: 0.05em;
    border-radius: 27px;
    background-color: #f15a24;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
  .headerSp-btns .btn-contact:hover,
  .headerSp-btns .btn-login:hover {
    background-color: #231815;
  }
  .headerSp-btns .btn-contact a,
  .headerSp-btns .btn-login a {
    color: #fff;
    font-size: clamp(1rem, 1.25vw, 1rem);
    font-weight: 400;
    text-decoration: none;
    display: block;
    padding: 0;
  }
  .headerSp-btns .btn-login {
    background-image: url(../img/common/icon_key.svg);
    background-repeat: no-repeat;
    background-position: left 17px top 15px;
    background-size: 12px;
    background-color: #008700;
  }
  .headerSp-btns .btn-login a {
    padding-left: 20px;
  }
}
.header {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  height: 96px;
  background-color: #fff;
  border-bottom: 4px solid #e9e9e9;
  /* メニューリンクの設定 */
  /* hoverしたら表示する */
  /* 下層メニューのaタグのデザイン */
}
@media screen and (max-width: 1259px) {
  .header {
    display: none;
  }
}
.header-container {
  height: 96px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 5px;
}
.header-logo a {
  margin: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: inherit;
}
.header-logo a .logo-image {
  width: 67px;
  margin-top: 8px;
  margin-right: 1px;
}
.header-logo a .logo-txt {
  font-size: clamp(0.9375rem, 2.03125vw, 1.625rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.065em;
}
.header-logo a .logo-txt span {
  display: block;
}
.header-logo a .logo-txt span.jp {
  margin-bottom: 4px;
  font-size: clamp(0.625rem, 1.015625vw, 0.8125rem);
}
.header-logo a .logo-txt span.en {
  margin-top: 5px;
  font-size: clamp(0.5625rem, 0.78125vw, 0.625rem);
  font-weight: 500;
  color: #808080;
  letter-spacing: 0.0075em;
}
@media screen and (min-width: 1259px) and (max-width: 1280px) {
  .header-logo a .logo-image {
    width: 90%;
    max-width: 55px;
  }
}
.header-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(0.8125rem, 1.015625vw, 0.8125rem);
}
.header nav {
  background-color: #fff;
  color: #1a1a1a;
  text-align: center;
}
.header nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.header nav ul ul {
  display: block;
}
.header nav ul li {
  position: relative;
  font-size: clamp(0.8125rem, 1.015625vw, 0.8125rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.025em;
}
.header nav ul li.parent a {
  display: block;
  margin-right: 15px;
  color: #1a1a1a;
}
.header nav ul li.parent a:hover {
  color: #f00;
}
.header nav li.parent ul {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 3em;
  left: -2em;
  right: 0;
  margin: auto;
  padding: 2px 10px 0;
  width: 15em;
  color: #1a1a1a;
  font-size: clamp(0.875rem, 1.09375vw, 0.875rem);
  background-color: #fff;
  border: solid 3px #6ec300;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.header nav li.parent ul::before {
  content: "";
  position: absolute;
  top: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-bottom: 12px solid #fff;
  z-index: 2;
}
.header nav li.parent ul::after {
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  border-bottom: 14px solid #6ec300;
  z-index: 1;
}
.header nav li.parent ul .menu {
  border-bottom: 1px solid #ddd;
}
.header nav li.parent ul .menu:last-child {
  border-bottom: none;
}
.header nav li.parent ul .menu a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 15em;
  height: 50px;
  padding-left: 1.35em;
  font-size: clamp(0.875rem, 1.09375vw, 0.875rem);
  text-align: left;
  color: #1a1a1a;
  line-height: 1;
  letter-spacing: -0.025em;
}
.header nav li.parent ul .menu a:hover {
  color: #f00;
}
.header nav li.parent ul .menu a::before {
  content: "●";
  position: absolute;
  left: 0;
  right: 0.5em;
  top: 52%;
  font-size: clamp(0.75rem, 0.9375vw, 0.75rem);
  color: #a8dc00;
  -webkit-transform: translateY(-52%);
          transform: translateY(-52%);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.header nav li.parent ul .menu a:hover::before {
  color: #f00;
}
.header nav li.parent ul.box1 {
  width: 14em;
  left: -1em;
}
.header nav li.parent ul.box1 .menu a {
  width: 13em;
}
.header nav li.parent ul.box2 {
  width: 13em;
  left: -2.85em;
}
.header nav li.parent ul.box2 .menu a {
  width: 11em;
}
.header nav li.parent ul.box3 {
  width: 11em;
  left: -0.5em;
}
.header nav li.parent ul.box3 .menu a {
  width: 9em;
}
.header nav li.parent ul.box4 {
  width: 17em;
  left: -4.5em;
}
.header nav li.parent ul.box4 .menu a {
  width: 16em;
}
.header nav li.parent ul.box5 {
  width: 14em;
  left: -3.25em;
}
.header nav li.parent ul.box5 .menu a {
  width: 12em;
}
.header nav ul li.parent::before {
  content: "";
  position: absolute;
  right: 5px;
  top: 18px;
  width: 7px;
  height: 7px;
  -webkit-transform: translateY(-50%) rotate(135deg);
          transform: translateY(-50%) rotate(135deg);
  border-top: 2px solid #00a600;
  border-right: 2px solid #00a600;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.header nav ul li.parent::after {
  content: "";
  position: absolute;
  right: 5px;
  top: 23px;
  width: 7px;
  height: 7px;
  -webkit-transform: translateY(-50%) rotate(135deg);
          transform: translateY(-50%) rotate(135deg);
  border-top: 2px solid #00a600;
  border-right: 2px solid #00a600;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.header nav ul li.parent:hover {
  text-decoration: none;
}
.header nav ul li.parent:hover::before {
  -webkit-transform: translateY(0%) rotate(-45deg);
          transform: translateY(0%) rotate(-45deg);
  border-top: 2px solid #f00;
  border-right: 2px solid #f00;
}
.header nav ul li.parent:hover::after {
  -webkit-transform: translateY(0%) rotate(-45deg);
          transform: translateY(0%) rotate(-45deg);
  border-top: 2px solid #f00;
  border-right: 2px solid #f00;
}
.header nav ul li a {
  display: block;
  color: #1a1a1a;
  padding: 15px 0 15px 20px;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.header nav ul li a:hover {
  color: #f00;
}
.header nav ul li:nth-child(1) a {
  padding-left: 0;
}
.header nav ul li li a {
  padding: 10px 15px;
}
.header nav li.parent:hover > ul,
.header nav li.parent ul li:hover > ul,
.header nav li.parent:active > ul,
.header nav li.parent ul li:active > ul {
  visibility: visible;
  opacity: 1;
}
.header nav li.parent ul li a {
  color: #fff;
  border-bottom: solid 1px rgba(255, 255, 255, 0.6);
}
.header nav li.parent ul li:last-child > a {
  border-bottom: none;
}
.header nav li.parent ul li a:hover,
.header nav li.parent ul li a:active {
  color: #fcc;
}
.header-btns {
  margin-left: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.65em;
}
.header-btns .btn-contact,
.header-btns .btn-login {
  width: 7.1em;
  height: 36px;
  text-align: center;
  line-height: 36px;
  letter-spacing: 0.015em;
  border-radius: 18px;
  background-color: #f15a24;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.header-btns .btn-contact:hover,
.header-btns .btn-login:hover {
  background-color: #231815;
}
.header-btns .btn-contact a,
.header-btns .btn-login a {
  color: #fff;
  font-size: clamp(0.8125rem, 1.015625vw, 0.8125rem);
  font-weight: 400;
  text-decoration: none;
  display: block;
  padding: 0;
}
.header-btns .btn-login {
  background-image: url(../img/common/icon_key.svg);
  background-repeat: no-repeat;
  background-position: left 12px top 11px;
  background-size: 11px;
  background-color: #008700;
}
.header-btns .btn-login a {
  padding-left: 16px;
}

/*
&-btns{
	display:flex;
	justify-content:flex-end;
	align-items: center;
	margin:0;
	gap:1.6em;
	.link{
		text-align: center;
		font-size:fsclamp(12, 13);
		font-weight:500;
		line-height:1;
		letter-spacing: .025em;
		a{
			display: block;
			color:#1a1a1a;
			&:hover{
				color:#f00;
			}
		}
	}
}
*/
.pankuzu {
  position: fixed;
  z-index: 10;
  top: 58px;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0;
  background-color: #e9e9e9;
}
.pankuzu-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 100%;
  margin: auto;
  height: 21px;
  padding: 4px 5% 0;
  font-size: clamp(0.6875rem, 1.015625vw, 0.8125rem);
  color: #231815;
  line-height: 1;
}
.pankuzu-inner a {
  color: #231815;
}
.pankuzu-inner a:hover {
  color: #f00;
}
.pankuzu-inner > li {
  display: inline-block;
  position: relative;
}
.pankuzu-inner > li:not(:last-of-type)::after {
  content: "＞";
  display: inline-block;
  margin-right: 0.5em;
  margin-left: 0.5em;
}
@media screen and (min-width: 1260px), print {
  .pankuzu {
    top: 96px;
  }
  .pankuzu-inner {
    max-width: 1260px;
    height: 23px;
    padding: 4px 40px 0;
  }
}

/*******************************************
	@FOOTER
********************************************/
/* FOOT-LINKS */
.foot-links {
  margin: 80px auto 0;
}
.foot-links-box {
  font-size: clamp(0.6875rem, 1.09375vw, 0.875rem);
  text-align: center;
}
.foot-links-box a {
  color: #231815;
}
.foot-links-box a:hover {
  color: #f00;
}
@media screen and (min-width: 768px), print {
  .foot-links {
    margin: 120px auto 0;
  }
}

.footer {
  margin-top: 50px;
  height: 35px;
  background-color: #00a600;
}
.footer .copyright {
  margin: auto;
  font-size: clamp(0.6875rem, 1.09375vw, 0.875rem);
  text-align: center;
  color: #fff;
  line-height: 35px;
}
@media screen and (min-width: 768px), print {
  .footer {
    margin-top: 80px;
    height: 60px;
  }
  .footer .copyright {
    margin-top: 45px;
    line-height: 60px;
  }
}

/*******************************************
	@ページヘッダー
********************************************/
.page-head {
  position: relative;
  width: 100%;
  height: 0;
  margin-top: 58px;
  background-repeat: no-repeat;
}
@media screen and (min-width: 1260px), print {
  .page-head {
    margin-top: 116px;
  }
}
.page-head.about {
  padding-bottom: 41.3333333333%;
  background-image: url(../img/page-head/page-head-about.svg);
  background-position: left -26% bottom -78%;
  background-size: 50%;
}
@media screen and (min-width: 1260px), print {
  .page-head.about {
    background-position: left -30% bottom -18%;
    background-size: 55%;
  }
}
.page-head.certification {
  padding-bottom: 45.9259259259%;
  background-image: url(../img/page-head/page-head-certification.webp);
  background-position: left center;
  background-size: 45%;
}
@media screen and (min-width: 880px), print {
  .page-head.certification {
    padding-bottom: 31.4285714286%;
    background-position: left 24% center;
    background-size: 30%;
  }
}
.page-head.join {
  padding-bottom: 45.9259259259%;
  background-image: url(../img/page-head/page-head-join.webp);
  background-position: left center;
  background-size: 45%;
}
@media screen and (min-width: 880px), print {
  .page-head.join {
    padding-bottom: 30%;
    background-position: left 24% center;
    background-size: 30%;
  }
}
.page-head.citizen {
  padding-bottom: 45.9259259259%;
  background-image: url(../img/page-head/page-head-citizen.webp);
  background-position: left center;
  background-size: 45%;
}
@media screen and (min-width: 880px), print {
  .page-head.citizen {
    padding-bottom: 30%;
    background-position: left 24% center;
    background-size: 30%;
  }
}
.page-head.partner {
  padding-bottom: 45.9259259259%;
  background-image: url(../img/page-head/page-head-partner.webp);
  background-position: left center;
  background-size: 45%;
}
@media screen and (min-width: 880px), print {
  .page-head.partner {
    padding-bottom: 26.1904761905%;
    background-position: left 24% center;
    background-size: 30%;
  }
}
.page-head.exclusive {
  margin: auto;
  margin-top: 75px;
  padding-top: 37.3333333333%;
  padding-bottom: 1.5em;
  background-image: url(../img/fig3.svg);
  background-position: center top;
  background-size: 90%;
}
@media screen and (min-width: 880px), print {
  .page-head.exclusive {
    margin-top: 100px;
    padding-top: 250px;
    padding-bottom: 2.5em;
    background-image: url(../img/fig3_pc.svg);
    background-position: center top;
    background-size: 800px;
  }
}
@media screen and (min-width: 1260px), print {
  .page-head.exclusive {
    margin-top: 140px;
    padding-bottom: 3.5em;
  }
}

.page-head_title {
  position: absolute;
  color: #00993e;
  font-size: clamp(1.625rem, 5vw, 4rem);
  font-weight: 700;
  line-height: 1.25;
}
.page-head_title span {
  color: #231815;
}
.page-head_title.about {
  top: 25%;
  left: 40%;
}
@media screen and (min-width: 1260px), print {
  .page-head_title.about {
    top: 27%;
    left: 45%;
  }
}
.page-head_title.certification {
  top: 30%;
  left: 50%;
}
@media screen and (min-width: 1260px), print {
  .page-head_title.certification {
    top: 36%;
    left: 53%;
  }
}
.page-head_title.join {
  top: 40%;
  left: 47%;
}
@media screen and (min-width: 1260px), print {
  .page-head_title.join {
    top: 41%;
    left: 50%;
  }
}
.page-head_title.citizen {
  top: 40%;
  left: 52%;
}
@media screen and (min-width: 1260px), print {
  .page-head_title.citizen {
    top: 41%;
    left: 54%;
  }
}
.page-head_title.partner {
  top: 30%;
  left: 50%;
}
@media screen and (min-width: 1260px), print {
  .page-head_title.partner {
    top: 36%;
    left: 53%;
  }
}
.page-head_title.exclusive {
  left: 0;
  right: 0;
  margin: auto;
  font-size: clamp(1.625rem, 4.53125vw, 3.625rem);
  text-align: center;
}

/* ページタイトル */
.page-title {
  position: relative;
  width: 100%;
  margin: 70px auto 0;
  padding: 0 5%;
  color: #00993e;
  font-size: clamp(1.5rem, 3.28125vw, 2.625rem);
  font-weight: 700;
  line-height: 1.25;
}
.page-title span {
  color: #231815;
}
.page-title.merit {
  padding-left: 0;
}
.page-title.separator {
  margin: 2em auto 0;
}
.page-title::after {
  content: "";
  display: block;
  width: 2.15em;
  height: 2px;
  margin-top: 0.2em;
  margin-bottom: 1em;
  background-color: #b7d34a;
}
@media screen and (min-width: 768px) and (max-width: 1259px) {
  .page-title {
    margin: 100px auto 0;
  }
}
@media screen and (min-width: 1260px), print {
  .page-title {
    max-width: 1200px;
    margin: 146px auto 0;
    padding: 0 40px;
  }
  .page-title.separator {
    margin: 2em auto 0;
  }
  .page-title::after {
    margin-top: 0.15em;
    height: 3px;
  }
}

/*******************************************
  @CONTENTS
********************************************/
.container,
.container-wide {
  width: 100%;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (min-width: 880px) {
  .container,
  .container-wide {
    width: 75%;
    max-width: 900px;
    padding: 0 40px;
    border-right: 2px solid #cef726;
  }
}

@media screen and (min-width: 880px) {
  .container-wide {
    max-width: 1020px;
  }
}

.bar::before {
  content: "";
  display: block;
  width: 20%;
  height: 2px;
  margin: 2.5em auto 3em;
  background-color: #b7d34a;
}
@media screen and (min-width: 880px), print {
  .bar::before {
    width: 90px;
    height: 3px;
  }
}

.line::before {
  content: "";
  display: block;
  width: 100%;
  margin: 2em auto;
  border-top: 1px solid #9e9e9e;
}
@media screen and (min-width: 880px) and (max-width: 1259px) {
  .line::before {
    margin: 2.5em auto;
  }
}
@media screen and (min-width: 1260px), print {
  .line::before {
    margin: 3em auto;
  }
}

.container p {
  margin: 0;
  padding: 0;
}
.container p + p {
  margin-top: 0;
}
.container_title {
  margin: 2em auto 0.4em;
  color: #00993e;
  font-size: clamp(1.375rem, 3.4090909091vw, 1.875rem);
  text-align: left;
  line-height: 1.4;
}
.container_title span {
  color: #231815;
}
.container_title span.tax {
  display: block;
  margin-left: -1em;
  margin-bottom: 0.25em;
  font-size: clamp(0.875rem, 2.2727272727vw, 1.25rem);
  font-weight: 500;
}
.container_title span.small {
  font-size: clamp(1rem, 2.5vw, 1.375rem);
  font-weight: 600;
}
.container_title.about, .container_title.merit, .container_title.branch, .container_title.notfound {
  margin: 3.5em auto 1em;
  color: #00993e;
  font-size: clamp(1.25rem, 3.4090909091vw, 1.875rem);
  text-align: center;
  letter-spacing: 0.35em;
}
.container_title .small {
  color: #231815;
  font-size: clamp(0.875rem, 2.2727272727vw, 1.25rem);
  font-weight: 400;
}
.container_title.single {
  margin: 0;
  margin-bottom: 1em;
  padding-bottom: 0.5em;
  border-bottom: 2px solid #b7d34a;
}
.container_title.merit {
  margin-bottom: 1em;
  color: #00993e;
  font-size: clamp(1.375rem, 3.6363636364vw, 2rem);
  letter-spacing: 0.075em;
}
.container_title.merit .small {
  font-size: clamp(1rem, 2.5vw, 1.375rem);
  font-weight: 600;
}
@media screen and (min-width: 880px), print {
  .container_title.merit {
    margin-bottom: 0;
  }
}
.container_title.notfound {
  margin: 0.2em auto 0.35em;
  color: #231815;
  letter-spacing: 0.1em;
}
.container_title:nth-of-type(1) {
  margin-top: 0em;
}
.container_title.branch {
  margin-top: 3em;
  letter-spacing: 0.15em;
}
.container_title.committee-sub {
  margin-top: 0.35em;
  font-size: clamp(1rem, 2.7272727273vw, 1.5rem);
}
.container_subtitle, .container_lead {
  margin: 1em auto 0.2em;
  color: #231815;
  font-size: clamp(1rem, 2.2727272727vw, 1.25rem);
  text-align: left;
  line-height: 1.4;
}
.container_lead {
  color: #00993e;
}
.container_lead span {
  font-size: clamp(0.875rem, 2.0454545455vw, 1.125rem);
  color: #231815;
}

.ol_number {
  margin-left: 0.75em;
  counter-reset: number;
}
.ol_number li {
  position: relative;
  padding-left: 1.5em;
}
.ol_number li.number {
  margin-left: 1em;
  padding-left: 0;
  list-style-type: decimal;
}
.ol_number li.maru::before {
  counter-increment: number;
  content: counter(number);
  position: absolute;
  top: 6px;
  left: 0;
  width: 1.25em;
  height: 1.25em;
  border: 1px solid #231815;
  border-radius: 50%;
  font-size: clamp(0.6875rem, 1.5909090909vw, 0.875rem);
  text-align: center;
  line-height: 1;
}
@media screen and (min-width: 880px), print {
  .ol_number li.maru::before {
    top: 7px;
    padding-left: 1px;
  }
}

.ul_dot {
  padding-left: 1.75em;
  list-style: disc;
}

.ul_maru li {
  position: relative;
  margin-bottom: 0.5em;
  padding-left: 0.2em;
}
.ul_maru li.maru::before {
  content: "●";
  position: absolute;
  left: -1em;
  top: 0.1em;
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  color: #00993e;
}
@media screen and (min-width: 880px), print {
  .ul_maru li {
    padding-left: 1.2em;
  }
  .ul_maru li.maru::before {
    left: 0;
    top: 0.2em;
  }
}

.image-center {
  margin: 2em auto 0;
  text-align: center;
}
.image-center.image-two {
  width: 100%;
  display: block;
}
.image-center.image-two img.certification-img {
  margin-bottom: 1em;
}
@media screen and (min-width: 880px), print {
  .image-center.image-two {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .image-center.image-two img.certification-img {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin-right: 1em;
  }
  .image-center.image-two img.certification-img:nth-child(2) {
    margin-right: 0;
  }
}

.image-center + .image-center {
  margin-top: 0;
}

/*******************************************
	@ボタン
********************************************/
.btn-box {
  width: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 1.5em;
  padding: 0;
}
@media screen and (min-width: 768px), print {
  .btn-box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-top: 2em;
    gap: 0 1em;
  }
  .btn-box.btn-left {
    padding-left: 1em;
    -webkit-box-pack: left;
        -ms-flex-pack: left;
            justify-content: left;
  }
}

/* トップページ：ボタン類 */
.btn {
  display: block;
  width: 21em;
  height: 3.2em;
  margin: 0;
  padding: 0;
  color: #008700;
  font-size: clamp(0.75rem, 1.8181818182vw, 1rem);
  font-weight: 500;
  text-align: center;
  line-height: 3.2em;
  border-radius: 1.6em;
  border: 1px solid #00a600;
  background-color: #fff;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-image: url(../img/btn_arrow.svg);
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 1.2em;
}
.btn.btn-w2 {
  width: 22em;
}
.btn.info {
  padding-top: 0.25em;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px), print {
  .btn {
    background-position: right 10px center;
    background-size: 1.2em;
  }
  .btn:hover {
    color: #fff;
    background-color: #00a600;
    background-image: url(../img/btn_arrow_over.svg);
  }
  .btn.info {
    padding-top: 0.35em;
  }
}

.btn-terms {
  width: 100%;
  margin: 0.2em 0 1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 0.5em;
  padding-bottom: 0em;
}
.btn-terms-link a {
  width: auto;
  padding: 0.15em 1em 0.3em !important;
  cursor: pointer;
  color: #006837;
  font-size: clamp(0.6875rem, 1.3636363636vw, 0.75rem);
  font-weight: 500;
  text-align: center;
  line-height: 1;
  border-radius: 3px;
  border: 1px solid #006837;
  background-color: #fff;
}
@media screen and (min-width: 768px), print {
  .btn-terms {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0.5em;
  }
  .btn-terms-link a:hover {
    color: #006837;
    background-color: #cef726;
  }
}

.pagetop {
  z-index: 10;
  height: 40px;
  width: 40px;
  position: fixed;
  right: 1.5%;
  bottom: 40px;
  background-color: #00a600;
  border: solid 2px #00a600;
  border-radius: 50%;
  display: none;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}

.pagetop-arrow {
  display: block;
  height: 12px;
  width: 12px;
  border-top: 4px solid #fff;
  border-right: 4px solid #fff;
  -webkit-transform: translateY(20%) rotate(-45deg);
          transform: translateY(20%) rotate(-45deg);
}

@media screen and (min-width: 768px), print {
  .pagetop {
    height: 65px;
    width: 65px;
    bottom: 70px;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
}
@media screen and (min-width: 768px) and (hover: hover) and (pointer: fine), print and (hover: hover) and (pointer: fine) {
  .pagetop:hover {
    background-color: #fff;
  }
  .pagetop:hover .pagetop-arrow {
    border-top: 4px solid #00a600;
    border-right: 4px solid #00a600;
  }
}
.pagination {
  width: 100%;
  height: 2em;
  margin: 2em auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
}
/*******************************************
	@サイドバー
********************************************/
.side {
  width: 100%;
  margin: 3em auto 0;
  padding: 0.5em 0 0;
  font-size: clamp(0.8125rem, 5vw, 0.9375rem);
}
.side-head {
  position: relative;
  padding-left: 1.75em;
  padding-bottom: 0.5em;
  color: #008700;
  font-size: clamp(0.875rem, 6.6666666667vw, 1.25rem);
  line-height: 1.5;
}
.side-head::before, .side-head::after {
  content: "";
  width: 12px;
  height: 12px;
  display: inline-block;
  position: absolute;
}
.side-head::after {
  /*top: .2em;
  left: .2em;
  width: 18px;
  height: 18px;
  background-color: rgba(255,90,95,.5);
  z-index: 2;*/
  top: calc(0.5em + 7px);
  left: 0.5em;
  background-color: #008700;
}
.side-head::before {
  /*top: .7em;
  left: .7em;
  width: 13px;
  height: 13px;
  background-color: rgba(255,90,95,.2);*/
  top: calc(0.5em + 14px);
  left: calc(0.5em + 5px);
  background-color: #cef726;
}
@media screen and (max-width: 879px) {
  .side-head {
    display: none;
  }
  .side-head.current ul.side-body {
    padding-left: 0;
  }
  .side-head.current ul.side-body li {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 1em;
    line-height: 1.5;
    font-size: clamp(0.8125rem, 5vw, 0.9375rem);
    font-weight: 600;
  }
  .side-head.current ul.side-body li::before {
    content: "";
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 2px #2558b0;
    border-right: solid 2px #2558b0;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
}
.side-subhead {
  padding: 0.5em 0;
  color: #231815;
  text-indent: 1em;
  font-size: clamp(0.875rem, 5.3333333333vw, 1rem);
  background-color: rgba(206, 247, 38, 0.5);
}
.side .side-body.link {
  margin-top: 0.75em;
  padding-left: 0.75em;
}
.side .side-body.link li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 0;
  margin-top: -0.25em;
  padding-left: 1em;
  line-height: 1.5;
}
.side .side-body.link li.bold {
  font-weight: 600;
}
.side .side-body.link li::before {
  content: "";
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px #2558b0;
  border-right: solid 2px #2558b0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
.side .side-body.normal {
  margin-top: 0.75em;
  padding-left: 0.75em;
}
.side .side-body.normal li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 1em;
  padding-left: 1.25em;
  line-height: 1.5;
}
.side .side-body.normal li.bold {
  font-weight: 600;
}
.side .side-body.normal li::before {
  content: "";
  width: 14px;
  height: 14px;
  background-color: #008700;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
.side .side-body.normal li::after {
  content: "";
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: absolute;
  top: 0;
  left: 3px;
  bottom: 0;
  margin: auto;
}
.side .side-body .cat-item {
  padding: 0 0 0 1em;
}
.side .side-body .cat-item:nth-child(1) {
  padding-top: 0.75em;
}
.side .side-body .cat-item .children {
  padding: 0;
  border-bottom: none;
}
.side .side-body .cat-item .children .cat-item {
  position: relative;
}
.side .side-body .cat-item .children > .cat-item + .cat-item {
  margin-top: 0;
  padding-top: 0.25em;
  border-top: none;
}
.side .side-body .cat-item + .cat-item {
  margin-top: 0.75em;
  padding-top: 0.75em;
  border-top: 1px dotted #008700;
}
@media screen and (min-width: 880px) {
  .side {
    width: 25%;
    max-width: 300px;
    min-width: 230px;
    margin: 0 0 0 -3px;
    padding: 0 0 0 0.25em;
    border-left: 2px solid #cef726;
  }
  .side-head {
    padding-bottom: 0.3em;
  }
  .side-head.current {
    padding-top: 0.5em;
    background-color: #f8f8f3;
    border-top: 4px solid #008700;
    border-bottom: 4px solid #008700;
  }
  .side-head.current ul.side-body {
    margin-left: -1.5em;
  }
  .side-head.current ul.side-body li {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 1em;
    line-height: 1.5;
    font-size: clamp(0.8125rem, 5vw, 0.9375rem);
    font-weight: 600;
  }
  .side-head.current ul.side-body li::before {
    content: "";
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 2px #2558b0;
    border-right: solid 2px #2558b0;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
  .side-head.current ul.side-body li:hover::before {
    border-top: solid 2px #f00;
    border-right: solid 2px #f00;
  }
  .side-subhead {
    margin-top: 2em;
    padding: 0.25em 0;
    color: #231815;
    text-indent: 1em;
    background-color: rgba(206, 247, 38, 0.4);
  }
  .side-subhead:nth-of-type(1) {
    margin-top: 0;
  }
  .side-subtitle {
    margin-top: 1.5em;
    margin-left: -0.5em;
    padding: 0.25em 0;
    color: #231815;
    text-indent: 1em;
    font-size: clamp(0.875rem, 4.6666666667vw, 0.875rem);
    background-color: rgba(221, 221, 221, 0.4);
  }
  .side-subtitle:nth-of-type(1) {
    margin-top: 0;
  }
  .side .side-body.normal {
    margin-top: 2em;
    padding-top: 1em;
    padding-left: 2em;
    border-top: 1px solid #008700;
    border-bottom: 1px solid #008700;
  }
  .side .side-body.normal li {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 1em;
    padding-left: 1.35em;
    line-height: 1.5;
  }
  .side .side-body.normal li.bold {
    font-weight: 600;
  }
  .side .side-body.normal li::before {
    content: "";
    width: 14px;
    height: 14px;
    background-color: #008700;
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
  .side .side-body.normal li::after {
    content: "";
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    position: absolute;
    top: 0;
    left: 3px;
    bottom: 0;
    margin: auto;
  }
  .side .side-body.normal li:hover::before {
    background-color: #f00;
  }
  .side .side-body.normal li:hover::after {
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
  }
  .side .side-body .cat-item {
    padding-left: 20px;
  }
  .side .side-body .cat-item .children {
    position: relative;
    padding: 0;
    letter-spacing: 0;
    border-bottom: none;
  }
  .side .side-body .cat-item .children > .cat-item + .cat-item {
    margin-top: 0;
    padding-top: 0.25em;
    border-top: none;
  }
  .side .side-body .cat-item + .cat-item {
    margin-top: 0.75em;
    padding-top: 0.75em;
    border-top: 1px dotted #008700;
  }
}

.training-menubox {
  display: none;
}
@media screen and (min-width: 880px) {
  .training-menubox {
    display: block;
    padding-bottom: 2em;
    padding-left: 0.5em;
    border-bottom: 4px solid #008700;
  }
}

.side-btns {
  width: 100%;
  height: auto;
  margin-top: 2em;
  padding-top: 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-top: 3px solid #008700;
}
.side-btns .disc {
  width: 80%;
  font-size: clamp(0.875rem, 4.6666666667vw, 0.875rem);
  margin-bottom: 0.5em;
  padding: 0.25em 1em;
  text-align: center;
  border-radius: 7px;
  border: 2px solid #6ec300;
  background-color: #fff;
}
.side-btns .disc a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: left;
      -ms-flex-pack: left;
          justify-content: left;
  color: #008700;
}
.side-btns .disc a span {
  display: block;
  width: 100%;
  margin-left: 1em;
  font-weight: 500;
  line-height: 2;
  text-align: left;
  background-image: url(../img/btn_arrow.svg);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: clamp(1rem, 6vw, 1.125rem);
}
.side-btns .disc img {
  width: 20%;
}
.side-btns .disc.subbox {
  width: 80%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 0;
  padding: 0;
  border: none;
}
.side-btns .disc.subbox a {
  width: 100%;
  margin-bottom: 0.5em;
  padding: 0.25em 1em;
  text-align: center;
  border-radius: 7px;
  border: 2px solid #6ec300;
  background-color: #fff;
}
.side-btns .disc.subbox a span {
  margin-left: 0.3em;
  line-height: 3;
}
@media screen and (min-width: 880px), print {
  .side-btns {
    margin-top: 2em;
    padding-top: 1em;
    padding-left: 20px;
    padding-bottom: 0;
    border-top: none;
  }
  .side-btns .disc {
    width: 100%;
    margin-bottom: 0.2em;
    padding: 0.25em 1em;
    background-image: url(../img/btn_arrow.svg);
    background-repeat: no-repeat;
    background-position: right 5% center;
    background-size: clamp(1rem, 6vw, 1.125rem);
    background-color: #fff;
    cursor: pointer;
  }
  .side-btns .disc:hover span {
    color: #fff;
  }
  .side-btns .disc a span {
    display: inline-block;
    margin: 0;
    margin-left: 0.5em;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0;
    background-image: none;
  }
  .side-btns .disc:hover {
    color: #fff;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    border: 2px solid #00a600;
    background-color: #00a600;
    background-image: url(../img/btn_arrow_over.svg);
  }
  .side-btns .disc.subbox {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 0;
    padding: 0;
    border: none;
    gap: 0.4em;
  }
  .side-btns .disc.subbox:hover {
    border: none;
    background-color: transparent;
    background-image: none;
  }
  .side-btns .disc.subbox a {
    width: 100%;
    margin-bottom: 0.2em;
    padding: 0.25em 1em;
    text-align: center;
    border: 2px solid #6ec300;
    background-color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    background-image: url(../img/btn_arrow.svg);
    background-repeat: no-repeat;
    background-position: right 5% center;
    background-size: clamp(1rem, 6vw, 1.125rem);
  }
  .side-btns .disc.subbox a span {
    display: inline-block;
    margin: 0;
    margin-left: 1em;
    color: #00a600;
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0;
    background-image: none;
  }
  .side-btns .disc.subbox a:hover {
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    border: 2px solid #00a600;
    background-color: #00a600;
    background-image: url(../img/btn_arrow_over.svg);
  }
  .side-btns .disc.subbox a:hover span {
    color: #fff;
  }
}

/*******************************************
	@TOP
********************************************/
.top .pankuzu {
  display: none;
}

main.index {
  width: 100%;
  margin: auto;
  padding: 0;
  display: block;
}
@media screen and (min-width: 880px), print {
  main.index {
    width: 100%;
    max-width: 100%;
    padding: 0;
  }
}

/* TOP-MV */
.top-mv {
  width: 100%;
  margin-bottom: 0;
  padding-bottom: 100px;
  background-color: #fff;
}
.top-mv .mv-box {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 253.3333333333%;
}
.top-mv .mv-title-catch {
  position: absolute;
  z-index: 1;
  top: 10.2%;
  left: 17.1%;
  font-size: clamp(14px, 1.82291vw, 35px);
  font-weight: 600;
  color: #fff;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  line-height: 2;
  letter-spacing: 0.3em;
}
.top-mv .mv-title-catch span.c-txt1 {
  margin-top: -1.32em;
  padding: 0;
  line-height: 0;
}
.top-mv .mv-title-catch span.c-txt2 {
  margin-top: -1em;
  padding: 0;
  line-height: 0;
}
.top-mv .mv-title-circle {
  position: absolute;
  width: 99.5%;
  height: auto;
  top: 0;
  left: -21.333333%;
}
.top-mv .mv-figs {
  position: absolute;
  width: 82.4%;
  height: auto;
  top: 21.5%;
  left: 6.67%;
}
.top-mv .mv-btns {
  position: absolute;
  width: 95%;
  height: auto;
  top: 59.5%;
  left: 2.5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.top-mv .mv-btns .disc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 49%;
  font-size: clamp(0.875rem, 1.40625vw, 1.125rem);
  margin-bottom: 2%;
  padding: 1em 0 0.8em;
  text-align: center;
  border-radius: 7px;
  border: 2px solid #6ec300;
  background-color: #fff;
}
.top-mv .mv-btns .disc a {
  width: 100%;
  display: block;
  color: #008700;
}
.top-mv .mv-btns .disc img {
  width: 60.3%;
}
.top-mv .mv-btns .disc span {
  display: block;
  margin: 5px auto 0;
  margin-left: -1.5em;
  font-size: clamp(12px, 1.09375vw, 21px);
  font-weight: 500;
  line-height: 2;
  background-image: url(../img/btn_arrow.svg);
  background-repeat: no-repeat;
  background-position: right 27px center;
  background-size: clamp(14px, 1.8vw, 22px);
}
.top-mv .mv-btns .disc.subbox {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 0;
  padding: 0;
  border: none;
}
.top-mv .mv-btns .disc.subbox a {
  width: 49%;
  padding: 0.2em 0 0.5em;
  border-radius: 7px;
  border: 2px solid #6ec300;
  background-color: #fff;
}
@media screen and (min-width: 768px), print {
  .top-mv {
    width: 100%;
    margin-bottom: 0;
    padding-bottom: 0;
  }
  .top-mv .mv-box {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 73%;
  }
  .top-mv .mv-title-catch {
    position: absolute;
    z-index: 1;
    top: 15.36%;
    left: 29.1%;
    font-size: clamp(14px, 1.82291vw, 35px);
    font-weight: 600;
    color: #fff;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    line-height: 2;
    letter-spacing: 0.25em;
  }
  .top-mv .mv-title-catch span.c-txt1 {
    margin-top: -1.275em;
    padding: 0;
    line-height: 0;
  }
  .top-mv .mv-title-catch span.c-txt2 {
    margin-top: -1em;
    padding: 0;
    line-height: 0;
  }
  .top-mv .mv-title-circle {
    position: absolute;
    width: 62.8%;
    height: auto;
    top: -7.1%;
    left: -7%;
  }
  .top-mv .mv-figs {
    position: absolute;
    width: 45.2%;
    height: auto;
    top: 28.6%;
    left: 22.1%;
  }
  .top-mv .mv-btns {
    position: absolute;
    width: 26.4%;
    height: auto;
    top: 17.3%;
    left: 70.3%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .top-mv .mv-btns .disc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    width: 100%;
    margin-right: 0;
    margin-bottom: 3%;
    background-image: url(../img/btn_arrow.svg);
    background-repeat: no-repeat;
    background-position: right 5% center;
    background-size: clamp(14px, 1.8vw, 22px);
    background-color: #fff;
    padding: 0.8em 1em;
    text-align: left;
    border-radius: 7px;
    border: 2px solid #6ec300;
    cursor: pointer;
  }
  .top-mv .mv-btns .disc:nth-child(2n) {
    margin-right: 0;
  }
  .top-mv .mv-btns .disc:hover span {
    color: #fff;
  }
  .top-mv .mv-btns .disc a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    color: #008700;
  }
  .top-mv .mv-btns .disc a img {
    width: 25%;
  }
  .top-mv .mv-btns .disc span {
    display: inline-block;
    margin: 0;
    margin-left: 0.5em;
    font-size: clamp(12px, 1.09375vw, 21px);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0;
    background-image: none;
  }
  .top-mv .mv-btns .disc:hover {
    color: #fff;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    border: 2px solid #00a600;
    background-color: #00a600;
    background-image: url(../img/btn_arrow_over.svg);
  }
  .top-mv .mv-btns .disc.subbox {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 0;
    padding: 0;
    border: none;
    gap: 0.4em;
  }
  .top-mv .mv-btns .disc.subbox:hover {
    border: none;
    background-color: transparent;
    background-image: none;
  }
  .top-mv .mv-btns .disc.subbox a {
    width: 49%;
    padding: 1.15em 0;
    border-radius: 7px;
    border: 2px solid #6ec300;
    background-color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    background-image: url(../img/btn_arrow.svg);
    background-repeat: no-repeat;
    background-position: right 10% center;
    background-size: clamp(14px, 1.8vw, 22px);
  }
  .top-mv .mv-btns .disc.subbox a span {
    display: inline-block;
    margin: 0;
    margin-left: 1em;
    color: #00a600;
    font-size: clamp(12px, 1.09375vw, 21px);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0;
    background-image: none;
  }
  .top-mv .mv-btns .disc.subbox a:hover {
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    border: 2px solid #00a600;
    background-color: #00a600;
    background-image: url(../img/btn_arrow_over.svg);
  }
  .top-mv .mv-btns .disc.subbox a:hover span {
    color: #fff;
  }
}

/* TOP-セクションタイトル*/
.top-sec-title {
  font-size: clamp(1rem, 2.5vw, 2rem);
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.2em;
}
.top-sec-title span {
  display: block;
  margin-bottom: 15px;
  font-size: clamp(0.6875rem, 1.25vw, 1rem);
  font-weight: 700;
  color: #00a600;
  letter-spacing: 0.05em;
}
.top-sec-title span.about {
  letter-spacing: 0.5em;
}

/* TOP-NEWS */
/* TOP-INFORMATION */
.top-news,
.top-info {
  position: relative;
  padding-top: 100px;
  background-color: #f9f9f4;
}
.top-news .fig1,
.top-info .fig1 {
  position: absolute;
  left: 46%;
  right: 54%;
  top: -6%;
  width: 18.5%;
}
.top-news .sec-info,
.top-info .sec-info {
  margin-top: -70px;
}
.top-news .news-box,
.top-news .info-box,
.top-info .news-box,
.top-info .info-box {
  position: relative;
  width: 100%;
  padding: 40px 0;
  border-top-left-radius: 30px;
  border-top-right-radius: 30px;
  background-color: #fff;
}
.top-news .news-box .fig2,
.top-news .info-box .fig2,
.top-info .news-box .fig2,
.top-info .info-box .fig2 {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: -8%;
  width: 22%;
}
.top-news .info-box,
.top-info .info-box {
  padding-top: 55px;
}
.top-news .info-box .btn-box,
.top-info .info-box .btn-box {
  margin-top: 2em;
}
.top-news .btn-box,
.top-info .btn-box {
  margin-top: 3em;
}
@media screen and (min-width: 768px), print {
  .top-news,
  .top-info {
    margin-top: 0;
    padding-top: 100px;
    padding-bottom: 0;
  }
  .top-news .fig1,
  .top-info .fig1 {
    left: 10%;
    right: 0;
    top: 40px;
    width: 8%;
    max-width: 138px;
    min-width: 90px;
  }
  .top-news .sec-info,
  .top-info .sec-info {
    margin-top: -40px;
  }
  .top-news .news-box,
  .top-news .info-box,
  .top-info .news-box,
  .top-info .info-box {
    position: relative;
    width: 100%;
    margin-top: 40px;
    margin-left: 17%;
    padding: 40px 0 40px 20%;
    border-top-left-radius: 60px;
    border-bottom-left-radius: 60px;
  }
  .top-news .news-box .fig2,
  .top-news .info-box .fig2,
  .top-info .news-box .fig2,
  .top-info .info-box .fig2 {
    left: -70%;
    right: 0;
    top: 65px;
    width: 11%;
    max-width: 140px;
    min-width: 90px;
  }
  .top-news .info-box,
  .top-info .info-box {
    position: relative;
    margin-top: 40px;
    margin-left: 0;
    padding: 110px 0 60px;
    border-top-left-radius: 60px;
    border-top-right-radius: 60px;
    border-bottom-left-radius: 0;
    background-color: #fff;
  }
  .top-news .info-box .pc-info-box,
  .top-info .info-box .pc-info-box {
    position: relative;
    margin-left: 17%;
    padding: 40px 0 40px 20%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (min-width: 768px) and (max-width: 1020px) {
  .top-news .news-box,
  .top-news .info-box,
  .top-info .news-box,
  .top-info .info-box {
    margin-left: 0;
    padding: 40px 0 40px 20%;
  }
  .top-news .info-box .fig2,
  .top-info .info-box .fig2 {
    left: -13%;
    right: 0;
    top: 65px;
    width: 11%;
    max-width: 140px;
    min-width: 90px;
    margin: 0;
  }
  .top-news .info-box .sec-title,
  .top-info .info-box .sec-title {
    margin-left: -18%;
  }
  .top-news .info-box .pc-info-box,
  .top-info .info-box .pc-info-box {
    margin-left: 0;
    padding: 40px 0;
  }
}

.news-list,
.info-list {
  width: 100%;
  padding: 0.5em 1em 0;
  letter-spacing: 0.05em;
  /*&-date{
  	display:flex;
  	align-items: center;
  	font-size:clamp(12px, 2vw, 14px);
  	font-weight:500;
  	color:#333;
  	letter-spacing: 0.02em;*/
  /*.catbox{
  	display:block;
  	width:10em;
  	margin-left:1em;
  	padding:.2em 0;
  	cursor: pointer;
  	font-size:clamp(12px, 2vw, 14px);
  	font-weight:500;
  	text-align: center;
  	line-height: 1;
  	border-radius:4px;
  	border:1px solid #333;
  	a{
  		color:#333;
  	}
  	&:hover{
  		a{
  			color:#fff;
  		}
  		background-color:#333;
  	}
  }*/
  /*.new{
  		width:3em;
  		margin-left:1em;
  		padding:.175em 0;
  		font-size:fsclamp(10, 12);
  		font-weight:700;
  		color:#fff;
  		text-align: center;
  		text-transform: uppercase;
  		line-height: 1;
  		border-radius:4px;
  		background-color:#f00;
  	}
  }*/
}
.news-list a,
.info-list a {
  padding-bottom: 0;
  color: #04c;
}
.news-list a:hover,
.info-list a:hover {
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  color: #f00;
  border-bottom: 1px solid #f00;
}
@media screen and (max-width: 600px) {
  .news-list-title, .news-list-body,
  .info-list-title,
  .info-list-body {
    line-height: 1.5;
  }
}
.news-list-title,
.info-list-title {
  margin-top: 0.25em;
  margin-bottom: 1em;
  font-size: clamp(0.875rem, 1.5625vw, 1.25rem);
}
.news-list-body,
.info-list-body {
  font-size: clamp(0.875rem, 1.25vw, 1rem);
}

@media screen and (min-width: 768px) and (max-width: 1020px) {
  .news-list,
  .info-list {
    width: 80%;
  }
  .news-list-title,
  .info-list-title {
    margin-top: 0.2em;
    margin-bottom: 0;
    font-size: clamp(1rem, 1.5625vw, 1.25rem);
  }
  .news-list-body,
  .info-list-body {
    margin-bottom: 2em;
  }
}
@media screen and (min-width: 1021px) {
  .news-list {
    width: 63%;
  }
  .news-list-title {
    margin-top: 0.2em;
    margin-bottom: 0em;
  }
  .info-list {
    width: 80%;
  }
  .info-list-title {
    margin-top: 0.2em;
    margin-bottom: 0em;
  }
}
.news-list + .news-list,
.info-list + .info-list {
  margin-top: 2em;
}

.info-list-pager {
  margin: 3em auto 1em;
}
.info-list-pager ul.page-numbers {
  border: none;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.info-list-pager ul.page-numbers:hover {
  background: none;
}
.info-list-pager ul.page-numbers li span.page-numbers,
.info-list-pager ul.page-numbers li a.page-numbers {
  font-size: 14px;
  height: 36px;
  line-height: 36px;
  margin: 6px;
  min-width: 36px;
  padding: 0;
  position: relative;
  text-align: center;
  text-decoration: none;
  -webkit-transition: color 0.25s, background-color 0.25s;
  transition: color 0.25s, background-color 0.25s;
  border-radius: 50%;
  margin: 4px;
  color: var(--color_main);
  border: solid 1px var(--color_main);
}
.info-list-pager ul.page-numbers li span.page-numbers.current, .info-list-pager ul.page-numbers li span.page-numbers:hover,
.info-list-pager ul.page-numbers li a.page-numbers.current,
.info-list-pager ul.page-numbers li a.page-numbers:hover {
  background-color: var(--color_main);
  color: #fff;
}

/* TOP-ABOUT */
.top-about {
  position: relative;
  z-index: 10;
  padding-bottom: 180px;
  background-color: #fff;
}
.top-about .about-container {
  position: relative;
  padding-top: 55px;
  padding-bottom: 90px;
  border-top-left-radius: 40px;
  border-top-right-radius: 40px;
  background-color: #f9f9f4;
}
.top-about .about-container .fig {
  position: absolute;
  width: 84%;
  left: 0;
  right: 0;
  margin: auto;
  bottom: -85px;
}
.top-about .about-container-inner {
  padding: 0 5%;
}
.top-about .about-container-inner .about-head-box {
  position: relative;
}
.top-about .about-container-inner .about-head-box .box-border {
  width: 100%;
  height: auto;
  padding: 0.25em 1.25em;
}
.top-about .about-container-inner .about-head-box .box-border .about-head {
  padding: 1.25em 0.5em;
  font-size: clamp(0.875rem, 2.734375vw, 2.1875rem);
  color: #008700;
  text-align: center;
  line-height: 2;
  letter-spacing: 0.3em;
  border-radius: 15px;
  background-color: #fff;
}
.top-about .about-container-inner .about-head-box .box-border-leftTop {
  position: absolute;
  border-top: 3px solid #a8dc00;
  border-left: 3px solid #a8dc00;
  top: -1px;
  left: -1px;
  width: 10px;
  height: 20px;
}
.top-about .about-container-inner .about-head-box .box-border-rightBottom {
  position: absolute;
  border-right: 3px solid #a8dc00;
  border-bottom: 3px solid #a8dc00;
  right: -1px;
  bottom: -1px;
  width: 10px;
  height: 20px;
}
.top-about .about-container-inner .about-body {
  margin: 40px 0 0;
  font-size: clamp(0.75rem, 1.25vw, 1rem);
  line-height: 2.2;
}
@media screen and (min-width: 768px), print {
  .top-about {
    margin-bottom: 0;
    padding-bottom: 50px;
    background-color: #fff;
  }
  .top-about .about-container {
    position: relative;
    padding-top: 110px;
    padding-bottom: 120px;
    border-top-left-radius: 60px;
    border-top-right-radius: 60px;
    background-color: #f9f9f4;
  }
  .top-about .about-container .fig {
    display: none;
  }
  .top-about .about-container-inner {
    width: 72%;
    max-width: 720px;
    margin: auto;
    padding: 0 40px;
  }
  .top-about .about-container-inner .about-head-box {
    margin-top: 50px;
  }
  .top-about .about-container-inner .about-head-box .box-border {
    padding: 0.25em 2em;
  }
  .top-about .about-container-inner .about-head-box .box-border .about-head {
    padding: 1.25em 0.5em;
    letter-spacing: 0.15em;
  }
  .top-about .about-container-inner .about-head-box .box-border-leftTop {
    border-top: 4px solid #a8dc00;
    border-left: 4px solid #a8dc00;
    width: 20px;
    height: 40px;
  }
  .top-about .about-container-inner .about-head-box .box-border-rightBottom {
    border-right: 4px solid #a8dc00;
    border-bottom: 4px solid #a8dc00;
    width: 20px;
    height: 40px;
  }
  .top-about .about-container-inner .about-body {
    margin: 60px 30px 0;
    line-height: 2.5;
    letter-spacing: 0.075em;
  }
}

/* TOP-ACCESS */
.top-access .fig {
  display: none;
}
.top-access .access-container {
  padding: 80px 5% 0;
  border-top: 1px solid #dfe4e5;
}
.top-access .access-content {
  margin-top: 40px;
  font-size: clamp(0.75rem, 1.25vw, 1rem);
  letter-spacing: 0;
}
.top-access .access-content .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 0.25em;
  font-size: clamp(1.125rem, 2.5vw, 2rem);
  font-weight: 500;
  letter-spacing: 0.075em;
}
.top-access .access-content .tel span {
  display: block;
  width: 2.4em;
  height: 2.4em;
  margin-right: 0.7em;
  font-size: clamp(0.625rem, 1.25vw, 1rem);
  font-weight: 600;
  color: #fff;
  text-transform: uppercase;
  text-align: center;
  line-height: 2.4em;
  letter-spacing: 0;
  border-radius: 50%;
  background-color: #00a600;
}
.top-access .access-content .mt {
  margin-top: 1em;
}
.top-access .access-map {
  position: relative;
  width: 100%;
  margin-top: 60px;
  aspect-ratio: 16/9;
  overflow: hidden;
}
.top-access .access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px), print {
  .top-access {
    background-color: #f9f9f4;
    position: relative;
  }
  .top-access .fig {
    position: absolute;
    z-index: 10;
    display: block;
    width: 45%;
    min-width: 550px;
    max-width: 833px;
    top: -9%;
    left: 0;
    right: 0;
    margin: auto;
  }
  .top-access .access-container {
    width: 100%;
    padding: 15% 40px 90px;
    border-top: none;
    border-top-left-radius: 60px;
    border-top-right-radius: 60px;
    background-color: #fff;
  }
  .top-access .access-box {
    max-width: 1000px;
    margin: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .top-access .top-sec-title {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin-top: 35px;
    border-right: 1px solid #dfe4e5;
  }
  .top-access .access-content {
    -webkit-box-flex: 3;
        -ms-flex: 3;
            flex: 3;
    padding-top: 3em;
    padding-left: 3em;
    padding-bottom: 2em;
  }
  .top-access .access-content .tel {
    margin-top: 0.1em;
  }
  .top-access .access-content .mt {
    margin-top: 0.5em;
  }
  .top-access .access-map {
    margin-top: 0;
    aspect-ratio: 16/5;
  }
}

/*******************************************
	@ABOUT 大阪社会福祉士会とは
********************************************/
/* 大阪社会福祉士会とは */
.about .container {
  margin: 0 auto;
}
.about-box {
  margin: 2em auto;
  padding: 1em 1em 1em 2em;
  background-color: #f8f8f3;
}
@media screen and (min-width: 880px), print {
  .about-box {
    padding: 2em 2.5em;
  }
}

/* PDFリンク部 */
.about-release {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1em;
  margin: 1.5em auto;
}
.about-release.description {
  margin-bottom: 2em;
}
.about-release li {
  width: calc((100% - 1em) / 2);
}
.about-release li a {
  display: block;
  width: 100%;
  padding-top: 1em;
  padding-bottom: 1em;
  color: inherit;
  text-align: center;
  background-color: #f8f8f3;
}
.about-release li img {
  width: 40%;
  height: auto;
}
@media screen and (min-width: 768px), print {
  .about-release li {
    width: calc((100% - 3em) / 4);
  }
  .about-release li a:hover {
    color: #fff;
    background-color: #231815;
  }
  .about-release.description {
    margin-bottom: 3em;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .about-release.description li {
    width: calc((75% - 2em) / 3);
  }
}

.about-organization {
  max-width: 100%;
  height: auto;
}

.about-branch {
  margin: 1.5em auto 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2em;
}
.about-branch-image {
  max-width: 100%;
  height: auto;
}
.about-branch-text {
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  line-height: 1.5;
  border-bottom: 2px solid #1e9d3a;
}
.about-branch-text th {
  padding: 0.4em 0.75em;
  font-weight: 600;
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
  border-bottom: 1px solid #1e9d3a;
  background-color: #f8f8f3;
}
.about-branch-text th.head, .about-branch-text th.area {
  padding: 0.3em 0;
  color: #fff;
  text-align: center;
  background-color: #1e9d3a;
}
.about-branch-text th.head {
  border-right: 1px solid #fff;
}
.about-branch-text th.area {
  letter-spacing: 1em;
  border-right: none;
}
.about-branch-text th a {
  color: #17813b;
}
.about-branch-text td {
  padding: 0.4em 0.75em 0.4em 1em;
  text-align: left;
  border-bottom: 1px solid #1e9d3a;
}
@media screen and (min-width: 768px), print {
  .about-branch {
    margin: 2em auto 2.5em;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .about-branch-image {
    width: 100%;
  }
  .about-branch a:hover {
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    color: #f00;
    border-bottom: solid 1px #f00;
  }
}

/*******************************************
	@CERTIFICATION　　　資格取得サポート体制
********************************************/
/* 資格取得サポート */
.certification .container {
  margin: 0 auto;
}
.certification .container.certification-lesson {
  position: relative;
  margin: 1em auto;
}
@media screen and (min-width: 880px), print {
  .certification .container {
    margin: 0 auto;
  }
  .certification .container.certification-lesson {
    margin: 2em auto;
  }
}

@media screen and (min-width: 768px), print {
  .certification .container .btn-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.certification-box {
  position: relative;
  margin: 1em auto;
  padding: 0 0 0 1em;
}
.certification-box .certification-fig_b {
  position: absolute;
  top: -1em;
  right: 1.7em;
  width: 17%;
}
@media screen and (min-width: 880px), print {
  .certification-box {
    padding: 0 0 0 1em;
  }
  .certification-box ul:nth-child(1) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .certification-box ul:nth-child(1) .maru {
    width: 17em;
    margin-right: 5em;
  }
  .certification-box .certification-fig_b {
    position: absolute;
    top: -2em;
    right: 4em;
    width: 8%;
  }
}

img.certification-img {
  width: 100%;
  height: auto;
}

.lesson_txt-img {
  position: relative;
  margin-top: 0em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1em;
}
.lesson_txt-img img {
  margin-top: 1em;
}
.lesson_txt-img .lesson-txt {
  -webkit-box-flex: 5;
      -ms-flex: 5;
          flex: 5;
}
.lesson_txt-img .lesson-icon3 {
  -webkit-box-flex: 2;
      -ms-flex: 2;
          flex: 2;
}
@media screen and (min-width: 880px), print {
  .lesson_txt-img {
    margin-top: 1em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 1em;
  }
  .lesson_txt-img .lesson-txt {
    -webkit-box-flex: 5;
        -ms-flex: 5;
            flex: 5;
  }
  .lesson_txt-img .lesson-icon3 {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin-top: -2.5em;
  }
}

/*******************************************
	@JOIN　入会希望の方へ
********************************************/
/* 入会希望の方へ */
.join .container {
  margin: 0 auto;
}
.join .container.merit {
  margin: 1em auto;
}
.join .container_subtitle {
  margin: 0 auto;
  margin-bottom: 0.75em;
  padding: 0;
  font-size: clamp(1rem, 2.5vw, 1.375rem);
  text-align: center;
}
@media screen and (min-width: 880px), print {
  .join .container {
    margin: 0 auto;
  }
  .join .container.merit {
    margin: 2em auto;
    border-right: none;
  }
}

/* 入会BG-AREA */
.join-box {
  margin-top: 1em;
  margin-bottom: 2em;
  padding: 1em 2em;
  text-align: center;
  font-weight: 500;
  font-size: clamp(1rem, 2.3863636364vw, 1.3125rem);
  line-height: 1.5;
}
.join-box.mb {
  margin-bottom: 1em;
}

/* 入会方法 */
.join-method {
  width: 20em;
  margin: 2em auto 0;
}
@media screen and (min-width: 880px), print {
  .join-method {
    width: 30em;
  }
}

/* メリット */
.merit-box {
  padding-top: 1.5em;
}
.merit-box_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1em;
}
.merit-box_item .text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.merit-box_item .container_title {
  margin-top: -1em;
}
.merit-box_item .icon {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 50%;
  margin: auto;
}
@media screen and (min-width: 880px), print {
  .merit-box {
    padding: 2em 0.5em;
  }
  .merit-box_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .merit-box_item .text {
    -webkit-box-flex: 3;
        -ms-flex: 3;
            flex: 3;
  }
  .merit-box_item .container_title {
    margin-top: 0;
  }
  .merit-box_item .icon {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: auto;
    margin: 0 0 0 auto;
  }
}

/*******************************************
	@CITIZEN 府民の方へ
********************************************/
/* 府民の方へ */
.citizen .container {
  margin: 0 auto;
}
@media screen and (min-width: 880px), print {
  .citizen .container {
    margin: 0 auto;
  }
}

/* 相談センターぱあとなあ */
.partner .container {
  margin: 0 auto;
}
.partner .container_subtitle {
  margin: 0 auto;
  margin-bottom: 0.75em;
  padding: 0;
  color: #00993e;
  font-size: clamp(1rem, 2.5vw, 1.375rem);
  text-align: center;
}
@media screen and (min-width: 880px), print {
  .partner .container {
    margin: 0 auto;
  }
}

/* 会員の方へページのBG-AREA */
.partner-box {
  width: 100%;
  margin: auto;
  margin-top: 2em;
  margin-bottom: 2em;
  padding: 2em 2em;
  background-color: #f8f8f3;
}
.partner-box ul {
  width: 20em;
  margin: auto;
  padding-left: 2em;
}
.partner-box li {
  font-weight: 500;
}
.partner-box.flow {
  position: relative;
  margin: 2em auto 0.4em;
  padding: 1.2em 1em;
  color: #231815;
}
.partner-box.flow .container_title {
  margin: 0 auto 0.25em;
  margin-right: 1em;
  font-size: clamp(1.0625rem, 2.7272727273vw, 1.5rem);
  text-align: center;
}
.partner-box.flow .sublead {
  margin-right: 3em;
  margin-bottom: 0.5em;
  font-size: clamp(0.9375rem, 2.2727272727vw, 1.25rem);
  font-weight: 500;
  text-align: center;
  line-height: 1.65;
}
.partner-box.flow .ul_maru li.maru {
  white-space: nowrap;
  width: 15.5em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 0.2em;
  font-weight: 700;
}
.partner-box.flow .ul_maru li.maru span {
  margin-left: 2px;
  font-size: clamp(1.25rem, 2.9545454545vw, 1.625rem);
  font-weight: 700;
  line-height: 1;
}
.partner-box.flow .partner-fig_c {
  position: absolute;
  top: -1.5em;
  right: -0.5em;
  width: 12%;
}
@media screen and (min-width: 880px), print {
  .partner-box {
    width: 80%;
  }
  .partner-box ul {
    padding-left: 0;
  }
  .partner-box.flow .container_title {
    margin-right: 0;
  }
  .partner-box.flow .sublead {
    margin-right: 0;
  }
  .partner-box.flow .ul_maru li.maru {
    width: 20em;
    margin-bottom: 0.4em;
  }
  .partner-box.flow .ul_maru li.maru span {
    margin-left: 5px;
  }
  .partner-box.flow .ul_maru li.maru::before {
    top: 0.3em;
  }
  .partner-box.flow .partner-fig_c {
    position: absolute;
    top: -1.5em;
    right: 1.5em;
    width: 10%;
  }
}

@media screen and (min-width: 880px), print {
  .partner .flow-p {
    width: 80%;
    margin: auto;
  }
}
/* 利用料金 */
.partner-cost {
  width: 90%;
  margin: 0 auto;
  padding: 0;
  font-size: clamp(0.875rem, 2.0454545455vw, 1.125rem);
  line-height: 1.65;
}
.partner-cost tr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: left;
  margin-bottom: 1em;
}
.partner-cost .head {
  font-size: clamp(1rem, 2.5vw, 1.375rem);
  color: #00993e;
  font-weight: 600;
}
@media screen and (min-width: 880px), print {
  .partner-cost {
    width: 80%;
  }
  .partner-cost tr {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .partner-cost .head {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    line-height: 1.2;
  }
  .partner-cost .body {
    -webkit-box-flex: 4;
        -ms-flex: 4;
            flex: 4;
    margin-left: 1em;
  }
}

/* 各支部トピックスなどのBOX */
/*
.seminar-box{
	margin-top:1em;
	margin-bottom:2em;
	padding:1em 2em;
	background-color: #f8f8f3;
}
*/
/* 研修会案内テーブル */
table.citizen-seminar-table {
  width: 100%;
  height: auto;
  margin-bottom: 20px;
  font-size: clamp(0.6875rem, 1.3636363636vw, 0.75rem);
  border-top: 1px solid #aaa;
  border-left: 1px solid #aaa;
}
table.citizen-seminar-table tr {
  border-bottom: 1px solid #aaa;
}
table.citizen-seminar-table th {
  width: 13.75%;
  font-size: clamp(0.75rem, 1.4772727273vw, 0.8125rem);
  font-weight: bold;
  text-align: center;
  border-right: 1px solid #aaa;
  background-color: #ddd;
}
table.citizen-seminar-table th.th4 {
  width: 45%;
}
table.citizen-seminar-table td {
  width: 13.75% !important;
  padding: 0.5em 0.15em;
  text-align: center;
  vertical-align: middle;
  border-right: 1px solid #aaa;
}

/*******************************************
	@EXCLUSIVE　会員専用
********************************************/
/* 会員専用 */
.exclusive main {
  margin-top: 3em;
}
@media screen and (min-width: 880px), print {
  .exclusive main {
    margin-top: 5em;
  }
}

.exclusive .container {
  margin: auto;
}
/* 会員の方へページのBG-AREA */
.exclusive-box {
  margin-top: 1em;
  margin-bottom: 2em;
  padding: 1em 2em;
  background-color: #f8f8f3;
}
.exclusive-box.order {
  margin-top: 2em;
  margin-bottom: 3em;
  padding: 1em 2em 2em;
}
.exclusive-box .container_lead {
  margin-bottom: 1em;
  text-align: center;
}

/* お知らせ・求人情報 */
.exclusive-info {
  margin-top: 1em;
  margin-bottom: 2em;
  padding: 1em;
  background-color: #f8f8f3;
  /*&-date{
  	display:flex;
  	align-items: center;
  	font-size:fsclamp(14, 16);
  	font-weight:500;
  	color:#231815;
  	letter-spacing: 0.02em;
  	.new{
  		width:3em;
  		margin-right:.5em;
  		padding:.175em 0;
  		font-size:fsclamp(11, 13);
  		font-weight:700;
  		color:#fff;
  		text-align: center;
  		text-transform: uppercase;
  		line-height: 1;
  		border-radius:4px;
  		background-color:#f00;
  	}
  }*/
}
@media screen and (min-width: 880px), print {
  .exclusive-info {
    padding: 1em 2em;
  }
}
.exclusive-info-title {
  padding-top: 0.3em;
  padding-bottom: 0.3em;
  font-size: clamp(1.125rem, 2.5vw, 1.375rem);
  font-weight: 600;
}
.exclusive-info-body {
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
}

/*******************************************
	@BRANCH　支部情報
********************************************/
.branch-info-box {
  margin-top: 1em;
  margin-bottom: 2em;
}

/* 新着情報一覧 ・・・ 研修情報、委員会情報と同じ*/
.branch {
  /*&-date{
  	display:flex;
  	align-items: center;
  	font-size:fsclamp(14, 16);
  	font-weight:500;
  	color:#231815;
  	letter-spacing: 0.02em;
  	.new{
  		width:3em;
  		margin-right:.5em;
  		padding:.175em 0;
  		font-size:fsclamp(11, 13);
  		font-weight:700;
  		color:#fff;
  		text-align: center;
  		text-transform: uppercase;
  		line-height: 1;
  		border-radius:4px;
  		background-color:#f00;
  	}
  }*/
}
.branch-list {
  position: relative;
  width: 100%;
  padding: 2em 5px;
  background-color: #fff;
  border-bottom: 1px solid #9e9e9f;
}
.branch-list:nth-of-type(1) {
  border-top: 1px solid #9e9e9f;
}
.branch-cat {
  position: absolute;
  left: 13em;
  display: block;
  width: auto;
  padding: 0.4em 1em;
  /*cursor: pointer;*/
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  font-weight: 500;
  color: #006837 !important;
  text-align: center;
  line-height: 1;
  border-radius: 10px;
  background-color: #cef726;
  /*&:hover{
  	color:#fff!important;
  	background-color:#231815;
  }*/
}
.branch-content {
  padding-left: 10px;
  padding-right: 10px;
}
.branch-content a {
  color: #231815;
}
@media screen and (min-width: 880px), print {
  .branch-content a:hover {
    color: #c00;
    /*color:#006837;*/
    /*text-decoration: underline 1px;*/
  }
}
.branch-title {
  padding-top: 0.3em;
  padding-bottom: 0.3em;
  font-size: clamp(1.125rem, 2.5vw, 1.375rem);
  font-weight: 600;
}
.branch-body {
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
}
/* 各支部トピックスなどのBOX */
.branch-box {
  margin-top: 1em;
  margin-bottom: 2em;
  padding: 1.5em 2em 0.5em;
  background-color: #f8f8f3;
  /*&.w-over{//北河内用
  	width:100%;
  }
  @media screen and (min-width:880px), print {
  	&.w-over{
  		width:100%;
  		max-width:736px;
  	}
  }*/
}

/*******************************************
	@TRAINING　　　研修情報
********************************************/
/* 研修情報 */
.training-box {
  margin-top: 1em;
  margin-bottom: 2em;
}

/* 研修情報 ・・・ 委員会情報、新着情報一覧と同じ */
.training-list {
  position: relative;
  width: 100%;
  padding: 2em 5px;
  background-color: #fff;
  border-bottom: 1px solid #9e9e9f;
}
.training-list:nth-of-type(1) {
  border-top: 1px solid #9e9e9f;
}
.training-date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(0.875rem, 1.25vw, 1rem);
  font-weight: 500;
  color: #231815;
  letter-spacing: 0.02em;
}
.training-date .new {
  width: 3em;
  margin-right: 0.5em;
  padding: 0.175em 0;
  font-size: clamp(0.6875rem, 1.015625vw, 0.8125rem);
  font-weight: 700;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  line-height: 1;
  border-radius: 4px;
  background-color: #f00;
}
.training-cat {
  position: absolute;
  left: 14em;
  display: block;
  width: 8em;
  padding: 0.2em 0;
  cursor: pointer;
  font-size: clamp(0.75rem, 1.09375vw, 0.875rem);
  font-weight: 500;
  color: #006837 !important;
  text-align: center;
  line-height: 1;
  border-radius: 10px;
  background-color: #cef726;
}
.training-cat:hover {
  color: #fff !important;
  background-color: #231815;
}
.training-content {
  padding-left: 10px;
  padding-right: 10px;
}
.training-content a {
  color: #231815;
}
@media screen and (min-width: 880px), print {
  .training-content a:hover {
    color: #006837;
    -webkit-text-decoration: underline 2px;
            text-decoration: underline 2px;
  }
}
.training-title {
  padding-top: 0.3em;
  padding-bottom: 0.3em;
  font-size: clamp(1.125rem, 1.71875vw, 1.375rem);
  font-weight: 600;
}
.training-body {
  font-size: clamp(0.875rem, 1.25vw, 1rem);
}
.training-details {
  width: 100%;
  margin-top: 2em;
}
.training-details-title {
  padding: 0.75em 0.5em;
  font-size: clamp(1.125rem, 1.71875vw, 1.375rem);
  font-weight: 600;
  color: #00993e;
  border-top: 2px solid #00a600;
  border-bottom: 2px solid #00a600;
}
.training-details-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(1rem, 1.40625vw, 1.125rem);
}
.training-details-box:nth-of-type(1) {
  border-top: none;
}
.training-details-box .head {
  width: 100%;
  font-weight: 400;
  padding: 0.15em 0.5em;
  background-color: rgba(204, 204, 204, 0.2);
}
.training-details-box .head span {
  margin-left: 0.5em;
  font-size: clamp(0.8125rem, 1.171875vw, 0.9375rem);
}
.training-details-box .body {
  width: 100%;
  padding: 0.25em 0.5em 1.25em;
}
.training-details-box .body.btns {
  margin: 0.5em;
}
.training-details-box .body.btns a.btn {
  margin: auto;
}
@media screen and (min-width: 880px), print {
  .training-details {
    margin: auto;
    margin-bottom: 1.5em;
    padding: 0;
  }
  .training-details .head {
    padding: 0.25em 0.5em;
  }
  .training-details .body {
    padding: 0.25em 1em 1.5em 1.5em;
  }
  .training-details .body.btns {
    margin: 0.5em;
  }
  .training-details .body.btns a.btn {
    margin: auto;
  }
}

.training-related {
  margin-top: 4em;
}
.training-related-title {
  padding: 0.75em 0.5em;
  font-size: clamp(1.125rem, 1.71875vw, 1.375rem);
  font-weight: 600;
  color: #00993e;
  border-top: 2px solid #00a600;
  border-bottom: 2px solid #00a600;
}
.training-related-box {
  width: 100%;
  margin-top: 1em;
  margin-bottom: 2em;
}
.blogcard {
  width: 100%;
  margin: auto;
  line-height: 1;
  word-wrap: break-word;
  border: 1px solid #ccc;
  border-radius: 5px;
  background-color: #fff;
}
.blogcard a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 25px;
  opacity: 1;
  color: #231815;
  line-height: 1.5;
  text-align: left;
  text-decoration: none;
}
.blogcard_thumbnail {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 100%;
  height: auto;
  margin-bottom: 1em;
  border: 1px solid rgba(204, 204, 204, 0.9);
}
.blogcard_content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.blogcard_title {
  font-size: clamp(1rem, 1.40625vw, 1.125rem);
  font-weight: 600;
  text-align: center;
}
.blogcard_excerpt {
  margin: 0.5em 0 0.75em;
  font-size: clamp(0.875rem, 1.25vw, 1rem);
}
.blogcard_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.35em;
  font-size: clamp(0.75rem, 1.09375vw, 0.875rem);
}
.blogcard_link .favicon {
  width: 8%;
  max-width: 24px;
}
@media screen and (min-width: 768px), print {
  .blogcard {
    width: 90%;
  }
  .blogcard:hover {
    border: 1px solid #008700;
  }
  .blogcard a {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    padding: 15px 20px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .blogcard a:hover {
    opacity: 0.6;
    color: #f00;
  }
  .blogcard_thumbnail {
    width: 24%;
    max-width: 180px;
    margin-bottom: 0;
    margin-right: 20px;
  }
  .blogcard_content {
    -webkit-box-flex: 3;
        -ms-flex: 3;
            flex: 3;
  }
  .blogcard_title {
    text-align: left;
  }
  .blogcard_excerpt {
    margin: 0.35em 0 0.75em;
  }
  .blogcard_link .favicon {
    width: 5%;
    max-width: 24px;
  }
}

/*******************************************
	@COMMITTEE　委員会情報
********************************************/
.committee-box {
  margin-top: 1em;
  margin-bottom: 2em;
}

/* 委員会情報 ・・・ 研修情報、新着情報一覧と同じ*/
.committee-list {
  position: relative;
  width: 100%;
  padding: 2em 5px;
  background-color: #fff;
  border-bottom: 1px solid #9e9e9f;
}
.committee-list:nth-of-type(1) {
  border-top: 1px solid #9e9e9f;
}
.committee-date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
  font-weight: 500;
  color: #231815;
  letter-spacing: 0.02em;
}
.committee-date .new {
  width: 3em;
  margin-right: 0.5em;
  padding: 0.175em 0;
  font-size: clamp(0.6875rem, 1.4772727273vw, 0.8125rem);
  font-weight: 700;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  line-height: 1;
  border-radius: 4px;
  background-color: #f00;
}
.committee-cat {
  position: absolute;
  left: 14em;
  display: block;
  width: 8em;
  padding: 0.2em 0;
  cursor: pointer;
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  font-weight: 500;
  color: #006837 !important;
  text-align: center;
  line-height: 1;
  border-radius: 10px;
  background-color: #cef726;
}
.committee-cat:hover {
  color: #fff !important;
  background-color: #231815;
}
.committee-content {
  padding-left: 10px;
  padding-right: 10px;
}
.committee-content a {
  color: #231815;
}
@media screen and (min-width: 880px), print {
  .committee-content a:hover {
    color: #006837;
    -webkit-text-decoration: underline 2px;
            text-decoration: underline 2px;
  }
}
.committee-title {
  padding-top: 0.3em;
  padding-bottom: 0.3em;
  font-size: clamp(1.125rem, 2.5vw, 1.375rem);
  font-weight: 600;
}
.committee-body {
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
}
/*******************************************
	@FAQ よくある質問
********************************************/
.faq-box {
  position: relative;
  margin-bottom: 1em;
  padding: 1em 1em 0;
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
  background-color: #f8f8f3;
}
@media screen and (min-width: 880px), print {
  .faq-box {
    margin-bottom: 1.5em;
    padding: 1em 1.5em 0;
  }
}
.faq-box-accordion {
  position: relative;
  display: block;
  cursor: pointer;
  -webkit-transition: 0.5s ease-in;
  transition: 0.5s ease-in;
  margin: 0;
  margin-bottom: 1em;
  padding-left: 2em;
  height: 2.5em;
  line-height: 2.5em;
  border: none;
  background-color: #f8f8f3;
}
.faq-box-accordion.extra2 {
  height: 3em;
  padding-right: 2.5em;
  line-height: 1.5em;
}
.faq-box-accordion.extra3, .faq-box-accordion.extra3a {
  height: 4.5em;
  padding-right: 2.5em;
  line-height: 1.5em;
}
.faq-box-accordion.extra4 {
  height: 6em;
  padding-right: 2.5em;
  line-height: 1.5em;
}
@media screen and (min-width: 880px), print {
  .faq-box-accordion {
    padding-left: 3em;
  }
  .faq-box-accordion.extra2 {
    height: 2.5em;
    padding-right: 2.75em;
    line-height: 2.5em;
  }
  .faq-box-accordion.extra3 {
    height: 3em;
    padding-right: 2.75em;
    line-height: 1.5em;
  }
  .faq-box-accordion.extra3a {
    height: 4em;
    padding-right: 2.5em;
    line-height: 1.5em;
  }
  .faq-box-accordion.extra4 {
    height: 4em;
    padding-right: 2.5em;
    line-height: 1.5em;
  }
}
.faq-box-accordion:hover {
  background-color: #f8f8f3;
}
@media screen and (min-width: 768px), print {
  .faq-box-accordion:hover span.plusminus {
    border: 1px solid #231815;
    background-color: #231815;
  }
}
.faq-box-accordion.active {
  margin-bottom: 0;
}
.faq-box-accordion:before {
  content: "Ｑ.";
  position: absolute;
  left: 0;
  display: inline-block;
  text-align: center;
  font-size: clamp(1.125rem, 2.7272727273vw, 1.5rem);
  font-weight: 700;
  color: #006934;
}
.faq-box-accordion span.plusminus {
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "●";
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #00993e;
  background-color: #00993e;
}
.faq-box-accordion span.plusminus::after {
  position: absolute;
  top: 0.25em;
  left: 0.2em;
  content: "＋";
  font-size: clamp(0.75rem, 1.8181818182vw, 1rem);
  color: #fff;
  line-height: 1;
}
@media screen and (min-width: 768px), print {
  .faq-box-accordion span.plusminus {
    width: 1.5em;
    height: 1.5em;
  }
  .faq-box-accordion span.plusminus::after {
    top: 0.15em;
    left: 0.2em;
  }
}
.faq-box-accordion.active span.plusminus {
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "●";
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #00993e;
  background-color: #fff;
}
.faq-box-accordion.active span.plusminus::after {
  position: absolute;
  top: 0.27em;
  left: 0.22em;
  content: "ー";
  font-size: clamp(0.75rem, 1.8181818182vw, 1rem);
  color: #00993e;
  line-height: 1;
}
@media screen and (min-width: 768px), print {
  .faq-box-accordion.active span.plusminus {
    width: 1.5em;
    height: 1.5em;
  }
  .faq-box-accordion.active span.plusminus::after {
    top: 0.19em;
    left: 0.22em;
  }
}
.faq-box .panel {
  max-height: 0;
  overflow: hidden;
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
}
.faq-box .panel .btn-box {
  margin-top: 0;
  padding-bottom: 1.5em;
}
@media screen and (min-width: 768px), print {
  .faq-box .panel .btn-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.faq-box .panel p.panel-box {
  position: relative;
  margin: 0.75em 0 0;
  padding: 1em 0.5em 1em;
  padding-left: 2em;
  border-top: 1px solid #888;
}
@media screen and (min-width: 880px), print {
  .faq-box .panel p.panel-box {
    padding: 1em 1em 1.5em;
    padding-left: 3em;
  }
}
.faq-box .panel p.panel-box:before {
  content: "Ａ.";
  position: absolute;
  top: 0.5em;
  left: 0;
  display: inline-block;
  text-align: center;
  font-size: clamp(1.125rem, 2.7272727273vw, 1.5rem);
  font-weight: 700;
  color: #006934;
}
@media screen and (min-width: 880px), print {
  .faq-box .panel p.panel-box:before {
    top: 0.35em;
  }
}

/* ------------------------------------------------- *
 *  ＠FORM　　　　　　　　　　　　　　　　
 * ------------------------------------------------- */
/* お問合せ枠 */
.contact-box {
  margin: auto;
  padding: 1em;
  background-color: #f8f8f3;
}
.contact-box_lead {
  margin-bottom: 2em !important;
  text-align: center;
}
@media screen and (min-width: 880px) {
  .contact-box {
    padding: 2em 1em;
  }
}

#formWrap {
  width: 100%;
  margin: 0;
}

.table-form {
  width: 100%;
  margin: auto;
}
.table-form th,
.table-form td {
  width: 100%;
  display: block;
  margin: 0;
  text-align: left;
}
.table-form th {
  margin-bottom: 7px;
  padding-left: 0.5rem;
  font-weight: 500;
  line-height: 1;
}
.table-form th span {
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  font-weight: 400;
}
.table-form th .required {
  margin-left: 0.6em;
  padding: 0.075em 0.5em;
  color: #fff;
  font-size: clamp(0.625rem, 1.3636363636vw, 0.75rem);
  border-radius: 4px;
  background-color: #c00;
}
.table-form th .small {
  margin-top: 0.75em;
  margin-bottom: 0.5em;
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  font-weight: 400;
  line-height: 1.4;
}
.table-form td {
  margin-bottom: 2em;
}
.table-form td .long {
  width: 100%;
}
@media screen and (min-width: 880px) {
  .table-form td {
    margin-bottom: 3em;
  }
}

label {
  cursor: pointer;
}

input[type=text], input[type=email], input[type=tel] {
  width: 100%;
  height: 2.5em;
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
  border-radius: 5px;
  border: solid 1px #D0D0D0;
  background-color: white;
}

textarea {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
  border-radius: 5px;
  border: solid 1px #D0D0D0;
  background-color: white;
}

input,
textarea {
  padding: 0.1em 0.3em;
  line-height: 1.5;
}

::-webkit-input-placeholder {
  color: #666;
}

::-moz-placeholder {
  color: #666;
}

:-ms-input-placeholder {
  color: #666;
}

::-ms-input-placeholder {
  color: #666;
}

::placeholder {
  color: #666;
}

/*table.formTable th span,*/
form.cmxform label.error,
label.error,
.error {
  color: #c00;
  font-size: clamp(0.75rem, 1.5909090909vw, 0.875rem);
  font-weight: 600;
}

.submit-center {
  width: 10em;
  margin: 0 auto;
  text-align: center;
}
@media screen and (min-width: 880px) {
  .submit-center {
    width: 14em;
  }
}
.submit-center.thanks {
  width: 12em;
  height: 2.5em;
  margin: 0 auto;
  padding: 0.5em;
  cursor: pointer;
  font-size: clamp(0.9375rem, 2.0454545455vw, 1.125rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
  background-color: #222;
  border-radius: 4px;
  border: 2px solid #222;
}
.submit-center.thanks a {
  color: #fff;
}
@media screen and (min-width: 880px) {
  .submit-center.thanks:hover {
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    background-color: #fff;
    border: 2px solid #222;
  }
  .submit-center.thanks:hover a {
    color: #222;
  }
}

input[type=submit],
input[type=button] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 2.5em;
  padding-left: 1em;
  cursor: pointer;
  font-size: clamp(1rem, 2.2727272727vw, 1.25rem);
  font-weight: 700;
  color: #fff;
  line-height: 1;
  letter-spacing: 0.25em;
  border-radius: 8px;
}

/* 同意したら送信ボタン */
input[type=submit] {
  background-color: #f15a24;
  border: 2px solid #f15a24;
}

/* 送信ボタン - マウスオーバー時 */
@media screen and (min-width: 880px) {
  input[type=submit]:hover {
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    color: #fff;
    background-color: #000;
    border: 2px solid #000;
  }
}

/* 送信ボタン - 押せないとき */
input[type=submit][disabled] {
  background-color: rgba(241, 90, 36, 0.8);
  cursor: default;
}

/* 戻って修正ボタン */
input[type=button] {
  background: #999;
  margin-top: 20px;
  border: 2px solid #999;
}

/* 戻って修正ボタン - マウスオーバー時 */
@media screen and (min-width: 880px) {
  input[type=button]:hover {
    color: #999;
    background: #fff;
    border: 2px solid #999;
  }
}

.error {
  padding-left: 10px;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: 1px solid #888;
  outline-offset: 0;
}

.tel-box {
  margin: 3em auto 1em;
  font-size: clamp(0.875rem, 1.8181818182vw, 1rem);
  font-weight: 600;
  text-align: center;
  line-height: 1.5;
}
.tel-box_lead {
  color: #f00;
}
.tel-box_body {
  margin: 1em auto !important;
  font-weight: 400;
}
.tel-box_tel {
  font-size: clamp(0.875rem, 2.0454545455vw, 1.125rem);
  font-weight: 700;
}
@media screen and (min-width: 880px) {
  .tel-box {
    margin: 3em auto 0;
  }
}

.thanks-head {
  font-size: clamp(1.25rem, 3.1818181818vw, 1.75rem);
  text-align: center;
  font-weight: 600;
}

.thanks-body {
  margin: 1em auto 2em;
  font-size: clamp(1rem, 2.0454545455vw, 1.125rem);
  text-align: center;
  font-weight: 400;
}

/*
.error-list{
  margin:2em auto;
  font-size:14px;
  text-align: center;
  font-weight:400;
  color:#f00;
}
*/
/*# sourceMappingURL=style.css.map */