@charset "UTF-8";
/* Scss Document */
@font-face {
  font-family: "kanjyuku";
  src: url("/font/kanjyuku.woff") format("woff"); }
@font-face {
  font-family: "honoka";
  src: url("/font/honoka.woff") format("woff"); }
@font-face {
  font-family: "beaunormal.woff";
  src: url("/font/beaunormal.woff.woff") format("woff"); }
/* Scss Document */
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: transparent; }

html {
  font-size: 62.5%; }

body {
  line-height: 1; }

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

ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

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

/* 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; }

/* Scss Document */
/* Scss Document */
/* Scss Document */
header #header {
  position: fixed;
  background: url("/img/common/main_back.png") no-repeat center;
  background-size: cover;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10000;
  height: 80px; }
  header #header .logo {
    position: absolute;
    width: 100%;
    top: 50%;
    transform: translateY(-50%);
    left: 4%;
    height: 60px;
    width: auto; }
    header #header .logo img {
      height: 100%;
      width: auto; }
  header #header .menu_btn {
    position: absolute;
    width: 100%;
    top: 50%;
    transform: translateY(-50%);
    top: 50%;
    width: 40px;
    height: 26px;
    right: 4%; }
    header #header .menu_btn span {
      width: 100%;
      height: 1px;
      border-radius: 10px;
      background: #fff;
      display: block;
      position: absolute;
      transition: .3s;
      display: block; }
      header #header .menu_btn span:first-child {
        top: 0; }
      header #header .menu_btn span:nth-child(2) {
        top: 12px; }
      header #header .menu_btn span:last-child {
        bottom: 0; }
    header #header .menu_btn p {
      color: #fff;
      text-align: center;
      font-size: 1rem;
      position: absolute;
      bottom: -20px;
      left: 0;
      right: 0; }
  header #header .menu_wrap {
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.9);
    height: calc(100vh - 80px);
    display: none;
    overflow: hidden; }
    header #header .menu_wrap ul {
      position: absolute;
      width: 100%;
      top: 50%;
      transform: translateY(-50%);
      top: 40%; }
    header #header .menu_wrap li a {
      color: #fff;
      text-align: center;
      display: block;
      padding: 10px 4vh;
      font-size: 1.6rem; }
    header #header .menu_wrap li.contact {
      width: 80%;
      margin: 6vh auto 4vh;
      border: solid 1px #80111B; }
      header #header .menu_wrap li.contact a {
        font-size: 1.6rem;
        display: block;
        padding: 15px;
        box-sizing: border-box;
        color: #fff;
        background: #80111B; }
header #header_test {
  position: fixed;
  background: url("/img/common/main_back.png") no-repeat center;
  background-size: cover;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10000;
  height: 80px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro","sans-serif"; }
  header #header_test .txt_wrap {
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translate(0, -50%);
    font-size: 2.2rem;
    color: #fff;
    font-weight: bold; }
  header #header_test .menu_btn {
    position: absolute;
    width: 100%;
    top: 50%;
    transform: translateY(-50%);
    top: 50%;
    width: 40px;
    height: 26px;
    right: 4%; }
    header #header_test .menu_btn span {
      width: 100%;
      height: 1px;
      border-radius: 10px;
      background: #fff;
      display: block;
      position: absolute;
      transition: .3s;
      display: block; }
      header #header_test .menu_btn span:first-child {
        top: 0; }
      header #header_test .menu_btn span:nth-child(2) {
        top: 12px; }
      header #header_test .menu_btn span:last-child {
        bottom: 0; }
    header #header_test .menu_btn p {
      color: #fff;
      text-align: center;
      font-size: 1rem;
      position: absolute;
      bottom: -20px;
      left: 0;
      right: 0; }
  header #header_test .menu_wrap {
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.9);
    height: calc(100vh - 80px);
    display: none;
    overflow: hidden; }
    header #header_test .menu_wrap ul {
      position: absolute;
      width: 100%;
      top: 50%;
      transform: translateY(-50%);
      top: 40%; }
    header #header_test .menu_wrap li a {
      color: #fff;
      text-align: center;
      display: block;
      padding: 10px 4vh;
      font-size: 1.6rem;
      font-weight: bold; }
    header #header_test .menu_wrap li.contact {
      width: 80%;
      margin: 6vh auto 4vh;
      border: solid 1px #80111B; }
      header #header_test .menu_wrap li.contact a {
        font-size: 1.6rem;
        display: block;
        padding: 15px;
        box-sizing: border-box;
        color: #fff;
        background: #80111B; }

.open header #header .menu_btn span:nth-child(1) {
  -webkit-transform: translateY(12px) rotate(-315deg);
  transform: translateY(12px) rotate(-315deg); }
