@charset "UTF-8";
/*
Theme Name: koyuki-farm
Version:1.1
*/
@font-face {
  font-family: 'standard';
  src: url("fonts/standard.ttf?65qa1e") format("truetype"), url("fonts/standard.woff?65qa1e") format("woff"), url("fonts/standard.svg?65qa1e#standard") format("svg");
  font-weight: normal;
  font-style: normal; }
[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'standard' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.icon-phone:before {
  content: "\e902"; }

.icon-mail:before {
  content: "\e612"; }

.icon-export:before {
  content: "\e900"; }

.icon-location:before {
  content: "\e608"; }

.icon-cross:before {
  content: "\e60b"; }

.icon-list:before {
  content: "\e610"; }

.icon-first:before {
  content: "\e60e"; }

.icon-last:before {
  content: "\e60f"; }

.icon-arrow-left2:before {
  content: "\e60d"; }

.icon-arrow-down2:before {
  content: "\e605"; }

.icon-arrow-up2:before {
  content: "\e603"; }

.icon-arrow-right2:before {
  content: "\e60c"; }

.icon-arrow-left22:before {
  content: "\e607"; }

.icon-arrow-down22:before {
  content: "\e609"; }

.icon-arrow-up22:before {
  content: "\e606"; }

.icon-arrow-right22:before {
  content: "\e60a"; }

.icon-twitter:before {
  content: "\e901"; }

.icon-facebook:before {
  content: "\e613"; }

.icon-instagram:before {
  content: "\e907"; }

.wf1 {
  font-family: "すずむし", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif; }

@keyframes fadein {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
@keyframes fadeleft {
  0% {
    opacity: 0;
    transform: translateX(20px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
@keyframes faderight {
  0% {
    opacity: 0;
    transform: translateX(-20px); }
  100% {
    opacity: 1;
    transform: translateX(0); } }
/*
2023/8 scss化
以降の追記はscssとする
新要素は最下部に追記
*/
/* スマホ、タブレット、PC共通 */
*, *:before, *:after {
  box-sizing: border-box; }

body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  margin: 0;
  padding: 0;
  line-height: 2;
  font-size: 14px;
  color: #000;
  -webkit-font-smoothing: antialiased;
  background: url(img/bg.jpg); }

img {
  border: none;
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  color: #006946;
  transition: .2s; }

a:hover {
  color: #ac6525; }

#trns {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99999;
  background-color: #fff; }

#trns .bg1 {
  position: absolute;
  background: url(img/trnsbg1.svg) 0% 0% repeat;
  top: -100%;
  left: -100%;
  right: -100%;
  bottom: -100%;
  z-index: -1;
  animation: trnsbg1 20s linear infinite; }

#trns .bg2 {
  position: absolute;
  background: url(img/trnsbg2.svg) 0% 0% repeat;
  top: -100%;
  left: -100%;
  right: -100%;
  bottom: -100%;
  z-index: -1;
  animation: trnsbg1 15s linear infinite; }

@keyframes trnsbg1 {
  from {
    transform: translate(0, 0); }
  to {
    transform: translate(230px, -192px); } }
@keyframes trnsbg2 {
  from {
    transform: translate(0, 0); }
  to {
    transform: translate(-230px, 192px); } }
header {
  position: relative; }

header .logo {
  margin: 0 auto;
  width: 180px;
  /*background-color: #fff;*/
  text-align: center;
  padding: 30px 15px 15px;
  position: relative;
  /*z-index: 2;*/ }

header .logo :after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: -1; }

header .logo.hover {
  animation: pulse .2s; }

header .logo a {
  /*z-index: 2;*/ }

header .bggrapes {
  position: absolute;
  top: 0;
  width: 100%;
  height: 30vw;
  overflow: hidden;
  z-index: -1; }

header .bggrapes img {
  position: absolute;
  width: 40%; }

header .bggrapes img.bg1 {
  top: -35%;
  left: -5%; }

header .bggrapes img.bg2 {
  top: -60%;
  right: -2%; }

header .bggrapes img.bg3 {
  width: 30%;
  top: -25%;
  right: -15%; }

/*.fadeDownSmall{
  animation:fadeDownSmall .5s forwards;
  transform:translateY(-20%);
  opacity: 0;
}
@keyframes fadeDownSmall{
  from{opacity:0; transform:translateY(-20%);}
  to{opacity:1; transform:translateY(0);}
}*/
.sec {
  padding-bottom: 40px; }

.btn {
  display: inline-block;
  background-color: #006946;
  position: relative;
  color: #fff;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  padding: 20px;
  border-radius: 4px; }

.btn:after {
  content: "";
  width: 100%;
  height: 100%;
  padding: 1px;
  border: solid 1px #006946;
  position: absolute;
  top: -2px;
  left: -2px;
  border-radius: 5px;
  box-sizing: content-box; }

.btn.hover {
  animation: tada 1s !important;
  color: #fff; }

.btn_round {
  background-color: #006946;
  border-radius: 100%;
  position: relative;
  color: #fff;
  line-height: 1;
  text-align: center;
  text-decoration: none; }

.btn_round:after {
  content: "";
  width: calc(100% + 4px);
  height: calc(100% + 4px);
  border-radius: 100%;
  border: solid 1px #006946;
  position: absolute;
  top: -3px;
  left: -3px;
  box-sizing: content-box; }

.btn_round.hover {
  animation: tada 1s !important;
  color: #fff; }

.midashi {
  background-image: url(img/bg_whitestripe.png);
  color: #265947;
  background-size: 30px;
  text-align: center;
  margin: 0 0 20px; }

.midashi .title {
  display: inline-block;
  position: relative; }

.midashi .title:before,
.midashi .title:after {
  content: "";
  display: block;
  width: 30px;
  height: 1px;
  border-top: solid 1px #265947;
  position: absolute; }

.midashi .title:before {
  top: 50%;
  left: -40px; }

.midashi .title:after {
  top: 50%;
  right: -40px; }

.pagetitle {
  margin: 20px 0;
  font-size: 24px;
  line-height: 1;
  padding: 15px 0 10px; }

.pagetitle .en {
  font-size: 14px;
  display: block;
  letter-spacing: .1em; }

nav .btn_menu {
  width: 60px;
  height: 60px;
  position: fixed !important;
  top: 15px;
  right: 15px;
  z-index: 10; }

nav .btn_menu .icon {
  display: block;
  width: 18px;
  height: 18px;
  margin: 12px auto 2px;
  overflow: hidden;
  background: url(img/menubtns.svg) no-repeat;
  background-position: 0 0; }

nav .btn_close {
  width: 60px;
  height: 60px;
  position: absolute;
  top: 15px;
  right: 15px;
  text-align: center;
  text-decoration: none;
  line-height: 1; }

nav .btn_close .icon {
  display: block;
  width: 18px;
  height: 18px;
  margin: 12px auto 2px;
  overflow: hidden;
  background: url(img/menubtns.svg) no-repeat;
  background-position: 0 -18px; }

nav ul {
  list-style: none;
  margin: 0;
  padding: 0; }

.nav__menu a {
  display: block;
  text-decoration: none;
  font-size: 16px;
  line-height: 1;
  padding: 10px;
  letter-spacing: -.1em; }

.nav__menu a,
.nav__menu a:link,
.nav__menu a:visited {
  color: #265947; }

.nav__menu a:active {
  color: #ac6525; }

.nav__menu a .icon {
  display: block;
  width: 45px;
  height: 40px;
  margin: 10px auto 3px;
  overflow: hidden;
  background: url(img/icons.svg?20250128) no-repeat; }

.nav__menu.menu1 .icon {
  background-position: 0 0; }

.nav__menu.menu2 .icon {
  background-position: 0 -40px; }

.nav__menu.menu3 .icon {
  background-position: 0 -80px; }

.nav__menu.menu4 .icon {
  background-position: 0 -120px; }

.nav__menu.menu5 .icon {
  background-position: 0 -160px; }

.nav__menu.menu6 .icon {
  background-position: 0 -200px; }

.nav__menu.menu7 .icon {
  background-position: 0 -240px; }

.nav__menu.menu8 .icon {
  background-position: 0 -280px; }

.nav__menu a .en {
  font-size: 12px;
  display: block;
  letter-spacing: .1em; }

.nav__menu:not(.current) a.hover .icon {
  animation: rubberBand .5s; }

.nav__menu.current {
  position: relative; }

.nav__menu.current:before {
  content: "";
  display: block;
  width: 60px;
  height: 60px;
  position: absolute;
  border-radius: 100%;
  /*overflow: hidden;*/
  background-image: url(img/bg_greenstripe.png);
  background-size: 30px;
  z-index: -1;
  left: calc(50% - 30px);
  top: calc(50% - 40px); }

.nav__menu.current:after {
  content: "";
  display: block;
  width: 24px;
  height: 2px;
  position: absolute;
  /*overflow: hidden;*/
  background-color: #265947;
  z-index: -1;
  left: calc(50% - 12px);
  bottom: 0; }

.nav__menu.current a {
  cursor: default; }

.breadcrumb {
  font-size: 10px;
  padding: 5px 2%;
  margin-bottom: 10px;
  line-height: 1.5; }

.breadcrumb a,
.breadcrumb a:link,
.breadcrumb a:visited {
  color: #006946; }

.breadcrumb a:active {
  color: #006946; }

.breadcrumb a,
.breadcrumb span {
  margin: 0 2px;
  color: #006946; }

.breadcrumb a span {
  text-decoration: underline; }

.breadcrumb span[property="name"] {
  display: inline-block;
  padding: 0;
  margin-top: -3px;
  vertical-align: middle;
  max-width: 140px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis; }

.footer_nav {
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center; }

.footer_nav:before {
  content: url(img/greendots.svg);
  display: block;
  position: relative;
  top: -10px; }

.footer_nav a {
  text-decoration: none;
  display: inline-block;
  padding: 5px; }

.footer_nav .current {
  position: relative; }

.footer_nav .current:after {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  position: absolute;
  border-radius: 100%;
  /*overflow: hidden;*/
  background-image: url(img/bg_whitestripe.png);
  background-size: 30px;
  z-index: -1;
  left: calc(50% - 20px);
  top: 0; }

.footer_nav .current a {
  cursor: default; }

.footer_nav .current a:hover {
  color: #006946; }

.footer_inner {
  overflow: hidden;
  position: relative;
  padding-top: 40px; }

.footer_inner .farm_info {
  text-align: center;
  padding: 50px 0 30px;
  font-size: 12px;
  color: #ac6525;
  line-height: 1.5;
  position: relative; }
  .footer_inner .farm_info .sns {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px; }
    .footer_inner .farm_info .sns a {
      display: inline-block;
      padding: 5px; }

.footer_inner .farm_info:after {
  content: "";
  display: block;
  width: 360px;
  height: 360px;
  background-color: #fff;
  border-radius: 100%;
  position: absolute;
  top: 0;
  left: calc(50% - 180px);
  z-index: -1; }

.footer_inner .farm_info .logo {
  width: 180px;
  margin-bottom: 10px; }

.footer_inner .farm_info address {
  font-style: normal; }

.footer_inner .farm_info .tel {
  font-size: 20px;
  margin: 0 5px;
  color: #ac6525;
  text-decoration: none;
  vertical-align: -3px; }

.footer_inner .farm_info .btn_fb {
  display: inline-block;
  vertical-align: -1px; }

#totop {
  width: 50px;
  height: 50px;
  position: absolute;
  top: 15px;
  left: calc(50% - 25px);
  font-size: 11px;
  padding-top: 8px;
  z-index: 2; }

#totop img {
  display: block;
  margin: 0 auto;
  transform: rotateZ(-90deg);
  margin-bottom: 2px; }

#totop.fix {
  position: fixed;
  bottom: 30px;
  top: auto; }

#totop.hover {
  color: #fff; }

footer {
  position: relative;
  overflow: hidden; }

footer .bggrapes_wrapper {
  position: absolute;
  z-index: -1;
  perspective: 100px;
  /*safari対策*/ }

footer .bggrapes {
  position: absolute;
  bottom: 0;
  width: 100vw;
  height: 30vw;
  overflow: hidden;
  transform: rotateX(180deg); }

footer .bggrapes img {
  position: absolute;
  width: 40%; }

footer .bggrapes img.bg1 {
  top: -35%;
  left: -5%; }

footer .bggrapes img.bg2 {
  top: -60%;
  right: -2%; }

footer .bggrapes img.bg3 {
  width: 30%;
  top: -25%;
  right: -15%; }

/********/
/* HOME */
/********/
#sec_top {
  padding-top: 5px;
  overflow: hidden; }

#sec_top .slider .slick-slide {
  border: solid 5px #fff;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.25);
  margin: 15px -50px 20px;
  transition: .5s;
  transform: rotate(2deg) scale(0.95) translateY(-10px);
  position: relative;
  overflow: hidden; }
  #sec_top .slider .slick-slide picture {
    display: block !important; }
  #sec_top .slider .slick-slide img {
    transition: 3s;
    transform: scale(1); }

#sec_top .slider .slick-slide.slide_playing {
  transform: rotate(-2deg) scale(1) translateY(0);
  z-index: 2; }
  #sec_top .slider .slick-slide.slide_playing img {
    transition: 10s;
    transform: scale(1.2); }

#sec_top .sec_inner {
  position: relative;
  top: -40px;
  padding-bottom: 10px;
  max-width: 600px;
  margin: 0 auto; }

