@charset "utf-8";
/* *********************************
社団法人  CSS
------------------------------------
【メディアクエリ】
■ メディアクエリ指定なし　：共通（スマホ基準）
■ max-width: 856px　：スマホ専用
■ min-width: 857px　：タブレット・PC用
■ min-width: 1000px　：PC専用
------------------------------------
【カラー】
■ ベースカラー　: #f2efe2
■ タイトル文字カラー　： #4c413a
■ アクセントカラー　: #2eb8b2
■ アクセントカラー　: #ff9292
------------------------------------
********************************* */
/* =================================
 reset
================================= */
html, body, div, span, applet, object, iframe,h1, h2, h3, h4, h5, h6, p, blockquote, pre,a, abbr, acronym, address, big, cite, code,del, dfn, em, img, ins, kbd, q, s, samp,small, strike, strong, sub, sup, tt, var,b, u, i, center,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td,article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary,time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
body { line-height: 1; }
ol, ul { list-style: none; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after,q:before, q:after { content: ''; content: none; }
table { border-collapse: collapse; border-spacing: 0; }
/* clearfix */
.cf:after{
	display:block;
	clear:both;
	height:0;
	visibility:hidden;
	content:".";
}
.cf {
	min-height:1px;
}
* html .cf {
  height: 1px;
  /*¥*//*/
  height: auto;
  overflow: hidden;
  /**/
}

/* =================================
 Font Awesome
================================= */
/* 軽量化のため使用分のみ(他のを使いたいときはcssを抜き出して増やす) */
@font-face {
  font-family: 'Font Awesome 5 Brands';
  font-style: normal;
  font-weight: 400;
  src: url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-brands-400.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  src: url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-solid-900.eot");
  src: url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-solid-900.eot?#iefix") format("embedded-opentype"), url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-solid-900.woff2") format("woff2"), url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-solid-900.woff") format("woff"), url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-solid-900.ttf") format("truetype"), url("//cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.6.3/webfonts/fa-solid-900.svg#fontawesome") format("svg");
  font-display: swap;
}

.fab {
  font-family: "Font Awesome 5 Brands",sans-serif;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
}
.fa-twitter::before { content: "\f099"; }
.fa-facebook-f:before { content: "\f39e"; }

.fas {
  -moz-osx-font-smoothing:grayscale;
  -webkit-font-smoothing:antialiased;
  display:inline-block;
  font-style:normal;
  font-variant:normal;
  text-rendering:auto;
  line-height:1;
  font-family:"Font Awesome 5 Free",sans-serif;
  font-weight:900
}
.fa-angle-double-down:before { content: "\f103"; }
.fa-angle-double-left:before { content: "\f100"; }
.fa-angle-double-right:before { content: "\f101"; }
.fa-angle-double-up:before { content: "\f102"; }
.fa-angle-down:before { content: "\f107"; }
.fa-angle-left:before { content: "\f104"; }
.fa-angle-right:before { content: "\f105"; }
.fa-angle-up:before { content: "\f106"; }
.fa-chevron-down:before { content: "\f078"; }
.fa-chevron-left:before { content: "\f053"; }
.fa-chevron-right:before { content: "\f054"; }
.fa-chevron-up:before { content: "\f077"; }

/* =================================
 Base Layout
================================= */
*, *::before, *::after {
  box-sizing: border-box;
}
body {
  width: 100%;
  color: #4c413a;
  font-family: fot-tsukuardgothic-std, sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 18px;
  line-height: 1.7;
  position: relative;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}
main {
  position: relative;
}

a {
  text-decoration: none;
  color: inherit;
  transition: 0.6s;
}
img {
  max-width: 100%;
  image-rendering: -webkit-optimize-contrast;
}
@media screen and (max-width:856px) {
  body {
    font-size: 16px;
    line-height: 1.4;
  }
}

/* =================================
 common style
================================= */
.pc {
  display: inline-block;
}
.sp {
  display: none;
}
main section:nth-child(even) {
  background: #f2efe2;
}

main section .secWrap {
  width: 94%;
  max-width: 1080px;
  margin: 0 auto;
  padding: 120px 3%;
}
/* 各セクションタイトル(マップ部分以外) */
/* 上下の高さの違いに関しては各部位で設定 */
main section .secTtl {
  padding-top: 80px;
  text-align: center;
  background: url(../img/ico_diapers.svg) no-repeat center top;
  background-size: 65px;
}
main section .secTtl h2 {
  font-size: 36px;
}
main section .secTtl div {
  width: 80%;
  max-width: 335px;
  margin: 15px auto;
  padding-top: 5px;
  font-size: 24px;
  color: #2eb8b2;
  background: url(../img/border.svg) no-repeat center top;
}
@media all and (-ms-high-contrast: none) {
  main section .secTtl {
    background-size: 243px;
  }
  main section .secTtl div {
    margin: 0 auto;
    padding-top: 25px;
    background: url(../img/border.svg) no-repeat center -20px;
  }
}
@media screen and (max-width:856px) {
  .pc {
    display: none;
  }
  .sp {
    display: inline-block;
  }
  main section .secWrap {
    padding: 60px 3%;
  }
/* 各セクションタイトル(マップ部分以外) */
/* 上下の高さの違いに関しては各部位で設定 */
  main section .secTtl {
    padding-top: 60px;
    background-size: 45px;
  }
  main section .secTtl h2 {
    font-size: 25px;
  }
  main section .secTtl div {
    font-size: 16px;
  }
}


/* =================================
 header
================================= */
header {
  height: 106px;
  padding: 0 5%;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 2px solid #999;
  background: rgba(255,255,255,1);
  transition: 0.6s;
  z-index: 10;
}
header h1 {
  max-width: 595px;
  width: 65%;
}
header h1 img {
  width: 100%;
  filter: drop-shadow(0px 0px 0px #4f4034);
}
header .contact {
  width: 30%;
  max-width: 280px;
}
header .contact a {
  padding: 2px 0 5px;
  font-size: 25px;
  font-weight: 400;
  text-align: center;
  color: #fff;
  position: relative;
  border: 2px solid #2eb8b2;
  border-radius: 25px;
  background: #2eb8b2;
  display: block;
}
header .contact a::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free",sans-serif;
  font-weight: 600;
  position: absolute;
  top: 3px;
  right: 20px;
}
header .contact a:hover {
  color: #2eb8b2;
  font-weight: 600;
  background: transparent;
}

header.fix {
  width: 100%;
  height: 68px;
  position: fixed;
  background: rgba(255,255,255,0.8);
  z-index: 10;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}
@media all and (-ms-high-contrast: none) {
  header .contact a {
    padding: 10px 0 0;
  }
  header .contact a::after {
    top: 5px;
  }
}
@media screen and (max-width:856px) {
  header {
    width: 100%;
    height: 50px;
    padding: 0 2%;
    position: fixed;
  }
  header h1 {
    width: 70%;
  }
  header .contact {
    width: 28%;
  }
  header .contact a {
    padding: 0 0 2px;
    font-size: 13px;
  }
  header .contact a::after {
    content: "";
  }

  header.fix {
    width: 100%;
    height: 48px;
  }
}

/* =================================
 main
================================= */
main {
  opacity: 0;
}
main .main {
  position: relative;
  background: url(../img/main.webp) no-repeat center;
  background-size: cover;
  z-index: -1;
}
.no-webp main .main {
  position: relative;
  background: url(../img/main.jpg) no-repeat center;
  background-size: cover;
  z-index: -1;
}
@media screen and (min-width:857px) {
  main .main.fix {
    background-attachment: fixed;
  }
}
@media screen and (max-width:856px) {
  main .main {
    margin-top: 0px;
/*    overflow: hidden;*/
    background: url(../img/main@2x.jpg) no-repeat center 50px;
    background-size: cover;
  }
}

/* =================================
 SVG
================================= */
.main .svgall {
  width: 100%;
  max-width: 1000px;
  margin-top: 0;
  position: absolute;
  top: 44%;
  left: 50%;
}
.main .mask {
  filter: drop-shadow(3px 3px 5px #333);
  transform: translate(-50%,-50%);
}
.main	.st0 {
  fill:#FFFFFF;
}
.main	.st1 {
  fill: none;
  stroke: #fff;
  stroke-width: 8;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}
.main	.st2 {
  fill: none;
  stroke: #fff;
  stroke-width: 6;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}
.main .svgbase {
  filter: invert(100%) sepia(0%) saturate(2%) hue-rotate(287deg) brightness(105%) contrast(101%);
}
@media all and (-ms-high-contrast: none) {
/*
  .main .svgall .mask.pc {
    display: none;
  }
  .main .svgall .sp.img {
    width: 90%;
    margin: 0 auto;
    display: inline-block;
    transform: translate(-50%,0);
    filter: glow(color=#333,strength=5px);
    filter: drop-shadow(3px 3px 5px #333);
    box-shadow: 0 0 30px rgba(0, 0, 0, .6);
  }
*/
}
@media screen and (max-width:856px) {
  .main .svgall {
    height: 100%;
    position: relative;
    top: inherit;
    left: inherit;
  }
  .main .svgall .sp.img {
    width: 90%;
    margin: 0 auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-25%);
    filter: drop-shadow(3px 3px 5px #333);
  }
  .main .svgall .sp.img img {
    max-width: 100%;
  }
}

/* =================================
 about
================================= */
.about .secWrap{
  padding: 90px 3% 55px;
}
.about .secTtl {
}
.about {
  text-align: center;
}
.about .txt {
  margin-top: 40px;
  font-size: 22px;
  line-height: 1.9;
}
.about ul {
  margin-top: 100px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.about ul li {
  width: 100%;
  max-width: 285px;
  margin-bottom: 65px;
}
.about ul li .imgBox {
  width: 100%;
  height: 285px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  background: #fff;
}
.about ul li .imgBox img {
  text-align: center;
  margin: 0 auto;
}
.about ul li:first-child img {
  max-width: 186px;
}
.about ul li dl {
  margin-top: 20px;
}
.about ul li dl dt {
  font-size: 30px;
}
.about ul li dl dd {
  padding-top: 20px;
  font-size: 20px;
}
@media screen and (max-width:856px) {
  .about .secWrap{
    padding: 60px 3% 55px;
  }
  .about .txt {
    font-size: 16px;
    line-height: 1.7;
  }
  .about ul {
    margin-top: 80px;
    justify-content: center;
  }
  .about ul li .imgBox {
    width: 260px;
    height: 260px;
    margin: 0 auto;
    justify-content: center;
  }
  .about ul li:first-child img {
    width: 170px;
  }
  .about ul li:nth-child(2) img {
    width: 145px;
  }
  .about ul li:last-child img {
    width: 181px;
  }
  .about ul li dl dt {
    font-size: 25px;
  }
  .about ul li dl dd {
    padding-top: 15px;
    font-size: 16px;
  }
}

/* =================================
 interview
================================= */
.interview {
  
}
.interview .secTtl {
}
.interview .oneday {
  margin-bottom: 200px;
  text-align: center;
}
.interview .onedayTtl {
  margin: 115px auto 60px;
  padding: 0 30px 25px;
  font-size: 36px;
  position: relative;
  display: inline-block;
  border-bottom: 2px solid #4c413a;
}
.interview .onedayTtl::before, .interview .onedayTtl::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.interview .onedayTtl::before {
  border: solid 20px transparent;
  border-top: solid 38px #4c413a;
}
.interview .onedayTtl::after {
  border: solid 20px transparent;
  border-top: solid 39px #fff;
  margin-top: -5px;
}
.interview .oneday .flex {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  counter-reset: count 0;
}
.interview .oneday dl {
  width: 30%;
  max-width: 284px;
  margin: 80px 5% 0 0;
  position: relative;
}
.interview .oneday dl::after {
  font-size: 30px;
  content: "\f054";
  font-family: "Font Awesome 5 Free",sans-serif;
  font-weight: 600;
  position: absolute;
  top: 38%;
  right: -13%;
}
.interview .oneday dl:nth-child(3), .interview .oneday dl:nth-child(5) {
  margin-right: 0;
}
.interview .oneday dl:nth-child(3)::after, .interview .oneday dl:nth-child(5)::after {
  content: "";
}
.interview .oneday dl dt {
  padding-left: 56px;
  font-size: 28px;
  text-align: left;
  position: relative;
}
.interview .oneday dl dt::before {
  width: 48px;
  height: 48px;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  background: #ff9191;
  border-radius: 50%;
}
.interview .oneday dl dt::after {
  color: #fff;
  font-size: 28px;
  content: counter(count);
  counter-increment: count 1;
  position: absolute;
  top: 0;
  left: 16px;
}
.interview .oneday dl dd {
  padding-top: 30px;
  font-size: 20px;
}
.interview .oneday dl dd img {
  width: 100%;
}
.interview .oneday dl dd figcaption {
  margin-top: 25px;
}

.interview .block {
  margin-top: 120px;
}
.interview .block .blockTtl {
  margin-bottom: 30px;
  font-size: 32px;
  text-align: center;
}
.interview .block .cont {
  max-width: 850px;
  margin: 0 auto 70px;
  padding: 25px 4%;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 600;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  border: 2px solid #4c413a;
}
.interview .block .cont::after {
  content: "";
  position: absolute;
  top: -10px;
  left: -10px; 
  border-top: 3.6vw solid rgba(255,146,146,0.9);  /* 好みで高さ色を変えてください */ 
  border-right: 3.6vw solid transparent;
  z-index: -1;
}
.interview .block .cont::before {
  content: "";
  position: absolute;
  bottom: -10px;
  right: -10px; 
  border-bottom: 3.5vw solid rgba(255,146,146,1);  /* 好みで高さ色を変えてください */ 
  border-left: 3.5vw solid transparent;
  z-index: -1;
}
.interview .block .cont .imgBox {
  flex-basis: 20%;
  text-align: center;
}
.interview .block .cont .imgBox figure {
  width: 100%;
  display: block;
}
.interview .block .cont .imgBox figure img {
  image-rendering: -webkit-optimize-contrast;
}
.interview .block .cont .imgBox figure figcaption {
  font-size: 16px;
  color: #ff9292;
}
.interview .block .cont .imgBox figure figcaption span {
  display: block;
}
.interview .block .cont .txtBox {
  flex-basis: 75%
}
@media all and (-ms-high-contrast: none) {
  .interview .oneday dl dt::before {
    top: -5px;
  }
}
@media screen and (max-width:856px) {
  .interview .oneday {
    margin-bottom: 150px;
  }
  .interview .onedayTtl {
    width: 100%;
    margin: 50px auto 60px;
    padding: 0 0 20px;
    font-size: 25px;
  }
  .interview .onedayTtl::before {
    border: solid 10px transparent;
    border-top: solid 19px #4c413a;
  }
  .interview .onedayTtl::after {
    border: solid 10px transparent;
    border-top: solid 20px #fff;
  }
  .interview .oneday .flex {
    display: inherit;
  }
  .interview .oneday dl {
    width: 100%;
    margin: 0 auto 110px;
  }
  .interview .oneday dl::after {
    content: "\f078";
    top: inherit;
    left: 50%;
    right: inherit;
    bottom: -65px;
    transform: translate(-50%, 0);
  }
  .interview .oneday dl:nth-child(3), .interview .oneday dl:nth-child(5) {
    margin-right: auto;
  }
  .interview .oneday dl:nth-child(3)::after {
    content: "\f078";
  }
  .interview .oneday dl:nth-child(5)::after {
    content: "";
  }
  .interview .oneday dl dt {
    padding-left: 70px;
    font-size: 25px;
  }
  .interview .oneday dl dt::before {
    width: 45px;
    height: 45px;
    top: -2px;
  }
  .interview .oneday dl dt::after {
    font-size: 25px;
    top: 2px;
    left: 15px;
  }
  .interview .oneday dl dd {
    font-size: 16px;
  }
  .interview .oneday dl dd figcaption {
    margin-top: 20px;
  }

  .interview .block .blockTtl {
    font-size: 25px;
  }
  .interview .block .cont {
    padding: 35px 4%;
  }
  .interview .block .cont::after {
    border-top: 10vw solid rgba(255,146,146,0.9);
    border-right: 10vw solid transparent;
  }
  .interview .block .cont::before {
    border-bottom: 10vw solid rgba(255,146,146,1);
    border-left: 10vw solid transparent;
  }
  .interview .block .cont .imgBox {
    flex-basis: 25%;
  }

  .interview .block .cont .imgBox figure figcaption {
    font-size: 12px;
  }
  .interview .block .cont .txtBox {
    flex-basis: 65%
  }
}

/* =================================
 map
================================= */
.map .secWrap {
  padding-bottom: 160px;
}
.map .mapTtl {
  text-align: center;
  position: relative;
}
.map .mapTtl h2 {
  font-size: 32px;
  color: #2eb8b2;
  position: relative;
  display: inline-block;
}
.map .mapTtl div {
  margin-top: 40px;
  padding: 0 30px 30px;
  position: relative;
  display: inline-block;
  border-bottom: 2px solid #4c413a;
}
.map .mapTtl div::before, .map .mapTtl div::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.map .mapTtl div::before {
  border: solid 20px transparent;
  border-top: solid 38px #4c413a;
}
.map .mapTtl div::after {
  border: solid 20px transparent;
  border-top: solid 39px #f2efe2;
  margin-top: -5px;
}
.map .mapTtl p {
  font-size: 36px;
}
.map .mapTtl h2::before {
  height: 51px;
  content: "";
  position: absolute;
  display: block;
  top: 4px;
  left: -60px;
  border-left: 2px solid #4c413a;
  transform: rotate(-30deg);
}
.map .mapTtl h2::after {
  height: 51px;
  content: "";
  position: absolute;
  top: 4px;
  right: -60px;
  display: block;
  border-right: 2px solid #4c413a;
  transform: rotate(30deg);
}
.map .mapTtl h2 span::before {
  height: 46px;
  content: "";
  position: absolute;
  top: 8px;
  left: -45px;
  display: block;
  border-left: 2px solid #4c413a;
  transform: rotate(-30deg);
}
.map .mapTtl h2 span::after {
  height: 46px;
  content: "";
  display: block;
  position: absolute;
  top: 8px;
  right: -45px;
  border-right: 2px solid #4c413a;
  transform: rotate(30deg);
}

.map .img {
  width: 100%;
  position: relative;
}
.map .img img:first-child {
  width: 20%;
  max-width: 153px;
  height: 201px;
  vertical-align: middle;
  position: absolute;
  bottom: -85px;
  left: -36px;
  display: inline-block;
/*  background: url(../img/topimg01.png) no-repeat;*/
  background-size: contain;
}
.map .img img:last-child {
  width: 84px;
  height: 88px;
  vertical-align: middle;
  position: absolute;
  bottom: 7px;
  right: 20px;
  display: inline-block;
/*  background: url(../img/topimg02.png) no-repeat;*/
  background-size: contain;
}

.map .comment {
  width: 94%;
  margin: 40px auto 0;
  text-align: right;
}
.map .notice {
  margin-top: 30px;
  text-align: center;
  font-size: 35px;
}
.map .notice .important {
  font-size: 45px;
  color: #E60012;
}
.map .graph_block {
  margin-top: 85px;
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.map .graph_block picture {
  width: 100%;
}

.map .block {
  margin-top: 85px;
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
}
.map .block img {
  max-width: 100%;
}
.map .block .cont {
  margin-top: 40px;
  text-align: center;
  flex-basis: 45%;
}
.map .block .cont .area {
  font-size: 32px
}
.map .block .cont .sup {
  padding-left: 55px;
  font-size: 20px;
  position: relative;
  display: inline-block;
}
.map .block .cont .sup::before {
  width: 47px;
  height: 25px;
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  display: block;
  background: #fcacac;
}
.map .block .cont .imgBox {
  margin-top: 15px;
}
.map .desc {
  margin: 10px 2%;
  font-size: 26px;
  text-align: right;
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.map .desc .red .txt {
  position: relative;
}
.map .desc .gray .txt {
  margin-left: 110px;
  position: relative;
}
.map .memoWrap {
  margin-top: 1.5em;
}
.map .memo {
  font-size: 18px;
  display: block;
}
.map .desc .red .txt::before, .map .desc .gray .txt::before {
  width: 51px;
  height: 25px;
  content: "";
  position: absolute;
  top: 8px;
  left: -60px;
}
.map .desc .red .txt::before {
  background: #fcacac;
}
.map .desc .gray .txt::before {
  background: #e0dada;
}

.map .city {
  margin-top: 50px;
}
@media screen and (max-width:856px) {
  .map .secWrap {
    padding-bottom: 60px;
  }
  .map .mapTtl {
    max-width: 500px;
    margin: 0 auto;
  }
  .map .mapTtl h2 {
    font-size: 24px;
  }
  .map .mapTtl div {
    margin-top: 30px;
    padding: 0 0 20px;
  }
  .map .mapTtl div::before {
    border: solid 10px transparent;
    border-top: solid 19px #4c413a;
  }
  .map .mapTtl div::after {
    border: solid 10px transparent;
    border-top: solid 20px #f2efe2;
  }
  .map .mapTtl p {
    font-size: 25px;
  }
  .map .mapTtl h2::before {
    top: 9px;
  }
  .map .mapTtl h2::after {
    top: 9px;
  }
  .map .mapTtl h2 span::before {
    top: 13px;
  }
  .map .mapTtl h2 span::after {
    top: 13px;
  }

  .map .img img:first-child {
    width: 83px;
    height: 110px;
    bottom: -70px;
    left: -10px;
  }
  .map .img img:last-child {
    width: 49px;
    height: 52px;
    bottom: -17px;
    right: -10px;
  }

  .map .notice {
    font-size: 25px;
  }
  .map .notice .important {
    font-size: 30px;
  }
  .map .graph_block {
    margin-top: 30px;
  }

  .map .block {
    margin-top: 60px;
    display: inherit;
  }
  .map .block .cont {
    margin-top: 50px;
  }
  .map .block .cont .imgBox img {
    width: 100%;
  }
  
  .lb-container img {
    width: 100%;
  }
  .map .block .cont .area {
    font-size: 24px
  }
  .map .block .cont .sup {
    margin-top: 5px;
    padding-left: 40px;
    font-size: 16px;
  }
  .map .block .cont .sup::before {
    width: 35px;
    height: 20px;
    top: 3px;
  }
  .map .desc {
    margin: 10px 0 10px 13%;
    font-size: 16px;
    text-align: left;
    display: inherit;
  }
  .map .desc .gray .txt {
    margin-left: 0;
  }
  .map .desc + .sup, .map .desc + .sup + .sup {
    font-size: 14px;
    text-align: left;
  }
  .map .desc div {
    margin-top: 20px;
  }
  .map .memo {
    font-size: 15px;
    text-align: left;
    line-height: 1.6;
  }
  .map .desc .red .txt::before, .map .desc .gray .txt::before {
    width: 35px;
    height: 20px;
    top: 3px;
    left: -45px;
  }
}

/* =================================
 recruiting
================================= */
.recruiting .secWrap {
  padding-bottom: 160px;
}
.recruiting .mapTtl {
}
.recruiting .mapTtl h2 {
}
.recruiting .flex {
  margin-top: 80px;
  text-align: center;
  display: flex;
  justify-content: space-between;
}
.recruiting .flex dl {
  width: 48%;
  max-width: 478px;
  padding-top: 110px;
  position: relative;
  display: flex;
}
.recruiting .flex dl dt {
  width: 270px;
  margin: 0 auto;
  padding: 50px 0 0;
  font-size: 30px;
  line-height: 1.3;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  border-radius: 130px 130px 0 0;
  background: #f1eee1;
}
.recruiting .flex dl dd {
  padding: 40px 10px;
  font-size: 26px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: space-between;
  border-top: 50px solid #f1eee1;
  border-right: 37px solid #f1eee1;
  border-bottom: 40px solid #f1eee1;
  border-left: 37px solid #f1eee1;
  background: #fff;
}
.recruiting .flex dl dd .btn {
  width: 100%;
  height: 90px;
  margin-top: 25px;
  font-size: 30px;
  color: #fff;
  position: relative;
  display: flex;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 45px;
  border: 2px solid #2eb7b1;
  background: #2eb7b1;
}
.recruiting .flex dl dd .btn.twitter {
  font-size: 21px;
  border: 2px solid #0798f2;
  background: #0798f2;
}
.recruiting .flex dl dd .btn:hover {
  color: #2eb7b1;
  background: transparent;
}
.recruiting .flex dl dd .btn.twitter:hover {
  color: #0798f2;
}
.recruiting .flex dl dd .btn.corp span {
  padding-bottom: 2px;
}
.recruiting .flex dl dd .btn::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free",sans-serif;
  font-weight: 600;
  font-size: 30px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  right: 20px;
}
.recruiting .flex dl dd .btn.twitter::before {
  content: "\f099";
  font-family: "Font Awesome 5 Brands",sans-serif;
  font-weight: 600;
  font-size: 30px;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: 25px;
}
.recruiting .flex dl dd .btn span {
  -ms-flex: 1;
  flex: 1;
}

.recruiting .support {
  width: 86%;
  max-width: 875px;
  margin: 70px auto 0;
  padding: 30px;
  border: 3px dashed #4c413a;/*ここのボーダーなんとかする*/
  border-radius: 15px;
}
.recruiting .support dl {
  font-size: 30px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
.recruiting .support dl dd {
  width: 100%;
  margin-top: 30px;
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
}
.recruiting .support dl dd a {
  margin: 0 5px;
}
/*サポート企業の皆さまの*/
/*
.recruiting .support dl dd::after {
  content: '※順不同';
  font-size: 14px;
  position: absolute;
  right: 0;
  bottom: -14px;
}
*/
.recruiting .support dl dd a:hover {
  opacity: 0.6;
}
@media all and (-ms-high-contrast: none) {
  .recruiting .flex dl dd .btn {
    padding-top: 10px;
  }
}
@media screen and (max-width:856px) {
  .recruiting .secWrap {
    padding-bottom: 60px;
  }
  .recruiting .flex {
    margin-top: 40px;
    display: inherit;
  }
  .recruiting .flex dl {
    width: 100%;
    max-width: inherit;
  }
  .recruiting .flex dl dt {
    width: 190px;
    padding: 35px 0 0;
    font-size: 22px;
    top: 30px;
  }
  .recruiting .flex dl dd {
    padding: 25px 10px 15px;
    font-size: 18px;
    border-top: 25px solid #f1eee1;
    border-right: 19px solid #f1eee1;
    border-bottom: 20px solid #f1eee1;
    border-left: 19px solid #f1eee1;
  }
  .recruiting .flex dl dd .btn {
    height: 65px;
    font-size: 20px;
  }
  .recruiting .flex dl dd .btn.twitter {
    font-size: 16px;
  }
  .recruiting .flex dl dd .btn::after {
    font-size: 22px;
    right: 8px;
  }
  .recruiting .flex dl dd .btn.twitter::before {
    font-size: 22px;
    left: 15px;
  }

  .recruiting .support {
    width: 100%;
    padding: 25px 15px;
    border: 3px dashed #4c413a;/*ここのボーダーなんとかする*/
  }
  .recruiting .support dl {
  font-size: 25px;
  }
  .recruiting .support dl dd {
    width: 100%;
    margin-top: 15px;
    display: initial;
  }
  .recruiting .support dl dd a {
    margin: 10px auto;
    text-align: center;
    display: block;
  }
  .recruiting .support dl dd a img {
    max-width: 100%;
  }
}

/* =================================
 message
================================= */
.message .secWrap {
  padding-bottom: 160px;
}
.message .mapTtl {
}
.message .mapTtl h2 {
}
.message .flex {
  margin-top: 100px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  /* 3個になったらbetweenに変更 */
/*  justify-content: space-between;*/
}
.message .flex .block {
  width: 260px;
  margin-bottom: 60px;
}
.message .flex .block .img {
  width: 260px;
  height: 260px;
  line-height: 1;
  border-radius: 50%;
  overflow: hidden;
}
.message .flex .block img {
  max-width: 100%;
  height: auto;
}
.message .flex .block dl {
  margin-top: 25px;
  text-align: center;
}
.message .flex .block dl dt {
  font-size: 26px;
}
.message .flex .block dl dd {
  margin-top: 5px;
  font-size: 18px;
  line-height: 1.4;
}
.message .flex .block dl dd span {
  display: block;
}
.message .flex .block dl dd span.memo {
  margin-top: 5px;
}
.message .btn {
  margin-top: 100px;
  text-align: center;
  font-size: 22px;                  
}
.message .btn a {
  width: 304px;
  height: 70px;
  margin: 0 auto;
  line-height: 64px;
  display: block;
  background: #fff;
  border: 2px solid #4c413a;
  border-radius: 35px;
  position: relative;
}
.message .btn a::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free",sans-serif;
  font-weight: 600;
  font-size: 24px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  right: 20px;
}
.message .btn a:hover {
  background: transparent;
}
.message .crowd {
  margin-top: 100px;
  padding: 10px;
  background: #fff;
  /* border-radius: 20px; */
}
.message .crowd .inner {
  padding: 30px 45px;
  display: flex;
  border: 1px dashed #ccc;
}
.message .crowd .inner .ttl,
.message .crowd .inner .member {
  width: 50%;
}
.message .crowd .inner .ttl {
  padding-left: 120px;
  font-size: 20px;
  background: url(../img/img_crowdfunding1.svg) no-repeat;
  background-position: left center;
  background-size: 81px;
}
.message .crowd .inner .ttl a:hover {
  text-decoration: underline;
}
.message .crowd .inner .ttl span {
  color: #2EB8B2;
  font-size: 24px;
}
.message .crowd .inner .member dl dt {
  margin-bottom: 10px;
  padding: 5px 15px;
  color: #fff;
  font-size: 18px;
  background: #2EB8B2;
}
.message .crowd .inner .member dl dd {
  font-size: 16px;
}
.message .crowd .inner .member dl dd.txt {
  text-align: right;
}
@media all and (-ms-high-contrast: none) {
  .message .btn a {
    line-height: 72px;
  }
}
@media screen and (max-width:856px) {
  .message .secWrap {
    padding-bottom: 80px;
  }
  .message .flex {
    margin-top: 50px;
    flex-wrap: wrap;
  }
  .message .flex .block {
    width: 30%;
    margin-bottom: 50px
  }
  .message .flex .block .img {
    width: 100%;
    height: auto;
  }
  .message .flex .block dl {
    margin-top: 10px;
  }
  .message .flex .block dl dt {
    font-size: 14px;
  }
  .message .flex .block dl dd {
    font-size: 10px;
    line-height: 1.4;
  }
  .message .btn {
    margin-top: 10px;             
  }
  .message .btn a {
    width: 260px;
    height: 60px;
    font-size: 18px;
    line-height: 52px;
  }
  .message .btn a::after {
    font-size: 20px;
  }

  .message .crowd .inner {
    padding: 20px 10px;
    display: inherit;
  }
  .message .crowd .inner .ttl,
  .message .crowd .inner .member {
    width: 100%;
  }
  .message .crowd .inner .ttl {
    padding: 50px 0 15px 0;
    text-align: center;
    font-size: 18px;
    background-position: top center;
    background-size: 40px;
  }
  .message .crowd .inner .ttl span {
    font-size: 22px;
  }
}

/* =================================
 philosophy
================================= */
.philosophy .secWrap {
  padding-bottom: 160px;
}
.philosophy .mapTtl {
}
.philosophy .mapTtl h2 {
}
.philosophy .flex {
/*
  text-align: center;
  display: flex;
  justify-content: space-between;
*/
}
.philosophy .comment p {
  margin-top: 40px;
  font-size: 24px;
  text-align: center;
}
.philosophy .comment p span {
  font-size: 30px;
}

.philosophy .activity {
  width: 86%;
  max-width: 875px;
  margin: 70px auto 0;
  padding: 20px;
  border: 3px dashed #4c413a;/*ここのボーダーなんとかする*/
  border-radius: 15px;
}
.philosophy .activity dl {
  font-size: 28px;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-around;
  align-items: center;
}
.philosophy .activity dl dt {
}
.philosophy .activity dl dd {
  padding-left: 45px;
  border-left: 1px solid #4c413a;
}

.philosophy .director {
  width: 90%;
  max-width: 808px;
  margin: 70px auto 0;
  padding: 55px 70px;
  display: flex;
  justify-content: space-between;
  border-radius: 10px;
  background: #fff;
}
.philosophy .director .imgBox {
  width: 35%;
  max-width: 175px;
}
.philosophy .director .imgBox img {
  width: 100%;
}
.philosophy .director .txtBox {
  width: 63%;
  font-size: 18px;
}
.philosophy .director .txtBox .position {
}
.philosophy .director .txtBox .name {
  font-size: 28px;
}
.philosophy .director .txtBox .profile {
  margin-top: 20px;
}
@media all and (-ms-high-contrast: none) {
  .philosophy .activity dl dt {
    padding-top: 10px;
  }
  .philosophy .activity dl dd ol {
    margin-top: 10px;
  }
}
@media screen and (max-width:856px) {
  .philosophy .secWrap {
    padding-bottom: 60px;
  }
  .philosophy .comment p {
    margin-top: 35px;
    font-size: 16px;
    line-height: 1.7;
  }
  .philosophy .comment p span {
    font-size: 18px;
  }

  .philosophy .activity {
    width: 100%;
    max-width: 100%;
    padding: 25px 10px;
  }
  .philosophy .activity dl {
    font-size: 25px;
    text-align: center;
    display: inherit;
  }
  .philosophy .activity dl dd {
    padding-left: 0;
    font-size: 18px;
    border-left: none;
  }
  .philosophy .activity dl dd ol li {
    margin-top: 15px;
  }

  .philosophy .director {
    width: 100%;
    padding: 60px 6% 45px;
    display: inherit;
  }
  .philosophy .director .imgBox {
    width: 100%;
    margin: 0 auto 40px;
    text-align: center;
  }
  .philosophy .director .txtBox {
    width: 100%;
    font-size: 16px;
  }
  .philosophy .director .txtBox .position {
    font-size: 15px;
    text-align: center;
  }
  .philosophy .director .txtBox .name {
    font-size: 25px;
    text-align: center;
  }
.philosophy .director .txtBox .profile {
  margin-top: 20px;
}
}

/* =================================
 report
================================= */
.report .secWrap {
  padding-bottom: 160px;
}
.report .mapTtl {
}
.report .mapTtl h2 {
}
.report .block {
  margin-top: 110px;
/*
  display: flex;
  justify-content: space-between;
*/
}
.report .block .cont {
  width: 45%;
  max-width: 450px;
  height: 385px;
  margin: 0 auto; /* fb入れるときはこれを消して親をflexに */
}
.report .block .cont.tw iframe {
  border: 1px solid #efefef!important;
}
@media screen and (max-width:856px) {
  .report .secWrap {
    padding-bottom: 60px;
  }
  .report .block {
    margin-top: 50px;
    display: inherit;
  }
  .report .block .cont {
    width: 100%;
    height: 300px;
    margin: 0 auto;
  }
  .report .block .cont.tw {
    margin-bottom: 35px;
  }
}

/* =================================
 news
================================= */
.news .secWrap {
}
.news .mapTtl {
}
.news .mapTtl h2 {
}
.news .block ul {
  width: 94%;
  max-width: 680px;
  margin: 80px auto 0;
  font-size: 16px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 500;
  font-style: normal;
}
.news .block ul li {
  /* padding: 20px 30px 10px 0;  リンクをつけるときはここの上下を半分に */
  padding: 15px 0 15px 0;
  position: relative;
  border-bottom: 2px solid #4c413a;
  display: flex; /* リンクをつけるときはここをコメント */
  justify-content: space-between; /* リンクをつけるときはここをコメント */
  align-items: center;
}
.news .block ul li a {
  padding: 10px 5px;
  display: flex; /* リンクをつけるときはここをコメントはずす */
  justify-content: space-between; /* リンクをつけるときはここをコメントはずす */
}
.news .block ul li a .txt {
/*
    background-image: linear-gradient(#ffcffb, #ffcffb);
    background-size: 100% 50%;
    background-position: 0 100%;
    background-repeat: no-repeat;
*/
}

.news .block ul li a:hover .txt {
  background-size: 100% 50%;/*JSからクラスactiveを付与されたときに背景の幅を全体に広げる*/
  text-decoration: underline;
}
.news .block ul li .txt dt {
  padding-right: 30px;
  position: relative;
}
.news .block ul li.toggle dl dt::after {
  content: '\f078';
  font-family: 'Font Awesome 5 Free';
  font-weight: 600;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(0, -50%);
}
.news .block ul li.toggle.on dl dt::after {
  transform: translate(0, -50%) rotate(180deg);
}
.news .block ul li .day {
  width: 17%;
  align-self: stretch;
}
.news .block ul li .txt {
  width: 80%;
}

.news .block ul li dl dt .ico {
  margin-right: 15px;
  padding: 2px 10px;
  font-size: 14px;
  border-radius: 5px;
}
.news .block ul li dl dt .cat01 {
  background: #FFC0CB;
}
.news .block ul li dl dt .cat02 {
  background: #f9b523;
}
.news .block ul li dl dt .cat03 {
  background: #a7d9f8;
}
.news .block ul li dl dd {
  margin-top: 15px;
  padding: 15px;
  font-size: 15px;
  background: #f2efe2;
  border-radius: 10px;
  word-break: break-all;
  display: none;
}
.news .block ul li dl dd a {
  text-decoration: underline;
}

.news .sns {
  width: 130px;
  margin: 100px auto 50px;
  display: flex;
  justify-content: space-between;
}
.news .sns .ico {
  width: 43px;
  height: 43px;
}
.news .sns a {
  width: 43px;
  height: 43px;
  color: #fff;
  text-align: center;
  line-height: 43px;
  position: relative;
  display: block;
  border-radius: 50%;
  overflow: hidden;
}
.news .sns .tw a {
  font-size: 25px;
  background: #1d9aef;
}
.news .sns .fb a {
  font-size: 34px;
  background: #1877f1;
}
.news .sns .fb a i {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -35%);
}
.news .sns a:hover {
  opacity: 0.6;
}
@media screen and (max-width:856px) {
  .news .block ul {
    width: 100%;
    margin: 45px auto 0;
    font-size: 14px;
  }
  .news .block ul li {
    border-bottom: 1px solid #4c413a;
  }
  .news .block ul li a {
    padding: 10px 5px;
  }

  .news .block ul li .day {
    width: 17%;
    font-size: 12px;
  }
  .news .block ul li .txt {
    width: 73%;
  }
  
  .news .block ul li dl dt .ico {
    margin-right: 5px;
    padding: 2px 5px;
    font-size: 10px;
  }
  .news .block ul li dl dd {
    margin-top: 10px;
    padding: 10px;
    font-size: 14px;
    word-break: break-all;
    line-height: 1.6;
  }
  .news .block ul li dl dd a {
    padding: 10px 0;
    font-size: 10px
  }
  .news .sns {
    margin: 100px auto 20px;
  }
}

/* =================================
 organization
================================= */
.organization .secWrap {
}
.organization .mapTtl {
}
.organization .mapTtl h2 {
}
.organization .block {
  width: 65%;
  max-width: 680px;
  margin: 80px auto 0;
  padding: 10px;
  font-size: 16px;
/*
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 500;
  font-style: normal;
*/
  position: relative;
  background: #f9f8f2;
  filter: drop-shadow(0 3px 4px #ccc);
}
.organization .block::before {
  width: 100px;
  height: 30px;
  content: '';
  position: absolute;
  top: 0;
  left: -30px;
  background-color: rgba(255,255,255,.4);
  border-left:2px dotted rgba(0,0,0,.1);
  border-right:2px dotted rgba(0,0,0,.1);
  box-shadow:0 0 5px rgba(0,0,0,0.2);
  padding: 0.25em 2em;
  color: #65513f;
  transform: rotate(-30deg);
}
.organization .block::after {
  width: 100px;
  height: 30px;
  content: '';
  position: absolute;
  top: 0;
  right: -30px;
  background-color: rgba(255,255,255,.4);
  border-left:2px dotted rgba(0,0,0,.1);
  border-right:2px dotted rgba(0,0,0,.1);
  box-shadow:0 0 5px rgba(0,0,0,0.2);
  padding: 0.25em 2em;
  color: #65513f;
  transform: rotate(30deg);
}
.organization .block dl {
  padding: 30px 50px;
  display: flex;
  flex-wrap: wrap;
/*  border: 1px dotted #f2efe2;*/
}
.organization .block dl dt {
  width: 35%;
}
.organization .block dl dd {
  width: 65%;
}
.organization .block dl dt, .organization .block dl dd {
  padding: 20px 0 10px; /* リンクをつけるときはここを半分に */
}
.organization .block dl dd a:hover {
  opacity: 0.6;
}

@media all and (-ms-high-contrast: none) {
  .organization .block {
    box-shadow: 0 3px 4px #ccc;
  }
}
@media screen and (max-width:856px) {
  .organization .block {
    width: 100%;
    padding: 5px;
    font-size: 14px;
    transform: rotate(-3deg);
  }
  .organization .block::before {
    left: 50%;
    transform: rotate(-15deg) translate(-50%, -1.75em);
  }
  .organization .block::after {
    display: none;
  }
  .organization .block dl {
    padding: 30px 20px;
  }
}

/* =================================
 footer
================================= */
footer {
  padding: 15px;
  font-size: 12px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-weight: 500;
  font-style: normal;
  text-align: center;
}
@media screen and (max-width:856px) {
  footer {
    padding: 10px;
    font-size: 10px;
  }
}

/* =================================
 pagetop
================================= */
.pagetop a {
  width: 48px;
  height: 48px;
  font-size: 10px;
  color: #fff;
  text-align: center;
  position: fixed;
  right: 10px;
  bottom: -100px;
  display: block;
  border-radius: 5px;
  background: #4f4034;
}
.pagetop.fix a {
  bottom: 30px;
}
.pagetop a i {
  font-size: 30px;
  transform: translate(0,-1px);
}
.pagetop span {
  margin: 5px auto 0;
  display: inline-block;
  transform: scale(0.9);
}
@media screen and (max-width:856px) {
  .pagetop a {
  }
}

/* =================================
 次階層
================================= */
.page .pageTtl {
  width: 100%;
  height: 150px;
  padding: 40px;
  text-align: center;
  line-height: 1;
  background: #f2efe2;
}
.page .pageTtl h2 {
  font-size: 40px;
}
.page .pageTtl div {
  padding-top: 10px;
  font-size: 20px;
  color: #2eb7b1;
}

.page .bread {
  width: 1000px;
  margin: 20px auto;
  font-size: 16px;
}
.page .bread span {
  margin-right: 25px;
  position: relative;
}
.page .bread span::before {
  content: '>';
  position: absolute;
  top: 50%;
  left: -15px;
  transform: translate(0, -50%);
}
.page .bread span:first-child::before {
  content: '';
}
.page .bread a:hover {
  text-decoration: underline;
}
.page .catchTxt {
  widows: 100%;
  margin-top: 55px;
  text-align: center;
}
@media screen and (max-width:856px) {
  .page .pageTtl {
    height: 100px;
    margin-top: 50px;
    padding: 30px;
  }
  .page .pageTtl h2 {
    font-size: 22px;
  }
  .page .pageTtl div {
    padding-top: 0;
    font-size: 14px;
  }

  .page .bread {
    width: 94%;
    margin: 5px auto 0;
    font-size: 12px;
  }
  
  .page .catchTxt {
    width: 90%;
    margin: 35px auto 0;
    font-size: 14px;
    text-align: left;
    line-height: 1.79;
  }
}

/* =================================
 message 次階層
================================= */
#message .message .block {
  margin-bottom: 60px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
#message .message .block .img {
  width: 240px;
  height: 240px;
  border-radius: 50%;
  overflow: hidden;
}
#message .message .block .img img {
  max-width: 100%;
}
#message .message .block dl {
}
#message .message .block dl {
  width: calc(92% - 240px);
}
#message .message .block dl .name {
  font-size: 26px;
}
#message .message .block dl dd span {
  margin-left: 15px;
  font-size: 17px;
  color: #2eb7b1;
}
#message .message .block dl dd.txt {
  padding-top: 20px;
  font-size: 16px;
}
#message .btn.back a::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free",sans-serif;
  font-weight: 600;
  font-size: 24px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%) rotate(180deg);
  left: 20px;
}
@media screen and (max-width:856px) {
  #message .secWrap {
    padding-bottom: 150px;
  }
  #message .message .block {
    margin-bottom: 60px;
    display: inherit;
  }
  #message .message .block .img {
    width: 140px;
    height: 140px;
  }
  #message .message .block dl {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
  #message .message .block dl dd {
    width: calc(92% - 140px);
  }
  #message .message .block dl dd.txt {
    width: 100%;
  }
  #message .message .block dl .name {
    font-size: 22px;
  }
  #message .message .block dl dd span {
    margin-left: 0;
    font-size: 14px;
    display: block;
  }
  #message .message .block dl dd span:first-child {
    margin-top: 5px;
  }
  #message .btn.back a::after {
    font-size: 20px;
  }
  
  
}

