@charset "UTF-8";

/* --------------------------------------------------------- */
/* main 
------------------------------------------------------------ */

/* -----[ mainImage ]----- */

#mainImageBox {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  border-top: solid 1px #ded2c2;
  border-bottom: solid 1px #ded2c2;
  z-index: 1;
}
#mainImage {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: 185px;
  background-image: url(../img/img_main01-pc.jpg);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
}
#mainImage h2 {
  width: 88%;
  max-width: 980px;
  margin: 0 0 -44px 0;
}
@media only screen and (max-width: 760px) {
  #mainImageBox {
    border-top: none;
    border-bottom: none;
  }
  #mainImage {
    height: 150px;
    background-image: url(../img/img_main01-sp.jpg);
  }
  #mainImage h2 {
    margin: 0;
  }
}

/* globalnav */
#mainimageWrap .globalnav {
  position: relative;
  margin: 0 auto -45px auto;
  z-index: 2;
}
#mainimageWrap .globalnav ul li::after {
  height: 64.45%;
  border-color: #b9afa0;
}

/* -----[ contents ]----- */

#contentsWrap {
  padding: 20px 0 81px 0;
}
#contentsWrap #leftWrap {
  width: 25%;
  max-width: 240px;
}
#contentsWrap #rightWrap {
  width: 72%;
  max-width: 700px;
}
@media only screen and (max-width: 760px) {
  #contentsWrap {
    padding: 48px 0 80px 0;
  }
  #contentsWrap #leftWrap,
  #contentsWrap #rightWrap {
    width: 100%;
    max-width: none;
  }
  #contentsWrap #rightWrap {
    margin: 0 0 63px 0;
  }
}

/* breadcrumb */
#contentsWrap #breadcrumb {
  margin: 0 0 20px 0;
}
#contentsWrap #breadcrumb ul {
  margin: -3px;
  font-size: 0;
}
#contentsWrap #breadcrumb ul li {
  position: relative;
  display: inline-block;
  margin: 3px;
  padding: 0 15px 0 0;
  font-size: 1.5rem;
}
#contentsWrap #breadcrumb ul li::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  display: block;
  width: 8px;
  height: 9px;
  background-image: url(../img/ico_crumb.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
#contentsWrap #breadcrumb ul li:last-child {
  padding: 0;
}
#contentsWrap #breadcrumb ul li:last-child::after {
  display: none;
}
#contentsWrap #breadcrumb ul li a {
  text-decoration: underline;
}

/* set */
#contentsWrap .set {
  margin: 0 0 50px 0;
}
#contentsWrap .set:last-child {
  margin: 0;
}
#contentsWrap .set::after {
  content: '';
  display: block;
  clear: both;
}
#contentsWrap .set .leftSet {
  float: left;
}
#contentsWrap .set .rightSet {
  float: right;
}
#contentsWrap .set h4 {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.34;
  color: #7bb200;
}
#contentsWrap .set h5 {
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
  color: #ff7e00;
}
#contentsWrap .set .table table tr {
  border-bottom: dotted 1px #b5afa2;
}
#contentsWrap .set .table table tr:last-child {
  border-bottom: none;
}
#contentsWrap .set .table table tr th,
#contentsWrap .set .table table tr td {
  padding: 10px;
  text-align: center;
  vertical-align: middle;
  background: #fff;
  border-right: dotted 1px #b5afa2;
}
#contentsWrap .set .table table tr th:last-child,
#contentsWrap .set .table table tr td:last-child {
  border-right: none;
}
#contentsWrap .set .large {
  font-size: 1.8rem;
  line-height: 1.34;
}
#contentsWrap .set .small {
  font-size: 1.3rem;
  line-height: 1.84;
}
#contentsWrap .set .bold {
  font-weight: bold;
}
#contentsWrap .set .left {
  text-align: left;
}
#contentsWrap .set .right {
  text-align: right;
}
#contentsWrap .set .center {
  text-align: center;
}
#contentsWrap .set .orange {
  color: #fa7c01;
}
#contentsWrap .set .green {
  color: #7bb200;
}
@media only screen and (max-width: 760px) {
  #contentsWrap .set {
    margin: 0 0 79px 0;
  }
  #contentsWrap .set .table {
    overflow-x: scroll;
  }
  #contentsWrap .set .table table {
    width: 100%;
  }
  #contentsWrap .set .large {
    font-size: 1.6rem;
    line-height: 1.44;
  }
  #contentsWrap .set .small {
    font-size: 1.2rem;
    line-height: 1.98;
  }
}