.open header #header .menu_btn span:nth-child(2) {
  opacity: 0; }
.open header #header .menu_btn span:nth-child(3) {
  -webkit-transform: translateY(-12px) rotate(315deg);
  transform: translateY(-12px) rotate(315deg); }

/*------------------------------
		768px以上
------------------------------*/
/*------------------------------
		980px以上
------------------------------*/
@media screen and (min-width: 981px) {
  .pc header #header .menu_wrap {
    display: block !important; }
  .pc header #header_test .menu_wrap {
    display: block !important; }

  header #header {
    transition: .3s; }
    header #header .logo {
      left: 2%; }
    header #header .menu_btn {
      display: none; }
    header #header .menu_wrap {
      transition: .3s;
      background: none;
      padding-bottom: 0;
      height: auto;
      margin: auto;
      right: 2%;
      top: 50%;
      left: auto;
      transform: translateY(-50%);
      width: 80%;
      max-width: 800px; }
      header #header .menu_wrap ul {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-flow: row wrap;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
        -webkit-box-align: stretch;
        -webkit-align-items: stretch;
        -ms-flex-align: stretch;
        align-items: stretch;
        -webkit-align-content: flex-start;
        -ms-flex-line-pack: start;
        align-content: flex-start;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        position: static;
        transform: none; }
        header #header .menu_wrap ul li {
          flex: 0 1 auto;
          width: auto;
          max-width: auto; }
          header #header .menu_wrap ul li a {
            padding: 15px 5px 5px;
            font-size: 1.4rem; }
            header #header .menu_wrap ul li a:after {
              content: '';
              border-bottom: 1px solid;
              display: block;
              width: 100%;
              padding-top: 10px;
              opacity: 0;
              transition: .4s; }
            header #header .menu_wrap ul li a:hover {
              opacity: 1; }
              header #header .menu_wrap ul li a:hover:after {
                opacity: 1;
                transform: translateY(-6px); }
          header #header .menu_wrap ul li.contact {
            transition: 0.3s;
            width: 160px;
            width: 18%;
            margin: 0;
            border: none;
            background: #fff; }
            header #header .menu_wrap ul li.contact a {
              font-size: 1.4rem;
              height: 50px;
              line-height: 25px;
              color: #80111B;
              background: rgba(255, 255, 255, 0); }
              header #header .menu_wrap ul li.contact a:after {
                display: none; }
            header #header .menu_wrap ul li.contact:hover {
              transition: 0.3s;
              opacity: 0.8; }
      header #header .menu_wrap.temp_con {
        right: auto;
        left: 50%;
        transform: translate(-50%, -50%); }
  header #header_test {
    transition: .3s; }
    header #header_test .logo {
      left: 2%; }
    header #header_test .menu_btn {
      display: none; }
    header #header_test .menu_wrap {
      transition: .3s;
      background: none;
      padding-bottom: 0;
      height: auto;
      margin: auto;
      right: 2%;
      top: 50%;
      left: auto;
      transform: translateY(-50%);
      width: 80%;
      max-width: 800px; }
      header #header_test .menu_wrap ul {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-flow: row wrap;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
        -webkit-box-align: stretch;
        -webkit-align-items: stretch;
        -ms-flex-align: stretch;
        align-items: stretch;
        -webkit-align-content: flex-start;
        -ms-flex-line-pack: start;
        align-content: flex-start;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        position: static;
        transform: none; }
        header #header_test .menu_wrap ul li {
          flex: 0 1 auto;
          width: auto;
          max-width: auto; }
          header #header_test .menu_wrap ul li a {
            padding: 15px 5px 5px;
            font-size: 1.4rem; }
            header #header_test .menu_wrap ul li a:after {
              content: '';
              border-bottom: 1px solid;
              display: block;
              width: 100%;
              padding-top: 10px;
              opacity: 0;
              transition: .4s; }
            header #header_test .menu_wrap ul li a:hover {
              opacity: 1; }
              header #header_test .menu_wrap ul li a:hover:after {
                opacity: 1;
                transform: translateY(-6px); }
          header #header_test .menu_wrap ul li.contact {
            transition: 0.3s;
            width: 160px;
            width: 18%;
            margin: 0;
            border: none;
            background: #fff; }
            header #header_test .menu_wrap ul li.contact a {
              font-size: 1.4rem;
              height: 50px;
              line-height: 25px;
              color: #80111B;
              background: rgba(255, 255, 255, 0); }
              header #header_test .menu_wrap ul li.contact a:after {
                display: none; }
            header #header_test .menu_wrap ul li.contact:hover {
              transition: 0.3s;
              opacity: 0.8; }
      header #header_test .menu_wrap.temp_con {
        right: auto;
        left: 50%;
        transform: translate(-50%, -50%); }
  header.hidden #header {
    height: 220px; }
    header.hidden #header .logo {
      transform: none;
      position: static;
      margin: auto;
      width: 80px;
      height: auto;
      padding: 20px 0 30px; }
      header.hidden #header .logo img {
        height: auto;
        width: 100%; }
    header.hidden #header .menu_wrap {
      transform: none;
      position: static; } }