#sec_top .bggrape {
  position: absolute;
  z-index: -1;
  width: 100%;
  top: calc(-160px + 10vw); }

#sec_top .bggrape img {
  position: absolute;
  width: 420px;
  max-width: none;
  right: -40px; }

#sec_top .copy {
  width: 310px;
  height: 310px;
  border-radius: 100%;
  text-align: center;
  color: #fff;
  padding: 55px 40px 0;
  position: relative; }

#sec_top .copy h2 {
  font-size: 52px;
  margin: 0;
  line-height: 1; }

#sec_top .copy h2 rt {
  font-size: 12px; }

#sec_top .copy .txt {
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .2em;
  margin: 15px 0 0; }

#sec_top .copy_1 {
  background-color: rgba(0, 61, 108, 0.8);
  z-index: 2;
  margin-top: calc(100px - 10vw);
  left: 40px;
  background-image: url(img/treeripe.svg);
  background-repeat: no-repeat;
  background-position: center 39%;
  background-size: 150px; }

#sec_top .copy_2 {
  background-color: rgba(159, 38, 61, 0.8);
  margin-top: -50px;
  left: -20px;
  padding: 75px 35px 0;
  background-image: url(img/lactobacillus.svg);
  background-repeat: no-repeat;
  background-position: center 42%;
  background-size: 190px; }

#sec_top .copy_2 h2 {
  font-size: 42px; }

#sec_top .btn_more {
  width: 80px;
  height: 80px;
  font-size: 20px;
  z-index: 2;
  position: relative;
  margin-top: -50px;
  left: 200px;
  padding-top: 22px; }

#sec_top .btn_more .ja {
  display: block;
  font-size: 13px; }

#sec_news {
  overflow: hidden; }

#sec_news .sec_inner {
  padding: 0 2%; }

#sec_news .midashi {
  font-size: 18px;
  padding: 10px 0;
  width: 300px;
  margin: 0 auto 20px; }

.bloglist {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }

.blogkiji {
  display: block;
  width: calc(50% - 3px);
  background-color: #fff;
  padding: 5px 5px 30px;
  text-decoration: none;
  margin-bottom: 6px;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.1);
  position: relative; }

.blogkiji.hover {
  animation: pulse .4s; }

.blogkiji .img {
  width: 100%;
  height: calc((50vw - 13px)*2/3); }

.blogkiji .tag {
  margin: 5px 2px;
  line-height: 1;
  font-size: 10px; }

.blogkiji .tag span {
  display: inline-block;
  padding: 3px 2px;
  background-color: #003d6c;
  color: #fff; }

.blogkiji .title {
  font-size: 12px;
  font-weight: normal;
  line-height: 1.5;
  margin: 0 3px; }

.blogkiji time {
  font-size: 10px;
  color: #999;
  position: absolute;
  bottom: 5px; }

#fb {
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
  padding: 0;
  /*display: none;*/ }

.fb_iframe_widget,
.fb_iframe_widget span,
.fb_iframe_widget iframe[style] {
  width: 100% !important; }

/*********/
/* About */
/*********/
#sec_about {
  margin-top: 80px;
  margin-bottom: 60px; }

#sec_about .sec_inner {
  padding: 0 2%; }

#sec_about .tagline {
  width: 250px;
  margin: 0 auto 25px;
  position: relative; }

#sec_about .message {
  background-color: #265947;
  border-radius: 10px;
  padding: 20px 15px 70px;
  color: #fff;
  font-size: 16px;
  position: relative;
  margin: 0 auto 200px;
  width: 96%; }

#sec_about .message .txt {
  position: relative;
  background-image: linear-gradient(#547568 0.1em, transparent 0.1em);
  background-size: 100% 2em;
  background-position: 0 -.11em;
  text-align: justify; }

#sec_about .staff {
  margin-top: 40px; }

#sec_about .staff .staff_info {
  margin: 0 auto 20px;
  position: relative;
  max-width: 360px; }

#sec_about .staff .staff_info img {
  width: 280px;
  height: 280px;
  border: solid 10px #fff;
  border-radius: 100%;
  margin: 0 auto;
  display: block;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
  position: relative; }

#sec_about .staff .staff_info .msg {
  background-color: #fff;
  padding: 15px 15px 5px;
  z-index: -1;
  margin: -20px 10px 0;
  height: calc(100% - 260px); }

#sec_about .staff .staff_info .msg .txt {
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 2em;
  background-position: 0 -.11em;
  text-align: justify; }

#sec_about .staff .staff_2 .img_sub {
  position: absolute;
  width: 110px;
  height: 110px;
  border: solid 7px #fff;
  right: 0;
  top: 170px; }

#sec_about .omoi {
  background-image: url(img/bg_mark.png);
  background-size: 105px;
  padding: 30px 15px 15px;
  border-radius: 10px;
  color: #fff;
  max-width: 500px;
  margin: 0 auto; }

#sec_about .omoi h3 {
  text-align: center;
  font-size: 24px;
  margin: 0 0 20px; }

#sec_about .omoi .txt {
  text-align: justify; }

#sec_nakama .sec_inner {
  padding: 0 2%; }

#sec_nakama .midashi {
  font-size: 18px;
  padding: 10px 0;
  width: 300px;
  margin: 0 auto 20px; }

#sec_nakama .nakama_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 460px;
  margin: 0 auto; }

#sec_nakama .nakama_info {
  width: calc(50% - 3px);
  margin-bottom: 20px; }

#sec_nakama .nakama_info .img {
  width: 140px;
  height: 140px;
  border: solid 4px #fff;
  border-radius: 100%;
  margin: 0 auto;
  display: block;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
  position: relative; }

