﻿.bg_color1, .hvr_bg_color1:hover {background-color: #f1cac1;}
.bg_color3, .hvr_bg_color3:hover{background-color: #aac49b;}
.bg_color4, .hvr_bg_color4:hover {background-color: #f1cac1;}
.bg_black, .hvr_bg_black:hover {
    background-color: #aac49b;
    color: #fff!important;
}
.txt_color2, .hvr_txt_color2:hover {color: #d68c7a;}
.txt_color4, .hvr_txt_color4:hover {color: #d68c7a;}
.border_color2, .hvr_border_color2:hover {border-color: #f1cac1;}
.border_color3, .hvr_border_color3:hover{border-color: #aac49b;}
.border_color4, .hvr_border_color4:hover { border-color: #aac49b;}


/* ----------　all　---------- */
.linkStyle{
	color:#d68c7a;
}
.linkStyle:hover{
	color:#d68c7a;
	opacity: 0.7;
	transition: all 0.5s;
}
#loading{
        background-color: #f4f4ec;
}
.lightboxOverlay {
    background-color: #fafaf0;
}
.liana,.patrima ,h1, h2, h3, h4, h5, h6,#contents .con_box .con_txt,.overlay .overlay-nav .top .en {
    font-family: 'Kaisei Opti', serif;
}
.txt_white, .hvr_txt_white:hover {
    color: #5e5040;
}
header.scr_header {
    background-color: rgba(250, 250, 240 ,0.5)!important;
    border: none;
}

.blur {
    background: #fafaf0;
}
footer #footer_info{
    background-color: #f4f4ec;
}
footer .info_btn_wrap p a{
        border-radius: 50px;
}
.overlay{
    background-color: rgba(250 ,250, 240 ,0.5);
}
.overlay .overlay-nav > ul li a {
    color: #5e5040;
}
.menu-trigger-bar,.close-trigger-bar {
    height: 3px;
    background-color: #f1cac1;
}
.close-trigger-bar:before ,.menu-trigger-bar:before{
    background-color: rgba(255 ,255, 255 ,0.5);
}
.filter{
    display: none!important;
}
#loading #loading_text .progressbar-text {
    color: #5e5040!important;
}
.overlay .overlay-nav .bottom a {
    border-radius: 50px;
}
.line1 img{
        vertical-align: top;
}
.top_sns{
        position: fixed;
    z-index: 1;
    right: -50px;
    left: auto;
    top: 40%;
    bottom: auto;
    flex-direction: column;
}
.top_sns.sns_links li {
    margin-right: 0%;
    margin-bottom: 15px;
}
.fix_banner_box{
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 2;
    display: flex;
    
}
.banner_fix {
    width: 80%;
    max-width: 350px;
    transition: 0.3s;
}
.banner1{
        margin-right: 20px;
}
.banner_fix:hover{
    opacity: 0.6;
}
/* ----------　TOP　---------- */
#main_img{
    height: 100vh;
    overflow: hidden;
}
#main_img:before {
    background-color: transparent;
}
#main_img .mask{
    position: absolute;
    width: 101%;
    z-index: 1;
    top: 0;
    left: 0;
    height: 101%;
}
#main_img .mask img{
    height: 100%;
}
#main_img .swiper-wrapper figure img{
    height: 110vh;
    width: auto;
}
.catch1{
        position: absolute;
    z-index: 2;
    right: 5%;
    top: 50%;
    transform: translateY(-50%);
        width: 30%;
    max-width: 240px;
}
.catch2{
        position: absolute;
    z-index: 2;
    bottom: 50px;
    max-width: 100px;
    width: 20%;
    left: 5%;
}
.main_dec{
        position: absolute;
    z-index: 2;
    bottom: 20px;
    left: 15%;
    width: 20%;
    max-width: 180px;
}
.scroll{
    display: none;
}
#video {
    height: 0;
}
#intro{
    position: relative;
    padding-bottom: 230px;
    padding-top: 100px;
}
#intro .intro_title {
    font-size: 40px;
    line-height: 2.2;
    letter-spacing: 5px;
}
#intro .intro_right {
    width: 90%;
    margin: auto;
}


