@charset "UTF-8";

.cmshtml {
  line-height: 1.15;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

.cmsbody {
  margin: 0;
}

.cmshtml article,
.cmshtml aside,
.cmshtml footer,
.cmshtml header,
.cmshtml nav,
.cmshtml section {
  display: block;
}

.cmshtml h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

.cmshtml figcaption,
.cmshtml figure,
.cmshtml main {
  /* 1 */
  display: block;
}

.cmshtml figure {
  margin: 1em 40px;
}

.cmshtml hr {
  box-sizing: content-box;
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

.cmshtml pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

.cmshtml a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
}

.cmshtml abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */
}

.cmshtml b,
.cmshtml strong {
  font-weight: inherit;
}

.cmshtml b,
.cmshtml strong {
  font-weight: bolder;
}

.cmshtml code,
.cmshtml kbd,
.cmshtml samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

.cmshtml dfn {
  font-style: italic;
}

.cmshtml mark {
  background-color: #ff0;
  color: #000;
}

.cmshtml small {
  font-size: 80%;
}

.cmshtml sub,
.cmshtml sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

.cmshtml sub {
  bottom: -0.25em;
}

.cmshtml sup {
  top: -0.5em;
}

.cmshtml audio,
.cmshtml video {
  display: inline-block;
}

.cmshtml audio:not([controls]) {
  display: none;
  height: 0;
}

.cmshtml img {
  border-style: none;
}

.cmshtml svg:not(:root) {
  overflow: hidden;
}

.cmshtml button,
.cmshtml input,
.cmshtml optgroup,
.cmshtml select,
.cmshtml textarea {
  font-family: sans-serif;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

.cmshtml button,
.cmshtml input {
  /* 1 */
  overflow: visible;
}

.cmshtml button,
.cmshtml select {
  /* 1 */
  text-transform: none;
}

.cmshtml button,
.cmshtml [type="button"],
.cmshtml [type="reset"],
.cmshtml [type="submit"] {
  -webkit-appearance: button;
  /* 2 */
}

.cmshtml button::-moz-focus-inner,
.cmshtml [type="button"]::-moz-focus-inner,
.cmshtml [type="reset"]::-moz-focus-inner,
.cmshtml [type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

.cmshtml button:-moz-focusring,
.cmshtml [type="button"]:-moz-focusring,
.cmshtml [type="reset"]:-moz-focusring,
.cmshtml [type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

.cmshtml fieldset {
  padding: 0.35em 0.75em 0.625em;
}

.cmshtml legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

.cmshtml progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

.cmshtml textarea {
  overflow: auto;
}

.cmshtml [type="checkbox"],
.cmshtml [type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

.cmshtml [type="number"]::-webkit-inner-spin-button,
.cmshtml [type="number"]::-webkit-outer-spin-button {
  height: auto;
}

.cmshtml [type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

.cmshtml [type="search"]::-webkit-search-cancel-button,
.cmshtml [type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

.cmshtml ::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

.cmshtml details,
.cmshtml menu {
  display: block;
}

.cmshtml summary {
  display: list-item;
}

.cmshtml canvas {
  display: inline-block;
}

.cmshtml template {
  display: none;
}

.cmshtml [hidden] {
  display: none;
}

.cmshtml .cf {
  zoom: 1;
}

.cmshtml .cf:before, .cmshtml .cf:after {
  content: "";
  display: table;
}

.cmshtml .cf:after {
  clear: both;
}

.cmshtml *:link,
.cmshtml *:visited,
.cmshtml *:active {
  color: inherit;
}

.cmshtml a:hover {
  color: inherit;
}

.cmshtml footer a:hover {
  text-decoration: underline;
}

.cmshtml .mb1 {
  margin-bottom: 6px;
}

.cmshtml .mb2 {
  margin-bottom: 12px;
}

.cmshtml .mb3 {
  margin-bottom: 18px;
}

.cmshtml .mb4 {
  margin-bottom: 24px;
}

.cmshtml .mb5 {
  margin-bottom: 30px;
}

.cmshtml .mb6 {
  margin-bottom: 36px;
}

.cmshtml .mb7 {
  margin-bottom: 42px;
}

.cmshtml .mb8 {
  margin-bottom: 48px;
}

.cmshtml .mb9 {
  margin-bottom: 54px;
}

.cmshtml .mb10 {
  margin-bottom: 60px;
}

.cmshtml .left {
  float: left;
}

.cmshtml .right {
  float: right;
}

.cmshtml .tar {
  text-align: right;
}

.cmshtml .tal {
  text-align: left;
}

.cmshtml .tac {
  text-align: center;
}

.cmshtml img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

.cmshtml img.left {
  margin-right: 48px;
}

.cmshtml img.right {
  margin-left: 48px;
}

.cmshtml .rad {
  border-radius: 6px;
}

.cmshtml .full {
  width: 100%;
  height: auto;
}

.cmshtml .red {
  color: #FF0000;
}

.cmshtml .small {
  font-size: 83%;
}

.cmshtml .big {
  font-size: 117%;
}

.cmshtml .bold {
  font-weight: bold;
}

.cmshtml .mt5 {
  margin-top: 5px;
}

.cmshtml .mt10 {
  margin-top: 10px;
}

.cmshtml .mt20 {
  margin-top: 20px;
}

.cmshtml .mt30 {
  margin-top: 30px;
}

.cmshtml .i-sh {
  box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.3);
}

.cmsbody,
.cmshtml dl,
.cmshtml dt,
.cmshtml dd,
.cmshtml ul,
.cmshtml ol,
.cmshtml li,
.cmshtml h1,
.cmshtml h2,
.cmshtml h3,
.cmshtml h4,
.cmshtml h5,
.cmshtml h6,
.cmshtml pre,
.cmshtml form,
.cmshtml input,
.cmshtml textarea,
.cmshtml small,
.cmshtml address,
.cmshtml aside,
.cmshtml blockquote,
.cmshtml th,
.cmshtml td {
  font-family: 'Noto Sans JP',YuGothic, "游ゴシック", "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  font-size: 16px;
  font-size: 1rem;
  color: #000;
  font-weight: 500;
  box-sizing: border-box;
  letter-spacing: 1px;
  z-index: 0;
  margin: 0;
  max-height: 100%;
}

@media screen and (max-width: 576px) {
  .cmsbody,
.cmshtml dl,
.cmshtml dt,
.cmshtml dd,
.cmshtml ul,
.cmshtml ol,
.cmshtml li,
.cmshtml h1,
.cmshtml h2,
.cmshtml h3,
.cmshtml h4,
.cmshtml h5,
.cmshtml h6,
.cmshtml pre,
.cmshtml form,
.cmshtml input,
.cmshtml textarea,
.cmshtml small,
.cmshtml address,
.cmshtml aside,
.cmshtml blockquote,
.cmshtml th,
.cmshtml td {
    font-size: 15px;
    font-size: 0.9375rem;
    letter-spacing: 0px;
  }
}

.cmshtml p, .cmshtml div {
  letter-spacing: inherit;
  margin: 0;
  box-sizing: border-box;
}

@media screen and (max-width: 576px) {
  .cmshtml p, .cmshtml div {
    letter-spacing: 0;
  }
}

.cmshtml p {
  font-family: inherit;
}

.cmshtml section {
  box-sizing: border-box;
}

.cmshtml {
  overflow-y: scroll;
  box-sizing: border-box;
}

.cmsbody {
  line-height: 1.7;
  position: relative;
}

@media screen and (max-width: 576px) {
  .cmsbody {
    line-height: 1.5;
  }
}

.cmshtml ul {
  margin: 0;
  padding: 0;
}

.cmshtml li {
  list-style: none;
}

.cmshtml li img {
  vertical-align: bottom;
}

.cmshtml a {
  color: inherit;
  cursor: pointer;
}

.cmshtml a:hover {
  opacity: 0.8;
}

.cmshtml ::selection {
  background-color: #FCA9A7;
  color: #fff;
  /* Safari */
}

.cmshtml ::-moz-selection {
  background-color: #FCA9A7;
  color: #fff;
  /* Firefox */
}

.cmshtml .arrow {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}

.cmshtml .triangle {
  content: "";
  box-sizing: border-box;
  width: 4px;
  height: 4px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  border: 4px solid transparent;
  border-left: 4px solid #FCA9A7;
}

.cmsbody {
  background: #fff;
}

.cmshtml .conceptstyle, .cmshtml .top_news, .cmshtml .top_info .title_area, .cmshtml .contents_list, .cmshtml .top_rec, .cmshtml #section_pageHeader .head_inner, .cmshtml .title-navi_ul {
  width: 1200px;
  margin-right: auto;
  margin-left: auto;
  position: relative;
  max-width: 100%;
  padding-left: 10px;
  padding-right: 10px;
}

.cmshtml #header {
  margin: 0 auto;
  position: relative;
}

.cmshtml .shopframe #header {
  z-index: 2;
}

@media print {
  .cmshtml h1 a {
    text-indent: 0;
  }
  .cmshtml #navi_main li a {
    text-indent: 0;
  }
  .cmshtml #navi_sub li a {
    text-indent: 0;
  }
}

.cmshtml a:hover {
  text-decoration: none;
}

.cmshtml #h-logo {
  position: absolute;
  top: 10px;
  left: 3.5vw;
  width: 179px;
  z-index: 2;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
}

@media screen and (max-width: 1200px) {
  .cmshtml #h-logo {
    margin-left: auto;
    margin-right: auto;
    left: 0;
  }
}

.cmshtml #h-logo a {
  display: inline-block;
  text-indent: -9999px;
  background: url(../img/logo.png) no-repeat 0 0;
  background-size: 100%;
  width: 179px;
  height: 147px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
}

.cmshtml #h-logo a:hover {
  opacity: 1;
}

@media screen and (max-width: 1200px) {
  .cmshtml #h-logo {
    top: 10px;
    max-width: calc(95% - 60px);
    position: relative;
  }
  .cmshtml #h-logo a {
    max-width: 100%;
    margin-bottom: 20px;
  }
}

.cmshtml #l-header {
  width: 100%;
  position: relative;
  /*h_nav End*/
}

@media screen and (min-width: 1201px) {
  .cmshtml #l-header {
    z-index: 3;
  }
  .cmshtml #l-header .headinner {
    width: 100%;
    transition: all 0.5s ease 0s;
    background: #fff;
  }
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header {
    z-index: auto;
    width: 100%;
  }
}

.cmshtml #l-header .h_nav {
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  padding-top: 54px;
  padding-right: 3vw;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav {
    position: fixed;
    padding: 0;
  }
}

.cmshtml #l-header .h_nav__list {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: flex-end;
  position: relative;
  transition: all 0.5s ease 0s;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__list {
    max-height: none;
    max-width: 100%;
    flex-wrap: wrap;
    display: block;
    border-top: none;
    background: #fff;
  }
}

.cmshtml #l-header .h_nav__item {
  text-align: center;
  transition: all 0.3s linear;
  line-height: 1.5;
  letter-spacing: 0;
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 500;
  transition: all 0.2s ease 0s;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item {
    height: auto;
    margin-top: 0;
    position: relative;
    width: 100%;
    text-align: left;
  }
}

.cmshtml #l-header .h_nav__item div {
  color: inherit;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item div.drawer-menu-item {
    padding: 0;
    text-decoration: none;
  }
}

.cmshtml #l-header .h_nav__item a {
  text-decoration: none;
  display: block;
  position: relative;
  box-sizing: border-box;
  transition: all 0.5s ease 0s;
}

@media screen and (max-width: 576px) {
  .cmshtml #l-header .h_nav__item a:hover {
    opacity: 1;
  }
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item a {
    width: 100%;
  }
}

@media screen and (min-width: 1201px) {
  .cmshtml #l-header .h_nav__item:hover {
    animation-name: nav;
    animation-fill-mode: backwards;
    animation-duration: 1.5s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
    animation-delay: 0s;
    animation-direction: normal;
  }
  .cmshtml #l-header .h_nav__item a:hover {
    opacity: 1;
    background-color: rgba(252, 169, 167, 0.1);
    box-shadow: inset 0 0 3px 8px #fff;
  }
}

@media screen and (min-width: 577px) and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item:hover {
    background-color: rgba(252, 169, 167, 0.2);
  }
}

.cmshtml #l-header .h_nav__item.h-nav__item--0, .cmshtml #l-header .h_nav__item.h-nav__item--1 {
  color: #111;
  background-repeat: no-repeat;
  background-position: center 23px;
  background-size: auto 44px;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item.h-nav__item--0, .cmshtml #l-header .h_nav__item.h-nav__item--1 {
    background-position: 10px center;
    background-size: auto 28px;
  }
}

@media screen and (min-width: 1201px) {
  .cmshtml #l-header .h_nav__item.h-nav__item--0:hover, .cmshtml #l-header .h_nav__item.h-nav__item--1:hover {
    animation: bg-wiggle 2s ease-out infinite, pop 0.2s ease-out;
  }
}

@media screen and (min-width: 1201px) {
  .cmshtml #l-header .h_nav__item.h-nav__item--0:hover, .cmshtml #l-header .h_nav__item.h-nav__item--1:hover {
    color: #666;
  }
}

.cmshtml #l-header .h_nav__item.h-nav__item--0 a, .cmshtml #l-header .h_nav__item.h-nav__item--1 a {
  padding: 70px 1.2vw 23px;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item.h-nav__item--0 a, .cmshtml #l-header .h_nav__item.h-nav__item--1 a {
    padding: 14px 0 14px 60px;
  }
}