#sec_nakama .nakama_info .msg {
  color: #fff;
  background-color: #003d6c;
  padding: 15px 10px 15px;
  z-index: -1;
  margin-top: -10px;
  font-size: 12px;
  line-height: 1.5;
  height: calc(100% - 130px);
  text-align: justify;
  max-width: 220px; }

#sec_nakama .nakama_info:nth-child(even) .msg {
  background-color: #9f263d; }

/************/
/* Products */
/************/
#sec_products .sec_inner {
  padding: 0 2%; }

#sec_products .introduction {
  position: relative;
  max-width: 700px;
  margin: 30px auto; }

#sec_products .introduction h2 {
  font-size: 26px;
  margin-top: 10px;
  margin-bottom: 5px;
  margin-left: -.1em; }

#sec_products .introduction h2 .kana {
  font-size: 14px;
  vertical-align: 4px; }

#sec_products .introduction .exp {
  background-color: #fff;
  border-radius: 7px;
  padding: 20px 15px 40px;
  margin-top: -20px; }

#sec_products .introduction .exp .txt {
  position: relative;
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 2em;
  background-position: 0 -.11em;
  text-align: justify;
  margin-bottom: 30px;
  margin-top: 0; }

#sec_products .introduction .exp .txt p {
  margin: 0; }

#sec_products .introduction .info {
  list-style: none;
  padding: 0;
  font-weight: bold;
  min-height: 70px; }
  @media (min-width: 1280px) {
    #sec_products .introduction .info {
      min-height: auto; } }
  #sec_products .introduction .info .awards {
    margin-bottom: 30px; }
    #sec_products .introduction .info .awards .award {
      display: flex;
      line-height: 20px;
      margin-bottom: 10px; }
      #sec_products .introduction .info .awards .award::before {
        content: "";
        display: inline-block;
        width: 20px;
        height: 20px;
        background-image: url(img/icon_award.svg);
        background-size: 100%;
        background-repeat: no-repeat;
        margin-right: 3px; }

#sec_products .introduction .info .maru {
  display: inline-block;
  border-radius: 50%;
  width: 12px;
  height: 12px; }

#sec_products .introduction .info .maru:first-child {
  margin-left: 10px; }

#sec_products .introduction .info .maru {
  margin-right: 2px; }

#sec_products .introduction .info .txt_rev {
  color: #fff;
  display: inline-block;
  padding: 0 5px;
  margin-top: 5px;
  margin-right: 5px;
  line-height: 1.5; }

#sec_products .introduction .btn {
  display: block;
  margin: 30px auto 0;
  width: 220px; }

#sec_products .group_g h2 {
  color: #006946;
  font-weight: normal; }

#sec_products .group_g .info .maru {
  background-color: #006946; }

#sec_products .group_g .info .shiromaru {
  border: 1px solid #006946;
  background-color: #fff; }

#sec_products .group_g .txt_rev {
  background-color: #006946; }

#sec_products .group_g .btn {
  background-color: #006946; }

#sec_products .group_g .btn:after {
  border: solid 1px #006946; }

#sec_products .group_b h2 {
  color: #003d6c;
  font-weight: normal; }

#sec_products .group_b .info .maru {
  background-color: #003d6c; }

#sec_products .group_b .info .shiromaru {
  border: 1px solid #003d6c;
  background-color: #fff; }

#sec_products .group_b .txt_rev {
  background-color: #003d6c; }

#sec_products .group_b .btn {
  background-color: #003d6c; }

#sec_products .group_b .btn:after {
  border: solid 1px #003d6c; }

#sec_products .group_r h2 {
  color: #9f263d;
  font-weight: normal; }

#sec_products .group_r .info .maru {
  background-color: #9f263d; }

#sec_products .group_r .info .shiromaru {
  border: 1px solid #9f263d;
  background-color: #fff; }

#sec_products .group_r .txt_rev {
  background-color: #9f263d; }

#sec_products .group_r .btn {
  background-color: #9f263d; }

#sec_products .group_r .btn:after {
  border: solid 1px #9f263d; }

#sec_products .group_o h2 {
  color: #ac6525;
  font-weight: normal; }

#sec_products .group_o .info .maru {
  background-color: #ac6525; }

#sec_products .group_o .info .shiromaru {
  border: 1px solid #ac6525;
  background-color: #fff; }

#sec_products .group_o .txt_rev {
  background-color: #ac6525; }

#sec_products .group_o .btn {
  background-color: #ac6525; }

#sec_products .group_o .btn:after {
  border: solid 1px #ac6525; }

#sec_products .group_yg h2 {
  color: #60904d;
  font-weight: normal; }

#sec_products .group_yg .info .maru {
  background-color: #60904d; }

#sec_products .group_yg .info .shiromaru {
  border: 1px solid #60904d;
  background-color: #fff; }

#sec_products .group_yg .txt_rev {
  background-color: #60904d; }

#sec_products .group_yg .btn {
  background-color: #60904d; }

#sec_products .group_yg .btn:after {
  border: solid 1px #60904d; }

.cnt_wrap {
  /*position: relative;*/ }

.product_wrap aside {
  min-width: 200px;
  max-width: 260px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100; }

.product_wrap aside .group_title {
  font-size: 20px;
  color: #fff;
  padding: 0 10px;
  position: relative;
  cursor: pointer; }
  .product_wrap aside .group_title::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 6px 10.4px 6px;
    border-color: transparent transparent #ffffff transparent;
    position: absolute;
    top: 15px;
    right: 10px;
    transition: .3s; }
  .product_wrap aside .group_title.close::after {
    transform: rotateX(180deg); }
  .product_wrap aside .group_title.grape {
    background-color: #265947; }
  .product_wrap aside .group_title.rice {
    background-color: #ac6525; }
  .product_wrap aside .group_title.vegetable {
    background-color: #60904d; }

.product_wrap aside ul {
  list-style: none;
  padding: 20px 0 20px 20px;
  margin: 0 auto; }
  @media (min-width: 960px) {
    .product_wrap aside ul {
      padding: 15px 0 10px 20px; } }

.product_wrap aside ul li {
  margin-bottom: 7px; }

.product_wrap aside ul li.group_g {
  border-left: 8px solid #006946; }

.product_wrap aside ul li.group_b {
  border-left: 8px solid #003d6c; }

.product_wrap aside ul li.group_r {
  border-left: 8px solid #9f263d; }

.product_wrap aside ul li.group_o {
  border-left: 8px solid #ac6525; }

.product_wrap aside ul li.group_yg {
  border-left: 8px solid #60904d; }

.product_wrap aside ul li a {
  text-decoration: none;
  display: flex;
  /*height: 24px;*/
  padding-left: 7px;
  line-height: 1.5;
  align-items: center; }
  .product_wrap aside ul li a.awards {
    position: relative; }
    .product_wrap aside ul li a.awards::after {
      content: "";
      display: inline-block;
      width: 20px;
      height: 20px;
      background-image: url(img/icon_award.svg);
      background-size: 100%;
      background-repeat: no-repeat;
      margin-left: 3px; }
  @media (min-width: 960px) {
    .product_wrap aside ul li a {
      font-size: 14px; } }

.product_wrap .ichiran_btn {
  background-color: #006946;
  border-radius: 7px 0 0 7px;
  color: #fff;
  position: fixed;
  bottom: 40px;
  right: 0px;
  z-index: 10;
  writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  white-space: nowrap;
  text-align: center;
  height: 95px;
  width: 30px;
  font-size: 20px;
  line-height: 30px;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  text-decoration: none;
  display: block; }

.product_wrap .close_btn {
  background-color: #fff;
  border-radius: 7px 0 0 7px;
  color: #006946;
  position: absolute;
  top: 50px;
  left: -29px;
  z-index: 100;
  writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  white-space: nowrap;
  text-align: center;
  height: 95px;
  width: 30px;
  font-size: 20px;
  line-height: 30px;
  text-decoration: none;
  display: block; }

.menu_bg {
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 9;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  display: none; }

/**********/
/* Access */
/**********/
#sec_access {
  margin: 120px auto 0;
  max-width: 480px; }

#sec_access .sec_inner {
  padding: 0 2%; }

#sec_access .access {
  position: relative;
  background-color: #fff;
  padding: 40px 15px 20px;
  border-radius: 7px; }

#sec_access .access .exp .txt {
  position: relative;
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 2em;
  background-position: 0 -.11em;
  text-align: justify;
  margin-bottom: 30px; }

#sec_access .access .exp .contact {
  font-size: 12px;
  color: #265947;
  line-height: 1.7; }

#sec_access .access .googlemap {
  width: 100%;
  height: 300px;
  background-color: #ccc;
  margin-bottom: 15px; }

/********/
/* Blog */
/********/
#sec_bloglist {
  padding: 0 2%;
  margin-bottom: 60px; }

.blog_wrap aside {
  min-width: 200px;
  max-width: 260px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100; }

.blog_wrap .cate_title {
  display: none; }

.blog_wrap .cate {
  list-style: none;
  padding: 0 10px; }
  @media (min-width: 960px) {
    .blog_wrap .cate {
      max-height: calc(100vh - 150px);
      overflow-y: auto; } }

.blog_wrap .cate > li:first-child {
  border-top: 1px dashed rgba(38, 89, 71, 0.3); }

.blog_wrap .cate li a {
  border-bottom: 1px dashed rgba(38, 89, 71, 0.3);
  display: block;
  padding: 8px 0 8px 10px;
  line-height: 1.5; }

.blog_wrap .cate a {
  text-decoration: none; }

.blog_wrap .cate .children {
  list-style: none;
  padding: 0 0 0 20px;
  border-bottom: 1px dashed rgba(38, 89, 71, 0.3); }

.blog_wrap .cate .children li:last-child a {
  border-bottom: none; }

.blog_wrap .cate .kijinum {
  font-size: 11px;
  display: inline-block;
  margin-left: 5px;
  vertical-align: 1px; }

.blog_wrap .cate .dropdown {
  position: relative; }

.blog_wrap .cate .dropdown .arrow {
  position: absolute;
  right: 15px;
  top: 4px; }

.blog_wrap .cate .dropdown .arrow img {
  transform: rotateZ(90deg);
  transition: .5s; }

.blog_wrap .cate .dropdown.active .arrow img {
  transform: rotateZ(-90deg); }

.blog_wrap .cate .children.month {
  display: none; }

.blog_wrap .close_btn {
  background-color: #fff;
  border-radius: 7px 0 0 7px;
  color: #006946;
  position: fixed;
  top: 50px;
  right: 200px;
  z-index: 100;
  writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  white-space: nowrap;
  text-align: center;
  height: 95px;
  width: 30px;
  font-size: 20px;
  line-height: 30px;
  display: block;
  text-decoration: none; }

.blog_wrap .cate_btn {
  background-color: #006946;
  border-radius: 7px 0 0 7px;
  color: #fff;
  position: fixed;
  bottom: 40px;
  right: 0px;
  z-index: 10;
  writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  white-space: nowrap;
  text-align: center;
  height: 95px;
  width: 30px;
  font-size: 20px;
  line-height: 30px;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  display: block;
  text-decoration: none; }

.wp-pagenavi {
  margin-top: 30px;
  text-align: center; }

.wp-pagenavi a,
.wp-pagenavi span {
  display: inline-block;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  text-align: center;
  line-height: 30px;
  text-decoration: none;
  font-size: 14px;
  margin: 0 2px; }

.wp-pagenavi .extend {
  background-color: transparent;
  color: #006946;
  width: auto; }

.wp-pagenavi .arrow {
  width: 12px;
  height: 12px;
  vertical-align: -1px; }

.wp-pagenavi .arrow.rev {
  transform: rotateZ(180deg); }

.wp-pagenavi .current {
  background-color: #b46b07;
  color: #fff; }

.wp-pagenavi .page,
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink,
.wp-pagenavi .first,
.wp-pagenavi .last {
  background-color: #006946;
  color: #fff; }

/************/
/* Blogkiji */
/************/
#sec_blogkiji {
  padding: 0 2%; }

#sec_blogkiji .kijiarea {
  background-color: #fff;
  padding: 10px; }

#sec_blogkiji .kijiarea .img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
  margin-bottom: 20px; }

