@charset "UTF-8";
/* ----------------------------------------------
 base
---------------------------------------------- */
html {
  font-size: 62.5%;
  /*基準が16pxの場合、10px*/ }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "游ゴシック Medium", "メイリオ", Meiryo, sans-serif;
  color: #333333;
  background-color: #ffffff;
  margin: 0;
  padding: 0; }

h1, h2, h3, h4, h5, h6, p, pre, ul, li, img, dl, dt, dd, blockquote, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  vertical-align: baseline; }

img {
  margin: 0;
  padding: 0;
  vertical-align: bottom; }

p, h1, h2, h3, h4, h5, h6 {
  margin: 30px 0 0 0;
  padding: 0;
  font-size: 1.6rem;
  letter-spacing: 0.05rem;
  line-height: 2.0; }

ul {
  margin: 25px 0 0 0;
  padding: 0;
  list-style-type: none; }
  ul li {
    margin: 15px 0 0 0;
    padding: 0;
    font-size: 1.6rem;
    line-height: 1.5; }
  ul li:first-child {
    margin: 0 0 0 0; }

ol {
  margin: 25px 0 0 0; }
  ol li {
    margin: 15px 0 0 0;
    padding: 0;
    font-size: 1.6rem;
    line-height: 1.5; }
  ol li:first-child {
    margin: 0 0 0 0; }

em {
  color: #eb6100;
  font-style: normal; }

table {
  margin: 40px 0 0 0;
  border-width: 0;
  padding: 0;
  empty-cells: show;
  border-top: 1px solid #cfcfcf;
  width: 100%; }

