@charset "UTF-8";
body {
  font-family: '游ゴシック', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;
  margin: 0;
  padding: 0;
  font-size: 14px;
  position: relative;
  background: #FFF; }

body, div, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ul, ol, li,
blockquote, pre, table, caption, th, td, address,
form, fieldset, legend, object {
  margin: 0;
  padding: 0; }

header, section, navi, footer {
  display: block; }

a, ins {
  text-decoration: none; }

address, em, cite, dfn, var {
  font-style: normal; }

input, textarea {
  font-weight: normal; }

img {
  vertical-align: baseline;
  max-width: 100%;
  height: auto; }

a img {
  border: none; }

h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ul, ol, li,
blockquote, pre, table, caption, th, td, address {
  line-height: 2;
  letter-spacing: 0.05em;
  color: #000; }

h1, h2, h3, h4 {
  font-weight: normal;
  letter-spacing: 0; }

a {
  color: #000;
  transition: all .3s ease; }
  a:hover {
    opacity: 0.6; }

li {
  list-style: none; }

a[href^="tel:"] {
  cursor: default;
  opacity: 1 !important; }

br.pcn {
  display: none; }
  @media screen and (max-width: 540px) {
    br.pcn {
      display: block; } }

@media screen and (max-width: 540px) {
  br.spn {
    display: none; } }

.table {
  display: table; }
  .table .t-tr {
    display: table-row; }
    .table .t-tr .t-th, .table .t-tr .t-td {
      display: table-cell; }

@media screen and (max-width: 540px) {
  .onlyPC {
    display: none !important; } }

.onlySP {
  display: none !important; }
  @media screen and (max-width: 540px) {
    .onlySP {
      display: initial !important; } }

.anime {
  opacity: 0;
  -webkit-transform: translateY(-10px) scale(0.99, 0.99);
  transform: translateY(-10px) scale(0.99, 0.99);
  -webkit-transition: 1s;
  transition: 1s; }

.move {
  opacity: 1;
  -webkit-transform: translateY(0) scale(1, 1);
  transform: translateY(0) scale(1, 1); }

.anime-r {
  overflow: hidden;
  opacity: 0;
  -webkit-transform: translateX(20px);
  transform: translateX(20px);
  -webkit-transition: all .5s;
  transition: all .5s; }

.move-r {
  overflow: hidden;
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0); }

.anime-l {
  overflow: hidden;
  opacity: 0;
  -webkit-transform: translateX(-20px);
  transform: translateX(-20px);
  -webkit-transition: all .5s;
  transition: all .5s; }

.move-l {
  overflow: hidden;
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0); }

.anime-d {
  opacity: 0;
  -webkit-transform: translateY(-50px);
  transform: translateY(-50px);
  -webkit-transition: 1s;
  transition: 1s;
  -webkit-transition-delay: .5s;
  transition-delay: .5s; }

.move-d {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0); }

.anime-b {
  opacity: 0;
  -webkit-transform: translateY(50px);
  transform: translateY(50px);
  -webkit-transition: 1s;
  transition: 1s; }

.move-b {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0); }

.delay1 {
  -webkit-transition-delay: .15s;
  transition-delay: .15s; }
  @media screen and (max-width: 540px) {
    .delay1 {
      -webkit-transition-delay: 0;
      transition-delay: 0; } }

.delay2 {
  -webkit-transition-delay: .25s;
  transition-delay: .25s; }
  @media screen and (max-width: 540px) {
    .delay2 {
      -webkit-transition-delay: 0;
      transition-delay: 0; } }

.delay3 {
  -webkit-transition-delay: .35s;
  transition-delay: .35s; }
  @media screen and (max-width: 540px) {
    .delay3 {
      -webkit-transition-delay: 0;
      transition-delay: 0; } }

.delay4 {
  -webkit-transition-delay: .45s;
  transition-delay: .45s; }
  @media screen and (max-width: 540px) {
    .delay4 {
      -webkit-transition-delay: 0;
      transition-delay: 0; } }

.delay5 {
  -webkit-transition-delay: .55s;
  transition-delay: .55s; }
  @media screen and (max-width: 540px) {
    .delay5 {
      -webkit-transition-delay: 0;
      transition-delay: 0; } }

/* ------ navibtn -----------------------------------*/
.hnavi_btn {
  position: absolute;
  top: 20px;
  right: 12px;
  z-index: 1000;
  display: none; }
  @media screen and (max-width: 767px) {
    .hnavi_btn {
      display: block; }
      .hnavi_btn.active {
        top: 15px;
        right: 236px; } }

.menu-button {
  width: 50px;
  height: 50px;
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 100000; }
  .menu-button i {
    display: block;
    width: 50px;
    height: 2px;
    border-radius: 3px;
    background: #000;
    transition: background 0.5s;
    position: absolute;
    right: 0;
    top: 20px; }
    .menu-button i:before, .menu-button i:after {
      content: "";
      display: block;
      width: 50px;
      height: 2px;
      border-radius: 3px;
      background: #000;
      position: absolute;
      transform: rotate(0deg);
      transition: all 0.3s !important; }
    .menu-button i:before {
      transform: translateY(12px); }
    .menu-button i:after {
      transform: translateY(-12px); }

.hnavi_btn.active .menu-button i {
  background: none; }
  .hnavi_btn.active .menu-button i:after {
    transform: translateY(0px) rotate(-45deg); }
  .hnavi_btn.active .menu-button i:before {
    transform: translateY(0px) rotate(45deg); }

body {
  padding-top: 127px; }
  @media screen and (max-width: 767px) {
    body {
      padding-top: 80px; } }
  body.top {
    padding-top: 127px; }
    @media screen and (max-width: 767px) {
      body.top {
        padding-top: 80px; } }