#sec_blogkiji .kijiarea .title {
  font-size: 18px;
  color: #006946;
  line-height: 1.5;
  margin-bottom: 3px;
  margin-top: 0; }

#sec_blogkiji .kijiarea .tag {
  margin: 5px 10px 5px 2px;
  line-height: 1;
  font-size: 12px;
  display: inline-block; }

#sec_blogkiji .kijiarea .tag span {
  display: inline-block;
  padding: 3px 2px;
  background-color: #003d6c;
  color: #fff; }

#sec_blogkiji .kijiarea time {
  font-size: 12px;
  color: #999;
  display: inline-block; }

#sec_blogkiji .kijiarea .kiji {
  text-align: justify; }
  #sec_blogkiji .kijiarea .kiji figure {
    margin: 1em 0; }

#sec_blogkiji .kijiarea .kiji p {
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 2em;
  background-position: 0 -.11em;
  border-top: .1em solid #eee;
  margin: 2em 0; }

#blognav {
  margin-bottom: 40px;
  margin-top: 20px;
  overflow: hidden;
  padding: 10px; }

#blognav > div {
  width: 140px; }

#blognav .blogkiji {
  width: 100%;
  height: calc(100% - 24px); }

#blognav .blogkiji .img {
  height: calc(130px * 2/3); }

#blognav .nextpost {
  float: left; }

#blognav .prevpost {
  float: right; }

#blognav .next,
#blognav .prev {
  font-size: 12px;
  text-decoration: none;
  position: relative;
  padding: 0 17px;
  display: block; }

#blognav .next .arrow {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 6px;
  height: auto;
  display: block; }

#blognav .next .arrow img {
  vertical-align: 1px;
  width: 100%;
  transform: rotate(180deg); }

#blognav .prev {
  text-align: right; }

#blognav .prev .arrow {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 6px;
  height: auto;
  display: block; }

#blognav .prev .arrow img {
  vertical-align: 1px;
  width: 100%; }

/***********/
/* Contact */
/***********/
#sec_contact {
  padding: 0 2%;
  max-width: 480px;
  margin: 50px auto 50px; }

#sec_contact .sec_inner {
  background-color: #fff;
  padding: 15px 15px 30px;
  border-radius: 7px; }

#sec_contact .txt {
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 2em;
  background-position: 0 -.11em;
  text-align: justify; }

#sec_contact .photo {
  transform: rotate(-3deg);
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
  border: solid 5px #fff;
  width: 70vw;
  max-width: 260px;
  margin: 30px auto; }

#sec_contact .tel_exp {
  color: #265947;
  line-height: 1.5;
  margin-bottom: 40px;
  text-align: center; }

#sec_contact .tel_exp .tel {
  font-size: 32px;
  text-decoration: none; }

#mailform .title {
  font-size: 16px;
  line-height: 16px;
  vertical-align: bottom;
  margin-bottom: 3px;
  display: block; }

#mailform .val {
  display: block; }

#mailform textarea,
#mailform input {
  border: 1px solid #265947;
  width: 100%;
  padding: 10px;
  font-size: 14px; }

#mailform textarea:focus,
#mailform input:focus {
  border: 1px solid #265947;
  outline: 0; }

#mailform textarea {
  height: 18em; }

#mailform .req {
  color: #ac6525;
  font-weight: bold;
  font-size: 12px;
  display: inline-block;
  line-height: 16px;
  margin-left: 10px;
  vertical-align: middle; }

#mailform label {
  display: block;
  margin-bottom: 20px; }

#mailform .btn_area {
  text-align: right;
  margin-top: 20px;
  display: block;
  display: flex;
  align-items: center;
  justify-content: flex-end; }

#mailform .btn_area input {
  width: 80px;
  background-color: #265947;
  color: #fff;
  box-shadow: none;
  border: none;
  order: 2; }

#mailform .btn_area input:disabled {
  background-color: #ccc; }

#mailform div.wpcf7-validation-errors {
  border: none;
  border-left: solid 5px #f00;
  text-align: justify;
  padding: 0 0 0 0.5em; }

#mailform div.wpcf7-mail-sent-ok {
  border: none;
  border-left: solid 5px #285847;
  text-align: justify;
  padding: 0 0 0 0.5em; }

#mailform .check {
  display: none; }
#mailform .check_area .wpcf7-list-item {
  margin: 0; }
#mailform .check_area label {
  margin-bottom: 0; }
@media (min-width: 960px) {
  #mailform .check_area {
    margin-left: 210px; } }
#mailform .check_txt {
  padding: 0 0 5px 30px;
  line-height: 24px;
  position: relative;
  display: inline-block;
  font-size: 13px; }
  #mailform .check_txt .btn_privacy {
    position: relative; }
    #mailform .check_txt .btn_privacy::after {
      content: "";
      display: inline-block;
      margin: 0 3px;
      position: relative;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 5px 8.7px 5px;
      border-color: transparent transparent #333 transparent; }
  #mailform .check_txt .req {
    vertical-align: inherit; }
#mailform .check_txt::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 25px;
  height: 25px;
  border: solid 1px #333;
  background-color: #fff; }
#mailform .check:checked + .wpcf7-list-item-label .check_txt::after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  left: 8px;
  width: 10px;
  height: 17px;
  transform: rotate(40deg);
  border-bottom: 3px solid #333;
  border-right: 3px solid #333; }
#mailform .privacy_txt {
  margin: 0;
  padding: 1px 10px;
  font-size: 13px;
  line-height: 1.7;
  color: #666;
  background-color: #eee;
  text-align: justify; }
  @media (min-width: 960px) {
    #mailform .privacy_txt {
      margin-left: 210px; } }

/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* スマホのみ */
@media screen and (max-width: 599px) {
  #sec_products .introduction .photos {
    width: 90vw;
    transform: rotate(3deg);
    margin: 0 auto; }

  #sec_products .introduction .photos .img {
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
    border: solid 5px #fff; }

  #sec_products .introduction .photos_wrapper {
    /*position: absolute;
    top:0;
    left: 4vw;*/ } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* タブレットのみ */
