@charset "utf-8";

/*--------------------------------------------------------------
# Common
--------------------------------------------------------------*/


/* ---------------
 RESET
--------------- */

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: none;
  font-weight: normal;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote {
  margin: 30px 0px;
  padding: 0 30px 20px 30px;
  background-color: #fcfcfc;
}

blockquote:before {
  content: "“";
  font-weight: bold;
  font-size: 500%;
  display: block;
  height: auto;
  color: #ccc;
  margin: 0 0 -40px -40px
}

blockquote:after {
  content: "”";
  text-align: right;
  float: right;
  height: auto;
  font-weight: bold;
  font-size: 500%;
  color: #ccc;
  display: block;
  margin: 0 -40px 0 0
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: none;
}


/* change colours to suit your needs */

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}


/* change colours to suit your needs */

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}


/* change border colour to suit your needs */

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}


/* --------------------
 HTML5
-------------------- */

article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
  display: block;
}


/* --------------------
 DEFAULT
-------------------- */


/* GLOBAL */

* {
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
  overflow-y: scroll;
}


/* BODY */

body {
  margin: 0;
  color: #2C333D;
  font-size: 14px;
  line-height: 1.5;
  height: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
}


/* HEADLINE */

h1, h2, h3, h4, h5, h6 {
  margin: 0;
}

:root *>h1, h2, h3, h4, h5, h6 {
  line-height: 1;
}


/* P */

p {
  line-height: 1.5;
}


/* LIST */

ol, ul, li {
  line-height: 1.5;
  list-style-type: none;
}


/* IMG */

img {
  border: 0;
  vertical-align: bottom;
}


/* TABLE */

table {
  border-collapse: collapse;
  border-spacing: 0;
}


/* A */

a {
  color: #3385BF;
  outline: none;
  overflow: hidden;
  text-decoration: none;
}

a:hover {
  color: #3385BF;
  text-decoration: underline;
}


/*--------------------------------------------------------------
# Layout
--------------------------------------------------------------*/


/* ----------------
 MISC CLASS
---------------- */


/* CF */

.cf:before, .cf:after {
  content: "";
  display: block;
  overflow: hidden;
}

.cf:after {
  clear: both;
}

.cf {
  zoom: 1;
}

.inner {
  width: 960px;
  margin: 0 auto;
}

.hide {
  display: none;
}

.show-mobile {
  display: none;
}

.hide-mobile {
  display: block;
}

/* 全ページ共通部分 START */


/* ----------------
 HEADER INTRO
---------------- */

.header-intro-copy {
  text-align: right;
  font-size: 11px;
  color: #999;
  padding: 8px 0;
  font-weight: normal;
}

/* ----------------
 PATH
---------------- */
.path {
  width: 960px;
  margin: 0 auto;
  overflow: hidden;
  padding: 10px 0;
}
.path li {
  float: left;
  margin-right: 5px;
  font-size: 11px;
}
.path li a {
  margin-right: 5px;
}

/* ----------------
 SECTION
---------------- */
section {
  font-size: 14px;
}
.layout_sub-contents {
  padding: 0;
}

/* ----------------
 FOOT SERVICE
---------------- */
.layout_footer-service-navi {
  padding: 32px 0;
  border-top: 1px solid #C8D8E3;
}

.footer-service-box {
  float: left;
  width: 239px;
  border-left: 1px solid #C8D8E3;
  text-align: center;
  padding: 20px;
}

.footer-service-box.end {
  width: 238px;
  border-right: 1px solid #C8D8E3;
}

.footer-service-box a {
  text-decoration: none;
  display: block;
}

.footer-service-box a:hover {
  opacity: 0.75;
}

.footer-service-name {
  color: #6EAC41;
  font-size: 16px;
  font-weight: normal;
  padding: 15px 0 10px 0;
}

.footer-service-text {
  text-align: left;
  color: #2D333D;
  line-height: 1.4;
  font-size: 13px;
}

/* ----------------
 CONTACT INFO
---------------- */
.layout_contact-info {
  background-size: 100% auto;
  padding: 32px 0 32px 0;
  color: #fff;
}

.btn_tc-start a {
  background: #E56761;
  color: #fff;
}