/* menu */
#contentsWrap #menu {
  margin: 0 0 22px 0;
  padding: 18px 17px 13px 17px;
  background: #fff;
  background-image: url(../img/common/bac_menu.jpg);
  background-repeat: no-repeat;
  background-position: bottom right;
  background-size: 116px auto;
  border-radius: 5px;
}
#contentsWrap #menu h3 {
  margin: 0 0 11px 0;
}
#contentsWrap #menu ul li {
  border-bottom: dotted 1px #836b5c;
}
#contentsWrap #menu ul li:last-child {
  border-bottom: none;
}
#contentsWrap #menu ul li a {
  position: relative;
  padding: 7px 0 9px 22px;
  text-decoration: underline;
}
#contentsWrap #menu ul li a::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 6px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  display: block;
  width: 4px;
  height: 7px;
  background-image: url(../img/common/ico_arrow.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* sideInquiry */
#contentsWrap .sideInquiry {
  padding: 17px 16px 17px 14px;
}
#contentsWrap .sideInquiry h3 {
  margin: 0 0 12px 0;
  padding: 0 0 12px 0;
}
#contentsWrap .sideInquiry p {
  margin: 0 0 6px 0;
  padding: 0 11px;
  font-size: 1.4rem;
}
#contentsWrap .sideInquiry ul li {
  margin: 0 0 14px 0;
}
#contentsWrap .sideInquiry ul li:last-child {
  margin: 0;
}
@media only screen and (max-width: 760px) {
  #contentsWrap .sideInquiry {
    padding: 20px 18px 18px 17px;
  }
  #contentsWrap .sideInquiry h3 {
    margin: 0 0 22px 0;
    padding: 0 0 18px 0;
  }
  #contentsWrap .sideInquiry p {
    margin: 0 0 29px 0;
    padding: 0 8px;
    font-size: 1.6rem;
    line-height: 1.75;
  }
  #contentsWrap .sideInquiry ul li {
    margin: 0 0 24px 0;
  }
}

/* --------------------------------------------------------- */
/* page 
------------------------------------------------------------ */

/* -----[ courses, kienergy ]----- */

.courses #contentsWrap .set h3,
.kienergy #contentsWrap .set h3 {
  margin: 0 0 24px 0;
}
.courses #contentsWrap .set .leftSet,
.kienergy #contentsWrap .set .leftSet {
  width: 27%;
  max-width: 185px;
}
.courses #contentsWrap .set .leftSet p,
.kienergy #contentsWrap .set .leftSet p {
  margin: 0 0 10px 0;
}
.courses #contentsWrap .set .leftSet p:last-child,
.kienergy #contentsWrap .set .leftSet p:last-child {
  margin: 0;
}
.courses #contentsWrap .set .leftSet ul,
.kienergy #contentsWrap .set .leftSet ul {
  margin: -5px;
  font-size: 0;
}
.courses #contentsWrap .set .leftSet ul li,
.kienergy #contentsWrap .set .leftSet ul li {
  display: inline-block;
  width: 93px;
  margin: 5px;
}
.courses #contentsWrap .set .rightSet,
.kienergy #contentsWrap .set .rightSet {
  width: 70%;
  max-width: 490px;
}
.courses #contentsWrap .set .rightSet h4,
.kienergy #contentsWrap .set .rightSet h4 {
  margin: 0 0 12px 0;
}
.courses #contentsWrap .set .rightSet .txt,
.kienergy #contentsWrap .set .rightSet .txt {
  margin: 0 0 23px 0;
}
.courses #contentsWrap .set .rightSet dl,
.kienergy #contentsWrap .set .rightSet dl {
  position: relative;
  padding: 22px 20px 25px 77px;
  background: #fff;
}
.courses #contentsWrap .set .rightSet dl dt,
.kienergy #contentsWrap .set .rightSet dl dt {
  position: absolute;
  top: -14px;
  left: -11px;
  width: 79px;
  height: auto;
  z-index: 2;
}
.courses #contentsWrap .set .rightSet dl dd,
.kienergy #contentsWrap .set .rightSet dl dd {
  position: relative;
  z-index: 1;
}
.courses #contentsWrap .set .rightSet dl dd ul li,
.kienergy #contentsWrap .set .rightSet dl dd ul li {
  margin: 0 0 6px 0;
  padding: 0 5px 6px 5px;
  font-size: 1.4rem;
  border-bottom: dotted 1px #836b5c;
}
.courses #contentsWrap .set .rightSet dl dd ul li:last-child,
.kienergy #contentsWrap .set .rightSet dl dd ul li:last-child {
  margin: 0;
}
@media only screen and (max-width: 760px) {
  .courses #contentsWrap .set h3,
  .kienergy #contentsWrap .set h3 {
    margin: 0 0 33px 0;
  }
  .courses #contentsWrap .set .leftSet,
  .kienergy #contentsWrap .set .leftSet,
  .courses #contentsWrap .set .rightSet,
  .kienergy #contentsWrap .set .rightSet {
    width: 100%;
    max-width: none;
  }
  .courses #contentsWrap .set .leftSet,
  .kienergy #contentsWrap .set .leftSet {
    margin: 0 0 25px 0;
  }
  .courses #contentsWrap .set .leftSet p,
  .kienergy #contentsWrap .set .leftSet p {
    margin: 0 0 16px 0;
  }
  .courses #contentsWrap .set .leftSet ul li,
  .kienergy #contentsWrap .set .leftSet ul li {
    width: 129px;
  }
  .courses #contentsWrap .set .rightSet h4,
  .kienergy #contentsWrap .set .rightSet h4 {
    margin: 0 0 19px 0;
  }
  .courses #contentsWrap .set .rightSet .txt,
  .kienergy #contentsWrap .set .rightSet .txt {
    margin: 0 0 36px 0;
  }
}