#intro .intro_title span{
        background-image: url(Dup/img/intro_dec1.png),url(Dup/img/intro_dec2.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left,right;
    display: inline-block;
    padding: 0 150px;
    margin-bottom: 50px;
}
#intro .intro_txt{
    height: 400px;
    line-height: 2.5;
    margin: auto;
    margin-bottom: -30px;
        font-weight: bold;
    font-size: 18px;
}
#intro .intro_img1{
        width: 30%;
    position: absolute;
    top: 0;
    right: 30px;
    max-width: 400px;
    /*border-radius: 29% 71% 22% 78% / 48% 40% 60% 52%;*/
}
#intro .intro_img2{
        width: 30%;
    position: absolute;
    bottom: 50px;
    left: 0%;
    border-radius: 50% 60% 45% 50% / 50% 40% 55% 55%;
}
#contents #contents_wrap{
    padding-bottom: 0;
}
#contents .con_txt span {
    text-align: center;
    font-size: 35px;
    line-height: 2.2;
    letter-spacing: 2px;
}

#contents .box1 .con_photo:before ,#contents .box2 .con_photo:before {
    content: '';
    border-radius: 29% 71% 22% 78% / 48% 40% 60% 52%;
    position: absolute;
    border: 2px dotted #333;
    width: 100%;
    height: 100%;
    z-index: 9;
    top: 15px;
    right: 10px;
}
#contents .box1 .con_photo:before {
    left: 10px;
}
#contents .box1 .con_img,#contents .box1 .con_photo:before{
      border-radius: 69% 31% 63% 37% / 41% 52% 48% 59%;
}
#contents .box2 .con_img {
    border-radius: 29% 71% 22% 78% / 48% 40% 60% 52%;
}

#contents .box1 .con_box_item,#contents .box2 .con_box_item{
    background-color: #f9eaea;
    border-radius: 50%;
    padding: 100px 10px;
    border-radius: 50% 60% 45% 50% / 50% 40% 55% 55%;
    z-index: 9;
    max-width: 550px;
    margin-left: -50px;

}
#contents .box1 .con_box_item{
    margin-left: 0px;
    margin-right: -50px;
}
#contents .back{
        background-image: url(Dup/img/line3.png);
    background-repeat: no-repeat;
    background-position: bottom;
    padding-bottom: 150px;
    background-size:100%;
}
#contents .con_box.box1{
    position: relative;
}
#contents .con_box.box1:before {
    content: '';
    background-image: url(Dup/img/con1.png);
    position: absolute;
    width: 200px;
    height: 230px;
    background-size: contain;
    background-repeat: no-repeat;
    bottom: 0;
    right: 0;
    z-index: 1;
}
#contents .con_box.box2{
    position: relative;
}
#contents .con_box.box2:before {
    content: '';
    background-image: url(Dup/img/con2.png);
    position: absolute;
        width: 180px;
    height: 200px;
    background-size: contain;
    background-repeat: no-repeat;
    top: 0;
    left: 0;
    z-index: 1;
}
#contents .box3 {
    background-color: #f4f4ec;
    padding-top: 50px;
    padding-bottom: 100px;
}
#contents .box3 .con_title {
    font-size: 40px;
    margin-bottom: 20px;
}
#contents .box3 .con_txt span{
    font-size: 20px;
    letter-spacing: 1px;
}
#contents .box3 .con_box_item{
    width: 100%;
    padding-right: 0%;
        padding-left: 0%;
}
#contents .box3 .con_box_item .point {
    width: 25%;
    max-width: 250px;
    margin: 30px 5%;
}
#contents .box3 .point.txt5{
    position: relative;
}
#contents .box3 .point.txt5:before {
    content: '';
    position: absolute;
    background-image: url(Dup/img/point_dec.png);
    width: 70px;
    height: 70px;
    background-repeat: no-repeat;
    background-size: cover;
    left: -50px;
}
#contents .box1 .con_txt,#contents .box2 .con_txt  {
    background-image: url(Dup/img/con_title.png);
    background-repeat: no-repeat;
    background-size: 20%;
    background-position: center top;
    padding-top: 70px;
}
#top_cms .cms_title{
    background-image: url(Dup/img/cms_title.png);
    background-size: contain;
    background-repeat: no-repeat;
    padding-left: 55px;
}
.more .more_item:before {
    background-color:#f1cac1!important;
}
.more .more_item{
    border: 1px solid #f1cac1;
    border-radius: 50px;
}
.more .more_item:hover .icon-right.after:after {
    color: #aac49b;
}
.line.line2{
    bottom: 0;
    position: absolute;
    width: 100%;
}
.top_cms_box{
    border: none;
}
/* ----------　下層ページ　---------- */
#page_title .en:before {
    background-color: #f1cac1;
}
#page_title_img:before {
    background-color: rgba(255, 255, 255,0.15);
}
/* お知らせ */
.pager li a {
    background-color: #f1cac1!important;
}
.pager li a:hover {
    background-color: #aac49b!important;
}
/* お米の美味しい食べ方 */