.btn_tc-contact a,
.btn_tc-price a,
.btn_tc-start a,
.btn_tc-outline a {
  position: relative;
  text-decoration: none;
  display: block;
  font-weight: normal;
  text-decoration: none !important;
  line-height: 1.2;
  box-shadow: 2px 2px 8px 1px rgba(0, 0, 0, .15);
  border-radius: 3px;
}

.btn_tc-price a {
  background: #6A89BD;
  color: #fff;
}

.btn_tc-contact a {
  background: #fdb23a;
  color: #515963;
}

.btn_tc-outline a {
  background-color: #fff;
  color: #515963;
  border: solid 1px #515963;
}

.layout_contact-info-btn {
  margin: 0 auto 0;
}

.layout_contact-info-btn-l {
  float: right;
}

.layout_contact-links-btn-l-1col {
  padding: 25px 0px 0px 0px;
}

.layout_contact-links-btn-r-1col {
  float: right;
  padding: 25px 0px 0px 0px;
}

.layout_contact-links-btn-l-2col {
  float: left;
  padding: 20px 0px 8px 0px;
}

.layout_contact-links-btn-r-2col {
  float: right;
  padding: 20px 0px 8px 0px;
}

.layout_contact_links {
  padding: 20px 0px 0px 0px;
}

.layout_contact_links .col1 {
  width: 560px;
  margin: auto;
}

.layout_contact_links .col1 .btn_tc-outline a {
  margin: 0 auto;
}

.layout_contact_links .col2 {
  width: 530px;
  margin: auto;
}

.btn_tc-contact,
.btn_tc-price,
.btn_tc-start {
  float: left;
}

 .btn_tc-contact a {
  width: 210px;
  margin: 0 40px 0 0;
} 

.btn_tc-contact a:hover {
  background: #e99c22;
}

.btn_tc-price a,
.btn_tc-outline a {
  width: 210px;
}

.btn_tc-price a:hover {
  background: #4d70aa;
}

.btn_tc-start a {
  width: 170px;
}

.btn_tc-start a:hover {
  background: #DD3931;
}

.btn_tc-outline a:hover {
  background-color: #e5e5e5;
}

.btn_tc-contact a,
.btn_tc-price a,
.btn_tc-start a,
.btn_tc-outline a {
  line-height: 1.2;
  padding: 20px 25px;
  font-size: 16px;
  text-align: center;
}