@media screen and (min-width: 1201px) {
  .cmshtml #l-header .h_nav__item.h-nav__item--0 a::before, .cmshtml #l-header .h_nav__item.h-nav__item--1 a::before {
    position: absolute;
    content: "";
    width: 1px;
    height: 40px;
    background: #fff;
    margin: auto;
    top: 0;
    left: 0;
    bottom: 0;
  }
}

.cmshtml #l-header .h_nav__item.h-nav__item--0:first-child a::before, .cmshtml #l-header .h_nav__item.h-nav__item--1:first-child a::before {
  display: none;
}

.cmshtml #l-header .h_nav__item.h_subnav {
  position: absolute;
  top: -54px;
  right: 0px;
  display: flex;
  flex-wrap: wrap;
  min-height: 54px;
  gap: 10px;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item.h_subnav {
    position: relative;
    right: auto;
    top: auto;
    margin-top: 20px;
    margin-left: 10px;
    margin-right: 10px;
    display: block;
    text-align: left;
    width: auto;
  }
}

.cmshtml #l-header .h_nav__item.h_subnav a::before, .cmshtml #l-header .h_nav__item.h_subnav a::after {
  display: none;
}

.cmshtml #l-header .h_nav__item.h_subnav > div {
  font-size: clamp(15px, 1.7vw, 17px);
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item.h_subnav > div {
    margin: auto;
    margin-top: 10px;
  }
}

.cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li {
  letter-spacing: 0;
  transition: all 0.5s ease 0s;
}

.cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li:hover {
  opacity: 0.8;
}

.cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li a {
  color: infinit;
  color: #fff;
  display: block;
  padding-left: 42px;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-right: 20px;
  position: relative;
  border-radius: 0 0 8px 8px;
  background-color: #FCA9A7;
  background-repeat: no-repeat;
  background-position: left 18px center;
  transition: all 0.2s ease 0s;
}

.cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li a:hover {
  box-shadow: 0 0;
  padding-top: 20px;
}

@media screen and (max-width: 1200px) {
  .cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li a {
    border-radius: 8px;
  }
}

.cmshtml #l-header .h_nav__item.h_subnav >div:nth-child(2n) a {
  background-color: #FEA645;
}

.cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li.contact a {
  background-image: url("../img/ico_tel.png");
}

.cmshtml #l-header .h_nav__item.h_subnav .h_subnav_li.rec a {
  background-image: url("../img/ico_rec.png");
}

.cmshtml .tel {
  font-weight: 700;
  letter-spacing: 0;
  display: inline-block;
  line-height: 1.4;
  font-size: 18px;
  font-size: 1.125rem;
  font-family: 'Roboto', Helvetica Neue, Helvetica, YuGothic, "游ゴシック", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
      background: #fff;
}

.cmshtml .tel a {
  position: relative;
  display: inline;
  color: inherit;
  text-decoration: none;
  font-size: 26px;
  font-size: 1.625rem;
  padding-left: 28px;
  background: url("../img/ico_tel2.png") no-repeat left center;
}

.cmshtml .mail {
  font-size: 21px;
  font-size: 1.3125rem;
  background: #FCA9A7;
  font-weight: 700;
  border-radius: 99px;
  color: #fff;
}

.cmshtml .mail a {
  text-decoration: none;
  display: inline-block;
  letter-spacing: 0;
  padding: 10px 30px 10px 50px;
  box-sizing: border-box;
  max-width: 100%;
  transition: all 0.5s ease 0s;
  position: relative;
}

.cmshtml .mail a::before {
  content: "";
  position: absolute;
  background: url("../img/ico_mail.png") no-repeat 0 0;
  left: 25px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 26px;
  height: 20px;
}

.cmshtml .sp-dropbutton {
  display: inline-block;
  position: absolute;
  right: 0px;
  top: 0px;
  width: 30px;
  height: 100%;
  transition: all 0.3s;
  z-index: 2;
}

.cmshtml .sp-dropbutton::before, .cmshtml .sp-dropbutton::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 21px;
  bottom: 0;
  right: 5px;
  transition: all 0.3s;
  height: 2px;
  width: 16px;
  background: #FCA9A7;
}

.cmshtml .sp-dropbutton::after {
  transform: rotate(90deg);
}

.cmshtml .sp-dropbutton.open::after {
  transform: rotate(0deg);
}

@media screen and (min-width: 1201px) {
  .cmshtml .sp-dropbutton {
    display: none;
  }
}

.cmshtml .line2 .sp-dropbutton::before, .cmshtml .line2 .sp-dropbutton::after {
  top: 35px;
}

@media screen and (min-width: 1201px) {
  .cmshtml .drawer-navbar {
    margin: 0 auto;
    height: auto;
    background-color: transparent;
    border: 0;
    box-sizing: border-box;
    position: relative;
  }
  .cmshtml .drawer-hamburger {
    display: none;
  }
}

.cmshtml .drawer-hamburger {
  background-color: #FCA9A7;
  padding-top: 12px;
  padding-bottom: 32px;
  border-radius: 0 0 0 20px;
}

.cmshtml .drawer-hamburger::after {
  content: "MENU";
  position: absolute;
  bottom: 5px;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 11px;
  color: #fff;
}

.cmshtml .drawer-hamburger:hover {
  cursor: pointer;
  background-color: #FCA9A7;
}

.cmshtml .drawer-dropdown {
  z-index: 100;
}

.cmshtml .drawer-hamburger-icon, .cmshtml .drawer-hamburger-icon::before, .cmshtml .drawer-hamburger-icon::after {
  background-color: #fff;
  height: 4px;
}

.cmshtml #l_footer {
  padding: calc(3.125vw + 50px) 0 3.125vw;
  position: relative;
  text-align: center;
}

.cmshtml #l_footer .sns {
  display: flex;
  justify-content: center;
  column-gap: 10px;
}

.cmshtml #l_footer .flogo {
  margin-top: calc(2vw + 20px);
  margin-bottom: 14px;
}

.cmshtml #l_footer .address {
  font-size: clamp(16px, 2.1vw, 18px);
  letter-spacing: 0;
  margin-bottom: 10px;
  font-weight: 400;
}

.cmshtml #l_footer .copy {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1.5;
  margin-top: 60px;
}

.cmshtml #l_footer .copy a {
  text-decoration: none;
  color: inherit;
}

.cmshtml #pagetop-side {
  width: 60px;
  height: 60px;
  position: fixed;
  bottom: 10px;
  right: 10px;
  text-indent: -9999px;
  z-index: 100;
  transition: bottom 0.1s;
}

@media screen and (max-width: 576px) {
  .cmshtml #pagetop-side {
    bottom: 4px;
    right: 4px;
    width: 40px;
    height: 40px;
  }
}

.cmshtml #pagetop-side a {
  display: block;
  background-image: url(../img/pagetop.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
  opacity: 1;
  cursor: pointer;
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  width: 100%;
  height: 100%;
}

.cmshtml #pagetop-side:hover {
  opacity: 0.8;
  animation: wiggle 2s ease-out infinite, pop 0.2s ease-out;
}

.cmshtml .l-container,
.cmshtml #contents {
  width: 1200px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  min-height: 40vh;
}

.cmshtml #contents {
  width: 1200px;
  width: 1220px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  min-height: 40vh;
  padding-left: 10px;
  padding-right: 10px;
}

@media screen and (max-width: 1100px) {
  .cmshtml #contents {
    padding-left: 1vw;
    padding-right: 1vw;
  }
}

.cmshtml .inner {
  width: 1200px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.cmshtml .l_main {
  overflow: hidden;
}

.cmshtml .pconly {
  display: block;
}

@media screen and (max-width: 576px) {
  .cmshtml .pconly {
    display: none;
  }
}

.cmshtml .sponly {
  display: none;
}

@media screen and (max-width: 576px) {
  .cmshtml .sponly {
    display: block;
  }
}

.cmshtml .spn {
  display: inline;
}

.cmshtml .flex_inner {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-flex-direction: row;
  flex-direction: row;
  justify-content: space-between;
  position: relative;
}

@media screen and (max-width: 576px) {
  .cmshtml .flex_inner {
    display: block;
  }
}

.cmshtml .just2, .cmshtml .just3, .cmshtml .just4, .cmshtml .just5, .cmshtml .just_gr {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
}

@media screen and (max-width: 576px) {
  .cmshtml .just2 .flex-blnk, .cmshtml .just3 .flex-blnk, .cmshtml .just4 .flex-blnk, .cmshtml .just5 .flex-blnk, .cmshtml .just_gr .flex-blnk {
    margin-bottom: 0 !important;
  }
}

.cmshtml .just_center {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
}

.cmshtml .just2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, calc(50% - 15px));
  gap: 15px;
}

@media screen and (max-width: 576px) {
  .cmshtml .just2 {
    grid-template: auto/repeat(1, 1fr);
  }
}

.cmshtml .anchor__list.just3 {
  display: grid;
  grid-template-columns: repeat(auto-fit, calc(33% - 15px));
  gap: 15px;
}

@media screen and (max-width: 576px) {
  .cmshtml .anchor__list.just3 {
    grid-template-columns: repeat(auto-fit, calc(50% - 15px));
  }
}

@media screen and (max-width: 460px) {
  .cmshtml .anchor__list.just3 {
    grid-template: auto/repeat(1, 1fr);
  }
}

.cmshtml .anchor__list.just3 > div {
  width: 100%;
  margin: 0;
}

.cmshtml .anchor__list.just3 div {
  width: 100%;
}

.cmshtml .anchor__list.just4 {
  display: grid;
  grid-template-columns: repeat(auto-fit, calc(25% - 15px));
  gap: 15px;
}

@media screen and (max-width: 800px) {
  .cmshtml .anchor__list.just4 {
    grid-template-columns: repeat(auto-fit, calc(50% - 15px));
  }
}

@media screen and (max-width: 576px) {
  .cmshtml .anchor__list.just4 {
    grid-template: auto/repeat(1, 1fr);
  }
}

.cmshtml .anchor__list.just4 > div {
  width: 100%;
  margin: 0;
}

.cmshtml .anchor__list.just5 {
  display: grid;
  grid-template-columns: repeat(auto-fit, calc(20% - 15px));
  gap: 15px;
}

@media screen and (max-width: 800px) {
  .cmshtml .anchor__list.just5 {
    grid-template-columns: repeat(auto-fit, calc(50% - 15px));
  }
}

@media screen and (max-width: 460px) {
  .cmshtml .anchor__list.just5 {
    grid-template: auto/repeat(1, 1fr);
  }
}

.cmshtml .anchor__list.just5 > div {
  width: 100%;
  margin: 0;
}

.cmshtml .hidden {
  overflow: hidden;
}

.cmshtml .default_none {
  display: none;
}

.cmshtml .mla {
  margin-left: auto;
}

.cmshtml .mra {
  margin-right: auto;
}

.cmshtml .title_bg {
  position: relative;
  background: #FCA9A7;
}

.cmshtml .title_bg::before {
  content: "";
  left: 0;
  top: 0;
  position: absolute;
  height: 100%;
  width: 100%;
  background: url("../img/bg_ttl.png") no-repeat 0 0;
  opacity: 0.2;
}

.cmshtml .bg_wrap {
  position: relative;
  background: #FCF2F4;
  padding: 60px 0px 40px;
  width: 100vw;
  max-width: 100vw;
  margin: 0 calc(50% - 50vw);
}

@media screen and (max-width: 1200px) {
  .cmshtml .bg_wrap {
    padding: 30px 0px 20px;
  }
}

.cmshtml .rad img {
  border-radius: 10px;
}

.cmshtml .dl_ico a {
  text-decoration: underline;
  position: relative;
}

.cmshtml .dl_ico a:after {
  display: inline-block;
  width: 31px;
  height: 31px;
  position: absolute;
  right: 5px;
  top: 0;
  bottom: 0;
  margin: auto;
  content: none;
}

.cmshtml .dl_ico a[href*=".pdf"] {
  padding: 5px 35px 5px 5px;
}

.cmshtml .dl_ico a[href*=".pdf"]:after {
  content: "";
  background: url("../img/icon-pdf-m.png") no-repeat 0 0;
  background-size: 100% 100%;
}

.cmshtml .dl_ico a[href*=".doc"], .cmshtml .dl_ico a[href*=".docx"] {
  padding: 5px 35px 5px 5px;
}

.cmshtml .dl_ico a[href*=".doc"]:after, .cmshtml .dl_ico a[href*=".docx"]:after {
  content: "";
  background: url("../img/icon-word-m.png") no-repeat 0 0;
  background-size: 100% 100%;
}

.cmshtml .dl_ico a[href*=".xls"], .cmshtml .dl_ico a[href*=".xlsx"] {
  padding: 5px 35px 5px 5px;
}

.cmshtml .dl_ico a[href*=".xls"]:after, .cmshtml .dl_ico a[href*=".xlsx"]:after {
  content: "";
  background: url("../img/icon-xcel-m.png") no-repeat 0 0;
  background-size: 100% 100%;
}

.cmshtml .color_bg {
  position: relative;
  width: 1200px;
  max-width: 100%;
  margin: 0 auto;
}

.cmshtml .color_bg::before {
  z-index: -1;
  content: "";
  background: #FCF2F4;
  width: 100vw;
  max-width: 100vw;
  margin: 0 calc(50% - 50vw);
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
}