/* 電子署名追加 */
.signature {
  margin-top: 4%;
  padding: 25px;
  border: 10px solid #f1eee1;
  display: flex;
  align-items: center;
}
.signature p {
  position: relative;
  vertical-align: middle;
  padding: 5px 20px 5px 140px;
}
.signature p::before {
  content: "";
  width: 110px;
  height: 110px;
  background: url(../img/ico_signature.svg) no-repeat center top;
  background-size: 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.btn-signature {
  width: 100%;
  max-width: 300px;
  height: 90px;
  font-size: 20px;
  line-height: 1.4;
  color: #fff;
  border-radius: 45px;
  border: 2px solid #2eb7b1;
  background-color: #2eb7b1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
}
.btn-signature::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free",sans-serif;
  font-weight: 600;
  font-size: 30px;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}

.btn-signature:hover {
  color: #2eb7b1;
  background: transparent;
}

@media screen and (max-width:856px) {
  .signature {
    display: block;
  }
  .signature p {
    padding: 100px 0 25px 0;
    text-align: center;
  }
  .signature p::before {
    width: 80px;
    height: 80px;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  .btn-signature {
    height: 65px;
    font-size: 18px;
    line-height: 1.2;
    margin-left: auto;
    margin-right: auto;
  }
  .btn-signature::after {
    font-size: 22px;
  }
}

/* 電子署名提出 */
.signature-submission {
  margin-top: 80px;
  text-align: center;
}
.signature-submission h2 {
  margin: 0 auto 20px;
  text-align: center;
  font-size: 25px;
  color: #2eb8b2;
  position: relative;
  display: inline-block;
}
.signature-submission h2::before {
  height: 51px;
  content: "";
  position: absolute;
  display: block;
  top: 15px;
  left: -60px;
  border-left: 2px solid #4c413a;
  transform: rotate(-30deg);
}
.signature-submission h2::after {
  height: 51px;
  content: "";
  position: absolute;
  top: 15px;
  right: -60px;
  display: block;
  border-right: 2px solid #4c413a;
  transform: rotate(30deg);
}
.signature-submission h2 span::before {
  height: 46px;
  content: "";
  position: absolute;
  top: 17px;
  left: -45px;
  display: block;
  border-left: 2px solid #4c413a;
  transform: rotate(-30deg);
}
.signature-submission h2 span::after {
  height: 46px;
  content: "";
  display: block;
  position: absolute;
  top: 17px;
  right: -45px;
  border-right: 2px solid #4c413a;
  transform: rotate(30deg);
}
.signature-submission figure figcaption {
  text-align: right;
}

@media screen and (max-width:856px) {
  .signature-submission h2 {
    font-size: 18px;
  }
  .signature-submission h2::before {
    top: 5px;
    left: -30px;
  }
  .signature-submission h2::after {
    top: 5px;
    right: -30px;
  }
  .signature-submission h2 span::before {
    top: 7px;
    left: -15px;
  }
  .signature-submission h2 span::after {
    top: 7px;
    right: -15px;
  }
}