/* サブページ共通部分 START */
/* ----------------
 SUB CONTENTS TITLE
---------------- */
.layout_sub-contents-title {
  height: 90px;
  background: #58a466;
  background: -webkit-linear-gradient(top, #94c05d 0%, #72b27e 100%);
  background: linear-gradient(to top, #94c05d 0%, #72b27e 100%);
  color: #fff;
}
.layout_sub-contents-title-inner {
  padding: 30px 0 0 0;
}
.sub-contents-title {
  font-size: 26px;
  display: inline-block;
  padding: 0 30px 0 0;
  text-shadow: 1px 1px 1px #549C61;
  vertical-align: middle;
  font-weight: normal;
}
.sub-contents-description {
  font-size: 14px;
  display: inline-block;
  vertical-align: middle;
}

/* ----------------
 SUB CONTENTS BODY
---------------- */
.layout_sub-contents-body {
  padding: 0;
  position: relative;
}

@media screen and (min-width: 960px) {
  body {
    min-width: 960px;
  }
}


/* 959px以下の指定 */
@media screen and (max-width: 959px) {
  /* 959px以下非表示 */
  .hide-pc-max {
    display: none;
  }
  .entry-content img {
    max-width: 100%;
  }

/* ----------------
    FOOT SERVICE
  ---------------- */
  .layout_footer-service-navi {
    padding: 0;
    border-top: 1px solid #000;
  }

  .footer-service-navi {
    margin: 0;
    width: auto;
  }

  .footer-service-box {
    float: left;
    width: 50%;
    border-left: none;
    text-align: center;
    padding: 0;
  }

  .footer-service-box.end {
    width: 50%;
    border: none;
  }

  .footer-service-box a {
    display: block;
    position: relative;
  }

  .footer-service-box a:hover {
    opacity: 0.75;
  }

  .footer-service-text,
  .footer-service-img {
    display: none;
  }

  .footer-service-name {
    display: block;
    padding: 15px 15px 15px 25px;
    color: #2C333D;
    font-size: 16px;
    font-weight: normal;
    padding: 15px 15px 15px 25px;
    font-size: 14px;
    text-align: left;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
  }

  .sla .footer-service-name,
  .flow .footer-service-name {
    border-right: none;
  }

  .footer-service-name:before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 7px;
    height: 7px;
    margin: -6px 0 0 7px;
    border-top: solid 2px #515963;
    border-right: solid 2px #515963;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transform-origin: 50% 50% 0px;
    -ms-transform-origin: 50% 50% 0px;
    transform-origin: 50% 50% 0px;
  }
    
 .layout_footer-service-navi {
    padding: 0;
    border-top: 1px solid #000;
  }
  .footer-service-navi {
    margin: 0;
    width: auto;
  }
  .footer-service-box {
    float: left;
    width: 50%;
    border-left: none;
    text-align: center;
    padding: 0;
  }
  .footer-service-box.end {
    width: 50%;
    border: none;
  }
  .footer-service-box a {
    display: block;
    position: relative;
  }
  .footer-service-box a:hover {
    filter: alpha(opacity=75);
    -moz-opacity: 0.75;
    opacity: 0.75;
  }
  .footer-service-text, .footer-service-img {
    display: none;
  }
  .footer-service-name {
    display: block;
    padding: 15px 15px 15px 25px;
    color: #2C333D;
    font-size: 16px;
    font-weight: normal;
    padding: 15px 15px 15px 25px;
    font-size: 14px;
    text-align: left;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
  }
  .sla .footer-service-name, .support .footer-service-name {
    border-right: none;
  }
  .footer-service-name:before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 7px;
    height: 7px;
    margin: -6px 0 0 7px;
    border-top: solid 2px #515963;
    border-right: solid 2px #515963;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  } 

/* ----------------
    CONTACT INFO
  ---------------- */
  .layout_contact-info-btn {
    width: auto;
    margin: 0 15px;
    padding: 0 0 0 0;
  }

  .layout_contact-info-btn-l {
    float: none;
    width: auto;
    padding: 10px 0 5px 0;
  }

  .layout_contact-info-btn-r {
    float: none;
    width: auto;
    padding: 10px 15px 20px 0;
    border-right: none;
  }

  .btn_tc-start {
    float: none;
  }

  .btn_tc-start a {
    width: auto;
    padding: 16px 15px;
    font-size: 15px;
    text-align: center;
  }

  .btn_tc-price {
    float: right;
    width: 50%;
    margin-right: 15px;
  }

  .btn_tc-contact {
    float: right;
    width: 50%;
    margin-right: -15px;
  }

  .btn_tc-price a,
  .btn_tc-contact a {
    width: auto;
    text-align: left;
    line-height: 1.2;
    padding: 8px;
    font-size: 13px;
    margin: auto;
  }

  .btn_tc-contact a:after,
  .btn_tc-price a:after,
  .btn_tc-start a:after {
    right: 10px;
  }
  
  /* ----------------
   SUB CONTENTS TITLE
  ---------------- */
  .layout_sub-contents {
    padding: 0;
  }
  .layout_sub-contents-title {
    width: auto;
    height: 50px;
    background: #58a466;
    background: -webkit-linear-gradient(top, #94c05d 0%, #72b27e 100%);
    background: linear-gradient(to top, #94c05d 0%, #72b27e 100%);
  }
  .layout_sub-contents-title-inner {
    width: auto;
    padding: 14px 0 0 0;
    text-align: center;
  }
  .sub-contents-title {
    font-size: 18px;
    text-align: center;
    padding: 0;
    text-shadow: 1px 1px 1px #549C61;
  }
  .sub-contents-description {
    display: none;
  }
  .show-mobile {
    display: block;
  }
  .hide-mobile {
    display: none;
  }
}


/* 779px以下の指定 */

@media only screen and (max-width: 779px) {
  /* 全ページ共通部分 START */
  body {
    display: block;
    overflow: visible;
  }
  .layout_sub-contents {
    width: 100%;
    position: relative;
  }
  /* ----------------
	 SECTION
	---------------- */
  /* 全ページ共通部分 END */
  /* サブページ共通部分 START */
  /* ----------------
   SUB CONTENTS BODY
  ---------------- */
  .layout_sub-contents-body {
    width: auto;
    margin: 0;
    padding: 0;
  }
  /* サブページ共通部分 END */
  /* AdminBar調整 */
  html #wpadminbar {
    position: fixed;
  }
  body.admin-bar .layout_sub-contents {
    margin-top: 0;
  }
}