.cmshtml .bg_grad {
  background: -moz-linear-gradient(to right, #FCA9A7, #FEA645);
  background: -webkit-linear-gradient(to right, #FCA9A7, #FEA645);
  background: linear-gradient(to right, #FCA9A7, #FEA645);
  color: #fff;
  font-weight: 700;
  text-align: center;
}

.cmshtml .dot_icon {
  padding-left: 24px !important;
  position: relative;
}

.cmshtml .dot_icon::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(0.3em + 10px);
  width: 1em;
  height: 1em;
  border-radius: 50%;
  background: #FCA9A7;
}

.cmshtml .relative {
  position: relative;
}

.cmshtml .tag_rt {
  position: absolute;
  right: 10px;
  top: 10px;
  display: inline-block;
}

.cmshtml .swingbox,
.cmshtml .flipbox,
.cmshtml .fadebox,
.cmshtml .fadeinbox,
.cmshtml .bouncedownbox,
.cmshtml .bouncebox {
  opacity: 0;
}

.cmshtml .swingbox.animate__animated,
.cmshtml .flipbox.animate__animated,
.cmshtml .fadebox.animate__animated,
.cmshtml .fadeinbox.animate__animated,
.cmshtml .bouncedownbox.animate__animated,
.cmshtml .bouncebox.animate__animated {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .cmshtml .animate__animated {
    animation-duration: var(--animate-duration) !important;
    -webkit-animation-duration: var(--animate-duration) !important;
    transition-duration: var(--animate-duration) !important;
    -webkit-transition-duration: var(--animate-duration) !important;
    animation-iteration-count: var(--animate-repeat) !important;
    -webkit-animation-iteration-count: var(--animate-repeat) !important;
  }
}

.cmshtml .ablock a {
  display: block;
}

.cmshtml .line-height2 {
  line-height: 2;
}

.cmshtml .rdplanetext.table_borderbottom .table table th,
.cmshtml .rdplanetext.table_borderbottom .table table td,
.cmshtml .rdplanetext2.table_borderbottom .table table th,
.cmshtml .rdplanetext2.table_borderbottom .table table td {
  border: none;
  border-bottom: 1px solid #A4A4A4;
}

.cmshtml .link_efect {
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  filter: brightness(100%);
}

.cmshtml .link_efect a {
  display: block;
  text-decoration: none;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  position: relative;
}

.cmshtml .link_efect:hover {
  filter: brightness(130%);
}

.cmshtml .wraptitle {
  background: #F8F4EE;
  display: inline-block;
  padding: 10px 20px;
  border-radius: 10px;
  width: 320px;
  max-width: 100%;
  border: 3px solid rgba(252, 169, 167, 0.5);
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 700;
  color: #333;
}

.cmshtml .underlinetitles {
  display: inline-block;
  background: linear-gradient(transparent 60%, rgba(252, 169, 167, 0.5) 60%);
}

.cmshtml .underlinetitles2 {
  display: inline-block;
  background: linear-gradient(transparent 60%, rgba(141, 221, 165, 0.9) 60%);
}

.cmshtml .font_roboto {
  font-family: 'Roboto', Helvetica Neue, Helvetica, YuGothic, "游ゴシック", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
}

.cmshtml .jp-style {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -webkit-text-orientation: upright;
  text-orientation: upright;
  margin-inline: auto;
}

.cmshtml .gaiyou {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  border: 1px solid #FCA9A7;
  background: #fff;
}

.cmshtml .gaiyou > div:nth-child(n+3) {
  border-top: 1px dotted #FCA9A7;
}

.cmshtml .gaiyou > div:nth-child(2n-1) {
  width: 25%;
  padding: 15px 1.5%;
  font-weight: 700;
  position: relative;
  background: rgba(252, 169, 167, 0.2);
  border-right: 1px dotted #FCA9A7;
}

.cmshtml .gaiyou > div:nth-child(2n) {
  width: 75%;
  padding: 15px 1.5%;
  background: #fff;
  font-weight: 400;
}

@media screen and (max-width: 576px) {
  .cmshtml .gaiyou > div {
    border-top: none !important;
  }
  .cmshtml .gaiyou > div:nth-child(2n-1) {
    border-right: none;
  }
  .cmshtml .gaiyou > div:nth-child(1n) {
    width: 100%;
  }
}

.cmshtml .ablock a {
  display: block !important;
}

.cmshtml .flex-blnk {
  border: none !important;
  box-shadow: none !important;
  background: none !important;
}

.cmshtml .flex-blnk::before, .cmshtml .flex-blnk::after {
  display: none !important;
}

.cmshtml .anchor__list {
  padding-top: calc(1vw + 20px);
  padding-bottom: calc(1vw + 20px);
  display: grid;
  grid-template-columns: repeat(auto-fit, calc(50% - 15px));
  gap: 15px;
  z-index: 1;
  position: relative;
}

@media screen and (max-width: 576px) {
  .cmshtml .anchor__list {
    grid-template: auto/repeat(1, 1fr);
  }
}

.cmshtml .anchor__list > div {
  position: relative;
  box-sizing: border-box;
  font-size: 15px;
  font-size: 0.9375rem;
  display: flex;
  align-items: center;
}

.cmshtml .anchor__list > div a {
  border-radius: 5px;
  background: #F8F4EE;
  transition-property: background;
  transition-duration: 0.3s;
  padding: 10px 25px;
  box-sizing: border-box;
  min-height: 65px;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  position: relative;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  width: 100%;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 576px) {
  .cmshtml .anchor__list > div a {
    min-height: 0;
  }
}

.cmshtml .anchor__list > div a::before {
  content: "";
  box-sizing: border-box;
  width: 24px;
  height: 24px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  border-radius: 50%;
  background: url("../img/arrow01.png") no-repeat center;
  right: 20px;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
}

.cmshtml .anchor__list > div:hover a {
  opacity: 1;
}

.cmshtml .faq {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.cmshtml .faq > div {
  position: relative;
}

.cmshtml .faq > div::before {
  position: absolute;
  left: 0px !important;
  top: 0;
  font-size: 28px;
  font-size: 1.75rem;
  width: 45px !important;
  height: 45px !important;
  line-height: 40px !important;
  background: #FCA9A7 !important;
  content: "Q";
  border-radius: 50%;
  text-align: center;
  color: #fff !important;
}

.cmshtml .faq > div:nth-child(2n-1) {
  padding: 14px 30px 14px 62px !important;
  font-weight: 700;
  font-size: 18px;
  font-size: 1.125rem;
}

.cmshtml .faq > div:nth-child(2n-1)::before {
  top: 9px;
}

.cmshtml .faq > div:nth-child(2n) {
  padding: 15px 30px 15px 62px !important;
}

.cmshtml .faq > div:nth-child(2n)::before {
  top: 8px;
  background: #FEA645 !important;
  content: "A";
}

.cmshtml .link_btn a {
  display: inline-block;
  position: relative;
  padding: 11px 33px;
  background: #FCA9A7;
  border-radius: 99em;
  text-decoration: none;
  transition: all 0.2s ease 0s;
  -webkit-transition: all 0.2s ease;
  -moz-transition: all 0.2s ease;
  color:#fff;
}

.cmshtml .link_btn.orange a {
  background-color: rgba(254, 166, 69, 0.3);
}

.cmshtml .link_btn.orange a::before {
  background-color: #FEA645;
}

.cmshtml .link_btn.blue a {
  background-color: rgba(149, 192, 233, 0.3);
}

.cmshtml .link_btn.blue a::before {
  background-color: #95C0E9;
}

.cmshtml .link_btn.green a {
  background-color: rgba(141, 221, 165, 0.3);
}

.cmshtml .link_btn.green a::before {
  background-color: #8DDDA5;
}

.cmshtml .dl_list_text {
  flex-wrap: wrap;
  display: flex;
  padding: 10px 0 10px;
}

.cmshtml .dl_list_text .dl_list_text_title {
  padding: 12px 0 12px 20px;
  position: relative;
}

.cmshtml .dl_list_text .dl_list_text_title::before {
  margin: auto;
  position: absolute;
  content: "";
  width: 5px;
  height: 30px;
  background: #FCA9A7;
  top: 0;
  bottom: 0;
  left: 0;
  border-radius: 9px;
}

.cmshtml .dl_list_text_btn {
  margin-bottom: 10px;
}

.cmshtml .dl_list_text_btn a {
  display: block;
  position: relative;
  text-decoration: none;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  box-sizing: border-box;
  padding: 10px 40px 10px 40px;
  background: #fff;
  border: 2px solid #FCA9A7;
  border-radius: 99px;
  font-weight: 500;
  color: #333;
}

.cmshtml .dl_list_text_btn a:before {
  content: "";
  position: absolute;
  left: 7px;
  inset-block: 0;
  margin-block: auto;
  width: 26px;
  height: 26px;
  background-image: url(../img/arrow2.png);
  background-repeat: no-repeat;
  background-position: center;
  -webkit-transition: inherit;
  transition: inherit;
  border-radius: 5px;
}

.cmshtml .dl_list_text_btn a[href*=".pdf"], .cmshtml .dl_list_text_btn a[href*=".doc"], .cmshtml .dl_list_text_btn a[href*=".docx"], .cmshtml .dl_list_text_btn a[href*=".xls"], .cmshtml .dl_list_text_btn a[href*=".xlsx"], .cmshtml .dl_list_text_btn a[href*=".zip"] {
  padding: 10px 20px 10px 60px;
}

.cmshtml .dl_list_text_btn a[href*=".pdf"]:before, .cmshtml .dl_list_text_btn a[href*=".doc"]:before, .cmshtml .dl_list_text_btn a[href*=".docx"]:before, .cmshtml .dl_list_text_btn a[href*=".xls"]:before, .cmshtml .dl_list_text_btn a[href*=".xlsx"]:before, .cmshtml .dl_list_text_btn a[href*=".zip"]:before {
  width: 50px;
  height: 100%;
  right: auto;
  left: 10px;
  background-position: left 5px center;
  background-size: 30px 30px;
}

.cmshtml .dl_list_text_btn a[href*=".pdf"] {
  color: #F56F61;
  border-color: #F56F61;
}

.cmshtml .dl_list_text_btn a[href*=".pdf"]:before {
  background-image: url("../img/icon-pdf-m.png");
}

.cmshtml .dl_list_text_btn a[href*=".doc"], .cmshtml .dl_list_text_btn a[href*=".docx"] {
  color: #95C0E9;
  border-color: #95C0E9;
}

.cmshtml .dl_list_text_btn a[href*=".doc"]:before, .cmshtml .dl_list_text_btn a[href*=".docx"]:before {
  background-image: url("../img/icon-word-m.png");
}

.cmshtml .dl_list_text_btn a[href*=".xls"], .cmshtml .dl_list_text_btn a[href*=".xlsx"] {
  color: #91B524;
  border-color: #91B524;
}

.cmshtml .dl_list_text_btn a[href*=".xls"]:before, .cmshtml .dl_list_text_btn a[href*=".xlsx"]:before {
  background-image: url("../img/icon-xcel-m.png");
}

.cmshtml .dl_list_text_btn a[href*=".zip"] {
  border-color: #EC8B2F;
  color: #EC8B2F;
}

.cmshtml .dl_list_text_btn a[href*=".zip"]:before {
  background-image: url("../img/zip.png");
}

.cmshtml .fullsize {
  text-align: center;
}

.cmshtml .fullsize img {
  width: 100vw;
  max-width: 100vw;
  margin: 0 calc(50% - 50vw);
}

.cmshtml .openbox,
.cmshtml .toggle-box > div:nth-child(2n-1) {
  padding: 13px 50px 13px 20px;
  font-weight: bold;
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  transition: background .12s ease-in-out;
  background-color: #fff;
  border: 1px solid #FCA9A7;
  font-size: 17px;
  font-size: 1.0625rem;
}

.cmshtml .openbox::before, .cmshtml .openbox::after,
.cmshtml .toggle-box > div:nth-child(2n-1)::before,
.cmshtml .toggle-box > div:nth-child(2n-1)::after {
  content: " ";
  width: 22px;
  height: 22px;
  position: absolute;
  right: 10px;
  top: 17px;
  bottom: 0;
  background: url("../img/h4.png") no-repeat center;
  background-size: contain;
}

.cmshtml .openbox::after,
.cmshtml .toggle-box > div:nth-child(2n-1)::after {
  width: 12px;
  height: 2px;
  background: #fff;
  transform: rotate(90deg);
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  right: 15px;
  top: 27px;
}

.cmshtml .openbox.open::after,
.cmshtml .toggle-box > div:nth-child(2n-1).open::after {
  transform: rotate(0deg);
}

.cmshtml .toggle-box {
  position: relative;
}

.cmshtml .toggle-box > div:nth-child(2n) {
  padding: 12px 20px;
  position: relative;
  display: none;
}

.cmshtml .toggle-box > div:nth-child(2n).open {
  display: block;
}

.cmshtml .dot_txt > div {
  padding-left: 20px !important;
  position: relative;
}

.cmshtml .dot_txt > div::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(0.45em + 0px);
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background: #FCA9A7;
}

.cmshtml .dot_txt2 > div {
  padding-left: 20px !important;
  position: relative;
}

.cmshtml .dot_txt2 > div::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(0.45em + 0px);
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background: #FEA645;
}

.cmshtml .car_txt > div {
  padding-left: 28px !important;
  position: relative;
}

.cmshtml .car_txt > div::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(0.25em + 0px);
  background: url("../img/ico_car.png") no-repeat 0 0;
  width: 20px;
  height: 20px;
}