@media screen and (min-width: 600px) and (max-width: 959px) {
  /*nav .nav_inner{
    background-color: #fff;
    position: fixed;
    top:0;
    left: 0;
    width: 100vw;
    height: 180px;
    padding-top: 50px;
    display: none;
    box-shadow: 0 0 20px rgba(0,0,0,.5);
  }
  nav .btn_menu{
    top:60px;
  }*/
  .blogkiji {
    margin-bottom: 15px; }

  .breadcrumb {
    font-size: 12px; } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* デスクトップ未満 */
@media screen and (max-width: 959px) {
  .pconly {
    display: none; }

  nav.clone {
    display: none !important; }

  nav .nav_inner {
    background-color: #fff;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    z-index: 100;
    opacity: 0;
    visibility: hidden; }

  nav .nav_inner ul {
    display: flex;
    flex-wrap: wrap;
    width: 280px;
    margin: 0 auto;
    position: relative;
    top: 52%;
    transform: translateY(-50%); }

  nav .nav_inner .nav__menu {
    width: 140px;
    text-align: center; }

  #sec_about .message .snaps_wrapper {
    position: absolute;
    bottom: 50px;
    left: 50%;
    transform: translate(-50%, 100%) rotate(-4deg); }
    #sec_about .message .snaps_wrapper .snaps {
      width: 300px; }
      #sec_about .message .snaps_wrapper .snaps img {
        width: 280px !important;
        box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
        border: solid 5px #fff;
        margin: 10px;
        aspect-ratio: 3/2;
        object-fit: cover; }

  .product_wrap aside {
    transform: translateX(150%);
    background-color: #fff; }

  .product_wrap aside .sidemenu_wrap {
    background-color: #fff;
    overflow: auto;
    height: 100vh; }

  #sec_access .access .photos {
    width: 205px;
    transform: translateY(-80%) rotate(3deg); }

  #sec_access .access .photos .img {
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
    border: solid 5px #fff; }

  #sec_access .access .photos_wrapper {
    position: absolute;
    top: 0;
    left: 15px; }

  .blog_wrap aside {
    transform: translateX(150%);
    background-color: #fff; }

  .blog_wrap aside .sidemenu_wrap {
    background-color: #fff;
    overflow: auto;
    height: 100vh; } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* タブレット以上 */
@media screen and (min-width: 600px) {
  nav .nav_inner ul {
    width: 560px; }

  #sec_top .slider .slick-slide {
    margin: 15px -60px 30px;
    transform: rotate(2deg) scale(0.95) translateY(-20px); }

  #sec_top .copy_1 {
    margin-top: 40px; }

  #sec_top .bggrape {
    top: -100px; }

  #sec_top .copy_1 {
    background-color: rgba(0, 61, 108, 0.95); }

  #sec_top .copy_2 {
    background-color: rgba(159, 38, 61, 0.95); }

  .bloglist {
    justify-content: flex-start; }

  .blogkiji {
    width: calc(25% - 3px); }

  .bloglist .blogkiji {
    margin-right: 4px; }

  .bloglist .blogkiji:nth-child(4n) {
    margin-right: 0; }

  .blogkiji .img {
    height: calc((25vw - 13px)*2/3);
    max-height: 162px; }

  #sec_about .message {
    width: 90%;
    max-width: 600px;
    margin: 0 auto 200px;
    padding: 20px 40px 70px; }

  #sec_about .staff {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 720px;
    margin: 40px auto 0; }

  #sec_about .staff .staff_info {
    width: calc(50% - 10px); }

  #sec_about .omoi {
    max-width: 800px; }

  #sec_nakama .nakama_list {
    max-width: 800px; }

  #sec_nakama .nakama_info {
    width: calc(25% - 3px); }

  #sec_products {
    /*  max-width: 900px;
      margin: 0 auto;*/ }

  #sec_products .introduction .photos .img_1 {
    width: 70%;
    max-width: 600px;
    transform: rotate(3deg);
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
    border: solid 5px #fff; }

  #sec_products .introduction .photos .img_2 {
    width: 40%;
    max-width: 350px;
    transform: rotate(-3deg);
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
    border: solid 5px #fff;
    position: absolute;
    right: 0;
    bottom: 15px; }

  #sec_products .introduction .photos_wrapper {
    position: relative;
    width: 92%;
    margin: 0 auto;
    z-index: 2; }

  #sec_products .introduction .exp {
    position: relative;
    padding: 30px;
    margin-top: -30px; }

  #sec_products .introduction .btn {
    position: absolute;
    bottom: 50px;
    right: 45px; }

  #sec_access {
    max-width: 700px;
    margin: 0 auto;
    margin-top: 140px; }

  #sec_access .access {
    padding: 40px 30px 20px; }

  #sec_access .access .googlemap {
    height: 500px; }

  #blognav > div {
    width: 190px; }

  #blognav .blogkiji .img {
    height: calc(180px * 2/3); }

  #sec_blogkiji {
    max-width: 700px;
    margin: 0 auto; }

  #sec_blogkiji .kijiarea {
    padding: 20px; }

  #sec_contact {
    width: 80vw;
    max-width: 700px;
    margin: 50px auto 50px; }

  #sec_contact .sec_inner {
    padding: 30px; } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* iPad縦以上も設定 */
@media screen and (min-width: 768px) {
  #sec_top {
    padding-top: 0;
    margin-top: -10px; }

  #sec_top .slider .slick-slide {
    border-width: 10px;
    margin-top: 30px;
    transform: rotate(2deg) scale(0.95) translateY(-30px); }

  #sec_news .sec_inner {
    padding: 0 20px; }

  #fb {
    margin-bottom: 0; }

  .blogkiji {
    width: calc(25% - 5px); }

  .bloglist .blogkiji {
    margin-right: 6px; } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* デスクトップ以上 */
