.mirai-wrapper p {
    /* text-align: justify; */
}

.mirai-wrapper p + p {
    margin-top: 2em;
    /* text-align: justify; */
}

.mirai-wrapper > div > h2 {
    margin: 60px 0 30px;
}

.mirai-wrapper {
    --content-width:700px;
}

/*------------------------------------------------*/

.mirai-logo {
    text-align: center;
    margin:40px 0;
}

.mirai-logo img {
    width:400px;
}

.mirai-mission h2 {
  position:relative;
  gap:10px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 19px;
  margin: 50px 0 30px;
}

.mirai-mission h2:before,
.mirai-mission h2:after {
  content:"";
  height:1px;
  width:60px;
  background:black;
}

.mirai-mission p {
    text-align: center;
}

.mirai-mission p span {
    padding-bottom: 1px;
    font-size: 1.3em;
    text-align: center;
    background: linear-gradient(transparent 50%, #cbff9959 70%);
    display: inline-block;
    margin: auto;
    word-break: auto-phrase;
}

/* ------------------------------------------------ */

.message {
    max-width: var(--content-width);
    margin:auto;
    border-bottom: 3px solid #f7c9dd;
    padding-bottom: 40px;
}


.mirai-wrapper .message h2 {
    border: solid #f7c9dd;
    border-width: 3px 0;
    padding: 25px 0;
    color: #ed7d31;
    margin-bottom: 40px;
    margin-top: 40px;
    /* font-size: 20px; */
    text-align: center;
}

.message > div {
    /* display: flex; */
    /* gap: 20px; */
    /* flex-direction: column-reverse; */
}

.message > div > div:first-child {
    width: 130px;
    float: right;
    margin: 0 0 10px 10px;
}

.message > div > div:first-child img {
    width:100%;
}

.message > div > div:last-child {
    flex:1;
    text-align: left;
}

.message > div > div p:first-child {
    font-size:20px;
}

.message > div + div {
    border-top: 3px solid  #f7c9dd;
    margin-top: 30px;
    padding-top: 30px;
}


/*------------------------------------------------*/

.recruit-method h2 {
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    margin: 80px 0 30px;
}


.recruit-contact {
    background: #E7F2E7;
    padding: 10px 20px 10px;
    display:flex;
    justify-content:space-between;
    margin-top: 20px;
    color:#61a85e;
    flex-direction: column;
}

.recruit-contact > div {
    display:flex;
    align-items: center;
    flex-direction: column;
    flex: 1;
    gap: 0px;
    padding: 25px 0;
}

.recruit-contact > div a {
    color:#61A85E;
}

.recruit-contact > div a:hover {
    text-decoration:underline;
}

.recruit-contact > div:first-child {
    border-bottom: 1px solid #61A85E;
}

.recruit-contact > div:nth-child(2) p {
    font-size: 20px !important;
}

.recruit-contact h3 {
    font-size: 1.1em;
    margin-bottom: 16px;
}

.recruit-contact p.recruit-tel {
    font-size: 26px;
    line-height: 1;
}

.recruit-contact p.recruit-tel span {
    font-size: .5em;
    padding-left:.2em;
    display: none;
}

@media screen and (max-width: 360px){
    .recruit-contact p.recruit-tel {
    font-size: 30px;
    }
}

.recruit-contact p.recruit-hours {
    font-size: 1em;
    font-weight: bold;
    margin-top: 15px;
}

.last-comment {
  margin-top:60px;
}

/*------------------------------------------------*/


ul.mirai-house-point {
    display:flex;
    gap: 15px;
    margin: 30px auto 20px;
    flex-wrap: wrap;
    /* max-width: 680px; */
    justify-content: center;
    align-items: center;
}

ul.mirai-house-point li {
    flex: 1 1 20%;
    background:#ffe498;
    border-radius: 50% 33% 34% 29% / 43% 54% 49% 45%;
    display:flex;
    padding: 62px 7px 62px;
    word-break:auto-phrase;
    text-align:center;
    flex-direction: column;
    box-sizing: border-box;
    justify-content: center;
    align-items: center;
}


ul.mirai-house-point + p {
    font-size:22px;
    margin-top: 30px;
    font-weight:bold;
}

ul.mirai-house-point li h3 {
    margin-bottom: 0.6em;
    font-size: 17px;
}


.mirai-house-point2 {
    display:flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.mirai-house-point2 > ul {
    margin: 0em 0 1.8em;
}

.mirai-house-point2 > ul li {
    list-style-type:disc;
    margin-left:1.5em;
}

.mirai-house-point2 > ul li {
    line-height:1.7;
}

.mirai-house-point2 > ul li + li {
    margin-top:.5em;
}

.guide-detail-wrapper > p {
    max-width: 700px;
    margin: auto;
    word-break: auto-phrase;
}

.guide-detail-wrapper > div {
    max-width: 700px;
    margin: 25px auto 0px;
    background: #e7f2e7;
    padding: 2em 2em 1.4em;
    box-sizing: border-box;
}

.mission-statement {
    display: flex;
    align-items: center;
    padding: 30px 7px 30px;
    justify-content: center;
}

.mission-statement ul {
    display:grid;
    gap:15px;
    margin: 0px 0 10px 2.5em;
    /* width: 490px; */
}

.mission-statement li {
    list-style-type:disc;
    margin-left:1.5em;
}

.mission-statement li span {
    background: linear-gradient(transparent 50%, #cbff9959 70%);
    padding:10px 0;
}

.mirai-house-about p {
    max-width: var(--content-width);
    margin: 25px auto;
}

/*------------------------------------------------*/
.swiper-slide {
    margin: auto;
}

.slider-thumbnail .swiper-slide {
    opacity: .5;
    transition: opacity .5s;
    width: calc(100% / 3);
}

.slider-thumbnail .swiper-slide.swiper-slide-thumb-active {
    opacity: 1;
}

.swiper {
    max-width: 600px;
    width: 100%;
    margin: 20px 0;
    overflow: visible;
}

.swiper-button-prev {
    left: -50px;
}

.swiper-button-next {
    right: -50px;
}

.swiper-slide img {
    height: auto;
    width: 100%;
    max-height: 270px;
    object-fit: contain;
}

.swiper-button-next, .swiper-button-prev {
  color:#ccc;
}

:root {
    --swiper-navigation-size: 40px;
}

.swiper-button-next{
  margin-right: 10px;
}

.swiper-button-prev {
  margin-left: 10px;
}

.thumb-wrapper {
    display: flex;
    overflow:auto;
    margin:auto;
    gap: 14px;
}

.thumb-media {
    transition:.2s;
}

.thumb-media:hover {
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
}

.thumb-media-active {
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
  opacity: 0.3;
}

.thumb-wrapper img {
    max-width: 80px;
    max-height: 80px;
    object-fit: cover;
    aspect-ratio: 1/1;
}

/*------------------------------------------------*/

.mirai-house-support h3,
.mirai-house-about h3 {
    text-align:center;
    color:#3c3c3c;
    font-size: 18px;
    margin: 40px 0 10px;
}

.mirai-house-support h3 + p {
    text-align:center;
    margin: 15px 0;
}

.mirai-house-support table {
  width: var(--content-width);
  border-collapse:collapse;
  table-layout: fixed;
  margin: 20px auto;
}

@media (max-width: 850px){
    .mirai-house-support table {
     width: 100%;
    }
}

.mirai-house-support2 {
    max-width: var(--content-width);
    margin: auto;
}

.guide-detail-wrapper {
        max-width: var(--content-width);
        margin: 25px auto 0px;
        background: #e7f2e7;
        display:flex;
        justify-content:center;
        padding: 2em 1.5em;
        box-sizing: border-box;
}

.guide-detail-wrapper ul li {
    list-style-type:disc;
    margin-left:1.5em;
    line-height: 1.7;
}

.guide-detail-wrapper ul li + li {
    margin-top:.5em;
}

.guide-detail-wrapper ol > li {
    margin-left: 1.8em;
    list-style-type: none;
    counter-increment: item;
    position:relative;
}

.guide-detail-wrapper ol > li:before {
  content: counter(item)'.';
  padding-right: .5em;
  font-weight: bold;
  color: #2e9a29;
  position:absolute;
  left:-1.5em;
}

.guide-detail-wrapper ol > li + li {
    margin-top:1em;
}

.guide-detail-wrapper ol ul {
    margin:.5em 1em;
}

.guide-detail-wrapper dl {
    display:flex;
    flex-wrap:wrap;
    --dt-width1: 144px;
    --dt-width2: 214px;
}

.guide-detail-wrapper dl dt {
    margin-bottom: 10px;
}

.guide-detail-wrapper dl dd:not(:last-child) {
    margin-bottom: 20px;
}

.guide-detail-wrapper dl.mirai-house-guide1 dt {
    font-weight:bold;
    width: var(--dt-width1);
}

.guide-detail-wrapper dl.mirai-house-guide1 dd {
    width: 100%;
}

.guide-detail-wrapper dl.mirai-house-guide2 dt {
    font-weight:bold;
    width: var(--dt-width2);
}

.guide-detail-wrapper dl.mirai-house-guide2 dd {
    width: 100%;
}

.mirai-house-support h4 {
    margin: 0px 0 20px;
    color: #61A85E;
    text-align: center;
    font-size: 1.2em;
    line-height: 1.5;
    word-break: auto-phrase;
}

.mirai-house-support .guide-detail-wrapper {
    flex-direction: column;
}


.mirai-house-support .guide-detail-wrapper + p {
    text-align:center;
    margin:20px 0;
}

/*------------------------------------------------*/

.mirai-house-line {
    max-width: 730px;
    margin: 20px auto;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row-reverse;
    gap: 20px;
    word-break: auto-phrase;
}

.mirai-house-line .qr {
    width: 110px;
}

.mirai-house-line p {
    flex:1;
    word-break: break-all;
}

.mirai-house-line .qr a {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    color:#61a85e;
}

.mirai-house-line .qr img {
    width:100%;
}


.mirai-house-line .qr p {
    font-size:14px;
    flex:1;
    word-break: auto-phrase;
    text-align: center;
    line-height: 1.4;
}

/*------------------------------------------------*/

.mirai-house-sns {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    width: 230px;
    margin: 30px auto;
}

.mirai-house-sns > div {
    text-align:center;
}

.mirai-house-sns > div img {
    width:100%;
}