.flow_type2 .box_wrap {
	border: 3px solid #f1cac1;
}
.flow_type2 .cate_box {
	padding: 30px;
	width: 100%!important;
}
.flow_type2 .box_txt1 {
    background-color: #f7f7f7;
    color: #f1cac1;
    text-align: center;
}
.flow_type2 .cate_box:not(:last-child) {
	border-bottom: 3px solid #f1cac1;
	position: relative;
}
.flow_type2 .cate_box:not(:last-child)::before,
.flow_type2 .cate_box:not(:last-child)::after {
	content: "";
	border: solid transparent;
	position: absolute;
	top: 100%;
	left: 17%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
.flow_type2 .cate_box:not(:last-child)::before {
	border-width: 22px;
	border-top-color: #f1cac1;
}
.flow_type2 .cate_box:not(:last-child)::after {
	border-width: 18px;
	border-top-color: #fafaf0;
}
.flow_type2{counter-reset: number 0;}

.flow_type2 .box_txt1{
    background-color: #aac49b;
    padding: 5px 10px;
    font-weight: 700;
    color: #ffffff;
    display: block;
    margin: 0px auto 10px;
    width: 50%;
}
.flow_type2 .d_table-cell:first-child .box_txt2{
    color: #d68c7a;
    text-align: center;
    background-color: transparent;
    font-weight: bold;
}
/* よくあるしつもん */
#cms_5-c .box_txt1::before {
    color:#aac49b;
}
/* 会社情報 */
#page7 .cate_box {
    border-bottom: 1px solid #aac49b;
}
/* お問い合わせ */
#page8 .banner {
    width: 80%;
    margin: 0 2% 25px;
    max-width: 400px;
} 
#page8 #contact_tel a{
    padding: 40px 20px;
}  
/* プライバシーポリシー */
/* サイトマップ */
#page10 .con_box{
        max-width: 800px;
}
#page10 ul {
    border-color: #f1cbc1;
    margin-left: 20px;
    padding-left: 15px;
    width: 45%!important;
}
/*-------------------------------------------------------
			            IE
-------------------------------------------------------*/

@media all and (-ms-high-contrast: none){
  .sample{

  }
}

/*-------------------------------------------------------
			          タブレット
-------------------------------------------------------*/
#loading #loading_text .progressbar-text {
    top: 65%;
}
/* ----------　TOP　---------- */
@media screen and (max-width: 768px){

#main_img {
    height: auto;
}
#main_img .swiper-wrapper figure img {
    height: auto;
    width: 100%;
}    
#main_img .mask img {
    height: auto;
}
.catch1 {
    max-width: 110px;
}
.catch2 {
    max-width: 55px;
    left: 3%;
}
#intro{
    padding-top:120px;
}
#intro .intro_right {
    width: 100%;
}
#intro .intro_title {
    font-size: 33px;
    line-height: 2;
}
#intro .intro_title span {
    padding: 0 88px;
    margin-bottom: 50px;
}
#intro .intro_txt {
    height: 360px;
    line-height: 2;
    font-size: 15px;
}
#intro .intro_img1 {
    width: 25%;    
}
#intro .intro_img2{
    width: 40%;
}
#contents .con_photo {
    width: 80%!important;
}
#contents .box1 .con_box_item, #contents .box2 .con_box_item {
    padding: 45px 10px 80px;
    width: 70%!important;
}
#contents .con_box.box1 {
    flex-direction: column-reverse;
}
#contents .con_txt span {
    font-size: 25px;
    line-height: 2;
}
#contents .box1 .con_box_item {
    margin-left: 0px;
    margin-right: 0px;
}
#contents .box1 .con_box_item, #contents .box2 .con_box_item {
    margin-left: 0px;
}
#contents .box3 .con_box_item .point {
    width: 35%;
}
#top_cms .cms_title h3{
    font-size: 40px;
}
/* ----------　下層ページ　---------- */
.page_container{
        padding-top: 120px;
}
#page_title .en {
    font-size: 45px;
    top: 40px;
}
/* お米の美味しい食べ方 */    
 .flow_type2 .cate_box:first-child {
    padding: 20px 20px 30px 20px;
}
.flow_type2 .cate_box:not(:first-child) {
    padding: 40px 20px 20px 20px;
}
.flow_type2 .cate_box:not(:last-child)::before, .flow_type2 .cate_box:not(:last-child)::after {
    left: 50%;
}
.flow_type2 .cate_box:not(:last-child)::after {
    border-top-color: #fff7ea;
}   
}