caption {
  font-size: 1.4em;
  text-align: left;
  padding: 0 0 8px 0;
  margin: 0;
  color: #666666;
  letter-spacing: 0.1rem;
  line-height: 1.5; }
  caption span {
    padding: 5px 15px;
    background-color: #145e98;
    color: #fff; }

th {
  font-weight: normal;
  text-align: center;
  margin: 0;
  padding: 12px;
  font-size: 1.5rem;
  letter-spacing: 0.05rem;
  line-height: 1.5;
  border-bottom: 1px solid #cfcfcf;
  vertical-align: top; }

th.m {
  vertical-align: middle; }

td {
  margin: 0;
  padding: 12px;
  font-size: 1.5rem;
  letter-spacing: 0.05rem;
  line-height: 1.5;
  border-bottom: 1px solid #cfcfcf;
  vertical-align: top; }

td.c {
  text-align: center; }

button, input, select, textarea {
  font: inherit; }

select {
  border: 1px solid #c0c0c0;
  font-size: 100%; }

input[type=text], textarea {
  background: #ffffff;
  padding: 5px;
  border: 1px solid #c0c0c0;
  color: #000000; }

input[type=text]:focus, textarea:focus {
  background: #fffde8; }

a:link {
  color: #508700;
  text-decoration: none; }

a:visited {
  color: #508700;
  text-decoration: none; }

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

a:active {
  color: #508700;
  text-decoration: underline; }

a:hover img {
  opacity: 0.8;
  -webkit-transition: opacity 0.1s;
  -moz-transition: opacity 0.1s;
  transition: opacity 0.1s; }

@media screen and (max-width: 600px) {
  img {
    max-width: 100%;
    height: auto; }
  input[type=text], textarea {
    max-width: 50vw; } }

/* ----------------------------------------------
 utility
---------------------------------------------- */
.u_mg_0 {
  margin-top: 0; }

.u_mg_5 {
  margin-top: 5px; }

.u_mg_10 {
  margin-top: 10px; }

.u_mg_15 {
  margin-top: 15px; }

.u_mg_60 {
  margin-top: 60px; }

.u_align_r {
  text-align: right; }

.u_align_c {
  text-align: center; }

/* vertical-align - utility
--------------------------------------------------------- */
/* border-none */
/* ----------------------------------------------
 component
---------------------------------------------- */
.h_lg {
  font-size: 2.6em;
  line-height: 1.0;
  font-weight: normal;
  margin: 60px 0 0 0;
  padding: 25px 30px;
  color: #508700;
  background: url("../imgs/common/well_bg.jpg") top left repeat; }
  @media screen and (max-width: 600px) {
    .h_lg {
      font-size: 2.2em;
      margin: 50px 0 0 0; } }

.h_md {
  font-size: 2.0em;
  font-weight: normal;
  color: #508700;
  margin: 60px 0 0 0;
  padding: 2px 0 1px 12px;
  line-height: 1.2;
  border-left: 3px solid #508700; }
  @media screen and (max-width: 600px) {
    .h_md {
      font-size: 1.8em;
      margin: 50px 0 0 0; } }

.h_sm {
  font-size: 1.6em;
  font-weight: bold;
  margin: 45px 0 0 0; }

ul.list_circle li {
  padding: 0 0 0 35px;
  background: url("../imgs/common/icon_circle.svg") 15px 9px no-repeat;
  background-size: 6px; }

ul.list_check li {
  padding: 0 0 0 30px;
  background: url("../imgs/common/icon_check.svg") 5px 7px no-repeat;
  background-size: 15px; }

.container {
  margin: 60px 0 0 0;
  padding: 0 40px; }
  @media screen and (max-width: 600px) {
    .container {
      padding: 0 30px; } }

.container_wide {
  margin: 60px 0 0 0;
  padding: 0; }

.container_line {
  margin: 60px 0 0 0;
  padding: 60px 40px 0 40px;
  border-top: 1px solid #e3e3e3; }
  @media screen and (max-width: 600px) {
    .container_line {
      margin: 50px 0 0 0;
      padding: 50px 30px 0 30px; } }

.container h2:first-child, .container h3:first-child, .container p:first-child, .container_wide h2:first-child, .container_wide h3:first-child, .container_wide p:first-child, .container_line h2:first-child, .container_line h3:first-child, .container_line p:first-child {
  margin-top: 0; }

.well {
  margin: 30px auto 0 auto;
  padding: 40px;
  width: 700px;
  background: url("../imgs/common/well_bg.jpg") top left repeat;
  -moz-border-radius: 10px;
  /* 旧Firefox */
  -webkit-border-radius: 10px;
  /* 旧Safari,旧Chrome */
  border-radius: 10px;
  /* CSS3 */ }
  @media screen and (max-width: 600px) {
    .well {
      width: auto; } }

.well_wh {
  margin: 40px auto 0 auto;
  padding: 0;
  width: 780px; }
  @media screen and (max-width: 600px) {
    .well_wh {
      width: auto; } }

.well ul:first-child, .well ol:first-child, .well table:first-child, .well_wh ul:first-child, .well_wh ol:first-child, .well_wh table:first-child {
  margin-top: 0; }

.text_caption {
  margin: 10px 0 0 0;
  font-size: 1.3em;
  color: #666666; }

a.button_green {
  display: inline-block;
  width: 33%;
  margin: 0 auto;
  padding: 15px 20px;
  border: 1px solid #92bb02;
  color: #ffffff;
  background: #92bb02 url("../imgs/common/icon_arrow_white.svg") 95% 51% no-repeat;
  background-size: 9px; }
  @media screen and (max-width: 600px) {
    a.button_green {
      width: 75%; } }
  a.button_green:hover {
    border: 1px solid #508700;
    background: #ffffff url("../imgs/common/icon_arrow_green.svg") 95% 51% no-repeat;
    background-size: 9px;
    color: #508700;
    text-decoration: none; }

a.button_gray {
  display: inline-block;
  width: 33%;
  margin: 0 auto;
  padding: 15px 20px;
  border: 1px solid #aaa;
  color: #ffffff;
  background: #aaa url("../imgs/common/icon_arrow_back_white.svg") 5% 51% no-repeat;
  background-size: 9px; }
  @media screen and (max-width: 600px) {
    a.button_gray {
      width: 75%; } }
  a.button_gray:hover {
    border: 1px solid #aaa;
    background: #ffffff url("../imgs/common/icon_arrow_back_gray.svg") 5% 51% no-repeat;
    background-size: 9px;
    color: #888;
    text-decoration: none; }

a.button_green_back {
  display: inline-block;
  width: 33%;
  margin: 0 auto;
  padding: 15px 20px;
  border: 1px solid #92bb02;
  color: #ffffff;
  background: #92bb02 url("../imgs/common/icon_arrow_back_white.svg") 5% 51% no-repeat;
  background-size: 9px; }
  @media screen and (max-width: 600px) {
    a.button_green_back {
      width: 75%; } }
  a.button_green_back:hover {
    border: 1px solid #508700;
    background: #ffffff url("../imgs/common/icon_arrow_back_gray.svg") 5% 51% no-repeat;
    background-size: 9px;
    color: #508700;
    text-decoration: none; }

/* ----------------------------------------------
 layout
---------------------------------------------- */
.wrapper {
  width: auto; }

#site_header {
  width: 100%; }

#main_content {
  width: 1000px;
  margin: 0 auto; }
  @media screen and (max-width: 600px) {
    #main_content {
      width: auto; } }

#site_footer {
  width: 100%;
  margin: 100px 0 0 0; }
  @media screen and (max-width: 600px) {
    #site_footer {
      margin: 80px 0 0 0; } }

.header_line {
  border-bottom: 1px solid #e3e3e3; }
  .header_line .inner {
    width: 1000px;
    margin: 0 auto;
    padding: 0; }
    .header_line .inner:after {
      content: "";
      display: block;
      clear: both; }
  .header_line p {
    margin: 0;
    padding: 8px 0 8px 0;
    font-size: 1.2rem;
    line-height: 1;
    color: #666666; }
  .header_line .desc {
    float: left; }
  .header_line .header_info {
    float: right; }
    .header_line .header_info ul {
      margin: 0;
      padding: 0; }
    .header_line .header_info li {
      margin: 0 0 0 1em;
      padding: 0;
      display: inline-block;
      font-size: 1.2rem;
      line-height: 1;
      color: #666666; }
      .header_line .header_info li a {
        padding: 8px 16px 8px 16px;
        display: block;
        background-color: #eeeeee;
        color: #666666; }
      .header_line .header_info li a:hover {
        color: #a0a0a0; }
    .header_line .header_info li.contact_sp {
      display: none; }
  @media screen and (max-width: 600px) {
    .header_line .inner {
      width: auto; }
    .header_line p {
      padding: 8px 0 8px 8px;
      font-size: 1.1rem; }
    .header_line .header_info li {
      font-size: 1.1rem; }
    .header_line .header_info li.access {
      display: none; }
    .header_line .header_info li.contact_sp {
      display: block; }
      .header_line .header_info li.contact_sp a {
        color: #fff;
        padding: 8px 10px 8px 10px;
        background-color: #eb6100; }
      .header_line .header_info li.contact_sp a:hover {
        background-color: #f38f35;
        text-decoration: none; } }

.header_body {
  width: 1000px;
  margin: 0 auto; }
  .header_body:after {
    content: "";
    display: block;
    clear: both; }
  .header_body .site_logo {
    width: 190px;
    height: 30px;
    float: left;
    margin: 25px 0 25px 0;
    padding: 0; }
  .header_body .gnav {
    width: 810px;
    float: right;
    margin: 21px 0 0 0; }
    .header_body .gnav > ul {
      margin: 0;
      padding: 0;
      display: flex;
      flex-direction: row;
      justify-content: flex-end; }
      .header_body .gnav > ul li {
        margin: 0 0 0 3px;
        padding: 0;
        line-height: 1; }
        .header_body .gnav > ul li img {
          height: 16px;
          padding-bottom: 4px; }
        .header_body .gnav > ul li a, .header_body .gnav > ul li span {
          display: block;
          padding: 10px 10px 5px 10px; }
        .header_body .gnav > ul li a:hover img {
          border-bottom: 1px solid #508700;
          opacity: 1; }
      .header_body .gnav > ul li.selected a img {
        border-bottom: 1px solid #508700; }
      .header_body .gnav > ul li.contact {
        margin: 0 0 0 15px; }
        .header_body .gnav > ul li.contact img {
          padding-bottom: 0;
          border-bottom: 0; }
        .header_body .gnav > ul li.contact a {
          padding: 10px 10px 10px 36px;
          background: #eb6100 url("../imgs/common/icon_contact.svg") 13px 13px no-repeat;
          background-size: 15px; }
        .header_body .gnav > ul li.contact a:hover {
          background-color: #f38f35; }
          .header_body .gnav > ul li.contact a:hover img {
            border-bottom: 0; }
      .header_body .gnav > ul li.dropdown:hover {
        background-color: #508700; }
        .header_body .gnav > ul li.dropdown:hover span img {
          border-bottom: 1px solid #508700; }
      .header_body .gnav > ul li.dropdown.selected span img {
        border-bottom: 1px solid #508700; }
      .header_body .gnav > ul li.dropdown.selected .menu a img {
        border-bottom: 0; }
      .header_body .gnav > ul li.dropdown.selected .menu .selected a img {
        opacity: 0.6;
        border-bottom: 0; }
      .header_body .gnav > ul .menu {
        margin: 0;
        padding: 0;
        position: absolute;
        width: 210px;
        /* Hiding */
        max-height: 0;
        overflow: hidden;
        background-color: #508700; }
        .header_body .gnav > ul .menu ul {
          margin: 0;
          padding: 5px 0 5px 0;
          display: block; }
          .header_body .gnav > ul .menu ul a {
            padding: 8px 10px 8px 10px; }
          .header_body .gnav > ul .menu ul img {
            height: 14px;
            width: auto;
            padding: 0;
            border-bottom: 0; }
          .header_body .gnav > ul .menu ul a:hover img {
            opacity: 0.6;
            border-bottom: 0; }
      .header_body .gnav > ul li.dropdown.active .menu {
        max-height: 200px; }
  @media screen and (max-width: 600px) {
    .header_body {
      width: auto; }
      .header_body .site_logo {
        float: none;
        margin: 25px auto 20px auto; }
      .header_body .gnav {
        width: auto;
        float: none;
        margin: 0;
        padding: 0 10px; }
        .header_body .gnav > ul {
          flex-wrap: wrap;
          justify-content: center; }
          .header_body .gnav > ul li img {
            height: 15px;
            padding-bottom: 1px; }
          .header_body .gnav > ul li a, .header_body .gnav > ul li span {
            display: block;
            padding: 10px 10px 5px 10px; }
          .header_body .gnav > ul li a:hover img {
            padding-bottom: 0;
            border-bottom: 1px solid #508700;
            opacity: 1; }
          .header_body .gnav > ul li.dropdown:hover span img {
            border-bottom: 0; }
          .header_body .gnav > ul li.dropdown.selected span img {
            border-bottom: 1px solid #508700; }
          .header_body .gnav > ul li.contact {
            display: none; } }

.no-svg .header_body .site_logo {
  background: url("../imgs/common/site_logo_alt.png") top left no-repeat; }

.top_image {
  height: 360px;
  background: #ebebeb url("../imgs/home/top_image.jpg") top left no-repeat;
  background-size: cover; }
  .top_image .inner {
    height: 360px;
    width: 1000px;
    margin: 0 auto;
    background: url("../imgs/home/top_image_bg.png") bottom left no-repeat;
    background-size: 1000px; }
  .top_image p {
    margin: 0;
    padding: 110px 0 0 0;
    text-align: center; }
  @media screen and (max-width: 600px) {
    .top_image {
      margin-top: 20px;
      height: 50vw;
      background-position: right top; }
      .top_image .inner {
        height: 50vw;
        width: 100%;
        background-size: 100%; }
        .top_image .inner p {
          padding: 14vw 0 0 0; }
        .top_image .inner img {
          width: 85%;
          height: auto; } }

.page_title {
  background: #f2ece4 url("../imgs/common/page_title_bg.jpg") top right no-repeat; }
  .page_title .inner {
    width: 1000px;
    margin: 0 auto; }
  .page_title h2 {
    margin: 0 0 0 3px;
    padding: 50px 0;
    text-align: center;
    font-size: 2.4em;
    color: #000000;
    font-weight: normal; }
  @media screen and (max-width: 600px) {
    .page_title {
      margin-top: 20px;
      background-position: 30% 0; }
      .page_title .inner {
        width: 100%; }
      .page_title h2 {
        padding: 50px 20px; } }

.home_lead {
  margin: 40px 0 0 0;
  padding: 0 40px; }
  .home_lead h2 {
    font-size: 2.4em;
    font-weight: normal;
    margin: 40px 0 0 0;
    padding: 0;
    color: #508700;
    text-align: center; }
  .home_lead p {
    margin: 15px 0 0 0;
    text-align: center; }
  .home_lead p.btn {
    margin: 50px 0 0 0;
    text-align: center; }
  .home_lead .home_photo_books {
    margin: 60px 0 0 0;
    padding: 0; }
  @media screen and (max-width: 600px) {
    .home_lead {
      padding: 0 30px; } }

.home_menu:after {
  content: "";
  display: block;
  clear: both; }

.home_menu ul {
  margin: 0 0 0 -12px;
  padding: 0; }
  .home_menu ul li {
    margin: 12px 0 0 12px;
    padding: 0;
    float: left; }

.h_lg_features {
  font-size: 2.6em;
  text-align: center;
  line-height: 1.0;
  font-weight: normal;
  margin: 60px 0 0 0;
  padding: 0 0 10px 0; }
  @media screen and (max-width: 600px) {
    .h_lg_features {
      margin: 50px 0 0 0; } }

.assist_others {
  margin: 30px 0 0 -10px;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap; }
  .assist_others .box {
    width: 415px;
    background-color: #e0ecf6;
    margin: 10px 0 0 10px;
    padding: 20px; }
    .assist_others .box h5 {
      font-size: 1.6em;
      margin: 0;
      color: #145e98; }
    .assist_others .box p {
      font-size: 1.5em;
      line-height: 1.5;
      margin: 15px 0 0 0; }
    .assist_others .box table {
      margin-top: 20px; }

.about_greeting {
  margin: 30px 0 0 0; }
  .about_greeting:after {
    content: "";
    display: block;
    clear: both; }
  .about_greeting .col {
    float: left;
    width: 430px;
    margin: 0 0 0 60px; }
  .about_greeting .col:first-child {
    margin: 0; }
  @media screen and (max-width: 600px) {
    .about_greeting .col {
      float: none;
      width: auto;
      margin: 60px 0 0 0; }
    .about_greeting .col:first-child {
      margin: 0; } }

.map {
  margin: 40px 0 20px 0; }

.works_container {
  margin: 30px 0 0 0;
  padding: 30px;
  border: 1px solid #e3e3e3; }
  .works_container:after {
    content: "";
    display: block;
    clear: both; }
  .works_container ul {
    margin: 0; }
  .works_container .text {
    float: left;
    width: 55%; }
  .works_container .book {
    float: right;
    width: 40%; }
    .works_container .book p {
      text-align: center; }

.works_list ul {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: 30px 0 0 -9px;
  padding: 0; }
  .works_list ul li {
    margin: 9px 0 0 9px;
    padding: 0; }
    .works_list ul li img {
      border: 1px solid #e3e3e3; }

.example_case {
  margin: 45px 0 0 0; }
  .example_case .header {
    background-color: #145e98;
    padding: 0;
    display: flex;
    flex-direction: row;
    align-items: center; }
    .example_case .header h5 {
      margin: 0;
      padding: 20px 0;
      width: 30%;
      text-align: center;
      font-family: Helvetica, Tahoma, Arial, sans-serif;
      font-weight: 100;
      color: #fff;
      align-items: center;
      font-size: 1.8em; }
    .example_case .header p {
      color: #fff;
      margin: 0;
      padding: 20px 0;
      width: 70%;
      align-items: center; }
    .example_case .header p.c {
      text-align: center;
      width: 100%; }
    @media screen and (max-width: 600px) {
      .example_case .header h5 {
        width: 35%;
        font-weight: bold; }
      .example_case .header p {
        width: 65%;
        font-size: 1.3em; } }
  .example_case table {
    margin-top: 0; }
    .example_case table th {
      vertical-align: middle; }
    .example_case table td.price {
      background-color: #eeeeee;
      text-align: center; }

.example_royalty {
  padding: 15px;
  border: 1px dotted #999999;
  text-align: center; }

.interview_index a {
  margin: 30px 0 0 0;
  display: block;
  cursor: pointer; }

.interview_index a:first-child {
  margin: 0; }

.interview_index a:hover img {
  opacity: 1; }

.interview_index a:hover .box p {
  color: #508700; }

.interview_index .box {
  background-color: #fff;
  border: 1px solid #e3e3e3; }
  .interview_index .box:after {
    content: "";
    display: block;
    clear: both; }
  .interview_index .box.box:hover {
    border-color: #508700; }
  .interview_index .box .photo {
    float: left;
    width: 200px; }
    .interview_index .box .photo p {
      margin: 0; }
  .interview_index .box .text {
    float: left;
    width: 668px;
    padding: 25px; }
    .interview_index .box .text h3 {
      padding: 0;
      margin: 0;
      line-height: 1.0; }
    .interview_index .box .text p {
      margin: 15px 0 0 0;
      color: #000000; }
    .interview_index .box .text p.book {
      margin: 5px 0 0 0;
      font-size: 1.5rem;
      line-height: 1.5; }
  @media screen and (max-width: 600px) {
    .interview_index .box .photo {
      width: 40%; }
    .interview_index .box .text {
      width: 52%;
      padding: 4%; }
      .interview_index .box .text p.book {
        font-size: 1.4rem; } }

.interview_box .q {
  margin: 60px 0 0 0;
  padding: 0 0 0 37px;
  font-size: 2.0em;
  line-height: 1.8;
  font-weight: normal;
  color: #508700;
  background: url("../imgs/interview/icon_q.svg") 0px 3px no-repeat;
  background-size: 28px; }

.interview_box .photoset:after {
  content: "";
  display: block;
  clear: both; }

.interview_box .photoset p {
  margin: 30px 0 0 0; }

.interview_box .photoset .photo_l {
  float: left;
  width: 360px; }

.interview_box .photoset .text_r {
  float: right;
  width: 520px; }

.interview_box .photoset .photo_r {
  float: right;
  width: 360px; }

.interview_box .photoset .text_l {
  float: left;
  width: 520px; }

@media screen and (max-width: 600px) {
  .interview_box .photoset .photo_l, .interview_box .photoset .text_r, .interview_box .photoset .photo_r, .interview_box .photoset .text_l {
    float: none;
    width: auto; }
  .interview_box .photoset .photo_l, .interview_box .photoset .photo_r {
    text-align: center; } }

.interview_book {
  margin: 80px 0 0 0;
  padding: 39px;
  border: 1px solid #e3e3e3; }
  .interview_book:after {
    content: "";
    display: block;
    clear: both; }
  .interview_book .book {
    float: left;
    width: 160px; }
  .interview_book .text {
    float: right;
    width: 660px; }
    .interview_book .text h5 {
      font-size: 1.6rem;
      line-height: 1.5;
      font-weight: bold;
      margin: 5px 0 0 0;
      padding: 0; }
    .interview_book .text p {
      margin: 10px 0 0 0;
      font-size: 1.5rem; }
  @media screen and (max-width: 600px) {
    .interview_book {
      padding: 29px; }
      .interview_book .book {
        width: 25%; }
      .interview_book .text {
        width: 70%; }
        .interview_book .text h5 {
          font-size: 1.5rem;
          margin: 0; } }

p.phone {
  margin: 20px 0 0 0;
  font-family: Helvetica, Tahoma, Arial, sans-serif;
  font-weight: normal;
  color: #508700;
  font-size: 2.6em; }
  p.phone span {
    padding-left: 24px;
    background: url("../imgs/common/icon_phone.svg") 0px 5px no-repeat;
    background-size: 20px; }

th .req {
  color: #cf3300;
  background-color: #ffe8e8;
  padding: 2px;
  font-size: 85%;
  -moz-border-radius: 3px;
  /* 旧Firefox */
  -webkit-border-radius: 3px;
  /* 旧Safari,旧Chrome */
  border-radius: 3px;
  /* CSS3 */ }

p.error {
  color: #cf3300; }

p.form_caption {
  margin: 5px 0 0 0;
  padding: 0;
  font-size: 90%;
  line-height: 1.5;
  color: #666666; }

.contact_conf_button {
  text-align: center; }
  @media screen and (max-width: 600px) {
    .contact_conf_button a {
      margin-top: 20px; } }

.footer_contact {
  margin: 0;
  padding: 35px 0;
  background-color: #f2ece4; }
  .footer_contact .inner {
    width: 1000px;
    margin: 0 auto; }
  .footer_contact .hl {
    text-align: center;
    margin: 0; }
  .footer_contact .contact_body {
    margin: 25px 49px 0 49px; }
    .footer_contact .contact_body:after {
      content: "";
      display: block;
      clear: both; }
    .footer_contact .contact_body .col {
      width: 300px;
      min-height: 52px;
      float: left;
      border-left: 1px solid #cdc3b5;
      padding: 10px 0; }
    .footer_contact .contact_body .col:first-child {
      border-left: 0; }
    .footer_contact .contact_body p {
      text-align: center;
      margin: 0;
      padding: 0;
      line-height: 1; }
    .footer_contact .contact_body .logo h2 {
      text-align: center;
      margin: 0 0 0 0;
      padding: 0;
      line-height: 1; }
    .footer_contact .contact_body .logo p {
      font-size: 1.2em;
      letter-spacing: 4px;
      color: #333333;
      margin: 8px 0 0 0;
      padding: 0 0 0 4px; }
    .footer_contact .contact_body .phone {
      font-family: Helvetica, Tahoma, Arial, sans-serif;
      color: #508700;
      font-size: 2.8em; }
      .footer_contact .contact_body .phone span {
        padding-left: 25px;
        background: url("../imgs/common/icon_phone.svg") 0px 7px no-repeat;
        background-size: 20px; }
    .footer_contact .contact_body .time {
      margin: 10px 0 0 0;
      font-size: 1.2em;
      letter-spacing: 0;
      color: #4a4a4a; }
    .footer_contact .contact_body .contact {
      margin: 5px 0 0 0; }
      .footer_contact .contact_body .contact img {
        height: 16px; }
      .footer_contact .contact_body .contact a {
        display: block;
        width: 160px;
        margin: 0 auto;
        padding: 14px 10px 14px 34px;
        background: #eb6100 url("../imgs/common/icon_contact.svg") 47px 17px no-repeat;
        background-size: 15px; }
      .footer_contact .contact_body .contact a:hover {
        background-color: #f38f35; }
        .footer_contact .contact_body .contact a:hover img {
          opacity: 1; }
  @media screen and (max-width: 600px) {
    .footer_contact {
      padding: 30px 0; }
      .footer_contact .inner {
        width: auto; }
      .footer_contact .hl {
        display: none; }
      .footer_contact .contact_body {
        margin: 0; }
        .footer_contact .contact_body .col {
          width: auto;
          min-height: auto;
          float: none;
          border-left: 0;
          padding: 0; }
        .footer_contact .contact_body .phone {
          margin: 30px 0 0 0;
          padding: 30px 0 0 0;
          border-top: 1px dotted #cdc3b5; }
        .footer_contact .contact_body .contact {
          margin: 20px 0 0 0; } }

.footer_nav {
  margin: 0;
  padding: 35px 0; }
  .footer_nav .inner {
    width: 1000px;
    margin: 0 auto; }
    .footer_nav .inner:after {
      content: "";
      display: block;
      clear: both; }
  .footer_nav a {
    color: #666666; }
  .footer_nav a:hover {
    color: #508700;
    text-decoration: underline; }
  .footer_nav .col {
    float: left;
    width: 340px; }
    .footer_nav .col p.h {
      margin: 0;
      padding: 0 0 10px 0;
      font-size: 1.3em;
      color: #333333; }
      .footer_nav .col p.h span {
        padding: 0 20px 0 0;
        background: url("../imgs/common/icon_arrow_down.svg") 95% 50% no-repeat;
        background-size: 9px; }
    .footer_nav .col ul {
      margin: 0;
      padding: 0; }
      .footer_nav .col ul li {
        font-size: 1.3em;
        margin: 8px 0 0 0;
        padding: 0 0 0 20px;
        background: url("../imgs/common/bullet.svg") 7px 5px no-repeat;
        background-size: 6px; }
      .footer_nav .col ul li:first-child {
        margin: 0; }
    .footer_nav .col ul.lower li {
      font-size: 1.2em; }
  .footer_nav .col_ex {
    float: left;
    margin: 0 0 0 20px;
    width: 300px; }
    .footer_nav .col_ex ul {
      margin: 0;
      padding: 0; }
      .footer_nav .col_ex ul li {
        margin: 10px 0 0 0;
        padding: 0; }
      .footer_nav .col_ex ul li:first-child {
        margin: 0; }
    .footer_nav .col_ex ul.social {
      margin: 0 -10px 0 0; }
      .footer_nav .col_ex ul.social:after {
        content: "";
        display: block;
        clear: both; }
      .footer_nav .col_ex ul.social li {
        float: left;
        margin: 15px 10px 0 0;
        padding: 0; }
  @media screen and (max-width: 600px) {
    .footer_nav .inner {
      width: auto;
      margin: 0 30px; }
    .footer_nav .col {
      float: none;
      width: auto; }
      .footer_nav .col p.h {
        border-top: 1px solid #e3e3e3;
        padding: 10px 0 0 0; }
      .footer_nav .col ul li {
        border-top: 1px solid #e3e3e3;
        margin-top: 10px;
        padding-top: 10px;
        background: url("../imgs/common/bullet.svg") 7px 15px no-repeat;
        background-size: 6px; }
      .footer_nav .col ul li:first-child {
        margin-top: 10px; }
      .footer_nav .col ul.lower {
        margin: 0 0 0 20px;
        padding-bottom: 5px; }
        .footer_nav .col ul.lower li {
          border-top: 0;
          padding-top: 2px;
          background: url("../imgs/common/bullet.svg") 7px 7px no-repeat;
          background-size: 6px; }
    .footer_nav .col_ex {
      float: none;
      width: auto;
      margin: 0; }
      .footer_nav .col_ex ul li {
        margin: 0;
        padding: 30px 0 0 0;
        text-align: center; }
      .footer_nav .col_ex ul.social {
        margin: 0 auto;
        width: 300px; }
        .footer_nav .col_ex ul.social li {
          float: left;
          margin: 15px 0px 0 0;
          padding: 0; }
        .footer_nav .col_ex ul.social li:first-child {
          margin: 15px 10px 0 0;
          padding: 0; } }

.footer_bottom {
  margin: 0;
  padding: 25px 0;
  border-top: 1px solid #e3e3e3; }
  .footer_bottom .inner {
    width: 1000px;
    margin: 0 auto; }
  .footer_bottom ul {
    margin: 0;
    padding: 0; }
    .footer_bottom ul:after {
      content: "";
      display: block;
      clear: both; }
    .footer_bottom ul li {
      font-size: 1.2em;
      float: left;
      border-left: 1px solid #dddddd;
      margin: 0 0 0 1em;
      padding: 0 0 0 1em; }
    .footer_bottom ul li:first-child {
      border-left: 0;
      margin: 0;
      padding: 0; }
    .footer_bottom ul a {
      color: #666666; }
    .footer_bottom ul a:hover {
      color: #666666;
      text-decoration: underline; }
  .footer_bottom .copyright {
    margin: 12px 0 0 0;
    font-size: 1.2em;
    font-family: Helvetica, Tahoma, Arial, sans-serif;
    color: #999999; }
  @media screen and (max-width: 600px) {
    .footer_bottom .inner {
      width: auto;
      padding: 0 10px 0 10px; }
      .footer_bottom .inner ul {
        text-align: center; }
        .footer_bottom .inner ul li {
          border: 0;
          float: none;
          display: inline-block;
          margin-top: 8px; }
    .footer_bottom .copyright {
      text-align: center; } }