@media screen and (min-width: 960px) {
  body {
    font-size: 16px; }

  .mobonly {
    display: none !important; }

  header .logo {
    width: 160px;
    padding: 70px 15px 20px;
    z-index: 2; }

  nav:not(.clone) .nav_inner {
    position: absolute;
    top: 110px;
    left: -15px;
    width: 100%; }

  nav .nav_inner {
    display: block !important;
    opacity: 1 !important; }

  nav:not(.clone) .nav_inner ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    position: relative;
    width: 100%;
    justify-content: center; }

  nav .nav_inner .nav__menu {
    text-align: center; }

  nav:not(.clone) .nav_inner .nav__menu.menu1 {
    margin-right: 200px; }

  .nav__menu a {
    padding: 0 1.7vw; }

  .nav__menu a .icon {
    margin-bottom: 8px; }

  .nav__menu.current:before {
    background-image: url(img/bg_whitestripe.png);
    top: calc(50% - 48px); }

  .nav__menu.current:after {
    bottom: -10px; }

  .pagetitle {
    font-size: 32px; }

  header .bggrapes img {
    width: 35%; }

  header .bggrapes img.bg3 {
    width: 24%;
    right: -13%; }

  .sec {
    margin-bottom: 60px; }

  footer .bggrapes img {
    width: 35%; }

  footer .bggrapes img.bg3 {
    width: 24%;
    right: -13%; }

  #totop {
    font-size: 14px;
    width: 60px;
    height: 60px;
    padding-top: 12px;
    left: calc(50% - 30px);
    top: 10px; }

  .footer_inner .farm_info {
    font-size: 14px;
    padding: 60px 0 20px;
    line-height: 1.3; }

  .footer_inner .farm_info:after {
    width: 430px;
    height: 430px;
    left: calc(50% - 215px); }

  .footer_inner .farm_info .logo {
    width: 250px;
    margin-bottom: 30px; }

  .footer_inner .farm_info .tel {
    font-size: 26px; }

  nav.clone {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 65px;
    background-color: #fff;
    z-index: 200;
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
    opacity: 0;
    visibility: hidden; }

  nav.clone .icon {
    display: none; }

  nav.clone .logo {
    width: 200px;
    display: block;
    top: 50%;
    position: relative;
    transform: translateY(-50%);
    padding: 0 10px; }

  nav.clone .nav_inner {
    position: absolute;
    top: 7px;
    right: 20px;
    /*width: calc(100% - 160px);*/
    /*padding:0 40px;*/ }

  nav.clone .nav_inner ul {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    width: auto; }

  nav.clone .nav__menu a {
    font-size: 14px;
    padding: 12px 1.7vw; }

  nav.clone .nav__menu:not(.menu8):not(.current) a.hover {
    color: #ac6525; }

  nav.clone .nav__menu.current:before {
    display: none; }

  nav.clone .nav__menu.current:after {
    bottom: 7px; }

  #sec_top .slider .slick-slide {
    margin: 30px -70px 30px; }

  .ie #sec_top .slider .slick-slide {
    margin: 60px 0 60px; }

  .ie #sec_top .slider .slick-slide.slide_playing {
    transform: rotate(-2deg) scale(1.15) translateY(0); }

  #sec_top .sec_inner {
    width: 85%;
    max-width: 1000px; }

  #sec_top .bggrape img {
    width: 500px; }

  #sec_top .copy {
    padding: 95px 55px 0; }

  #sec_top .copy h2 {
    font-size: 72px; }

  #sec_top .copy h2 rt {
    font-size: 16px; }

  #sec_top .copy .txt {
    font-size: 16px;
    margin-top: 20px; }

  #sec_top .copy_2 h2 {
    font-size: 52px; }

  #sec_top .copy_1 {
    width: 430px;
    height: 430px;
    left: -50px;
    background-position: center 45%;
    background-size: 220px; }

  #sec_top .copy_2 {
    width: 370px;
    height: 370px;
    left: 100px;
    padding: 90px 40px 0;
    background-position: center 44%;
    background-size: 230px; }

  #sec_top .btn_more {
    width: 120px;
    height: 120px;
    left: 480px;
    margin-top: -140px;
    font-size: 24px;
    padding-top: 38px; }

  #sec_top .btn_more .ja {
    font-size: 14px; }

  .midashi .title:before,
  .midashi .title:after {
    width: 50px; }

  .midashi .title:before {
    left: -80px; }

  .midashi .title:after {
    right: -80px; }

  #sec_news {
    margin-bottom: 0; }

  #sec_news .sec_inner {
    max-width: 1100px;
    margin: 0 auto; }

  #sec_news .midashi {
    font-size: 30px;
    width: 600px;
    margin-bottom: 70px; }

  .blogkiji {
    padding: 8px 8px 30px; }

  .blogkiji .tag {
    font-size: 12px;
    margin: 10px 2px 8px; }

  .blogkiji .title {
    font-size: 16px; }

  .blogkiji time {
    font-size: 12px;
    margin: 0 3px; }

  #sec_about {
    overflow: hidden; }

  #sec_about .tagline {
    width: 380px;
    margin: 0 auto 50px; }

  #sec_about .tagline:after {
    top: -25px;
    right: -30px; }

  #sec_about .message {
    font-size: 18px;
    width: 580px;
    padding: 50px 70px 20px;
    margin: 0 auto; }

  #sec_about .message .snaps img {
    width: 310px;
    position: absolute;
    border: solid 7px #fff;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
    aspect-ratio: 3/2;
    object-fit: cover; }

  #sec_about .message .snaps img:nth-child(1) {
    top: 50px;
    left: -400px;
    transform: rotate(-4deg);
    z-index: 4; }

  #sec_about .message .snaps img:nth-child(2) {
    top: 215px;
    left: -300px;
    transform: rotate(2deg);
    z-index: 3; }

  #sec_about .message .snaps img:nth-child(3) {
    width: 380px;
    top: 100px;
    right: -360px;
    transform: rotate(-3deg);
    z-index: 3; }

  #sec_about .message .snaps_wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%; }

  #sec_about .staff {
    max-width: 920px; }

  #sec_about .staff .staff_info {
    max-width: none; }

  #sec_about .staff .staff_info img {
    width: 400px;
    height: 400px; }

  #sec_about .staff .staff_2 .img_sub {
    width: 150px;
    height: 150px;
    right: -40px;
    top: 210px; }

  #sec_about .staff .staff_info .msg {
    width: 360px;
    margin: -20px auto 0;
    padding: 15px 25px 5px;
    height: calc(100% - 370px); }

  #sec_about .omoi {
    margin-top: 40px;
    width: 90%;
    max-width: 980px;
    padding: 30px 50px 15px; }

  #sec_about .omoi h3 {
    font-size: 30px; }

  #sec_nakama .midashi {
    width: 580px;
    font-size: 30px;
    margin-bottom: 40px; }

  #sec_nakama .nakama_list {
    max-width: 1000px; }

  #sec_nakama .nakama_info {
    width: calc(25% - 30px); }

  #sec_nakama .nakama_info .img {
    width: 200px;
    height: 200px; }

  #sec_nakama .nakama_info .msg {
    font-size: 14px;
    padding: 20px 20px 10px;
    height: calc(100% - 180px); }

  .cnt_wrap {
    max-width: 1180px;
    width: 100%;
    margin: 0 auto;
    padding-top: 10px;
    position: relative; }

  #sec_products {
    width: 75%; }

  #sec_products .introduction {
    margin-bottom: 60px;
    max-width: 800px; }

  #sec_products .introduction .btn {
    width: 235px; }

  .product_wrap aside {
    display: block;
    position: absolute;
    top: 30px;
    left: 87%;
    right: auto;
    transform: translateX(-50%) !important; }

  .product_wrap aside.fixed {
    position: fixed;
    top: 90px; }

  .product_wrap aside .product_list {
    border-radius: 9px;
    overflow: hidden;
    margin-bottom: 20px;
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
    background-color: #fff; }

  .product_wrap .ichiran_btn,
  .product_wrap .close_btn {
    display: none; }

  #sec_access {
    margin-top: 40px;
    overflow: hidden;
    width: 100%;
    max-width: none; }

  #sec_access .access {
    max-width: 780px;
    width: 70vw;
    padding: 50px;
    margin: 0 auto; }

  #sec_access .access .photos_wrapper {
    position: relative;
    z-index: 1; }

  #sec_access .access .exp p {
    width: 42vw;
    max-width: 500px;
    margin: 0 auto 35px; }

  #sec_access .access .exp .contact {
    font-size: 14px; }

  #sec_access .access .photos .img {
    width: 275px;
    position: absolute;
    border: solid 7px #fff;
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2); }

  #sec_access .access .photos .img_1 {
    top: -30px;
    right: -250px;
    transform: rotate(-4deg);
    z-index: 2; }

  #sec_access .access .photos .img_2 {
    top: 100px;
    left: -250px;
    transform: rotate(4deg);
    z-index: 2; }

  .blog_wrap {
    /*  max-width: calc(100vw - 280px);
      margin: 0;*/ }

  .blog_wrap aside {
    display: block;
    position: absolute;
    top: 30px;
    left: 87%;
    right: auto;
    transform: translateX(-50%) !important; }

  .blog_wrap aside.fixed {
    position: fixed;
    top: 90px; }

  .blog_wrap aside > div {
    border-radius: 9px;
    overflow: hidden;
    margin-bottom: 20px;
    background-color: #fff;
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2); }

  .blog_wrap .close_btn {
    display: none; }

  .blog_wrap aside .cate_title {
    display: block;
    background-color: #265947;
    color: #fff;
    font-size: 20px;
    padding: 0 10px; }

  .blog_wrap .cate_btn {
    display: none; }

  .blog_wrap .cate {
    padding: 30px 15px;
    margin: 0; }

  .blog_wrap .cate a {
    font-size: 14px; }

  .blog_wrap .cate .dropdown {
    position: relative; }

  .blog_wrap .cate .dropdown .arrow {
    position: absolute;
    right: 15px; }

  #sec_bloglist {
    width: 75%; }

  .blog_wrap .blogkiji {
    width: calc(33% - 5px);
    margin-bottom: 30px;
    margin-right: 10px; }

  .blog_wrap .bloglist .blogkiji:nth-child(3n) {
    margin-right: 0; }

  .blog_wrap .bloglist .blogkiji:nth-child(4n) {
    margin-right: 10px; }

  .breadcrumb a,
  .breadcrumb span {
    font-size: 14px; }

  .breadcrumb a:hover {
    color: #ac6525; }

  .wp-pagenavi a, .wp-pagenavi span {
    width: 40px;
    height: 40px;
    line-height: 40px; }

  #sec_blogkiji,
  .breadcrumb.blog {
    width: 75%;
    max-width: none;
    margin: 0 0 15px 0; }

  #blognav {
    margin: 20px auto 40px; }

  #blognav > div {
    width: 250px; }

  #blognav .blogkiji .img {
    height: calc(240px * 2/3); }

  #sec_blogkiji .kijiarea {
    padding: 40px; }

  #sec_blogkiji .kijiarea .title {
    font-size: 24px; }

  #sec_contact {
    max-width: 800px; }

  #sec_contact .sec_inner {
    padding: 30px 60px; }

  #sec_contact .tel_wrap {
    display: flex;
    margin: 0 auto 30px;
    justify-content: space-between; }

  #sec_contact .photo {
    width: 50%;
    max-width: 310px;
    margin: 10px auto; }

  #sec_contact .tel_wrap .tel_exp {
    padding-top: 40px;
    font-size: 14px;
    width: 45%; }

  #sec_contact .tel_wrap .tel_exp .hosoku {
    font-size: 12px; }

  #mailform {
    max-width: 680px;
    margin: 0 auto; }

  #mailform label {
    display: flex; }

  #mailform label .title {
    width: 210px;
    line-height: 40px; }

  #mailform label .val {
    width: calc(100% - 210px); }

  #mailform label.check_area {
    padding-left: 210px; }

  #mailform .check_txt::before {
    top: 2px; }

  #mailform .check:checked + .check_txt::after {
    top: 3px; } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* サイドメニュー対応 */
@media screen and (min-width: 1180px) {
  .product_wrap aside.fixed {
    left: calc(50% - 590px + 1026px); }

  .blog_wrap aside.fixed {
    left: calc(50% - 590px + 1026px); } }
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
/* デスクトップ幅広のみ */
@media screen and (min-width: 1280px) {
  header .logo {
    width: 220px;
    padding: 70px 20px 30px; }

  nav:not(.clone) .nav_inner {
    top: 130px; }

  nav:not(.clone) .nav_inner .nav__menu.menu1 {
    margin-right: 280px; }

  .nav__menu a .icon {
    margin-bottom: 14px; }

  header .bggrapes img.bg1 {
    width: 390px;
    top: -100px;
    left: -40px; }

  header .bggrapes img.bg2 {
    width: 390px;
    top: -190px;
    right: 0; }

  header .bggrapes img.bg3 {
    width: 310px;
    top: -110px;
    right: -150px; }

  footer .bggrapes img.bg1 {
    width: 390px;
    top: -100px;
    left: -40px; }

  footer .bggrapes img.bg2 {
    width: 390px;
    top: -190px;
    right: 0; }

  footer .bggrapes img.bg3 {
    width: 310px;
    top: -110px;
    right: -150px; }

  nav.clone .logo {
    width: 220px; }

  nav.clone .nav__menu a {
    font-size: 16px;
    padding-top: 10px; }

  #sec_products .introduction {
    max-width: none; }

  #sec_products .sec_inner {
    padding: 0; }

  #sec_products .introduction h2 {
    font-size: 40px; }

  #sec_products .introduction h2 .kana {
    font-size: 18px;
    vertical-align: 8px; }

  #sec_products .introduction .exp {
    padding: 40px 50px 40px 60px; }

  #sec_products .introduction .exp_inner {
    display: flex;
    justify-content: space-between; }

  #sec_products .introduction .exp_inner .txt {
    width: 480px; }

  #sec_products .introduction .exp_inner .infoarea {
    width: 235px; }

  #sec_products .introduction .info {
    margin: 0; }

  #sec_products .introduction .btn {
    position: relative;
    bottom: auto;
    right: auto; }

  .blog_wrap {
    margin: 0 auto;
    width: 1180px; }

  .blog_wrap aside {
    width: 260px; } }
