@charset "UTF-8";
/*------------------------------------------------------------------------------------

  reset

------------------------------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css?family=Oswald:300,600");
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,
main, menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline; }

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

ol, ul {
  list-style: none; }

table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0; }

/*------------------------------------------------------------------------------------

  font

------------------------------------------------------------------------------------*/
@font-face {
  font-family: 'Oswald';
  font-display: swap; }

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/NotoSansjp-Light.woff2") format("woff2"), url("../fonts/NotoSansjp-Light.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/NotoSansjp-Bold.woff2") format("woff2"), url("../fonts/NotoSansjp-Bold.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'YakuHanJPs';
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/YakuHanJPs-Light.eot");
  src: url("../fonts/YakuHanJPs-Light.woff2") format("woff2"), url("../fonts/YakuHanJPs-Light.woff") format("woff");
  font-display: swap; }

@font-face {
  font-family: 'YakuHanJPs';
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/YakuHanJPs-Bold.eot");
  src: url("../fonts/YakuHanJPs-Bold.woff2") format("woff2"), url("../fonts/YakuHanJPs-Bold.woff") format("woff");
  font-display: swap; }

/*------------------------------------------------------------------------------------

  base

------------------------------------------------------------------------------------*/
*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
          box-sizing: inherit; }

html {
  font-size: 62.5%;
  height: 100%;
  min-height: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

body {
  height: 100%;
  min-height: 100%;
  background-color: #fff;
  color: #323228;
  font-family: -apple-system, BlinkMacSystemFont, YakuHanJPs, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
  word-break: break-all;
  word-wrap: break-all;
  word-wrap: break-word;
  -webkit-text-size-adjust: 100%; }

input,
textarea,
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 6px 10px 5px;
  border: 1px solid #E6DCC3;
  border-radius: 0;
  font-size: 16px; }
  input:focus,
  textarea:focus,
  select:focus {
    outline: none; }

input:not(:target) {
  padding: 0 10px\9; }

@media all and (-ms-high-contrast: none) {
  input:not(:target) {
    padding: 6px 10px 5px; } }

input::-moz-focus-inner,
select::-moz-focus-inner {
  border: 0; }

input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
  opacity: 1;
  color: #aaa !important; }