.header {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
  box-sizing: border-box;
  padding: 0 0 0 18px;
  position: relative;
  justify-content: flex-end;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  box-sizing: border-box;
  transition: all .3s ease;
  z-index: 500;
  /*   &.active{
    height: 110px;
    @media screen and (max-width: 767px) {
      height: 80px;
    }
    .hlogo{
      img{
        width: 200px;
        @media screen and (max-width: 767px) {
          width: 140px;
        }
      }
    }
    .gnavi{
      li{
        font-size: 12px;
        @media screen and (max-width: 540px) {
          font-size: 19px;
        }
        &:nth-of-type(5),
        &:nth-of-type(6){
          font-size: 12px;
          @media screen and (max-width: 540px) {
            font-size: 19px;
          }
        }
        &:last-of-type{
          a{
            font-size: 12px;
            height: 110px;
            @media screen and (max-width: 540px) {
              font-size: 19px;
            }
          }
        }
      }
    }
  } */ }
  @media screen and (max-width: 767px) {
    .header {
      height: 80px; } }
  .header .logow {
    display: none; }
  .header .logod {
    display: inline-block; }
  .header.white .logow {
    display: inline-block; }
  .header.white .logod {
    display: none; }
  .header.white .menu-button i {
    background: #FFF; }
    .header.white .menu-button i:before, .header.white .menu-button i:after {
      background: #FFF; }
  .header.white .hnavi_btn.active .menu-button i {
    background: none; }
    .header.white .hnavi_btn.active .menu-button i:after, .header.white .hnavi_btn.active .menu-button i:before {
      background: #000; }
  .header.white .gnavi li a {
    color: #FFF; }
  .header .hlogo {
    top: 9px;
    left: 18px;
    position: absolute;
    z-index: 100;
    transition: all .3s ease; }
    .header .hlogo img {
      transition: all .3s ease; }
      @media screen and (max-width: 767px) {
        .header .hlogo img {
          width: 140px; } }
  .header .hnavi.active {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.8);
    z-index: 900; }
  .header .gnavi {
    display: flex;
    justify-content: flex-end;
    transition: all .3s ease; }
    @media screen and (max-width: 767px) {
      .header .gnavi {
        display: block;
        right: -230px;
        top: 0;
        position: fixed;
        width: 230px;
        background: #000;
        height: 100%;
        transition: all .3s ease;
        z-index: 10000;
        padding: 43px 10px 50px 20px;
        box-sizing: border-box; }
        .header .gnavi.active {
          right: 0;
          display: block; } }
    .header .gnavi li {
      writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
      white-space: nowrap;
      margin-left: 14px;
      font-size: 15px;
      font-weight: bold;
      padding-top: 7px; }
      @media screen and (max-width: 767px) {
        .header .gnavi li {
          margin: 0 0 12px;
          writing-mode: horizontal-tb;
          -ms-writing-mode: lr-tb;
          margin: 0 0 5px;
          padding-top: 0;
          font-size: 19px;
          letter-spacing: 0; } }
      .header .gnavi li a {
        text-decoration: none; }
        @media screen and (max-width: 767px) {
          .header .gnavi li a {
            color: #FFF; } }
      .header .gnavi li:nth-of-type(5), .header .gnavi li:nth-of-type(6) {
        font-weight: normal;
        font-size: 14px;
        margin-left: 17px; }
        @media screen and (max-width: 767px) {
          .header .gnavi li:nth-of-type(5), .header .gnavi li:nth-of-type(6) {
            margin: 0 0 5px;
            font-size: 19px; } }
      .header .gnavi li:last-of-type {
        padding-top: 0;
        margin-left: 22px; }
        @media screen and (max-width: 767px) {
          .header .gnavi li:last-of-type {
            margin: 0 0 5px; } }
        .header .gnavi li:last-of-type a {
          background: #000;
          color: #FFF;
          height: 127px;
          width: 60px;
          display: -webkit-flex;
          display: -moz-flex;
          display: -ms-flex;
          display: -o-flex;
          display: flex;
          flex-direction: column;
          justify-content: center;
          align-items: center;
          font-size: 14px;
          transition: all .3s ease;
          box-sizing: border-box; }
          @media screen and (max-width: 767px) {
            .header .gnavi li:last-of-type a {
              background: none;
              height: auto;
              width: 100%;
              text-align: left;
              display: block;
              font-size: 19px; } }
          .header .gnavi li:last-of-type a:hover {
            text-decoration: none;
            background: #FFF;
            border: 3px solid #000;
            color: #000;
            opacity: 1 !important; }
            @media screen and (max-width: 767px) {
              .header .gnavi li:last-of-type a:hover {
                background: #000;
                color: #FFF;
                border: none; } }

.footer {
  background: #000;
  padding-top: 90px; }
  @media screen and (max-width: 540px) {
    .footer {
      padding-top: 25px; } }
  .footer .fnavi {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 80px; }
    @media screen and (max-width: 767px) {
      .footer .fnavi {
        display: none; } }
    .footer .fnavi ul {
      margin: 0 36px; }
      @media screen and (max-width: 1000px) {
        .footer .fnavi ul {
          margin: 0 15px; } }
      .footer .fnavi ul:nth-of-type(1) {
        margin-left: 16px; }
      .footer .fnavi ul:nth-of-type(2) {
        margin-right: 26px; }
      .footer .fnavi ul:nth-of-type(3) {
        margin-right: 45px; }
      .footer .fnavi ul li {
        font-size: 14px; }
        .footer .fnavi ul li:first-of-type {
          font-size: 16px;
          font-weight: bold; }
        .footer .fnavi ul li.top {
          font-size: 14px; }
        .footer .fnavi ul li a {
          color: #FFF; }
  .footer .fcnt {
    text-align: center; }
    .footer .fcnt p {
      color: #FFF; }
      .footer .fcnt p.flogo {
        margin-bottom: 49px; }
        @media screen and (max-width: 540px) {
          .footer .fcnt p.flogo {
            margin-bottom: 6px; }
            .footer .fcnt p.flogo img {
              width: 30px; } }
      .footer .fcnt p.fname {
        font-size: 20px;
        font-weight: bold;
        margin-bottom: 11px; }
        @media screen and (max-width: 540px) {
          .footer .fcnt p.fname {
            font-size: 14px;
            margin-bottom: 0; } }
      .footer .fcnt p.faddress {
        font-size: 14px;
        margin-bottom: 34px;
        line-height: 1.715; }
        @media screen and (max-width: 540px) {
          .footer .fcnt p.faddress {
            font-size: 12px;
            margin-bottom: 24px;
            line-height: 1.5; } }
      .footer .fcnt p.sake_txt {
        font-size: 12px;
        margin-bottom: 40px;
        line-height: 1.5; }
        @media screen and (max-width: 540px) {
          .footer .fcnt p.sake_txt {
            font-size: 10px;
            margin-bottom: 23px; } }
    .footer .fcnt .fsns {
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flex;
      display: -o-flex;
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      margin-bottom: 27px; }
      @media screen and (max-width: 540px) {
        .footer .fcnt .fsns {
          margin-bottom: 20px; } }
      .footer .fcnt .fsns li {
        margin: 0 7px; }
  .footer .copyright .img {
    font-size: 0; }
    .footer .copyright .img img {
      width: 100%;
      height: auto; }
  .footer .copyright .txt {
    position: absolute;
    bottom: 15px;
    left: 0;
    width: 100%;
    text-align: center;
    font-size: 12px;
    color: #FFF; }
    @media screen and (max-width: 540px) {
      .footer .copyright .txt {
        font-size: 10px;
        bottom: 10px; } }

.top_mv {
  position: relative;
  margin-bottom: 150px; }
  @media screen and (max-width: 767px) {
    .top_mv {
      margin-bottom: 60px; } }
  @media screen and (max-width: 540px) {
    .top_mv {
      margin-bottom: 20px; } }
  .top_mv .main_copy {
    position: absolute;
    right: 0;
    top: calc(50% - 51px);
    z-index: 100; }
    @media screen and (max-width: 980px) {
      .top_mv .main_copy {
        width: 45%;
        top: calc(50% - 3vw); } }
    @media screen and (max-width: 540px) {
      .top_mv .main_copy {
        width: 78%; } }
  .top_mv ul li img {
    width: 100%;
    height: auto; }

.top_news {
  width: 1105px;
  margin: 0 auto;
  border-top: 1px solid #c9c9c9;
  border-bottom: 1px solid #c9c9c9;
  padding: 40px 42px 50px 110px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 170px;
  box-sizing: border-box; }
  @media screen and (max-width: 1150px) {
    .top_news {
      width: calc(100% - 40px);
      padding-left: 20px;
      padding-right: 20px; } }
  @media screen and (max-width: 800px) {
    .top_news {
      padding: 40px 0;
      margin-bottom: 100px;
      align-items: flex-start; } }
  @media screen and (max-width: 540px) {
    .top_news {
      padding: 25px 0 20px;
      margin-bottom: 48px; } }
  .top_news .top_news_ttl {
    font-weight: bold;
    font-size: 32px;
    writing-mode: vertical-lr;
    -ms-writing-mode: tb-lr;
    white-space: nowrap;
    margin-right: 64px;
    line-height: 1; }
    @media screen and (max-width: 800px) {
      .top_news .top_news_ttl {
        font-size: 28px;
        margin-right: 30px; } }
    @media screen and (max-width: 540px) {
      .top_news .top_news_ttl {
        font-size: 18px; } }
  .top_news ul {
    width: 620px;
    margin-right: 64px;
    box-sizing: border-box; }
    @media screen and (max-width: 1150px) {
      .top_news ul {
        width: calc(100% - 270px);
        padding-right: 30px;
        margin-right: 0; } }
    @media screen and (max-width: 800px) {
      .top_news ul {
        margin-bottom: 16px;
        width: calc(100% - 60px);
        padding-right: 0; } }
    .top_news ul li {
      font-size: 14px;
      display: flex;
      line-height: 1.4;
      margin-bottom: 13px; }
      @media screen and (max-width: 800px) {
        .top_news ul li {
          display: block; } }
      @media screen and (max-width: 540px) {
        .top_news ul li {
          font-size: 12px;
          line-height: 1.3;
          margin-bottom: 8px; } }
      .top_news ul li:last-of-type {
        margin-bottom: 0; }
      .top_news ul li .date {
        font-weight: bold;
        width: 124px;
        flex-shrink: 0; }
        @media screen and (max-width: 540px) {
          .top_news ul li .date {
            font-size: 11px;
            width: 100%;
            line-height: 1.3; } }
      @media screen and (max-width: 540px) {
        .top_news ul li .ttl {
          line-height: 1.5; } }
      @media screen and (max-width: 540px) {
        .top_news ul li {
          line-height: 1.5; } }
  @media screen and (max-width: 800px) {
    .top_news .btn {
      width: 100%; } }
  .top_news .btn a {
    width: 167px; }
    @media screen and (max-width: 800px) {
      .top_news .btn a {
        margin: 0 auto; } }
    @media screen and (max-width: 540px) {
      .top_news .btn a {
        width: 84px;
        height: 35px;
        font-size: 10px; } }
    .top_news .btn a img {
      margin-right: 8px; }
      @media screen and (max-width: 540px) {
        .top_news .btn a img {
          width: 13px; } }

.top_about {
  margin-bottom: 170px; }
  @media screen and (max-width: 540px) {
    .top_about {
      margin-bottom: 76px; } }
  .top_about .sec_ttl {
    width: 1105px;
    margin: 0 auto; }
    @media all and (-ms-high-contrast: none) {
      .top_about .sec_ttl {
        height: 6em;
        -ms-writing-mode: lr-tb; }
        .top_about .sec_ttl span {
          writing-mode: vertical-lr;
          -ms-writing-mode: tb-lr; } }
    @supports (-ms-ime-align: auto) {
      .top_about .sec_ttl {
        height: 6em;
        -ms-writing-mode: lr-tb;
        writing-mode: horizontal-tb; }
        .top_about .sec_ttl span {
          writing-mode: vertical-lr;
          -ms-writing-mode: tb-lr; } }
    @media screen and (max-width: 1150px) {
      .top_about .sec_ttl {
        width: 100%;
        padding: 0 20px;
        box-sizing: border-box; } }
    @media screen and (max-width: 560px) {
      .top_about .sec_ttl {
        padding: 0 0 0 3px; } }
  .top_about ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 50px; }
    @media screen and (max-width: 560px) {
      .top_about ul {
        display: block;
        overflow: hidden;
        margin-bottom: 19px; } }
    .top_about ul li {
      font-size: 0; }
      .top_about ul li.img1 {
        padding-top: 60px;
        width: 60%; }
        @media screen and (max-width: 560px) {
          .top_about ul li.img1 {
            width: 88%;
            margin-bottom: 25px;
            padding-top: 12px; } }
      .top_about ul li.img2 {
        width: 34.4%; }
        @media screen and (max-width: 560px) {
          .top_about ul li.img2 {
            width: 56%;
            float: right; } }
      .top_about ul li img {
        width: 100%;
        height: auto; }
  .top_about .cnt {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: center; }
    @media screen and (max-width: 680px) {
      .top_about .cnt {
        display: block;
        padding: 0 20px; } }
    .top_about .cnt .txt {
      font-size: 18px;
      font-weight: bold;
      margin-right: 56px; }
      @media screen and (max-width: 800px) {
        .top_about .cnt .txt {
          font-size: 15px;
          margin-right: 30px; } }
      @media screen and (max-width: 680px) {
        .top_about .cnt .txt {
          margin-bottom: 25px; } }
      @media screen and (max-width: 560px) {
        .top_about .cnt .txt {
          font-size: 13px;
          margin-right: 0;
          margin-bottom: 13px;
          line-height: 1.85;
          text-align: justify; } }

.top_products {
  width: 1205px;
  margin: 0 auto 183px;
  display: flex;
  justify-content: flex-end; }
  @media screen and (max-width: 1245px) {
    .top_products {
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box; } }
  @media screen and (max-width: 980px) {
    .top_products {
      padding-left: 10%; } }
  @media screen and (max-width: 560px) {
    .top_products {
      margin-bottom: 75px; } }
  .top_products .cnt .img {
    margin-bottom: 20px; }
  .top_products .cnt .txt {
    font-size: 18px;
    font-weight: bold;
    margin-right: 56px;
    margin-bottom: 20px; }
    @media screen and (max-width: 560px) {
      .top_products .cnt .txt {
        font-size: 13px;
        line-height: 1.85;
        margin-right: 0;
        margin-bottom: 13px; } }

.top_img {
  font-size: 0;
  margin-bottom: 170px; }
  @media screen and (max-width: 560px) {
    .top_img {
      margin-bottom: 60px; } }
  .top_img img {
    width: 100%;
    height: auto; }

.top_cnt {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 180px; }
  @media screen and (max-width: 560px) {
    .top_cnt {
      display: block;
      margin-bottom: 70px; } }
  .top_cnt .sec_ttl {
    writing-mode: horizontal-tb;
    -ms-writing-mode: lr-tb; }
  .top_cnt .img {
    margin-bottom: 5px; }
    @media screen and (max-width: 560px) {
      .top_cnt .img {
        font-size: 0;
        margin-bottom: 2px; } }
    .top_cnt .img img {
      width: 100%;
      height: auto; }
  .top_cnt .link a {
    font-size: 18px;
    font-weight: bold;
    display: inline-block;
    position: relative; }
    @media screen and (max-width: 560px) {
      .top_cnt .link a {
        font-size: 12px; } }
    .top_cnt .link a:before {
      content: '';
      width: 100%;
      height: 3px;
      background: #000;
      display: block;
      position: absolute;
      bottom: 0;
      left: 0;
      transition: all .6s ease; }
    .top_cnt .link a:hover {
      text-decoration: none; }
      .top_cnt .link a:hover:before {
        width: 0; }
  .top_cnt .top_info {
    width: 48.5%;
    text-align: right; }
    @media screen and (max-width: 560px) {
      .top_cnt .top_info {
        width: calc(100% - 40px);
        margin-bottom: 66px; } }
  .top_cnt .top_company {
    width: 39.5%;
    padding-top: 172px; }
    @media screen and (max-width: 560px) {
      .top_cnt .top_company {
        width: 100%;
        padding-left: 30%;
        box-sizing: border-box;
        padding-top: 0; } }

.sec_ttl {
  font-size: 40px;
  font-weight: bold;
  writing-mode: vertical-lr;
  -ms-writing-mode: tb-lr;
  white-space: nowrap;
  font-size: 42px; }
  @media screen and (max-width: 767px) {
    .sec_ttl {
      font-size: 30px; } }
  @media screen and (max-width: 560px) {
    .sec_ttl {
      font-size: 25px; } }

.btn a {
  width: 257px;
  height: 70px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  align-items: center;
  color: #FFF;
  font-size: 14px;
  background: #000;
  font-weight: bold;
  transition: all .6s ease;
  transition: background-color .3s ease;
  box-sizing: border-box; }
  @media screen and (max-width: 560px) {
    .btn a {
      width: 130px;
      font-size: 10px;
      height: 35px; } }
  .btn a:hover {
    background: #FFF;
    border: 3px solid #000;
    color: #000;
    opacity: 1 !important; }

.page_mv {
  background: url("../img/about/about_ttl_bg.jpg") no-repeat center;
  background-size: cover;
  height: 570px;
  margin-bottom: 175px; }
  @media screen and (max-width: 560px) {
    .page_mv {
      height: 285px;
      margin-bottom: 45px; } }
  .page_mv .page_ttl {
    width: 1265px;
    height: 100%;
    box-sizing: border-box;
    padding-bottom: 27px;
    margin: 0 auto;
    display: flex;
    justify-content: flex-start;
    align-items: flex-end; }
    @media screen and (max-width: 1305px) {
      .page_mv .page_ttl {
        padding: 0 20px 27px;
        width: 100%;
        box-sizing: border-box; } }
    @media screen and (max-width: 560px) {
      .page_mv .page_ttl {
        padding: 0 20px 10px; }
        .page_mv .page_ttl img {
          width: auto;
          height: 30px; } }

.about .page_mv {
  background: url("../img/about/about_ttl_bg.jpg") no-repeat center;
  background-size: cover; }

.about .about_cnt {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  flex-direction: row-reverse; }
  @media screen and (max-width: 767px) {
    .about .about_cnt {
      display: block;
      padding: 0 20px; } }
  @media screen and (max-width: 560px) {
    .about .about_cnt {
      margin-bottom: 75px; } }
  .about .about_cnt .sec_ttl {
    font-size: 90px;
    margin-left: 115px;
    margin-top: -10px; }
    @media screen and (max-width: 1000px) {
      .about .about_cnt .sec_ttl {
        margin-left: 60px;
        font-size: 60px;
        line-height: 1; } }
    @media screen and (max-width: 767px) {
      .about .about_cnt .sec_ttl {
        writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
        display: block;
        margin: 0 0 50px;
        font-size: 40px; } }
    @media screen and (max-width: 560px) {
      .about .about_cnt .sec_ttl {
        font-size: 30px;
        margin-bottom: 43px; } }
  .about .about_cnt .txt {
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl; }
    @media screen and (max-width: 767px) {
      .about .about_cnt .txt {
        writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb; } }
    .about .about_cnt .txt p {
      margin-left: 40px;
      font-size: 16px;
      font-weight: bold;
      line-height: 2.5; }
      @media screen and (max-width: 1000px) {
        .about .about_cnt .txt p {
          font-size: 15px;
          margin-left: 25px; } }
      @media screen and (max-width: 767px) {
        .about .about_cnt .txt p {
          margin: 0 0 25px; } }
      @media screen and (max-width: 540px) {
        .about .about_cnt .txt p {
          font-size: 13px;
          line-height: 2; } }
      .about .about_cnt .txt p:last-of-type {
        margin-left: 0; }

.about .about_cnt2,
.about .about_cnt3,
.about .about_cnt4,
.about .about_cnt5 {
  display: flex;
  margin-bottom: 180px; }
  @media screen and (max-width: 767px) {
    .about .about_cnt2,
    .about .about_cnt3,
    .about .about_cnt4,
    .about .about_cnt5 {
      display: block; } }
  @media screen and (max-width: 560px) {
    .about .about_cnt2,
    .about .about_cnt3,
    .about .about_cnt4,
    .about .about_cnt5 {
      margin-bottom: 50px; } }
  .about .about_cnt2 .sec_ttl,
  .about .about_cnt3 .sec_ttl,
  .about .about_cnt4 .sec_ttl,
  .about .about_cnt5 .sec_ttl {
    line-height: 1.5;
    margin-bottom: 123px;
    font-size: 40px;
    writing-mode: vertical-rl;
    -ms-writing-mode: vertical-rl; }
    @media screen and (max-width: 980px) {
      .about .about_cnt2 .sec_ttl,
      .about .about_cnt3 .sec_ttl,
      .about .about_cnt4 .sec_ttl,
      .about .about_cnt5 .sec_ttl {
        margin-bottom: 60px;
        font-size: 32px; } }
    @media screen and (max-width: 767px) {
      .about .about_cnt2 .sec_ttl,
      .about .about_cnt3 .sec_ttl,
      .about .about_cnt4 .sec_ttl,
      .about .about_cnt5 .sec_ttl {
        flex-shrink: 0;
        margin-right: 40px; } }
    @media screen and (max-width: 560px) {
      .about .about_cnt2 .sec_ttl,
      .about .about_cnt3 .sec_ttl,
      .about .about_cnt4 .sec_ttl,
      .about .about_cnt5 .sec_ttl {
        font-size: 22px;
        margin-right: 15px; } }
  .about .about_cnt2 .cnt,
  .about .about_cnt3 .cnt,
  .about .about_cnt4 .cnt,
  .about .about_cnt5 .cnt {
    width: 310px;
    padding-right: 100px; }
    @media screen and (max-width: 1150px) {
      .about .about_cnt2 .cnt,
      .about .about_cnt3 .cnt,
      .about .about_cnt4 .cnt,
      .about .about_cnt5 .cnt {
        padding-right: 50px; } }
    @media screen and (max-width: 767px) {
      .about .about_cnt2 .cnt,
      .about .about_cnt3 .cnt,
      .about .about_cnt4 .cnt,
      .about .about_cnt5 .cnt {
        display: flex;
        width: 100%;
        padding-right: 20px;
        box-sizing: border-box; } }
    .about .about_cnt2 .cnt .txt,
    .about .about_cnt3 .cnt .txt,
    .about .about_cnt4 .cnt .txt,
    .about .about_cnt5 .cnt .txt {
      font-size: 14px;
      font-weight: bold; }
      @media screen and (max-width: 767px) {
        .about .about_cnt2 .cnt .txt,
        .about .about_cnt3 .cnt .txt,
        .about .about_cnt4 .cnt .txt,
        .about .about_cnt5 .cnt .txt {
          padding-top: 100px;
          margin-bottom: 50px; } }
      @media screen and (max-width: 560px) {
        .about .about_cnt2 .cnt .txt,
        .about .about_cnt3 .cnt .txt,
        .about .about_cnt4 .cnt .txt,
        .about .about_cnt5 .cnt .txt {
          padding-top: 90px;
          font-size: 13px;
          line-height: 1.85;
          margin-bottom: 18px; } }
  .about .about_cnt2 .img,
  .about .about_cnt3 .img,
  .about .about_cnt4 .img,
  .about .about_cnt5 .img {
    padding-top: 205px;
    width: 61%; }
    @media screen and (max-width: 767px) {
      .about .about_cnt2 .img,
      .about .about_cnt3 .img,
      .about .about_cnt4 .img,
      .about .about_cnt5 .img {
        width: 100%;
        box-sizing: border-box;
        padding-top: 0; } }
    .about .about_cnt2 .img img,
    .about .about_cnt3 .img img,
    .about .about_cnt4 .img img,
    .about .about_cnt5 .img img {
      width: 100%;
      height: auto; }

@media all and (-ms-high-contrast: none) {
  .about .about_cnt1 .sec_ttl,
  .about .about_cnt4 .sec_ttl {
    height: 8em; } }

@supports (-ms-ime-align: auto) {
  .about .about_cnt1 .sec_ttl,
  .about .about_cnt4 .sec_ttl {
    height: 8em; } }

@media all and (-ms-high-contrast: none) {
  .about .about_cnt2 .sec_ttl,
  .about .about_cnt2 .sec_ttl {
    height: 7em; } }

@supports (-ms-ime-align: auto) {
  .about .about_cnt2 .sec_ttl,
  .about .about_cnt2 .sec_ttl {
    height: 7em; } }

.about .about_cnt2,
.about .about_cnt4 {
  justify-content: flex-end; }
  @media screen and (max-width: 1150px) {
    .about .about_cnt2,
    .about .about_cnt4 {
      padding-left: 20px; } }
  .about .about_cnt2 .sec_ttl,
  .about .about_cnt4 .sec_ttl {
    margin-left: -12px; }
    @media screen and (max-width: 767px) {
      .about .about_cnt2 .sec_ttl,
      .about .about_cnt4 .sec_ttl {
        margin-left: -6px; } }
  @media screen and (max-width: 767px) {
    .about .about_cnt2 .img,
    .about .about_cnt4 .img {
      padding-left: 20px; } }
  @media screen and (max-width: 560px) {
    .about .about_cnt2 .img,
    .about .about_cnt4 .img {
      padding-left: 0; } }

.about .about_cnt3,
.about .about_cnt5 {
  flex-direction: row-reverse;
  justify-content: flex-end; }
  @media screen and (max-width: 1150px) {
    .about .about_cnt3,
    .about .about_cnt5 {
      padding-right: 20px; } }
  .about .about_cnt3 .sec_ttl,
  .about .about_cnt5 .sec_ttl {
    margin-right: -12px; }
    @media screen and (max-width: 767px) {
      .about .about_cnt3 .sec_ttl,
      .about .about_cnt5 .sec_ttl {
        margin-right: -6px;
        margin-left: 40px; } }
  .about .about_cnt3 .cnt,
  .about .about_cnt5 .cnt {
    padding: 0 0 0 100px;
    display: flex;
    flex-direction: column;
    align-items: flex-end; }
    @media screen and (max-width: 1150px) {
      .about .about_cnt3 .cnt,
      .about .about_cnt5 .cnt {
        padding-left: 50px; } }
    @media screen and (max-width: 767px) {
      .about .about_cnt3 .cnt,
      .about .about_cnt5 .cnt {
        flex-direction: row-reverse;
        align-items: flex-start;
        padding-left: 20px; } }
    @media screen and (max-width: 767px) {
      .about .about_cnt3 .cnt .img,
      .about .about_cnt5 .cnt .img {
        padding-right: 20px; } }
    @media screen and (max-width: 560px) {
      .about .about_cnt3 .cnt .img,
      .about .about_cnt5 .cnt .img {
        padding-right: 0; } }

.about .about_cnt5 {
  margin-bottom: 170px; }
  @media screen and (max-width: 560px) {
    .about .about_cnt5 {
      margin-bottom: 70px; } }

.about .about_fcnt {
  background: url("../img/about/about_fbg.jpg") no-repeat center;
  background-size: cover;
  height: 400px;
  text-align: center;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center; }
  @media screen and (max-width: 560px) {
    .about .about_fcnt {
      background: url("../img/about/about_fbg.jpg") no-repeat center;
      background-size: cover;
      height: 200px; } }
  .about .about_fcnt .txt {
    font-size: 20px;
    font-weight: bold;
    color: #FFF;
    margin-bottom: 34px;
    font-feature-settings: "palt"; }
    @media screen and (max-width: 560px) {
      .about .about_fcnt .txt {
        font-size: 12px;
        margin-bottom: 20px; } }
  .about .about_fcnt .btn a {
    width: 167px;
    background: #FFF;
    color: #000; }
    @media screen and (max-width: 560px) {
      .about .about_fcnt .btn a {
        width: 85px; } }
    .about .about_fcnt .btn a:hover {
      background: #000;
      color: #FFF;
      border: none; }

.products .page_mv {
  background: url("../img/products/products_ttl_bg.jpg") no-repeat center bottom;
  background-size: cover; }

.products .ttl_wrap {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 80px; }
  @media screen and (max-width: 560px) {
    .products .ttl_wrap {
      margin-bottom: 40px; } }
  .products .ttl_wrap .sec_ttl {
    font-size: 40px; }
    @media screen and (max-width: 560px) {
      .products .ttl_wrap .sec_ttl {
        font-size: 30px; } }

.products .sake_list {
  display: flex;
  flex-wrap: wrap;
  width: 1106px;
  margin: 0 auto 106px; }
  @media screen and (max-width: 1150px) {
    .products .sake_list {
      width: calc(100% - 40px);
      padding: 0 20px; } }
  @media screen and (max-width: 560px) {
    .products .sake_list {
      justify-content: space-between; } }
  .products .sake_list li {
    width: 224px;
    margin: 0 70px 55px 0;
    text-align: center; }
    @media screen and (max-width: 1150px) {
      .products .sake_list li {
        width: 22%;
        margin-right: 4%; } }
    @media screen and (max-width: 560px) {
      .products .sake_list li {
        width: 45%;
        margin-right: 0; } }
    .products .sake_list li:nth-of-type(4n) {
      margin-right: 0; }
    .products .sake_list li a {
      display: block; }
    .products .sake_list li .img {
      height: 285px;
      display: flex;
      align-items: flex-end;
      justify-content: center;
      margin-bottom: 23px; }
    .products .sake_list li .grade {
      font-size: 14px;
      font-weight: bold;
      line-height: 1.4; }
      @media screen and (max-width: 767px) {
        .products .sake_list li .grade {
          font-size: 13px; } }
    .products .sake_list li .name {
      font-size: 20px;
      line-height: 1.4;
      margin-bottom: 10px; }
      @media screen and (max-width: 767px) {
        .products .sake_list li .name {
          font-size: 18px;
          margin-bottom: 5px; } }
    .products .sake_list li .txt {
      font-size: 14px; }
      @media screen and (max-width: 767px) {
        .products .sake_list li .txt {
          font-size: 12px; } }
    .products .sake_list li .txt2 {
      font-size: 13px; }
      @media screen and (max-width: 767px) {
        .products .sake_list li .txt2 {
          font-size: 1px; } }
    @media screen and (max-width: 560px) {
      .products .sake_list li.taru .img {
        height: auto; } }

.info .page_mv {
  background: url("../img/info/info_ttl_bg.jpg") no-repeat center;
  background-size: cover; }

.info .info_sec {
  width: 1105px;
  margin: 0 auto 114px; }
  @media screen and (max-width: 1150px) {
    .info .info_sec {
      width: calc(100% - 40px);
      padding: 0 20px; } }
  @media screen and (max-width: 560px) {
    .info .info_sec {
      margin-bottom: 50px; } }
  .info .info_sec .img {
    margin-bottom: 54px; }
    @media screen and (max-width: 560px) {
      .info .info_sec .img {
        margin-right: -20px;
        margin-bottom: 30px; } }
  .info .info_sec .wrap {
    display: flex; }
    .info .info_sec .wrap.kurakengaku {
      margin-bottom: 80px; }
      @media screen and (max-width: 560px) {
        .info .info_sec .wrap.kurakengaku {
          margin-bottom: 60px; } }
    .info .info_sec .wrap .sec_ttl {
      font-size: 40px;
      line-height: 1;
      margin-right: 64px;
      padding-top: 9px; }
      @media screen and (max-width: 560px) {
        .info .info_sec .wrap .sec_ttl {
          margin-right: 20px;
          font-size: 25px; } }
    .info .info_sec .wrap .cnt .lead {
      font-size: 16px;
      font-weight: bold;
      margin-bottom: 44px; }
      @media screen and (max-width: 560px) {
        .info .info_sec .wrap .cnt .lead {
          font-size: 14px;
          margin-bottom: 25px; } }
    .info .info_sec .wrap .cnt .txt1 {
      font-size: 14px;
      margin-bottom: 40px; }
      @media screen and (max-width: 560px) {
        .info .info_sec .wrap .cnt .txt1 {
          font-size: 13px;
          margin-bottom: 18px; } }
    .info .info_sec .wrap .cnt .txt2 {
      font-size: 14px;
      margin-bottom: 13px; }
      @media screen and (max-width: 560px) {
        .info .info_sec .wrap .cnt .txt2 {
          font-size: 13px; } }
    .info .info_sec .wrap .cnt .txt3 {
      font-size: 12px;
      margin-bottom: 40px; }
      @media screen and (max-width: 560px) {
        .info .info_sec .wrap .cnt .txt3 {
          font-size: 18px; } }
    .info .info_sec .wrap .cnt .btn {
      margin-bottom: 35px; }
      .info .info_sec .wrap .cnt .btn a {
        height: 50px;
        width: 196px; }

.info .kurabiraki {
  border: 4px solid #000;
  width: 1106px;
  margin: 0 auto 180px;
  padding: 60px 73px;
  box-sizing: border-box; }
  @media screen and (max-width: 1150px) {
    .info .kurabiraki {
      width: calc(100% - 40px); } }
  @media screen and (max-width: 560px) {
    .info .kurabiraki {
      padding: 30px 30px;
      margin-bottom: 70px; } }
  .info .kurabiraki .kurabiraki_ttl {
    text-align: center;
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 0;
    letter-spacing: 0.1em; }
    @media screen and (max-width: 560px) {
      .info .kurabiraki .kurabiraki_ttl {
        font-size: 24px; } }
  .info .kurabiraki .lead {
    text-align: center;
    font-size: 14px;
    margin-bottom: 46px; }
    @media screen and (max-width: 560px) {
      .info .kurabiraki .lead {
        font-size: 13px;
        margin-bottom: 30px;
        line-height: 1.5; } }
  .info .kurabiraki .date {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 83px; }
    @media screen and (max-width: 560px) {
      .info .kurabiraki .date {
        font-size: 15px;
        margin-bottom: 40px; } }
  .info .kurabiraki h3 {
    font-size: 16px;
    font-weight: bold; }
    @media screen and (max-width: 560px) {
      .info .kurabiraki h3 {
        font-size: 15px; } }
  .info .kurabiraki p {
    font-size: 14px;
    margin-bottom: 50px; }
    @media screen and (max-width: 560px) {
      .info .kurabiraki p {
        font-size: 13px;
        margin-bottom: 30px; } }
    .info .kurabiraki p:last-of-type {
      margin-bottom: 0; }

.info .info_img {
  font-size: 0; }
  .info .info_img img {
    width: 100%;
    height: auto; }

.company .page_mv {
  background: url("../img/company/company_ttl_bg.jpg") no-repeat center;
  background-size: cover; }

.company .main_lead {
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 160px; }
  @media screen and (max-width: 1150px) {
    .company .main_lead {
      padding: 0 20px; } }
  @media screen and (max-width: 560px) {
    .company .main_lead {
      font-size: 14px;
      text-align: left;
      margin-bottom: 40px; } }

.company .company_sec {
  width: 1106px;
  margin: 0 auto 94px;
  display: flex; }
  @media screen and (max-width: 1150px) {
    .company .company_sec {
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box; } }
  .company .company_sec:last-of-type {
    margin-bottom: 170px; }
    @media screen and (max-width: 560px) {
      .company .company_sec:last-of-type {
        margin-bottom: 70px; } }
  .company .company_sec .sec_ttl {
    font-size: 40px;
    line-height: 1;
    margin-right: 137px;
    padding-top: 9px; }
    @media screen and (max-width: 980px) {
      .company .company_sec .sec_ttl {
        margin-right: 60px; } }
    @media screen and (max-width: 560px) {
      .company .company_sec .sec_ttl {
        font-size: 25px;
        width: auto;
        margin-right: 40px; } }
  @media screen and (max-width: 1150px) {
    .company .company_sec .cnt {
      width: calc(100% - 180px); } }
  @media screen and (max-width: 980px) {
    .company .company_sec .cnt {
      width: calc(100% - 110px); } }
  @media screen and (max-width: 560px) {
    .company .company_sec .cnt {
      width: calc(100% - 70px); } }
  .company .company_sec .cnt .table {
    display: table;
    width: 100%; }
    .company .company_sec .cnt .table li {
      display: table-row; }
      .company .company_sec .cnt .table li p {
        display: table-cell;
        font-size: 14px;
        padding: 7px 0; }
        @media screen and (max-width: 560px) {
          .company .company_sec .cnt .table li p {
            font-size: 13px; } }
        .company .company_sec .cnt .table li p.ttl {
          width: 144px; }
          @media screen and (max-width: 560px) {
            .company .company_sec .cnt .table li p.ttl {
              width: 95px; } }
        @media screen and (max-width: 560px) {
          .company .company_sec .cnt .table li p.txt {
            line-height: 1.5; } }
    .company .company_sec .cnt .table.outline li .ttl {
      width: 214px; }
      @media screen and (max-width: 560px) {
        .company .company_sec .cnt .table.outline li .ttl {
          width: 95px;
          line-height: 1.5; } }
  .company .company_sec .cnt .award {
    margin-top: 10px;
    width: 924px;
    border-top: 2px solid #000;
    display: table; }
    @media screen and (max-width: 1150px) {
      .company .company_sec .cnt .award {
        width: 100%; } }
    .company .company_sec .cnt .award li {
      width: 100%;
      display: table-row;
      box-sizing: border-box; }
      @media screen and (max-width: 767px) {
        .company .company_sec .cnt .award li {
          display: block;
          border-bottom: 2px solid #000;
          padding: 15px; } }
      .company .company_sec .cnt .award li p {
        display: table-cell;
        vertical-align: middle;
        height: 78px;
        border-bottom: 2px solid #000; }
        @media screen and (max-width: 980px) {
          .company .company_sec .cnt .award li p {
            padding-right: 20px; } }
        @media screen and (max-width: 767px) {
          .company .company_sec .cnt .award li p {
            display: block;
            border-bottom: none;
            padding-right: 0;
            height: auto; } }
      .company .company_sec .cnt .award li .year {
        width: 82px;
        white-space: nowrap;
        padding-left: 20px; }
        @media screen and (max-width: 767px) {
          .company .company_sec .cnt .award li .year {
            padding: 0;
            width: 100%; } }
      .company .company_sec .cnt .award li .ttl {
        width: 423px;
        line-height: 1.5; }
        @media screen and (max-width: 767px) {
          .company .company_sec .cnt .award li .ttl {
            width: 100%; } }
      .company .company_sec .cnt .award li .name {
        width: 250px; }
        @media screen and (max-width: 767px) {
          .company .company_sec .cnt .award li .name {
            width: 100%; } }
      .company .company_sec .cnt .award li .grade {
        width: 125px; }
        @media screen and (max-width: 767px) {
          .company .company_sec .cnt .award li .grade {
            width: 100%; } }

.company .company_img {
  font-size: 0; }
  .company .company_img img {
    width: 100%;
    height: auto; }

.contact .page_mv {
  background: url("../img/contact/contact_ttl_bg.jpg") no-repeat center;
  background-size: cover;
  margin-bottom: 122px; }
  @media screen and (max-width: 840px) {
    .contact .page_mv {
      margin-bottom: 80px; } }

.contact .main_lead {
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 110px; }
  @media screen and (max-width: 840px) {
    .contact .main_lead {
      padding: 0 20px;
      margin-bottom: 80px; } }
  @media screen and (max-width: 560px) {
    .contact .main_lead {
      margin-bottom: 50px;
      font-size: 14px;
      text-align: left; } }
  .contact .main_lead span {
    font-size: 12px;
    font-weight: normal; }
    @media screen and (max-width: 560px) {
      .contact .main_lead span {
        margin-top: 12px;
        display: inline-block; } }
  .contact .main_lead a {
    display: inline-block;
    position: relative; }
    .contact .main_lead a:before {
      content: '';
      width: 100%;
      height: 2px;
      background: #000;
      display: block;
      position: absolute;
      bottom: 1px;
      left: 0;
      transition: all .6s ease; }
    .contact .main_lead a:hover {
      text-decoration: none; }
      .contact .main_lead a:hover:before {
        width: 0; }

.sakuragumi .page_mv {
  background: url("../img/member/sakuragumi_ttl_bg.jpg") no-repeat center;
  background-size: cover;
  margin-bottom: 122px; }
  @media screen and (max-width: 840px) {
    .sakuragumi .page_mv {
      margin-bottom: 80px; } }

.sakuragumi .sakuragumi_sec {
  width: 800px;
  margin: 0 auto 68px; }
  @media screen and (max-width: 840px) {
    .sakuragumi .sakuragumi_sec {
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box; } }
  @media screen and (max-width: 560px) {
    .sakuragumi .sakuragumi_sec {
      margin-bottom: 40px; } }
  .sakuragumi .sakuragumi_sec .ttl {
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 19px; }
    @media screen and (max-width: 560px) {
      .sakuragumi .sakuragumi_sec .ttl {
        font-size: 22px;
        margin-bottom: 10px; } }
  .sakuragumi .sakuragumi_sec .txt {
    line-height: 3;
    font-size: 14px; }
    @media screen and (max-width: 560px) {
      .sakuragumi .sakuragumi_sec .txt {
        line-height: 2; } }

.sakuragumi .sakuragumi_form {
  width: 800px;
  margin: 0 auto; }
  @media screen and (max-width: 840px) {
    .sakuragumi .sakuragumi_form {
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box; } }
  @media screen and (max-width: 560px) {
    .sakuragumi .sakuragumi_form {
      margin-top: 50px; } }
  .sakuragumi .sakuragumi_form > .ttl {
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 25px; }
    @media screen and (max-width: 560px) {
      .sakuragumi .sakuragumi_form > .ttl {
        font-size: 22px;
        margin-bottom: 10px; } }
  .sakuragumi .sakuragumi_form .lead {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 68px; }
    @media screen and (max-width: 560px) {
      .sakuragumi .sakuragumi_form .lead {
        font-size: 14px;
        margin-bottom: 30px; } }
    .sakuragumi .sakuragumi_form .lead a {
      display: inline-block;
      position: relative; }
      .sakuragumi .sakuragumi_form .lead a:before {
        content: '';
        width: 100%;
        height: 2px;
        background: #000;
        display: block;
        position: absolute;
        bottom: 1px;
        left: 0;
        transition: all .6s ease; }
      .sakuragumi .sakuragumi_form .lead a:hover {
        text-decoration: none; }
        .sakuragumi .sakuragumi_form .lead a:hover:before {
          width: 0; }
  @media screen and (max-width: 560px) {
    .sakuragumi .sakuragumi_form .form {
      padding: 0; } }
  .sakuragumi .sakuragumi_form .form .table {
    margin: 0 0 17px; }
    .sakuragumi .sakuragumi_form .form .table .t-tr .ttl {
      width: 200px; }
    .sakuragumi .sakuragumi_form .form .table .t-tr .cnt {
      padding-bottom: 70px; }
      @media screen and (max-width: 560px) {
        .sakuragumi .sakuragumi_form .form .table .t-tr .cnt {
          padding-bottom: 0; } }

.form {
  width: 800px;
  margin: 0 auto 180px; }
  @media screen and (max-width: 840px) {
    .form {
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box; } }
  @media screen and (max-width: 560px) {
    .form {
      margin-bottom: 70px; } }
  .form .table {
    margin: 0 auto 47px;
    display: table;
    width: 100%; }
    @media screen and (max-width: 560px) {
      .form .table {
        display: block;
        margin-bottom: 30px; } }
    .form .table .t-tr {
      display: table-row; }
      @media screen and (max-width: 560px) {
        .form .table .t-tr {
          display: block; } }
      .form .table .t-tr .ttl {
        display: table-cell;
        font-size: 16px;
        width: 230px;
        vertical-align: top; }
        @media screen and (max-width: 840px) {
          .form .table .t-tr .ttl {
            width: 200px; } }
        @media screen and (max-width: 560px) {
          .form .table .t-tr .ttl {
            display: block;
            font-size: 14px; } }
        .form .table .t-tr .ttl .his {
          font-size: 12px; }
      .form .table .t-tr .cnt {
        display: table-cell;
        padding-top: 8px;
        padding-bottom: 43px; }
        @media screen and (max-width: 560px) {
          .form .table .t-tr .cnt {
            display: block;
            padding-bottom: 0;
            margin-bottom: 24px; } }
        .form .table .t-tr .cnt input[type=text],
        .form .table .t-tr .cnt input[type=date],
        .form .table .t-tr .cnt input[type=email],
        .form .table .t-tr .cnt input[type=tel] {
          font-size: 16px;
          width: 570px;
          height: 36px;
          padding: 0 8px;
          box-sizing: border-box;
          border: 1px solid #b5b5b5;
          border-radius: 0; }
          @media screen and (max-width: 840px) {
            .form .table .t-tr .cnt input[type=text],
            .form .table .t-tr .cnt input[type=date],
            .form .table .t-tr .cnt input[type=email],
            .form .table .t-tr .cnt input[type=tel] {
              width: 100%;
              box-sizing: border-box; } }
        .form .table .t-tr .cnt.address p {
          display: flex;
          align-items: center;
          margin-bottom: 20px; }
          @media screen and (max-width: 560px) {
            .form .table .t-tr .cnt.address p {
              display: block; } }
          .form .table .t-tr .cnt.address p:last-of-type {
            margin-bottom: 0; }
          .form .table .t-tr .cnt.address p .ttl {
            width: 100px;
            flex-shrink: 0;
            font-size: 14px;
            font-weight: normal; }
          @media screen and (max-width: 840px) {
            .form .table .t-tr .cnt.address p .area {
              width: calc(100% - 100px); } }
          @media screen and (max-width: 560px) {
            .form .table .t-tr .cnt.address p .area {
              width: 100%; } }
          .form .table .t-tr .cnt.address p .area input {
            width: 468px; }
            @media screen and (max-width: 840px) {
              .form .table .t-tr .cnt.address p .area input {
                width: 100%; } }
        .form .table .t-tr .cnt textarea {
          font-size: 14px;
          width: 570px;
          height: 268px;
          padding: 15px 20px;
          box-sizing: border-box;
          border: 1px solid #b5b5b5;
          border-radius: 0; }
          @media screen and (max-width: 840px) {
            .form .table .t-tr .cnt textarea {
              width: 100%;
              box-sizing: border-box; } }
          @media screen and (max-width: 560px) {
            .form .table .t-tr .cnt textarea {
              height: 200px; } }
        .form .table .t-tr .cnt .txt {
          display: block;
          font-size: 12px;
          padding-top: 3px; }
  .form .submit input {
    width: 257px;
    height: 70px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    align-items: center;
    color: #FFF;
    font-size: 18px;
    background: #000;
    font-weight: bold;
    transition: all .6s ease;
    transition: background-color .3s ease;
    box-sizing: border-box;
    margin: 0 auto;
    cursor: pointer;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0; }
    @media screen and (max-width: 560px) {
      .form .submit input {
        font-size: 12px;
        width: 160px;
        height: 50px; } }
    .form .submit input:hover {
      background: #FFF;
      border: 3px solid #000;
      color: #000;
      opacity: 1 !important; }

.news .page_mv {
  background: url("../img/news/news_ttl_bg.jpg") no-repeat center;
  background-size: cover;
  margin-bottom: 122px; }
  @media screen and (max-width: 840px) {
    .news .page_mv {
      margin-bottom: 80px; } }

.news.archive {
  margin-bottom: 176px; }
  @media screen and (max-width: 767px) {
    .news.archive {
      margin-bottom: 80px; } }
  .news.archive .list {
    width: 800px;
    margin: 0 auto 140px;
    border-top: 1px solid #c9c9c9; }
    @media screen and (max-width: 840px) {
      .news.archive .list {
        width: calc(100% - 40px); } }
    .news.archive .list li {
      border-bottom: 1px solid #c9c9c9; }
      .news.archive .list li a {
        min-height: 96px;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        flex-direction: column;
        justify-content: center;
        padding: 8px 0;
        box-sizing: border-box; }
        @media screen and (max-width: 840px) {
          .news.archive .list li a {
            min-height: 70px; } }
        .news.archive .list li a .ttl {
          font-size: 24px;
          font-weight: bold;
          line-height: 1.5;
          margin-bottom: 8px; }
          @media screen and (max-width: 840px) {
            .news.archive .list li a .ttl {
              font-size: 20px; } }
          @media screen and (max-width: 560px) {
            .news.archive .list li a .ttl {
              font-size: 18px;
              margin-bottom: 4px; } }
        .news.archive .list li a .date {
          font-size: 14px;
          line-height: 1.6; }
          @media screen and (max-width: 840px) {
            .news.archive .list li a .date {
              font-size: 12px; } }

.pagination ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  flex-wrap: wrap; }
  .pagination ul li {
    width: 38px;
    height: 38px;
    margin: 0 8px;
    font-size: 14px; }
    @media screen and (max-width: 480px) {
      .pagination ul li {
        margin: 0 5px; } }
    @media screen and (max-width: 360px) {
      .pagination ul li {
        width: 34px;
        height: 34px; } }
    .pagination ul li.active {
      background: #000;
      color: #FFF;
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flex;
      display: -o-flex;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      border-radius: 50%; }
    .pagination ul li.num a {
      width: 38px;
      height: 38px;
      border-radius: 50%;
      border: 1px solid #000;
      box-sizing: border-box;
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flex;
      display: -o-flex;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      .pagination ul li.num a:hover {
        opacity: 1;
        background: #000;
        color: #FFF; }
      @media screen and (max-width: 360px) {
        .pagination ul li.num a {
          width: 34px;
          height: 34px; } }
    .pagination ul li.next, .pagination ul li.prev {
      width: 50px; }
      @media screen and (max-width: 480px) {
        .pagination ul li.next, .pagination ul li.prev {
          width: 38px; }
          .pagination ul li.next a, .pagination ul li.prev a {
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: -o-flex;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            height: 38px; } }
      @media screen and (max-width: 360px) {
        .pagination ul li.next, .pagination ul li.prev {
          width: 30px; }
          .pagination ul li.next a, .pagination ul li.prev a {
            height: 34px; } }
    .pagination ul li.next {
      margin-left: 15px; }
      .pagination ul li.next a {
        display: block; }
        .pagination ul li.next a:hover {
          transform: translateX(5px); }
      @media screen and (max-width: 360px) {
        .pagination ul li.next {
          margin-left: 10px; } }
    .pagination ul li.prev {
      margin-right: 15px; }
      .pagination ul li.prev a {
        display: block; }
        .pagination ul li.prev a:hover {
          transform: translateX(-5px); }
      @media screen and (max-width: 360px) {
        .pagination ul li.prev {
          margin-right: 10px; } }

.single {
  margin-bottom: 176px; }
  @media screen and (max-width: 767px) {
    .single {
      margin-bottom: 100px; } }
  .single .page_mv {
    margin-bottom: 172px; }
    @media screen and (max-width: 767px) {
      .single .page_mv {
        margin-bottom: 80px; } }
  .single .entry {
    width: 800px;
    margin: 0 auto 55px; }
    @media screen and (max-width: 840px) {
      .single .entry {
        width: 100%;
        padding: 0 20px;
        box-sizing: border-box;
        margin-bottom: 40px; } }
    .single .entry .entry_ttl {
      font-size: 32px;
      margin-bottom: 6px;
      letter-spacing: 0;
      line-height: 1.5; }
      @media screen and (max-width: 767px) {
        .single .entry .entry_ttl {
          font-size: 20px; } }
    .single .entry .date {
      font-size: 16px;
      font-weight: bold;
      margin-bottom: 70px;
      letter-spacing: 0; }
      @media screen and (max-width: 767px) {
        .single .entry .date {
          font-size: 13px;
          margin-bottom: 40px; } }
    .single .entry .body p {
      margin-bottom: 35px;
      font-size: 16px;
      letter-spacing: 0; }
      @media screen and (max-width: 767px) {
        .single .entry .body p {
          font-size: 15px; } }
    .single .entry .body a {
      text-decoration: underline; }
      .single .entry .body a:hover {
        text-decoration: none; }
    .single .entry .body ul {
      padding-left: 2em;
      margin-bottom: 35px; }
      .single .entry .body ul li {
        list-style-type: disc;
        margin-bottom: 10px;
        line-height: 1.5em;
        font-size: 16px; }
        @media screen and (max-width: 767px) {
          .single .entry .body ul li {
            font-size: 15px; } }
    .single .entry .body ol {
      padding-left: 2em;
      margin-bottom: 35px; }
      .single .entry .body ol li {
        list-style-type: decimal;
        margin-bottom: 10px;
        line-height: 1.5em;
        font-size: 16px; }
        @media screen and (max-width: 767px) {
          .single .entry .body ol li {
            font-size: 15px; } }
    .single .entry .body hr {
      margin-bottom: 35px;
      border-color: #000; }
    .single .entry .body blockquote {
      padding: 30px;
      background: #eee;
      font-size: 14px;
      margin-bottom: 35px; }
      .single .entry .body blockquote p {
        font-size: 15px;
        font-style: italic; }
      .single .entry .body blockquote p:first-child {
        margin-top: 0; }
      .single .entry .body blockquote p:last-of-type {
        margin-bottom: 0; }

.paginationSingle {
  width: 800px;
  margin: 0 auto; }
  @media screen and (max-width: 840px) {
    .paginationSingle {
      width: 100%;
      padding: 0 20px;
      box-sizing: border-box; } }
  .paginationSingle ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; }
    .paginationSingle ul li {
      font-size: 16px;
      font-weight: bold;
      width: 80px; }
      @media screen and (max-width: 360px) {
        .paginationSingle ul li {
          font-size: 14px;
          width: 70px; } }
      .paginationSingle ul li.prev a {
        background: url("../img/common/prevs.svg") no-repeat left center;
        background-size: auto 35px;
        padding-left: 45px;
        line-height: 50px;
        display: block; }
        .paginationSingle ul li.prev a:hover {
          transform: translateX(-5px); }
        @media screen and (max-width: 480px) {
          .paginationSingle ul li.prev a {
            line-height: 40px; } }
        @media screen and (max-width: 360px) {
          .paginationSingle ul li.prev a {
            padding-left: 40px; } }
      .paginationSingle ul li.next a {
        background: url("../img/common/nexts.svg") no-repeat right center;
        background-size: auto 35px;
        padding-right: 45px;
        line-height: 50px;
        display: block; }
        .paginationSingle ul li.next a:hover {
          transform: translateX(5px); }
        @media screen and (max-width: 480px) {
          .paginationSingle ul li.next a {
            line-height: 40px; } }
        @media screen and (max-width: 360px) {
          .paginationSingle ul li.next a {
            padding-right: 40px; } }
      .paginationSingle ul li.back {
        width: 148px; }
        @media screen and (max-width: 480px) {
          .paginationSingle ul li.back {
            width: 120px; } }
        @media screen and (max-width: 360px) {
          .paginationSingle ul li.back {
            width: 100px; } }
        .paginationSingle ul li.back a {
          width: 148px;
          height: 50px;
          display: -webkit-flex;
          display: -moz-flex;
          display: -ms-flex;
          display: -o-flex;
          display: flex;
          flex-direction: column;
          justify-content: center;
          align-items: center;
          color: #FFF;
          background: #000;
          border: 2px solid #000;
          box-sizing: border-box; }
          .paginationSingle ul li.back a:hover {
            background: #FFF;
            color: #000;
            opacity: 1; }
          @media screen and (max-width: 480px) {
            .paginationSingle ul li.back a {
              width: 120px;
              height: 40px;
              font-size: 13px; } }
          @media screen and (max-width: 360px) {
            .paginationSingle ul li.back a {
              width: 100px; } }

.page404_ttl {
  font-weight: bold;
  font-size: 24px;
  text-align: center;
  margin-bottom: 40px;
  padding: 0 0px; }

.not404 {
  text-align: center;
  padding: 0 20px; }

/*# sourceMappingURL=../maps/style.css.map */