.grecaptcha-badge {
  display: none; }

.google_cap {
  margin-top: .5em;
  color: #999;
  line-height: 1.5;
  font-size: 80%; }
  .google_cap a {
    color: #999; }

#sec_top .bnr_bplus {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 90%;
  max-width: 350px;
  padding: 10px;
  background-color: #fff;
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  text-decoration: none;
  z-index: 90;
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2); }
  @media (min-width: 960px) {
    #sec_top .bnr_bplus {
      left: auto;
      right: 20px;
      transform: none; } }
  #sec_top .bnr_bplus.hide {
    transform: translateX(-50%) translateY(200%); }
    @media (min-width: 960px) {
      #sec_top .bnr_bplus.hide {
        transform: translateY(200%); } }
  #sec_top .bnr_bplus .photo {
    width: 70px;
    height: 70px;
    border-radius: 100%; }
  #sec_top .bnr_bplus .txt .cmt {
    display: block;
    color: #265947;
    font-size: clamp(10px, calc(-1.636px + 3.636vw), 12px);
    font-weight: 600; }
  #sec_top .bnr_bplus .txt .ttl {
    display: inline-block;
    font-family: "リュウミン R-KL", serif;
    color: #333;
    font-size: clamp(11px, calc(-12.273px + 7.273vw), 15px);
    line-height: 1.3333;
    position: relative;
    padding: 0 5px; }
    #sec_top .bnr_bplus .txt .ttl::before {
      content: "「";
      position: absolute;
      top: 0;
      left: -.5em; }
    #sec_top .bnr_bplus .txt .ttl::after {
      content: "」";
      position: absolute;
      bottom: 0;
      right: -.5em; }
  #sec_top .bnr_bplus .lbl {
    position: absolute;
    bottom: 0;
    right: 0;
    font-size: 10px;
    line-height: 12px;
    font-weight: 600;
    color: #fff;
    display: block;
    width: 70px;
    height: 100%;
    background-color: #265947;
    padding: 5px;
    clip-path: polygon(100% 0, 100% 100%, 0 100%); }
    #sec_top .bnr_bplus .lbl span {
      position: absolute;
      bottom: 5px;
      right: 5px; }

#sec_homestyle {
  margin-bottom: 100px; }
  #sec_homestyle .midashi {
    font-size: 18px;
    padding: 10px 0;
    width: 300px;
    margin: 0 auto 20px; }
    @media (min-width: 960px) {
      #sec_homestyle .midashi {
        font-size: 30px;
        width: 670px;
        margin-bottom: 50px; } }
  @media (min-width: 960px) {
    #sec_homestyle .ss_cont {
      display: flex;
      justify-content: center;
      align-items: flex-start;
      gap: clamp(15px, calc(-115.000px + 13.542vw), 80px); } }
  #sec_homestyle .ss_unit {
    display: grid;
    gap: 10px;
    margin-bottom: 60px; }
    @media (min-width: 960px) {
      #sec_homestyle .ss_unit:nth-child(2) {
        margin-top: 60px; } }
    #sec_homestyle .ss_unit .photo {
      width: 90vw;
      height: 90vw;
      max-width: 300px;
      max-height: 300px;
      margin: 0 auto;
      position: relative; }
      #sec_homestyle .ss_unit .photo::before {
        content: "";
        position: absolute;
        top: -5px;
        left: -5px;
        width: calc(100% + 10px);
        height: calc(100% + 10px);
        border-radius: 100%;
        border: solid 1px #265947; }
      #sec_homestyle .ss_unit .photo img {
        width: 100%;
        height: 100%;
        border-radius: 100%;
        object-fit: cover; }
    #sec_homestyle .ss_unit .ttl {
      font-size: 24px;
      font-weight: 600;
      color: #265947;
      line-height: 1.5;
      text-align: center; }
    #sec_homestyle .ss_unit .exp {
      line-height: 1.5;
      color: #265947;
      width: 90vw;
      max-width: 300px;
      margin: 0 auto; }
  #sec_homestyle .btn_more {
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-size: 24px;
    margin: 0 auto;
    width: 120px;
    height: 120px; }
    #sec_homestyle .btn_more .ja {
      display: block;
      font-size: 14px; }

#sec_harvest {
  margin-bottom: 100px; }
  #sec_harvest .midashi {
    font-size: 18px;
    padding: 10px 0;
    width: 300px;
    margin: 0 auto 20px; }
    @media (min-width: 960px) {
      #sec_harvest .midashi {
        font-size: 30px;
        width: 670px;
        margin-bottom: 70px; } }
  #sec_harvest .schedule {
    overflow: scroll;
    padding: 10px 10px 10px 10px;
    max-width: 520px;
    margin: 0 auto;
    box-sizing: border-box; }
    @media (min-width: 600px) {
      #sec_harvest .schedule {
        overflow: auto; } }
    @media (min-width: 960px) {
      #sec_harvest .schedule {
        max-width: 700px;
        padding: 10px 0; } }
    #sec_harvest .schedule img {
      width: 500px;
      max-width: none; }
      @media (min-width: 960px) {
        #sec_harvest .schedule img {
          width: 700px; } }
  #sec_harvest .hosoku_img {
    text-align: right;
    max-width: 600px;
    margin: 0 auto; }
    @media (min-width: 960px) {
      #sec_harvest .hosoku_img {
        max-width: 800px; } }
    #sec_harvest .hosoku_img img {
      width: 210px; }
      @media (min-width: 960px) {
        #sec_harvest .hosoku_img img {
          width: 280px; } }
  #sec_harvest .btn_more {
    display: block;
    width: 200px;
    margin: 50px auto;
    font-size: 18px; }

#sec_news {
  margin-bottom: 100px; }
  #sec_news .sec_inner {
    padding: 0 20px; }
  #sec_news .exp {
    color: #265947;
    max-width: 500px;
    margin: 0 auto 20px;
    text-align: justify; }
  #sec_news .fb_wrapper {
    position: relative;
    max-width: 500px;
    margin: 0 auto; }
    #sec_news .fb_wrapper .sn_photos {
      transform: rotate(-3deg) translateX(-10px);
      margin: 10px auto;
      max-width: 400px; }
      @media (min-width: 960px) {
        #sec_news .fb_wrapper .sn_photos {
          position: absolute;
          width: 400px;
          transform: none;
          margin: 0;
          top: 0;
          left: calc(50% - 190px); } }
      #sec_news .fb_wrapper .sn_photos img {
        display: block;
        width: 90% !important;
        max-width: 380px;
        border: solid 6px #fff;
        box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
        aspect-ratio: 3/2;
        object-fit: cover;
        margin: 10px; }
        @media (min-width: 960px) {
          #sec_news .fb_wrapper .sn_photos img {
            position: absolute;
            width: 380px !important; }
            #sec_news .fb_wrapper .sn_photos img:nth-child(1) {
              top: 50px;
              left: -500px;
              transform: rotate(5deg); }
            #sec_news .fb_wrapper .sn_photos img:nth-child(2) {
              top: 180px;
              right: -450px;
              transform: rotate(-5deg);
              width: 350px !important; }
            #sec_news .fb_wrapper .sn_photos img:nth-child(3) {
              top: 440px;
              left: -430px;
              transform: rotate(-3deg);
              width: 320px !important; } }
    #sec_news .fb_wrapper .btn_insta {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 282px;
      background-color: #fff;
      border-radius: 10px;
      padding: 5px;
      text-align: center;
      font-size: 18px;
      position: relative;
      left: calc(50% - 141px);
      top: -20px;
      transform: rotate(3deg); }
      @media (min-width: 960px) {
        #sec_news .fb_wrapper .btn_insta {
          position: absolute;
          top: 550px;
          left: auto;
          right: -320px; } }
      #sec_news .fb_wrapper .btn_insta img {
        display: inline-block;
        margin-right: 5px; }