.cmshtml .train_txt > div {
  padding-left: 28px !important;
  position: relative;
}

.cmshtml .train_txt > div::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(0.25em + 0px);
  background: url("../img/ico_train.png") no-repeat 0 0;
  width: 20px;
  height: 20px;
}

.cmshtml .ol-list {
  counter-reset: item;
  position: relative;
  padding-bottom: 1.5em;
  padding-left: 0;
}

.cmshtml .ol-list .ol-list_li {
  list-style-type: none;
  position: relative;
  padding-left: 60px;
  padding-bottom: 10px;
}

.cmshtml .ol-list .ol-list_li:before {
  position: absolute;
  left: 0px;
  top: 4;
  font-family: 'Roboto', Helvetica Neue, Helvetica, YuGothic, "游ゴシック", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  font-weight: 700;
  color: #fff;
  letter-spacing: 0;
  font-size: 30px;
  font-size: 1.875rem;
  width: 50px;
  height: 50px;
  line-height: 48px;
  border: 2px solid #FCA9A7;
  background: -moz-linear-gradient(to top, #FCA9A7 50%, #fff 50%);
  background: -webkit-linear-gradient(to top, #FCA9A7 50%, #fff 50%);
  background: linear-gradient(to top, #FCA9A7 50%, #fff 50%);
  background: #FCA9A7;
  text-align: center;
  flex-shrink: 1;
  counter-increment: item;
  content: counter(item) "";
  display: inline-block;
  box-sizing: border-box;
  border-radius: 5px;
}

.cmshtml .flow {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(20px, 3vw, 40px);
  align-items: start;
  margin-inline: auto;
  width: 1000px;
  max-width: 100%;
  padding-block: clamp(60px, 8vw, 100px);
  isolation: isolate;
  position: relative;
}

.cmshtml .flow::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  pointer-events: none;
  width: 100vw;
  max-width: 100vw;
  top: 0;
  bottom: 0;
  left: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background: radial-gradient(120% 28% at 70% 10%, rgba(164, 227, 186, 0.38) 0%, rgba(164, 227, 186, 0.3) 55%, rgba(164, 227, 186, 0) 100%), radial-gradient(120% 28% at 25% 35%, rgba(255, 186, 208, 0.36) 0%, rgba(255, 186, 208, 0.28) 55%, rgba(255, 186, 208, 0) 100%), radial-gradient(120% 28% at 75% 62.5%, rgba(255, 210, 148, 0.38) 0%, rgba(255, 210, 148, 0.3) 55%, rgba(255, 210, 148, 0) 100%), radial-gradient(120% 28% at 30% 80.5%, rgba(170, 215, 255, 0.36) 0%, rgba(170, 215, 255, 0.28) 55%, rgba(170, 215, 255, 0) 100%);
}

.cmshtml .flow::after {
  position: absolute;
  content: "";
  z-index: -1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: url("../img/left.png") no-repeat left center, url("../img/right.png") no-repeat right center;
  filter: drop-shadow(0 0 1px rgba(255, 255, 255, 0.85)) drop-shadow(0 0 2px rgba(255, 255, 255, 0.45));
  mix-blend-mode: screen;
  pointer-events: none;
  width: 100vw;
  max-width: 100vw;
  top: 0;
  bottom: 0;
  left: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

@media screen and (max-width: 800px) {
  .cmshtml .flow::after {
    background: url("../img/left.png") no-repeat left top, url("../img/right.png") no-repeat right bottom;
  }
}

@media (max-width: 800px) {
  .cmshtml .flow {
    grid-template-columns: 1fr;
    gap: 60px;
  }
}

.cmshtml .flow .flow_ul {
  position: relative;
  display: grid;
  gap: 18px;
}

@media (max-width: 800px) {
  .cmshtml .flow .flow_ul::before, .cmshtml .flow .flow_ul::after {
    opacity: 0.35;
  }
}

.cmshtml .flow .flow_ul .flow_li {
  z-index: 1;
  display: grid;
  grid-template-columns: 80px 1fr;
  align-items: center;
  column-gap: 18px;
  min-height: 100px;
}

.cmshtml .flow .flow_ul .flow_li::before {
  content: "";
  position: absolute;
  left: 40px;
  top: -28px;
  bottom: -28px;
  width: 2px;
  background: repeating-linear-gradient(to bottom, #777 0 4px, transparent 4px 8px);
  opacity: 0.7;
  height: calc(100% - 56px);
  z-index: -1;
}

.cmshtml .flow .flow_ul .flow_li:first-child::before {
  top: 28px;
}

.cmshtml .flow .flow_ul .flow_li:last-child::before {
  bottom: 28px;
}

.cmshtml .flow .flow_ul .flow_li .prim {
  position: relative;
  z-index: 2;
  font-family: "Zen Maru Gothic",'Noto Sans JP',YuGothic, "游ゴシック", "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  width: 80px;
  height: 80px;
  border-radius: 50%;
  place-items: center;
  font-weight: 800;
  color: #fff;
  background: #9ecb3b;
  font-size: 40px;
  font-size: 2.5rem;
  display: inline-block;
  text-align: center;
  line-height: 75px;
  letter-spacing: 0;
}

.cmshtml .flow .flow_ul .flow_li .prim::before {
  position: absolute;
  content: "";
  border: 1px dashed rgba(255, 255, 255, 0.6);
  left: 3px;
  top: 3px;
  height: calc(100% - 8px);
  width: calc(100% - 8px);
  border-radius: 50%;
}

.cmshtml .flow .flow_ul .flow_li .prim >div p::after {
  content: "月";
  font-size: 24px;
  display: inline;
}

.cmshtml .flow .flow_ul .flow_li .txt, .cmshtml .flow .flow_ul .flow_li .rdplanetext {
  line-height: 1.6;
  font-weight: 600;
  color: #222;
}

.cmshtml .flow .flow_ul > div {
  position: relative;
}

.cmshtml .flow .flow_ul > div:nth-child(-n+3) .prim {
  background: #8DDDA5;
}

.cmshtml .flow .flow_ul > div:nth-child(n+4):nth-child(-n+6) .prim {
  background: #F49A9A;
}

.cmshtml .flow .flow_ul > div:nth-child(n+7):nth-child(-n+9) .prim {
  background: #FEAF58;
}

.cmshtml .flow .flow_ul > div:nth-child(n+10) .prim {
  background: #95C0E8;
}

.cmshtml .flow .flex_img {
  display: grid;
  gap: clamp(16px, 3vw, 40px);
  grid-template-columns: 1fr;
  align-items: start;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 800px) {
  .cmshtml .flow .flex_img {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}

.cmshtml .flow .flex_img >div{
  width: clamp(0px, 100%, 400px);
  position: relative;
}

.cmshtml .flow .flex_img >div::before, .cmshtml .flow .flex_img >div::after {
  position: absolute;
  content: "";
}

.cmshtml .flow .flex_img >div:nth-child(odd) {
  justify-self: start;
}

.cmshtml .flow .flex_img >div:nth-child(even)  {
  justify-self: end;
}

.cmshtml .flow .flex_img .imgwrap img ,
.cmshtml .flow .flex_img .rdplaneimage img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
}

.cmshtml .flow .flex_img >div:nth-child(1):before  {
  right: -60px;
  width: 110px;
  height: 95px;
  background: url("../img/ico_spr.png") no-repeat 0 0;
  top: -60px;
  z-index: -1;
}

.cmshtml .flow .flex_img >div:nth-child(2):before {
  left: -60px;
  width: 85px;
  height: 69px;
  background: url("../img/ico_sum.png") no-repeat 0 0;
  bottom: 0%;
  z-index: 1;
}

.cmshtml .flow .flex_img >div:nth-child(2):after  {
  right: -10px;
  width: 127px;
  height: 127px;
  background: url("../img/ico_sum2.png") no-repeat 0 0;
  top: -80px;
  z-index: -1;
}

.cmshtml .flow .flex_img >div:nth-child(3):before {
  right: -60px;
  width: 97px;
  height: 86px;
  background: url("../img/ico_aut.png") no-repeat 0 0;
  top: 20%;
  z-index: 1;
}

.cmshtml .flow .flex_img >div:nth-child(3):after {
  left: -10px;
  width: 96px;
  height: 80px;
  background: url("../img/ico_aut2.png") no-repeat 0 0;
  bottom: -10px;
  z-index: 2;
}

.cmshtml .flow .flex_img >div:nth-child(4):before {
  left: -70px;
  width: 94px;
  height: 87px;
  background: url("../img/ico_win.png") no-repeat 0 0;
  bottom: 10%;
  z-index: -1;
}

.cmshtml .flow .flex_img >div:nth-child(4):after  {
  right: 10px;
  width: 39px;
  height: 44px;
  background: url("../img/ico_win2.png") no-repeat 0 0;
  bottom: -40px;
  z-index: -1;
}

.cmshtml .food-hero {
  position: relative;
  padding: clamp(56px, 7vw, 110px) 16px;
}

.cmshtml .food-hero::before {
  content: "";
  position: absolute;
  inset: -20%;
  background: radial-gradient(60% 45% at 18% 20%, rgba(255, 220, 170, 0.45) 0%, rgba(255, 220, 170, 0) 70%), radial-gradient(55% 40% at 85% 30%, rgba(193, 231, 208, 0.4) 0%, rgba(193, 231, 208, 0) 70%), radial-gradient(60% 45% at 70% 85%, rgba(200, 224, 255, 0.4) 0%, rgba(200, 224, 255, 0) 72%), url("../img/texture2.png") repeat;
  z-index: 0;
  pointer-events: none;
  width: 100vw;
  max-width: 100vw;
  top: 0;
  bottom: 0;
  left: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.cmshtml .food-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/syoku.png") no-repeat left center, url("../img/syokur.png") no-repeat right center, radial-gradient(circle at 12% 25%, rgba(255, 255, 255, 0.55) 0 2px, transparent 3px), radial-gradient(circle at 24% 70%, rgba(255, 255, 255, 0.55) 0 2px, transparent 3px), radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.55) 0 2px, transparent 3px), radial-gradient(circle at 88% 62%, rgba(255, 255, 255, 0.55) 0 2px, transparent 3px);
  opacity: .65;
  z-index: 0;
  pointer-events: none;
  background-size: contain;
}

.cmshtml .food-box {
  position: relative;
  z-index: 1;
  max-width: 860px;
  margin: 0 auto;
  padding: clamp(28px, 4.5vw, 52px);
  border-radius: 26px;
  backdrop-filter: blur(6px);
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(160, 140, 110, 0.12);
  text-align: center;
  background: url("../img/syoku01.png") no-repeat left 10px bottom 20px, rgba(255, 255, 255, 0.88) url("../img/syoku02.png") no-repeat right 10px bottom 20px;
  padding-bottom: 120px;
}

.cmshtml .food-title {
  margin: 0 0 20px;
  font-weight: 800;
  letter-spacing: .08em;
  font-size: clamp(26px, 3.6vw, 40px);
  color: #4a3b2f;
  position: relative;
  display: inline-block;
  font-family: 'Kiwi Maru','Noto Sans JP', "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  /* ゆるい波線っぽい下線（CSSだけ） */
}

.cmshtml .food-title::after {
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: -10px;
  height: 8px;
  background: radial-gradient(circle at 10% 60%, rgba(219, 188, 138, 0.55) 0 3px, transparent 4px), radial-gradient(circle at 30% 40%, rgba(219, 188, 138, 0.55) 0 3px, transparent 4px), radial-gradient(circle at 50% 60%, rgba(219, 188, 138, 0.55) 0 3px, transparent 4px), radial-gradient(circle at 70% 40%, rgba(219, 188, 138, 0.55) 0 3px, transparent 4px), radial-gradient(circle at 90% 60%, rgba(219, 188, 138, 0.55) 0 3px, transparent 4px);
  opacity: .9;
}

.cmshtml .food-lead {
  margin: 0 auto;
  max-width: 44em;
  font-size: 15px;
  line-height: 2.0;
  color: #3f3a35;
}

.cmshtml .contactwrap {
  padding: clamp(80px, 7vw, 110px) 16px;
  text-align: center;
  background: url("../img/flag_l.png") no-repeat left 3vw top 30px, url("../img/flag_r.png") no-repeat right 3vw top 30px;
  position: relative;
}
.cmshtml .contactwrap::before {
background: url(../img/cont_lt.png) no-repeat left top, url(../img/cont_rb.png) no-repeat right 0 bottom 0;
content: "";
position: absolute;
left: 0;
bottom: 0;
width: 100%;
height: 100%;
pointer-events: none;
content: "";
position: absolute;
left: 0;
bottom: 0;
width: 100%;
height: 100%;
pointer-events: none;
z-index: -1;
width: 100vw;
max-width: 100vw;
margin: 0 calc(50% - 50vw);
height: 100%;
background-size: clamp(100px, 68vw, 662px),clamp(100px, 68vw, 565px);
}

@media screen and (max-width: 672px) {
  .cmshtml .contactwrap {
    background-size: clamp(100px, 49.875vw, 311px);
    background-position: left 0 top 30px,right 0 top 30px;
  }
}

.cmshtml .contactwrap .h2 {
  background: #442704;
  border-radius: 99em;
  padding: 12px 24px;
  font-weight: 700;
  color: #fff;
  position: relative;
  font-size: clamp(18px, 2.5vw, 28px);
  font-family: "Zen Maru Gothic",'Noto Sans JP',YuGothic, "游ゴシック", "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  display: inline-block;
  width: 400px;
  max-width: calc(100% - 20px);
  margin-bottom: 60px;
  margin-top: 60px;
}

.cmshtml .contactwrap .h2 >div::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 3px;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px dashed #fff;
  border-radius: 99em;
}

.cmshtml .contactwrap .h2::before {
  content: "";
  position: absolute;
  background: url("../img/ico05.png") no-repeat 0 0;
  width: 90px;
  height: 125px;
  left: 10px;
  bottom: calc(100% - 22px);
  z-index: 2;
  pointer-events: none;
}

.cmshtml .contactwrap .h2::after {
  content: "";
  position: absolute;
  background: url("../img/ico06.png") no-repeat 0 0;
  width: 63px;
  height: 89px;
  right: 25px;
  bottom: calc(100% - 7px);
  z-index: 2;
  pointer-events: none;
}

.cmshtml .contactwrap .gridinner {
  display: grid;
  grid-template-columns: repeat(2, max-content);
  gap: 30px;
  justify-content: center;
  padding: clamp(30px, 4vw, 40px) 0;
}

@media screen and (max-width: 576px) {
  .cmshtml .contactwrap .gridinner {
    grid-template-columns: 1fr;
  }
}

.cmshtml .contactwrap .btns {
  font-weight: 700;
  transition: all 0.2s ease 0s;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.08);
  position: relative;
  bottom: 0;
  border-radius: 99em;
  min-width: 280px;
}

.cmshtml .contactwrap .btns:hover {
  bottom: -2px;
}

.cmshtml .contactwrap .btns a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.cmshtml .contactwrap .tel{
border:#FCA9A7 2px solid;
}
.cmshtml .contactwrap .tel a {
  background-position: 30px center;
  padding: 10px 28px 10px 58px;
  font-size: clamp(26px, 3.0vw, 30px);
  background-image: url("../img/ico_tel3.png") ;
}

.cmshtml .contactwrap .mail a {
  padding: 14px 30px 14px 60px;
}

.cmshtml .slider-area {
  z-index: 0;
  position: relative;
  overflow: hidden;
}

.cmshtml .slider-area .top-slide {
  padding-top: 0px;
}

.cmshtml #slide-wrap {
  position: relative;
  width: 100%;
}

.cmshtml .no-flexbox #slide-wrap .swiper-wrapper {
  width: 900px;
  margin: 0 auto;
}

