@charset "UTF-8";
/*------------------------------------------- */
/* common */
/*------------------------------------------- */
/* ========================================
  common
=========================================== */
.contents {
  margin: 0 10px 10px;
  padding: 10px;
  border-radius: 5px;
  background: #fff; }

.contents .head {
  margin: 0 0 10px;
  padding: 10px 10px 8px;
  border-radius: 5px;
  border: 1px solid #e95899;
  color: #e95899;
  font-size: 25.6px;
  font-size: 1.6rem;
  font-weight: normal;
  text-align: center;
  letter-spacing: 0.1em; }

.contents .subhead {
  margin: 0 0 10px;
  padding: 7px 5px 5px;
  border-radius: 5px;
  background: #e95899;
  color: #fff;
  font-size: 32px;
  font-size: 2rem;
  font-weight: normal;
  text-align: center;
  letter-spacing: 0.1em; }

.contents .text {
  margin: 0 0 20px;
  line-height: 1.8; }

.contents .text p {
  text-indent: 1em; }

.contents .text p.noIndent {
  text-indent: 0; }

.contents .text p span {
  color: #e95899; }

.contents figure {
  margin: 10px 0; }

/*------------------------------------------- */
/* experience */
/*------------------------------------------- */
.contents ul {
  margin: 0 0 0 16px; }

.contents ul li {
  color: #e95899; }

.contents dl {
  margin: 0 0 20px; }

.contents dl dt {
  margin: 0 0 5px;
  color: #e95899;
  font-size: 24px;
  font-size: 1.5rem; }

.contents .link {
  position: relative;
  margin: 0 0 10px;
  padding: 12px 15px 10px;
  border-radius: 5px;
  background: #a671a7;
  color: #fff;
  font-size: 25.6px;
  font-size: 1.6rem;
  letter-spacing: 0.1em; }

.contents .link:after {
  position: absolute;
  top: 50%;
  right: 20px;
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg) translateY(-50%);
          transform: rotate(45deg) translateY(-50%); }

/*------------------------------------------- */
/* business description */
/*------------------------------------------- */
.contents .business div:last-child {
  margin: 0; }

/*------------------------------------------- */
/* counseilng room */
/*------------------------------------------- */
.leadBox .head {
  line-height: 1.4; }

.leadBox .lead {
  font-size: 19.2px;
  font-size: 1.2rem;
  text-align: center;
  line-height: 1.4; }

.faqArea {
  margin: 0 10px 10px; }

.faqArea dl {
  margin: 0 0 10px; }

.faqArea dl dt {
  position: relative;
  margin: 0 0 10px;
  padding: 12px 50px 10px;
  border-radius: 5px;
  background: #e95899 url(img/ico_question.png) no-repeat 15px 50%;
  background-size: 20px;
  color: #fff; }

.faqArea dl dt:before {
  position: absolute;
  top: 50%;
  right: 10px;
  content: "";
  width: 20px;
  height: 20px;
  border: 1px solid #fff;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%); }

.faqArea dl dt:after {
  position: absolute;
  top: 50%;
  right: 13px;
  content: "＋";
  margin-top: -10px}

.faqArea dl dt.active:after {
  top: 50%;
  right: 15px;
  content: "−";
  margin-top: -10px; }

.faqArea dl dd {
  display: none;
  padding: 10px 15px;
  border-radius: 5px;
  background: #fff; }

.faqArea dl dd .text {
  padding: 0 0 0 50px;
  background: url(img/ico_answer.png) no-repeat 0 50%;
  background-size: 26px; }

.faqArea dl dd .text p {
  margin: 0 0 15px; }

.faqArea dl dd .text a {
  position: relative;
  padding: 0 20px 0 0;
  color: #e95899;
  text-decoration: underline;
  text-align: right; }

.faqArea dl dd .text a:after {
  position: absolute;
  top: 50%;
  right: 15px;
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1px solid #e95899;
  border-right: 1px solid #e95899;
  -webkit-transform: rotate(45deg) translateY(-50%);
          transform: rotate(45deg) translateY(-50%); }

.faqArea dl dd .faqClose {
  margin: 20px 0 0;
  padding: 10px 0 0;
  border-top: 1px solid #e6e6e6;
  color: #999;
  font-size: 25.6px;
  font-size: 1.6rem;
  text-align: center; }

.faqArea article:nth-of-type(odd) dl dt {
  background: #cb5087 url(img/ico_question.png) no-repeat 15px 50%;
  background-size: 20px; }

/*------------------------------------------- */
/* dictionary */
/*------------------------------------------- */
.lineList {
  margin: 0 10px 10px; }

.lineList ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }

.lineList ul li {
  width: calc((100% - 20px) / 5);
  height: 40px;
  margin: 0 0 5px; }

.lineList ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  border-radius: 5px;
  background: #e95899;
  color: #fff;
  font-size: 25.6px;
  font-size: 1.6rem; }

.lineList ul li a span {
  padding: 0 0 0 5px;
  font-size: 19.2px;
  font-size: 1.2rem; }

.lineList ul li a.current {
  border: 1px solid #e95899;
  background: #fff;
  color: #e95899; }

.lineBox {
  border: 1px solid #e95899; }

.lineBox .subhead {
  margin: 0 0 20px;
  padding: 7px 15px 5px;
  text-align: left; }

.lineBox .subhead span {
  padding: 0 0 0 5px;
  font-size: 25.6px;
  font-size: 1.6rem; }

.lineBox dl dt {
  margin: 0 0 10px;
  padding: 2px 0 0 8px;
  border-left: 2px solid #e95899;
  font-size: 28.8px;
  font-size: 1.8rem;
  line-height: 1.2; }

.lineBox dl dd {
  margin: 0 0 0 10px; }

.lineBox .linkArea {
  padding: 20px 0 0;
  border-top: 1px solid #e95899;
  overflow: hidden; }

.lineBox .linkArea .lineLink {
  width: 50%; }

.lineBox .linkArea .lineLink a {
  position: relative;
  color: #e95899;
  font-size: 28.8px;
  font-size: 1.8rem;
  text-decoration: underline; }

.lineBox .linkArea .lineLink a:before {
  position: absolute;
  top: 0;
  content: "";
  width: 26px;
  height: 26px;
  border-radius: 100%;
  background: #e95899; }

.lineBox .linkArea .lineLink a:after {
  position: absolute;
  top: 50%;
  content: "";
  width: 8px;
  height: 8px;
  margin-top: -5px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg); }

.lineBox .linkArea .lineLink.back {
  float: left; }

.lineBox .linkArea .lineLink.back a {
  padding: 0 0 0 40px; }

.lineBox .linkArea .lineLink.back a:before {
  left: 0; }

.lineBox .linkArea .lineLink.back a:after {
  left: 11px;
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg); }

.lineBox .linkArea .lineLink.next {
  float: right; }

.lineBox .linkArea .lineLink.next a {
  padding: 0 40px 0 0;
  text-align: right; }

.lineBox .linkArea .lineLink.next a:before {
  right: 0; }

.lineBox .linkArea .lineLink.next a:after {
  right: 11px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg); }

/*------------------------------------------- */
/* method */
/*------------------------------------------- */
.method .mainLead {
  margin: 0 0 5px;
  color: #e95899;
  font-size: 32px;
  font-size: 2rem;
  text-align: center; }

.method .lead {
  margin: 0 0 10px;
  text-align: center; }

.method .check {
  margin: 0 0 20px;
  padding: 7px 5px 5px;
  border-radius: 5px;
  border: 1px solid #e95899;
  color: #e95899;
  font-size: 28.8px;
  font-size: 1.8rem;
  text-align: center; }

.method .inPageLink {
  margin: 0 0 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.2); }

.method .inPageLink p {
  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;
  width: 50%;
  height: 50px;
  padding: 10px;
  border: 1px solid #e95899;
  background: #fdedf4; }

.method .inPageLink p:last-of-type {
  border-left: none; }

.method .inPageLink p img {
  width: auto;
  height: 20px; }

.method article:first-of-type {
  margin: 0 0 20px; }

.method article h3 {
  margin: 0 0 20px;
  padding: 20px 0 0;
  text-align: center; }

.method article h3 span {
  display: inline-block;
  position: relative; }

.method article h3 span:before {
  position: absolute;
  top: 50%;
  left: -50px;
  content: "";
  width: 43px;
  height: 12px;
  background: url(img/bg_leaf_f.png) no-repeat 0 0;
  background-size: cover;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%); }

.method article h3 span:after {
  position: absolute;
  top: 50%;
  right: -50px;
  content: "";
  width: 43px;
  height: 12px;
  background: url(img/bg_leaf_b.png) no-repeat 0 0;
  background-size: cover;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%); }

.method article h3 span img {
  width: auto;
  height: 18px; }

.method article .point {
  margin: 0 0 10px;
  padding: 10px 10px 8px;
  border-radius: 5px;
  background: #e95899;
  color: #fff;
  font-size: 25.6px;
  font-size: 1.6rem;
  font-weight: normal;
  text-align: center; }

.method article .item {
  margin: 0 0 10px;
  padding: 10px 10px 8px;
  border-radius: 5px;
  border: 1px solid #e95899;
  background: linear-gradient(rgba(233, 88, 153, 0), rgba(233, 88, 153, 0.2));
  color: #e95899;
  font-size: 25.6px;
  font-size: 1.6rem;
  font-weight: normal;
  text-align: center; }

/*------------------------------------------- */
/* policy */
/*------------------------------------------- */
.policy .contents {
  padding: 20px;
  border: 1px solid #ccc; }

.policy .contents dt {
  margin: 0 0 10px;
  color: #333;
  font-size: 22.4px;
  font-size: 1.4rem;
  font-weight: bold; }

.policy .contents dd {
  margin: 0 0 15px; }

.policy .contents dd.last {
  margin: 0 0 30px; }

.policy .contents dd a {
  display: inline;
  color: #666; }

.policy .contents dd span {
  font-size: 19.2px;
  font-size: 1.2rem; }