#sec_style {
  margin-top: 60px; }
  #sec_style .style_unit {
    position: relative;
    padding: 70px 15px;
    min-height: 800px;
    color: #134533; }
    @media (min-width: 960px) {
      #sec_style .style_unit {
        padding: 150px 120px; } }
    #sec_style .style_unit .su_inner {
      max-width: 600px;
      margin: 0 auto;
      opacity: 0; }
      @media (min-width: 960px) {
        #sec_style .style_unit .su_inner {
          max-width: 1400px; } }
    #sec_style .style_unit .ttl {
      font-size: clamp(26px, calc(10.286px + 4.911vw), 48px);
      margin-bottom: 40px;
      line-height: 1.5;
      font-weight: normal; }
    @media (min-width: 960px) {
      #sec_style .style_unit .txt {
        width: 600px; } }
    #sec_style .style_unit .txt > * + * {
      margin-top: 20px; }
      @media (min-width: 960px) {
        #sec_style .style_unit .txt > * + * {
          margin-top: 40px; } }
    #sec_style .style_unit .txt p {
      text-align: justify; }
    #sec_style .style_unit .txt strong {
      background: linear-gradient(transparent 50%, rgba(255, 208, 0, 0.5) 50%);
      display: inline; }
    #sec_style .style_unit .txt .note {
      color: #904D10; }
    #sec_style .style_unit .txt .hosoku {
      color: #904D10;
      font-size: 13px; }
    #sec_style .style_unit .bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: -1;
      opacity: 0; }
      #sec_style .style_unit .bg img {
        position: absolute;
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: object-position 5s cubic-bezier(0.3, 0, 0.7, 1); }
        #sec_style .style_unit .bg img:nth-child(2) {
          display: none; }
    #sec_style .style_unit.style1 .bg img, #sec_style .style_unit.style3 .bg img {
      object-position: 70%; }
      #sec_style .style_unit.style1 .bg img.ani, #sec_style .style_unit.style3 .bg img.ani {
        object-position: 30%; }
        @media (min-width: 600px) {
          #sec_style .style_unit.style1 .bg img.ani, #sec_style .style_unit.style3 .bg img.ani {
            object-position: 15%; } }
        @media (min-width: 768px) {
          #sec_style .style_unit.style1 .bg img.ani, #sec_style .style_unit.style3 .bg img.ani {
            object-position: 0%; } }
    @media (min-width: 960px) {
      #sec_style .style_unit.style2 .su_inner {
        display: grid;
        justify-content: end; }
        #sec_style .style_unit.style2 .su_inner .ttl {
          text-align: right; } }
    #sec_style .style_unit.style2 .bg img {
      object-position: 30%; }
      #sec_style .style_unit.style2 .bg img.ani {
        object-position: 80%; }
        @media (min-width: 600px) {
          #sec_style .style_unit.style2 .bg img.ani {
            object-position: 100%; } }
    #sec_style .style_unit.style2, #sec_style .style_unit.style3 {
      color: #fff; }
      #sec_style .style_unit.style2 .txt .hosoku, #sec_style .style_unit.style3 .txt .hosoku {
        color: #fff; }
  #sec_style .snaps {
    position: relative;
    height: 100vw;
    max-height: 600px; }
    #sec_style .snaps img {
      position: absolute;
      display: block;
      width: 80%;
      max-width: 500px;
      border: solid 6px #fff;
      box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
      aspect-ratio: 3/2;
      object-fit: cover; }
      #sec_style .snaps img:nth-child(1) {
        top: -30px;
        left: 50%;
        transform: translateX(-55%) rotate(-3deg); }
        @media (min-width: 768px) {
          #sec_style .snaps img:nth-child(1) {
            transform: translateX(-70%) rotate(-3deg); } }
      #sec_style .snaps img:nth-child(2) {
        width: 70%;
        max-width: 400px;
        top: 40vw;
        left: 50%;
        transform: translateX(-40%) rotate(5deg); }
        @media (min-width: 600px) {
          #sec_style .snaps img:nth-child(2) {
            top: 260px; } }
        @media (min-width: 768px) {
          #sec_style .snaps img:nth-child(2) {
            transform: translateX(-20%) rotate(5deg); } }

#sec_about .company_info {
  background-color: rgba(255, 255, 255, 0.4);
  padding: 50px 15px 20px;
  margin: 120px auto;
  color: #265947;
  max-width: 960px; }
  @media (min-width: 960px) {
    #sec_about .company_info {
      padding: 50px 100px 50px; } }
  #sec_about .company_info > .ttl {
    text-align: center;
    font-size: 26px;
    line-height: 1;
    margin-bottom: 50px; }
    #sec_about .company_info > .ttl .ja {
      display: inline-block; }
    #sec_about .company_info > .ttl .en {
      display: block;
      font-size: 14px; }
  #sec_about .company_info .outline {
    line-height: 1.5;
    margin: 0 auto; }
    @media (max-width: 599px) {
      #sec_about .company_info .outline {
        display: block;
        width: 100%; } }
    @media (min-width: 960px) {
      #sec_about .company_info .outline {
        width: 100%; } }
    @media (max-width: 599px) {
      #sec_about .company_info .outline tbody {
        display: block; } }
    #sec_about .company_info .outline tr {
      border-bottom: solid 1px rgba(38, 89, 71, 0.2); }
      @media (max-width: 599px) {
        #sec_about .company_info .outline tr {
          display: block; } }
    #sec_about .company_info .outline th {
      padding: 10px 60px 10px 20px;
      font-weight: normal;
      text-align: left;
      vertical-align: baseline; }
      @media (max-width: 599px) {
        #sec_about .company_info .outline th {
          display: block;
          padding: 10px 5px 0;
          font-weight: bold; } }
    #sec_about .company_info .outline td {
      padding: 10px 20px 10px 0; }
      @media (max-width: 599px) {
        #sec_about .company_info .outline td {
          display: block;
          padding: 0 5px 10px; } }
#sec_about .daihyou {
  overflow: hidden;
  margin-bottom: 300px; }
  #sec_about .daihyou .main_snap {
    display: block;
    width: calc(100% - 10px);
    max-width: 800px;
    border: solid 6px #fff;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
    aspect-ratio: 3/2;
    object-fit: cover;
    margin: 0 auto;
    z-index: 2;
    position: relative; }
  #sec_about .daihyou .cont {
    width: calc(100% - 30px);
    max-width: 600px;
    margin: -10px auto 0;
    background-color: #fff;
    padding: 50px 15px;
    color: #265947;
    position: relative; }
    @media (min-width: 600px) {
      #sec_about .daihyou .cont {
        padding: 50px 50px; } }
    @media (min-width: 960px) {
      #sec_about .daihyou .cont {
        max-width: 680px; } }
    #sec_about .daihyou .cont .ttl {
      text-align: center;
      font-size: 26px;
      line-height: 1;
      margin-bottom: 50px; }
      #sec_about .daihyou .cont .ttl .en {
        display: block;
        font-size: 14px; }
    #sec_about .daihyou .cont p {
      position: relative;
      line-height: 2.5;
      background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
      background-size: 100% 2.5em;
      background-position: 0 -.11em;
      text-align: justify;
      margin-bottom: 2.5em;
      border-top: solid 1px #eee; }
    #sec_about .daihyou .cont .sub_snap {
      display: block;
      width: 90%;
      max-width: 400px;
      border: solid 6px #fff;
      box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
      aspect-ratio: 3/2;
      object-fit: cover;
      margin: 20px auto;
      z-index: 2;
      position: relative; }
      @media (min-width: 960px) {
        #sec_about .daihyou .cont .sub_snap {
          position: absolute; } }
      #sec_about .daihyou .cont .sub_snap.snap5 {
        transform: translateX(20%) rotate(3deg); }
        @media (min-width: 600px) {
          #sec_about .daihyou .cont .sub_snap.snap5 {
            transform: translateX(40%) rotate(3deg); } }
        @media (min-width: 960px) {
          #sec_about .daihyou .cont .sub_snap.snap5 {
            right: -390px;
            transform: translateX(0) translateY(0%) rotate(3deg); } }
      #sec_about .daihyou .cont .sub_snap.snap6 {
        transform: translateX(-20%) rotate(-3deg); }
        @media (min-width: 600px) {
          #sec_about .daihyou .cont .sub_snap.snap6 {
            transform: translateX(-40%) rotate(-3deg); } }
        @media (min-width: 960px) {
          #sec_about .daihyou .cont .sub_snap.snap6 {
            left: -390px;
            transform: translateX(0) translateY(0%) rotate(-3deg); } }
    #sec_about .daihyou .cont .sign {
      text-align: right;
      font-size: 14px; }
      #sec_about .daihyou .cont .sign .name {
        font-size: 24px;
        line-height: 1;
        margin-top: 10px; }
        #sec_about .daihyou .cont .sign .name .en {
          font-size: 14px;
          display: block; }
#sec_about .nidaime {
  position: relative;
  color: #fff;
  width: calc(100% - 30px);
  margin: 0 auto;
  max-width: 600px; }
  @media (min-width: 960px) {
    #sec_about .nidaime {
      max-width: 900px; } }
  #sec_about .nidaime .main_snap {
    display: block;
    width: 80%;
    max-width: 400px;
    border: solid 6px #fff;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
    aspect-ratio: 3/2;
    object-fit: cover;
    z-index: 2;
    position: absolute;
    left: 50%;
    transform: translate(-50%, -80%) rotate(3deg); }
    @media (min-width: 960px) {
      #sec_about .nidaime .main_snap {
        left: auto;
        right: 0;
        transform: translate(20%, -60%) rotate(3deg); } }
  #sec_about .nidaime .cont {
    border-radius: 20px;
    padding: 60px 15px 30px;
    background-image: url(img/bg_mark.png);
    background-size: 105px; }
    @media (min-width: 600px) {
      #sec_about .nidaime .cont {
        padding: 60px 50px 30px; } }
    @media (min-width: 960px) {
      #sec_about .nidaime .cont {
        padding: 30px 100px 30px; } }
    #sec_about .nidaime .cont .ttl {
      text-align: center;
      font-size: clamp(20px, calc(6.286px + 4.286vw), 32px); }
      @media (min-width: 960px) {
        #sec_about .nidaime .cont .ttl {
          text-align: left;
          transform: translateX(-32px); } }
    #sec_about .nidaime .cont .sign {
      text-align: right;
      display: flex;
      justify-content: flex-end;
      align-items: center;
      gap: 10px;
      margin-top: 20px; }
      @media (min-width: 600px) {
        #sec_about .nidaime .cont .sign {
          transform: translateX(20px); } }
      #sec_about .nidaime .cont .sign .txt {
        line-height: 1.5; }
        #sec_about .nidaime .cont .sign .txt .name {
          font-size: 24px; }
      #sec_about .nidaime .cont .sign .photo {
        display: block;
        width: 120px;
        height: 120px;
        border-radius: 100%;
        border: solid 6px #fff;
        box-shadow: 0 0 5px rgba(0, 0, 0, 0.2); }