.cmshtml #slide-wrap.swiper-container .swiper-slide {
  width: auto;
}

.cmshtml #slide-wrap.swiper-container .swiper-slide img {
  max-height: 100%;
  width: auto;
}

.cmshtml .no-flexbox #slide-wrap.swiper-container {
  overflow: hidden;
}

.cmshtml .no-flexbox #slide-wrap.swiper-container .swiper-slide {
  float: left;
}

.cmshtml #slide-wrap .swiper-pagination .swiper-pagination-bullet {
  background-color: rgba(255, 255, 255, 0.3);
  opacity: 1.0;
}

.cmshtml #slide-wrap .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #fea645;
}

.cmshtml #slide-wrap .slide-wrap:hover .swiper-pagination {
  opacity: 1.0;
}

.cmshtml #slide-wrap .swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 5px;
}

.cmshtml #slide-wrap .swiper-pagination-fraction, .cmshtml #slide-wrap .swiper-pagination-custom, .cmshtml #slide-wrap .swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 2px;
}

.cmshtml .top-slide {
  position: relative;
  overflow: hidden;
}

.cmshtml .top-slide .swiper-button-prev, .cmshtml .top-slide .swiper-button-next {
  opacity: 0;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23ffff'%2F%3E%3C%2Fsvg%3E");
}

.cmshtml .top-slide .swiper-button-next {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E");
}

.cmshtml .top-slide:hover .swiper-button-prev, .cmshtml .top-slide:hover .swiper-button-next {
  opacity: 0.7;
}

.cmshtml .swiper-container .swiper-slide {
  position: relative;
}

.cmshtml .swiper-slide-content {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0, -50%);
  max-width: 40%;
}

.cmshtml .swiper-slide-active .swiper-slide-content {
  animation: fromB .8s ease-in-out 0.1s 1 normal both;
}

.cmshtml .swiper-container {
  height: 600px;
}

.cmshtml .swiper-slide,.cmshtml .swiper-slide >div {
  height: 100%;
}


.cmshtml .swiper-slide img {
  border-radius: 10px;
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

@media (max-width: 800px) {
  .cmshtml .swiper-container {
    height: 300px;
  }
  .cmshtml #slide-wrap.swiper-container .swiper-slide img{
  max-width: none;
  }
}

.cmshtml .min {
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", HGS明朝E,serif;
}

.cmshtml .conceptstyle {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
}

@media screen and (max-width: 800px) {
  .cmshtml .conceptstyle {
    display: block;
  }
}

.cmshtml .conceptstyle > div {
  width: 50%;
  position: relative;
}

@media screen and (max-width: 800px) {
  .cmshtml .conceptstyle > div {
    width: 100%;
    max-width: 100%;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    min-height: 1px;
  }
}

.cmshtml .conceptstyle.rev {
  flex-direction: row-reverse;
}

.cmshtml .top_about {
  position: relative;
  background: url("../img/about_lt.png") no-repeat left top, url("../img/about_rb.png") no-repeat right bottom, #F8F9F1 url("../img/about_lb.png") no-repeat left 4vw bottom 0;
  padding-top: 50px;
  padding-bottom: 30px;
  position: relative;
  min-height: 775px;
  padding-bottom: 120px;
}

@media screen and (max-width: 1000px) {
  .cmshtml .top_about {
    background: url("../img/about_lt.png") no-repeat left top, url("../img/about_rb.png") no-repeat right bottom, #F8F9F1 url("../img/about_lb.png") no-repeat left 1vw bottom 400px;
    padding-left: 5%;
    padding-right: 5%;
  }
}

@media screen and (max-width: 800px) {
  .cmshtml .top_about {
    background: linear-gradient(rgba(248, 249, 241, 0.35), rgba(248, 249, 241, 0.35)), url("../img/about_lt.png") no-repeat left top, url("../img/about_rb.png") no-repeat right bottom, #F8F9F1 url("../img/about_lb.png") no-repeat left 1vw bottom 400px;
  }
}

.cmshtml .top_about .about_figure > div {
  position: absolute;
}

.cmshtml .top_about .about_figure > div:nth-child(1) {
  top: 225px;
  left: calc( 50% - 750px);
}

.cmshtml .top_about .about_figure > div:nth-child(2) {
  top: 90px;
  right: calc( 50% - 750px);
}

@media screen and (max-width: 1500px) {
  .cmshtml .top_about .about_figure > div:nth-child(1) {
    top: 240px;
    left: 1vw;
  }
  .cmshtml .top_about .about_figure > div:nth-child(2) {
    top: 90px;
    right: 1vw;
  }
}

@media screen and (min-width: 1001px) and (max-width: 1380px) {
  .cmshtml .top_about .about_figure .imgwrap {
    max-width: 27vw;
  }
}

.cmshtml .top_about .about_figure .imgwrap img {
  border-radius: 50px;
}

@media screen and (max-width: 1000px) {
  .cmshtml .top_about .about_figure {
    margin: 0 auto 40px;
    max-width: 743px;
    width: 100%;
    display: flex;
    border-radius: 30px;
    overflow: hidden;
  }
  .cmshtml .top_about .about_figure > div {
    width: 50%;
    position: relative;
    aspect-ratio: 400 / 533;
    overflow: hidden;
  }
  .cmshtml .top_about .about_figure > div:nth-child(1) {
    top: 0;
    left: 0;
  }
  .cmshtml .top_about .about_figure > div:nth-child(1) img {
    border-radius: 30px 0 0 30px;
  }
  .cmshtml .top_about .about_figure > div:nth-child(2) {
    top: 0;
    left: 0;
  }
  .cmshtml .top_about .about_figure > div:nth-child(2) img {
    border-radius: 0 30px 30px 0;
  }
}

.cmshtml .top_about .about_title {
  text-align: center;
}

.cmshtml .top_about .about_title .h2 {
  font-family: 'Kiwi Maru','Noto Sans JP', "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  font-size: clamp(22px, 2.5vw, 30px);
  letter-spacing: -1px;
  margin-bottom: clamp(30px, 7vw, 70px);
  font-weight: 500;
  margin-top: 15px;
}

@media screen and (max-width: 100px) {
  .cmshtml .top_about .about_title .h2 {
    font-size: clamp(24px, 4.5vw, 30px);
    letter-spacing: 0px;
    line-height: 1.7;
  }
}

.cmshtml .top_about .about_title .h3 {
  width: 500px;
  max-width: 100%;
  font-weight: 700;
  font-size: clamp(16px, 2.5vw, 18px);
  margin-bottom: clamp(30px, 4vw, 60px);
  text-align: left;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}

.cmshtml .top_about .about_title .txt, .cmshtml .top_about .about_title .rdplanetext {
  width: 500px;
  max-width: 100%;
  font-size: clamp(15px, 2.3vw, 16px);
  margin-bottom: clamp(40px, 4vw, 60px);
  text-align: left;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}

@media screen and (min-width: 1001px) and (max-width: 1380px) {
  .cmshtml .top_about .about_title .h3, .cmshtml .top_about .about_title .txt, .cmshtml .top_about .about_title .rdplanetext {
    width: 400px;
  }
}

.cmshtml .top_about .about_title .btn_wrap {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px 20px;
}

.cmshtml .top_about .about_title .btn_wrap .link_btn {
  font-weight: 700;
}

.cmshtml .top_about .about_title .btn_wrap .link_btn a {
  background: url("../img/bg01.jpg") repeat;
}

.cmshtml .top_about .about_title .btn_wrap >div:nth-child(2n) a {
  background: url("../img/bg02.jpg") repeat;
}

.cmshtml .link_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px 20px;
}

.cmshtml .top_news {
  position: relative;
  padding-top: clamp(50px, 6vw, 80px);
  padding-bottom: clamp(50px, 6vw, 80px);
}

.cmshtml .top_news .title_wrap {
  width: 25%;
}

@media screen and (max-width: 800px) {
  .cmshtml .top_news .title_wrap {
    width: 100%;
    display: flex;
    gap: 20px;
    margin-bottom: 30px;
    align-items: center;
    flex-wrap: wrap;
  }
}

.cmshtml .top_news .title_wrap .h2 {
  font-weight: 400;
  color: #555555;
  font-size: clamp(30px, 6vw, 60px);
  z-index: -1;
  position: relative;
}

.cmshtml .top_news .title_wrap .h3 {
  font-weight: 700;
  font-size: clamp(14px, 1vw, 16px);
  color: #444444;
  line-height: 1.2;
  display: inline-block;
  text-align: center;
  z-index: -1;
  position: relative;
}

.cmshtml .top_news .title_wrap .link_btn {
  margin-top: 40px;
  margin-left: auto;
}

@media screen and (max-width: 800px) {
  .cmshtml .top_news .title_wrap .link_btn {
    margin-top: auto;
  }
}

.cmshtml .top_news .title_wrap .link_btn a {
  background: linear-gradient(to right, #FEBE7C 0%, #FDC0B2 33%, #F9ADAD 66%, #F18F91 100%);
  padding: 11px 33px;
}

.cmshtml .top_news .top_news__wrap {
  width: 75%;
  max-height: 282px;
  overflow: auto;
  margin-top: 20px;
}

@media screen and (max-width: 800px) {
  .cmshtml .top_news .top_news__wrap {
    width: 100%;
  }
}

.cmshtml .top_news__wrap .rdnewArticle .rdnewArticle-item + .rdnewArticle-item {
  border-top: 0;
}

.cmshtml .top_news__wrap .rdnewArticle {
  border: none;
  padding-left: 0;
  padding-right: 0;
}

.cmshtml .top_news__wrap .top_news__dl, .cmshtml .top_news__wrap .rdnewArticle .rdnewArticle-item .rdnewArticle-contWrap {
  padding: 22px 0;
  display: flex;
  flex-wrap: wrap;
  position: relative;
  border-top: none;
  border-bottom: 1px dotted #A4A4A4;
}

.cmshtml .top_news__wrap .top_news__dt, .cmshtml .top_news__wrap .rdnewArticle .rdnewArticle-item .rdnewArticle-contWrap .rdnewArticle-ContDate {
  letter-spacing: 0;
  flex-shrink: 1;
  font-size: 14px;
  font-size: 0.875rem;
  width: 120px;
  font-weight: 700;
  color: #FEA645;
}

.cmshtml .top_news__wrap .top_news__dd, .cmshtml .top_news__wrap .rdnewArticle .rdnewArticle-item .rdnewArticle-contWrap .rdnewArticle-ContTitle {
  flex-shrink: 1;
  width: calc(100% - 120px);
}

.cmshtml .top_news__wrap .top_news__dd a, .cmshtml .top_news__wrap .rdnewArticle .rdnewArticle-item .rdnewArticle-contWrap .rdnewArticle-ContTitle a {
  display: block;
  position: relative;
  padding-left: 25px;
  text-decoration: none;
}

.cmshtml .top_news__wrap .top_news__dd a::before, .cmshtml .top_news__wrap .rdnewArticle .rdnewArticle-item .rdnewArticle-contWrap .rdnewArticle-ContTitle a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  font-weight: 700;
  box-sizing: border-box;
  color: #FCA9A7;
  background: url("../img/arrow2.png") no-repeat left center;
  width: 8px;
  height: 12px;
}

