@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Roboto:300,400,700");
@import url("https://fonts.googleapis.com/css2?family=BIZ+UDPGothic:wght@400;700&display=swap");
html, body {
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "BIZ UDPGothic", "游ゴシック体", YuGothic, "Yu Gothic Medium", sans-serif;
}

.wrapper90 {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}

.table_vertibal_box {
  margin-top: 30px;
  margin-bottom: 40px;
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.table_vertibal_box th:first-child{
  border-radius: 6px 0 0 0;
}

.table_vertibal_box th:last-child{
  border-radius: 0 6px 0 0;
  border-left: 0.6px solid #ffffff;
}

.table_vertibal_box th:first-child {
  width: 10%;
}

.table_vertibal_box th{
  text-align: center;
  color:white;
  background: linear-gradient(#86ace2,#0065f4);
  border-left: 0.3px solid #ffffff;
  width: 30%;
  padding: 10px 5px;
}

.table_vertibal_box td:first-child {
  width: 10%;
  text-align: center;
}

.table_vertibal_box td{
  border-left: 1px solid #c3c3c3;
  border-bottom: 1px solid #c3c3c3;
  border-top:none;
  box-shadow: 0px -3px 8px 1px #eee inset;
  width: 30%;
  padding: 12px 0;
}

.table_vertibal_box td:last-child{
  border-right: 1px solid #c3c3c3;
}

.table_vertibal_box tr:last-child td:first-child {
  border-radius: 0 0 0 5px;
}

.table_vertibal_box tr:last-child td:last-child {
  border-radius: 0 0 5px 0;
}

.mb-4rem {
	margin-bottom: 4rem;
}

.wrapper60 {
  width: 60%;
  margin-left: auto;
  margin-right: auto;
}
			  
@media (max-width: 840px){
	.wrapper60 {
		width: 85%;
    }
}

/* hosyou.htmlのtableのcss ここから */
.table_next-to_box {
  margin-top: 30px;
  margin-bottom: 40px;
  max-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.table_next-to_box tr:first-of-type th:first-of-type {
  border-radius: 6px 0 0 0;
}

.table_next-to_box tr:last-of-type th:last-of-type {
  border-radius: 0 0 0 6px;
}

.table_next-to_box th{
  text-align: center;
  color:white;
  background: linear-gradient(#86ace2,#0065f4);
  border-left: 0.3px solid #ffffff;
  width: 10%;
  padding: 10px 5px;
}

.table_next-to_box td{
  text-align: center;
  border-left: 1px solid #c3c3c3;
  border-bottom: 1px solid #c3c3c3;
  border-top:none;
  box-shadow: 0px -3px 8px 1px #eee inset;
  width: 20%;
  padding: 12px 0;
}

.table_next-to_box td:last-child{
  border-right: 1px solid #c3c3c3;
}

.table_next-to_box tr:first-of-type td:first-of-type {
  border-radius: 0 5px 0 0;
  border-top: 1px solid #c3c3c3;
}

.table_next-to_box tr:last-of-type td:last-of-type {
  border-radius: 0 0 5px 0;
}
/* hosyou.htmlのtableのcss ここまで */
				  
ul.cp_list {
	padding: 0.5em;
	list-style-type: none;
	margin-bottom: 1.5rem;
}
ul.cp_list li {
	position:relative;
	padding: 0em 0.3em 0.3em 1.3em;
	margin: 0 auto;
}
ul.cp_list li::before {
	position: absolute;
	content: '';
	display: block;
	top: 0.5em;
	left: 0;
	width: 6px;
	height: 6px;
	border-right: 3px solid #4D83C4;
	border-bottom: 3px solid #4D83C4;
	transform: rotate(-45deg);
}
				  
.m-tb {
  margin: 1.5rem 0;
}
				  
.left-bd {
  padding: 0.5rem 1rem;
  border-left: 4px solid #4D83C4;
}

@media screen and (max-width: 980px) {
  .table_vertibal_box .thead {
    display: none;
  }
	
  .table_vertibal_box tr {
    width: 100%;
  }
	
  .table_vertibal_box td {
    display: flex;
    flex-direction: row;
    width: 100%;
  }
	
  .table_vertibal_box td:first-child {
	display: flex;
	justify-content: center;
    background: linear-gradient(#86ace2,#0065f4);
    color: #fff;
    font-weight: bold;
    text-align: center;
	width: 100%;
  }
	
  .table_vertibal_box td:first-child::before {
	display: none;
  }
	
  .table_vertibal_box td:before {
    content: attr(data-label);
    float: left;
    font-weight: bold;
	margin-left: 30px;
    margin-right: 10%;
    width: 15%;
  }
	
  .table_vertibal_box td {
    border-right: 1px solid #c3c3c3;
  }
	
  .table_vertibal_box tr:nth-of-type(2) td:first-child {
    border-radius: 5px 5px 0 0;
}
	
  .table_vertibal_box tr:nth-of-type(4) td:first-child {
    border-radius: 0;
}
	
  .table_vertibal_box tr:nth-of-type(4) td:last-child {
    border-radius: 0 0 5px 5px;
}
}
	
@media screen and (max-width: 660px) {
  .table_vertibal_box td {
    display: flex;
    flex-direction: column;
  }
			
  .table_vertibal_box td:before {
    width: auto;
  }
	
  ul.cp_list {
    padding: 0.5rem 1.5rem 0.5rem 1.5rem;
    width: auto;
    margin: 0 auto;
  }
}
				  
.label {
	display: inline-block;
	line-height: 80px;
}

@media (max-width: 990px) {
    .label {
        line-height: 60px;
	}
}

.bl-r {
	padding-right: 15px;
}

.br-l {
	border-left: 0.1em solid rgba(0, 0, 0, 0.1);
	padding-left: 15px;
}

.font-weight-md-bold {
    font-weight: bold;
}

.fl-sa {
	display: flex;
	justify-content: space-around;
}

@media (max-width: 840px) {
    .fl-sa {
        display: block;
		text-align: center;
    }
}

.bg-colored-01 {
  background-color: #4472c4 !important;
}

.bg-colored-02 {
  background-color: #43afc0 !important;
}

.bg-colored-03 {
  background-color: #43bb8d !important;
}

.bg-colored-04 {
  background-color: #45b451 !important;
}

.bg-colored-05 {
  background-color: #70ad47 !important;
}

.color-okushin {
  color: #1D665D;
}

.font-futura {
  font-family: futura-pt-bold, sans-serif;
  font-weight: 700;
  font-style: normal;
}

.text-black {
  color: #000 !important;
}

label > label {
  margin-bottom: 0;
}

form > .card-header-space {
  margin-top: 0;
}

.alert-space:empty {
  display: none;
}

@media print {
  .sticky-top {
    position: relative;
  }
  .no-print {
    display: none;
  }
}
@media print {
  .card-anken-detail .scroll-table {
    overflow: inherit;
    width: 100%;
  }
  .card-anken-detail .scroll-table.scroll-lg > table {
    min-width: 0;
  }
}

.bootstrap-select > .form-error + .dropdown-toggle {
  background: #f6cdd1 !important;
}

.table-calc > tbody > tr.bg-normal > td {
  background-color: #fff;
}
.table-calc > tbody > tr.bg-saturday > td:first-child, .table-calc > tbody > tr.bg-saturday > td:last-child {
  background-color: #c0e7ef;
}
.table-calc > tbody > tr.bg-saturday > td.active {
  background-color: #fff;
}
.table-calc > tbody > tr.bg-saturday:hover > td {
  background-color: rgb(251, 255, 191);
}
.table-calc > tbody > tr.bg-saturday:hover:nth-of-type(odd) > td {
  background-color: rgb(251, 255, 191);
}
.table-calc > tbody > tr.bg-sunday > td:first-child, .table-calc > tbody > tr.bg-sunday > td:last-child {
  background-color: #efc2c2;
}
.table-calc > tbody > tr.bg-sunday > td.active {
  background-color: #fff;
}
.table-calc > tbody > tr.bg-sunday:hover > td {
  background-color: rgb(251, 255, 191);
}
.table-calc > tbody > tr.bg-sunday:hover:nth-of-type(odd) > td {
  background-color: rgb(251, 255, 191);
}
.table-calc > tbody > tr.bg-holiday > td:first-child, .table-calc > tbody > tr.bg-holiday > td:last-child {
  background-color: #efc2c2;
}
.table-calc > tbody > tr.bg-holiday > td.active {
  background-color: #fff;
}
.table-calc > tbody > tr.bg-holiday:hover > td {
  background-color: rgb(251, 255, 191);
}
.table-calc > tbody > tr.bg-holiday:hover:nth-of-type(odd) > td {
  background-color: rgb(251, 255, 191);
}
.table-calc > tbody > tr.no-color-on-hover:hover > td {
  background-color: inherit;
}
.table-calc > tbody > tr.no-color-on-hover:hover:nth-of-type(odd) > td {
  background-color: inherit;
}
.headline-section {
  text-align: center;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: inherit;
  overflow-x: hidden;
}
@media (min-width: 768px) {
  .headline-section {
    overflow-x: inherit;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.headline-section .headline-text-space {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
@media (min-width: 768px) {
  .headline-section .headline-text-space {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
  }
}
.headline-section .headline-text-space > div {
  position: relative;
  z-index: 1;
  text-align: left;
  max-width: 100%;
}
.headline-section .headline-text-space > div h1 {
  display: inline-block;
  font-weight: bold;
  font-size: 2rem;
}
@media (min-width: 768px) {
  .headline-section .headline-text-space > div h1 {
    font-size: 3rem;
  }
}
.headline-section .headline-text-space > div .headline-body {
  max-width: 100%;
  font-size: 1.25rem;
}
@media (min-width: 768px) {
  .headline-section .headline-text-space > div .headline-body {
    font-size: 1.5rem;
  }
}
@media (min-width: 992px) {
  .headline-section .headline-text-space > div .headline-body {
    max-width: inherit;
  }
}
.headline-section .headline-image-space {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
.headline-section .headline-image-space > div {
  position: relative;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .headline-section .headline-image-space > div {
    padding: 0;
  }
}
.headline-section .headline-image-space > div .headline-image {
  max-width: 100%;
}
@media (min-width: 992px) {
  .headline-section .headline-image-space > div .headline-image {
    max-width: 30rem;
    position: absolute;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
  }
}
.headline-section.head-01 {
  margin: 2em;
}
@media (min-width: 768px) {
  .headline-section.head-01 {
    margin: 0 auto;
    max-width: 68rem;
  }
}
@media (min-width: 768px) {
  .headline-section.head-01 .headline-text-space > div {
    padding: 8rem 0;
    max-width: 42rem;
    margin-left: 2rem;
  }
}
@media (min-width: 768px) {
  .headline-section.head-01 .headline-text-space > div .headline-body {
    max-width: 42rem;
  }
}
.headline-section.head-01 .headline-image-space {
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
@media (min-width: 768px) {
  .headline-section.head-01 .headline-image-space {
    -ms-flex-preferred-size: 30rem;
        flex-basis: 30rem;
  }
}
.headline-section.head-01 .headline-image-space > div {
  position: relative;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .headline-section.head-01 .headline-image-space > div {
    padding: 0;
  }
}
.headline-section.head-01 .headline-image-space > div .headline-image {
  max-width: 100%;
}
@media (min-width: 992px) {
  .headline-section.head-01 .headline-image-space > div .headline-image {
    position: absolute;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
  }
}
.headline-section.head-01 .headline {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
}
@media (min-width: 992px) {
  .headline-section.head-01 .headline {
    margin: 0.25rem 0;
    display: inline-block;
  }
}
.headline-section.head-02 {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  padding: 4rem 0;
}
@media (min-width: 768px) {
  .headline-section.head-02 {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    max-width: 72rem;
  }
}
.headline-section.head-02 .headline-text-space {
  padding: 0 2rem 0;
}
@media (min-width: 576px) {
  .headline-section.head-02 .headline-text-space {
    padding: 2rem;
  }
}
.headline-section.head-02 .headline-text-space > div {
  padding: 0;
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-text-space > div {
    padding: 2rem 0;
  }
}
.headline-section.head-02 .headline-text-space > div .headline-body {
  z-index: 10;
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-text-space > div .headline-body {
    max-width: 28rem;
  }
}
.headline-section.head-02 .headline-text-space > div p {
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-text-space > div p {
    margin-bottom: 1rem;
  }
}
.headline-section.head-02 .headline-text-space .headline {
  margin: 0;
}
@media (min-width: 992px) {
  .headline-section.head-02 .headline-text-space .headline {
    margin: 0.25rem 0;
  }
}
.headline-section.head-02 .headline-image-space {
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  width: 100%;
}

.headline-section.head-02 .headline-image-space > div {
  position: relative;
  padding: 0 2rem;
  min-height: 28rem;
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-image-space > div {
    height: auto;
    padding: 0;
  }
}
.headline-section.head-02 .headline-image-space > div .headline-image {
  max-width: 100%;
  position: absolute;
  margin: auto;
}
.headline-section.head-02 .headline-image-space > div .headline-image.image-low {
  z-index: 0;
  bottom: 0;
  top: 0;
  max-width: 80vw;
  right: auto;
  left: -5rem;
}
@media (min-width: 576px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-low {
    max-width: 30rem;
    right: auto;
    left: -3rem;
  }
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-low {
    max-width: 22rem;
    right: auto;
    left: -5rem;
  }
}
@media (min-width: 992px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-low {
    max-width: 28rem;
    right: auto;
    left: -5rem;
  }
}
@media (min-width: 1200px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-low {
    max-width: 38rem;
    right: auto;
    left: -6rem;
  }
}
.headline-section.head-02 .headline-image-space > div .headline-image.image-mid {
  z-index: 0;
  max-width: 16rem;
  right: 0;
  left: auto;
  top: 2rem;
  bottom: auto;
}
@media (min-width: 576px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-mid {
    max-width: 22rem;
    left: auto;
    right: 0;
    top: -3rem;
    bottom: auto;
  }
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-mid {
    max-width: 17rem;
    left: auto;
    right: 0;
    top: 0;
    bottom: auto;
  }
}
@media (min-width: 992px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-mid {
    max-width: 20rem;
    left: auto;
    right: 2rem;
    top: 0;
    bottom: auto;
  }
}
@media (min-width: 1200px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-mid {
    max-width: 24rem;
    left: auto;
    right: -2rem;
    top: -4rem;
    bottom: auto;
  }
}
.headline-section.head-02 .headline-image-space > div .headline-image.image-top {
  z-index: 0;
  max-width: 45vw;
  bottom: -7rem;
  left: auto;
  right: 2rem;
  top: 0;
}
@media (min-width: 576px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-top {
    max-width: 16rem;
    left: auto;
    right: 2rem;
    top: auto;
    bottom: -2rem;
  }
}
@media (min-width: 768px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-top {
    max-width: 12rem;
    left: auto;
    right: 1rem;
    top: auto;
    bottom: 2rem;
  }
}
@media (min-width: 992px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-top {
    max-width: 14rem;
    left: auto;
    right: 3rem;
    top: auto;
    bottom: -3rem;
  }
}
@media (min-width: 1200px) {
  .headline-section.head-02 .headline-image-space > div .headline-image.image-top {
    max-width: 14rem;
    left: 0;
    right: -25rem;
    top: auto;
    bottom: 0;
  }
}
.headline-section.head-03 {
  padding: 2rem;
}
@media (min-width: 768px) {
  .headline-section.head-03 {
    padding: 8rem 2rem;
    max-width: 68rem;
  }
}
@media (min-width: 768px) {
  .headline-section.head-03 .headline-text-space > div {
    padding: 8em 0;
    max-width: 44em;
  }
}
@media (min-width: 768px) {
  .headline-section.head-03 .headline-text-space > div .headline-body {
    max-width: 28em;
  }
}
@media (min-width: 768px) {
  .headline-section.head-03 .headline-image-space {
    -ms-flex-preferred-size: 30rem;
        flex-basis: 30rem;
  }
}
.headline-section.head-03 .headline-image-space > div {
  position: relative;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .headline-section.head-03 .headline-image-space > div {
    padding: 0;
  }
}
.headline-section.head-03 .headline-image-space > div .headline-image {
  max-width: 100%;
}
@media (min-width: 992px) {
  .headline-section.head-03 .headline-image-space > div .headline-image {
    position: absolute;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
  }
}
.headline-section.head-03 .headline {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0.25rem 0;
}
@media (min-width: 992px) {
  .headline-section.head-03 .headline {
    display: inline-block;
  }
}
.headline-section .headline {
  position: relative;
  overflow: hidden;
  display: inline-block;
  margin: 0.25rem 0;
}
@media (min-width: 768px) {
  .headline-section .headline {
    display: block;
  }
}

.headline .rect {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  background: #334252;
  width: 100%;
  height: 100%;
  -webkit-transform: translateX(-101%);
          transform: translateX(-101%);
}

.name-scroll-space {
  width: 100%;
  overflow-x: hidden;
  background-color: #F6F6F6;
}

.name-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  position: relative;
}

.name-wrap {
  white-space: nowrap;
  width: 100%;
  position: relative;
}

.name-wrap-right {
  position: absolute;
  left: 100vw;
}

.name-text {
  margin: 0;
  padding: 0;
  position: relative;
  font-size: 10vw;
  color: #D0D0D0;
}

.menu-trigger,
.menu-trigger span {
  display: inline-block;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.menu-trigger {
  position: relative;
  width: 1.5rem;
  height: 1.5rem;
  background: none;
  border: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
}
.menu-trigger:focus {
  outline: none;
}

.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 4px;
  background-color: #000;
  border-radius: 4px;
  -webkit-transform-origin: center center;
          transform-origin: center center;
}

.menu-trigger span:nth-of-type(1) {
  top: 0;
}

.menu-trigger span:nth-of-type(2) {
  top: 0.5rem;
}

.menu-trigger span:nth-of-type(3) {
  bottom: 0.25rem;
}

#btn-hum-menu.active span:nth-of-type(1) {
  -webkit-transform: translateY(0.5rem) rotate(-45deg);
          transform: translateY(0.5rem) rotate(-45deg);
}

#btn-hum-menu.active span:nth-of-type(2) {
  opacity: 0;
}

#btn-hum-menu.active span:nth-of-type(3) {
  -webkit-transform: translateY(-0.5rem) rotate(45deg);
          transform: translateY(-0.5rem) rotate(45deg);
}

header.header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 3rem;
  z-index: 1000;
}
@media (min-width: 1150px) {
  header.header {
    height: 5.5rem;
  }
}
header.header .header-top {
  background-color: #1D665D;
  height: 0.25rem;
}
@media (min-width: 1150px) {
  header.header .header-top {
    height: 2.25em;
  }
}
header.header .header-top .header-top-inner {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  display: none;
  height: 100%;
}
@media (min-width: 1150px) {
  header.header .header-top .header-top-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
header.header .header-top .header-top-inner .header-top-left {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
header.header .header-top .header-top-inner .header-top-left > span {
  display: inline-block;
  margin-left: 1rem;
  color: #fff;
  font-size: 0.875rem;
}
@media (min-width: 1200px) {
  header.header .header-top .header-top-inner .header-top-left > span {
    font-size: 1rem;
  }
}
header.header .header-top .header-top-inner .header-top-right {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner > li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
  margin-left: 0.2rem;
  margin-right: 0.2rem;
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner > li > .header-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  -webkit-transition: -webkit-transform 0.2s ease 0s;
  transition: -webkit-transform 0.2s ease 0s;
  transition: transform 0.2s ease 0s;
  transition: transform 0.2s ease 0s, -webkit-transform 0.2s ease 0s;
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner > li > .header-links:hover {
  text-decoration: none;
  color: #ffffb4;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner > li > .header-links > i {
  margin: 0.25rem;
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner > li > .header-links .header-icon-tel-number {
  font-size: 1.5rem;
}
header.header .header-top .header-top-inner .header-top-right .header-top-right-inner > li:last-child {
  margin-right: 1rem;
}
header.header .header-bottom-nav {
  background-color: #fff;
  -webkit-box-shadow: 1px 1px 14px -4px rgba(0, 0, 0, 0.4);
          box-shadow: 1px 1px 14px -4px rgba(0, 0, 0, 0.4);
  height: 3rem;
}
header.header .header-bottom-nav .header-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  height: 100%;
}
header.header .header-bottom-nav .header-logo .header-nav-logo {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
header.header .header-bottom-nav .header-logo .header-nav-logo .header-logo-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
header.header .header-bottom-nav .header-logo .header-nav-logo .header-logo-link .header-nav-logo-inner {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
header.header .header-bottom-nav .header-logo .header-nav-logo .header-logo-link .header-nav-logo-inner.logo-mark-image {
  width: 2.1rem;
  height: 2rem;
  margin: 0.25rem 0 0.25rem 1rem;
}
header.header .header-bottom-nav .header-logo .header-nav-logo .header-logo-link .header-nav-logo-inner.logo-mark-image > img {
  width: 2.1rem;
  height: 2rem;
}
header.header .header-bottom-nav .header-logo .header-nav-logo .header-logo-link .header-nav-logo-type {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
header.header .header-bottom-nav .header-logo .header-nav-logo .header-logo-link .header-nav-logo-type span {
  display: inline-block;
  color: #000;
  margin: 0 0.2em;
  font-size: 1.5rem;
}
header.header .header-bottom-nav .header-logo .header-nav-links {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
  height: 100%;
}
header.header .header-bottom-nav .header-logo .header-nav-links .header-nav {
  text-align: right;
  margin-right: 1rem;
  height: 100%;
}
header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  height: 100%;
}
header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul li {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
  height: 100%;
  position: relative;
}
header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul li .header-nav-link-item {
  display: none;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #000;
  height: 100%;
}
header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul li .header-nav-link-item:hover {
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(85%, transparent), color-stop(0%, #63d3c5));
  background-image: linear-gradient(transparent 85%, #63d3c5 0%);
  text-decoration: none;
}
@media (min-width: 768px) {
  header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul li .header-nav-link-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0.25rem;
    font-size: 0.85em;
  }
}
@media (min-width: 1150px) {
  header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul li .header-nav-link-item {
    padding: 0 1rem;
    font-size: 1em;
  }
}
header.header .header-bottom-nav .header-logo .header-nav-links .header-nav ul li.inc-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: 0.25rem;
}
header.header .header-bottom-nav .header-logo .header-hum {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (min-width: 768px) {
  header.header .header-bottom-nav .header-logo .header-hum {
    display: none;
  }
}
header.header .header-bottom-nav .header-logo .header-hum .header-hum-inner {
  margin: 0 1rem 0 0;
}

#contents {
  margin-top: 5.25rem;
}

.btn-inner-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.btn-inner-center > span, .btn-inner-center > img {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
  margin: 0 0.1rem;
}
.btn-inner-center > span {
  display: none;
}
@media (min-width: 768px) {
  .btn-inner-center > span {
    display: inherit;
  }
}

.sp-list-wrapper {
  position: relative;
  width: 100%;
  background-color: #334252;
  padding: 10rem 0;
  margin: 0 auto;
}

.sp-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.sp-item {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 22rem;
      flex-basis: 22rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 1rem;
}

.spl-link {
  position: relative;
  display: block;
  height: 100%;
  color: #000;
  text-decoration: none;
  -webkit-transition: background-color 0.2s ease 0s, -webkit-transform 0.2s ease 0s;
  transition: background-color 0.2s ease 0s, -webkit-transform 0.2s ease 0s;
  transition: transform 0.2s ease 0s, background-color 0.2s ease 0s;
  transition: transform 0.2s ease 0s, background-color 0.2s ease 0s, -webkit-transform 0.2s ease 0s;
}
.spl-link:hover, .spl-link:focus {
  color: #000;
  text-decoration: none;
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
}
.spl-link:hover:before, .spl-link:focus:before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 0, 0.1);
  pointer-events: none;
  z-index: 1;
}

.spl-card {
  position: relative;
  background-color: #fff;
  border-radius: 0.5rem;
  height: 100%;
}
.spl-card:before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0px 0px 18px -6px inset rgba(0, 0, 0, 0.8);
          box-shadow: 0px 0px 18px -6px inset rgba(0, 0, 0, 0.8);
}
.spl-card .spl-image img {
  max-width: 100%;
  height: auto;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}
.spl-card .spl-title {
  font-size: 1.5rem;
  margin: 1rem;
}
.spl-card .spl-body {
  margin: 1rem;
}

.whats-new-section {
  padding: 2rem;
  text-align: center;
  background-color: #F6F6F6;
}
.whats-new-section h2 {
  font-size: 1.875rem;
  margin: 1rem 0;
}

.datelist li .time {
  position: relative;
}
.datelist li .time:before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  margin: auto;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  background-color: #adb5bd;
}
.datelist li .time time {
  position: relative;
  z-index: 1;
  background-color: #F6F6F6;
}

.section-w-limit .section-inner {
  max-width: 68rem;
  margin: 0 auto;
  padding: 2rem;
}

.certificate-section {
  padding: 2rem;
}

.inquiry-section {
  padding: 4rem 0;
  background-color: #F6F6F6;
}
.inquiry-section .section-inner {
  padding: 0 1rem;
}
@media (min-width: 768px) {
  .inquiry-section .section-inner {
    padding: 0 2rem;
  }
}
.inquiry-section .section-inner .inquiry-button-space {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.inquiry-section .section-inner .inquiry-button-space .inquiry-button-wrapper {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
@media (min-width: 768px) {
  .inquiry-section .section-inner .inquiry-button-space .inquiry-button-wrapper {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
  }
}
.inquiry-section .section-inner .inquiry-button-space .inquiry-button-wrapper a {
  display: inline-block;
  background-color: #fff;
  border-radius: 1.5rem;
  width: 100%;
  margin: 0.5rem 0;
  padding: 0.75rem 0.5rem;
  color: #F75940;
  -webkit-box-shadow: 0 0.25rem 1rem -0.5rem #6c757d;
          box-shadow: 0 0.25rem 1rem -0.5rem #6c757d;
  -webkit-transition: background-color 0.2s ease 0s;
  transition: background-color 0.2s ease 0s;
  line-height: 1.4;
}
@media (min-width: 768px) {
  .inquiry-section .section-inner .inquiry-button-space .inquiry-button-wrapper a {
    width: 30rem;
    padding: 0.75rem 1rem;
  }
}
.inquiry-section .section-inner .inquiry-button-space .inquiry-button-wrapper a:hover {
  text-decoration: none;
  background-color: #F75940;
  color: #fff;
}

.inquiry-button-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
.inquiry-button-flex .inquiry-button-item-left .inquiry-button-icon i {
  font-size: 1.875rem;
}
.inquiry-button-flex .inquiry-button-item-left .inquiry-button-icon-caption {
  font-size: 0.75rem;
}
.inquiry-button-flex .inquiry-button-item-right {
  margin-left: 0.5rem;
}
.inquiry-button-flex .inquiry-button-item-right span {
  font-size: 1.25rem;
  font-weight: bold;
}
@media (min-width: 320px) {
  .inquiry-button-flex .inquiry-button-item-right span {
    font-size: 1.5rem;
  }
}
@media (min-width: 576px) {
  .inquiry-button-flex .inquiry-button-item-right span {
    font-size: 2.25rem;
  }
}
.inquiry-button-flex .inquiry-button-item-right span.inquiry-type-form {
  font-size: 1.25rem;
  font-weight: bold;
}
@media (min-width: 320px) {
  .inquiry-button-flex .inquiry-button-item-right span.inquiry-type-form {
    font-size: 1.25rem;
  }
}
@media (min-width: 576px) {
  .inquiry-button-flex .inquiry-button-item-right span.inquiry-type-form {
    font-size: 2.25rem;
  }
}

.packages-section {
  background-color: #F6F6F6;
  padding: 0 0 2rem;
}

footer {
  background-color: #1D665D;
}
footer .footer-inner {
  max-width: 68rem;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
footer .footer-inner .footer-left {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
@media (min-width: 768px) {
  footer .footer-inner .footer-left {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
  }
}
footer .footer-inner .footer-right {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
footer .copyright {
  font-size: 1.125rem;
  color: #fff;
  background-color: #334252;
  padding: 0.5rem 0;
  text-align: center;
}

.company-info {
  color: #fff;
  padding: 2rem 2rem 0;
}
.company-info a {
  color: #fff;
}
.company-info ahover {
  color: #fff;
  text-decoration: none;
}
@media (min-width: 768px) {
  .company-info {
    padding: 4rem 2rem;
  }
}
.company-info .company-name {
  font-size: 1.5rem;
  margin-bottom: 2rem;
}
.company-info .company-details {
  font-size: 1.125rem;
}
.company-info .company-details .company-phone-numbers {
  margin-top: 2rem;
}

.sitemap {
  color: #fff;
  padding: 2rem;
}
.sitemap a {
  color: #fff;
}
.sitemap ahover {
  color: #fff;
  text-decoration: none;
}
@media (min-width: 768px) {
  .sitemap {
    padding: 4rem 0;
  }
}
.sitemap .sitemap-header {
  font-size: 1.5rem;
  font-weight: bold;
}
.sitemap .sitemap-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.sitemap .sitemap-flex .sitemap-wrapper {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
@media (min-width: 768px) {
  .sitemap .sitemap-flex .sitemap-wrapper {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
  }
}

.sitemap-wrapper-item {
  border-bottom: thin solid #fff;
  margin: 0.25rem 1rem 0.25rem 0;
}
.sitemap-wrapper-item .sitemap-title {
  font-size: 1.125rem;
  padding: 0.25rem 0;
}
.sitemap-wrapper-item .sitemap-title .sitemap-collapse {
  display: block;
  position: relative;
}
.sitemap-wrapper-item .sitemap-title .sitemap-collapse:hover {
  color: #fff;
}
.sitemap-wrapper-item .sitemap-title .sitemap-collapse:before {
  position: absolute;
  right: 0.25rem;
  content: "\f055";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  top: 0;
  bottom: 0;
  margin: auto;
}
.sitemap-wrapper-item .sitemap-title .sitemap-collapse[aria-expanded=true]:before {
  content: "\f056";
}

.sitemap-list {
  margin-bottom: 0.5rem;
}
.sitemap-list .sitemap-list-item {
  border-bottom: thin solid #fff;
}
.sitemap-list .sitemap-list-item a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.125rem;
  padding: 0.25rem 1.5rem 0.25rem 0;
}
.sitemap-list .sitemap-list-item a:hover {
  color: #fff;
}
.sitemap-list .sitemap-list-item a:before {
  position: absolute;
  display: inline-block;
  right: 0.66rem;
  content: "\f0da";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  top: 0;
  bottom: 0;
  margin: auto;
  height: 1.5rem;
}
.sitemap-list.sitemap-list-inner {
  font-size: 1rem;
}

.collapse-item .sitemap-list .sitemap-list-item {
  border-bottom: none;
}

.sitemap-space .sitemap-wrapper-item {
  margin-bottom: 2em;
}
.sitemap-space .sitemap-wrapper-item .sitemap-list .sitemap-list-item {
  margin: 0.25em 0;
}
.sitemap-space .sitemap-wrapper-item .sitemap-list .sitemap-list-item a {
  position: relative;
  display: inline-block;
  font-size: 1.125rem;
  padding: 0 0 0 1em;
  -webkit-box-pack: unset;
      -ms-flex-pack: unset;
          justify-content: unset;
  -webkit-box-align: unset;
      -ms-flex-align: unset;
          align-items: unset;
}
.sitemap-space .sitemap-wrapper-item .sitemap-list .sitemap-list-item a:hover {
  color: inherit;
}
.sitemap-space .sitemap-wrapper-item .sitemap-list .sitemap-list-item a:after {
  position: absolute;
  display: inline-block;
  font-size: 1.125rem;
  left: 0;
  content: "・";
  top: 0;
  bottom: 0;
  margin: auto;
}
.sitemap-space .sitemap-wrapper-item .sitemap-list .sitemap-list-item a:before {
  display: none;
}
.sitemap-space .sitemap-wrapper-item .sitemap-list.sitemap-list-inner {
  font-size: 1rem;
}

#hum-menu {
  position: fixed;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.8);
  width: 100%;
  height: 100%;
  padding-top: 2rem;
  padding-bottom: 2rem;
  overflow-y: auto;
  z-index: 990;
}

#sitemap-hum {
  font-size: 1.25rem;
  padding: 1rem;
}
#sitemap-hum.sitemap .sitemap-header {
  display: none;
}
#sitemap-hum.sitemap .sitemap-wrapper .sitemap-wrapper-item {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  margin-right: 0.5rem;
}
#sitemap-hum.sitemap .sitemap-list .sitemap-list-item a {
  padding-top: 0.5em;
  padding-bottom: 0.5em;
}
#sitemap-hum.sitemap .sitemap-list.sitemap-list-inner .sitemap-list-item a {
  font-size: 1rem;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
}

.hum-buttons {
  padding: 0 2rem 0 1rem;
}

.hum-buttons-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.hum-buttons-list li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  color: #fff;
  margin: 0.25rem 0;
}
@media (max-width: 767.98px) {
  .hum-buttons-list li {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
}
.hum-buttons-list li .btn {
  display: block;
  color: #fff;
  font-size: 1.5rem;
  margin: 0 1rem;
  padding-left: 0;
  padding-right: 0;
}
.hum-buttons-list li .btn:hover {
  text-decoration: none;
}
.hum-buttons-list li .btn.link-sns {
  color: #334252;
}

.breadcrumb-wrapper {
  margin-top: 3.25rem;
}
@media (min-width: 992px) {
  .breadcrumb-wrapper {
    margin-top: 5.25rem;
  }
}
.breadcrumb-wrapper .breadcrumb {
  margin-bottom: 0;
}

.breadcrumb-wrapper + #contents {
  margin-top: 0;
}
.breadcrumb-wrapper.is-top + #contents {
  margin-top: 5.25rem;
}

.hero-section {
  position: relative;
}
.hero-section .hero-section-inner {
  max-width: 68rem;
  margin: 0 auto;
}

.hero-set {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 2rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (min-width: 768px) {
  .hero-set {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.hero-set .hero-left {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  text-align: center;
  margin: 3rem 0 0;
}
@media (min-width: 768px) {
  .hero-set .hero-left {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
    text-align: inherit;
    margin: auto;
  }
}
.hero-set .hero-left > h1 {
  margin: 0;
  font-size: 1.875rem;
}
.hero-set .hero-right {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  text-align: center;
}
@media (min-width: 768px) {
  .hero-set .hero-right {
    -webkit-box-flex: 0;
        -ms-flex-positive: 0;
            flex-grow: 0;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
  }
}
.hero-set .hero-right img {
  max-width: 100%;
  height: auto;
}

.hero-grand-title {
  margin: 0 0 0.125rem;
  font-size: 0.875rem;
  line-height: 1.2;
}

.hero-parent-title {
  margin: 0 0 0.25rem;
  font-size: 1.125rem;
  line-height: 0.8;
}

.content-section {
  padding: 0 2rem 2rem;
  background: #E9ECEF;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0rem, #ffffff), color-stop(5rem, #F6F6F6), to(#F6F6F6));
  background: linear-gradient(#ffffff 0rem, #F6F6F6 5rem, #F6F6F6 100%);
}
@media (max-width: 767.98px) {
  .content-section {
    padding: 0 1rem 2rem;
  }
}

.content-section-inner {
  max-width: 68rem;
  margin: 0 auto;
}

.mg-50a {
	margin: 50px auto;
}

.content-kadomaru-wide-padding {
    margin: 1rem auto 2rem;
    border-radius: 0.5rem;
    padding: 2rem 8rem;
    background-color: #fff;
    -webkit-box-shadow: 1px 1px 13px -6px rgba(0, 0, 0, 0.4);
    box-shadow: 1px 1px 13px -6px rgba(0, 0, 0, 0.4);
}
@media (max-width: 980px) {
  .content-kadomaru-wide-padding {
    padding: 1.5rem 4rem;
  }
}
@media (max-width: 620px) {
  .content-kadomaru-wide-padding {
    padding: 1.5rem 2rem;
  }
}

.content-kadomaru {
  margin: 1rem auto 2rem;
  border-radius: 0.5rem;
  padding: 2rem;
  background-color: #fff;
  -webkit-box-shadow: 1px 1px 13px -6px rgba(0, 0, 0, 0.4);
          box-shadow: 1px 1px 13px -6px rgba(0, 0, 0, 0.4);
}
@media (max-width: 767.98px) {
  .content-kadomaru {
    padding: 1.5rem;
  }
}
.content-kadomaru h2 {
  margin-bottom: 1.5rem;
}

.dot-list {
  list-style: disc;
  margin-left: 1.25rem;
  margin-bottom: 1rem;
}

.arrow-list {
  padding: 0;
  margin-bottom: 1rem;
}
.arrow-list li {
  position: relative;
  padding-left: 1rem;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
.arrow-list li:before {
  position: absolute;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f0da";
  width: 1rem;
  height: 100%;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.arrow-row {
  position: relative;
  padding-left: 1rem;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
.arrow-row:before {
  position: absolute;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f0da";
  width: 1rem;
  height: 100%;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.light-list {
  padding: 0;
  margin-bottom: 1rem;
}
.light-list li {
  position: relative;
  padding-left: 3.5rem;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
.light-list li:before {
  position: absolute;
  font-family: "Font Awesome 6 Free";
  font-weight: 400;
  font-size: 1.5rem;
  content: "\f0eb";
  width: 1.5rem;
  height: 2.5rem;
  left: 0.875rem;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: 1;
}
.light-list li:after {
  position: absolute;
  content: "";
  width: 3rem;
  height: 3rem;
  background-color: rgba(255, 255, 0, 0.7);
  border-radius: 1.5rem;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.list-icon-2x li {
  padding-left: 2rem;
}
.list-icon-2x li:before {
  font-size: 2rem;
  width: 2rem;
}

.list-icon-3x li {
  padding-left: 3rem;
}
.list-icon-3x li:before {
  font-size: 3rem;
  width: 3rem;
}

.process-list, .phase-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.process-list > li, .phase-list > li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  margin: 0.5rem 0;
}
@media (min-width: 576px) {
  .process-list > li, .phase-list > li {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-preferred-size: 12rem;
        flex-basis: 12rem;
  }
}
.process-list > li > span, .phase-list > li > span {
  position: relative;
  display: block;
  background-color: #334252;
  color: #fff;
  border-radius: 0.25rem;
  padding: 1.5rem 0.5rem;
  text-align: center;
  width: 100%;
  margin-top: 2rem;
}
@media (min-width: 576px) {
  .process-list > li > span, .phase-list > li > span {
    width: auto;
    margin-top: 0;
    margin-left: 2rem;
  }
}
.process-list > li > span:before, .phase-list > li > span:before {
  position: absolute;
  display: block;
  color: #334252;
  content: "\f061";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 1.5rem;
  left: 0;
  right: 0;
  top: -2.5rem;
  bottom: auto;
  margin: auto;
  height: 2rem;
  width: 2rem;
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
@media (min-width: 576px) {
  .process-list > li > span:before, .phase-list > li > span:before {
    text-align: inherit;
    width: auto;
    height: 2rem;
    top: 0;
    bottom: 0;
    right: auto;
    left: -1.65rem;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
.process-list > li > span.no-arrow:before, .phase-list > li > span.no-arrow:before {
  display: none;
}
.process-list > li:first-child > span, .phase-list > li:first-child > span {
  margin-left: 0;
}
.process-list > li:first-child > span:before, .phase-list > li:first-child > span:before {
  display: none;
}

.phase-set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (min-width: 768px) {
  .phase-set {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.phase-set > li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 24rem;
      flex-basis: 24rem;
  text-align: center;
}

.phase-block {
  padding: 0;
  margin: 0 0.25rem;
}
@media (min-width: 576px) {
  .phase-block {
    padding: 0.5rem;
  }
}

.phase-item {
  position: relative;
  display: block;
  background-color: #334252;
  color: #fff;
  border-radius: 0.25rem;
  padding: 1.5rem 0.5rem;
  text-align: center;
  width: 100%;
}

.phase-title {
  font-weight: bold;
  position: relative;
}
.phase-title > span {
  position: relative;
  display: block;
  padding: 0.5rem 0;
  width: calc(100% - 1rem);
  text-align: center;
  border-top: thin solid #000;
}
.phase-title > span:before {
  position: absolute;
  content: "";
  background-color: #000;
  width: 1rem;
  height: 1px;
  left: -1rem;
  top: 0;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transform-origin: bottom right;
          transform-origin: bottom right;
}
.phase-title > span:after {
  position: absolute;
  content: "";
  background-color: #000;
  width: 1rem;
  height: 1px;
  right: -1rem;
  top: 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transform-origin: bottom left;
          transform-origin: bottom left;
}

.phase-list {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (min-width: 576px) {
  .phase-list {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.phase-list > li {
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
@media (min-width: 576px) {
  .phase-list > li {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
  }
}
.phase-list > li > span {
  margin-left: 0;
  margin-right: 2rem;
  margin-top: 0;
  margin-bottom: 2rem;
}
.phase-list > li > span:before {
  display: none;
}
.phase-list > li > span:after {
  position: absolute;
  display: block;
  color: #334252;
  content: "\f061";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 1.5rem;
  left: 0;
  right: 0;
  top: auto;
  bottom: -2.5rem;
  margin: auto;
  height: 2rem;
  width: 2rem;
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
@media (min-width: 576px) {
  .phase-list > li > span:after {
    text-align: inherit;
    width: auto;
    height: 2rem;
    top: 0;
    bottom: 0;
    left: auto;
    right: -1.65rem;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
.phase-list > li > span.no-arrow {
  margin-right: 0;
}
.phase-list > li > span.no-arrow:after {
  display: none;
}

.image-link-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.image-link-list > li {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  text-align: center;
  margin-bottom: 0.5rem;
  -ms-flex-preferred-size: 16rem;
      flex-basis: 16rem;
}
.image-link-list > li > a {
  display: block;
  -webkit-transition: -webkit-transform 0.2s ease-in 0s;
  transition: -webkit-transform 0.2s ease-in 0s;
  transition: transform 0.2s ease-in 0s;
  transition: transform 0.2s ease-in 0s, -webkit-transform 0.2s ease-in 0s;
  margin-right: 0.5rem;
  height: 100%;
  background-color: #334252;
}
.image-link-list > li > a:hover {
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
  text-decoration: none;
}

.image-link-set {
  margin-bottom: 0;
}
.image-link-set > img {
  width: 100%;
  height: auto;
  border: thin solid #334252;
}
.image-link-set > figcaption {
  background-color: #334252;
  color: #fff;
  padding: 1rem 0.5rem;
  font-size: 1.125rem;
}
.image-link-set.set-examples > figcaption {
  padding: 0;
  color: inherit;
  background-color: inherit;
}
.image-link-set.set-examples > figcaption .system-kinds {
  background-color: #334252;
  color: #fff;
  padding: 0.25rem 0.5rem;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-gyoumu, .image-link-set.set-examples > figcaption .system-kinds.kind-seizou {
  background-color: #84B7DF;
  color: #212529;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-koyou {
  background-color: #79c29b;
  color: #212529;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-order, .image-link-set.set-examples > figcaption .system-kinds.kind-bunka {
  background-color: #e7e3d9;
  color: #212529;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-kyouiku, .image-link-set.set-examples > figcaption .system-kinds.kind-business {
  background-color: #fbd100;
  color: #212529;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-shien {
  background-color: #db926e;
  color: #212529;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-kaigo, .image-link-set.set-examples > figcaption .system-kinds.kind-syakai {
  background-color: #8A80BF;
  color: #fff;
}
.image-link-set.set-examples > figcaption .system-kinds.kind-ec, .image-link-set.set-examples > figcaption .system-kinds.kind-iryou {
  background-color: #ec5e7c;
  color: #fff;
}
.image-link-set.set-examples > figcaption .system-company-name {
  font-size: 1.125rem;
  font-weight: bold;
  padding: 0.5rem 0.5rem 0.25rem;
  color: #fff;
  background-color: #334252;
  line-height: 1.4;
}
.image-link-set.set-examples > figcaption .system-info {
  color: #fff;
  font-size: 0.875rem;
  padding: 0 0.5rem 0.5rem;
  line-height: 1.4;
  background-color: #334252;
}

.badge.kind-gyoumu, .badge.kind-seizou {
  background-color: #84B7DF;
  color: #212529;
}
.badge.kind-koyou {
  background-color: #79c29b;
  color: #212529;
}
.badge.kind-order, .badge.kind-syakai, .badge.kind-bunka {
  background-color: #e7e3d9;
  color: #212529;
}
.badge.kind-kyouiku, .badge.kind-business {
  background-color: #fbd100;
  color: #212529;
}
.badge.kind-shien {
  background-color: #db926e;
  color: #212529;
}
.badge.kind-kaigo {
  background-color: #8A80BF;
  color: #fff;
}
.badge.kind-ec, .badge.kind-iryou {
  background-color: #ec5e7c;
  color: #fff;
}
.badge.use-system-whatsnew {
  background-color: #f7b9c6;
  color: #212529;
}
.badge.use-system-inquiry {
  background-color: #c8c4e1;
  color: #212529;
}
.badge.use-system-events {
  background-color: #bfe2cf;
  color: #212529;
}
.badge.use-system-other-01 {
  background-color: #d5e6f4;
  color: #212529;
}
.badge.use-system-other-02 {
  background-color: #ffe562;
  color: #212529;
}
.badge.use-system-other-03 {
  background-color: #efcfc0;
  color: #212529;
}
.badge.use-system-other-04 {
  background-color: #e8c6d9;
  color: #212529;
}
.badge.use-system-other-05 {
  background-color: #cce8c6;
  color: #212529;
}

.image-text-set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (min-width: 768px) {
  .image-text-set {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.image-text-set .image-text-image {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  text-align: center;
}
@media (min-width: 768px) {
  .image-text-set .image-text-image {
    -ms-flex-preferred-size: 20rem;
        flex-basis: 20rem;
  }
}
.image-text-set .image-text-image img {
  max-width: 100%;
  height: auto;
  padding: 0;
}
@media (min-width: 768px) {
  .image-text-set .image-text-image img {
    padding: 1rem;
  }
}
.image-text-set .image-text-text {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
@media (min-width: 768px) {
  .image-text-set .image-text-text {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
  }
}
.image-text-set.sticky-image {
  position: inherit;
  -webkit-box-align: inherit;
      -ms-flex-align: inherit;
          align-items: inherit;
}
@media (min-width: 768px) {
  .image-text-set.sticky-image {
    position: relative;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.image-text-set.sticky-image .image-text-image {
  position: inherit;
  top: inherit;
}
@media (min-width: 768px) {
  .image-text-set.sticky-image .image-text-image {
    position: sticky;
    top: 6em;
  }
}

.marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(80%, transparent), color-stop(20%, #B1EF36));
  background: linear-gradient(transparent 80%, #B1EF36 20%);
}

.marker-orange {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(80%, transparent), color-stop(20%, #FFCC00));
  background: linear-gradient(transparent 80%, #FFCC00 20%);
}

/* アニメーション前のスタイル */
.js-marker {
  display: inline;
  position: relative;
  background-image: -webkit-gradient(linear, left top, right top, from(#B1EF36), to(#B1EF36));
  background-image: linear-gradient(90deg, #B1EF36, #B1EF36);
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: 0 15%;
  -webkit-transition: all 1s ease-in-out;
  transition: all 1s ease-in-out; /* マーカーを引く速度を調整 */
}
.js-marker.marker-red {
  background-image: -webkit-gradient(linear, left top, right top, from(#dc3545), to(#dc3545));
  background-image: linear-gradient(90deg, #dc3545, #dc3545);
}

/* アニメーション発火時 */
.js-marker.inview {
  background-size: 100% 15%;
}

.prev-button {
  background-color: #334252;
  display: inline-block;
  color: #fff;
  padding: 0.5rem 4rem;
  border-radius: 1.5rem;
  -webkit-transition: background-color 0.2s ease 0s;
  transition: background-color 0.2s ease 0s;
}
.prev-button:hover {
  color: #fff;
  background-color: #506881;
}

.news-button {
  background-color: #1070BA;
  display: inline-block;
  color: #fff;
  padding: 0.5rem 4rem;
  border-radius: 1.5rem;
  -webkit-transition: background-color 0.2s ease 0s;
  transition: background-color 0.2s ease 0s;
}
.news-button:hover {
  color: #fff;
  background-color: #2a98ed;
  text-decoration: none;
}

.qa-row {
  position: relative;
  padding-left: 2rem;
  margin: 0 0 1rem;
}
.qa-row.qa-q:before {
  content: "Q";
}
.qa-row.qa-a:before {
  content: "A";
}
.qa-row:before {
  position: absolute;
  font-family: "Font Awesome 6 Free";
  font-size: 1.5rem;
  font-weight: 900;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1.5rem;
  height: 2.5rem;
}

.qanda-inner {
  margin: 0 2rem;
}
.qanda-inner p:last-of-type {
  margin-bottom: 0;
}

table.one-row-table {
  font-size: 0.9em;
}
@media (max-width: 575.98px) {
  table.one-row-table {
    width: 100%;
  }
}
table.one-row-table tr th, table.one-row-table tr td {
  font-size: 1em;
  font-weight: normal;
  border-top: thin solid #ced4da;
  border-bottom: thin solid #ced4da;
  border-right: thin solid #ced4da;
  padding: 0.25em 0.5em;
  text-align: left;
}
@media (max-width: 575.98px) {
  table.one-row-table tr th, table.one-row-table tr td {
    display: block;
    width: 100%;
    border-left: thin solid #ced4da;
    border-top: 0;
  }
}
table.one-row-table tr th {
  background-color: #e9f2f9;
}
table.one-row-table tr th:first-child, table.one-row-table tr td:first-child {
  border-left: thin solid #ced4da;
}
@media (max-width: 575.98px) {
  table.one-row-table tr th:first-child {
    border-top: thin solid #ced4da;
  }
}

.swiper {
  width: 100%;
  height: 100%;
}

.swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;
  /* Center slide text vertically */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  height: auto !important;
}

.swiper-vertical-set .swiper-slide {
  height: 100% !important;
}

.swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.swiper {
  width: 100%;
  height: 300px;
  margin-left: auto;
  margin-right: auto;
  border: thin solid #dee2e6;
}

.swiper-wrapper {
  -webkit-transition-timing-function: cubic-bezier(0, 0.51, 0.01, 0.93);
          transition-timing-function: cubic-bezier(0, 0.51, 0.01, 0.93);
}

.swiper-slide {
  background-size: cover;
  background-position: center;
}

.swiper-large {
  height: auto;
  width: 100%;
}

.swiper-thumbs {
  height: 20%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 10px 0;
}

.swiper-thumbs .swiper-slide {
  width: 25%;
  height: 100%;
  cursor: pointer;
  margin-top: 0.5em;
  border: thin solid #ced4da;
  padding: 0.25em;
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
  -webkit-transform-origin: center center;
          transform-origin: center center;
  position: relative;
  -webkit-transition: all 0.2s ease 0s;
  transition: all 0.2s ease 0s;
}
.swiper-thumbs .swiper-slide:hover:before {
  position: absolute;
  content: "";
  display: block;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 0, 0.2);
  pointer-events: none;
}

.swiper-thumbs .swiper-slide-thumb-active {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
}
.swiper-thumbs .swiper-slide-thumb-active:before {
  position: absolute;
  content: "";
  display: block;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 0, 0.2);
  pointer-events: none;
}

.swiper-thumbs img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.swiper-vertical-set:after {
  content: "";
  display: block;
  clear: both;
}

.swiper-vertical-left {
  float: left;
  width: calc(100% - 11em);
}
@media (max-width: 767.98px) {
  .swiper-vertical-left {
    width: calc(100% - 6em);
  }
}

.swiper-vertical-right {
  float: right;
  width: 10em;
}
@media (max-width: 767.98px) {
  .swiper-vertical-right {
    width: 5em;
  }
}

.company-wrap h3, .title-p-wrap h3 {
  font-size: 1rem;
  font-weight: bold;
  margin: 0.25rem 0;
}
.company-wrap p, .title-p-wrap p {
  margin-bottom: 2rem;
}

.button-link-list {
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.button-link-list > li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 24em;
      flex-basis: 24em;
}
@media (max-width: 319.98px) {
  .button-link-list > li {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
}
.button-link-list > li a {
  display: block;
  margin: 0.25em;
  position: relative;
}
.button-link-list > li a .button-link-title {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  margin: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.button-link-list > li a .button-link-title .button-link-title-inner {
  position: relative;
}
.button-link-list > li a .button-link-title .button-link-title-inner .link-title {
  position: relative;
  display: block;
  padding: 0.1em 0.25em 0;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  z-index: 2;
}
.button-link-list > li a .button-link-title .button-link-title-inner .link-bg {
  background-color: #fff;
  position: absolute;
  opacity: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 0;
  -webkit-transition: height 0.4s ease 0s;
  transition: height 0.4s ease 0s;
  z-index: 1;
}
.button-link-list > li a .button-link-image {
  -webkit-filter: grayscale(100%);
          filter: grayscale(100%);
  -webkit-transition: -webkit-filter 0.4s ease 0s;
  transition: -webkit-filter 0.4s ease 0s;
  transition: filter 0.4s ease 0s;
  transition: filter 0.4s ease 0s, -webkit-filter 0.4s ease 0s;
}
.button-link-list > li a .button-link-image img {
  width: 100%;
  height: auto;
}
.button-link-list > li a:hover .button-link-title .button-link-title-inner .link-title {
  color: #000;
  background-color: rgba(0, 0, 0, 0);
}
.button-link-list > li a:hover .button-link-title .button-link-title-inner .link-bg {
  height: 100%;
  opacity: 1;
}
.button-link-list > li a:hover .button-link-image {
  -webkit-filter: grayscale(0%);
          filter: grayscale(0%);
}
.button-link-list.list-saboten > li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 12em;
      flex-basis: 12em;
}
@media (max-width: 319.98px) {
  .button-link-list.list-saboten > li {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -ms-flex-preferred-size: 33%;
        flex-basis: 33%;
  }
}
.button-link-list.list-saboten > li a {
  position: relative;
  border: thin solid #ced4da;
  border-radius: 0.25em;
}
.button-link-list.list-saboten > li a .button-link-title {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.button-link-list.list-saboten > li a .button-link-title .button-link-title-inner .link-title {
  margin-left: 1em;
  background-color: transparent;
  color: #343a40;
}
.button-link-list.list-saboten > li a .button-link-title .button-link-title-inner .link-bg {
  margin-left: 1em;
}
.button-link-list.list-saboten > li a .button-link-image {
  text-align: right;
}
.button-link-list.list-saboten > li a .button-link-image img {
  width: 5em;
  height: auto;
  padding: 0.5em;
}
.button-link-list.list-saboten > li a:hover {
  border: thin solid #495057;
}
.button-link-list.list-saboten > li a:hover:before {
  position: absolute;
  content: "";
  background-color: rgba(255, 255, 0, 0.15);
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}
.button-link-list.list-saboten > li a:hover .button-link-title .button-link-title-inner .link-title {
  color: #000;
  background-color: rgba(0, 0, 0, 0);
}
.button-link-list.list-saboten > li a:hover .button-link-title .button-link-title-inner .link-bg {
  height: 100%;
  opacity: 1;
}
.button-link-list.list-saboten > li a:hover .button-link-image {
  -webkit-filter: grayscale(0%);
          filter: grayscale(0%);
}

.rinen-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
@media (max-width: 767.98px) {
  .rinen-header {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.rinen-header .rinen-header-text-space {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: auto;
      flex-basis: auto;
}
.rinen-header .rinen-header-text-space > span {
  font-size: 2em;
  line-height: 1.3;
}
@media (max-width: 767.98px) {
  .rinen-header .rinen-header-text-space > span {
    font-size: 1.5em;
  }
}
.rinen-header .rinen-header-image-space {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 12em;
      flex-basis: 12em;
}
@media (max-width: 767.98px) {
  .rinen-header .rinen-header-image-space {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    text-align: center;
  }
}
.rinen-header .rinen-header-image-space .rinen-header-image {
  display: block;
  width: 100%;
  height: 100%;
}
.rinen-header .rinen-header-image-space .rinen-header-image > source, .rinen-header .rinen-header-image-space .rinen-header-image > img {
  width: 100%;
  height: auto;
}
@media (max-width: 767.98px) {
  .rinen-header .rinen-header-image-space .rinen-header-image > source, .rinen-header .rinen-header-image-space .rinen-header-image > img {
    width: 8em;
  }
}

.underline {
  border-bottom: thin dashed #ced4da;
  padding-bottom: 0.5em;
}

dl.staff dt {
  color: #d4411e;
  margin-bottom: 0.5em;
}
dl.staff dd {
  line-height: 1.8;
  margin-bottom: 2em;
}
dl.historytable {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
dl.historytable dt {
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 10em;
      flex-basis: 10em;
  border-right: 0.1em solid #1D665D;
  margin-bottom: 2em;
}
@media (max-width: 767.98px) {
  dl.historytable dt {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    text-align: center;
    margin-bottom: 1em;
    border-right: none;
  }
}
dl.historytable dt > div {
  padding: 0.5em 1em;
}
dl.historytable dd {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: calc(100% - 10em);
      flex-basis: calc(100% - 10em);
  margin-bottom: 2em;
}
dl.historytable dd > div {
  padding: 0.5em 1em;
}
dl.historytable dd > div img {
  margin: 1em 0;
}
@media (max-width: 767.98px) {
  dl.historytable dd {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    text-align: center;
    margin-bottom: 2em;
  }
  dl.historytable dd > div {
    padding-left: inherit;
  }
}

.representative {
  border-radius: 50%;
  -webkit-box-shadow: 1px 1px 10px #888;
          box-shadow: 1px 1px 10px #888;
}

.kadomaru {
  border-radius: 0.25em;
}

.media-year {
  border-left: 0.2em solid #1D665D;
  padding-left: 0.25em;
  padding-top: 0.25em;
  padding-bottom: 0.25em;
  margin: 2em 0 1em;
}

.media-space .m_fl {
  font-weight: bold;
  float: right;
}
@media (max-width: 767.98px) {
  .media-space .m_fl {
    float: none;
  }
}
.media-space .media-at {
  color: #1D665D;
  font-weight: bold;
}
.media-space .media-at:after {
  content: "";
  clear: both;
}
.media-space .pdf {
  display: inline-block;
  background-color: #dc3545;
  padding: 0 0.5em;
  border-radius: 0.25em;
}
.media-space .pdf:before {
  content: "PDF";
  font-size: 0.8em;
  color: #fff;
  font-weight: bold;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "游ゴシック体", YuGothic, "Yu Gothic Medium", sans-serif;
}
.media-space .url {
  display: inline-block;
  background-color: #1070BA;
  padding: 0 0.5em;
  border-radius: 0.25em;
}
.media-space .url:before {
  content: "URL";
  font-size: 0.8em;
  color: #fff;
  font-weight: bold;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "游ゴシック体", YuGothic, "Yu Gothic Medium", sans-serif;
}

.staff-space .staffh3 {
  font-size: 1rem;
  color: #1D665D;
}
.staff-space .namae {
  display: inline-block;
  font-size: 0.9em;
  color: #495057;
  margin-right: 0.5em;
}
.staff-space .staffinfo {
  font-size: 0.9em;
  color: #495057;
}
.staff-space .nyusyanen {
  margin-left: 0.5em;
  margin-right: 0.5em;
}
.staff-space .nyusyanen2 {
  font-weight: bold;
}
.staff-space dl.staff {
  margin-top: 2em;
  margin-bottom: 2em;
  border-bottom: thin dashed #ced4da;
}
.staff-space dl dt {
  margin: 1em 0;
}

.name-card-space h3, .name-card-space h4 {
  color: #1D665D;
  font-weight: bold;
  margin-bottom: 1em;
}
.name-card-space .ncimage {
  margin-top: 1em;
  margin-bottom: 1em;
}
.name-card-space .resimg {
  max-width: 100%;
  height: auto;
}

.flex-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
@media (max-width: 767.98px) {
  .flex-list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.flex-list ul.left, .flex-list ul.right {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
}
@media (max-width: 767.98px) {
  .flex-list ul.left, .flex-list ul.right {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
}
.flex-list ul.left > li, .flex-list ul.right > li {
  display: block;
  position: relative;
  padding-left: 1.25em;
  padding-right: 0.75em;
  margin-bottom: 0.25em;
}
.flex-list ul.left > li:before, .flex-list ul.right > li:before {
  position: absolute;
  content: "\f219";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  left: 0;
  top: 0;
  -webkit-transform: scale(0.75);
          transform: scale(0.75);
  -webkit-transform-origin: center center;
          transform-origin: center center;
  color: #2ea293;
}

.privacy-box-space {
  line-height: 2;
}
.privacy-box-space h3 {
  margin: 2em 0 1em;
  font-weight: bold;
  color: #1D665D;
}
.privacy-box-space h4 {
  font-weight: bold;
}

.lity-space {
  position: relative;
  display: block;
}
.lity-space:before {
  position: absolute;
  right: 1.5rem;
  bottom: 1.5rem;
  content: "\f00e";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 1.5rem;
  color: #fff;
  pointer-events: none;
}
.lity-space.lity-trans:before {
  color: rgba(0, 0, 0, 0.4);
}

.forminput {
  table-layout: fixed;
  margin-bottom: 2em;
  width: 100%;
}
.forminput tr th, .forminput tr td {
  padding: 1em;
}
.forminput tr th {
  width: 12em;
  background-color: #1D665D;
  border-bottom: thin solid #fff;
  color: #fff;
}
.forminput tr td {
  border-bottom: thin dotted #adb5bd;
  border-right: thin dotted #adb5bd;
}
.forminput tr:nth-child(1) th {
  border-top: thin solid #1D665D;
}
.forminput tr:nth-child(1) td {
  border-top: thin dotted #adb5bd;
}
@media (max-width: 767.98px) {
  .forminput {
    margin-left: 0;
    margin-right: 0;
  }
  .forminput tr th, .forminput tr td {
    display: block;
    max-width: inherit;
    width: 100%;
    border: none;
  }
  .forminput tr th {
    padding: 0.25rem 0.5rem;
  }
  .forminput tr td {
    padding: 1rem 0;
  }
  .forminput tr:nth-child(1) th, .forminput tr:nth-child(1) td {
    border: none;
  }
}

.error {
  font-weight: bold;
  color: #dc3545;
  margin: 0;
}
.error:blank {
  display: none;
}

.box {
  margin-bottom: 2em;
}

.scrollBox {
  max-height: 16em;
  overflow-y: scroll;
  border: thin solid #adb5bd;
  padding: 1.5em;
}

.background-masker {
  background-color: #fff;
  display: inline-block;
}

@-webkit-keyframes placeHolderShimmer {
  0% {
    background-position: -800px 0;
  }
  100% {
    background-position: 800px 0;
  }
}

@keyframes placeHolderShimmer {
  0% {
    background-position: -800px 0;
  }
  100% {
    background-position: 800px 0;
  }
}
.animated-background {
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: placeHolderShimmer;
          animation-name: placeHolderShimmer;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  background-color: #f6f7f8;
  background: -webkit-gradient(linear, left top, right top, color-stop(8%, #eeeeee), color-stop(18%, #bbbbbb), color-stop(33%, #eeeeee));
  background: linear-gradient(to right, #eeeeee 8%, #bbbbbb 18%, #eeeeee 33%);
  background-size: 800px 104px;
  display: block;
}

.static-background {
  background-color: #f6f7f8;
  background-size: 800px 104px;
  height: 1em;
  position: relative;
  margin-bottom: 20px;
}

.hover-scale {
  -webkit-transform-origin: center center;
          transform-origin: center center;
  -webkit-transition: all 0.2s ease-in 0s;
  transition: all 0.2s ease-in 0s;
}
.hover-scale:hover {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  -webkit-box-shadow: 1px 1px 6px 3px #ced4da;
          box-shadow: 1px 1px 6px 3px #ced4da;
}

.badge.dan-ochi {
  white-space: inherit;
}

#scroll-to-top {
  position: fixed;
  font-size: 2.5em;
  bottom: 2.2em;
  right: 1em;
  width: 1.5em;
  height: 1.5em;
  background-color: #fff;
  border-radius: 50%;
  z-index: 1000;
}
#scroll-to-top #js-scroll-to-top {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  color: #2b9688;
}
#scroll-to-top #js-scroll-to-top:hover {
  text-decoration: none;
  color: #247e73;
}

body.overflow-hidden #scroll-to-top {
  display: none;
}

.ckeditor-body table {
  max-width: 100%;
}
@media (max-width: 767.98px) {
  .ckeditor-body table {
    width: 100% !important;
  }
}
@media (max-width: 767.98px) {
  .ckeditor-body table thead tr th, .ckeditor-body table thead tr td, .ckeditor-body table tbody tr th, .ckeditor-body table tbody tr td {
    display: block !important;
    width: 100% !important;
    word-break: break-all;
  }
}
@media (max-width: 767.98px) {
  .ckeditor-body img {
    width: auto !important;
    max-width: 100%;
    height: auto;
  }
}

.csr_bnr-link {
  max-width: 37.5em;
  padding-left: 1em;
  padding-right: 1em;
  display: inline-block;
  -webkit-transition: -webkit-transform 0.2s ease 0s;
  transition: -webkit-transform 0.2s ease 0s;
  transition: transform 0.2s ease 0s;
  transition: transform 0.2s ease 0s, -webkit-transform 0.2s ease 0s;
}
.csr_bnr-link img {
  border-radius: 0.5rem;
  width: 100%;
  height: auto;
}
.csr_bnr-link:hover {
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
}

.btn_recruit_form {
  display: inline-block;
  background: #EFEFEF linear-gradient(180deg, #f1f1f1, #EFEFEF) repeat-x;
  border: thin solid #adb5bd;
  border-radius: 2em;
  width: 100%;
  margin: 0.5rem 0;
  padding: 0.75rem 0.5rem;
  color: #222;
  -webkit-box-shadow: 0 0.25rem 1rem -0.5rem #6c757d;
          box-shadow: 0 0.25rem 1rem -0.5rem #6c757d;
  -webkit-transition: background-color 0.2s ease 0s;
  transition: background-color 0.2s ease 0s;
  font-size: 1.4rem;
  line-height: 1.4;
  font-weight: bold;
}
@media (min-width: 576px) {
	.btn_recruit_form {
		font-size: 1.8rem;
	}
}
@media (min-width: 768px) {
  .btn_recruit_form {
    width: 30rem;
    padding: 0.75rem 1rem;
  }
}
.btn_recruit_form:hover {
  color: #222;
  text-decoration: none;
  border-color: #919ca6;
  background: gainsboro linear-gradient(180deg, #e1e1e1, gainsboro) repeat-x;
}

.mail_img {
	width: 100%;
	max-width: 13em;
}

.caution::after{
    content: "必須";
    font-weight: normal;
    background-color: rgb(217, 83, 79);
    width: 40px;
    color: rgb(255, 255, 255);
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    padding: 0.1em 0.5em;
    border-radius: 0.25em;
}

.floating-banner {
    position: fixed;
    z-index: 99;
    top: 6.5rem;
    right: 0;
    background: #28645c;/* バナーの背景色 */
    color: #fff;/* バナー内の文字色 */
    font-weight: bold;
    text-align: center;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
}

.floating-banner a {
    text-decoration: none;/* リンクに下線が入らないように */
}

.banner {
	padding: 0.5em;
	line-height: 1;
}

.cta {
    display: inline;
    width: auto;
    height: auto;
	padding: 1em 0.7em 1em 0.5em;
    font-size: 18px;
    background: linear-gradient(270deg, #F4A240 0%, #E3A608 100%); /* ボタンの背景 */
    border-radius: 25px;
    margin: 0;
	text-align: center;
	writing-mode: vertical-rl;
	line-height: 1;
	letter-spacing: 0.1em;
}

.cta i {
	margin-bottom: 0.2em;
	font-size: 1.5em;
}

.btn_video img {
	width: 100%;
	border: 0.2em solid #ccc;
	border-radius: 0.6em;
}

.fs-120 {
	font-size: 1.2em;
}

.non-new-line {
	display: none;
}

.detail-btn {
	padding: 0.625rem 1.25rem !important;

}

@media screen and (max-width: 1475px) {	
	
	.floating-banner {
		top: auto;
		right: auto;
		bottom: 0;
        width: 100vw;
		display: flex;
		justify-content: center;
		border-top-left-radius: 0px;
        border-bottom-left-radius: 0px;
    }
	
	.banner {
		display: flex;
		align-items: center;
    }
	
	.non-new-line {
	    display: inline-block;
    }
	
	.new-line {
		display: none;
	}
	
	.cta {
		padding: 0.5rem 1rem 0.7rem; 
		order: 0;
        font-size: 16px;
	    writing-mode: horizontal-tb;
    }
	
	.cta i {
		margin-bottom: 0;
		margin-right: 0.2em;
	}
}