/* -----[ guide ]----- */

.guide #contentsWrap .set h3 {
  margin: 0 0 24px 0;
}
.guide #contentsWrap .set h4 {
  margin: -0.3em 0 7px 0;
  line-height: 1.6;
}
.guide #contentsWrap .set h5 {
  margin: 0 0 8px 0;
}
.guide #contentsWrap .set .txt {
  margin: 0 0 24px 0;
  padding: 0 20px 0 0px;
  font-size: 1.5rem;
  line-height: 1.5;
}
.guide #contentsWrap .set ul {
  margin: 0 0 7px 0;
}
.guide #contentsWrap .set ul li {
  position: relative;
  margin: 0 0 7px 0;
  padding: 0 0 0 27px;
  font-size: 1.5rem;
  line-height: 1.5;
}
.guide #contentsWrap .set ul li:last-child {
  margin: 0;
}
.guide #contentsWrap .set ul li::after {
  content: '';
  position: absolute;
  top: calc(1.5em / 2);
  left: 12px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  display: block;
  width: 4px;
  height: 7px;
  background: url(../img/common/ico_arrow.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.guide #contentsWrap .set .table table tr:nth-child(2n) th,
.guide #contentsWrap .set .table table tr:nth-child(2n) td {
  background: #fcfcf8;
}
.guide #contentsWrap .set .table.table01 {
  margin: 0 0 22px 0;
}
.guide #contentsWrap .set .table.table01:last-child {
  margin: 0;
}
.guide #contentsWrap .set .table.table01 table tr th {
  width: 115px;
}
.guide #contentsWrap .set .table.table01 table tr td {
  width: 324px;
}
.guide #contentsWrap .set .table.table01 table tr td:last-child {
  width: 211px;
}
.guide #contentsWrap .set .table.table02 {
  margin: 0 0 20px 0;
}
.guide #contentsWrap .set .table.table02:last-child {
  margin: 0;
}
.guide #contentsWrap .set .table.table02 table tr th {
  width: 290px;
}
.guide #contentsWrap .set .table.table02 table tr td {
  width: 350px;
}
.guide #contentsWrap .set .a_inquiry::after {
  content: '';
  display: block;
  clear: both;
}
.guide #contentsWrap .set .a_inquiry p {
  float: left;
}
.guide #contentsWrap .set .a_inquiry p.c_inuiry {
  width: 30.37%;
  max-width: 198px;
}
.guide #contentsWrap .set .a_inquiry p.tel {
  width: 27.61%;
  max-width: 180px;
}
.guide #contentsWrap .set .a_inquiry p.mail {
  width: 42.02%;
  max-width: 274px;
}
@media only screen and (max-width: 760px) {
  .guide #contentsWrap .set h3 {
    margin: 0 0 33px 0;
  }
  .guide #contentsWrap .set h4 {
    margin: -0.3em 0 11px 0;
  }
  .guide #contentsWrap .set h5 {
    margin: 0 0 13px 0;
  }
  .guide #contentsWrap .set .txt {
    margin: 0 0 38px 0;
    padding: 0;
  }
  .guide #contentsWrap .set ul {
    margin: 0 0 11px 0;
  }
  .guide #contentsWrap .set .table.table01 {
    margin: 0 0 35px 0;
  }
  .guide #contentsWrap .set .table.table01 table tr th {
    width: 18%;
    min-width: 115px;
  }
  .guide #contentsWrap .set .table.table01 table tr td {
    width: 50%;
    min-width: 324px;
  }
  .guide #contentsWrap .set .table.table01 table tr td:last-child {
    width: 32%;
    min-width: 211px;
  }
  .guide #contentsWrap .set .table.table02 {
    margin: 0 0 32px 0;
  }
  .guide #contentsWrap .set .table.table02 table tr th {
    width: 45%;
    min-width: 290px;
  }
  .guide #contentsWrap .set .table.table02 table tr td {
    width: 55%;
    min-width: 350px;
  }
  .guide #contentsWrap .set .a_inquiry p.c_inuiry {
    width: 100%;
    max-width: none;
  }
  .guide #contentsWrap .set .a_inquiry p.tel {
    width: 39.09%;
    max-width: none;
  }
  .guide #contentsWrap .set .a_inquiry p.mail {
    width: 60.91%;
    max-width: none;
  }
}