.cmshtml .grid3 {
  display: grid;
  grid-template: auto/repeat(3, 1fr);
  gap: 50px 30px;
  position: relative;
  justify-items: center;
}

@media screen and (max-width: 800px) {
  .cmshtml .grid3 {
    grid-template: auto/repeat(2, 1fr);
    justify-content: center;
    gap: 50px 20px;
  }
}

@media screen and (max-width: 576px) {
  .cmshtml .grid3 {
    grid-template: auto/repeat(1, 1fr);
  }
}

@keyframes katakata {
  0% {
    transform: translateY(-2px) rotate(6deg);
  }
  10% {
    transform: translate(0) rotate(0deg);
  }
  20% {
    transform: translate(0) rotate(-6deg);
  }
  30% {
    transform: translateY(-2px) rotate(0deg);
  }
  40% {
    transform: translateY(-2px) rotate(6deg);
  }
  50% {
    transform: translate(2px) rotate(-2deg);
  }
  60% {
    transform: translateY(2px) rotate(0deg);
  }
  70% {
    transform: translate(0) rotate(6deg);
  }
  80% {
    transform: translate(2px) rotate(-2deg);
  }
  90% {
    transform: translate(0) rotate(0deg);
  }
  100% {
    transform: translateY(-2px) rotate(6deg);
  }
}

@keyframes katakata2 {
  0% {
    transform: otate(-16deg);
  }
  20% {
    transform: rotate(16deg);
  }
  40% {
    transform: rotate(-16deg);
  }
  50% {
    transform: rotate(12deg);
  }
  70% {
    transform: rotate(-16deg);
  }
  80% {
    transform: rotate(12deg);
  }
  100% {
    transform: rotate(-16deg);
  }
}

.cmshtml .top_info {
  padding-top: 70px;
  text-align: center;
  padding-bottom: 100px;
  overflow: hidden;
}

.cmshtml .top_info .title_area {
  width: 1100px;
  position: relative;
  z-index: -1;
}

.cmshtml .top_info .title_area .deco {
  position: absolute;
  animation: katakata2 15s step-start 0s infinite normal;
  z-index: -1;
}

@media screen and (max-width: 800px) {
  .cmshtml .top_info .title_area .deco {
    margin-top: 80px;
    opacity: 0.7;
  }
}

.cmshtml .top_info .title_area .deco01 {
  left: 60px;
  top: 5vw;
  animation: katakata 15s step-start 0s infinite normal;
}

.cmshtml .top_info .title_area .deco02 {
  left: 0px;
  top: calc(5vw + 70px);
}

.cmshtml .top_info .title_area .deco03 {
  left: 40px;
  top: calc(5vw + 145px);
}

.cmshtml .top_info .title_area .deco04 {
  right: 40px;
  top: calc(5vw - 15px);
}

.cmshtml .top_info .title_area .deco05 {
  right: 0px;
  top: calc(5vw + 60px);
  animation: katakata 10s step-start 0s infinite normal;
}

.cmshtml .top_info .title_area .deco06 {
  right: 50px;
  top: calc(5vw + 150px);
}

.cmshtml .top_info .txt {
  display: inline-block;
  text-align: left;
}

.cmshtml .top_info .h2 {
  font-family: 'Kiwi Maru','Noto Sans JP', "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  font-weight: 500;
  letter-spacing: 0;
  margin-top: 30px;
  margin-bottom: 30px;
  font-size: clamp(20px, 2.5vw, 30px);
}

.cmshtml .contents_list {
  margin-top: 60px;
  width: 1100px;
  gap: 20px;
}

.cmshtml .contents_list > div {
  background: #FCF2F4;
  margin-bottom: 2vw;
}

.cmshtml .contents_list > div:nth-child(3n) {
  background: #EFF7EE;
}

.cmshtml .contents_list > div:nth-child(3n - 1) {
  background: #FCFBF2;
}

.cmshtml .contents_list .contents_li {
  margin-left: auto;
  margin-right: auto;
  width: clamp(100px, 30vw, 320px);
  height: clamp(100px, 30vw, 320px);
  border-radius: 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cmshtml .contents_list .imgwrap {
  text-align: center;
}

.cmshtml .contents_list .h4 {
  font-weight: 500;
  margin-top: 20px;
  font-size: clamp(18px, 2.5vw, 21px);
  position: relative;
}

@media screen and (max-width: 800px) {
  .cmshtml .contents_list {
    grid-template: auto/repeat(3, 1fr);
  }
  .cmshtml .contents_list .contents_li {
    border-radius: 40px;
  }
}

@media screen and (max-width: 576px) {
  .cmshtml .contents_list {
    display: flex;
    flex-wrap: wrap;
  }
  .cmshtml .contents_list .contents_li {
    border-radius: 40px;
    width: clamp(240px, 42vw, 320px);
    height: clamp(240px, 42vw, 320px);
  }
}

.cmshtml .top_rec {
  width: 1340px;
  padding-top: 80px;
  padding-bottom: 80px;
  padding-left: 54px;
  flex-wrap: nowrap;
}

.cmshtml .top_rec::before {
  background: #F8F4EE;
  content: "";
  width: 100vw;
  max-width: 100vw;
  margin: 0 calc(50% - 50vw);
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

.cmshtml .top_rec::after {
  z-index: -1;
  position: absolute;
  right: 0;
  bottom: 80px;
  background: url("../img/bgo03.png") no-repeat right bottom;
  width: 300px;
  height: 341px;
  content: "";
}

.cmshtml .top_rec .imgwrap, .cmshtml .top_rec .rdplaneimage {
  border-radius: 73% 63% 57% 74%/88% 76% 64% 56%;
  background: linear-gradient(to right, #FEBE7C 0%, #FDC0B2 33%, #F9ADAD 66%, #F18F91 100%);
  padding: 4px;
  z-index: 1;
  position: relative;
  margin-right: -50px;
  margin-bottom: auto;
}

.cmshtml .top_rec .imgwrap::before, .cmshtml .top_rec .rdplaneimage::before {
  content: "";
  position: absolute;
  left: -54px;
  top: -30px;
  background: url("../img/bgo01.png") no-repeat 0;
  width: 254px;
  height: 250px;
  z-index: -1;
}

.cmshtml .top_rec .imgwrap::after, .cmshtml .top_rec .rdplaneimage::after {
  content: "";
  background: url("../img/ico04.png") no-repeat 0 0;
  width: 129px;
  height: 213px;
  position: absolute;
  right: -50px;
  top: 0;
  animation: fuwafuwa2 8s ease-out infinite;
  background-size: 100% 100%;
}

.cmshtml .top_rec .imgwrap img, .cmshtml .top_rec .rdplaneimage img {
  border-radius: 73% 63% 57% 74%/88% 76% 64% 56%;
}

.cmshtml .top_rec .text_area {
  width: calc(100% - 550px);
  width: 600px;
  max-width: 100%;
  background: url("../img/bgo02.png") no-repeat 0 0;
  background-size: 100% 100%;
  padding: 55px;
  text-align: center;
  margin-right: auto;
  position: relative;
}

.cmshtml .top_rec .text_area .h2 {
  font-size: 36px;
  font-size: 2.25rem;
  font-weight: 700;
  color: #755514;
  padding-bottom: 15px;
  background: url("../img/dot.png") repeat-x bottom;
  width: 230px;
  text-align: center;
  display: inline-block;
}

.cmshtml .top_rec .text_area .txt, .cmshtml .top_rec .text_area .rdplanetext {
  line-height: 2;
  margin-top: clamp(20px, 3vw, 30px);
}

.cmshtml .top_rec .text_area .link_btn {
  margin-top: clamp(20px, 3vw, 45px);
}

.cmshtml .top_rec .text_area .link_btn a {
  background: #fff;
  -webkit-transition: all .3s;
  transition: all .3s;
  border: 0px solid #FEA645;
  color: #333;
}

.cmshtml .top_rec .text_area .link_btn a:hover {
  transform: scale(1.1, 1.1);
  opacity: 1;
  border-width: 3px;
}

@media screen and (max-width: 1120px) {
  .cmshtml .top_rec {
    padding-left: 10px;
  }
  .cmshtml .top_rec > div {
    width: 50%;
  }
  .cmshtml .top_rec .text_area, .cmshtml .top_rec .imgwrap {
    width: 50%;
  }
  .cmshtml .top_rec .imgwrap {
    margin-right: -30px;
  }
  .cmshtml .top_rec .imgwrap::before {
    left: -6px;
  }
}

@media screen and (max-width: 800px) {
  .cmshtml .top_rec {
    flex-wrap: wrap;
    width: 550px;
  }
  .cmshtml .top_rec > div {
    width: 100%;
  }
  .cmshtml .top_rec .imgwrap, .cmshtml .top_rec .rdplaneimage, .cmshtml .top_rec .text_area {
    width: 100%;
    margin-right: auto;
  }
  .cmshtml .top_rec .imgwrap {
    margin-bottom: -30px;
  }
  .cmshtml .top_rec .text_area {
    padding: 40px 3vw 50px;
  }
}

.cmshtml .forfixed {
  margin-top: 0px;
}

@media screen and (max-width: 1200px) {
  .cmshtml .forfixed {
    margin-top: 0px;
    padding-top: 0px;
  }
}

@keyframes upup {
  0% {
    margin-top: 245px;
    transform: scale(1);
  }
  100% {
    margin-top: -200px;
    transform: scale(0.84);
  }
}

@-webkit-keyframes fuwafuwa2 {
  0% {
    -webkit-transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, -10px);
  }
  100% {
    -webkit-transform: translate(0, 0);
  }
}

@keyframes fuwafuwa2 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, -10px);
  }
  100% {
    transform: translate(0, 0);
  }
}

@keyframes kuru {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes bg-pop {
  0% {
    background-size: 40px auto;
  }
  50% {
    background-size: 48px auto;
  }
  100% {
    background-size: 40px auto;
  }
}

@keyframes bg-wiggle {
  0% {
    background-position: center 23px;
  }
  5% {
    background-position: center 18px;
  }
  10% {
    background-position: center 26px;
  }
  15% {
    background-position: center 23px;
  }
  100% {
    background-position: center 23px;
  }
}

@keyframes wiggle {
  0% {
    margin-bottom: 0;
  }
  5% {
    margin-bottom: -5px;
  }
  10% {
    margin-bottom: 6px;
  }
  15% {
    margin-bottom: 0;
  }
  100% {
    margin-bottom: 0;
  }
}

@keyframes pop {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.95);
  }
  100% {
    transform: scale(1);
  }
}

.cmshtml #acp-page #l-header .headinner {
  background-size: auto 100%,auto 100%;
}

.cmshtml #section_pageHeader {
  margin-bottom: 4vw;
  background: url("../img/head_lt.png") no-repeat left top, #F8F9F1 url("../img/head_rt.png") no-repeat right top;
  text-align: center;
  position: relative;
  padding-top: calc(1vw + 40px);
  padding-bottom: calc(1vw + 0px);
}

@media screen and (max-width: 800px) {
  .cmshtml #section_pageHeader {
    background: #F8F9F1 url("../img/headsp.png") no-repeat center top;
    background-size: cover;
  }
}

.cmshtml #section_pageHeader .jp {
  line-height: 1.5;
  font-weight: 500;
  font-size: clamp(34px, 3.8vw, 46px);
  position: relative;
  font-family: 'Kiwi Maru','Noto Sans JP', "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  padding-bottom: calc(1vw + 10px);
}

.cmshtml .title-navi_ul {
  padding-bottom: clamp(0px, 4.08163vw, 80px);
  padding-left: 0;
  padding-right: 0;
  display: grid;
  justify-content: center;
  gap: 22px 0;
  grid-template-columns: repeat(auto-fit, 300px);
  max-width: calc(300px * 4);
  margin-inline: auto;
}

@media screen and (max-width: 1200px) {
  .cmshtml .title-navi_ul {
    grid-template-columns: repeat(4, 1fr);
    max-width: 100%;
  }
}

@media screen and (max-width: 800px) {
  .cmshtml .title-navi_ul {
    letter-spacing: 0;
  }
}

@media (max-width: 420px) {
  .cmshtml .title-navi_ul {
    grid-template-columns: 1fr;
    margin-bottom: 40px;
    padding: 5px 16px;
    gap: 0;
    margin-left: auto;
    margin-right: auto;
    background: #F8F4EE;
    border-radius: 10px;
    width: calc(100% - 20px);
  }
}

.cmshtml .title-navi_ul > div {
  border-left: 1px dashed #777;
  position: relative;
  text-align: center;
  font-size: 15px;
  font-size: 0.9375rem;
  box-sizing: border-box;
  line-height: 1.6;
}

