@charset "UTF-8";
/*Theme Name: GFC */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Noto+Serif+JP:wght@200;400;700&display=swap");
@media (min-width: 768px) {
  /*--- 全共通 ---*/
  html {
    font-size: 125%;
  }
  body {
    position: relative;
    font-family: "Noto Sans JP", "Hiragino Sans", sans-serif;
    margin: 0 auto;
    color: #6e6e6e;
    font-weight: 500;
    line-height: 1.6;
    font-size: 0.75rem;
    min-width: 1000px;
  }
  body *:first-child {
    margin-top: 0;
  }
  body *:last-child {
    margin-bottom: 0;
  }
  body p {
    line-height: 2;
  }
  body ul:not([class]) {
    margin: 1rem 0 1rem 1.5rem;
    list-style-type: disc;
  }
  body ol:not([class]) {
    margin: 1rem 0 1rem 1.5rem;
    list-style-type: decimal;
  }
  body dl:not([class]) {
    margin: 2rem 0 1rem;
  }
  body dl:not([class]) dt {
    font-size: 1rem;
    color: #fff;
    background-color: #6e6e6e;
    padding: 0.5rem 1rem;
  }
  body dl:not([class]) dd {
    padding: 1rem 1rem;
    line-height: 2;
    margin-bottom: 1rem;
  }
  body iframe {
    width: 100%;
    display: block;
    margin: 0 auto 1rem;
  }
  body table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1rem;
    border: 3px solid #6e6e6e;
    font-size: 1rem;
  }
  body table caption {
    font-size: 1.25rem;
  }
  body table caption small {
    display: block;
    font-size: 0.75rem;
    text-align: right;
  }
  body table th,
  body table td {
    padding: 1rem 0.5rem;
    border: 3px solid #6e6e6e;
    text-align: center;
  }
  body table td {
    background-color: #fff;
    color: #6e6e6e;
  }
  body table th {
    text-align: center;
    background-color: #6e6e6e;
    color: #fff;
    font-size: 1rem;
  }
  body table .gold {
    background-color: #e0c11d;
    color: #fff;
    font-weight: bold;
  }
  body table .white {
    background-color: #fff;
    color: #6e6e6e;
  }
  body select,
  body textarea,
  body input[type="url"],
  body input[type="text"],
  body input[type="date"],
  body input[type="tel"],
  body input[type="email"],
  body input[type="number"] {
    display: block;
    background-color: #e8e8e8;
    padding: 0.7rem 0.5rem;
    font-size: 1rem;
  }
  body textarea,
  body input[type="url"],
  body input[type="text"],
  body input[type="date"],
  body input[type="tel"],
  body input[type="email"],
  body input[type="number"] {
    width: 100%;
  }
  body select {
    width: 50%;
  }
  body input[type="checkbox"],
  body input[type="radio"] {
    margin: 0 0.5rem;
  }
  body input[type="submit"],
  body button[type="submit"] {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    outline: none;
    -webkit-transition: 0.5s all;
    transition: 0.5s all;
    background-color: inherit;
    max-width: 300px;
  }
  body .t_al {
    text-align: left;
  }
  body .t_ac {
    text-align: center;
  }
  body .t_ar {
    text-align: right;
  }
  body .imgleft,
  body .imgright {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin: 1rem 0 2rem;
  }
  body .imgleft > *,
  body .imgright > * {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
  }
  body .imgright {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  body .inner {
    max-width: 1040px;
    padding: 0 1rem;
    margin: 0 auto;
  }
  body .btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
    text-decoration: none;
    padding: 0.5rem;
    width: 100%;
    max-width: 400px;
    min-height: 70px;
    color: #6e6e6e;
    border: 3px solid #6e6e6e;
    font-size: 1rem;
    line-height: 1.2;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    margin: 1rem auto;
    position: relative;
    cursor: pointer;
    font-weight: bold;
  }
  body .btn img {
    margin-right: 0.5rem;
  }
  body .btn:hover {
    opacity: 1;
    background-color: #6e6e6e;
    color: #fff;
  }
  body .btn.arrow {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding-right: 3rem;
  }
  body .btn.arrow::before, body .btn.arrow::after {
    position: absolute;
    content: "";
    background-color: #6e6e6e;
    height: 3px;
    right: 1rem;
    top: calc(50% + 3px);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  body .btn.arrow::before {
    width: 20px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  body .btn.arrow::after {
    width: 10px;
    -webkit-transform-origin: right center;
            transform-origin: right center;
    -webkit-transform: translateY(-50%) rotate(35deg);
            transform: translateY(-50%) rotate(35deg);
  }
  body .btn.arrow:hover::before, body .btn.arrow:hover::after {
    background-color: #fff;
  }
  body .btn.white {
    color: #fff;
    border: 3px solid #fff;
  }
  body .btn.white:hover {
    background-color: #aaafb1;
  }
  body .btn.white.arrow::before, body .btn.white.arrow::after {
    background-color: #fff;
  }
  body .btn.white.arrow:hover::before, body .btn.white.arrow:hover::after {
    background-color: #6e6e6e;
  }
  body .btn.white2 {
    color: #000;
    border: 5px solid #000;
    background-color: #fff;
    width: 440px;
    padding: 30px;
  }
  body .btn.white2:hover {
    background-color: #aaafb1;
    color: #fff;
    border: 5px solid #aaafb1;
  }
  body .btn.white2.arrow::before, body .btn.white2.arrow::after {
    background-color: #000;
  }
  body .btn.white2.arrow:hover::before, body .btn.white2.arrow:hover::after {
    background-color: #fff;
  }
  body .btn.gray {
    color: #fff;
    border: none;
    background-color: #6e6e6e;
  }
  body .btn.gray:hover {
    background-color: #e0c11d;
    color: #fff;
  }
  body .btn.gray.arrow::before, body .btn.gray.arrow::after {
    height: 2px;
    background-color: #fff;
  }
  body .btn.gray.arrow:hover::before, body .btn.gray.arrow:hover::after {
    background-color: #fff;
  }
  body .btn.black {
    color: #000;
    border: 3px solid #000;
  }
  body .btn.black::before, body .btn.black::after {
    height: 2px;
    background-color: #000;
  }
  body .btn.black:hover {
    background: #000;
    color: #fff;
  }
  body .btn.org {
    color: #fff;
    border: 3px solid #cb4f0d;
    background: #cb4f0d;
  }
  body .btn.org img {
    margin-left: 20px;
    vertical-align: middle;
  }
  body .btn.org:hover {
    background: #cba10d;
    border: 3px solid #cba10d;
  }
  body .btn.org.big {
    font-size: 2.4rem;
    max-width: 100%;
    padding: 35px;
  }
  body .btn.line {
    background-color: #06c755;
    color: #fff;
    border: none;
    -webkit-box-shadow: 0 6px #157c3f;
            box-shadow: 0 6px #157c3f;
    position: relative;
    top: 0;
    font-size: 2rem;
    max-width: 550px;
  }
  body .btn.line:hover {
    color: #fff;
    top: -4px;
    -webkit-box-shadow: 0 10px #157c3f;
            box-shadow: 0 10px #157c3f;
  }
  body .btn.ygreen {
    background-color: #bcce32;
    color: #fff;
    border: none;
    border-radius: 5px;
    -webkit-box-shadow: 0 6px #78841a;
            box-shadow: 0 6px #78841a;
    padding: 1.2rem;
    position: relative;
    top: 0;
    font-size: 1.7rem;
    max-width: 500px;
  }
  body .btn.ygreen:hover {
    color: #fff;
    top: 4px;
    -webkit-box-shadow: 0 0 #78841a;
            box-shadow: 0 0 #78841a;
  }
  body .btn.center {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  body .p_cta {
    text-align: center;
    margin: 30px auto;
  }
  body .p_cta .cmp {
    font-size: 1.2rem;
  }
  body .p_cta .cmp span {
    display: block;
    margin: 0 auto;
    font-size: 0.8rem;
    text-align: center;
  }
  body .p_cta .caution {
    font-size: 0.5rem;
  }
  body .small {
    text-align: center;
  }
  body .grecaptcha-badge {
    visibility: hidden;
  }
  /*---- header ----*/
  header {
    position: relative;
  }
  header .l_header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    color: #fff;
    z-index: 10;
    padding-bottom: 11px;
    -webkit-transition: background 0.3s;
    transition: background 0.3s;
  }
  header .l_header .inner {
    max-width: 1200px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  header .l_header .inner .logo {
    padding-top: 20px;
  }
  header .l_header .inner .h_menu {
    -webkit-box-flex: 0;
        -ms-flex: 0 3 830px;
            flex: 0 3 830px;
  }
  header .l_header.show {
    background-color: rgba(110, 110, 110, 0.8);
  }
  header .l_header.scroll {
    background-color: rgba(110, 110, 110, 0.8);
  }
  header .h_menu {
    position: relative;
    z-index: 1;
  }
  header .h_menu .reserb_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  header .h_menu .reserb_list li {
    margin-left: 1rem;
  }
  header .h_menu .reserb_list li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    min-width: 150px;
    min-height: 50px;
    padding: 0.5rem;
    line-height: 1.2;
    background-color: rgba(224, 193, 29, 0.8);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    font-size: 0.7rem;
  }
  header .h_menu .reserb_list li a:hover {
    background-color: #e0c11d;
    opacity: 1;
  }
  header .h_menu .menu_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 1rem;
    gap: 10px;
  }
  header .h_menu .menu_list > li {
    position: relative;
  }
  header .h_menu .menu_list > li:hover .sub_menu {
    visibility: visible;
  }
  header .h_menu .menu_list > li .sub_menu {
    background: rgba(110, 110, 110, 0.8);
    left: 0;
    position: absolute;
    top: 100%;
    visibility: hidden;
    min-width: 220px;
    width: 100%;
    z-index: 1;
  }
  header .h_menu .menu_list > li .sub_menu li a {
    padding: 10px;
    display: block;
    border-bottom: 1px solid #fff;
  }
  header .sub_catch {
    position: relative;
  }
  header .sub_catch .bg_img {
    width: 100%;
    min-height: 300px;
    height: 100vh;
    max-height: 520px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  header .sub_catch .bg_img img {
    width: 100%;
  }
  header .sub_catch .txt_blc {
    position: absolute;
    width: 250px;
    height: 100%;
    top: 0;
    left: 10%;
    background-color: rgba(110, 110, 110, 0.8);
    padding: 180px 2.5rem 1.5rem;
    color: #fff;
  }
  header .sub_catch .txt_blc p {
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
  }
  header .sub_catch .txt_blc .btn {
    min-height: 70px;
  }
  header .sub_catch .txt_blc .page_title {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 2.5rem;
    white-space: nowrap;
  }
  header .sub_catch2 {
    position: relative;
  }
  header .sub_catch2 .bg_img {
    width: 100%;
    min-height: 300px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  header .sub_catch2 .bg_img img {
    width: 100%;
  }
  header .sub_catch2 .img {
    width: 100%;
  }
  header .blc_catch {
    position: relative;
  }
  header .blc_catch .bg_img {
    width: 100%;
    height: 100vh;
    min-height: 700px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  header .blc_catch .swiper-slide {
    position: relative;
  }
  header .blc_catch .txt_blc {
    position: absolute;
    width: 490px;
    height: 100%;
    top: 0;
    left: 7%;
    background-color: rgba(110, 110, 110, 0.8);
    padding: 180px 2.5rem 1.5rem;
    color: #fff;
  }
  header .blc_catch .txt_blc p {
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
  }
  header .blc_catch .txt_blc .btn {
    min-height: 70px;
  }
  header .blc_catch .txt_blc .page_title {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 2.5rem;
    white-space: nowrap;
  }
  header .catch_slider {
    overflow: hidden;
  }
  header .org_title {
    background: #cb4f0d;
    color: #fff;
    text-align: center;
    font-weight: 900;
    font-size: 2rem;
    padding: 140px 0 50px;
  }
  /*---- ベースとcompornent ----*/
  main {
    padding: 3.5rem 0;
    /*---- 見出し系 ----*/
    /*---- セクション ----*/
    /*---- コンポーネント----*/
  }
  main section {
    padding: 3.5rem 0;
  }
  main h1:not([class]),
  main h2:not([class]),
  main h3:not([class]),
  main h4:not([class]),
  main h5:not([class]),
  main h6:not([class]) {
    margin: 2rem 0 1rem;
    font-size: 1rem;
    line-height: 1.2;
  }
  main p {
    margin-bottom: 1.5em;
  }
  main strong {
    font-size: 1.5em;
  }
  main img {
    margin-bottom: 1rem;
  }
  main blockquote {
    padding: 1rem 1rem;
    margin: 1rem auto;
    background-color: #e8e8e8;
    border-radius: 1rem;
  }
  main blockquote *:first-child {
    margin-top: 0;
  }
  main blockquote *:last-child {
    margin-bottom: 0;
  }
  main .sec_title {
    font-size: 2.5rem;
    margin: 1rem auto 2.5rem;
    text-align: center;
    color: #333333;
    font-weight: bold;
    padding-bottom: 10px;
    position: relative;
  }
  main .sec_title::after {
    position: absolute;
    content: "";
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    height: 5px;
    width: 100%;
    max-width: 200px;
    background-color: #aaafb1;
    background-image: -webkit-gradient(linear, left top, right top, from(#aaafb1), color-stop(30%, #aaafb1), color-stop(30%, #6e6e6e), color-stop(70%, #6e6e6e), color-stop(70%, #aaafb1), to(#aaafb1));
    background-image: linear-gradient(90deg, #aaafb1, #aaafb1 30%, #6e6e6e 30%, #6e6e6e 70%, #aaafb1 70%, #aaafb1 100%);
  }
  main .sec_title_icon {
    margin-bottom: 3rem;
    font-size: 2.2rem;
    text-align: center;
    color: #000;
    font-weight: bold;
    padding-bottom: 10px;
  }
  main .sec_title_icon span:not([class]) {
    display: inline;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e0c11d));
    background: linear-gradient(transparent 60%, #e0c11d 60%);
    padding: 0 0.5rem;
  }
  main .sec_title_icon .line {
    color: #cba10d;
    margin-top: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main .sec_title_icon .line::before {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 5px;
    background-color: #cba10d;
    margin-right: 2rem;
  }
  main .sec_title_icon .line::after {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 5px;
    background-color: #cba10d;
    margin-left: 2rem;
  }
  main .sec_title_icon img {
    display: block;
    margin: 0 auto 0.5rem;
  }
  main .t_gold {
    font-size: 1.25rem;
    color: #e0c11d;
    text-align: center;
    margin: 3rem 0 2rem;
  }
  main .t_listtitle {
    font-size: 1.5rem;
    margin: 2rem 0 1rem;
  }
  main .t_listtitle small {
    margin-left: 10px;
    font-size: 1rem;
  }
  main .w_900 {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
  }
  main .blc_img {
    margin: 2.5rem 0;
    display: block;
  }
  main .blc_reserve {
    background-color: #e0c11d;
    color: #fff;
    padding: 1.5rem 0;
    color: #fff;
  }
  main .blc_reserve .btn {
    color: #fff;
    border: 3px solid #fff;
  }
  main .blc_reserve .btn:hover {
    background-color: #fff;
    color: #e0c11d;
  }
  main .blc_reserve .btn.arrow::before, main .blc_reserve .btn.arrow::after {
    background-color: #fff;
  }
  main .blc_reserve .btn.arrow:hover::before, main .blc_reserve .btn.arrow:hover::after {
    background-color: #e0c11d;
  }
  main .blc_reserve .title {
    font-size: 1.5rem;
    text-align: center;
    margin-bottom: 1rem;
  }
  main .blc_reserve .cta_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (300px)[auto-fill];
        grid-template-columns: repeat(auto-fill, 300px);
    gap: 3rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main .blc_reserve .tel p {
    font-size: 1rem;
    line-height: 1.2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 0.5rem;
  }
  main .blc_reserve .tel img {
    margin-right: 0.5rem;
    vertical-align: middle;
  }
  main .blc_reserve .tel a {
    font-size: 2rem;
    line-height: 1.2;
  }
  main .blc_service {
    padding: 3.5rem 0 1.5rem;
  }
  main .blc_service .link_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 2rem 2.5rem;
  }
  main .blc_service .link_list li {
    position: relative;
    overflow: hidden;
  }
  main .blc_service .link_list a img {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  main .blc_service .link_list a:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  main .blc_service .link_list .title {
    position: absolute;
    z-index: 1;
    width: 100%;
    padding: 1rem;
    background-color: rgba(0, 0, 0, 0.4);
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    font-size: 1rem;
    font-weight: bold;
  }
  main .table_wrap {
    margin: 1rem auto 2rem;
  }
  main .table_wrap.mini {
    max-width: 900px;
  }
  main .table_wrap.small {
    max-width: 600px;
  }
  main .bg_gray {
    background-color: #e8e8e8;
    padding: 2.5rem;
  }
  main .bg_img01 {
    background-image: image-set(url(images/common/bg_01.png) 1x, url(images/common/bg_01@2x.png) 2x);
    background-image: -webkit-image-set(url(images/common/bg_01.png) 1x, url(images/common/bg_01@2x.png) 2x);
    padding: 6rem 0;
    background-position: top;
    background-repeat: no-repeat;
  }
  main .bg_img02 {
    background-image: image-set(url(images/common/bg_02.jpg) 1x, url(images/common/bg_02@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_02.jpg) 1x, url(images/common/bg_02@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .bg_img03 {
    background-image: image-set(url(images/common/bg_03.jpg) 1x, url(images/common/bg_03@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_03.jpg) 1x, url(images/common/bg_03@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .bg_gold {
    background-image: image-set(url(images/common/bg_gold.jpg) 1x, url(images/common/bg_gold@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_gold.jpg) 1x, url(images/common/bg_gold@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .bg_hexagon {
    background-image: image-set(url(images/common/bg_hexagon.jpg) 1x, url(images/common/bg_hexagon@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_hexagon.jpg) 1x, url(images/common/bg_hexagon@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio,
  main .wpcf7-form-control-wrap .wpcf7-checkbox {
    display: block;
    padding: 0.8rem 0;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item,
  main .wpcf7-form-control-wrap .wpcf7-checkbox .wpcf7-list-item {
    display: block;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item:not(:last-of-type),
  main .wpcf7-form-control-wrap .wpcf7-checkbox .wpcf7-list-item:not(:last-of-type) {
    margin-bottom: 0.5rem;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label {
    cursor: pointer;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label input,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label input {
    display: none;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label input:checked + .wpcf7-list-item-label::after,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label input:checked + .wpcf7-list-item-label::after {
    display: block;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label {
    padding-left: 40px;
    position: relative;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::before, main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::after,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::before,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::after {
    position: absolute;
    content: "";
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 0;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::after,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::after {
    display: none;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::before {
    left: 0;
    border-radius: 50%;
    width: 16px;
    height: 16px;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::after {
    left: 3px;
    border-radius: 50%;
    width: 10px;
    height: 10px;
  }
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::before {
    left: 0;
    width: 16px;
    height: 16px;
    border: 1px solid #e0c11d;
  }
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::after {
    left: 4px;
    width: 18px;
    height: 10px;
    border-left: 2px solid #e0c11d;
    border-bottom: 2px solid #e0c11d;
    -webkit-transform-origin: 25% center;
            transform-origin: 25% center;
    -webkit-transform: rotate(-45deg) translateY(-50%);
            transform: rotate(-45deg) translateY(-50%);
  }
  main .c_post_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 2.5rem 1rem;
    padding: 1.5rem;
    background-color: #e8e8e8;
    margin: 1rem auto 2rem;
    max-width: 1080px;
  }
  main .c_post_list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    background-color: #fff;
  }
  main .c_post_list .info {
    margin-bottom: 0.5rem;
  }
  main .c_post_list .cat {
    margin-left: 0.5rem;
  }
  main .c_post_list .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    display: inline-block;
  }
  main .c_post_list .cat a:not(:last-of-type) {
    margin-right: 0.5rem;
  }
  main .c_post_list .thumb {
    width: 100%;
    position: relative;
  }
  main .c_post_list .thumb::before {
    content: "";
    display: block;
    padding-top: 62.5%;
  }
  main .c_post_list .thumb img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  main .c_post_list .text {
    padding: 1rem;
  }
  main .c_post_list .btn {
    margin-top: auto;
    width: 100%;
    min-height: 50px;
    -webkit-box-shadow: 0 -10px #e8e8e8;
            box-shadow: 0 -10px #e8e8e8;
  }
  main .c_news_list li {
    padding-bottom: 2rem;
    border-bottom: 5px solid #6e6e6e;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  main .c_news_list li:not(:first-of-type) {
    padding-top: 2rem;
  }
  main .c_news_list .info {
    margin-bottom: 0.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 240px;
            flex: 0 0 240px;
  }
  main .c_news_list time {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100px;
            flex: 0 0 100px;
  }
  main .c_news_list .cat {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 140px;
            flex: 0 0 140px;
  }
  main .c_news_list .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    max-width: 100%;
    display: inline-block;
  }
  main .c_news_list .cat a:not(:last-of-type) {
    margin-bottom: 5px;
  }
  main .c_news_list .title {
    padding: 0 0.5rem;
  }
  main .c_service_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
  main .c_service_list li {
    border: 3px solid #6e6e6e;
  }
  main .c_service_list .thumb img {
    width: 100% !important;
  }
  main .c_service_list .title {
    text-align: center;
    font-size: 1rem;
    color: #fff;
    padding: 0.5rem;
    background-color: #e0c11d;
  }
  main .c_service_list .text {
    padding: 1rem;
  }
  main .c_service_list .btn {
    margin: 0;
    min-height: 60px;
    max-width: 100%;
  }
  main .c_service_list .acc_content {
    display: none;
  }
  main .c_service_list .acc_content.open {
    display: block;
  }
  main .c_service_link {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.5rem 2.5rem;
  }
  main .c_service_link li {
    position: relative;
  }
  main .c_service_link img {
    width: 100%;
  }
  main .c_service_link .title {
    position: absolute;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 0;
    width: 100%;
    text-align: center;
    font-size: 1rem;
    color: #fff;
    padding: 1rem 0.5rem;
    background-color: rgba(0, 0, 0, 0.4);
  }
  main .c_link_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem 2.5rem;
    margin: 1rem 0 3rem;
  }
  main .c_qa_list {
    margin: 1rem auto 2rem;
    padding: 2.5rem;
    background-color: #e8e8e8;
    border: 3px solid #6e6e6e;
  }
  main .c_qa_list .acc_label {
    cursor: pointer;
  }
  main .c_qa_list .acc_content {
    display: none;
  }
  main .c_qa_list .acc_content.open {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  main .c_qa_list dt {
    position: relative;
    font-size: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: #fff;
    background-color: #6e6e6e;
    margin-bottom: 1.5rem;
  }
  main .c_qa_list dt::before {
    content: "Q";
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    font-size: 2.25rem;
    padding: 0 1rem;
  }
  main .c_qa_list dd {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: #6e6e6e;
    margin-bottom: 2.5rem;
  }
  main .c_qa_list dd::before {
    content: "A";
    color: #e0c11d;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    font-size: 2.25rem;
    padding: 0 1rem;
  }
  main .c_part_list {
    margin: 2rem 0 1rem;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 36% 64%;
        grid-template-columns: 36% 64%;
  }
  main .c_part_list dt,
  main .c_part_list dd {
    border: 1.5px solid #6e6e6e;
    padding: 1rem;
  }
  main .c_part_list dt {
    font-size: 1rem;
    color: #fff;
    background-color: #6e6e6e;
    padding: 0.5rem 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main .c_part_list dt:not(:first-of-type) {
    border-top: 1.5px solid #fff;
  }
  main .c_part_list dt:not(:last-of-type) {
    border-bottom: 1.5px solid #fff;
  }
  main .c_part_list dd {
    background-color: #fff;
    color: #6e6e6e;
    padding: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-right: 3px solid #6e6e6e;
  }
  main .c_part_list dd:first-of-type {
    border-top: 3px solid #6e6e6e;
  }
  main .c_part_list dd:last-of-type {
    border-bottom: 3px solid #6e6e6e;
  }
  main .c_dot_list {
    margin: 1rem auto 2rem;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(360px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  }
  main .c_dot_list li {
    padding: 5px 10px 5px 25px;
    position: relative;
  }
  main .c_dot_list li::before {
    position: absolute;
    content: "";
    left: 0;
    top: 10px;
    width: 15px;
    height: 15px;
    background-color: #e0c11d;
  }
  main .blc_form {
    margin-top: 2rem;
  }
  main .blc_form input[type="submit"] {
    margin-bottom: 0;
  }
  main .c_form_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    max-width: 570px;
    margin: 2rem auto 2.5rem;
  }
  main .c_form_list dt:not(:last-of-type),
  main .c_form_list dd:not(:last-of-type) {
    margin-bottom: 2.5rem;
  }
  main .c_form_list dt {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 170px;
            flex: 0 1 170px;
    padding: 0.8rem 0.5rem 0.8rem 0;
  }
  main .c_form_list dt span {
    margin-left: 5px;
    color: #e0c11d;
  }
  main .c_form_list dd {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 400px;
            flex: 0 1 400px;
  }
  main .c_check_list {
    padding: 1.5rem;
    background-color: #fff;
    border: 3px solid #6e6e6e;
    margin: 1rem auto 2rem;
    max-width: 900px;
  }
  main .c_check_list li {
    padding-left: 2rem;
    position: relative;
  }
  main .c_check_list li:not(:last-of-type) {
    margin-bottom: 0.5rem;
  }
  main .c_check_list li::before {
    position: absolute;
    content: "";
    top: 50%;
    left: 4px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 14px;
    height: 8px;
    border-left: 3px solid #e0c11d;
    border-bottom: 3px solid #e0c11d;
  }
  main .c_checkbox_list {
    padding: 1.5rem;
    background-color: #fff;
    border: 3px solid #6e6e6e;
    margin: 1rem auto 2rem;
    max-width: 900px;
  }
  main .c_checkbox_list > li {
    padding-left: 2rem;
    position: relative;
  }
  main .c_checkbox_list > li:not(:last-of-type) {
    margin-bottom: 0.5rem;
  }
  main .c_checkbox_list > li::before, main .c_checkbox_list > li::after {
    position: absolute;
    content: "";
    top: 50%;
  }
  main .c_checkbox_list > li::before {
    left: 4px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 14px;
    height: 8px;
    border-left: 3px solid #e0c11d;
    border-bottom: 3px solid #e0c11d;
  }
  main .c_checkbox_list > li::after {
    left: 0px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: 2px solid #6e6e6e;
  }
  main .c_checkbox_list2 {
    padding: 1.5rem 3rem;
    background-color: #fff;
    border: 10px solid #cba10d;
    margin: 0 auto 1rem;
    max-width: 900px;
    font-size: 0.7rem;
    color: #000;
  }
  main .c_checkbox_list2 > li {
    padding-left: 2rem;
    position: relative;
  }
  main .c_checkbox_list2 > li:not(:last-of-type) {
    margin-bottom: 0.7rem;
  }
  main .c_checkbox_list2 > li::before, main .c_checkbox_list2 > li::after {
    position: absolute;
    content: "";
    top: 50%;
  }
  main .c_checkbox_list2 > li::before {
    left: 7px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 18px;
    height: 12px;
    border-left: 4px solid #fff;
    border-bottom: 4px solid #fff;
    z-index: 2;
  }
  main .c_checkbox_list2 > li::after {
    left: 0px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 30px;
    height: 30px;
    background-color: #000;
    border: 2px solid #000;
    border-radius: 5px;
    z-index: 1;
  }
  main .c_checkbox_list2 > li span {
    color: #cba10d;
  }
  main .c_checkbox_list3 {
    padding: 1.5rem;
    background-color: #fff;
    border: 10px solid #cb4f0d;
    margin: 0 auto 1rem;
    max-width: 480px;
    font-size: 1rem;
    color: #000;
  }
  main .c_checkbox_list3 > li {
    padding-left: 2rem;
    position: relative;
  }
  main .c_checkbox_list3 > li:not(:last-of-type) {
    margin-bottom: 0.9rem;
  }
  main .c_checkbox_list3 > li::before, main .c_checkbox_list3 > li::after {
    position: absolute;
    content: "";
    top: 50%;
  }
  main .c_checkbox_list3 > li::before {
    left: 7px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 18px;
    height: 12px;
    border-left: 4px solid #fff;
    border-bottom: 4px solid #fff;
    z-index: 2;
  }
  main .c_checkbox_list3 > li::after {
    left: 0px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 30px;
    height: 30px;
    background-color: #000;
    border: 2px solid #000;
    border-radius: 5px;
    z-index: 1;
  }
  main .c_checkbox_list3 > li span {
    color: #cba10d;
  }
  main .c_value_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    padding: 2rem 2rem;
    margin-bottom: 3rem;
  }
  main .c_value_list p {
    line-height: 1.5;
  }
  main .c_value_list li {
    background-color: #fff;
    border: 10px solid #e0c11d;
    padding: 2rem 0.7rem;
    text-align: center;
    font-size: 0.8rem;
    color: #000;
    width: 350px;
  }
  main .c_value_list li .point {
    font-size: 1.5rem;
    font-weight: bold;
  }
  main .c_value_list li .list_price {
    font-size: 1.2rem;
    text-decoration: line-through;
  }
  main .c_value_list li .price {
    font-size: 2.5rem;
    color: #cba10d;
  }
  main .c_course_list > li {
    background-color: #fff;
    border: 5px solid #cba10d;
    padding: 2.2rem 1.2rem;
    font-size: 0.75rem;
    font-weight: normal;
    color: #000;
    margin-bottom: 2.5rem;
  }
  main .c_course_list > li .imgleft .img {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 430px;
            flex: 1 1 430px;
  }
  main .c_course_list > li .imgleft .text {
    padding-left: 0.5rem;
  }
  main .c_course_list > li .course_name {
    font-size: 1.8rem;
    color: #cba10d;
    font-weight: bold;
    text-align: center;
    margin-bottom: 1.5rem;
  }
  main .c_course_list > li .sub_title {
    background-color: #cba10d;
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    padding: 0 1rem;
    margin: 1.5rem 0 1rem;
  }
  main .c_course_list > li .recommend_list {
    margin: 1.5rem 0;
    list-style-type: none;
  }
  main .c_course_list > li .recommend_list > li {
    margin-bottom: 1rem;
  }
  main .c_course_list > li .gold {
    font-size: 1.5rem;
    color: #cba10d;
    font-weight: bold;
    text-align: center;
    margin: 0 0 1.7rem;
  }
  main .c_course_list > li .price_table {
    table-layout: fixed;
  }
  main .c_course_list > li .price_table th {
    font-weight: bold;
  }
  main .c_reason_list > li {
    position: relative;
    margin-bottom: 9rem;
  }
  main .c_reason_list > li .text {
    position: absolute;
    padding: 1.5rem;
    background-color: #fff;
    -webkit-box-shadow: 3px 6px 20px -4px #e8e8e8;
            box-shadow: 3px 6px 20px -4px #e8e8e8;
    position: relative;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 600px;
            flex: 0 0 600px;
  }
  main .c_reason_list > li .text .title {
    font-size: 1.5rem;
    color: #e0c11d;
    margin-bottom: 1rem;
  }
  main .c_reason_list > li:nth-child(2) {
    margin-bottom: 12rem;
  }
  main .c_reason_list > li:nth-child(3) {
    margin-bottom: 15rem;
  }
  main .c_reason_list .imgleft .text {
    left: -5rem;
    top: 10rem;
  }
  main .c_reason_list .imgleft .text > img {
    position: absolute;
    right: 1rem;
    top: -5rem;
  }
  main .c_reason_list .imgleft .text .c_reason_img {
    border: 5px solid #000;
  }
  main .c_reason_list .imgleft .text .inbody {
    text-align: center;
    position: absolute;
    left: -25rem;
    top: 3rem;
  }
  main .c_reason_list .imgleft .text .inbody > img {
    margin: 70px 0 40px 0;
  }
  main .c_reason_list .imgright .text {
    right: -5rem;
    top: 10rem;
  }
  main .c_reason_list .imgright .text > img {
    position: absolute;
    left: 1rem;
    top: -5rem;
  }
  main .c_reason_list .imgright .c_reason_img {
    border: 5px solid #000;
  }
  main .c_caption_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 2.5rem;
    margin: 2.5rem 0;
  }
  main .c_caption_list figure {
    position: relative;
  }
  main .c_caption_list figure img {
    margin: 0;
    width: 100%;
  }
  main .c_caption_list figure figcaption {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    padding: 1rem;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.3);
  }
  main .c_bd_blc {
    padding: 1rem;
    border: 3px solid #6e6e6e;
    max-width: 900px;
    margin: 1rem auto 2rem;
    text-align: center;
    font-size: 1.25rem;
  }
  main .c_bd_blc .slash {
    position: relative;
  }
  main .c_bd_blc .slash::after {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    width: 100%;
    height: 3px;
    background-color: #e0c11d;
    -webkit-transform: translate(-50%, -50%) rotate(20deg);
            transform: translate(-50%, -50%) rotate(20deg);
  }
  main .c_bd_blc strong {
    font-weight: bold;
    font-size: 1.75rem;
    color: #e0c11d;
    margin: 0 1rem;
  }
  main .c_bd_blc b {
    font-weight: bold;
  }
  main .c_bd_blc small {
    font-size: 0.75rem;
  }
  main .c_trainer_list > li {
    border: 5px solid #000;
    background-color: #fff;
    padding: 1.5rem;
    color: #000;
  }
  main .c_trainer_list > li img {
    padding-right: 50px;
  }
  main .c_trainer_list > li .name {
    font-size: 1.8rem;
    margin-bottom: 1rem;
  }
  main .c_trainer_list > li .name small {
    margin-left: 1rem;
    font-size: 0.75rem;
    vertical-align: middle;
  }
  main .c_map_blc:not(:last-of-type) {
    margin-bottom: 2.5rem;
  }
  main .c_map_blc iframe {
    width: 100%;
    margin-bottom: 1rem;
  }
  main .c_map_blc .title {
    padding: 1rem;
    font-size: 1.5rem;
    margin: 0;
    border-bottom: 3px solid #6e6e6e;
  }
  main .c_map_blc .title small {
    font-size: 1rem;
    margin-left: 5px;
  }
  main .c_map_blc .address {
    font-size: 1rem;
  }
  main .c_map_blc p {
    border-bottom: 3px solid #6e6e6e;
    padding: 1rem;
    margin: 0;
  }
  main .c_map_blc2 {
    color: #000;
    text-align: center;
    font-size: 1rem;
  }
  main .c_map_blc2 iframe {
    width: 100%;
    margin-bottom: 1.5rem;
  }
  main .c_map_blc2 .title {
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }
  main .c_map_blc2 .address {
    margin-bottom: 2.5rem;
  }
  main .c_point_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 2.5rem 1rem;
  }
  main .c_point_list li {
    text-align: center;
  }
  main .c_point_list .title {
    font-size: 1.25rem;
    color: #e0c11d;
    margin-bottom: 1rem;
    line-height: 1.2;
  }
  main .c_point_list .text {
    text-align: left;
    line-height: 1.6;
  }
  main .c_plan_blc {
    padding: 2.5rem 1rem;
    border: 3px solid #6e6e6e;
    margin: 1rem auto 2.5rem;
    max-width: 900px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main .c_plan_blc.yellow {
    border: 3px solid #e0c11d;
    border-radius: 10px;
  }
  main .c_plan_blc .left_col {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 160px;
            flex: 0 0 160px;
    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-weight: bold;
  }
  main .c_plan_blc .left_col .round {
    width: 114px;
    height: 114px;
    background-color: #6e6e6e;
    color: #fff;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 0.5rem;
    text-align: center;
  }
  main .c_plan_blc .left_col .round.blue {
    background-color: #3b6caf;
  }
  main .c_plan_blc .left_col .round.yellow {
    background-color: #e0c11d;
  }
  main .c_plan_blc .left_col .round span {
    font-size: 0.9rem;
  }
  main .c_plan_blc .right_col {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 690px;
            flex: 1 1 690px;
    padding: 0 1rem;
  }
  main .c_plan_blc .right_col p {
    font-size: 1.25rem;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom: 1rem;
  }
  main .c_plan_blc .right_col span {
    color: #e0c11d;
    margin-left: 1rem;
    font-weight: bold;
  }
  main .c_plan_blc .right_col .ml {
    margin-left: 2.2rem;
  }
  main .c_plan_blc .right_col strong {
    font-weight: bold;
    font-size: 2.5rem;
  }
  main .c_plan_blc .right_col small {
    font-size: 1rem;
  }
  main .c_flow_list {
    margin: 1rem auto 2rem;
    counter-reset: item;
    max-width: 900px;
    position: relative;
  }
  main .c_flow_list::before {
    position: absolute;
    content: "";
    z-index: -1;
    width: 160px;
    height: 100%;
    background-color: #e0c11d;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 0;
    left: 50%;
  }
  main .c_flow_list.yellow li {
    border: 3px solid #e0c11d;
    border-radius: 10px;
  }
  main .c_flow_list li {
    counter-increment: item;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 1rem;
    border: 3px solid #6e6e6e;
    background-color: #fff;
  }
  main .c_flow_list li:not(:last-of-type) {
    margin-bottom: 3.5rem;
  }
  main .c_flow_list li:before {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100px;
            flex: 0 0 100px;
    content: counter(item);
    font-size: 5.5rem;
    color: #e0c11d;
    line-height: 1;
    font-weight: bold;
    text-align: center;
  }
  main .c_flow_list li .title {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 210px;
            flex: 0 0 210px;
    font-size: 1.25rem;
    font-weight: bold;
    padding-left: 1rem;
    padding-right: 0.5rem;
  }
  main .c_flow_list li .text {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 auto;
            flex: 0 1 auto;
  }
  main .c_img_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(400px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
    gap: 1rem;
    margin: 1rem auto 2.5rem;
  }
  main .c_term_list {
    margin: 1rem auto;
  }
  main .c_term_list li {
    color: #333333;
  }
  main .c_term_list li:not(:last-of-type) {
    margin-bottom: 0.5rem;
  }
  main .c_pagination {
    text-align: center;
    margin: 2rem auto;
    font-size: 1rem;
  }
  main .c_pagination a,
  main .c_pagination span {
    display: inline-block;
    margin: 0 5px;
    padding: 0 5px;
  }
  main .c_pagination a:hover,
  main .c_pagination span {
    color: #e0c11d;
  }
  main .c_postlink {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin: 2rem auto;
  }
  main .c_postlink a {
    display: block;
    text-align: center;
    text-decoration: none;
    padding: 0.5rem 0.5rem;
    color: #fff;
    background-color: #e0c11d;
    border: 2px solid #e0c11d;
    font-size: 0.75rem;
    line-height: 1.2;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    width: 170px;
    margin: 1rem auto;
    position: relative;
    cursor: pointer;
  }
  main .c_postlink a:hover {
    opacity: 0.8;
    background-color: #fff;
    color: #e0c11d;
  }
  main .c_numb_list {
    margin-bottom: 30px;
  }
  main .c_numb_list:not(:last-of-type) {
    margin-bottom: 100px;
  }
  main .c_numb_list li {
    border-radius: 20px;
    border: 5px solid #000;
    padding: 40px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 30px;
    position: relative;
  }
  main .c_numb_list li span {
    font-size: 4.8rem;
    line-height: 1;
    font-weight: bold;
  }
  main .c_numb_list li > div {
    width: 84%;
    margin-left: 30px;
  }
  main .c_numb_list li > div.mini {
    width: 64%;
  }
  main .c_numb_list li > div .title {
    color: #cb4f0d;
    font-weight: bold;
    font-size: 1.8rem;
    border-bottom: 1px solid #000;
    margin-bottom: 20px;
    padding-bottom: 10px;
  }
  main .c_numb_list li > div p {
    font-weight: bold;
    font-size: 1rem;
  }
  main .c_numb_list li > img {
    position: absolute;
    bottom: 0;
    right: 0;
  }
  /*---- 固定ページ共通 ----*/
  .p_page *:first-child {
    margin-top: 0;
  }
  .p_page *:last-child {
    margin-bottom: 0;
  }
  .p_page h1:not([class]) {
    color: #e0c11d;
    background-color: #e0c11d;
    padding: 0.5rem 1rem;
  }
  .p_page h2:not([class]) {
    color: #e0c11d;
    font-size: 1.5rem;
    margin: 2rem 0 3rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
  }
  .p_page h3:not([class]) {
    color: #e0c11d;
    font-size: 1.5rem;
    margin: 2rem 0 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_page h3:not([class])::after {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 3px;
    background-color: #e0c11d;
    margin-left: 2rem;
  }
  .p_page h4:not([class]) {
    color: #e0c11d;
    font-size: 1.25rem;
    margin: 1rem 0 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_page h4:not([class])::after {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 12px;
    background-color: #e0c11d;
    background: transparent repeating-linear-gradient(110deg, #e0c11d, #e0c11d 1px, transparent 1px, transparent 10px);
    margin-left: 1rem;
  }
  .p_page h5:not([class]) {
    background-color: #6e6e6e;
    color: #fff;
    padding: 0.5rem;
  }
  .p_page p span:not([class]) {
    color: #e0c11d;
  }
  .price_table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1rem;
    border: 3px solid #fff;
    font-size: 1rem;
    font-weight: normal;
  }
  .price_table caption {
    font-size: 1.25rem;
  }
  .price_table caption small {
    display: block;
    font-size: 0.75rem;
    text-align: right;
  }
  .price_table th,
  .price_table td {
    background-color: #e3e3e3;
    border: 10px solid #fff;
    text-align: center;
    vertical-align: middle;
  }
  .price_table td {
    padding: 1rem 0.5rem;
    color: #6e6e6e;
  }
  .price_table th {
    padding: 0.5rem 0.5rem;
    color: #6e6e6e;
    font-size: 1rem;
  }
  .price_table .gold {
    background-color: #e0c11d;
    color: #fff;
    font-weight: bold;
    vertical-align: middle;
    padding: 10px;
  }
  .price_table .gold span {
    font-size: 2rem;
  }
  .price_table .gold .strikethrough {
    font-size: 1rem;
    text-decoration: line-through;
  }
  .price_table .dgray {
    background-color: #333333;
    color: #fff;
  }
  .price_table .bg_white {
    background-color: #fff;
  }
  /*---- 各ページ ---*/
  .p_top *:first-child {
    margin-top: 0;
  }
  .p_top *:last-child {
    margin-bottom: 0;
  }
  .p_top .blc_img {
    margin: 5rem 0;
  }
  .p_top .sec_news .imgleft .box {
    border: 3px solid #6e6e6e;
    padding: 1.5rem;
  }
  .p_top .sec_news .imgleft .box .title {
    color: #bc1717;
    font-size: 1rem;
    font-weight: bold;
    border-bottom: 2px solid #6e6e6e;
    margin-bottom: 1rem;
  }
  .p_top .sec_news .news .btn {
    max-width: 190px;
    margin-right: 0;
    font-size: 1em;
    min-height: 50px;
  }
  .p_top .sec_news .news_list {
    padding: 0 2rem;
    margin-bottom: 1.5rem;
  }
  .p_top .sec_news .news_list li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  .p_top .sec_news .news_list .info {
    margin-bottom: 0.3rem;
  }
  .p_top .sec_news .news_list .cat {
    margin-left: 1rem;
  }
  .p_top .sec_news .news_list .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    display: inline-block;
  }
  .p_top .sec_news .news_list .cat a:not(:first-of-type) {
    margin-left: 0.5rem;
  }
  .p_top .sec_concept .imgleft,
  .p_top .sec_concept .imgright {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1rem;
  }
  .p_top .sec_concept .imgleft .title,
  .p_top .sec_concept .imgright .title {
    font-size: 1.5rem;
    color: #e0c11d;
    margin-bottom: 1rem;
  }
  .p_top .sec_concept .imgleft .text {
    padding-left: 2.5rem;
  }
  .p_top .sec_concept .imgright {
    margin-bottom: 5rem;
  }
  .p_top .sec_concept .imgright .text {
    padding-right: 2.5rem;
  }
  .p_top .sec_serivice .c_service_list {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .p_top .sec_serivice .acc_content li {
    border: none;
  }
  .p_top .sec_serivice .acc_content li:not(:last-child) {
    border-bottom: 2px solid #6e6e6e;
  }
  .p_top .sec_serivice .acc_content a {
    background: #aaafb1;
    color: #fff;
    display: block;
    padding: 20px;
    font-weight: bold;
    font-size: 0.9rem;
  }
  .p_company .c_part_list {
    max-width: 800px;
    margin: 0 auto;
  }
  .p_personaltraning {
    padding: 0 0 3.5rem;
    margin: 0;
    color: #000;
  }
  .p_personaltraning .inner {
    max-width: 1200px;
  }
  .p_personaltraning .sec_lead .c_check_list {
    max-width: 800px;
  }
  .p_personaltraning .sec_lead .t_strong {
    font-size: 1.9rem;
    color: #fff;
    text-align: center;
  }
  .p_personaltraning .sec_whatis .imgleft,
  .p_personaltraning .sec_whatis .imgright {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 0.75rem;
  }
  .p_personaltraning .sec_whatis .imgleft .title,
  .p_personaltraning .sec_whatis .imgright .title {
    font-size: 1.3rem;
    color: #e0c11d;
    margin-bottom: 2rem;
  }
  .p_personaltraning .sec_whatis .imgleft .text {
    padding: 0 2.5rem;
  }
  .p_personaltraning .sec_whatis .imgright {
    margin-bottom: 5rem;
  }
  .p_personaltraning .sec_whatis .imgright .text {
    padding: 0 2.5rem;
  }
  .p_personaltraning .sec_whatis .value {
    margin-bottom: 3rem;
  }
  .p_personaltraning .sec_reason {
    margin-top: -6rem;
    margin-bottom: 7rem;
  }
  .p_personaltraning .sec_reason .inner {
    padding: 0 2.5rem 14rem;
    margin-top: 5rem;
  }
  .p_personaltraning .sec_compare {
    margin-top: -14rem;
  }
  .p_personaltraning .sec_voice {
    padding: 3.5rem 5rem;
    max-width: 1200px;
    margin: 0 auto;
  }
  .p_personaltraning .sec_voice .swiper-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .swiper-slide {
    width: 48% !important;
    height: auto !important;
    border: 1px solid #6e6e6e;
    border-radius: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 40px;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .thumb {
    max-width: 480px;
    width: 100%;
    position: relative;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .thumb:before {
    content: "";
    display: block;
    padding-top: 62.5%;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .thumb img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    border-radius: 10px;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .cont {
    padding: 20px;
    color: #6c6c6c;
  }
  .p_personaltraning .sec_cource .inner {
    padding: 0 5rem;
  }
  .p_personaltraning .sec_staff .inner {
    padding: 0 5rem;
  }
  .p_personaltraning .blc_reserve .inner {
    max-width: 1040px;
  }
  .p_rentalgym .sec_lead .c_check_list {
    max-width: 800px;
  }
  .p_rentalstudio .sec_lead .c_check_list {
    max-width: 800px;
  }
  .p_membership ul {
    width: 730px;
    margin: 0 auto 50px;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    gap: 100px 50px;
  }
  .p_membership ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    font-weight: bold;
  }
  .p_membership ul .title {
    color: #fff;
    text-align: center;
    font-size: 1.2rem;
    padding: 5px;
    background: #333333;
  }
  .p_membership ul img {
    border: 1px solid #000;
  }
  .p_membership ul p {
    color: #000;
    font-size: 1rem;
    line-height: 1.4;
  }
  .p_membership ul .btn {
    margin: auto 0 0;
  }
  .p_membership .t_ac {
    color: #000;
    font-weight: bold;
    font-size: 1rem;
  }
  .p_contact .wpcf7-list-item-label::before,
  .p_reserve .wpcf7-list-item-label::before {
    border: 1px solid #e0c11d;
  }
  .p_contact .wpcf7-list-item-label::after,
  .p_reserve .wpcf7-list-item-label::after {
    background-color: #e0c11d;
  }
  .p_use .sec_title_icon span:not([class]) {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e3946a));
    background: linear-gradient(transparent 60%, #e3946a 60%);
  }
  .p_use p {
    font-weight: bold;
    font-size: 1rem;
  }
  .sec_flow {
    color: #000;
  }
  .sec_flow .sub_title {
    background: #333333;
    color: #fff;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 40px;
    text-align: center;
  }
  .sec_flow p.t_ac {
    font-size: 1rem;
    font-weight: bold;
  }
  .sec_flow strong {
    display: block;
    font-size: 2rem;
    font-weight: 900;
    margin-bottom: 40px;
  }
  .sec_flow strong span {
    color: #cb4f0d;
  }
  .sec_flow .kaihipay {
    background: #e1fff8;
    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-weight: 900;
    padding: 40px;
    margin-bottom: 30px;
  }
  .sec_flow .kaihipay img {
    margin: 0;
  }
  .sec_flow .kaihipay div {
    margin-left: 60px;
    width: 100%;
  }
  .sec_flow .kaihipay div .title {
    color: #009966;
    font-size: 2rem;
    line-height: 1;
    font-weight: bold;
    margin-bottom: 0;
  }
  .sec_flow .kaihipay div p {
    color: #6eb09a;
    font-size: 1.6rem;
  }
  .sec_flow .akerun {
    background: #dbedf6;
    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-weight: 900;
    padding: 40px;
    margin-bottom: 30px;
  }
  .sec_flow .akerun img {
    margin: 0;
  }
  .sec_flow .akerun div {
    margin-left: 60px;
    width: 100%;
  }
  .sec_flow .akerun div .title {
    color: #008ccf;
    font-size: 2rem;
    line-height: 1;
    font-weight: bold;
    margin-bottom: 0;
  }
  .sec_flow .akerun div p {
    color: #68a6c4;
    font-size: 1.6rem;
  }
  .sec_flow .plus {
    margin: 30px auto;
    display: block;
  }
  .sec_flow .btn.black {
    margin: 0 auto 100px;
  }
  .sec_flow .box {
    background: #eeccba;
    padding: 40px;
  }
  .p_pgs,
  .p_tokiwa {
    padding: 0;
  }
  .p_pgs .inner,
  .p_tokiwa .inner {
    max-width: 1040px;
  }
  .p_pgs h2:not([class]),
  .p_tokiwa h2:not([class]) {
    color: #cb4f0d;
  }
  .p_pgs h3:not([class]),
  .p_tokiwa h3:not([class]) {
    color: #cb4f0d;
  }
  .p_pgs h3:not([class])::after,
  .p_tokiwa h3:not([class])::after {
    display: none;
  }
  .p_pgs li,
  .p_tokiwa li {
    list-style: none;
  }
  .p_pgs .sec_title_icon span:not([class]),
  .p_tokiwa .sec_title_icon span:not([class]) {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e3946a));
    background: linear-gradient(transparent 60%, #e3946a 60%);
  }
  .p_pgs .sec_title_icon .line,
  .p_tokiwa .sec_title_icon .line {
    color: #cb4f0d;
  }
  .p_pgs .sec_title_icon .line::before,
  .p_tokiwa .sec_title_icon .line::before {
    background-color: #cb4f0d;
  }
  .p_pgs .sec_title_icon .line::after,
  .p_tokiwa .sec_title_icon .line::after {
    background-color: #cb4f0d;
  }
  .p_pgs .sec_lead .content,
  .p_tokiwa .sec_lead .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 40px;
    max-width: 1000px;
    margin: 0 auto;
  }
  .p_pgs .sec_lead .content > div,
  .p_tokiwa .sec_lead .content > div {
    -webkit-box-flex: 1;
        -ms-flex: auto;
            flex: auto;
  }
  .p_pgs .sec_lead .bubble,
  .p_tokiwa .sec_lead .bubble {
    background-color: #fff;
    margin: 0 20px 40px;
    padding: 20px 15px;
    font-weight: 700;
    font-size: 1.1rem;
    text-align: center;
    position: relative;
  }
  .p_pgs .sec_lead .bubble::after,
  .p_tokiwa .sec_lead .bubble::after {
    content: "";
    background-color: #fff;
    width: 25px;
    height: 25px;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
    position: absolute;
    bottom: -25px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .p_pgs .sec_lead .t_strong,
  .p_tokiwa .sec_lead .t_strong {
    font-size: 1.9rem;
    color: #fff;
    text-align: center;
    margin-top: 1.5rem;
  }
  .p_pgs .bg_img01,
  .p_tokiwa .bg_img01 {
    padding: 5rem 0 8rem;
  }
  .p_pgs .sec_intro h3,
  .p_tokiwa .sec_intro h3 {
    margin: 0 0 1rem 0;
    font-size: 1.25rem;
    font-weight: 700;
  }
  .p_pgs .sec_intro .imgleft .text,
  .p_tokiwa .sec_intro .imgleft .text {
    padding: 0 1.2rem;
  }
  .p_pgs .c_value_list li,
  .p_tokiwa .c_value_list li {
    padding: 1rem 0.5rem;
    border: 10px solid #000;
  }
  .p_pgs .c_value_list li p,
  .p_tokiwa .c_value_list li p {
    margin-bottom: 0.5em;
    font-size: 0.8rem;
  }
  .p_pgs .c_value_list li .big,
  .p_tokiwa .c_value_list li .big {
    font-size: 1.6rem;
  }
  .p_pgs .c_about_list,
  .p_tokiwa .c_about_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 2.5em;
  }
  .p_pgs .c_about_list img,
  .p_tokiwa .c_about_list img {
    margin: 0;
    width: 100%;
  }
  .p_pgs .c_about_list h3,
  .p_tokiwa .c_about_list h3 {
    font-weight: 700;
    margin: 1rem auto;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p_pgs .sec_kodawari,
  .p_tokiwa .sec_kodawari {
    width: 1000px;
    margin: 0 auto;
  }
  .p_pgs .sec_kodawari .subtitle,
  .p_tokiwa .sec_kodawari .subtitle {
    text-align: center;
    color: #cb4f0d;
  }
  .p_pgs .sec_kodawari .subtitle span,
  .p_tokiwa .sec_kodawari .subtitle span {
    background: #333;
    color: #fff;
    text-align: center;
    border-radius: 100px;
    padding: 5px 20px;
    margin-right: 20px;
  }
  .p_pgs .sec_kodawari .main_title,
  .p_tokiwa .sec_kodawari .main_title {
    text-align: center;
    font-size: 2rem;
    color: #333;
  }
  .p_pgs .sec_kodawari .txt_ora,
  .p_tokiwa .sec_kodawari .txt_ora {
    color: #cb4f0d;
    text-align: center;
    font-size: 1.2rem;
  }
  .p_pgs .sec_kodawari img,
  .p_tokiwa .sec_kodawari img {
    display: block;
    margin: 0 auto 50px;
  }
  .p_pgs .sec_kodawari .box ul,
  .p_tokiwa .sec_kodawari .box ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .p_pgs .sec_kodawari li,
  .p_tokiwa .sec_kodawari li {
    width: 48%;
  }
  .p_pgs .sec_kodawari .osusume,
  .p_tokiwa .sec_kodawari .osusume {
    margin-bottom: 0;
    background: #333;
    color: #e0c11d;
    text-align: center;
    border-radius: 100px;
    padding: 5px 20px;
    width: 30%;
    display: block;
    margin: 0 auto;
  }
  .p_pgs .sec_kodawari .subh3,
  .p_tokiwa .sec_kodawari .subh3 {
    font-size: 1.5rem;
    color: #cb4f0d;
    text-align: center;
  }
  .p_pgs .sec_kodawari .txt,
  .p_tokiwa .sec_kodawari .txt {
    color: #333;
    text-align: center;
  }
  .p_pgs .sec_kodawari iframe,
  .p_tokiwa .sec_kodawari iframe {
    height: 300px;
  }
  .p_pgs .sec_kodawari strong,
  .p_tokiwa .sec_kodawari strong {
    display: block;
    text-align: center;
    margin: 0 auto;
    background: #cb4f0d;
    color: #fff;
    border-radius: 100px;
    margin: 50px 0 20px;
  }
  .p_pgs .sec_kodawari .box02 ul,
  .p_tokiwa .sec_kodawari .box02 ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    background: #efefef;
    padding: 20px;
  }
  .p_pgs .sec_kodawari .box02 ul li,
  .p_tokiwa .sec_kodawari .box02 ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_pgs .sec_kodawari .box02 .left,
  .p_tokiwa .sec_kodawari .box02 .left {
    font-size: 1.5rem;
    margin-right: 20px;
    color: #333;
  }
  .p_pgs .sec_kodawari .box02 .right,
  .p_tokiwa .sec_kodawari .box02 .right {
    color: #333;
    font-size: 1.1rem;
  }
  .p_pgs .sec_kodawari .lasttxt,
  .p_tokiwa .sec_kodawari .lasttxt {
    text-align: center;
    font-size: 1.5rem;
    color: #cb4f0d;
  }
  .p_pgs .blc_more,
  .p_tokiwa .blc_more {
    background-color: #cb4f0d;
    color: #fff;
    padding: 40px 0;
  }
  .p_pgs .blc_more h2,
  .p_tokiwa .blc_more h2 {
    font-size: 1.5rem;
    text-align: center;
  }
  .p_pgs .blc_more .btn_content,
  .p_tokiwa .blc_more .btn_content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_pgs .blc_more .btn,
  .p_tokiwa .blc_more .btn {
    color: #fff;
    border: 3px solid #fff;
    margin-top: 2rem;
    height: 4rem;
  }
  .p_pgs .blc_more .btn:hover,
  .p_tokiwa .blc_more .btn:hover {
    background-color: #fff;
    color: #cb4f0d;
  }
  .p_pgs .blc_more .btn:hover::before, .p_pgs .blc_more .btn:hover::after,
  .p_tokiwa .blc_more .btn:hover::before,
  .p_tokiwa .blc_more .btn:hover::after {
    background-color: #cb4f0d;
  }
  .p_pgs .blc_more .arrow::before, .p_pgs .blc_more .arrow::after,
  .p_tokiwa .blc_more .arrow::before,
  .p_tokiwa .blc_more .arrow::after {
    background-color: #fff;
  }
  .p_pgs .sec_about .c_about_list img,
  .p_tokiwa .sec_about .c_about_list img {
    border: 5px solid #000;
  }
  .p_pgs .sec_about .machine_content > ul,
  .p_tokiwa .sec_about .machine_content > ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 50px;
    margin: 100px auto 0;
  }
  .p_pgs .sec_about .machine_content img,
  .p_tokiwa .sec_about .machine_content img {
    width: 100%;
  }
  .p_pgs .sec_about .machine_content .swiper-button-next,
  .p_pgs .sec_about .machine_content .swiper-button-prev,
  .p_tokiwa .sec_about .machine_content .swiper-button-next,
  .p_tokiwa .sec_about .machine_content .swiper-button-prev {
    display: none;
  }
  .p_pgs .sec_machine,
  .p_tokiwa .sec_machine {
    background-color: #fff;
  }
  .p_pgs .sec_machine .tab_list,
  .p_tokiwa .sec_machine .tab_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 1em;
    margin: 0 auto 3em;
  }
  .p_pgs .sec_machine [data-tab-content],
  .p_tokiwa .sec_machine [data-tab-content] {
    display: none;
  }
  .p_pgs .sec_machine [data-tab-content].is_active,
  .p_tokiwa .sec_machine [data-tab-content].is_active {
    display: block;
  }
  .p_pgs .sec_machine .machine_tab,
  .p_tokiwa .sec_machine .machine_tab {
    cursor: pointer;
    background-color: #fff;
    padding: 1em 0.5em;
    border: 5px solid #333333;
    position: relative;
    text-align: center;
    font-size: 1rem;
  }
  .p_pgs .sec_machine .machine_tab::before, .p_pgs .sec_machine .machine_tab::after,
  .p_tokiwa .sec_machine .machine_tab::before,
  .p_tokiwa .sec_machine .machine_tab::after {
    content: "";
    display: block;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    position: absolute;
  }
  .p_pgs .sec_machine .machine_tab::before,
  .p_tokiwa .sec_machine .machine_tab::before {
    background-color: #333333;
    width: 25px;
    height: 25px;
    bottom: -25px;
  }
  .p_pgs .sec_machine .machine_tab::after,
  .p_tokiwa .sec_machine .machine_tab::after {
    background-color: #fff;
    width: 15px;
    height: 15px;
    bottom: -13px;
    z-index: 10;
  }
  .p_pgs .sec_machine .machine_tab.is_active,
  .p_tokiwa .sec_machine .machine_tab.is_active {
    background-color: #333333;
    color: #fff;
  }
  .p_pgs .sec_machine .machine_tab.is_active::after,
  .p_tokiwa .sec_machine .machine_tab.is_active::after {
    display: none;
  }
  .p_pgs .sec_machine .machine_content,
  .p_tokiwa .sec_machine .machine_content {
    border: 10px solid #333333;
    padding: 4em 2em;
  }
  .p_pgs .sec_machine .machine_content > ul,
  .p_tokiwa .sec_machine .machine_content > ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 4em 2em;
    margin: 0;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
  .p_pgs .sec_machine .machine_content li,
  .p_tokiwa .sec_machine .machine_content li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: 100%;
  }
  .p_pgs .sec_machine .machine_content li:hover .mask > p,
  .p_tokiwa .sec_machine .machine_content li:hover .mask > p {
    opacity: 1;
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .p_pgs .sec_machine .machine_content li h3,
  .p_tokiwa .sec_machine .machine_content li h3 {
    font-size: 1.3rem;
    margin: auto 0 0.7em;
    display: block;
    text-align: center;
    color: #333333;
  }
  .p_pgs .sec_machine .machine_content li img,
  .p_tokiwa .sec_machine .machine_content li img {
    width: 100%;
    margin: auto 0 0;
    display: block;
    border: 5px solid #000;
  }
  .p_pgs .sec_machine .machine_content li .mask,
  .p_tokiwa .sec_machine .machine_content li .mask {
    position: relative;
  }
  .p_pgs .sec_machine .machine_content li .mask p,
  .p_tokiwa .sec_machine .machine_content li .mask p {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 30px;
    font-size: 1.1rem;
  }
  .p_pgs .sec_machine .machine_content .swiper-button-next,
  .p_pgs .sec_machine .machine_content .swiper-button-prev,
  .p_tokiwa .sec_machine .machine_content .swiper-button-next,
  .p_tokiwa .sec_machine .machine_content .swiper-button-prev {
    display: none;
  }
  .p_pgs .sec_course h3,
  .p_tokiwa .sec_course h3 {
    font-size: 2.5rem;
    line-height: 1.6;
    font-weight: 700;
    display: block;
    text-align: center;
    position: relative;
    padding: 20px;
    color: #fff;
    background: #cb4f0d;
  }
  .p_pgs .sec_course h3:before,
  .p_tokiwa .sec_course h3:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #cb4f0d;
  }
  .p_pgs .sec_course h3 span,
  .p_tokiwa .sec_course h3 span {
    display: block;
    font-size: 1rem;
  }
  .p_pgs .sec_course .content,
  .p_tokiwa .sec_course .content {
    background-color: #fff;
    border: 5px solid #cb4f0d;
    padding: 4em 2em;
    position: relative;
    margin-bottom: 1rem;
  }
  .p_pgs .sec_course dl,
  .p_tokiwa .sec_course dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_pgs .sec_course dl dt,
  .p_tokiwa .sec_course dl dt {
    color: #fff;
    width: 40%;
    background-color: #333333;
    text-align: center;
    font-size: 1.2rem;
    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;
  }
  .p_pgs .sec_course dl dt:not(:last-of-type),
  .p_tokiwa .sec_course dl dt:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  .p_pgs .sec_course dl dt.gold,
  .p_tokiwa .sec_course dl dt.gold {
    color: #e0c11d;
    font-size: 2rem;
  }
  .p_pgs .sec_course dl dt.nomal,
  .p_tokiwa .sec_course dl dt.nomal {
    font-size: 2rem;
  }
  .p_pgs .sec_course dl dt.year,
  .p_tokiwa .sec_course dl dt.year {
    color: #e3946a;
    font-size: 2rem;
  }
  .p_pgs .sec_course dl dd,
  .p_tokiwa .sec_course dl dd {
    width: 60%;
    padding: 10px 30px;
    line-height: 1.4;
    background-color: #e8e8e8;
    color: #333333;
    font-size: 1rem;
  }
  .p_pgs .sec_course dl dd span,
  .p_tokiwa .sec_course dl dd span {
    font-size: 1.3rem;
  }
  .p_pgs .sec_course dl dd span.gold,
  .p_tokiwa .sec_course dl dd span.gold {
    color: #e0c11d;
    font-size: 2rem;
  }
  .p_pgs .sec_course dl dd span.nomal,
  .p_tokiwa .sec_course dl dd span.nomal {
    font-size: 2rem;
  }
  .p_pgs .sec_course dl dd span.year,
  .p_tokiwa .sec_course dl dd span.year {
    color: #e3946a;
    font-size: 2rem;
  }
  .p_pgs .sec_course dl dd strong,
  .p_tokiwa .sec_course dl dd strong {
    font-weight: 500;
    display: block;
    font-size: 1rem;
  }
  .p_pgs .sec_course .example,
  .p_tokiwa .sec_course .example {
    border: 5px solid #6e6e6e;
    padding: 10px 30px;
    font-size: 1rem;
    background-color: #fff;
  }
  .p_pgs .sec_term .box_bg,
  .p_tokiwa .sec_term .box_bg {
    background-color: #e8e8e8;
    max-width: 1000px;
    max-height: 550px;
    margin: 0 auto;
    overflow: scroll;
  }
  .p_pgs .sec_term .box_bg div,
  .p_tokiwa .sec_term .box_bg div {
    padding: 50px;
  }
  .p_pgs .sec_access .content,
  .p_tokiwa .sec_access .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_pgs .sec_access .content iframe,
  .p_tokiwa .sec_access .content iframe {
    width: 450px;
    height: 300px;
  }
  .p_pgs .sec_access .content div,
  .p_tokiwa .sec_access .content div {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
  }
  .p_pgs .sec_access .content h3,
  .p_tokiwa .sec_access .content h3 {
    display: block;
    margin: 0 0 1.5rem 0;
  }
  .p_pgs .sec_access .content h3 span,
  .p_tokiwa .sec_access .content h3 span {
    display: block;
    color: #6e6e6e;
    font-size: 1rem;
    margin-top: 0.5em;
  }
  .p_pgs .sec_access .content p span,
  .p_tokiwa .sec_access .content p span {
    display: block;
    color: #6e6e6e;
    margin-top: 0.5em;
  }
  .p_hachiman .sec_title_icon,
  .p_sakioka .sec_title_icon {
    font-weight: 900;
  }
  .p_hachiman .sec_title_icon span:not([class]),
  .p_sakioka .sec_title_icon span:not([class]) {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e3946a));
    background: linear-gradient(transparent 60%, #e3946a 60%);
  }
  .p_hachiman .sec_about .lead,
  .p_sakioka .sec_about .lead {
    max-width: 1250px;
    margin: 0 auto;
    text-align: center;
    font-weight: 900;
    font-size: 1.6rem;
    color: #000;
  }
  .p_hachiman .sec_about .lead:not(:last-child),
  .p_sakioka .sec_about .lead:not(:last-child) {
    margin-bottom: 100px;
  }
  .p_hachiman .sec_about .lead strong,
  .p_sakioka .sec_about .lead strong {
    display: block;
    color: #cb4f0d;
    font-size: 1.6rem;
    font-weight: 900;
  }
  .p_hachiman .sec_about .lead strong span,
  .p_sakioka .sec_about .lead strong span {
    color: #cb4f0d;
    font-size: 3.2rem;
  }
  .p_hachiman .sec_about .machine_content > ul,
  .p_sakioka .sec_about .machine_content > ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 50px;
    width: 1020px;
    margin: 0 auto 100px;
  }
  .p_hachiman .sec_about .machine_content img,
  .p_sakioka .sec_about .machine_content img {
    width: 100%;
  }
  .p_hachiman .sec_about .machine_content .swiper-button-next,
  .p_hachiman .sec_about .machine_content .swiper-button-prev,
  .p_sakioka .sec_about .machine_content .swiper-button-next,
  .p_sakioka .sec_about .machine_content .swiper-button-prev {
    display: none;
  }
  .p_hachiman .sec_machine .machine_content > ul,
  .p_sakioka .sec_machine .machine_content > ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 50px;
    width: 1000px;
    margin: 0 auto;
  }
  .p_hachiman .sec_machine .machine_content li,
  .p_sakioka .sec_machine .machine_content li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: 100%;
  }
  .p_hachiman .sec_machine .machine_content li h3,
  .p_sakioka .sec_machine .machine_content li h3 {
    font-size: 1.2rem;
    margin: auto auto 20px;
    display: block;
    text-align: center;
    color: #333333;
    font-weight: bold;
  }
  .p_hachiman .sec_machine .machine_content li h3:after,
  .p_sakioka .sec_machine .machine_content li h3:after {
    display: none;
  }
  .p_hachiman .sec_machine .machine_content li img,
  .p_sakioka .sec_machine .machine_content li img {
    width: 100%;
    border: 10px solid #000;
  }
  .p_hachiman .sec_machine .machine_content .swiper-button-next,
  .p_hachiman .sec_machine .machine_content .swiper-button-prev,
  .p_sakioka .sec_machine .machine_content .swiper-button-next,
  .p_sakioka .sec_machine .machine_content .swiper-button-prev {
    display: none;
  }
  .p_hachiman .sec_course h3,
  .p_sakioka .sec_course h3 {
    font-size: 3rem;
    line-height: 1.6;
    font-weight: 700;
    display: block;
    text-align: center;
    position: relative;
    padding: 20px;
    color: #fff;
    background: #cb4f0d;
    margin-bottom: 80px;
  }
  .p_hachiman .sec_course h3:before,
  .p_sakioka .sec_course h3:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -88px;
    border: 88px solid transparent;
    border-top: 50px solid #cb4f0d;
  }
  .p_hachiman .sec_course h3:after,
  .p_sakioka .sec_course h3:after {
    display: none;
  }
  .p_hachiman .sec_course h3 span,
  .p_sakioka .sec_course h3 span {
    display: block;
    font-size: 1.6rem;
  }
  .p_hachiman .sec_course li,
  .p_sakioka .sec_course li {
    list-style: none;
  }
  .p_hachiman .sec_course li:not(:last-child),
  .p_sakioka .sec_course li:not(:last-child) {
    margin-bottom: 60px;
  }
  .p_hachiman .sec_course dl,
  .p_sakioka .sec_course dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_hachiman .sec_course dl dt,
  .p_sakioka .sec_course dl dt {
    color: #fff;
    width: 40%;
    background-color: #333333;
    text-align: center;
    font-size: 1.6rem;
    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;
    font-weight: 900;
    padding: 10px;
    margin-bottom: 40px;
  }
  .p_hachiman .sec_course dl dt.gold,
  .p_sakioka .sec_course dl dt.gold {
    color: #c4c25b;
    font-size: 2rem;
  }
  .p_hachiman .sec_course dl dt.nomal,
  .p_sakioka .sec_course dl dt.nomal {
    font-size: 2rem;
  }
  .p_hachiman .sec_course dl dt.year,
  .p_sakioka .sec_course dl dt.year {
    color: #e3946a;
    font-size: 2rem;
  }
  .p_hachiman .sec_course dl dd,
  .p_sakioka .sec_course dl dd {
    width: 60%;
    padding: 10px 30px;
    background-color: #e8e8e8;
    color: #333333;
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 40px;
  }
  .p_hachiman .sec_course dl dd span,
  .p_sakioka .sec_course dl dd span {
    font-size: 2rem;
    font-weight: 900;
    margin-right: 10px;
  }
  .p_hachiman .sec_course dl dd span.nomal,
  .p_sakioka .sec_course dl dd span.nomal {
    font-size: 2rem;
  }
  .p_hachiman .sec_course dl dd strong,
  .p_sakioka .sec_course dl dd strong {
    display: block;
    font-size: 1rem;
  }
  .p_hachiman .sec_flow .btn.big,
  .p_sakioka .sec_flow .btn.big {
    margin: 60px auto 0;
  }
  .p_hachiman .sec_gallery .machine_content > ul,
  .p_sakioka .sec_gallery .machine_content > ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 50px;
  }
  .p_hachiman .sec_gallery .machine_content .swiper-button-next,
  .p_hachiman .sec_gallery .machine_content .swiper-button-prev,
  .p_sakioka .sec_gallery .machine_content .swiper-button-next,
  .p_sakioka .sec_gallery .machine_content .swiper-button-prev {
    display: none;
  }
  .p_hachiman .sec_access,
  .p_sakioka .sec_access {
    color: #000;
  }
  .p_hachiman .sec_access .content,
  .p_sakioka .sec_access .content {
    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;
  }
  .p_hachiman .sec_access .content iframe,
  .p_sakioka .sec_access .content iframe {
    width: 450px;
    height: 300px;
    margin: 0;
  }
  .p_hachiman .sec_access .content > div,
  .p_sakioka .sec_access .content > div {
    margin-left: 50px;
  }
  .p_hachiman .sec_access .content h3,
  .p_sakioka .sec_access .content h3 {
    display: block;
    margin: 0 0 20px;
    font-weight: 900;
    font-size: 2rem;
    color: #000;
  }
  .p_hachiman .sec_access .content p,
  .p_sakioka .sec_access .content p {
    font-size: 1rem;
    font-weight: bold;
  }
  /*---- 投稿系 ---*/
  .p_post *:first-child {
    margin-top: 0;
  }
  .p_post *:last-child {
    margin-bottom: 0;
  }
  .p_post h1:not([class]) {
    color: #e0c11d;
    font-size: 1.25rem;
    margin: 1.5rem 0 2.5rem;
    padding-bottom: 1rem;
    border-bottom: 5px solid #6e6e6e;
  }
  .p_post h2:not([class]) {
    color: #e0c11d;
    padding: 0.5rem 0.5rem 0.5rem 2rem;
    position: relative;
    font-size: 1.25rem;
  }
  .p_post h2:not([class])::before {
    position: absolute;
    content: "";
    width: 1rem;
    height: 3px;
    border-radius: 10px;
    background-color: #e0c11d;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 0;
  }
  .p_post h3:not([class]) {
    color: #fff;
    background-color: #e0c11d;
    padding: 0.5rem 1rem;
  }
  .p_post h4:not([class]) {
    background-color: #6e6e6e;
    color: #fff;
    padding: 0.5rem 1rem;
  }
  .p_post article a {
    text-decoration: underline;
  }
  .p_post article span {
    color: #e0c11d;
  }
  .p_post .c_post_link {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    padding: 0 60px;
    margin: 3rem auto 2rem;
    position: relative;
  }
  .p_post .c_post_link .btn {
    min-width: 220px;
  }
  .p_post .c_post_link .prev a,
  .p_post .c_post_link .next a {
    position: absolute;
    width: 40px;
    height: 70px;
    background-color: #6e6e6e;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transition: background 0.3s;
    transition: background 0.3s;
    top: 50%;
  }
  .p_post .c_post_link .prev a:hover,
  .p_post .c_post_link .next a:hover {
    background-color: #e0c11d;
  }
  .p_post .c_post_link .prev a {
    left: 0;
    -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
            clip-path: polygon(0 50%, 100% 0, 100% 100%);
  }
  .p_post .c_post_link .next a {
    right: 0;
    -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
            clip-path: polygon(0 0, 0 100%, 100% 50%);
  }
  .p_single .thumb {
    margin: 1rem auto 1.5rem;
    text-align: center;
  }
  .p_single .info {
    margin-bottom: 0.5rem;
    font-size: 1rem;
  }
  .p_single .cat {
    margin-left: 0.5rem;
  }
  .p_single .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    display: inline-block;
  }
  .p_single .cat a:not(:first-of-type) {
    margin-left: 0.5rem;
  }
  /*--- footer ---*/
  footer .blc_cta {
    background-color: #6e6e6e;
    padding: 1.5rem 0;
    color: #fff;
  }
  footer .blc_cta .inner {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .blc_cta .tel .title {
    font-size: 1rem;
    line-height: 1.2;
  }
  footer .blc_cta .tel .title img {
    margin-right: 1rem;
    vertical-align: middle;
  }
  footer .blc_cta .tel a {
    font-size: 2rem;
    line-height: 1.2;
  }
  footer .l_footer {
    padding: 2.5rem 0;
  }
  footer .l_footer .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  footer .l_footer .map_col {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 400px;
            flex: 0 1 400px;
  }
  footer .l_footer .info_col {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 600px;
            flex: 0 1 600px;
    padding: 0 2rem;
  }
  footer .l_footer .logo_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    margin-bottom: 1.5rem;
  }
  footer .l_footer .info_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 100px 1fr;
        grid-template-columns: 100px 1fr;
    gap: 0.5rem 1rem;
  }
  footer .l_footer .info_list dt {
    border: 1px solid #6e6e6e;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .f_bottom {
    padding: 0.5rem 0;
    background-color: #6e6e6e;
    color: #fff;
  }
  footer .f_bottom .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .f_bottom .menu_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  footer .f_bottom .menu_list li {
    padding: 0 0.5rem;
    line-height: 1.2;
  }
  footer .f_bottom .menu_list li:not(:first-of-type) {
    border-left: 1px solid #fff;
  }
  .smonly {
    display: none;
  }
}

@media (max-width: 767px) {
  /*--- 全共通 ---*/
  html {
    font-size: 100%;
  }
  body {
    position: relative;
    font-family: "Noto Sans JP", "Hiragino Sans", sans-serif;
    margin: 0 auto;
    color: #6e6e6e;
    font-weight: 500;
    line-height: 1.6;
    font-size: 1rem;
  }
  body *:first-child {
    margin-top: 0;
  }
  body *:last-child {
    margin-bottom: 0;
  }
  body::-webkit-scrollbar {
    display: none;
  }
  body p {
    line-height: 2;
  }
  body ul:not([class]) {
    margin: 1rem 0 1rem 1.5rem;
    list-style-type: disc;
  }
  body ol:not([class]) {
    margin: 1rem 0 1rem 1.5rem;
    list-style-type: decimal;
  }
  body dl:not([class]) {
    margin: 2rem 0 1rem;
  }
  body dl:not([class]) dt {
    font-size: 1rem;
    color: #fff;
    background-color: #6e6e6e;
    padding: 0.5rem 1rem;
  }
  body dl:not([class]) dd {
    padding: 1rem 0rem;
    line-height: 2;
    margin-bottom: 1rem;
  }
  body iframe {
    width: 100%;
    display: block;
    margin: 0 auto 1rem;
  }
  body table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1rem;
    border: 3px solid #6e6e6e;
    font-size: 0.9rem;
  }
  body table caption {
    font-size: 1.25rem;
  }
  body table caption small {
    display: block;
    font-size: 0.75rem;
    text-align: right;
  }
  body table th,
  body table td {
    padding: 1rem 5px;
    border: 1px solid #6e6e6e;
    text-align: center;
  }
  body table td {
    background-color: #fff;
    color: #6e6e6e;
  }
  body table th {
    text-align: center;
    background-color: #6e6e6e;
    color: #fff;
    font-size: 1rem;
  }
  body table .gold {
    background-color: #e0c11d;
    color: #fff;
    font-weight: bold;
  }
  body table .white {
    background-color: #fff;
    color: #6e6e6e;
  }
  body select,
  body textarea,
  body input[type="url"],
  body input[type="text"],
  body input[type="date"],
  body input[type="tel"],
  body input[type="email"],
  body input[type="number"] {
    display: block;
    background-color: #e8e8e8;
    padding: 0.7rem 0.5rem;
    font-size: 1rem;
  }
  body textarea,
  body input[type="url"],
  body input[type="text"],
  body input[type="date"],
  body input[type="tel"],
  body input[type="email"],
  body input[type="number"] {
    width: 100%;
  }
  body select {
    width: 100%;
  }
  body input[type="checkbox"],
  body input[type="radio"] {
    margin: 0 0.5rem;
  }
  body input[type="submit"],
  body button[type="submit"] {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    outline: none;
    -webkit-transition: 0.5s all;
    transition: 0.5s all;
    background-color: inherit;
    max-width: 300px;
  }
  body .t_al {
    text-align: left;
  }
  body .t_ac {
    text-align: center;
  }
  body .t_ar {
    text-align: right;
  }
  body .imgleft,
  body .imgright {
    margin: 1rem 0 2rem;
  }
  body .imgleft .img,
  body .imgright .img {
    text-align: center;
    margin-bottom: 1rem;
  }
  body .imgright {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  body .inner {
    padding: 0 1rem;
    margin: 0 auto;
  }
  body .btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-decoration: none;
    padding: 0.5rem;
    width: 100%;
    max-width: 400px;
    min-height: 50px;
    color: #6e6e6e;
    border: 3px solid #6e6e6e;
    font-size: 1rem;
    line-height: 1.2;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    margin: 1rem auto;
    position: relative;
    cursor: pointer;
    font-weight: bold;
  }
  body .btn img {
    margin-right: 0.5rem;
  }
  body .btn:hover {
    opacity: 1;
    background-color: #6e6e6e;
    color: #fff;
  }
  body .btn.arrow {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding-right: 2.5rem;
  }
  body .btn.arrow::before, body .btn.arrow::after {
    position: absolute;
    content: "";
    background-color: #6e6e6e;
    height: 2px;
    right: 0.5rem;
    top: calc(50% + 3px);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  body .btn.arrow::before {
    width: 20px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  body .btn.arrow::after {
    width: 10px;
    -webkit-transform-origin: right center;
            transform-origin: right center;
    -webkit-transform: translateY(-50%) rotate(35deg);
            transform: translateY(-50%) rotate(35deg);
  }
  body .btn.arrow:hover::before, body .btn.arrow:hover::after {
    background-color: #fff;
  }
  body .btn.white {
    color: #fff;
    border: 3px solid #fff;
  }
  body .btn.white:hover {
    background-color: #aaafb1;
  }
  body .btn.white.arrow::before, body .btn.white.arrow::after {
    background-color: #fff;
  }
  body .btn.white.arrow:hover::before, body .btn.white.arrow:hover::after {
    background-color: #6e6e6e;
  }
  body .btn.white2 {
    color: #000;
    border: 5px solid #000;
    background-color: #fff;
    font-size: 0.9rem;
  }
  body .btn.white2:hover {
    background-color: #aaafb1;
    color: #fff;
    border: 5px solid #aaafb1;
  }
  body .btn.white2.arrow::before, body .btn.white2.arrow::after {
    background-color: #000;
  }
  body .btn.white2.arrow:hover::before, body .btn.white2.arrow:hover::after {
    background-color: #fff;
  }
  body .btn.gray {
    color: #fff;
    border: none;
    background-color: #6e6e6e;
  }
  body .btn.gray:hover {
    background-color: #e0c11d;
    color: #fff;
  }
  body .btn.gray.arrow::before, body .btn.gray.arrow::after {
    height: 2px;
    background-color: #fff;
  }
  body .btn.gray.arrow:hover::before, body .btn.gray.arrow:hover::after {
    background-color: #fff;
  }
  body .btn.black {
    color: #000;
    border: 3px solid #000;
  }
  body .btn.black::before, body .btn.black::after {
    height: 2px;
    background-color: #000;
  }
  body .btn.black:hover {
    background: #000;
    color: #fff;
  }
  body .btn.org {
    color: #fff;
    border: 3px solid #cb4f0d;
    background: #cb4f0d;
  }
  body .btn.org img {
    margin-left: 20px;
    vertical-align: middle;
  }
  body .btn.org:hover {
    background: #cba10d;
    border: 3px solid #cba10d;
  }
  body .btn.org.big {
    font-size: 1.2rem;
    max-width: 100%;
    padding: 20px;
  }
  body .btn.line {
    background-color: #06c755;
    color: #fff;
    border: none;
    -webkit-box-shadow: 0 6px #157c3f;
            box-shadow: 0 6px #157c3f;
    position: relative;
    top: 0;
    font-size: 1.5rem;
  }
  body .btn.line img {
    max-width: 50px;
  }
  body .btn.line:hover {
    color: #fff;
    top: -4px;
    -webkit-box-shadow: 0 10px #157c3f;
            box-shadow: 0 10px #157c3f;
  }
  body .btn.ygreen {
    background-color: #bcce32;
    color: #fff;
    border: none;
    border-radius: 5px;
    -webkit-box-shadow: 0 6px #78841a;
            box-shadow: 0 6px #78841a;
    padding: 1rem 0.5rem;
    position: relative;
    top: 0;
    font-size: 1.3rem;
    max-width: 500px;
  }
  body .btn.ygreen:hover {
    color: #fff;
    top: 4px;
    -webkit-box-shadow: 0 0 #78841a;
            box-shadow: 0 0 #78841a;
  }
  body .btn.center {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  body .p_cta {
    text-align: center;
    margin: 20px auto;
    padding: 10px;
  }
  body .p_cta .cmp {
    font-size: 0.9rem;
  }
  body .p_cta .cmp span {
    display: block;
    margin: 0 auto;
    font-size: 0.8rem;
    text-align: center;
  }
  body .p_cta .caution {
    font-size: 0.4rem;
  }
  body .small {
    text-align: center;
  }
  body .grecaptcha-badge {
    visibility: hidden;
  }
  /*---- header ----*/
  header {
    position: relative;
  }
  header .l_header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    color: #fff;
    z-index: 10;
    padding: 10px 0;
    -webkit-transition: background 0.3s;
    transition: background 0.3s;
  }
  header .l_header .inner .logo img {
    max-height: 80px;
  }
  header .l_header.show {
    background-color: rgba(110, 110, 110, 0.8);
  }
  header .l_header.scroll {
    background-color: rgba(110, 110, 110, 0.8);
  }
  header .h_menu {
    position: relative;
  }
  header .h_menu .reserb_list li {
    margin-bottom: 0.5rem;
  }
  header .h_menu .reserb_list li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    display: block;
    padding: 1rem 0.5rem;
    line-height: 1.2;
    background-color: rgba(224, 193, 29, 0.8);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  header .h_menu .reserb_list li a:hover {
    background-color: #e0c11d;
    opacity: 1;
  }
  header .h_menu .menu_list {
    color: #fff;
  }
  header .h_menu .menu_list > li {
    margin-bottom: 0.5rem;
  }
  header .h_menu .menu_list > li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    display: block;
    padding: 0.5rem 0.5rem;
    line-height: 1.2;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  header .h_menu .menu_list > li .sub_menu {
    padding-left: 30px;
  }
  header .h_menu .menu_list > li .sub_menu a {
    position: relative;
  }
  header .h_menu .menu_list > li .sub_menu a:after {
    position: absolute;
    content: "＞";
    left: -20px;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  header .h_menu .h_nav {
    z-index: 100;
    position: fixed;
    top: 0;
    right: 0px;
    min-width: 300px;
    width: 50%;
    max-width: 600px;
    height: 100vh;
    background-color: #aaafb1;
    padding: 80px 10px 30px;
    overflow-y: auto;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
  }
  header .h_menu .h_nav.open {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
  header .h_menu .h_nav_btn {
    z-index: 150;
    display: inline-block;
    width: 40px;
    height: 30px;
    cursor: pointer;
    position: fixed;
    top: 30px;
    right: 20px;
    z-index: 100;
  }
  header .h_menu .h_nav_btn span {
    display: inline-block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 100%;
    height: 6px;
    background-color: #000;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  header .h_menu .h_nav_btn span:nth-of-type(1) {
    top: 3%;
  }
  header .h_menu .h_nav_btn span:nth-of-type(3) {
    top: 97%;
  }
  header .h_menu .h_nav_btn.open span {
    background-color: #000;
    border: 1px solid #000;
  }
  header .h_menu .h_nav_btn.open span:nth-of-type(1) {
    -webkit-transform: translate(-50%, -50%) rotate(135deg);
            transform: translate(-50%, -50%) rotate(135deg);
    top: 50%;
  }
  header .h_menu .h_nav_btn.open span:nth-of-type(2) {
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
    opacity: 0;
  }
  header .h_menu .h_nav_btn.open span:nth-of-type(3) {
    -webkit-transform: translate(-50%, -50%) rotate(-135deg);
            transform: translate(-50%, -50%) rotate(-135deg);
    top: 50%;
  }
  header .h_menu .modal_bg {
    position: fixed;
    z-index: 99;
    width: 100%;
    height: 0;
    background-color: rgba(0, 0, 0, 0.7);
    top: 0;
    left: 0;
    opacity: 0;
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  header .h_menu .modal_bg.open {
    height: 100vh;
    opacity: 1;
  }
  header .sub_catch {
    position: relative;
  }
  header .sub_catch .bg_img {
    min-height: 300px;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    -o-object-fit: cover;
       object-fit: cover;
  }
  header .sub_catch .inner {
    background-color: rgba(110, 110, 110, 0.8);
  }
  header .sub_catch .txt_blc {
    width: 100%;
    color: #fff;
    padding: 1rem 0;
  }
  header .sub_catch .txt_blc .page_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1.8rem;
  }
  header .sub_catch2 {
    position: relative;
  }
  header .sub_catch2 .bg_img {
    min-height: 300px;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    -o-object-fit: cover;
       object-fit: cover;
  }
  header .sub_catch2 .img {
    width: 100%;
  }
  header .sub_catch2 .inner {
    background-color: rgba(110, 110, 110, 0.8);
  }
  header .blc_catch {
    position: relative;
  }
  header .blc_catch .bg_img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    -o-object-fit: cover;
       object-fit: cover;
  }
  header .blc_catch .swiper-container {
    overflow: hidden;
  }
  header .blc_catch .swiper-slide {
    position: relative;
  }
  header .blc_catch .inner {
    padding: 180px 1rem 2rem;
    min-height: 100vh;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  header .blc_catch .txt_blc {
    width: 100%;
    top: 0;
    left: 0;
    background-color: rgba(110, 110, 110, 0.8);
    padding: 180px 2rem 2rem;
    padding: 1rem;
    color: #fff;
  }
  header .blc_catch .txt_blc p {
    font-size: 1rem;
    margin-bottom: 1.5rem;
  }
  header .blc_catch .txt_blc .btn {
    min-height: 70px;
  }
  header .blc_catch .txt_blc .page_title {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 2.5rem;
    white-space: nowrap;
  }
  header .org_title {
    background: #cb4f0d;
    color: #fff;
    text-align: center;
    font-weight: 900;
    font-size: 5vw;
    padding: 120px 20px 20px;
  }
  /*---- ベースとcompornent ----*/
  main {
    padding: 2rem 0;
    /*---- 見出し系 ----*/
    /*---- セクション ----*/
    /*---- コンポーネント----*/
  }
  main section {
    padding: 3rem 0;
  }
  main section .inner > *:first-child {
    margin-top: 0;
  }
  main section .inner > *:last-child {
    margin-bottom: 0;
  }
  main h1:not([class]),
  main h2:not([class]),
  main h3:not([class]),
  main h4:not([class]),
  main h5:not([class]),
  main h6:not([class]) {
    margin: 2rem 0 1rem;
    font-size: 1rem;
    line-height: 1.2;
  }
  main p {
    margin-bottom: 1.5em;
  }
  main strong {
    font-size: 1.5em;
  }
  main img {
    margin-bottom: 1rem;
  }
  main blockquote {
    padding: 1rem 1rem;
    margin: 1rem auto;
    background-color: #e8e8e8;
    border-radius: 1rem;
  }
  main blockquote *:first-child {
    margin-top: 0;
  }
  main blockquote *:last-child {
    margin-bottom: 0;
  }
  main .sec_title {
    font-size: 7.2vw;
    margin: 1rem auto 2rem;
    text-align: center;
    color: #333333;
    font-weight: bold;
    border-top: 4px double #6e6e6e;
    border-bottom: 4px double #6e6e6e;
  }
  main .sec_title_icon {
    margin-bottom: 2rem;
    font-size: 1.3rem;
    text-align: center;
    color: #000;
    font-weight: bold;
    padding-bottom: 10px;
  }
  main .sec_title_icon span:not([class]) {
    display: inline;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e0c11d));
    background: linear-gradient(transparent 60%, #e0c11d 60%);
  }
  main .sec_title_icon .line {
    color: #cba10d;
    margin-top: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main .sec_title_icon .line::before {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 5px;
    background-color: #cba10d;
    margin-right: 1rem;
  }
  main .sec_title_icon .line::after {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 5px;
    background-color: #cba10d;
    margin-left: 1rem;
  }
  main .sec_title_icon img {
    display: block;
    margin: 0 auto 0.5rem;
    width: 50px;
  }
  main .t_gold {
    font-size: 1.25rem;
    color: #e0c11d;
    margin: 3rem 0 2rem;
  }
  main .t_listtitle {
    font-size: 1.5rem;
    margin: 2rem 0 1rem;
  }
  main .t_listtitle small {
    display: block;
    font-size: 1rem;
  }
  main .blc_img {
    margin: 2rem 0;
    display: block;
  }
  main .blc_reserve {
    background-color: #e0c11d;
    color: #fff;
    padding: 1.5rem 0;
    color: #fff;
  }
  main .blc_reserve .btn {
    color: #fff;
    border: 3px solid #fff;
  }
  main .blc_reserve .btn:hover {
    background-color: #fff;
    color: #e0c11d;
  }
  main .blc_reserve .btn.arrow::before, main .blc_reserve .btn.arrow::after {
    background-color: #fff;
  }
  main .blc_reserve .btn.arrow:hover::before, main .blc_reserve .btn.arrow:hover::after {
    background-color: #e0c11d;
  }
  main .blc_reserve .title {
    font-size: 1.5rem;
    text-align: center;
    margin-bottom: 1rem;
  }
  main .blc_reserve .cta_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (300px)[auto-fill];
        grid-template-columns: repeat(auto-fill, 300px);
    gap: 1rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  main .blc_reserve .tel {
    text-align: center;
  }
  main .blc_reserve .tel p {
    font-size: 1rem;
    line-height: 1.2;
    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;
    margin-bottom: 0.5rem;
  }
  main .blc_reserve .tel img {
    margin-right: 0.5rem;
    vertical-align: middle;
  }
  main .blc_reserve .tel a {
    font-size: 2rem;
    line-height: 1.2;
  }
  main .blc_service {
    padding: 2rem 0;
  }
  main .blc_service .link_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(240px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
  }
  main .blc_service .link_list li {
    position: relative;
    overflow: hidden;
  }
  main .blc_service .link_list a {
    display: block;
  }
  main .blc_service .link_list a img {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    -webkit-transform: scale(1);
            transform: scale(1);
    display: block;
    width: 100%;
  }
  main .blc_service .link_list a:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  main .blc_service .link_list .title {
    position: absolute;
    z-index: 1;
    width: 100%;
    padding: 1rem;
    background-color: rgba(0, 0, 0, 0.4);
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    font-size: 1rem;
    font-weight: bold;
  }
  main .table_wrap {
    margin: 1rem auto 2rem;
    overflow-x: auto;
  }
  main .table_wrap table {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    min-width: 100%;
  }
  main .bg_gray {
    background-color: #e8e8e8;
    padding: 2rem 1rem;
  }
  main .bg_img01 {
    background-image: image-set(url(images/common/bg_01.png) 1x, url(images/common/bg_01@2x.png) 2x);
    background-image: -webkit-image-set(url(images/common/bg_01.png) 1x, url(images/common/bg_01@2x.png) 2x);
    padding: 2rem 1rem;
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .bg_img02 {
    background-image: image-set(url(images/common/bg_02.jpg) 1x, url(images/common/bg_02@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_02.jpg) 1x, url(images/common/bg_02@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .bg_img03 {
    background-image: image-set(url(images/common/bg_03.jpg) 1x, url(images/common/bg_03@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_03.jpg) 1x, url(images/common/bg_03@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .bg_gold {
    background-image: image-set(url(images/common/bg_gold.jpg) 1x, url(images/common/bg_gold@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_gold.jpg) 1x, url(images/common/bg_gold@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
    margin: 0 -1rem;
  }
  main .bg_hexagon {
    background-image: image-set(url(images/common/bg_hexagon.jpg) 1x, url(images/common/bg_hexagon@2x.jpg) 2x);
    background-image: -webkit-image-set(url(images/common/bg_hexagon.jpg) 1x, url(images/common/bg_hexagon@2x.jpg) 2x);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio,
  main .wpcf7-form-control-wrap .wpcf7-checkbox {
    display: block;
    padding: 0.8rem 0;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item,
  main .wpcf7-form-control-wrap .wpcf7-checkbox .wpcf7-list-item {
    display: inline-block;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item:not(:last-of-type),
  main .wpcf7-form-control-wrap .wpcf7-checkbox .wpcf7-list-item:not(:last-of-type) {
    padding-right: 0.5rem;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label {
    cursor: pointer;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label input,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label input {
    display: none;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label input:checked + .wpcf7-list-item-label::after,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label input:checked + .wpcf7-list-item-label::after {
    display: block;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label {
    padding-left: 30px;
    position: relative;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::before, main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::after,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::before,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::after {
    position: absolute;
    content: "";
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 0;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::after,
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::after {
    display: none;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::before {
    left: 0;
    border-radius: 50%;
    width: 16px;
    height: 16px;
  }
  main .wpcf7-form-control-wrap .wpcf7-radio label .wpcf7-list-item-label::after {
    left: 3px;
    border-radius: 50%;
    width: 10px;
    height: 10px;
  }
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::before {
    left: 0;
    width: 16px;
    height: 16px;
    border: 1px solid #e0c11d;
  }
  main .wpcf7-form-control-wrap .wpcf7-checkbox label .wpcf7-list-item-label::after {
    left: 4px;
    width: 18px;
    height: 10px;
    border-left: 2px solid #e0c11d;
    border-bottom: 2px solid #e0c11d;
    -webkit-transform-origin: 25% center;
            transform-origin: 25% center;
    -webkit-transform: rotate(-45deg) translateY(-50%);
            transform: rotate(-45deg) translateY(-50%);
  }
  main .c_post_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(240px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 2em 1rem;
    padding: 1.5rem 1rem;
    background-color: #e8e8e8;
    margin: 1rem auto 2rem;
  }
  main .c_post_list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    background-color: #fff;
  }
  main .c_post_list .info {
    margin-bottom: 0.5rem;
  }
  main .c_post_list .cat {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 5px;
  }
  main .c_post_list .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    display: inline-block;
  }
  main .c_post_list .thumb {
    width: 100%;
    position: relative;
  }
  main .c_post_list .thumb::before {
    content: "";
    display: block;
    padding-top: 62.5%;
  }
  main .c_post_list .thumb img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  main .c_post_list .text {
    padding: 0.5rem;
  }
  main .c_post_list .btn {
    margin-top: auto;
    width: 100%;
    max-width: 100%;
    min-height: 50px;
  }
  main .c_news_list li {
    padding-bottom: 1rem;
    border-bottom: 3px solid #6e6e6e;
  }
  main .c_news_list li:not(:first-of-type) {
    padding-top: 1rem;
  }
  main .c_news_list .info {
    margin-bottom: 0.5rem;
  }
  main .c_news_list .cat {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 5px;
  }
  main .c_news_list .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    max-width: 100%;
    display: inline-block;
  }
  main .c_service_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
  }
  main .c_service_list li {
    border: 3px solid #6e6e6e;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main .c_service_list .thumb img {
    width: 100% !important;
    max-height: 200px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  main .c_service_list .title {
    text-align: center;
    font-size: 1.25rem;
    color: #fff;
    padding: 0.5rem;
    background-color: #e0c11d;
  }
  main .c_service_list .text {
    padding: 1rem;
  }
  main .c_service_list .btn {
    margin: 0;
    margin-top: auto;
    min-height: 40px;
    max-width: 100%;
  }
  main .c_service_list .acc_content {
    display: none;
  }
  main .c_service_list .acc_content.open {
    display: block;
  }
  main .c_service_link {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.5rem 2.5rem;
  }
  main .c_service_link li {
    position: relative;
  }
  main .c_service_link img {
    width: 100%;
  }
  main .c_service_link .title {
    position: absolute;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 0;
    width: 100%;
    text-align: center;
    font-size: 1rem;
    color: #fff;
    padding: 1rem 0.5rem;
    background-color: rgba(0, 0, 0, 0.4);
  }
  main .c_link_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(240px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem 2rem;
    margin: 1rem 0 3rem;
  }
  main .c_qa_list {
    margin: 1rem auto 2rem;
    padding: 1rem 0.5rem;
    background-color: #e8e8e8;
    border: 2px solid #6e6e6e;
  }
  main .c_qa_list .acc_label {
    cursor: pointer;
  }
  main .c_qa_list .acc_content {
    display: none;
  }
  main .c_qa_list .acc_content.open {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  main .c_qa_list dt {
    position: relative;
    font-size: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: #fff;
    background-color: #6e6e6e;
    margin-bottom: 1.5rem;
  }
  main .c_qa_list dt::before {
    content: "Q";
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    font-size: 2rem;
    padding-right: 0.5rem;
  }
  main .c_qa_list dd {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    color: #6e6e6e;
    margin-bottom: 2.5rem;
  }
  main .c_qa_list dd::before {
    content: "A";
    color: #e0c11d;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    font-size: 2rem;
    padding-right: 0.5rem;
  }
  main .c_part_list {
    margin: 2rem 0 1rem;
  }
  main .c_part_list dt,
  main .c_part_list dd {
    border: 1.5px solid #6e6e6e;
    padding: 1rem;
  }
  main .c_part_list dt {
    font-size: 1rem;
    color: #fff;
    background-color: #6e6e6e;
    padding: 0.5rem 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main .c_part_list dd {
    background-color: #fff;
    color: #6e6e6e;
  }
  main .c_dot_list {
    margin: 1rem auto 2rem;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(360px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  }
  main .c_dot_list li {
    padding: 5px 10px 5px 20px;
    position: relative;
  }
  main .c_dot_list li::before {
    position: absolute;
    content: "";
    left: 0;
    top: 12px;
    width: 10px;
    height: 10px;
    background-color: #e0c11d;
  }
  main .blc_form input[type="submit"] {
    margin-bottom: 0;
  }
  main .c_form_list {
    max-width: 570px;
    margin: 1rem auto 2.5rem;
  }
  main .c_form_list dt,
  main .c_form_list dd {
    margin-bottom: 1rem;
  }
  main .c_form_list dt span {
    margin-left: 5px;
    color: #e0c11d;
  }
  main .c_check_list {
    padding: 1rem 0.5rem;
    background-color: #fff;
    border: 3px solid #6e6e6e;
    margin: 1rem auto 2rem;
    max-width: 900px;
  }
  main .c_check_list li {
    padding-left: 2rem;
    position: relative;
  }
  main .c_check_list li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  main .c_check_list li::before {
    position: absolute;
    content: "";
    top: 50%;
    left: 4px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 14px;
    height: 8px;
    border-left: 3px solid #e0c11d;
    border-bottom: 3px solid #e0c11d;
  }
  main .c_checkbox_list {
    padding: 1rem 0.5rem;
    background-color: #fff;
    border: 3px solid #6e6e6e;
    margin: 1rem auto 2rem;
    max-width: 900px;
  }
  main .c_checkbox_list > li {
    padding-left: 2rem;
    position: relative;
  }
  main .c_checkbox_list > li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  main .c_checkbox_list > li::before, main .c_checkbox_list > li::after {
    position: absolute;
    content: "";
    top: 50%;
  }
  main .c_checkbox_list > li::before {
    left: 4px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 14px;
    height: 8px;
    border-left: 3px solid #e0c11d;
    border-bottom: 3px solid #e0c11d;
  }
  main .c_checkbox_list > li::after {
    left: 0px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: 2px solid #6e6e6e;
  }
  main .c_checkbox_list2 {
    padding: 1rem 1rem;
    background-color: #fff;
    border: 5px solid #cba10d;
    margin: 1rem auto 1rem;
    font-size: 1rem;
    color: #000;
  }
  main .c_checkbox_list2 > li {
    padding-left: 2.5rem;
    position: relative;
  }
  main .c_checkbox_list2 > li:not(:last-of-type) {
    margin-bottom: 0.9rem;
  }
  main .c_checkbox_list2 > li::before, main .c_checkbox_list2 > li::after {
    position: absolute;
    content: "";
    top: 50%;
  }
  main .c_checkbox_list2 > li::before {
    left: 7px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 18px;
    height: 12px;
    border-left: 4px solid #fff;
    border-bottom: 4px solid #fff;
    z-index: 2;
  }
  main .c_checkbox_list2 > li::after {
    left: 0px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 30px;
    height: 30px;
    background-color: #000;
    border: 2px solid #000;
    border-radius: 5px;
    z-index: 1;
  }
  main .c_checkbox_list2 > li span {
    color: #cba10d;
  }
  main .c_checkbox_list3 {
    padding: 1rem 0.5rem;
    background-color: #fff;
    border: 5px solid #cb4f0d;
    margin: 1rem auto 1rem;
    font-size: 1rem;
    color: #000;
  }
  main .c_checkbox_list3 > li {
    padding-left: 2.5rem;
    position: relative;
  }
  main .c_checkbox_list3 > li:not(:last-of-type) {
    margin-bottom: 0.9rem;
  }
  main .c_checkbox_list3 > li::before, main .c_checkbox_list3 > li::after {
    position: absolute;
    content: "";
    top: 50%;
  }
  main .c_checkbox_list3 > li::before {
    left: 7px;
    -webkit-transform-origin: 25% 50%;
            transform-origin: 25% 50%;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 18px;
    height: 12px;
    border-left: 4px solid #fff;
    border-bottom: 4px solid #fff;
    z-index: 2;
  }
  main .c_checkbox_list3 > li::after {
    left: 0px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 30px;
    height: 30px;
    background-color: #000;
    border: 2px solid #000;
    border-radius: 5px;
    z-index: 1;
  }
  main .c_value_list {
    padding: 1rem;
    margin-bottom: 1rem;
  }
  main .c_value_list p {
    line-height: 1.5;
  }
  main .c_value_list li {
    background-color: #fff;
    border: 10px solid #e0c11d;
    padding: 0.8rem;
    text-align: center;
    font-size: 1rem;
    color: #000;
    margin-bottom: 1rem;
  }
  main .c_value_list li .point {
    font-size: 1.7rem;
    font-weight: bold;
  }
  main .c_value_list li .list_price {
    font-size: 1.4rem;
    text-decoration: line-through;
  }
  main .c_value_list li .price {
    font-size: 2.5rem;
    color: #cba10d;
  }
  main .c_course_list > li {
    background-color: #fff;
    border: 5px solid #cba10d;
    padding: 1rem;
    font-size: 1rem;
    font-weight: normal;
    color: #000;
    margin-bottom: 2rem;
  }
  main .c_course_list > li .course_name {
    font-size: 1.5rem;
    color: #cba10d;
    font-weight: bold;
    text-align: center;
    margin-bottom: 1rem;
  }
  main .c_course_list > li .sub_title {
    background-color: #cba10d;
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    padding: 0.3rem 0.5rem;
    margin: 1.5rem 0 1rem;
  }
  main .c_course_list > li .recommend_list {
    margin: 1.5rem 0;
    list-style-type: none;
  }
  main .c_course_list > li .recommend_list > li {
    margin-bottom: 1rem;
  }
  main .c_course_list > li .gold {
    font-size: 1.2rem;
    color: #cba10d;
    font-weight: bold;
    text-align: center;
    margin: 0 0 1rem;
  }
  main .c_course_list > li .price_table {
    table-layout: fixed;
  }
  main .c_course_list > li .price_table th {
    font-weight: bold;
  }
  main .c_reason_list > li {
    margin-bottom: 1.5rem;
  }
  main .c_reason_list > li p {
    margin-bottom: 1rem;
  }
  main .c_reason_list > li .text {
    padding: 0 1rem 1rem;
    background-color: #fff;
    -webkit-box-shadow: 3px 6px 20px -4px #e8e8e8;
            box-shadow: 3px 6px 20px -4px #e8e8e8;
  }
  main .c_reason_list > li .text > img {
    width: 100px;
    margin-bottom: 0;
  }
  main .c_reason_list > li .text .title {
    font-size: 1.3rem;
    color: #e0c11d;
    margin-bottom: 1rem;
  }
  main .c_reason_list > li .text .inbody {
    text-align: center;
  }
  main .c_caption_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(200px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
    margin: 2.5rem 0;
  }
  main .c_caption_list figure {
    position: relative;
  }
  main .c_caption_list figure img {
    margin: 0;
    width: 100%;
  }
  main .c_caption_list figure figcaption {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    padding: 1rem 0.5rem;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.3);
  }
  main .c_bd_blc {
    padding: 1rem;
    border: 3px solid #6e6e6e;
    max-width: 900px;
    margin: 1rem auto 2rem;
    text-align: center;
    font-size: 1.25rem;
  }
  main .c_bd_blc .slash {
    position: relative;
  }
  main .c_bd_blc .slash::after {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    width: 100%;
    height: 3px;
    background-color: #e0c11d;
    -webkit-transform: translate(-50%, -50%) rotate(20deg);
            transform: translate(-50%, -50%) rotate(20deg);
  }
  main .c_bd_blc strong {
    font-weight: bold;
    font-size: 1.75rem;
    color: #e0c11d;
    margin: 0 1rem;
  }
  main .c_bd_blc b {
    font-weight: bold;
  }
  main .c_bd_blc small {
    font-size: 0.75rem;
    display: block;
  }
  main .c_trainer_list > li {
    border: 5px solid #000;
    background-color: #fff;
    padding: 1rem;
    color: #000;
  }
  main .c_trainer_list > li .name {
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }
  main .c_trainer_list > li .name small {
    margin-left: 1rem;
    font-size: 0.75rem;
    vertical-align: middle;
  }
  main .c_map_blc:not(:last-of-type) {
    margin-bottom: 2.5rem;
  }
  main .c_map_blc iframe {
    width: 100%;
    margin-bottom: 1rem;
  }
  main .c_map_blc .title {
    padding: 1rem 0;
    font-size: 1.5rem;
    margin: 0;
    border-bottom: 3px solid #6e6e6e;
  }
  main .c_map_blc .address {
    font-size: 1rem 0;
  }
  main .c_map_blc p {
    border-bottom: 3px solid #6e6e6e;
    padding: 1rem 0;
    margin: 0;
  }
  main .c_map_blc2 {
    color: #000;
    font-size: 1rem;
  }
  main .c_map_blc2 iframe {
    width: 100%;
    margin-bottom: 1.5rem;
  }
  main .c_map_blc2 .title {
    text-align: center;
    font-size: 1.3rem;
    margin-bottom: 1rem;
  }
  main .c_map_blc2 .address {
    margin-bottom: 2.5rem;
  }
  main .c_point_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(260px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 2.5rem 1rem;
  }
  main .c_point_list li {
    text-align: center;
  }
  main .c_point_list .title {
    font-size: 1.25rem;
    color: #e0c11d;
    margin-bottom: 1rem;
    line-height: 1.2;
  }
  main .c_point_list .text {
    text-align: left;
    line-height: 1.6;
  }
  main .c_plan_blc {
    padding: 2rem 1rem;
    border: 3px solid #6e6e6e;
    margin: 1rem auto 2.5rem;
    max-width: 900px;
  }
  main .c_plan_blc.yellow {
    border: 3px solid #e0c11d;
    border-radius: 10px;
  }
  main .c_plan_blc .left_col {
    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-weight: bold;
    margin-bottom: 1rem;
  }
  main .c_plan_blc .left_col .round {
    width: 114px;
    height: 114px;
    background-color: #6e6e6e;
    color: #fff;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 0.5rem;
    text-align: center;
  }
  main .c_plan_blc .left_col .round.blue {
    background-color: #3b6caf;
  }
  main .c_plan_blc .left_col .round.yellow {
    background-color: #e0c11d;
  }
  main .c_plan_blc .left_col .round span {
    font-size: 0.9rem;
  }
  main .c_plan_blc .right_col p {
    font-size: 1rem;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom: 1rem;
  }
  main .c_plan_blc .right_col span {
    color: #e0c11d;
    margin-left: 1rem;
    font-weight: bold;
  }
  main .c_plan_blc .right_col strong {
    font-weight: bold;
    font-size: 2rem;
  }
  main .c_plan_blc .right_col small {
    font-size: 1rem;
    display: block;
    text-align: right;
  }
  main .c_flow_list {
    margin: 1rem auto 2rem;
    counter-reset: item;
    position: relative;
  }
  main .c_flow_list::before {
    position: absolute;
    content: "";
    z-index: -1;
    width: 120px;
    height: 100%;
    background-color: #e0c11d;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 0;
    left: 50%;
  }
  main .c_flow_list.yellow li {
    border: 3px solid #e0c11d;
    border-radius: 10px;
  }
  main .c_flow_list li {
    counter-increment: item;
    position: relative;
    padding: 1rem;
    border: 2px solid #6e6e6e;
    background-color: #fff;
  }
  main .c_flow_list li:not(:last-of-type) {
    margin-bottom: 2.5rem;
  }
  main .c_flow_list li .title {
    font-size: 1.25rem;
    font-weight: bold;
  }
  main .c_flow_list li .title:before {
    content: counter(item);
    font-size: 3rem;
    color: #e0c11d;
    line-height: 1;
    font-weight: bold;
    text-align: center;
    padding-right: 10px;
  }
  main .c_img_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(240px, 1fr))[auto-fill];
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
    margin: 1rem auto 2.5rem;
  }
  main .c_term_list {
    margin: 1rem auto;
  }
  main .c_term_list li {
    color: #333333;
  }
  main .c_term_list li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  main .c_pagination {
    text-align: center;
    margin: 2rem auto;
    font-size: 1rem;
  }
  main .c_pagination a,
  main .c_pagination span {
    display: inline-block;
    margin: 0 5px;
    padding: 0 5px;
  }
  main .c_pagination a:hover,
  main .c_pagination span {
    color: #e0c11d;
  }
  main .c_postlink {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin: 2rem auto;
  }
  main .c_postlink a {
    display: block;
    text-align: center;
    text-decoration: none;
    padding: 0.5rem 0.5rem;
    color: #fff;
    background-color: #e0c11d;
    border: 2px solid #e0c11d;
    font-size: 0.75rem;
    line-height: 1.2;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    width: 170px;
    margin: 1rem auto;
    position: relative;
    cursor: pointer;
  }
  main .c_postlink a:hover {
    opacity: 0.8;
    background-color: #fff;
    color: #e0c11d;
  }
  main .c_numb_list {
    margin-bottom: 20px;
  }
  main .c_numb_list:not(:last-of-type) {
    margin-bottom: 40px;
  }
  main .c_numb_list li {
    border-radius: 20px;
    border: 3px solid #000;
    padding: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 20px;
    position: relative;
  }
  main .c_numb_list li span {
    font-size: 2.5rem;
    line-height: 1;
    font-weight: bold;
  }
  main .c_numb_list li > div {
    width: 77%;
    margin-left: 20px;
  }
  main .c_numb_list li > div .title {
    color: #cb4f0d;
    font-weight: bold;
    font-size: 1.4rem;
    border-bottom: 1px solid #000;
    margin-bottom: 10px;
    padding-bottom: 5px;
  }
  main .c_numb_list li > div p {
    font-weight: bold;
    font-size: 1rem;
  }
  main .c_numb_list li > img {
    position: absolute;
    bottom: 5px;
    left: 0;
    width: 80px;
  }
  /*---- 固定ページ共通 ----*/
  .p_page *:first-child {
    margin-top: 0;
  }
  .p_page *:last-child {
    margin-bottom: 0;
  }
  .p_page h1:not([class]) {
    color: #e0c11d;
    background-color: #e0c11d;
    padding: 0.5rem 1rem;
  }
  .p_page h2:not([class]) {
    color: #e0c11d;
    font-size: 1.5rem;
    margin: 2rem 0 3rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
  }
  .p_page h3:not([class]) {
    color: #e0c11d;
    font-size: 1.5rem;
    margin: 2rem 0 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_page h3:not([class])::after {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 3px;
    background-color: #e0c11d;
    margin-left: 1rem;
  }
  .p_page h4:not([class]) {
    color: #e0c11d;
    font-size: 1.25rem;
    margin: 1rem 0 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_page h4:not([class])::after {
    content: "";
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    height: 12px;
    background-color: #e0c11d;
    background: transparent repeating-linear-gradient(110deg, #e0c11d, #e0c11d 1px, transparent 1px, transparent 10px);
    margin-left: 1rem;
  }
  .p_page h5:not([class]) {
    background-color: #6e6e6e;
    color: #fff;
    padding: 0.5rem;
  }
  .p_page p span:not([class]) {
    color: #e0c11d;
  }
  .price_table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1rem;
    border: 1px solid #fff;
    font-size: 0.9rem;
    font-weight: normal;
  }
  .price_table caption {
    font-size: 1.25rem;
  }
  .price_table caption small {
    display: block;
    font-size: 0.75rem;
    text-align: right;
  }
  .price_table th,
  .price_table td {
    background-color: #e3e3e3;
    border: 3px solid #fff;
    text-align: center;
    vertical-align: middle;
  }
  .price_table td {
    padding: 1rem 0.5rem;
    color: #6e6e6e;
  }
  .price_table th {
    padding: 0.5rem 0.5rem;
    color: #6e6e6e;
    font-size: 1rem;
  }
  .price_table .gold {
    background-color: #e0c11d;
    color: #fff;
    font-weight: bold;
    vertical-align: middle;
  }
  .price_table .gold span {
    font-size: 1.2rem;
  }
  .price_table .gold .strikethrough {
    font-size: 0.8rem;
    text-decoration: line-through;
  }
  .price_table .dgray {
    background-color: #333333;
    color: #fff;
  }
  .price_table .bg_white {
    background-color: #fff;
  }
  /*---- 各ページ ---*/
  .p_top *:first-child {
    margin-top: 0;
  }
  .p_top *:last-child {
    margin-bottom: 0;
  }
  .p_top .blc_img {
    margin: 5rem 0;
  }
  .p_top .sec_news .imgleft .box {
    border: 3px solid #6e6e6e;
    padding: 1.5rem;
    margin-bottom: 1rem;
  }
  .p_top .sec_news .imgleft .box .title {
    color: #bc1717;
    font-size: 1rem;
    font-weight: bold;
    border-bottom: 2px solid #6e6e6e;
    margin-bottom: 1rem;
  }
  .p_top .sec_news .news .btn {
    max-width: 190px;
    margin-right: 0;
    font-size: 1em;
    min-height: 50px;
  }
  .p_top .sec_news .news_list {
    margin: 2rem 0;
  }
  .p_top .sec_news .news_list li {
    border-bottom: 1px solid #6e6e6e;
  }
  .p_top .sec_news .news_list li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  .p_top .sec_news .news_list .info {
    margin-bottom: 0.5rem;
  }
  .p_top .sec_news .news_list .cat {
    margin-left: 1rem;
  }
  .p_top .sec_news .news_list .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    display: inline-block;
  }
  .p_top .sec_news .news_list .cat a:not(:first-of-type) {
    margin-left: 0.5rem;
  }
  .p_top .sec_concept .imgleft,
  .p_top .sec_concept .imgright {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1rem;
  }
  .p_top .sec_concept .imgleft .title,
  .p_top .sec_concept .imgright .title {
    font-size: 1.5rem;
    color: #e0c11d;
    margin-bottom: 1rem;
    text-align: center;
  }
  .p_top .sec_concept .imgleft .img img,
  .p_top .sec_concept .imgright .img img {
    width: 100%;
    max-height: 300px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .p_top .sec_serivice .acc_content li {
    border: none;
  }
  .p_top .sec_serivice .acc_content li:not(:last-child) {
    border-bottom: 2px solid #6e6e6e;
  }
  .p_top .sec_serivice .acc_content a {
    background: #aaafb1;
    color: #fff;
    display: block;
    padding: 10px;
    font-weight: bold;
    font-size: 0.8rem;
  }
  .p_company .table_wrap {
    margin: 0 auto;
  }
  .p_personaltraning {
    padding: 0 0 1rem;
    margin: 0;
    color: #000;
  }
  .p_personaltraning .sec_lead .t_strong {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #fff;
    text-align: center;
  }
  .p_personaltraning .sec_whatis .imgleft,
  .p_personaltraning .sec_whatis .imgright {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1rem;
  }
  .p_personaltraning .sec_whatis .imgleft .title,
  .p_personaltraning .sec_whatis .imgright .title {
    font-size: 1.3rem;
    color: #e0c11d;
    margin-bottom: 1rem;
  }
  .p_personaltraning .sec_whatis .value {
    margin-bottom: 2rem;
  }
  .p_personaltraning .sec_compare {
    padding: 0 1rem 3rem;
  }
  .p_personaltraning .sec_voice {
    padding: 0 2rem 3rem;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .swiper-slide {
    height: auto !important;
    border: 1px solid #6e6e6e;
    border-radius: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .thumb {
    width: 100%;
    position: relative;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .thumb:before {
    content: "";
    display: block;
    padding-top: 62.5%;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .thumb img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    border-radius: 10px;
  }
  .p_personaltraning .sec_voice .swiper-wrapper .cont {
    padding: 10px;
    color: #6c6c6c;
    font-size: 0.8rem;
  }
  .p_personaltraning .blc_reserve .inner {
    max-width: 1040px;
  }
  .p_rentalgym .sec_lead .t_ac {
    text-align: left;
  }
  .p_rentalstudio .sec_lead .t_ac {
    text-align: left;
  }
  .p_membership ul {
    margin-bottom: 40px;
  }
  .p_membership ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    font-weight: bold;
    margin-bottom: 40px;
  }
  .p_membership ul .title {
    color: #fff;
    text-align: center;
    font-size: 1.2rem;
    padding: 5px;
    background: #333333;
  }
  .p_membership ul img {
    border: 1px solid #000;
  }
  .p_membership ul p {
    color: #000;
    font-size: 1rem;
    line-height: 1.4;
    margin-bottom: 0;
  }
  .p_membership .t_ac {
    color: #000;
    font-weight: bold;
    font-size: 1rem;
  }
  .p_contact .wpcf7-list-item-label::before,
  .p_reserve .wpcf7-list-item-label::before {
    border: 1px solid #e0c11d;
  }
  .p_contact .wpcf7-list-item-label::after,
  .p_reserve .wpcf7-list-item-label::after {
    background-color: #e0c11d;
  }
  .p_use .sec_title_icon span:not([class]) {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e3946a));
    background: linear-gradient(transparent 60%, #e3946a 60%);
  }
  .p_use p {
    font-weight: bold;
  }
  .sec_flow {
    color: #000;
  }
  .sec_flow .sub_title {
    background: #333333;
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: center;
  }
  .sec_flow p.t_ac {
    font-weight: bold;
  }
  .sec_flow strong {
    display: block;
    font-size: 1.2rem;
    font-weight: 900;
    margin-bottom: 20px;
  }
  .sec_flow strong span {
    color: #cb4f0d;
  }
  .sec_flow .kaihipay {
    background: #e1fff8;
    font-weight: 900;
    padding: 20px;
    margin-bottom: 20px;
    text-align: center;
  }
  .sec_flow .kaihipay .title {
    color: #009966;
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 0;
  }
  .sec_flow .kaihipay p {
    color: #6eb09a;
  }
  .sec_flow .akerun {
    background: #dbedf6;
    font-weight: 900;
    padding: 20px;
    margin-bottom: 20px;
    text-align: center;
  }
  .sec_flow .akerun .title {
    color: #008ccf;
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 0;
  }
  .sec_flow .akerun p {
    color: #68a6c4;
  }
  .sec_flow .plus {
    margin: 20px auto;
    display: block;
  }
  .sec_flow .btn.black {
    margin: 0 auto 40px;
  }
  .sec_flow .box {
    background: #eeccba;
    padding: 20px;
  }
  .p_pgs,
  .p_tokiwa {
    padding: 0;
  }
  .p_pgs h2:not([class]),
  .p_tokiwa h2:not([class]) {
    color: #cb4f0d;
  }
  .p_pgs h3:not([class]),
  .p_tokiwa h3:not([class]) {
    color: #cb4f0d;
  }
  .p_pgs h3:not([class])::after,
  .p_tokiwa h3:not([class])::after {
    display: none;
  }
  .p_pgs li,
  .p_tokiwa li {
    list-style: none;
  }
  .p_pgs .sec_title_icon span:not([class]),
  .p_tokiwa .sec_title_icon span:not([class]) {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e3946a));
    background: linear-gradient(transparent 60%, #e3946a 60%);
  }
  .p_pgs .sec_title_icon .line,
  .p_tokiwa .sec_title_icon .line {
    color: #cb4f0d;
  }
  .p_pgs .sec_title_icon .line::before, .p_pgs .sec_title_icon .line::after,
  .p_tokiwa .sec_title_icon .line::before,
  .p_tokiwa .sec_title_icon .line::after {
    background-color: #cb4f0d;
  }
  .p_pgs .sec_lead .content,
  .p_tokiwa .sec_lead .content {
    margin: 0 auto;
  }
  .p_pgs .sec_lead .content > div:not(:last-of-type),
  .p_tokiwa .sec_lead .content > div:not(:last-of-type) {
    margin-bottom: 2em;
  }
  .p_pgs .sec_lead .bubble,
  .p_tokiwa .sec_lead .bubble {
    background-color: #fff;
    margin: 0 0 20px;
    padding: 5px;
    font-weight: 700;
    font-size: 1rem;
    text-align: center;
    position: relative;
  }
  .p_pgs .sec_lead .bubble::after,
  .p_tokiwa .sec_lead .bubble::after {
    content: "";
    background-color: #fff;
    width: 10px;
    height: 10px;
    -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
            clip-path: polygon(0 0, 50% 100%, 100% 0);
    position: absolute;
    bottom: -9px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .p_pgs .sec_lead .t_strong,
  .p_tokiwa .sec_lead .t_strong {
    font-size: 1.2rem;
    color: #fff;
    text-align: center;
    margin-top: 1.5rem;
  }
  .p_pgs .bg_img01,
  .p_tokiwa .bg_img01 {
    padding: 2rem 1rem;
  }
  .p_pgs .sec_intro h3,
  .p_tokiwa .sec_intro h3 {
    margin: 0 0 1rem 0;
    font-size: 1.25rem;
    font-weight: 700;
  }
  .p_pgs .c_value_list li,
  .p_tokiwa .c_value_list li {
    border: 5px solid #000;
    padding: 1rem 0.5rem;
  }
  .p_pgs .c_value_list li p,
  .p_tokiwa .c_value_list li p {
    margin-bottom: 0.5em;
  }
  .p_pgs .c_value_list li .big,
  .p_tokiwa .c_value_list li .big {
    font-size: 1.8rem;
  }
  .p_pgs .sec_about .c_about_list li:not(:last-of-type),
  .p_tokiwa .sec_about .c_about_list li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  .p_pgs .sec_about .c_about_list img,
  .p_tokiwa .sec_about .c_about_list img {
    margin: 0;
    width: 100%;
    border: 5px solid #000;
  }
  .p_pgs .sec_about .c_about_list h3,
  .p_tokiwa .sec_about .c_about_list h3 {
    font-weight: 700;
    margin: 1rem auto;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p_pgs .sec_about .machine_content,
  .p_tokiwa .sec_about .machine_content {
    position: relative;
    overflow: hidden;
    padding-top: 40px;
  }
  .p_pgs .sec_about .machine_content img,
  .p_tokiwa .sec_about .machine_content img {
    width: 100%;
  }
  .p_pgs .sec_about .machine_content .swiper-button-next,
  .p_pgs .sec_about .machine_content .swiper-button-prev,
  .p_tokiwa .sec_about .machine_content .swiper-button-next,
  .p_tokiwa .sec_about .machine_content .swiper-button-prev {
    --swiper-navigation-color: #fff;
    z-index: 1;
  }
  .p_pgs .sec_kodawari,
  .p_tokiwa .sec_kodawari {
    margin: 0 20px;
  }
  .p_pgs .sec_kodawari .subtitle,
  .p_tokiwa .sec_kodawari .subtitle {
    text-align: center;
    color: #cb4f0d;
    text-align: center;
  }
  .p_pgs .sec_kodawari .subtitle span,
  .p_tokiwa .sec_kodawari .subtitle span {
    background: #333;
    color: #fff;
    text-align: center;
    border-radius: 100px;
    padding: 5px 20px;
    display: block;
  }
  .p_pgs .sec_kodawari .main_title,
  .p_tokiwa .sec_kodawari .main_title {
    text-align: center;
    font-size: 1.3rem;
    color: #333;
  }
  .p_pgs .sec_kodawari .txt_ora,
  .p_tokiwa .sec_kodawari .txt_ora {
    color: #cb4f0d;
    text-align: center;
    font-size: 1.2rem;
  }
  .p_pgs .sec_kodawari img,
  .p_tokiwa .sec_kodawari img {
    display: block;
    margin: 0 auto 50px;
  }
  .p_pgs .sec_kodawari .osusume,
  .p_tokiwa .sec_kodawari .osusume {
    margin-bottom: 0;
    background: #333;
    color: #e0c11d;
    text-align: center;
    border-radius: 100px;
    padding: 5px 20px;
    display: block;
    margin: 0 auto;
  }
  .p_pgs .sec_kodawari .subh3,
  .p_tokiwa .sec_kodawari .subh3 {
    font-size: 1.2rem;
    color: #cb4f0d;
    text-align: center;
  }
  .p_pgs .sec_kodawari .txt,
  .p_tokiwa .sec_kodawari .txt {
    color: #333;
    text-align: center;
  }
  .p_pgs .sec_kodawari iframe,
  .p_tokiwa .sec_kodawari iframe {
    width: 100%;
    height: 200px;
  }
  .p_pgs .sec_kodawari li,
  .p_tokiwa .sec_kodawari li {
    margin-bottom: 30px;
  }
  .p_pgs .sec_kodawari strong,
  .p_tokiwa .sec_kodawari strong {
    display: block;
    text-align: center;
    margin: 0 auto;
    color: #cb4f0d;
    border-radius: 100px;
    margin: 50px 0 20px;
    font-size: 1.1rem !important;
  }
  .p_pgs .sec_kodawari .box02 ul,
  .p_tokiwa .sec_kodawari .box02 ul {
    background: #efefef;
    padding: 20px;
  }
  .p_pgs .sec_kodawari .box02 .left,
  .p_tokiwa .sec_kodawari .box02 .left {
    font-size: 1.5rem;
    margin-right: 20px;
    color: #333;
  }
  .p_pgs .sec_kodawari .box02 .right,
  .p_tokiwa .sec_kodawari .box02 .right {
    color: #333;
  }
  .p_pgs .sec_kodawari .lasttxt,
  .p_tokiwa .sec_kodawari .lasttxt {
    text-align: center;
    font-size: 1.5rem;
    color: #cb4f0d;
  }
  .p_pgs .sec_kodawari ul,
  .p_tokiwa .sec_kodawari ul {
    margin: 0 !important;
  }
  .p_pgs .blc_more,
  .p_tokiwa .blc_more {
    background-color: #cb4f0d;
    color: #fff;
    padding: 40px 0;
  }
  .p_pgs .blc_more h2,
  .p_tokiwa .blc_more h2 {
    font-size: 1.1rem;
    text-align: center;
  }
  .p_pgs .blc_more .btn,
  .p_tokiwa .blc_more .btn {
    color: #fff;
    border: 3px solid #fff;
    margin-top: 1rem;
  }
  .p_pgs .blc_more .arrow::before, .p_pgs .blc_more .arrow::after,
  .p_tokiwa .blc_more .arrow::before,
  .p_tokiwa .blc_more .arrow::after {
    background-color: #fff;
  }
  .p_pgs .sec_machine .tab_list,
  .p_tokiwa .sec_machine .tab_list {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0 auto 2em;
  }
  .p_pgs .sec_machine .tab_list li:not(:last-of-type),
  .p_tokiwa .sec_machine .tab_list li:not(:last-of-type) {
    margin-bottom: 1rem;
  }
  .p_pgs .sec_machine [data-tab-content],
  .p_tokiwa .sec_machine [data-tab-content] {
    display: none;
  }
  .p_pgs .sec_machine [data-tab-content].is_active,
  .p_tokiwa .sec_machine [data-tab-content].is_active {
    display: block;
  }
  .p_pgs .sec_machine .machine_tab,
  .p_tokiwa .sec_machine .machine_tab {
    background-color: #fff;
    padding: 1em 0.5em;
    border: 5px solid #333333;
    position: relative;
    text-align: center;
    font-size: 1rem;
  }
  .p_pgs .sec_machine .machine_tab.is_active,
  .p_tokiwa .sec_machine .machine_tab.is_active {
    background-color: #333333;
    color: #fff;
  }
  .p_pgs .sec_machine .machine_tab.is_active::after,
  .p_tokiwa .sec_machine .machine_tab.is_active::after {
    display: none;
  }
  .p_pgs .sec_machine .machine_content,
  .p_tokiwa .sec_machine .machine_content {
    position: relative;
    overflow: hidden;
    border: 5px solid #333333;
    padding: 2em 1em;
  }
  .p_pgs .sec_machine .machine_content > ul,
  .p_tokiwa .sec_machine .machine_content > ul {
    margin: 0;
  }
  .p_pgs .sec_machine .machine_content li:not(:last-of-type),
  .p_tokiwa .sec_machine .machine_content li:not(:last-of-type) {
    margin-bottom: 1em;
  }
  .p_pgs .sec_machine .machine_content li img,
  .p_tokiwa .sec_machine .machine_content li img {
    width: 100%;
    display: block;
  }
  .p_pgs .sec_machine .machine_content li h3,
  .p_tokiwa .sec_machine .machine_content li h3 {
    margin: 0 0 0.3em;
    display: block;
    text-align: center;
    color: #333333;
    font-size: 1.3rem;
  }
  .p_pgs .sec_machine .machine_content .swiper-button-next,
  .p_pgs .sec_machine .machine_content .swiper-button-prev,
  .p_tokiwa .sec_machine .machine_content .swiper-button-next,
  .p_tokiwa .sec_machine .machine_content .swiper-button-prev {
    --swiper-navigation-color: #fff;
    z-index: 1;
  }
  .p_pgs .sec_course h3,
  .p_tokiwa .sec_course h3 {
    font-size: 1.5rem;
    line-height: 1.6;
    font-weight: 700;
    display: block;
    text-align: center;
    position: relative;
    padding: 20px;
    color: #fff;
    background: #cb4f0d;
  }
  .p_pgs .sec_course h3:before,
  .p_tokiwa .sec_course h3:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #cb4f0d;
  }
  .p_pgs .sec_course h3 span,
  .p_tokiwa .sec_course h3 span {
    display: block;
    font-size: 0.7rem;
  }
  .p_pgs .sec_course .content,
  .p_tokiwa .sec_course .content {
    background-color: #fff;
    border: 5px solid #cb4f0d;
    padding: 2em 1em;
    position: relative;
    margin-bottom: 1rem;
  }
  .p_pgs .sec_course dl dt,
  .p_tokiwa .sec_course dl dt {
    color: #fff;
    background-color: #333333;
    text-align: center;
    font-size: 1.1rem;
    padding: 5px;
  }
  .p_pgs .sec_course dl dt.gold,
  .p_tokiwa .sec_course dl dt.gold {
    color: #e0c11d;
    font-size: 1.8rem;
  }
  .p_pgs .sec_course dl dt.nomal,
  .p_tokiwa .sec_course dl dt.nomal {
    font-size: 1.8rem;
  }
  .p_pgs .sec_course dl dt.year,
  .p_tokiwa .sec_course dl dt.year {
    color: #e3946a;
    font-size: 1.8rem;
  }
  .p_pgs .sec_course dl dd,
  .p_tokiwa .sec_course dl dd {
    text-align: center;
    padding: 5px;
    line-height: 1.4;
    background-color: #e8e8e8;
    color: #333333;
    font-size: 1rem;
  }
  .p_pgs .sec_course dl dd span,
  .p_tokiwa .sec_course dl dd span {
    font-size: 1.1rem;
  }
  .p_pgs .sec_course dl dd span.gold,
  .p_tokiwa .sec_course dl dd span.gold {
    color: #e0c11d;
    font-size: 1.6rem;
  }
  .p_pgs .sec_course dl dd span.nomal,
  .p_tokiwa .sec_course dl dd span.nomal {
    font-size: 1.6rem;
  }
  .p_pgs .sec_course dl dd span.year,
  .p_tokiwa .sec_course dl dd span.year {
    color: #e3946a;
    font-size: 1.6rem;
  }
  .p_pgs .sec_course dl dd strong,
  .p_tokiwa .sec_course dl dd strong {
    font-weight: 500;
    display: block;
    font-size: 0.9rem;
  }
  .p_pgs .sec_course .example,
  .p_tokiwa .sec_course .example {
    border: 5px solid #6e6e6e;
    padding: 10px;
    font-size: 1rem;
    background-color: #fff;
  }
  .p_pgs .sec_term .box_bg,
  .p_tokiwa .sec_term .box_bg {
    background-color: #e8e8e8;
    max-width: 1000px;
    max-height: 400px;
    margin: 0 auto;
    overflow: scroll;
  }
  .p_pgs .sec_term .box_bg div,
  .p_tokiwa .sec_term .box_bg div {
    padding: 20px;
  }
  .p_pgs .sec_access .content h3,
  .p_tokiwa .sec_access .content h3 {
    display: block;
    margin: 0 0 0.7rem 0;
  }
  .p_pgs .sec_access .content h3 span,
  .p_tokiwa .sec_access .content h3 span {
    display: block;
    color: #6e6e6e;
    font-size: 1rem;
    margin-top: 0.3em;
  }
  .p_pgs .sec_access .content p span,
  .p_tokiwa .sec_access .content p span {
    display: block;
    color: #6e6e6e;
    margin-top: 0.3em;
  }
  .p_hachiman .sec_title_icon,
  .p_sakioka .sec_title_icon {
    font-weight: 900;
  }
  .p_hachiman .sec_title_icon span:not([class]),
  .p_sakioka .sec_title_icon span:not([class]) {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #e3946a));
    background: linear-gradient(transparent 60%, #e3946a 60%);
  }
  .p_hachiman .sec_about .lead,
  .p_sakioka .sec_about .lead {
    text-align: center;
    font-weight: 900;
    color: #000;
  }
  .p_hachiman .sec_about .lead:not(:last-child),
  .p_sakioka .sec_about .lead:not(:last-child) {
    margin-bottom: 40px;
  }
  .p_hachiman .sec_about .lead strong,
  .p_sakioka .sec_about .lead strong {
    display: block;
    color: #cb4f0d;
    font-size: 1.2rem;
    font-weight: 900;
  }
  .p_hachiman .sec_about .lead strong span,
  .p_sakioka .sec_about .lead strong span {
    color: #cb4f0d;
    font-size: 2rem;
  }
  .p_hachiman .sec_about .machine_content,
  .p_sakioka .sec_about .machine_content {
    position: relative;
    overflow: hidden;
    margin-bottom: 20px;
  }
  .p_hachiman .sec_about .machine_content img,
  .p_sakioka .sec_about .machine_content img {
    width: 100%;
  }
  .p_hachiman .sec_about .machine_content .swiper-button-next,
  .p_hachiman .sec_about .machine_content .swiper-button-prev,
  .p_sakioka .sec_about .machine_content .swiper-button-next,
  .p_sakioka .sec_about .machine_content .swiper-button-prev {
    --swiper-navigation-color: #fff;
    z-index: 1;
  }
  .p_hachiman .sec_machine,
  .p_sakioka .sec_machine {
    color: #000;
  }
  .p_hachiman .sec_machine .machine_content,
  .p_sakioka .sec_machine .machine_content {
    position: relative;
    overflow: hidden;
  }
  .p_hachiman .sec_machine .machine_content li h3,
  .p_sakioka .sec_machine .machine_content li h3 {
    font-size: 1.2rem;
    margin: auto auto 20px;
    display: block;
    text-align: center;
    color: #333333;
    font-weight: bold;
  }
  .p_hachiman .sec_machine .machine_content li h3:after,
  .p_sakioka .sec_machine .machine_content li h3:after {
    display: none;
  }
  .p_hachiman .sec_machine .machine_content li img,
  .p_sakioka .sec_machine .machine_content li img {
    width: 100%;
    border: 10px solid #000;
  }
  .p_hachiman .sec_machine .machine_content .swiper-button-next,
  .p_hachiman .sec_machine .machine_content .swiper-button-prev,
  .p_sakioka .sec_machine .machine_content .swiper-button-next,
  .p_sakioka .sec_machine .machine_content .swiper-button-prev {
    --swiper-navigation-color: #fff;
    z-index: 1;
  }
  .p_hachiman .sec_course h3,
  .p_sakioka .sec_course h3 {
    font-size: 1.4rem;
    line-height: 1.6;
    font-weight: 700;
    display: block;
    text-align: center;
    position: relative;
    padding: 20px;
    color: #fff;
    background: #cb4f0d;
  }
  .p_hachiman .sec_course h3:before,
  .p_sakioka .sec_course h3:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -40px;
    border: 40px solid transparent;
    border-top: 20px solid #cb4f0d;
  }
  .p_hachiman .sec_course h3:after,
  .p_sakioka .sec_course h3:after {
    display: none;
  }
  .p_hachiman .sec_course h3 span,
  .p_sakioka .sec_course h3 span {
    display: block;
    font-size: 0.7rem;
  }
  .p_hachiman .sec_course ul,
  .p_sakioka .sec_course ul {
    margin: 0;
  }
  .p_hachiman .sec_course ul li,
  .p_sakioka .sec_course ul li {
    list-style: none;
  }
  .p_hachiman .sec_course ul li:not(:last-child),
  .p_sakioka .sec_course ul li:not(:last-child) {
    margin-bottom: 40px;
  }
  .p_hachiman .sec_course dl dt,
  .p_sakioka .sec_course dl dt {
    color: #fff;
    background-color: #333333;
    text-align: center;
    font-weight: 900;
    padding: 5px;
  }
  .p_hachiman .sec_course dl dt.gold,
  .p_sakioka .sec_course dl dt.gold {
    color: #e0c11d;
    font-size: 1.4rem;
  }
  .p_hachiman .sec_course dl dt.nomal,
  .p_sakioka .sec_course dl dt.nomal {
    font-size: 1.4rem;
  }
  .p_hachiman .sec_course dl dt.year,
  .p_sakioka .sec_course dl dt.year {
    color: #e3946a;
    font-size: 1.4rem;
  }
  .p_hachiman .sec_course dl dd,
  .p_sakioka .sec_course dl dd {
    text-align: center;
    padding: 5px;
    background-color: #e8e8e8;
    color: #333333;
    font-weight: 500;
  }
  .p_hachiman .sec_course dl dd span,
  .p_sakioka .sec_course dl dd span {
    font-weight: 900;
  }
  .p_hachiman .sec_course dl dd span.nomal,
  .p_sakioka .sec_course dl dd span.nomal {
    font-size: 1.6rem;
  }
  .p_hachiman .sec_course dl dd strong,
  .p_sakioka .sec_course dl dd strong {
    display: block;
    font-size: 0.8rem;
  }
  .p_hachiman .sec_flow .btn.big,
  .p_sakioka .sec_flow .btn.big {
    margin: 40px auto 0;
  }
  .p_hachiman .sec_gallery .machine_content,
  .p_sakioka .sec_gallery .machine_content {
    position: relative;
    overflow: hidden;
  }
  .p_hachiman .sec_gallery .machine_content li img,
  .p_sakioka .sec_gallery .machine_content li img {
    width: 100%;
    display: block;
  }
  .p_hachiman .sec_gallery .machine_content .swiper-button-next,
  .p_hachiman .sec_gallery .machine_content .swiper-button-prev,
  .p_sakioka .sec_gallery .machine_content .swiper-button-next,
  .p_sakioka .sec_gallery .machine_content .swiper-button-prev {
    --swiper-navigation-color: #fff;
    z-index: 1;
  }
  .p_hachiman .sec_access,
  .p_sakioka .sec_access {
    color: #000;
  }
  .p_hachiman .sec_access .content iframe,
  .p_sakioka .sec_access .content iframe {
    width: 100%;
    height: 200px;
    margin: 0 auto 20px;
    display: block;
  }
  .p_hachiman .sec_access .content h3,
  .p_sakioka .sec_access .content h3 {
    display: block;
    margin: 0 0 10px;
    font-weight: 900;
    font-size: 1.4rem;
    color: #000;
  }
  .p_hachiman .sec_access .content p,
  .p_sakioka .sec_access .content p {
    font-weight: bold;
  }
  /*---- 投稿系 ---*/
  .p_post *:first-child {
    margin-top: 0;
  }
  .p_post *:last-child {
    margin-bottom: 0;
  }
  .p_post h1:not([class]) {
    color: #e0c11d;
    font-size: 1.25rem;
    margin: 2rem 0 2.5rem;
    padding-bottom: 1rem;
    border-bottom: 5px solid #6e6e6e;
  }
  .p_post h2:not([class]) {
    color: #e0c11d;
    padding: 0.5rem 0.5rem 0.5rem 2rem;
    position: relative;
    font-size: 1.25rem;
  }
  .p_post h2:not([class])::before {
    position: absolute;
    content: "";
    width: 1rem;
    height: 3px;
    border-radius: 10px;
    background-color: #e0c11d;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 0;
  }
  .p_post h3:not([class]) {
    color: #fff;
    background-color: #e0c11d;
    padding: 0.5rem 1rem;
  }
  .p_post h4:not([class]) {
    background-color: #6e6e6e;
    color: #fff;
    padding: 0.5rem 1rem;
  }
  .p_post article a {
    text-decoration: underline;
  }
  .p_post article span {
    color: #e0c11d;
  }
  .p_post .c_post_link {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    padding: 0 60px;
    margin: 3rem auto 2rem;
    position: relative;
  }
  .p_post .c_post_link .btn {
    min-width: 220px;
  }
  .p_post .c_post_link .prev a,
  .p_post .c_post_link .next a {
    position: absolute;
    width: 40px;
    height: 70px;
    background-color: #6e6e6e;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transition: background 0.3s;
    transition: background 0.3s;
    top: 50%;
  }
  .p_post .c_post_link .prev a:hover,
  .p_post .c_post_link .next a:hover {
    background-color: #e0c11d;
  }
  .p_post .c_post_link .prev a {
    left: 0;
    -webkit-clip-path: polygon(0 50%, 100% 0, 100% 100%);
            clip-path: polygon(0 50%, 100% 0, 100% 100%);
  }
  .p_post .c_post_link .next a {
    right: 0;
    -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
            clip-path: polygon(0 0, 0 100%, 100% 50%);
  }
  .p_single .thumb {
    margin: 1rem auto 1.5rem;
    text-align: center;
  }
  .p_single .info {
    margin-bottom: 0.5rem;
  }
  .p_single .cat {
    margin-left: 0.5rem;
  }
  .p_single .cat a {
    background-color: #e0c11d;
    color: #fff;
    padding: 0 5px;
    line-height: 1.6;
    display: inline-block;
  }
  .p_single .cat a:not(:first-of-type) {
    margin-left: 0.5rem;
  }
  /*--- footer ---*/
  footer .blc_cta {
    background-color: #6e6e6e;
    padding: 1.5rem 0;
    color: #fff;
  }
  footer .blc_cta .inner {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    gap: 1rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .blc_cta .tel {
    text-align: center;
  }
  footer .blc_cta .tel .title {
    font-size: 1rem;
    line-height: 1.2;
  }
  footer .blc_cta .tel .title img {
    margin-right: 1rem;
    vertical-align: middle;
  }
  footer .blc_cta .tel a {
    font-size: 2rem;
    line-height: 1.2;
  }
  footer .l_footer {
    padding: 2.5rem 0;
  }
  footer .l_footer .map_col {
    margin-bottom: 20px;
  }
  footer .l_footer .logo_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    margin-bottom: 1.5rem;
  }
  footer .l_footer .info_list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 100px 1fr;
        grid-template-columns: 100px 1fr;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0.5rem 0.5rem;
  }
  footer .l_footer .info_list dt {
    border: 1px solid #6e6e6e;
    text-align: center;
  }
  footer .f_bottom {
    padding: 1rem 0;
    background-color: #6e6e6e;
    color: #fff;
  }
  footer .f_bottom .menu_list li {
    line-height: 1.2;
    border-bottom: 1px solid #fff;
  }
  footer .f_bottom .menu_list li:not(:last-of-type) {
    margin-bottom: 0.5rem;
  }
  footer .f_bottom .menu_list li a {
    padding: 0.5rem;
    display: inline-block;
  }
  footer .f_bottom small {
    margin-top: 1rem;
    display: block;
    text-align: center;
  }
  .pconly {
    display: none;
  }
}
/*# sourceMappingURL=style.css.map */