/*-------------------------------------------------------
		            	スマホ
-------------------------------------------------------*/
@media screen and (max-width: 667px){
#loading #loading_text .progressbar-text {
    top: 70%;
}
#loading .kvArea .img_box img {
    max-width: 80%;
    height: auto;
}
   footer #logo2{
            margin-top: 30px;
    }

.top_sns {
    position: relative;
    right: auto;
    left: auto;
    bottom: auto;
    flex-direction: inherit;
    margin: auto;
    width: 90%;
    max-width: 300px;
}    
.top_sns.sns_links li {
    margin-right: 2%;
    margin-left: 2%;
    margin-bottom: 15px;
    margin-top: 15px;
    width: 10%;
}
.fix_banner_box {
    bottom: 0px;
    right: 0px;
}
.banner1 {
    margin-right: 0px;
}
/* ----------　TOP　---------- */
#luxy.top {
    background-color: #fbf9ea;
    padding-top: 55px;}
.catch1 {
        max-width: 70px;
    top: 50%;
    right: 10px;
}
.catch2 {
    max-width: 35px;
    left: 3%;
    bottom: 0px;
}
#intro {
        padding-top: 150px;
    padding-bottom: 135px;
}
 #intro .intro_title {
    font-size: 23px;
}
#intro .intro_title span {
    padding: 0 35px;
    margin-bottom: 0px;
    background-size: 50px;
}
#intro .intro_txt {
    font-size: 15px;
    height: auto;
}
#intro .intro_img1{
    right: 50%;
    top: 15px;
        width: 40%;
    transform: translateX(50%);
}
 #intro .intro_img2 {
    width: 50%;
}
#contents .con_photo {
    width: 100%!important;
}
#contents .con_txt span {
    font-size: 25px;
    line-height: 2;
}
#contents .more {
    z-index: 2;
    margin-top: 20px;
}
#contents .box1 .con_box_item, #contents .box2 .con_box_item {
    padding: 40px 10px 60px;
    width: 100%!important;
}
#contents .box3 .con_box_item .point {
    width: 45%;
    margin: 30px 2%;
}
#top_cms_wrap{
        padding: 0 5%;
}
#contents .box3 .con_title {
    font-size: 30px;
}
#contents .con_box.box1:before {
    width: 80px;
    height: 150px;
    bottom: -100px;
    right: -20px;
}
#contents .con_box.box2:before {
    width: 152px;
    height: 90px;
    top: 0;
    left: -20px;
}

#contents .con_box.box1 {
    flex-direction: column;
}
#contents .box1 .con_photo:before, #contents .box2 .con_photo:before {
    border: 1px dotted #333;
    top: 5px;
    right: -8px;
}
#contents .box1 .con_txt, #contents .box2 .con_txt {
    padding-top: 40px;
}
#top_cms {
    padding-bottom: 40px;
}
.top_cms_box:last-child {
    border: none;
    margin-bottom: 0px;
}
#top_cms .cms_title h3 {
    font-size: 30px;
}
/* ----------　下層ページ　---------- */
#page_title .en {
    font-size: 30px;

}
#page8 .banner {
    width: 100%;
    margin: 0 0% 25px;
}
#page10 ul {
    margin-left: 0px;
    width: 100%!important;
}
}