@media screen and (max-width: 800px) {
  .cmshtml .title-navi_ul > div {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

@media screen and (max-width: 576px) {
  .cmshtml .title-navi_ul > div {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

@media screen and (max-width: 420px) {
  .cmshtml .title-navi_ul > div {
    border-left: 0;
    border-right: 0;
    border-top: 1px dashed #777;
  }
  .cmshtml .title-navi_ul > div:first-child {
    border-top: 0;
  }
}

@media screen and (min-width: 421px) {
  .cmshtml .title-navi_ul > div:last-child, .cmshtml .title-navi_ul > div:nth-child(4n) {
    border-right: 1px dashed #777;
  }
}

.cmshtml .title-navi_ul > div a {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 10px 8px 20px;
  text-decoration: none;
  color: #3d3732;
  position: relative;
  transition: all 0.5s ease 0s;
}

.cmshtml .title-navi_ul > div a::before {
  content: "";
  box-sizing: border-box;
  width: 6px;
  height: 6px;
  position: absolute;
  bottom: 6px;
  right: 0;
  left: 0;
  margin: auto;
  border-right: 1px solid #666;
  border-bottom: 1px solid #666;
  transform: rotate(45deg);
  transition: all 0.5s ease 0s;
}

@media screen and (max-width: 420px) {
  .cmshtml .title-navi_ul > div a {
    flex-direction: row;
    justify-content: space-between;
    padding: 12px 6px;
  }
  .cmshtml .title-navi_ul > div a::before {
    left: auto;
    right: 2px;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
  }
}

.cmshtml .title-navi_ul > div:hover a {
  color: #FCA9A7;
  background: #FCF2F4;
}

.cmshtml .step_arrow {
  position: relative;
  height: 60px;
}

.cmshtml .step_arrow::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 24px 30px 0 30px;
  border-color: #FEA645 transparent transparent;
  position: absolute;
  bottom: calc(50% - 12px);
  left: 50%;
  transform: translate(-50%);
}

.cmshtml div.rdplanetitle h2 {
  font-size: clamp(30px, 3.5vw, 42px);
  position: relative;
  font-weight: 500;
  line-height: 1.5;
  font-family: 'Kiwi Maru','Noto Sans JP', "メイリオ", Meiryo,'Roboto', Helvetica Neue, Helvetica, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN";
  padding-top: 120px;
  margin-bottom: 40px;
  text-align: center;
}

.cmshtml div.rdplanetitle h2::before {
  content: "";
  width: 71px;
  height: 117px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  display: inline-block;
  background: url("../img/ico00.png") no-repeat center;
}

.cmshtml div.rdplanetitle h3 {
  line-height: 1.5;
  font-size: clamp(20px, 2.5vw, 28px);
  position: relative;
  padding: 12px 0;
  border-top: 2px solid #ccc;
}

.cmshtml div.rdplanetitle h3::before {
  content: "";
  position: absolute;
  width: 20%;
  height: 2px;
  left: 0;
  top: -2px;
  background: #FCA9A7;
}

.cmshtml div.rdplanetitle h4 {
  font-size: clamp(18px, 2vw, 24px);
  color: #333;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  padding: 13px 0;
  font-weight: 700;
  margin-bottom: 20px;
}

.cmshtml div.rdplanetitle h4::before {
  content: "";
  position: absolute;
  width: 40px;
  height: 2px;
  left: 0;
  bottom: 0px;
  background: #FCA9A7;
}

.cmshtml div.rdplanetitle h5 {
  font-size: clamp(17px, 1.4vw, 20px);
  font-weight: 700;
  position: relative;
  padding-left: 35px;
  padding-bottom: 5px;
  padding-top: 5px;
  color: #FCA9A7;
}

.cmshtml div.rdplanetitle h5::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  background: url("../img/shape4.png") no-repeat 0 0;
  background-size: cover;
  width: 24px;
  height: 24px;
}

.cmshtml #contents .rdplanetext .table table, .cmshtml #contents .rdplanetext2 .table table {
  border-collapse: collapse;
}

.cmshtml #contents .rdtableTable {
  border-collapse: collapse;
  border: 1px solid #A4A4A4;
}

.cmshtml #contents .rdtable tbody th {
  border-right-color: #A4A4A4;
  border-right-width: 1px;
  background: #FCF2F4;
}

@media screen and (max-width: 576px) {
  .cmshtml .rdplanetext, .cmshtml .rdplanetext2 {
    /* responsiv table block */
  }
  .cmshtml .rdplanetext.scrl_tb, .cmshtml .rdplanetext.scrtable, .cmshtml .rdplanetext2.scrl_tb, .cmshtml .rdplanetext2.scrtable {
    overflow: auto;
  }
  .cmshtml .rdplanetext.scrl_tb .table table, .cmshtml .rdplanetext.scrtable .table table, .cmshtml .rdplanetext2.scrl_tb .table table, .cmshtml .rdplanetext2.scrtable .table table {
    min-width: 576px;
  }
  .cmshtml .rdplanetext.scrl_tb .table table tr, .cmshtml .rdplanetext.scrtable .table table tr, .cmshtml .rdplanetext2.scrl_tb .table table tr, .cmshtml .rdplanetext2.scrtable .table table tr {
    display: table-row !important;
    width: auto;
  }
  .cmshtml .rdplanetext.scrl_tb .table table tr td, .cmshtml .rdplanetext.scrl_tb .table table tr th, .cmshtml .rdplanetext.scrtable .table table tr td, .cmshtml .rdplanetext.scrtable .table table tr th, .cmshtml .rdplanetext2.scrl_tb .table table tr td, .cmshtml .rdplanetext2.scrl_tb .table table tr th, .cmshtml .rdplanetext2.scrtable .table table tr td, .cmshtml .rdplanetext2.scrtable .table table tr th {
    display: table-cell;
    width: auto;
  }
  .cmshtml .rdplanetext.block_tb .table table tr td, .cmshtml .rdplanetext.block_tb .table table tr th, .cmshtml .rdplanetext.blocktable .table table tr td, .cmshtml .rdplanetext.blocktable .table table tr th, .cmshtml .rdplanetext2.block_tb .table table tr td, .cmshtml .rdplanetext2.block_tb .table table tr th, .cmshtml .rdplanetext2.blocktable .table table tr td, .cmshtml .rdplanetext2.blocktable .table table tr th {
    width: 100% !important;
  }
}

.cmshtml .rdplanetext.half_tb .table table th, .cmshtml .rdplanetext.half_tb .table table td, .cmshtml .rdplanetext.blockhalf .table table th, .cmshtml .rdplanetext.blockhalf .table table td, .cmshtml .rdplanetext2.half_tb .table table th, .cmshtml .rdplanetext2.half_tb .table table td, .cmshtml .rdplanetext2.blockhalf .table table th, .cmshtml .rdplanetext2.blockhalf .table table td {
  width: 50%;
}

@media screen and (max-width: 576px) {
  .cmshtml .rdplanetext.half_tb .table table th, .cmshtml .rdplanetext.half_tb .table table td, .cmshtml .rdplanetext.blockhalf .table table th, .cmshtml .rdplanetext.blockhalf .table table td, .cmshtml .rdplanetext2.half_tb .table table th, .cmshtml .rdplanetext2.half_tb .table table td, .cmshtml .rdplanetext2.blockhalf .table table th, .cmshtml .rdplanetext2.blockhalf .table table td {
    width: 100% !important;
  }
}

.cmshtml .rdplanetext.borderb_tb .table table th, .cmshtml .rdplanetext.borderb_tb .table table td, .cmshtml .rdplanetext.table_borderbottom .table table th, .cmshtml .rdplanetext.table_borderbottom .table table td, .cmshtml .rdplanetext2.borderb_tb .table table th, .cmshtml .rdplanetext2.borderb_tb .table table td, .cmshtml .rdplanetext2.table_borderbottom .table table th, .cmshtml .rdplanetext2.table_borderbottom .table table td {
  border: none;
  border-bottom: 1px solid #A4A4A4;
}

.cmshtml .dl_tb a, .cmshtml .datasheet a {
  min-height: 30px;
  display: inline-block;
  position: relative;
  padding-left: 35px;
  text-decoration: none;
  font-weight: 700;
}

.cmshtml .dl_tb a::before, .cmshtml .datasheet a::before {
  background-image: url(../img/download.png);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% 100%;
  width: 30px;
  height: 30px;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}

.cmshtml .dl_tb a[href*=".pdf"]::before, .cmshtml .datasheet a[href*=".pdf"]::before {
  background-image: url(../img/icon-pdf-m.png);
  background-size: 30px 30px;
}

.cmshtml .dl_tb a[href*=".doc"]::before, .cmshtml .dl_tb a[href*=".docx"]::before, .cmshtml .datasheet a[href*=".doc"]::before, .cmshtml .datasheet a[href*=".docx"]::before {
  background-image: url(../img/icon-word-m.png);
  background-size: 30px 30px;
}

.cmshtml .dl_tb a[href*=".xls"]::before, .cmshtml .dl_tb a[href*=".xlsx"]::before, .cmshtml .datasheet a[href*=".xls"]::before, .cmshtml .datasheet a[href*=".xlsx"]::before {
  background-image: url(../img/icon-xcel-m.png);
  background-size: 30px 30px;
}

.cmshtml .dl_tb a[href*=".zip"]::before, .cmshtml .datasheet a[href*=".zip"]::before {
  background-image: url(../img/zip.png);
  background-size: 30px 30px;
}

.cmshtml .dl_tb tr td:last-child a[href*=".pdf"]::before, .cmshtml .datasheet tr td:last-child a[href*=".pdf"]::before {
  background-image: url(../img/icon-pdf-g.png);
}

.cmshtml div.rdplanetext .table table th,
.cmshtml div.rdplanetext2 .table table th {
  background: #FCF2F4;
}

@media screen and (max-width: 576px) {
  .cmshtml .resp_tb table th {
    display: none;
  }
  .cmshtml .resp_tb table td {
    display: block;
    border: none;
  }
  .cmshtml .resp_tb table tr {
    border-bottom: solid thin #e6e6e6;
  }
  .cmshtml .resp_tb table a {
    padding-bottom: 0.1em;
    color: inherit;
    border-bottom: solid thin #FCA9A7;
    text-decoration: none;
  }
}

.cmshtml .rdplanetext.bd_tb figure.table table th, .cmshtml .rdplanetext.bd_tb figure.table table td, .cmshtml .rdplanetext2.bd_tb figure.table table th, .cmshtml .rdplanetext2.bd_tb figure.table table td {
  border-color: #A4A4A4;
  border-left: 1px solid #A4A4A4;
  border-right: 1px solid #A4A4A4;
}

@media screen and (max-width: 576px) {
  .cmshtml .rdflexarea.rev {
    flex-direction: column-reverse;
  }
}

.cmshtml dd.contact_item_input input[type="text"],
.cmshtml dd.contact_item_input input[type="tel"],
.cmshtml dd.contact_item_input input[type="email"],
.cmshtml dd.contact_item_input input[type="date"] {
  padding: 8px;
  height: auto;
  background-color: #F8F4EE;
  border: none;
  border-radius: 5px;
  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
  outline: none;
}

.cmshtml dd.contact_item_input input[type="text"]:focus,
.cmshtml dd.contact_item_input input[type="tel"]:focus,
.cmshtml dd.contact_item_input input[type="email"]:focus,
.cmshtml dd.contact_item_input input[type="date"]:focus {
  background-color: #F8F4EE;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  border: none;
}

.cmshtml dl.contact_item_table {
  border: 1px solid #ededed;
  /*contact-table-style*/
}

.cmshtml dl.contact_item_table input[type="file"]:focus,
.cmshtml dl.contact_item_table input[type="tel"]:focus,
.cmshtml dl.contact_item_table input[type="number"]:focus,
.cmshtml dl.contact_item_table textarea:focus,
.cmshtml dl.contact_item_table select:focus,
.cmshtml dl.contact_item_table input[type="text"][name="img_auth"]:focus {
  background-color: #F8F4EE;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  border: none;
}

.cmshtml dl.contact_item_table dt.contact_item_title {
  margin-bottom: 4px;
  font-weight: 700;
  padding: 10px 10px 10px !important;
  border-bottom: 1px solid #ededed;
}

.cmshtml dl.contact_item_table dt.contact_item_title:not(:first-child) {
  margin-top: 3px;
  margin-top: auto !important;
}

.cmshtml dd.contact_item_input,
.cmshtml .contact_item_inside_input,
.cmshtml .contact_item_file_box {
  border-bottom: 1px solid #ededed;
  padding: 10px 20px !important;
}

.cmshtml .contact_item_inside_input,
.cmshtml .contact_item_inside_title.contact_inp_title_address2 {
  border: none !important;
}

.cmshtml div.rdcontact_btn_area {
  margin-bottom: 30px;
}

.cmshtml div.rdcontact_btn_area .rdcontact_btn_submit {
  background: #FCA9A7;
  border-radius: 999px;
  border: none;
}

.cmshtml div.rdcontact_btn_area .rdcontact_btn_submit:hover,
.cmshtml div.rdcontact_btn_area .rdcontact_btn_submit .rdcontact_btn_area .rdcontact_btn_submit:focus {
  background: rgba(252, 169, 167, 0.8);
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
}

.cmshtml .contact_item_inside_table {
  display: flex;
  flex-wrap: wrap;
  align-items: normal;
}

.cmshtml .contact_item_inside_table dt:last-child, .cmshtml .contact_item_inside_table dd:last-child {
  border-bottom: none;
}

.cmshtml .contact_item_inside_title {
  border-bottom: 1px solid #ededed;
  padding: 10px 0px !important;
}

.cmshtml .btn_contacts_post_api {
  margin: 5px 10px;
}

.cmshtml .contact_header {
  margin-bottom: 10px;
}

.cmshtml .contact_footer {
  margin-top: 10px;
}

.cmshtml .blogcontents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 60px;
  /*blogframe側、記事ブロック：幅いっぱい縦並び*/
  /*date*/
}