/*------------------------------
		1200px以上
------------------------------*/
/* Scss Document */
footer {
  background: url("/img/common/main_back.png") center/cover no-repeat;
  color: #fff;
  text-align: center;
  padding: 40px 20px 10px; }
  footer #gotop {
    position: fixed;
    display: block;
    right: 10px;
    bottom: 60px;
    width: 50px;
    height: 20px;
    transform: rotate(-90deg);
    cursor: pointer;
    transition: .3s; }
    footer #gotop:hover {
      transform: rotate(-90deg) translateX(10px); }
    footer #gotop:before, footer #gotop:after {
      content: '';
      display: block;
      background: #80111B;
      height: 1px;
      position: absolute; }
    footer #gotop:before {
      width: 50px;
      left: 0;
      top: 20px; }
    footer #gotop:after {
      width: 10px;
      right: -1px;
      transform: rotate(45deg);
      top: 16px; }
  footer .foot_wrap .pc_wrap {
    margin-bottom: 5%;
    padding-bottom: 5%;
    border-bottom: solid 1px #fff; }
    footer .foot_wrap .pc_wrap .company_name_box {
      text-align: justify;
      margin-bottom: 20px; }
      footer .foot_wrap .pc_wrap .company_name_box .company_name {
        font-size: 1.6rem; }
        @media (min-width: 768px) {
          footer .foot_wrap .pc_wrap .company_name_box .company_name {
            font-size: calc( 1.6rem + ( 1vw - 7.68px ) * 2.734375 ); } }
        @media (min-width: 1280px) {
          footer .foot_wrap .pc_wrap .company_name_box .company_name {
            font-size: 3rem; } }
        footer .foot_wrap .pc_wrap .company_name_box .company_name.temp_ttl {
          font-size: 1.6rem;
          font-weight: bold; }
          @media (min-width: 768px) {
            footer .foot_wrap .pc_wrap .company_name_box .company_name.temp_ttl {
              font-size: calc( 1.6rem + ( 1vw - 7.68px ) * 1.7578125 ); } }
          @media (min-width: 1280px) {
            footer .foot_wrap .pc_wrap .company_name_box .company_name.temp_ttl {
              font-size: 2.5rem; } }
      footer .foot_wrap .pc_wrap .company_name_box .street_address {
        font-size: 1.2rem; }
        @media (min-width: 768px) {
          footer .foot_wrap .pc_wrap .company_name_box .street_address {
            font-size: calc( 1.2rem + ( 1vw - 7.68px ) * 0.390625 ); } }
        @media (min-width: 1280px) {
          footer .foot_wrap .pc_wrap .company_name_box .street_address {
            font-size: 1.4rem; } }
      footer .foot_wrap .pc_wrap .company_name_box .tell {
        font-size: 1.2rem; }
        @media (min-width: 768px) {
          footer .foot_wrap .pc_wrap .company_name_box .tell {
            font-size: calc( 1.2rem + ( 1vw - 7.68px ) * 0.462962963 ); } }
        @media (min-width: 1200px) {
          footer .foot_wrap .pc_wrap .company_name_box .tell {
            font-size: 1.4rem; } }
        footer .foot_wrap .pc_wrap .company_name_box .tell a {
          position: relative; }
          footer .foot_wrap .pc_wrap .company_name_box .tell a .tell_img {
            line-height: 0; }
            footer .foot_wrap .pc_wrap .company_name_box .tell a .tell_img img {
              width: 3%;
              margin-bottom: 5px; }
    footer .foot_wrap .pc_wrap.bor_none {
      margin-bottom: 0;
      padding-bottom: 0;
      border-bottom: none; }
  footer .foot_wrap .flex_wrap .left_box {
    flex: 0 1 100%;
    width: 100%;
    max-width: 100%; }
  footer .foot_wrap .flex_wrap .right_box {
    flex: 0 1 100%;
    width: 100%;
    max-width: 100%; }
  footer .foot_wrap .flex_wrap .toggle {
    margin-bottom: 4%; }
    footer .foot_wrap .flex_wrap .toggle .t_btn {
      font-size: 1.2rem;
      width: 100%;
      text-align: center;
      padding: 2% 0;
      color: #fff;
      border: solid 1px #fff;
      margin-bottom: 2%;
      position: relative;
      cursor: pointer; }
      @media (min-width: 768px) {
        footer .foot_wrap .flex_wrap .toggle .t_btn {
          font-size: calc( 1.2rem + ( 1vw - 7.68px ) * 0.462962963 ); } }
      @media (min-width: 1200px) {
        footer .foot_wrap .flex_wrap .toggle .t_btn {
          font-size: 1.4rem; } }
      footer .foot_wrap .flex_wrap .toggle .t_btn .arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 15px;
        height: 15px;
        right: 10px; }
        footer .foot_wrap .flex_wrap .toggle .t_btn .arrow:before {
          position: absolute;
          content: "";
          width: 1px;
          height: 100%;
          background: #fff;
          top: 50%;
          left: 50%;
          transform: translateX(-50%) translateY(-50%); }
        footer .foot_wrap .flex_wrap .toggle .t_btn .arrow:after {
          position: absolute;
          content: "";
          height: 1px;
          width: 100%;
          background: #fff;
          top: 50%;
          left: 50%;
          transform: translateX(-50%) translateY(-50%); }
      footer .foot_wrap .flex_wrap .toggle .t_btn.active .arrow:before {
        display: none; }
    footer .foot_wrap .flex_wrap .toggle .sales_txt {
      font-size: 1.1rem;
      text-align: justify;
      display: none;
      margin-bottom: 4%; }
      @media (min-width: 768px) {
        footer .foot_wrap .flex_wrap .toggle .sales_txt {
          font-size: calc( 1.1rem + ( 1vw - 7.68px ) * 0.2314814815 ); } }
      @media (min-width: 1200px) {
        footer .foot_wrap .flex_wrap .toggle .sales_txt {
          font-size: 1.2rem; } }
  footer .foot_wrap.test {
    font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro","sans-serif"; }
    footer .foot_wrap.test .pc_wrap .btn {
      font-weight: bold; }
  footer .btn a {
    font-size: 1.4rem;
    background: #fff;
    color: #80111B;
    width: 100%;
    height: 75px;
    padding: 0;
    line-height: 75px;
    margin-bottom: 4%;
    box-shadow: 0px 0px 0px rgba(0, 0, 0, 0);
    border: solid 1px #fff;
    max-width: 100%; }
    @media (min-width: 768px) {
      footer .btn a {
        font-size: calc( 1.4rem + ( 1vw - 7.68px ) * 0.9259259259 ); } }
    @media (min-width: 1200px) {
      footer .btn a {
        font-size: 1.8rem; } }
    footer .btn a:after {
      display: none; }
  footer .copyright {
    font-size: 1rem;
    text-align: center;
    margin: 70px auto 0; }

/*------------------------------
		768px以上
------------------------------*/
@media screen and (min-width: 769px) {
  footer {
    padding: 60px 20px 10px; }
    footer .foot_wrap .pc_wrap {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
      -webkit-flex-flow: row wrap;
      -ms-flex-flow: row wrap;
      flex-flow: row wrap;
      -webkit-box-align: stretch;
      -webkit-align-items: stretch;
      -ms-flex-align: stretch;
      align-items: stretch;
      -webkit-align-content: flex-start;
      -ms-flex-line-pack: start;
      align-content: flex-start;
      -webkit-box-pack: justify;
      -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
      justify-content: space-between;
      margin-bottom: 1%;
      padding-bottom: 1%; }
      footer .foot_wrap .pc_wrap .company_name_box {
        flex: 0 1 49%;
        width: 49%;
        max-width: 49%;
        text-align: justify;
        margin-bottom: 0; }
        footer .foot_wrap .pc_wrap .company_name_box .company_name {
          transition: 0.3s;
          cursor: pointer; }
          footer .foot_wrap .pc_wrap .company_name_box .company_name:hover {
            transition: 0.3s;
            opacity: 0.7; }
        footer .foot_wrap .pc_wrap .company_name_box .tell a .tell_img {
          top: -8px; }
        footer .foot_wrap .pc_wrap .company_name_box .tell a .tell_txt {
          transition: 0.3s; }
        footer .foot_wrap .pc_wrap .company_name_box .tell a:hover {
          opacity: 0.7; }
          footer .foot_wrap .pc_wrap .company_name_box .tell a:hover .tell_txt {
            transition: 0.3s;
            opacity: 0.7; }
      footer .foot_wrap .pc_wrap .btn {
        flex: 0 1 49%;
        width: 49%;
        max-width: 49%;
        margin: 0; }
        footer .foot_wrap .pc_wrap .btn a {
          margin: auto 0 auto auto; }
    footer .foot_wrap .flex_wrap .left_box {
      flex: 0 1 49%;
      width: 49%;
      max-width: 49%; }
    footer .foot_wrap .flex_wrap .right_box {
      flex: 0 1 49%;
      width: 49%;
      max-width: 49%; }
    footer .foot_wrap .flex_wrap .toggle {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
      -webkit-flex-flow: row wrap;
      -ms-flex-flow: row wrap;
      flex-flow: row wrap;
      -webkit-box-align: stretch;
      -webkit-align-items: stretch;
      -ms-flex-align: stretch;
      align-items: stretch;
      -webkit-align-content: flex-start;
      -ms-flex-line-pack: start;
      align-content: flex-start;
      -webkit-box-pack: justify;
      -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
      justify-content: space-between;
      align-items: flex-start;
      margin: 0; }
      footer .foot_wrap .flex_wrap .toggle .t_btn {
        flex: 0 1 30%;
        width: 30%;
        max-width: 30%;
        width: 100%;
        cursor: default; }
      footer .foot_wrap .flex_wrap .toggle .sales_txt {
        flex: 0 1 65%;
        width: 65%;
        max-width: 65%;
        display: block !important; }
    footer .btn {
      margin: auto; }
      footer .btn a {
        border: solid 1px #80111B;
        cursor: pointer;
        margin: auto; }
        footer .btn a:hover {
          opacity: 0.7; } }
/*------------------------------
		980px以上
------------------------------*/
@media screen and (min-width: 981px) {
  footer .btn a {
    width: 70%; } }
/*------------------------------
		1280px以上
------------------------------*/
body {
  letter-spacing: 0.15em;
  line-height: 1.875;
  font-size: 1.4rem;
  font-family: "kanjyuku", YuGothic, "Yu Gothic medium", "Hiragino Sans", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "sans-serif";
  position: relative;
  word-wrap: break-word; }

.of {
  overflow: hidden; }

.fl {
  float: left; }

.fr {
  float: right; }

.mt10 {
  margin-top: 10px; }

.mr10 {
  margin-right: 10px; }

.mb10 {
  margin-bottom: 10px; }

.ml10 {
  margin-left: 10px; }

.mt20 {
  margin-top: 20px; }

.mr20 {
  margin-right: 20px; }

.mb20 {
  margin-bottom: 20px; }

.ml20 {
  margin-left: 20px; }

.mt30 {
  margin-top: 30px; }

.mr30 {
  margin-right: 30px; }

.mb30 {
  margin-bottom: 30px; }

.ml30 {
  margin-left: 30px; }

.pl10 {
  padding-left: 10px; }

.pr10 {
  padding-right: 10px; }

.pt10 {
  padding-top: 10px; }

.pb10 {
  padding-bottom: 10px; }

.t_center {
  text-align: center; }

.t_left {
  text-align: left; }

.t_right {
  text-align: right; }

.sp_only {
  display: inherit; }
  @media screen and (min-width: 769px) {
    .sp_only {
      display: none; } }
  @media screen and (min-width: 981px) {
    .sp_only {
      display: none; } }

.tab_only {
  display: none; }
  @media screen and (min-width: 769px) {
    .tab_only {
      display: inherit; } }
  @media screen and (min-width: 981px) {
    .tab_only {
      display: none; } }

.sp_tab_only {
  display: inherit; }
  @media screen and (min-width: 769px) {
    .sp_tab_only {
      display: inherit; } }
  @media screen and (min-width: 981px) {
    .sp_tab_only {
      display: none; } }

.pc_tab_only {
  display: none; }
  @media screen and (min-width: 769px) {
    .pc_tab_only {
      display: inherit; } }
  @media screen and (min-width: 981px) {
    .pc_tab_only {
      display: inherit; } }

.pc_only {
  display: none; }
  @media screen and (min-width: 769px) {
    .pc_only {
      display: none; } }
  @media screen and (min-width: 981px) {
    .pc_only {
      display: inherit; } }

a, button {
  text-decoration: none;
  color: inherit;
  transition: .4s; }

img {
  width: 100%;
  vertical-align: bottom; }

.w1600 {
  box-sizing: border-box;
  width: 100%;
  max-width: 1600px;
  margin: auto;
  padding: 0 4%; }
  @media screen and (min-width: 981px) {
    .w1600 {
      padding: 0 2%; } }
  @media screen and (min-width: 1141px) {
    .w1600 {
      padding: 0; } }

.w1200 {
  box-sizing: border-box;
  width: 100%;
  max-width: 1200px;
  margin: auto;
  padding: 0 4%; }
  @media screen and (min-width: 981px) {
    .w1200 {
      padding: 0 2%; } }
  @media screen and (min-width: 1141px) {
    .w1200 {
      padding: 0; } }

.w980 {
  box-sizing: border-box;
  width: 100%;
  max-width: 980px;
  margin: auto;
  padding: 0 4%; }
  @media screen and (min-width: 981px) {
    .w980 {
      padding: 0 2%; } }
  @media screen and (min-width: 1141px) {
    .w980 {
      padding: 0; } }

h1 {
  font-size: 1rem;
  font-weight: normal;
  letter-spacing: normal;
  line-height: 1;
  position: absolute;
  bottom: 5px;
  left: 0;
  right: 0;
  color: #fff;
  z-index: 999;
  height: auto;
  padding: 0 4%;
  text-align: center;
  opacity: 0.8; }

h2 {
  font-size: 2.8rem;
  text-align: center;
  font-weight: normal; }
  @media (min-width: 768px) {
    h2 {
      font-size: calc( 2.8rem + ( 1vw - 7.68px ) * 2.34375 ); } }
  @media (min-width: 1280px) {
    h2 {
      font-size: 4rem; } }

h3 {
  font-size: 2.4rem;
  text-align: center;
  font-weight: normal; }
  @media (min-width: 768px) {
    h3 {
      font-size: calc( 2.4rem + ( 1vw - 7.68px ) * 1.171875 ); } }
  @media (min-width: 1280px) {
    h3 {
      font-size: 3rem; } }

p {
  font-size: 100%; }

.en {
  font-family: "beaunormal", "serif";
  letter-spacing: normal; }

i {
  margin-right: 5px; }

a:hover {
  opacity: 0.8; }

.flex_wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-align-content: flex-start;
  -ms-flex-line-pack: start;
  align-content: flex-start;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }

.is-empty {
  margin: 0 !important;
  padding: 0 !important; }

.box {
  margin-bottom: 26.6666666667%; }

.attention {
  font-size: 1rem;
  letter-spacing: normal;
  color: #666; }

.cap {
  font-size: 1rem;
  letter-spacing: normal;
  line-height: 1;
  position: absolute;
  left: 5px;
  bottom: 5px;
  z-index: 1;
  text-shadow: 0 1px 0 #fff, 1px 0 0 #fff, 0 -1px 0 #fff, -1px 0 0 #fff, -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff; }

.kome_wrap {
  position: relative; }
  .kome_wrap .kome {
    position: absolute;
    right: -10px;
    top: -15px;
    font-size: 1rem !important;
    color: #AEAEAE !important;
    line-height: normal !important; }

#breadcrumb {
  margin-top: 10px;
  font-size: 1.2rem;
  letter-spacing: normal; }
  #breadcrumb a {
    padding-right: 15px;
    position: relative;
    color: #80111B; }
    #breadcrumb a:after {
      content: '';
      position: absolute;
      width: 4px;
      height: 4px;
      border-top: 1px solid;
      border-right: 1px solid;
      top: 50%;
      transform: rotate(45deg) translate(0%, -50%);
      right: 8px; }

/*下層ページタイトル*/
#titleimg {
  background-size: cover;
  background-position: center;
  height: 45vw;
  max-height: 340px;
  position: relative;
  margin-bottom: 10%;
  overflow: hidden; }
  #titleimg h2 {
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.8rem;
    z-index: 2;
    color: #fff;
    line-height: 1.8;
    width: auto;
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2); }
    @media (min-width: 768px) {
      #titleimg h2 {
        font-size: calc( 1.8rem + ( 1vw - 7.68px ) * 1.3671875 ); } }
    @media (min-width: 1280px) {
      #titleimg h2 {
        font-size: 2.5rem; } }
    #titleimg h2:after {
      content: '';
      border-bottom: 1px solid;
      display: block;
      width: 100%; }
  #titleimg:after {
    content: '';
    background: rgba(0, 0, 0, 0.6);
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    z-index: 1; }