/* -----[ overview ]----- */

.overview #contentsWrap .set h3 {
  margin: 0 0 24px 0;
}
.overview #contentsWrap .set .table table tr th {
  background: #f7f7ea;
  border-right: solid 4px #accf61;
}
.overview #contentsWrap .set .table table tr td {
  padding: 10px 20px;
  text-align: left;
}
.overview #contentsWrap .set .table.table01 table tr th {
  width: 102px;
}
.overview #contentsWrap .set .table.table01 table tr td {
  width: 478px;
}
.overview #contentsWrap .set .table.table02 table tr th {
  width: 102px;
}
.overview #contentsWrap .set .table.table02 table tr td {
  width: 478px;
}
.overview #contentsWrap .set .read {
  margin: 0 0 20px 0;
  padding: 0 20px;
}
.overview #contentsWrap .set .read .txt {
  margin: 0 0 18px 0;
}
.overview #contentsWrap .set .read .img {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -13px;
}
.overview #contentsWrap .set .read .img p {
  width: 41.69%;
  padding: 13px;
}
.overview #contentsWrap .set .read2 {
  padding: 0 20px;
}
.overview #contentsWrap .set .read2::after {
  content: '';
  display: block;
  clear: both;
}
.overview #contentsWrap .set .read2 ul {
  float: left;
  width: 50%;
  max-width: 300px;
}
.overview #contentsWrap .set .read2 ul li dl {
  font-size: 0;
}
.overview #contentsWrap .set .read2 ul li dl dt,
.overview #contentsWrap .set .read2 ul li dl dd {
  display: inline-block;
  vertical-align: top;
  font-size: 1.5rem;
}
.overview #contentsWrap .set .read2 ul li dl dd {
  padding: 0 0 0 2em;
}
.overview #contentsWrap .set .read2 ul li dl dd ul {
  float: none;
  width: auto;
  max-width: none;
}
@media only screen and (max-width: 760px) {
  .overview #contentsWrap .set h3 {
    margin: 0 0 33px 0;
  }
  .overview #contentsWrap .set .table.table01 table tr th {
    width: 18%;
    min-width: 102px;
  }
  .overview #contentsWrap .set .table.table01 table tr td {
    width: 82%;
    min-width: 478px;
  }
  .overview #contentsWrap .set .table.table02 table tr th {
    width: 18%;
    min-width: 102px;
  }
  .overview #contentsWrap .set .table.table02 table tr td {
    width: 82%;
    min-width: 228px;
  }
  .overview #contentsWrap .set .read {
    margin: 0 0 32px 0;
    padding: 0;
  }
  .overview #contentsWrap .set .read .txt {
    margin: 0 0 28px 0;
  }
  .overview #contentsWrap .set .read .img {
    margin: -16px;
  }
  .overview #contentsWrap .set .read .img p {
    width: 100%;
    padding: 16px;
  }
  .overview #contentsWrap .set .read2 {
    padding: 0;
  }
  .overview #contentsWrap .set .read2 ul {
    width: 100%;
    max-width: none;
  }
}

/* -----[ philosophy ]----- */