.cmshtml .blogcontents .mainarea {
  width: calc(100% - 300px);
  margin-bottom: 60px;
}

.cmshtml .blogcontents .blogcommon {
  width: 270px;
  margin-bottom: 60px;
}

.cmshtml .blogcontents .rdListShort {
  display: block;
}

.cmshtml .blogcontents .rdListShort:first-child {
  border-top: 3px dotted #FADEE1;
}

.cmshtml .blogcontents .rdListShort .rdListItem {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  column-gap: 1.5rem;
  /*row-gap: 0.5rem;*/
  align-items: flex-start;
  padding: 10px;
  width: auto;
  margin: 0;
  border:none;
  box-shadow: none;
  border-bottom: 3px dotted #FADEE1;
}

  /*アイキャッチ画像のサムネ化*/
.cmshtml .blogcontents .rdListShort .rdListItem .rdListTitle, .cmshtml .blogcontents .rdListShort .rdListItem .rdListCategory, .cmshtml .blogcontents .rdListShort .rdListItem .rdListTag, .cmshtml .blogcontents .rdListShort .rdListItem .rdListExcerpt {
  grid-column: 2;
}

.cmshtml .blogcontents .rdListShort .rdListItem > .rdListImage {
  grid-column: 1;
  grid-row: 1 / span 3;
}

.cmshtml .blogcontents .rdListShort .rdListItem .rdListImageItem {
  /* 画像の縦横比いろいろでも、はみ出さずトリミング 
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;*/
}

  /*画像がないとき用（.noimage） JS連動左詰め*/
/*
.cmshtml .blogcontents .rdListShort .rdListItem.noimage {
  grid-template-columns: 1fr;
  padding-top: 20px;
}

.cmshtml .blogcontents .rdListShort .rdListItem.noimage .rdListTitle, .cmshtml .blogcontents .rdListShort .rdListItem.noimage .rdListMeta, .cmshtml .blogcontents .rdListShort .rdListItem.noimage .rdListExcerpt {
  grid-column: 1;
}

.cmshtml .blogcontents .rdListShort .rdListItem .rdListImageItemDummy {
  display: none;
}*/

.cmshtml .blogcontents .rdListShort .rdListItem .rdListTitle {
 
}

.cmshtml .blogcontents .rdListShort .rdListItem h3.rdarticleTitleText {
  border: none;
  position: relative;
  margin-bottom: 0;
    padding-bottom: 0;
}

.cmshtml .blogcontents .rdListShort .rdListItem h3.rdarticleTitleText ＆:before {
  display: inline-block;
  position: absolute;
  top: 0px;
  bottom: 0px;
  left: 0;
  width: 4px;
  height: 100%;
  background: linear-gradient(#FCA9A7, #FEA645);
}

.cmshtml .blogcontents .rdListShort .rdListItem h3.rdarticleTitleText a {
  text-decoration: none;
  display: block;
  padding-left: 26px;
}

.cmshtml .blogcontents .rdListShort .rdListItem h3.rdarticleTitleText a:after {
  position: absolute;
  left: 0;
  top: 0.45em;
  content: "";
  width: 20px;
  height: 20px;
  border-style: solid;
  border-width: 5px;
  border-color: #FCA9A7;
  border-radius: 50%;
  box-sizing: border-box;
}

.cmshtml .blogcontents .rdListShort .rdListItem .rdpublishDate {
  color: #FCA9A7;
  font-size: 11px;
  letter-spacing: 0;
}

.cmshtml .blogcontents .rdListShort .rdListItem div.rdListCategory {
  position: static;
  width: 100%;
  margin-bottom: 0;
  padding-right: 10px;
  padding-left: 10px;
}

.cmshtml .blogcontents .rdListShort .rdListItem div.rdListCategory a {
  text-decoration: none;
}

.cmshtml .blogcontents .rdListShort .rdListItem li.rdListCategoryItem {
  background-color: #FCA9A7;
  color: #FFF;
  border: none;
  padding: 2px 10px 0px;
  border-radius: 99px;
  font-size: 14px;
}

.cmshtml .blogcontents .rdListShort .rdListItem .ItemrdListTagListItem {
  border: 1px solid #FCA9A7;
  padding: 2px 10px 0;
  border-radius: 99px;
  background: none;
  color: #FCA9A7;
  font-size: 14px;
}

.cmshtml .blogcontents .rdListShort .rdListItem .ItemrdListTagListItem a {
  color: inherit;
  text-decoration: none;
}

.cmshtml .blogcontents .rdListShort .rdListItem .rdListExcerpt {
  
}
/*続きを読む*/
.cmshtml .blogcontents .rdListShort .rdListItem .rdListExcerpt .rdReadMore {
  color: #666;
}

.cmshtml .blogmain_main .blogcontents {
  margin-bottom: 60px;
  /*タイトル（リンク）*/
}

.cmshtml .blogmain_main .blogcontents .rdarticleTitle h3 {
  font-size: clamp(20px, 2.5vw, 24px);
  padding-bottom: 12px;
  padding-top: 18px;
  border-bottom: 2px solid #A4A4A4;
  position: relative;
  line-height: 1.5;
}

.cmshtml .blogmain_main .blogcontents .rdarticleTitle h3::before {
  position: absolute;
  content: "";
  left: 0;
  bottom: -2px;
  width: 60px;
  height: 2px;
  background: #FCA9A7;
  border-right: 2px solid #fff;
}

.cmshtml .blogmain_main .blogcontents .rdpublishDate {
  color: #FCA9A7;
  display: block;
}

@media screen and (max-width: 800px) {
  .cmshtml .blogcontents .mainarea, .cmshtml .blogcontents .blogcommon {
    width: 100%;
    margin-bottom: 30px;
  }
  .cmshtml .blogcontents .rdListShort .rdListItem {
    display: block;
  }
  .cmshtml .blogcontents .rdListShort .rdListItem .rdListImage {
    grid-row: auto;
    grid-column: 1;
    margin-bottom: 1rem;
    text-align: center;
  }
}

  /*ブログ共通部分カラー*/
  /*最新記事一覧*/
  /*月別アーカイブ*/
  /*ブログ内検索*/
  /*ブログカテゴリー*/
  /*ブログカレンダー*/
  /*タグリスト*/
  /*年アーカイブ*/

.cmshtml .blogcommon .rdblartlist .rdnewArticle {
  border: none;
}

.cmshtml .blogcommon .rdMonthlyArchive .rdMonthlyArchive-item:before {
  border-color: #FCA9A7;
}

.cmshtml .blogcommon .rdBlogSearch .rdBlogSearch-btn {
  background-color: #FCA9A7;
}

.cmshtml .blogcommon .rdCategorylist .rdCategorylist-link:after {
  border-left-color: #FCA9A7;
}

.cmshtml .blogcommon .rdCategorylist .rdCategorylist-link:hover {
  background: #FCF2F4;
  color: #FCA9A7;
}

.cmshtml .blogcommon .rdCalendar .rdCalendarTable-link {
  background: #FCA9A7;
}

.cmshtml .blogcommon .rdCalendar .rdCalendarTable-link:hover {
  background: #FEA645;
}

.cmshtml .blogcommon .rdTaglist .rdTaglist-link {
  background: #FCF2F4;
}

.cmshtml .blogcommon .rdTaglist .rdTaglist-link:after {
  background: #FCF2F4;
}

.cmshtml .blogcommon .rdTaglist .rdTaglist-link:before {
  background: #FCF2F4;
}

.cmshtml .blogcommon .rdTaglist .rdTaglist-link:hover {
  background: #FCA9A7;
}

.cmshtml .blogcommon .rdTaglist .rdTaglist-link:hover:before {
  background: #FCA9A7;
}

.cmshtml .blogcommon .rdTaglist .rdTaglist-link:hover:after {
  background: #FCA9A7;
}

.cmshtml .blogcommon .rdYearlyArchive-item .rdYearlyArchive-link {
  background: #FEA645;
  color: #fff;
  text-decoration: none;
  transition: all 0.5s ease 0s;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
}

.cmshtml .blogcommon .rdYearlyArchive-item .rdYearlyArchive-link:hover {
  background: #FCA9A7;
}

.cmshtml .blogcontents .rdpagination .rdpagenationLinkActive,
.cmshtml .blogcontents .rdpagination .rdpagenationLink:hover {
  background: #FCA9A7;
}
#editView.showhideElement .cmshtml #l-header .h_nav__list {
  justify-content: space-between;
  padding-right: 0; }
#editView.showhideElement .cmshtml #l-header .h_nav__list > div {
flex-grow: 1; }
        
#editView .cmshtml #l-header [data-blocks="サブナビ"] {
  position: absolute;
  right: 0;
  top: -54px;
  width: 100%;
  min-height: 54px;
}

#editView .cmshtml #l-header .h_nav__item.h_subnav {
  top: 0;
}

#editView .cmshtml [data-aos=fade-up], #editView .cmshtml [data-aos=flip-left], #editView .cmshtml [data-aos=zoom-in-up] {
  transform: none;
  opacity: 1;
}

#editView .cmshtml .fade, #editView .cmshtml [data-aos^=fade] {
  opacity: 1;
}

#editView .cmshtml .forfixed {
  margin-top: 0;
}

#editView .cmshtml #h-logo {
  position: relative;
  top: 0px;
}

#editView .cmshtml .drawer-nav {
  overflow: visible;
}

#editView .cmshtml .h_nav {
  padding-top: 23px;
  height: auto;
  margin-top: -100px
}

#editView .cmshtml .top-slide {
  max-height: 600px;
  overflow: auto;
}
#editView .cmshtml #slide-wrap {
height: auto;
}

#editView .cmshtml .top-slide .swiper-wrapper {
  padding-top: 23px;
  flex-wrap: wrap;
}

#editView .cmshtml .conceptstyle.rev {
  flex-direction: row-reverse;
}

#editView .cmshtml .conceptstyle .flex_row_inner {
  max-width: 100%;
  width: 100%;
}

#editView .cmshtml .top_news__wrap {
  max-height: none;
  overflow: visible;
  width: 100%;
  padding-top: 23px;
}

#editView .cmshtml .top_contents .contents_list .contents_li .title2 {
  position: relative;
}

#editView .cmshtml .conceptstyle .flex_txt {
  padding: 2vw;
}

#editView .cmshtml .swiper-wrapper {
  flex-wrap: wrap;
}

#editView .cmshtml #section_pageHeader {
  padding-top: 23px;
}

#editView .cmshtml #section_pageHeader .headimg {
  position: relative;
}

#editView .cmshtml #section_pageHeader .headimg img {
  width: 100%;
  position: relative;
  background: none;
  z-index: 0;
  max-height: 400px;
}

#editView .cmshtml #section_pageHeader .head_inner {
  padding: 0;
}

#editView .cmshtml #section_pageHeader #title-wrap {
  width: 100%;
  position: relative;
  background: none;
}

#editView .cmshtml .title-navi {
  margin: 0 5%;
}

#editView .cmshtml .title-navi:empty {
  display: block !important;
}

#editView .cmshtml .toggle-box > div:nth-child(2n), #editView .cmshtml .faq > div:nth-child(2n) {
  display: block;
}

#editView .cmshtml .dl_list_text {
  justify-content: space-between;
}

#editView .cmshtml .day_list .text_area:last-child::after {
  content: none;
}

#editView .cmshtml .faq > div:nth-child(2n-1)::after {
  border-radius: 0%;
  right: auto;
  transition: none;
}

#editView .cmshtml .hidden {
  overflow: visible;
}

#editView .cmshtml .swingbox, #editView .cmshtml .flipbox, #editView .cmshtml .fadebox, #editView .cmshtml .fadeinbox, #editView .cmshtml .bouncedownbox, #editView .cmshtml .bouncebox {
  opacity: 1;
}

#editView .cmshtml .top_news__dd,
#editView .cmshtml .top_news__dt,
#editView .cmshtml .flex_left,
#editView .cmshtml .flex_right,
#editView .cmshtml .edit_inner {
  width: 100% !important;
  max-width: 100% !important;
}

#editView .cmshtml {
  overflow-y: auto;
  overflow-x: hidden;
}

#editView .cmshtml .top_news__wrap {
  padding-top: 23px;
}

#editView .cmshtml .active {
  min-width: 78px;
}

#editView .cmshtml .active edit {
  min-height: 44px;
}

#editView .cmshtml edit p {
  min-width: 3em;
}

#editView .cmshtml .rdareaItem edit {
  min-width: 3.6em;
}

#editView .cmshtml .bg_wrap,
#editView .cmshtml .color_bg::before,
#editView .cmshtml .fullsize img,
#editView .cmshtml .wide_wrap {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}
#editView .cmshtml [data-blocks$="(固定)"]{
pointer-events: none;
}





#editView .cmshtml [data-blocks="お知らせエリア"]{
width: 75%;
}

#editView .cmshtml .top_about .about_figure > div:nth-child(1) {
position: absolute;
top: -30px;
left: calc( 50% - 750px);
}

#editView .cmshtml .top_about .about_figure > div:nth-child(2) {
position: absolute;
top: -30px;
  right: calc( 50% - 750px);
}

#editView .cmshtml .top_about [data-blocks="タイトルエリア"]{
margin-top: 100px;
}

#editView .cmshtml .top_rec [data-blocks="テキストエリア"]{
width: 600px;
    max-width: 100%;
}
#editView .cmshtml .swiper-wrapper {
  height: auto;
}