input.error,
textarea.error {
  background-color: #FFF0F0;
  border-color: #ff0000; }

select.error {
  background-color: #FFF0F0;
  border-color: #ff0000; }

textarea {
  resize: vertical; }

select::-ms-expand {
  display: none; }

select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #aaa; }
  select:-moz-focusring * {
    color: #aaa;
    text-shadow: none; }

button {
  white-space: nowrap; }
  button:focus {
    outline: none; }

a {
  text-decoration: none;
  -webkit-transition: color 0.17s ease-out;
  -o-transition: color 0.17s ease-out;
  transition: color 0.17s ease-out; }
  a:link {
    color: #00AAAA; }
  a:visited {
    color: #00AAAA; }
  a:hover {
    color: #008282;
    text-decoration: underline; }
  a:active {
    color: #008282; }

section {
  padding: 6% 0; }
  @media (max-width: 767px) {
    section {
      padding: 40px 20px 45px; } }

.inner {
  margin: auto;
  width: 980px;
  overflow: hidden; }
  @media (min-width: 768px) and (max-width: 979px) {
    .inner {
      width: 90%; } }
  @media (max-width: 767px) {
    .inner {
      width: 100%; } }

/*------------------------------------------------------------------------------------

  header

------------------------------------------------------------------------------------*/
.header_wrap {
  position: fixed;
  top: 0;
  z-index: 100;
  width: 100%;
  height: 70px;
  margin: 0 auto;
  padding: 0 20px;
  overflow: hidden;
  -webkit-transition: all 0.5s ease-out;
  -o-transition: all 0.5s ease-out;
  transition: all 0.5s ease-out;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: space-between;
  -ms-flex-pack: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  .header_wrap .logo svg, .header_wrap .logo img {
    width: 250px;
    height: 50px;
    vertical-align: middle;
    fill: #fff; }
  .header_wrap.change {
    background: rgba(255, 255, 255, 0.9); }
    .header_wrap.change .logo svg, .header_wrap.change .logo img {
      fill: #504934; }
  @media (max-width: 767px) {
    .header_wrap {
      height: 60px;
      padding: 0 10px; }
      .header_wrap .logo svg, .header_wrap .logo img {
        width: 200px; } }

.nav_btn {
  position: fixed;
  right: 10px;
  top: 2px;
  z-index: 200;
  color: #fff;
  padding: 6px 15px;
  font-family: 'Oswald';
  font-weight: 300;
  font-size: 28px;
  font-size: 2.8rem;
  -webkit-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out; }
  .nav_btn span:after {
    content: attr(data-txt_menu); }
  .nav_btn:hover {
    cursor: pointer;
    color: #008282; }
  .nav_btn.change {
    color: #504934; }
    .nav_btn.change:hover {
      color: #008282; }
  @media (max-width: 767px) {
    .nav_btn {
      padding: 6px 10px;
      font-size: 24px;
      font-size: 2.4rem; } }

.open .nav_btn {
  color: #fff; }
  .open .nav_btn span:after {
    content: attr(data-txt_close); }

.open .logo {
  opacity: 0; }

.header_wrap {
  display: block\9; }
  .header_wrap .logo {
    float: left\9; }

@media all and (-ms-high-contrast: none) {
  .header_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    .header_wrap .logo {
      float: none; } }

@media (max-width: 767px) {
  .android .header_wrap {
    position: relative;
    z-index: 1000; }
    .android .header_wrap .logo svg, .android .header_wrap .logo img {
      fill: #323228; }
  .android .nav_btn {
    position: absolute;
    right: 0;
    top: -1px;
    z-index: 1100;
    color: #323228; }
  .android.open .nav_btn {
    color: #fff; } }

/*------------------------------------------------------------------------------------

  navi

------------------------------------------------------------------------------------*/
.nav_wrap {
  position: fixed;
  z-index: 150;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #323228;
  -webkit-transition: all 0.5s ease-out;
  -o-transition: all 0.5s ease-out;
  transition: all 0.5s ease-out;
  visibility: hidden;
  opacity: 0; }
  .nav_wrap ul {
    margin-top: 70px; }
    .nav_wrap ul li {
      -js-display: flex;
      /*IE*/
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: space-between;
      -ms-flex-pack: space-between;
      justify-content: space-between;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      height: 70px;
      line-height: 1.2; }
      .nav_wrap ul li a {
        display: block;
        position: relative;
        color: #fff;
        padding: 0 30px;
        font-family: 'Oswald';
        font-weight: 300;
        font-size: 26px;
        font-size: 2.6rem; }
        .nav_wrap ul li a:hover {
          text-decoration: none;
          color: #008282; }
          .nav_wrap ul li a:hover span {
            color: #fff; }
        .nav_wrap ul li a span {
          display: block;
          font-family: 'Oswald';
          font-weight: 300;
          font-size: 12px;
          font-size: 1.2rem;
          opacity: .7; }

.open .nav_wrap {
  -webkit-transition: all 0.5s ease-out;
  -o-transition: all 0.5s ease-out;
  transition: all 0.5s ease-out;
  visibility: visible !important;
  opacity: 1;
  z-index: 150; }

@media (max-width: 767px) {
  .nav_wrap ul {
    margin-top: 60px; } }

@media (max-width: 320px) {
  .nav_wrap li a {
    font-size: 16px; }
    .nav_wrap li a span {
      font-size: 14px; } }

@media (max-width: 767px) {
  .android .nav_wrap {
    display: none; }
  .android.open .nav_wrap {
    display: block; } }

/*------------------------------------------------------------------------------------

  main

------------------------------------------------------------------------------------*/
.container {
  height: auto;
  min-height: calc(100vh - 420px);
  margin: 0 auto; }

main {
  width: 100%;
  background: #fff; }

/* top */
.top .container {
  padding-bottom: 100vh; }

.top main {
  position: relative;
  top: 100vh;
  padding-bottom: 1px; }

/* top IE */
.top .container {
  padding-bottom: 0\9; }

.top main {
  position: static\9; }

@media all and (-ms-high-contrast: none) {
  .top .container {
    padding-bottom: 0; }
  .top main {
    position: static; } }

/*------------------------------------------------------------------------------------

  footer

------------------------------------------------------------------------------------*/
.footer_wrap {
  position: relative;
  background: #fff; }

.footer {
  width: 100%;
  padding-top: 20px;
  background: #C8C3B4;
  clear: both; }
  .footer .logo {
    text-align: center;
    padding-top: 20px; }
    .footer .logo svg, .footer .logo img {
      width: 440px;
      height: 100px;
      fill: #504934; }
      @media (max-width: 767px) {
        .footer .logo svg, .footer .logo img {
          width: 70%;
          height: 50px; } }
  .footer .footer_nav {
    -js-display: flex;
    /*IE*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 20px auto; }
    .footer .footer_nav li {
      padding: 0 20px 0 0; }
      .footer .footer_nav li:last-of-type {
        margin-right: 0; }
        .footer .footer_nav li:last-of-type:after {
          display: none; }
      .footer .footer_nav li:after {
        content: "";
        width: 1px;
        height: 15px;
        background: #000;
        display: inline-block;
        margin: 0 0 5px 20px;
        vertical-align: middle; }
      .footer .footer_nav li a {
        color: #504934;
        font-family: 'Oswald';
        font-weight: 300;
        font-size: 16px;
        font-size: 1.6rem; }
        @media (max-width: 320px) {
          .footer .footer_nav li a {
            font-size: 14px !important; } }
        .footer .footer_nav li a:hover {
          color: #008282; }
    @media (max-width: 767px) {
      .footer .footer_nav {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        width: 80%; }
        .footer .footer_nav li {
          width: 50%;
          padding: 5px 0;
          text-align: center; }
          .footer .footer_nav li:after {
            display: none; }
        .footer .footer_nav a {
          display: block;
          padding: 5px; } }
  .footer .share {
    -js-display: flex;
    /*IE*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 60px auto 50px;
    width: 30%; }
    .footer .share li {
      width: 30%;
      text-align: center; }
      .footer .share li a {
        padding: 10px 10px 5px 10px; }
        .footer .share li a:hover {
          color: #008282; }
        .footer .share li a svg, .footer .share li a img {
          width: 20px;
          height: 20px;
          fill: #323228; }
        .footer .share li a:hover svg {
          fill: #008282; }
        .footer .share li a:hover img {
          opacity: .8; }
    @media (max-width: 767px) {
      .footer .share {
        width: 70%; }
        .footer .share li a svg {
          width: 24px;
          height: 24px; } }
  .footer .copyright {
    text-align: center;
    font-size: 11px;
    font-size: 1.1rem;
    padding-bottom: 30px; }

.page_top {
  float: right;
  margin: 2%; }
  .page_top a {
    width: 25px;
    padding: 10px; }
    .page_top a svg, .page_top a img {
      fill: #00AAAA;
      width: 25px;
      height: 15px; }
    .page_top a:hover svg {
      fill: #008282; }
    .page_top a:hover img {
      opacity: .8; }

@media (max-width: 767px) {
  .android .footer_nav {
    display: block; } }

/*------------------------------------------------------------------------------------

  button

------------------------------------------------------------------------------------*/
.btn_wrap {
  padding-top: 30px;
  text-align: center; }

a.btn {
  padding: 3px 6px;
  display: inline-block; }
  a.btn:hover {
    text-decoration: none; }

a.btn,
.btn {
  cursor: pointer;
  border: 1px solid #777;
  background-color: #777;
  color: #fff;
  text-align: center;
  font-family: 'Oswald';
  font-weight: 300;
  font-size: 20px;
  font-size: 2rem;
  width: 300px;
  height: 60px;
  padding: 10px;
  -webkit-transition: all 0.17s ease-out;
  -o-transition: all 0.17s ease-out;
  transition: all 0.17s ease-out; }
  @media (max-width: 767px) {
    a.btn,
    .btn {
      width: 100%; } }
  a.btn:visited,
  .btn:visited {
    color: #fff; }
  a.btn:hover,
  .btn:hover {
    opacity: .7; }
  a.btn.btn_basic,
  .btn.btn_basic {
    color: #fff;
    background-color: #00AAAA;
    border-color: #00AAAA; }
    a.btn.btn_basic:visited,
    .btn.btn_basic:visited {
      color: #fff; }
    a.btn.btn_basic:hover,
    .btn.btn_basic:hover {
      opacity: 1;
      background-color: #008282;
      border-color: #008282; }
  a.btn.btn_line,
  .btn.btn_line {
    color: #00AAAA;
    background-color: #fff;
    border-color: #00AAAA; }
    a.btn.btn_line:visited,
    .btn.btn_line:visited {
      color: #00AAAA; }
    a.btn.btn_line:hover,
    .btn.btn_line:hover {
      opacity: 1;
      color: #008282;
      border: 1px solid #008282; }
  a.btn.btn_mini,
  .btn.btn_mini {
    width: 80px;
    height: 18px;
    line-height: 1.5;
    padding: 0;
    margin-left: 10px;
    font-size: 10px;
    font-size: 1rem; }

/*------------------------------------------------------------------------------------

anime

------------------------------------------------------------------------------------*/
.fadein .main_ttl,
.fadein .middle_ttl,
.fadein .lead_text,
.fadein dl {
  -webkit-transition: all 1s cubic-bezier(0.5, 0, 0.5, 1);
  -o-transition: all 1s cubic-bezier(0.5, 0, 0.5, 1);
  transition: all 1s cubic-bezier(0.5, 0, 0.5, 1);
  opacity: .0;
  -webkit-transform: translate(0, 50%);
      -ms-transform: translate(0, 50%);
          transform: translate(0, 50%); }

.fadein .card {
  -webkit-transition: all 0.8s cubic-bezier(0.2, 0, 0.2, 0.8);
  -o-transition: all 0.8s cubic-bezier(0.2, 0, 0.2, 0.8);
  transition: all 0.8s cubic-bezier(0.2, 0, 0.2, 0.8);
  opacity: .0;
  -webkit-transform: translate(0, 5%);
      -ms-transform: translate(0, 5%);
          transform: translate(0, 5%); }

.fadein.scrollin .main_ttl,
.fadein.scrollin .middle_ttl,
.fadein.scrollin .lead_text,
.fadein.scrollin .card,
.fadein.scrollin dl {
  opacity: 1;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0); }

@media (max-width: 767px) {
  .android .fadein .main_ttl,
  .android .fadein .middle_ttl,
  .android .fadein .lead_text,
  .android .fadein .card,
  .android .fadein dl {
    opacity: 1;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0); } }

/*------------------------------------------------------------------------------------

  others

------------------------------------------------------------------------------------*/
.clearfix:after {
  content: "";
  display: block;
  clear: both; }

.flex {
  -js-display: flex;
  /*IE*/
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }

/* PC/ SP switch
--------------------------------------------------*/
@media (min-width: 768px) {
  .sp {
    display: none !important; } }

@media (max-width: 767px) {
  .pc {
    display: none !important; } }

/* style
--------------------------------------------------*/
/* font-size */
.fs10 {
  font-size: 10px; }

.fs11 {
  font-size: 11px; }

.fs12 {
  font-size: 12px; }

.fs13 {
  font-size: 13px; }

.fs14 {
  font-size: 14px; }

/* font-weight */
.fwB {
  font-weight: bold; }

/* background */
.bg_white {
  background: #fff; }

.bg_red {
  background: #FFF0F0; }

/* align
--------------------------------------------------*/
.taL {
  text-align: left !important; }

.taC {
  text-align: center !important; }

.taR {
  text-align: right !important; }

.vaT {
  vertical-align: top !important; }

.vaM {
  vertical-align: middle !important; }

/* width
--------------------------------------------------*/
.w30 {
  width: 30px !important; }

.w50 {
  width: 50px !important; }

.w60 {
  width: 60px !important; }

.w70 {
  width: 70px !important; }

.w75 {
  width: 75px !important; }

.w80 {
  width: 80px !important; }

.w90 {
  width: 90px !important; }

.w100 {
  width: 100px !important; }

.w105 {
  width: 105px !important; }

.w110 {
  width: 110px !important; }

.w120 {
  width: 120px !important; }

.w130 {
  width: 130px !important; }

.w140 {
  width: 140px !important; }

.w145 {
  width: 145px !important; }

.w150 {
  width: 150px !important; }

.w155 {
  width: 155px !important; }

.w165 {
  width: 165px !important; }

.w175 {
  width: 175px !important; }

.w200 {
  width: 200px !important; }

.w210 {
  width: 210px !important; }

.w220 {
  width: 220px !important; }

.w270 {
  width: 270px !important; }

.w280 {
  width: 280px !important; }

.w350 {
  width: 350px !important; }

.w375 {
  width: 375px !important; }

.w410 {
  width: 410px !important; }

.w430 {
  width: 430px !important; }

.w500 {
  width: 500px !important; }

.w580 {
  width: 580px !important; }

.min_w100 {
  min-width: 100px !important; }

.min_w110 {
  min-width: 110px !important; }

.min_w135 {
  min-width: 135px !important; }

.min_w140 {
  min-width: 140px !important; }

.min_w150 {
  min-width: 150px !important; }

.min_w230 {
  min-width: 230px !important; }

.min_w250 {
  min-width: 250px !important; }

.min_w280 {
  min-width: 280px !important; }

/* height
--------------------------------------------------*/
.h403 {
  height: 403px !important; }

.h500 {
  height: 500px !important; }

/* padding
--------------------------------------------------*/
/* padding-top */
.pt5 {
  padding-top: 5px !important; }

.pt10 {
  padding-top: 10px !important; }

.pt15 {
  padding-top: 15px !important; }

.pt20 {
  padding-top: 20px !important; }

.pt25 {
  padding-top: 25px !important; }

.pt30 {
  padding-top: 30px !important; }

.pt35 {
  padding-top: 35px !important; }

.pt40 {
  padding-top: 40px !important; }

.pt80 {
  padding-top: 80px !important; }

/* padding-bottom */
.pb5 {
  padding-bottom: 5px !important; }

.pb10 {
  padding-bottom: 10px !important; }

.pb15 {
  padding-bottom: 15px !important; }

.pb20 {
  padding-bottom: 20px !important; }

.pb25 {
  padding-bottom: 25px !important; }

.pb30 {
  padding-bottom: 30px !important; }

.pb35 {
  padding-bottom: 35px !important; }

.pb40 {
  padding-bottom: 40px !important; }

/* padding-left */
.pl5 {
  padding-left: 5px !important; }

.pl10 {
  padding-left: 10px !important; }

.pl15 {
  padding-left: 15px !important; }

.pl20 {
  padding-left: 20px !important; }

.pl25 {
  padding-left: 25px !important; }

.pl30 {
  padding-left: 30px !important; }

.pl35 {
  padding-left: 35px !important; }

.pl40 {
  padding-left: 40px !important; }

/* padding-right */
.pr5 {
  padding-right: 5px !important; }

.pr10 {
  padding-right: 10px !important; }

.pr15 {
  padding-right: 15px !important; }

.pr20 {
  padding-right: 20px !important; }

.pr25 {
  padding-right: 25px !important; }

.pr30 {
  padding-right: 30px !important; }

.pr35 {
  padding-right: 35px !important; }

.pr40 {
  padding-right: 40px !important; }

/* margin
--------------------------------------------------*/
/* margin-top */
.mt5 {
  margin-top: 5px !important; }

.mt10 {
  margin-top: 10px !important; }

.mt15 {
  margin-top: 15px !important; }

.mt20 {
  margin-top: 20px !important; }

.mt25 {
  margin-top: 25px !important; }

.mt30 {
  margin-top: 30px !important; }

.mt35 {
  margin-top: 35px !important; }

.mt40 {
  margin-top: 40px !important; }

.mt50 {
  margin-top: 50px !important; }

.mt80 {
  margin-top: 80px !important; }

/* margin-bottom */
.mb5 {
  margin-bottom: 5px !important; }

.mb10 {
  margin-bottom: 10px !important; }

.mb15 {
  margin-bottom: 15px !important; }

.mb20 {
  margin-bottom: 20px !important; }

.mb25 {
  margin-bottom: 25px !important; }

.mb30 {
  margin-bottom: 30px !important; }

.mb35 {
  margin-bottom: 35px !important; }

.mb40 {
  margin-bottom: 40px !important; }

/* margin-left */
.ml5 {
  margin-left: 5px !important; }

.ml10 {
  margin-left: 10px !important; }

.ml15 {
  margin-left: 15px !important; }

.ml20 {
  margin-left: 20px !important; }

.ml25 {
  margin-left: 25px !important; }

.ml30 {
  margin-left: 30px !important; }

.ml35 {
  margin-left: 35px !important; }

.ml40 {
  margin-left: 40px !important; }

/* margin-right */
.mr5 {
  margin-right: 5px !important; }

.mr10 {
  margin-right: 10px !important; }

.mr15 {
  margin-right: 15px !important; }

.mr20 {
  margin-right: 20px !important; }

.mr25 {
  margin-right: 25px !important; }

.mr30 {
  margin-right: 30px !important; }

.mr35 {
  margin-right: 35px !important; }

.mr40 {
  margin-right: 40px !important; }

/* float
--------------------------------------------------*/
.fL {
  float: left; }

.fR {
  float: right; }

.cB {
  clear: both; }

/* position
--------------------------------------------------*/
.posir {
  position: relative; }

.posia {
  position: absolute; }

.posis {
  position: static; }

.posif {
  position: fixed; }

/* border
--------------------------------------------------*/
/* input parts
--------------------------------------------------*/
.select {
  padding: 5px 34px 3px 10px;
  border-radius: 0;
  background: #fff url("../img/icon_triangle.svg") right center no-repeat;
  background-size: 24px 8px; }
  .select::-moz-focus-inner {
    border: 0; }

input[type="text"],
input[type="tel"],
input[type="email"] {
  min-height: 35px; }

.short {
  width: 13em !important; }

.medium {
  width: 18em !important; }

.long {
  width: 100%; }

.long:not(:target) {
  width: 80%\9; }

@media all and (-ms-high-contrast: none) {
  .long:not(:target) {
    width: 100%; } }

@media (max-width: 767px) {
  .short, .medium, .long {
    width: 100% !important; } }

.ckb {
  -js-display: flex;
  /*IE*/
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 2em;
  cursor: pointer; }
  .ckb input[type="checkbox"] {
    display: none; }
  .ckb span {
    padding-left: 23px;
    position: relative; }
  .ckb span:before {
    content: "";
    display: block;
    position: absolute;
    top: 4px;
    left: 0;
    width: 16px;
    height: 16px;
    border: 1px solid #aaa;
    background-color: #fff; }
  .ckb input[type="checkbox"]:checked + span {
    color: #b20000; }
  .ckb input[type="checkbox"]:checked + span:after {
    content: "";
    display: block;
    position: absolute;
    top: 4px;
    left: 5px;
    width: 7px;
    height: 13px;
    -webkit-transform: rotate(40deg);
        -ms-transform: rotate(40deg);
            transform: rotate(40deg);
    border-bottom: 3px solid #ff0000;
    border-right: 3px solid #ff0000; }

input[type="text"]:disabled,
input[type="tel"]:disabled,
input[type="email"]:disabled,
select:disabled,
textarea:disabled {
  background-color: #aaa; }

p.small {
  display: block;
  color: #888;
  font-size: 13px;
  margin: -5px 0 5px; }
  @media (max-width: 767px) {
    p.small {
      margin-top: -3px; } }

p.error {
  color: #ff0000;
  font-size: 12px;
  margin: 5px 0 -10px; }
  @media (max-width: 767px) {
    p.error {
      margin-bottom: -3px; } }

span.required {
  color: #fff;
  background-color: #ff0000;
  font-size: 12px;
  padding: 0 4px;
  margin-left: 8px; }

:placeholder-shown {
  color: #aaa;
  font-size: 16px; }

::-webkit-input-placeholder {
  color: #aaa;
  font-size: 16px; }

:-moz-placeholder {
  opacity: 1;
  color: #aaa;
  font-size: 16px; }

::-moz-placeholder {
  opacity: 1;
  color: #aaa;
  font-size: 16px; }

:-ms-input-placeholder {
  color: #aaa;
  font-size: 16px; }

/*------------------------------------------------------------------------------------

  汎用スタイル

------------------------------------------------------------------------------------*/
.main_ttl, .middle_ttl {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #9B8250;
  line-height: 1.6;
  letter-spacing: -.1rem;
  text-align: center; }

.main_ttl {
  font-size: 32px;
  font-size: 3.2rem;
  text-align: center; }

.middle_ttl {
  font-size: 24px;
  font-size: 2.4rem; }

.lead_text {
  padding-top: 40px; }

@media (max-width: 767px) {
  .main_ttl {
    font-size: 24px;
    font-size: 2.4rem; }
  .middle_ttl {
    font-size: 24px;
    font-size: 2.4rem; }
  .lead_text {
    padding-top: 25px; } }

@media (max-width: 320px) {
  .main_ttl {
    font-size: 24px;
    font-size: 2.4rem; }
  .middle_ttl {
    font-size: 24px;
    font-size: 2.4rem; } }

.top .middle_ttl,
.company .middle_ttl {
  font-family: 'Oswald';
  font-weight: 300;
  font-size: 32px;
  font-size: 3.2rem;
  letter-spacing: 0; }

.company .main_ttl {
  font-family: 'Oswald';
  font-weight: 300;
  font-size: 36px;
  font-size: 3.6rem;
  letter-spacing: 0; }

/*------------------------------------------------------------------------------------

  TOP

------------------------------------------------------------------------------------*/
.top .lead_text span {
  color: #9B8250;
  padding-right: 3px; }

/*-----------------
  section キービジュアル
-----------------*/
.top-movie_wrap, .top-movie_wrap .top-movie {
  position: fixed;
  width: 100%;
  height: 100%;
  height: 100vh; }
  .top-movie_wrap .top-movie {
    position: relative; }
    .top-movie_wrap .top-movie video {
      position: absolute;
      min-width: 100%;
      min-width: 100vw;
      min-height: 100%;
      min-height: 100vh;
      top: 50%;
      left: 50%;
      background-attachment: fixed;
      -ms-transform: translate(-50%, -50%);
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
      @media (max-width: 767px) {
        .top-movie_wrap .top-movie video {
          width: 100%; } }

.top_title {
  background-color: rgba(0, 0, 0, 0.4);
  color: #fff;
  position: relative;
  height: 100vh;
  margin: -100vh auto 0;
  z-index: 50;
  -js-display: flex;
  /*IE*/
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  .top_title h1 {
    font-size: 44px;
    font-size: 4.4rem;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    margin: 70px auto 0;
    text-align: center;
    padding: 30px; }
  @media (max-width: 767px) {
    .top_title h1 {
      margin-top: 0;
      font-size: 25px;
      font-size: 2.5rem;
      line-height: 1.5; } }

/*-----------------
  section トップビジュアル
-----------------*/
.top_visual {
  width: 100%;
  height: 80vh;
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  text-align: center;
  position: relative;
  padding: 0; }
  @media (max-width: 767px) {
    .top_visual {
      background-attachment: scroll; } }
  .top_visual:after {
    content: "";
    width: 100%;
    height: 80vh;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(50, 50, 40, 0.1); }
  .top_visual .top_ttl {
    font-family: 'Oswald';
    font-weight: 600;
    font-size: 80px;
    font-size: 8rem;
    color: rgba(255, 255, 255, 0.8);
    position: absolute;
    bottom: 7%;
    right: 4%;
    z-index: 10; }
    @media (max-width: 767px) {
      .top_visual .top_ttl {
        font-size: 50px;
        font-size: 5rem; } }
  .top_visual .sub_ttl {
    font-size: 20px;
    font-size: 2rem;
    color: rgba(255, 255, 255, 0.8);
    position: absolute;
    bottom: 6%;
    right: 5%;
    z-index: 10; }
    @media (max-width: 767px) {
      .top_visual .sub_ttl {
        font-size: 15px;
        font-size: 1.5rem; } }

.bg_fixed {
  min-height: 100vh; }

.bg_scrolling {
  min-height: 100vh; }

.top-movie_wrap, .top-movie_wrap .top-movie {
  position: relative\9;
  overflow: hidden\9; }

@media all and (-ms-high-contrast: none) {
  .top-movie_wrap, .top-movie_wrap .top-movie {
    position: relative;
    overflow: hidden; } }

@media (max-width: 767px) {
  .android .top-movie_wrap, .android .top-movie_wrap .top-movie, .top-movie_wrap .android .top-movie, .android .top-movie {
    display: none; }
  .android .top_visual {
    height: 100%; } }

/*-----------------
  section
-----------------*/
section.bg_left,
section.bg_right {
  height: auto;
  margin: 6% 0; }
  section.bg_left:before,
  section.bg_right:before {
    display: block;
    content: ""; }

section.bg_right .bg_img {
  margin-left: 40% !important; }
  @media (max-width: 767px) {
    section.bg_right .bg_img {
      margin-left: 6% !important; } }

section.bg_right .card {
  margin-left: 0 !important; }
  @media (min-width: 1120px) {
    section.bg_right .card {
      margin-left: 10% !important; } }
  @media (max-width: 767px) {
    section.bg_right .card {
      margin-left: 6% !important; } }

/*-----------------
  parallax
-----------------*/
.js_parallax {
  position: relative;
  height: auto;
  overflow: hidden; }

.bg_img {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 60%;
  height: 400px; }
  @media (max-width: 767px) {
    .bg_img {
      width: 100%;
      height: 300px;
      margin-left: -8%; } }

/*-----------------
  img_area
-----------------*/
/*-----------------
  card
-----------------*/
.card {
  width: 58%;
  max-width: 640px;
  height: auto;
  padding: 4%;
  margin: -360px 0 0 40%;
  background: #fff; }
  .card .middle_ttl {
    text-align: left; }
  .card .lead_text {
    padding: 20px 0 40px; }
  @media (max-width: 767px) {
    .card {
      width: 90%;
      padding: 6%;
      margin: -100px 0 0 5%; } }

/*------------------------------------------------------------------------------------

  company

------------------------------------------------------------------------------------*/
.company_list dl {
  -js-display: flex;
  /*IE*/
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 6% 0;
  border-bottom: 1px solid #E6DCC3; }
  .company_list dl:first-of-type {
    margin-top: 5%;
    border-top: 1px solid #E6DCC3; }
  .company_list dl:last-child {
    margin-bottom: 5%; }
  .company_list dl dt {
    -ms-flex-preferred-size: 13em;
        flex-basis: 13em;
    max-width: 208px; }
  .company_list dl dd {
    -ms-flex-preferred-size: calc(100% - 13em);
        flex-basis: calc(100% - 13em);
    max-width: calc(100% - 208px); }
    .company_list dl dd ul {
      padding-bottom: 5%; }
      .company_list dl dd ul:last-child {
        padding-bottom: 5%; }
      .company_list dl dd ul li:first-child {
        padding-bottom: 1%; }

@media (max-width: 767px) {
  .company_list dl {
    padding: 10% 0;
    display: block; }
    .company_list dl dt, .company_list dl dd {
      max-width: 100%; }
    .company_list dl dt {
      padding-bottom: 5%; } }

.address_link {
  margin-top: 4%; }

/*------------------------------------------------------------------------------------

  access

------------------------------------------------------------------------------------*/
.guide {
  margin: 5% 0 13%; }
  .guide:last-child {
    margin-bottom: 0; }
  .guide dl {
    -js-display: flex;
    /*IE*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: space-between;
    -ms-flex-pack: space-between;
    justify-content: space-between; }
    .guide dl dt {
      width: 45%; }
      .guide dl dt h4 {
        color: #9B8250;
        margin-bottom: 2%; }
      .guide dl dt a.btn {
        margin: 5px 0 0 3%; }
      .guide dl dt p {
        clear: both;
        margin-bottom: 2%; }
        .guide dl dt p:nth-of-type(1) {
          margin-bottom: 0; }
      .guide dl dt div {
        font-size: 14px;
        font-size: 1.4rem;
        margin: 4% 0;
        position: relative;
        clear: both;
        padding: 2% 4%; }
        .guide dl dt div:before {
          content: "";
          display: block;
          position: absolute;
          top: 0;
          left: 0;
          border-top: 1px solid #E6DCC3;
          border-left: 1px solid #E6DCC3;
          width: 40px;
          height: 40px; }
        .guide dl dt div:after {
          content: "";
          display: block;
          position: absolute;
          right: 0;
          bottom: 0;
          border-right: 1px solid #E6DCC3;
          border-bottom: 1px solid #E6DCC3;
          width: 40px;
          height: 40px; }
    .guide dl dd {
      width: 50%; }
      .guide dl dd .map_area {
        position: relative;
        padding-bottom: 56.25%;
        margin-bottom: 5%;
        width: 100%;
        height: 0;
        overflow: hidden;
        content: ""; }
        .guide dl dd .map_area iframe,
        .guide dl dd .map_area object,
        .guide dl dd .map_area embed {
          position: absolute;
          top: 0;
          left: 0;
          width: 100% !important;
          height: 100% !important; }
  @media (max-width: 767px) {
    .guide {
      margin: 5% 0 20%; }
      .guide dl {
        display: block !important; }
      .guide dt, .guide dd {
        width: 100% !important; } }

/*------------------------------------------------------------------------------------

  recruit

------------------------------------------------------------------------------------*/
.requirements h3 {
  color: #9B8250; }
  .requirements h3:after {
    content: "";
    display: block;
    width: 20%;
    height: 1px;
    background: #9B8250; }

.requirements .text {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 4% 0 8%; }

.note {
  margin-top: 4%;
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1.5; }

.mynavi_link a:hover {
  opacity: .8; }


  /*------------------------------------------------------------------------------------

    corporate_pdf_button

  ------------------------------------------------------------------------------------*/
a[href$=".pdf"]:after {
    content:" ";
    display: inline-block;
    width: 24px;
    height: 24px;
    background: url(../img/pdf_icon.png) no-repeat;
}

/*------------------------------------------------------------------------------------

  news

------------------------------------------------------------------------------------*/
.news-heading {
  color:#00AAAA;
}

.news-text {
  display:none;
  font-size: 14px;
  margin-top: 10px;
}