.philosophy #contentsWrap .set h3 {
  margin: 0 0 24px 0;
}
.philosophy #contentsWrap .set .read {
  padding: 0 30px 0 20px;
}
@media only screen and (max-width: 760px) {
  .philosophy #contentsWrap .set h3 {
    margin: 0 0 33px 0;
  }
  .philosophy #contentsWrap .set .read {
    padding: 0;
  }
}

/* -----[ sitemap ]----- */

.sitemap #contentsWrap {
  padding: 20px 0 101px 0;
}
.sitemap #contentsWrap .set h3 {
  margin: 0 0 24px 0;
}
.sitemap #contentsWrap .set .read {
  padding: 0 20px 0 10px;
}
.sitemap #contentsWrap .set .read a {
  display: inline;
}
.sitemap #contentsWrap .set .read p {
  margin: 0 0 20px 0;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
}
.sitemap #contentsWrap .set .read .set02 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -10px -10px calc(-10px + 20px) -10px;
}
.sitemap #contentsWrap .set .read .set02 dl {
  width: 33.33%;
  padding: 10px;
}
.sitemap #contentsWrap .set .read .set02 dl dt {
  margin: 0 0 3px 0;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
}
.sitemap #contentsWrap .set .read .set02 dl dd {
  padding: 0 8px;
}
.sitemap #contentsWrap .set .read .set02 dl dd a {
  color: #51463f;
}
.sitemap #contentsWrap .set .read .set02 dl dd a:hover {
  color: #988578;
}
.sitemap #contentsWrap .set .read ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -10px;
}
.sitemap #contentsWrap .set .read ul li {
  width: 33.33%;
  padding: 10px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
}
@media only screen and (max-width: 760px) {
  .sitemap #contentsWrap {
    padding: 48px 0 80px 0;
  }
  .sitemap #contentsWrap .set h3 {
    margin: 0 0 33px 0;
  }
  .sitemap #contentsWrap .set .read {
    padding: 0;
  }
  .sitemap #contentsWrap .set .read p {
    margin: 0 0 32px 0;
  }
  .sitemap #contentsWrap .set .read .set02 {
    margin: -10px -10px calc(-10px + 32px) -10px;
  }
  .sitemap #contentsWrap .set .read .set02 dl {
    width: 100%;
  }
  .sitemap #contentsWrap .set .read ul li {
    width: 100%;
  }
}

/* -----[ inquiry ]----- */

.inquiry #contentsWrap {
  padding: 20px 0 101px 0;
}
.inquiry #contentsWrap .set h3 {
  margin: 0 0 24px 0;
}
.inquiry #contentsWrap .set .read {
  padding: 0 20px;
}
.inquiry #contentsWrap .set .read .img {
  margin: 0 0 20px 0;
}
.inquiry #contentsWrap .set .read .img img {
  max-width: 352px;
}
.inquiry #contentsWrap .set .read .table {
  margin: 0 0 20px 0;
}
.inquiry #contentsWrap .set .read .table table tr th {
  width: 212px;
  background: #f7f7ea;
  border-right: solid 4px #accf61;
}
.inquiry #contentsWrap .set .read .table table tr td {
  width: 418px;
  padding: 10px 20px;
}
@media only screen and (max-width: 760px) {
  .inquiry #contentsWrap {
    padding: 48px 0 80px 0;
  }
  .inquiry #contentsWrap .set h3 {
    margin: 0 0 33px 0;
  }
  .inquiry #contentsWrap .set .read {
    padding: 0;
  }
  .inquiry #contentsWrap .set .read .img {
    margin: 0 0 40px 0;
    text-align: center;
  }
  .inquiry #contentsWrap .set .read .img img {
    max-width: 271px;
  }
  .inquiry #contentsWrap .set .read .table {
    margin: 0 0 32px 0;
    overflow-x: visible;
  }
  .inquiry #contentsWrap .set .read .table table {
    display: block;
    width: auto;
  }
  .inquiry #contentsWrap .set .read .table table tbody {
    display: block;
  }
  .inquiry #contentsWrap .set .read .table table tr {
    display: block;
    margin: 0 0 24px 0;
    border-bottom: none;
  }
  .inquiry #contentsWrap .set .read .table table tr:last-child {
    margin: 0;
  }
  .inquiry #contentsWrap .set .read .table table tr th {
    display: block;
    width: 100%;
    font-size: 1.8rem;
    border-bottom: solid 4px #accf61;
    border-right: none;
  }
  .inquiry #contentsWrap .set .read .table table tr td {
    display: block;
    width: 100%;
    padding: 14px 16px;
  }
}