.btn a {
  color: #fff;
  font-size: 1.4rem;
  text-align: center;
  max-width: 380px;
  width: 90%;
  margin: auto;
  padding: 20px;
  display: block;
  box-sizing: border-box;
  background: #80111B;
  position: relative;
  border: 1px solid #80111B; }
  @media (min-width: 768px) {
    .btn a {
      font-size: calc( 1.4rem + ( 1vw - 7.68px ) * 0.390625 ); } }
  @media (min-width: 1280px) {
    .btn a {
      font-size: 1.6rem; } }
  .btn a:after {
    content: '';
    position: absolute;
    width: 100%;
    top: 50%;
    transform: translateY(-50%);
    position: absolute;
    width: 4px;
    height: 4px;
    border-top: 1px solid;
    border-right: 1px solid;
    top: 50%;
    transform: rotate(45deg) translate(0%, -50%);
    border-color: #fff;
    right: 20px;
    font-size: 1.4rem; }
  .btn a:hover {
    color: #80111B;
    background: #fff;
    opacity: 1; }
    .btn a:hover:after {
      border-color: #80111B; }
.btn.ye a {
  background: #80111B;
  border: 1px solid #80111B; }
  .btn.ye a:hover {
    color: #80111B;
    background: #fff; }

.contact_box .contact_wrap {
  border-top: solid 1px #000;
  border-bottom: solid 1px #000;
  padding: 5% 0; }
  .contact_box .contact_wrap .txt {
    letter-spacing: 0.0em;
    text-align: center;
    margin-bottom: 8%; }
    .contact_box .contact_wrap .txt .contact_title {
      font-size: 1.8rem; }
      @media (min-width: 786px) {
        .contact_box .contact_wrap .txt .contact_title {
          font-size: calc( 1.8rem + ( 1vw - 7.86px ) * 0.4830917874 ); } }
      @media (min-width: 1200px) {
        .contact_box .contact_wrap .txt .contact_title {
          font-size: 2rem; } }
    .contact_box .contact_wrap .txt .contact_txt {
      font-size: 1.3rem; }
      @media (min-width: 786px) {
        .contact_box .contact_wrap .txt .contact_txt {
          font-size: calc( 1.3rem + ( 1vw - 7.86px ) * 0.7246376812 ); } }
      @media (min-width: 1200px) {
        .contact_box .contact_wrap .txt .contact_txt {
          font-size: 1.6rem; } }
  .contact_box .contact_wrap .contact_btn a {
    font-size: 2rem;
    background: #BA9632;
    border: solid 1px #BA9632;
    color: #fff;
    max-width: 380px;
    width: 90%;
    margin: auto;
    padding: 10px;
    display: block;
    box-sizing: border-box;
    text-align: center;
    box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.2); }
    .contact_box .contact_wrap .contact_btn a:hover {
      background: #fff;
      color: #BA9632;
      opacity: 1; }

.more {
  text-align: center; }
  .more a {
    display: inline-block;
    padding: 5px;
    position: relative;
    padding-right: 10px; }
    .more a:after {
      content: '';
      border-bottom: 1px solid;
      display: block;
      width: 100%;
      padding-top: 4px; }
    .more a:before {
      content: '';
      display: block;
      position: absolute;
      width: 4px;
      height: 4px;
      border-top: 1px solid;
      border-right: 1px solid;
      top: 50%;
      transform: rotate(45deg) translate(0%, -50%);
      top: 45%;
      right: 0px; }
    .more a:hover {
      opacity: 1;
      letter-spacing: 0.3em; }

.radio-input {
  display: none;
  cursor: pointer; }
  .radio-input:checked + .radio-parts {
    color: #80111B; }
    .radio-input:checked + .radio-parts:after {
      content: "";
      display: block;
      position: absolute;
      top: 8px;
      left: 4px;
      width: 7px;
      height: 7px;
      background: #80111B;
      border-radius: 50%; }

.radio-parts {
  padding-left: 20px;
  position: relative;
  margin-right: 20px;
  line-height: 1;
  cursor: pointer; }
  .radio-parts:before {
    content: "";
    display: block;
    position: absolute;
    top: 4px;
    left: 0;
    width: 13px;
    height: 13px;
    border: 1px solid #999;
    border-radius: 50%; }

.title {
  text-align: center;
  margin-bottom: 5%;
  font-size: 2rem; }
  @media (min-width: 768px) {
    .title {
      font-size: calc( 2rem + ( 1vw - 7.68px ) * 0.78125 ); } }
  @media (min-width: 1280px) {
    .title {
      font-size: 2.4rem; } }

.copy {
  text-align: center;
  font-size: 1.4rem; }
  @media (min-width: 768px) {
    .copy {
      font-size: calc( 1.4rem + ( 1vw - 7.68px ) * 0.390625 ); } }
  @media (min-width: 1280px) {
    .copy {
      font-size: 1.6rem; } }

#contents {
  margin-top: 80px; }

.conversion {
  max-width: 850px;
  margin: auto; }
  .conversion .comment {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start; }
    .conversion .comment .fukidashi {
      flex: 0 1 68%;
      width: 68%;
      max-width: 68%;
      position: relative;
      box-shadow: 0 0 3px rgba(0, 0, 0, 0.4);
      box-sizing: border-box;
      background: #80111B;
      color: #fff;
      text-align: center;
      padding: 15px 0;
      border-radius: 50px;
      font-size: 1.8rem;
      font-weight: bold; }
      @media (min-width: 768px) {
        .conversion .comment .fukidashi {
          font-size: calc( 1.8rem + ( 1vw - 7.68px ) * 1.5625 ); } }
      @media (min-width: 1280px) {
        .conversion .comment .fukidashi {
          font-size: 2.6rem; } }
      .conversion .comment .fukidashi span {
        font-size: 1.4rem; }
        @media (min-width: 768px) {
          .conversion .comment .fukidashi span {
            font-size: calc( 1.4rem + ( 1vw - 7.68px ) * 1.3671875 ); } }
        @media (min-width: 1280px) {
          .conversion .comment .fukidashi span {
            font-size: 2.1rem; } }
      .conversion .comment .fukidashi:after {
        content: '';
        position: absolute;
        width: 100%;
        top: 50%;
        transform: translateY(-50%);
        width: 20px;
        height: 20px;
        background: url("/img/home/fukidashi.png") center/cover no-repeat;
        right: -18px; }
    .conversion .comment .img {
      flex: 0 1 32%;
      width: 32%;
      max-width: 32%; }
  .conversion .conversion_wrap {
    border: 4px solid #80111B;
    box-shadow: 20px 20px 0 rgba(229, 191, 35, 0.6);
    padding: 40px 4%; }
    .conversion .conversion_wrap .remort {
      text-align: center;
      font-weight: bold;
      color: #80111B;
      font-size: 1.6rem; }
    .conversion .conversion_wrap .tel {
      margin-bottom: 20px;
      text-align: center; }
      .conversion .conversion_wrap .tel a {
        font-size: 3.4rem;
        letter-spacing: normal;
        line-height: 1.2; }
        @media (min-width: 320px) {
          .conversion .conversion_wrap .tel a {
            font-size: calc( 3.4rem + ( 1vw - 3.2px ) * 10.2678571429 ); } }
        @media (min-width: 768px) {
          .conversion .conversion_wrap .tel a {
            font-size: 8rem; } }
        .conversion .conversion_wrap .tel a .icon {
          width: 14%;
          max-width: 60px;
          display: inline-block;
          vertical-align: middle;
          line-height: 0;
          margin-top: -5px; }
      .conversion .conversion_wrap .tel .time {
        font-size: 1.5rem; }
    .conversion .conversion_wrap .contact_btn {
      text-align: center; }
      .conversion .conversion_wrap .contact_btn p {
        color: #80111B;
        position: relative;
        margin-bottom: 10px;
        font-size: 1.9rem;
        display: inline-block; }
        .conversion .conversion_wrap .contact_btn p:before, .conversion .conversion_wrap .contact_btn p:after {
          content: '';
          width: 1px;
          height: 20px;
          border-radius: 4px;
          background: #80111B;
          position: absolute;
          bottom: 0; }
        .conversion .conversion_wrap .contact_btn p:before {
          transform: rotate(-25deg);
          left: -10px; }
        .conversion .conversion_wrap .contact_btn p:after {
          transform: rotate(25deg);
          right: -10px; }
      .conversion .conversion_wrap .contact_btn .btn {
        margin: 0 auto; }
        .conversion .conversion_wrap .contact_btn .btn a {
          background: #80111B;
          border: 1px solid #80111B;
          width: 100%;
          border-radius: 6px;
          font-weight: bold;
          padding: 10px 0;
          font-size: 2.3rem; }
          .conversion .conversion_wrap .contact_btn .btn a:hover {
            color: #80111B;
            background: #fff; }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) {
  .box {
    margin-bottom: 15%; }

  h1 {
    bottom: 10px; }

  .contact_box .contact_wrap .txt {
    margin-bottom: 3.3333333333%; }

  .conversion .comment {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 90%;
    margin: auto; }
  .conversion .conversion_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center; }
    .conversion .conversion_wrap .tel {
      margin-bottom: 0;
      flex: 0 1 54%;
      width: 54%;
      max-width: 54%; }
      .conversion .conversion_wrap .tel a {
        font-size: 5rem; } }
      @media screen and (min-width: 769px) and (min-width: 768px) {
        .conversion .conversion_wrap .tel a {
          font-size: calc( 5rem + ( 1vw - 7.68px ) * 1.171875 ); } }
      @media screen and (min-width: 769px) and (min-width: 1280px) {
        .conversion .conversion_wrap .tel a {
          font-size: 5.6rem; } }
@media screen and (min-width: 769px) {
      .conversion .conversion_wrap .tel .time {
        text-align: right;
        letter-spacing: normal; }
    .conversion .conversion_wrap .contact_btn {
      flex: 0 1 42%;
      width: 42%;
      max-width: 42%; } }
/*------------------------------
		981px以上
------------------------------*/
@media screen and (min-width: 981px) {
  #contents {
    margin-top: 220px; }

  #titleimg {
    height: 25vw; }
    #titleimg:after {
      display: none; } }
/*------------------------------
		1201px以上
------------------------------*/

/*# sourceMappingURL=base.css.map */
