@charset "utf-8";
/* CSS Document */
/*html{
  font-family:"ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
}*/
body{
  font-family:"ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
}
html,td{
    color:#4d4d4d;
    line-height:1.6;
}
.bodyWrap{
  display: flex; 
  display: -ms-flexbox; /*IE9~用*/
  width:100%;
  padding-top:27px;
}
.rightWrap{
  display: flex; 
  display: -ms-flexbox; /*IE9~用*/
  flex-direction: column;
  -ms-flex-direction: column;
  justify-content: space-between;
  -ms-flex-pack: justify;
  -webkit-justify-content:space-between;
  width:calc(100% - 240px);
  margin-left:240px;
}
.index_rightWrap{
  width:calc(100% - 240px);
}

h1{
  font-size:24px;
}
/*pc-sp切替用*/
.pc{ display: block; }
.sp{ display: none; }
@media screen and (max-width: 767px) {
    .pc{ display: none; }
    .sp{ display: block; }
}

.flex{
    display: flex; 
    display: -ms-flexbox; /*IE9~用*/
    justify-content: center;
    -ms-flex-pack: center;
}
section{
    padding:30px 0;
}
.normal{
    background:#FFF9E7;
    overflow: hidden;
}
a{
    text-decoration: none;
    color:#4d4d4d;
}
a.link{
  display: block;
}
a.link:hover{
    opacity: 0.8;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
}
.list_menu{
    padding-left:37px;
    padding-bottom: 80px;
    text-align:left;
    margin:10px 50px;
    list-style: none;
}
.list_menu li{
  position: relative;
  font-size:14px;
  padding:5px 0 ;
}
.list_menu li:before{
  content: "";
    display: block;
    width: 18px;
    height: 18px;
    box-sizing: border-box;
    border-radius: 50%;
    border-width: 1px;
    border-style: solid;
    background-color:white;
    position: absolute;
    left: -29px;
    top: 5px;
}
.list_menu li:after{
    content: "";
    display: block;
    position: absolute;
    left: -22px;
    top: 10px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 6px;
    border-color: transparent transparent transparent #1A1A1A;
}
img {
  max-width:100%; 
  vertical-align: bottom;/*画像の余白消し*/
  width /***/:auto; /*IE8用ハック*/
} /*画像サイズが横幅に合わせて可変します*/

/*赤二線固定 20200123*/  
#head_border{ 
  width: 100%;  
  height: 30px; 
  position: fixed;  
  z-index: 9999;  
} 
#head_border span{  
  display: block; 
  width:100%; 
} 
#head_border .border1{  
  border-top: solid 15px #ba2f1a; 
} 
#head_border .border2{  
  border-top: solid 5px white;  
} 
#head_border .border3{  
  border-top: solid 7px #ba2f1a;  
}
/*サイドメニュー*/
header{
    width:240px;
    position: fixed;
    background:url(../common/bk.gif);
    outline-offset: 1px;        /* 外側の線と内側の線の空き具合を調整*/         
    text-align: center;
    z-index:100;
    flex-shrink: 0;
}
.headWrap{
    height:100vh;
    overflow: auto;
    -ms-overflow-style: none;    /* IE, Edge 対応 */
    scrollbar-width: none;       /* Firefox 対応 */
}
.headWrap::-webkit-scrollbar {  /* Chrome, Safari 対応 */
        display:none;
}
header img{
    margin:5px;
    width:200px;
}
#logo{
    background: white;
    padding: 10px 30px 10px 15px;
    box-sizing: border-box;
    margin-bottom: 20px;
    font-size:13px;
}
#logo p{
    color:#fc0d0c;
}
.bnr_menu img{
    width:210px;
}

/*黒フチボタン*/
.btn{
    background: white;
    border:solid #4D4D4D 2px;
    border-radius: 7px;
    /*display: block;*/
    clear:both;
    overflow: hidden;
    text-decoration:none;
    padding:10px 7px;
    display: flex; 
    display: -ms-flexbox; /*IE9~用*/
    justify-content: center;
    -ms-flex-pack: center;
    box-shadow: 2px 3px 0px #808080;
    color:#4d4d4d;
    font-weight: bolder;
    font-size:1.2em;
    margin:14px 15px;
}
.btn:hover,
.btn_icon:hover{
    box-shadow: 0px 1px 0px #808080;
    transform: translate3d(0, 2px, 0);
}
.btn img,.btn p{
    align-self:center;
    -ms-flex-item-align: center;
    margin-right:10px;
}
.btn p{
  font-size:16px;
}
.btn img{
    width:30px;
}

/*トップスライダー*/
.thumb-item-nav{
  padding:0 60px;
}
.thumb-item-nav li{
  padding:0 10px;
}
.thumbLine {
  height:auto%;
  padding:10px 0;
}
.thumb-item li a{
   display: block;
   cursor: pointer;
}

/*メインコンテンツ*/
main{
  display: block;/*IE対策*/
  min-height:0%;/*IE対策*/
  min-width:784px;
}
#main_image{
    width: 100%;
    position: relative;
}
#catch{
    width:47%;
    position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
    
}
#main_image .slider img{
    width:100%;
    height:auto;
    display: block;
    /*max-width:1000px;
    margin:10px auto;*/
}
/*.thumb-item{
  background-color:#FFF9E7;
}*/
.slick-next{
    right:20px;
}
.slick-prev{
    left:20px;
}
#store{
    background:url(../img/bk_veg.jpg)center;
    background-size: cover;
}
.btn_store img{
  display: block;
  width:650px;
  margin:auto;
}
.ribbon-wrapper {  
  display: block;
  position: relative;
  margin: 15px auto;
  padding: 10px 0 30px; 
  width: 95%;
  background: #fff;
  box-sizing: border-box;
  border-radius: 15px;
  /*border-right: solid 75px #ba2f1a;*/
  }
.dot{
    content: "";
  position: absolute;
  left: 1%;
  top: 5px;
  width: 98%;
  height: 1px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.8) 0%, rgba(255, 255, 255, 0.8) 50%, transparent 50%, transparent 100%);
  background-size: 12px 4px;
}
.ribbon {  
  display: inline-block;
  position: absolute;
  top: -6px;
  left: 25px;
  margin: 0;
  padding: 12px 0 4px;
  z-index: 2;
  width: 70px;
  text-align: center;
  color: white;
  font-size: 16px;
  font-weight:bold;
  background: #ba2f1a;
  border-radius: 2px 0 0 0;
  }
.ribbon:before {
  position: absolute;
  content: '';
  top: 0;
  left: -5px;
  border: none;
  border-bottom: solid 6px #741406;
  border-left: solid 5px transparent;
}
.ribbon:after {
  content: '';
  position: absolute;
  left: 0;
  top: 100%;
  height: 0;
  width: 0;
  border-left: 35px solid transparent;
  border-right: 35px solid transparent;
  border-top: 12px solid #ba2f1a;
}
.news_slider{
  padding:50px 20px 0 20px;
  width:80%;
  max-width:900px;
  margin:0 auto;
}
.news_slider article{
    padding:0 20px;
    position: relative;
    font-weight: bolder;
}
.news_slider article figure{
    position: relative;
    margin-bottom:10px;
    max-height:267px;
    overflow: hidden;
    border-radius: 10px;
}
.news_slider article img{
    width:100%;
    border-radius: 7px;
    height:auto;
}
.campaign .date,.campaign_sub .date{
    color:#ba2f1a;
}
.information .date,.information_sub .date{
    color:#10964D;
}
#news .information .date,
#news .campaign .date{
  font-size:12px;
  display: inline;
}
#news .ttl{
  font-size:14px;
  margin-top:5px;
}
.tag{
    display: inline-block;
    color:white;
    /*position: absolute;*/
    /*top:5%;*/
    font-size:12px;
    padding:3px 1em;
    opacity:0.9;
    border-radius: 3px;
    margin-right:1em;
}
.campaign .tag{
    background:#ba2f1a;
}
.information .tag{
    background :#10964D;
}
#more{
    color:white;
    position: absolute;
    right:-60px;
    top:40%;
    text-align: center;
}
.more{
  position: absolute;
  left: 115px;
  top:16px;
  z-index:70;
}
.more a{
  font-size:14px;
  color:#ba2f1a;
  border-bottom:1px solid #ba2f1a;
}

/*スマホトップ下部のLINE、ポイントカード部分*/
#bottom_info.flex{
  flex-wrap: wrap;
  -ms-flex-wrap: wrap;
}
#bottom_info .content{
  max-width:380px;
  background-color:#FFF9E7;
  border-radius: 10px;
  position: relative;
  margin:0 auto 20px;
}
#bottom_info .content p{
  font-size:13px;
  margin:0 auto;
  width:80%;
}
#bottom_info .content h2{
  width: 90%;
  margin: 0 auto;
}
#bottom_info .content .btn{
  border-radius: 30px;
  position: relative;
  box-shadow: none;
  width:80%;
  margin:15px auto;
}
#bottom_info .content .btn:after{
  content:"";
  display: block;
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 2px white;
  border-right: solid 2px white;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 20px;
  margin-top: -4px;
}
#bottom_info .content.top_point .btn:after{
  border-top: solid 2px #d04925;
  border-right: solid 2px #d04925;
}
.top_line .btn{
  background-color: #00B901;
  color: white;
  border-color:white;
}
.top_point .btn{
  color:#d04925;
  border-color:#d04925;
}
.top_recruit .btn{  
  color:#EFA023;
  border-color:#EFA023;
} 
#bottom_info .content.top_recruit .btn:after{ 
  border-top: solid 2px #EFA023;  
  border-right: solid 2px #EFA023;  
}
.top_property .btn{
  color:#067D42;
  border-color:#067D42;
}
#bottom_info .content.top_property .btn:after{
  border-top: solid 2px #067D42;
  border-right: solid 2px #067D42;
}
#bottom_info .content figure{
  width:90%;
  max-width:400px;
  margin:30px auto;
}
#bottom_info .content figure.top_point_ico{
  width:80%;
  max-width:200px;
  margin:20px auto;
}
.top_line .link{
  width:260px;
  border-bottom:1px solid #00B901;
  text-align: center;
  color:#00B901;
  margin-right:auto;
  margin-left:auto;
}
footer{
    padding-top:50px;
    text-align: center;
    position: relative;
    min-width:784px;
}
footer .flex{
  flex-wrap:wrap;
  -ms-flex-wrap: wrap;
}
footer .list_menu{
    padding:0;
    margin:20px auto 40px;
    width:80%;
}
footer .list_menu li{
    margin-bottom:5px;
    padding:0 20px;
    border-right:solid 1px #808080;
    font-size:12px;
}
@media screen and (max-width:1400px) { 
    footer .list_menu{
      width:600px;
    }
    footer .list_menu li{
      margin-bottom:10px;
    }
    footer .list_menu li:nth-child(6){
      border:none;
    }
}
footer .list_menu li:last-child{ 
    border:none;
}
footer .list_menu li a{
    color:#808080;
    display: block;
}
footer .list_menu li:before,
footer .list_menu li:after{
  display: none;
}
.mini_list{
  margin:15px 0 10px;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.mini_list li{
  list-style: none;
  border-right:1px solid #FFF9E7;
  padding:0 9px;
  margin-bottom:3px;
  font-size:11px;
}
.mini_list li:last-child{
  border:none;
}
.mini_list li a{
  color:#FFF9E7;
}
#copy p{
  font-size:11px;
  padding:5px 0 10px;
}
#copy{
    background:#ba2f1a;
    color:#FFF9E7;
    padding:5px 0;
}
#picture{
    position: absolute;
    bottom:85px;
    right:5%;
    z-index:-1;
}

/*上に戻るボタン*/
#page_top{
 position: fixed;
 right:40px;
 bottom: 5px;
 z-index:100;
}
.arrow{
 display: inline-block;
 text-decoration: none;
 background: #067D42;
 color: #FFF;
 width: 52px;
 height: 52px;
 line-height: 52px;
 border-radius: 50%;
 border:solid 2px white;
 text-align: center;
 overflow: hidden;
 transition: .4s;
 position: relative;
 box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.29);
}
.arrow i{
 margin: auto;
 line-height: 52px;
}

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

↓ 中ページ　↓

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

/*共通部分*/

/*.overWrap{
  margin-bottom:50px;
}*/
.overWrap .ttl_em{
  font-size:1.6em;
  position:relative;    /* 位置調整 */
  font-weight:normal;   /* 文字の太さ調整 */
  text-align:center;    /* 文字位置指定 */
  background-color:#fff;
  width:85%;
  padding:50px 0 ;
  margin:0 auto -50px;
  border-radius: 7px;
  font-weight: bolder;
  max-width:1100px;
  min-width:800px;
}
.overWrap .ttl_point{
  color:#444;
  font-size: 0.6em;
  display:flex; 
  display: -ms-flexbox; /*IE9~用*/
  align-items:center;
  -ms-flex-pack: center;
  width:20%;
  margin: auto;
  line-height:1em;
  font-weight:normal;
}
.overWrap .ttl_point:before,.ttl_point:after{
  content: "";
  flex-grow: 1;
  height: 1px;
  background: #444;
  display: block;
}
.overWrap .ttl_point:before{
  margin-right: .4em;
}
.overWrap .ttl_point:after{
  margin-left: .4em;
}
.overWrap  section{
  padding:50px 0 0;
}
.overWrap .content_bk{
  background:white;
}
.overWrap .content{
  width:85%;
  max-width:1100px;
  min-width:800px;
  margin-right:auto;
  margin-left:auto;
}
.overWrap .content .inner{
  padding: 50px;
}
.icon_ttl{
  position: relative;
  border-bottom:solid 2px #4d4d4d;
  padding-bottom:10px;
  background-color: transparent;
}
.icon_ttl:before{
  content:"";
  display: inline-block;
  width:36px;
  height:36px;
  vertical-align: middle;
  margin-right:10px;
}
.normal_ttl{
  background-color:#FFF9E7;
  padding:5px 10px;
}
.overWrap .content p.block{
  padding:20px 0;
}
.overWrap .flex{
  display: flex; 
  display: -ms-flexbox; /*IE9~用*/
  justify-content: center;
  -ms-flex-pack: center;
  padding:20px 0;
}
.overWrap .flex .half{
  width:50%;
  padding:10px;
}

/*
アイコン付き黒フチボタン
（アイコン画像の指定、微調整は各部にて）
*/
.btn_icon{
    position: relative;
    width:280px;
    background: white;
    border:solid #4D4D4D 2px;
    border-radius: 7px;
    box-shadow: 2px 3px 0px #808080;
    margin:40px auto 20px;
}
.btn_icon a{
    padding:20px 20px 16px;
    color:#4d4d4d;
    font-weight: bolder;
    font-size:16px;
    text-align: center;
}
.btn_icon:before{
    content: "";
    display: block;
    position: absolute;
    width: 80px;
    height: 40px;
    background: #fff;
    left: 0;
    right: 0;
    top: -10px;
    margin: auto;
}

.normal_table{
  margin:20px;
  word-break: break-all; /*IE対策*/
}
.normal_table th{
    background-color:#FFF9E7;
    border-bottom:solid 5px #fff;
    width:175px;
    min-width:115px; /*IE対策*/
    vertical-align: middle;
    padding:10px;
}
.normal_table td{
    padding:20px 30px;
}

.normal_box{
    background-color:#FFF9E7;
    border-radius: 5px;
    margin:10px;
}
.normal_box p{
    text-align: center;
    font-size: 0.8em;
}

/*記事周り（新着情報・お知らせ情報・キャンペーン情報の一覧、詳細）*/
#newsList .flex{
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  padding:0;
  align-items:flex-start;
}
#newsList figure{
  width: 15%;
  max-height:144px;
  overflow: hidden;
  border-radius: 7px;
  margin-right:24px;
}
#newsList figure img{
  width:100%;
  height:auto;/*画像伸び防止*/
}
#newsList .news_detail{
  font-weight: bolder;
  width:80%;
  box-sizing: border-box;
  padding-right:25px;
}
#newsList li{
  margin:auto;
  list-style: none;
  border-top: dashed 1px #CACACA;
  padding:20px;
  overflow: hidden;
}
#newsList li a{
  display: block;
  position: relative;
}
#newsList li:last-child{
  border-bottom: dashed 1px #CACACA;
}
#newsList .nav_icon{
    position: absolute;
    right: 0;
    top: 50%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    overflow: hidden;
    width: 24px;
    height: 24px;
    line-height: 24px;
}
#newsList .nav_icon::before{
  content: '';
  width: 8px;
  height: 8px;
  border: 0px;
  border-top: solid 1px #CACACA;
  border-right: solid 1px #CACACA;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 6px;
  margin-top: -4px;
}
#newsList .campaign_sub,#newsList .information_sub{
  font-size: 0.75em;
  display: flex; 
  display: -ms-flexbox; /*IE9~用*/
  aline-items:center;
  margin-bottom:3px;

}
#newsList .campaign_sub .news_cat{
  background: #ba2f1a;
  color: white;
  padding:1px 9px;
  margin: 0 0 0 10px ;
  border-radius: 3px;
}
#newsList .information_sub .news_cat{
  background: #10964D;
  color: white;
  padding:1px 9px;
  margin: 0 0 0 10px ;
  border-radius: 3px;
}
#newsList.info .icon_ttl:before,
#newsDetail.info .icon_ttl:before,
.news_slider.information .icon_ttl:before{
  background: url(../common/ico_info.png) #fff no-repeat top center;
  background-size:34px 34px;
}
#newsList.campaign .icon_ttl:before,
#newsDetail.campaign .icon_ttl:before,
.news_slider.campaign .icon_ttl:before{
  background: url(../common/ico_campaign.png) #fff no-repeat top center;
  background-size:34px 28px;
}
#newsList .deadline{
  color:#808080;
  font-size:12px;
  font-weight: lighter;
}
.info_img{
  width:100%;
  /*max-width:500px;*/
  text-align: center;
  margin:20px auto;
}
.img_cap{
  text-align: center;
  margin-top:20px;
}
.leaflet{
  max-width: 500px;
  margin:20px auto;
}
/*サンワ・マイ・フレンド*/
#imagesong .btn_icon:before,
#imagesong .icon_ttl:before{
  background: url(../common/ico_song.png) #fff no-repeat top center;
  background-size:28px 31px;
}
#imagesong .btn_icon:before{
  top:-20px;/*見栄えのいい位置に調整*/
}

/*店舗物件紹介*/
#property .icon_ttl:before{
  background: url(../common/ico_info.png) #fff no-repeat top center;
  background-size:34px 34px;
}
#property .btn_icon:before{
  background: url(../common/ico_mail.png) #fff no-repeat top center;
  background-size:38px 26px;
  top:-16px;/*見栄えのいい位置に調整*/
}

/*店舗・チラシ情報一覧*/
#shop_list h2{
  background-color: transparent;
  padding: 0;
  margin:0;
}
#shop_list .logo{
  height:27px;
}
#shop_list h3{
  background-color: transparent;
  font-size:18px;
}
#shop_list .fd .logo{
  height:36px;
}
#shop_list section.sanwa{
  padding-top:0;
}
#shop_list .area{
  display: inline-block;
  padding: 3px 12px;
  color: white;
  border-radius: 6px;
}
#shop_list .sanwa .area{
  background-color:#ba2f1a;
}
#shop_list .fd .area{
  background-color:#067D42;
}
#shop_list .normal_table{
  margin:20px 0;
  width:100%;
  font-size:13px;
}
#shop_list .normal_table th{
  width:auto;
  min-width:0px;
}
#shop_list .normal_table td{
  padding: 15px 10px;
  border-top:1px solid #CACACA;
  vertical-align: middle;
  text-align: center;
}
#shop_list .normal_table tr:first-child td{
  border-top:none;
}
#shop_list .normal_table tr:last-child td{
  border-bottom:1px solid #CACACA;
}

#shop_list .sanwa .normal_table td:first-child a:hover{
  color:#ba2f1a;
}
#shop_list .fd .normal_table td:first-child a:hover{
  color:#067D42;
}
#shop_list .normal_table td:nth-child(2){
  min-width:120px;
}
#shop_list .normal_table td:nth-child(3){
  text-align: left;
}
#shop_list .normal_table td:nth-child(5) a{
  font-size:12px;
  color:white;
  background-color:#ba2f1a;
  border-radius: 5px;
  width: 90px;
  margin: 0 auto;
  padding:5px 0;
}
#shop_list .fd .normal_table td:nth-child(5) a{
  background-color:#067D42;
}
/*アコーディオン*/
.acd-content{
  /*display: none;*/ /*(2021.01.13コメントアウト)*/
  padding-top:20px;
}
.acd-menu.btn{
  display: none; /*(2021.01.13追記)*/
  padding:20px;
}

/*店舗情報詳細*/
#shop_detail .sanwa .icon_ttl:before{ 
  background: url(../common/ico_store.png) #fff no-repeat top center;
  background-size:30px 30px;
}
#shop_detail .food-one .icon_ttl:before{ 
  background: url(../common/ico_store_fd.png) #fff no-repeat top center;
  background-size:27px 25px;
}
#shop_detail .normal{
  overflow: visible;
  border-radius: 10px
}
#shop_detail .normal_table th{
  width:100px;
    min-width:0px;
}
#shop_detail .flex .mapWrap{
  max-height:300px;
}
#shop_detail iframe{
  width:100%;
  height:100%;
}
.ribbon2-wrapper {  
  display: block;
  position: relative;
  margin: 20px auto;
  padding: 20px 0;
}
.ribbon2-wrapper .flex{
/*  justify-content: space-between;*/
  padding:0;
}
.ribbon2-wrapper .content{
  min-width:0;
  padding-left:230px;
  width:auto;
}
.ribbon2 {
  display: inline-block;
  position: absolute;
  left:-10px;
  padding: 0 40px;
  margin: 0;
  height: 50px;
  line-height: 50px;
  font-size: 18px;
  letter-spacing: 0.1em;
  color: white;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.12);
}
.ribbon2:before {
  position: absolute;
  content: '';
  right: -20px;
  border: none;
  border-top:25px solid transparent;
  border-bottom:25px solid transparent;
}
.ribbon2.red:before{
  border-left:20px solid #BA2F1A;
}
.ribbon2.line_color:before{
  border-left:20px solid #00B901;
}
.ribbon2:after {
  position: absolute;
  content: '';
  top:50px;
  left: 0px;
  border: none;
  border-bottom: solid 5px transparent;
  border-left: solid 5px transparent;
}
.ribbon2.red:after{
  border-top: solid 5px #741406;
  border-right: solid 5px #741406;
} 
.ribbon2.line_color:after{
  border-top: solid 5px #0E7420;
  border-right: solid 5px #0E7420;
} 
.red{
  background-color: #BA2F1A;
}
.shufoo{
  padding-right:20px;
}
.line_color{
  background-color: #00B901;
}
.line_pict{
  width: 170px;
  position: absolute;
  top: 85px;
  left: 30px;
}
.line_cap h4{
  color:#E86106;
  font-size:26px;
  text-align: center;
  margin:10px 0;
}
.line_cap p{
  margin:15px 0;
}
.line_btn{
  display: block;
  max-width: 400px;
  color:white;
  text-align: center;
  font-weight: bold;
  background-color:#00B002;
  padding:10px;
  border-radius: 5px;
  box-shadow:2px 3px #808080;
  margin-right:auto;
  margin-left:auto;
}
.qr{
  background-color: white;
  max-width:100px;
  width: 25%;
  margin:20px;
  padding:20px;
  border-radius: 5px
}

/*サイトポリシー*/
#site_policy h3{
  color:#067D42;
}

/*個人情報の取り扱いについて*/
#privacy_policy dl{
  margin:20px 0;
}
#privacy_policy dd{
  margin-bottom:20px;
}

/*会社情報*/
#company .flex{
  align-items: center; 
  -ms-flex-pack: center;
}
#company .flex figure{
  width:100%;
  text-align: center;
  margin-right:20px;
}
.company_btn .btn{
  width:30%;
  padding:20px 7px;
  box-sizing: border-box;
}
.green_ttl{ 
  background-color: #067D42;  
  color: #FFF9E7; 
  padding: 5px 20px;  
  display: inline-block;  
  margin: 10px 0; 
  font-size: 16px;  
  border-radius:3px;  
  letter-spacing: 0.1em;  
} 
.green_ttl span{  
  margin-left: 15px;  
  border-left: 1px solid #FFF9E7; 
  padding-left: 15px; 
  font-size: 12px;  
  display: inline-block;  
} 
.green_mes{ 
  color: #067D42; 
  border-bottom: 1px solid #067D42; 
  display: block; 
  font-size: 20px;  
} 
section.philosophy{ 
  border-top: 2px dashed #FFF9E7; 
  padding-top: 20px;  
} 
.in_phi{  
  padding-bottom:20px;  
} 
.heart img{ 
  width:120px;  
}

/*会社概要*/
.dot_table{
  text-align: center;
}
.dot_table th{
  background-color: transparent;
  color:#BA2F1A;
  border-bottom:2px dotted #CACACA;
}
.dot_table td{
  padding:7px 30px;
}
.dot_table tr:nth-child(2){
  padding-top:20px;
}
.dot_table th:first-child,
.dot_table td:first-child{
  border-right:2px dotted #CACACA;
}
#guideline ul{
  padding-left:20px;
}
#guideline li{
  position: relative;
  list-style: none;
}
#guideline li:before{
  content:'';
  position: absolute;
  top:10px;
  left:-20px;
  display: block;
  width:10px;
  height:3px;
  background-color: #CACACA;
}

/*採用情報*/
#recruit .permanent .icon_ttl:before{ 
  background: url(../common/ico_recruit01.png) #fff no-repeat top center;
  background-size:25px 30px;
}
#recruit .staff .icon_ttl:before{ 
  background: url(../common/ico_recruit02.png) #fff no-repeat top center;
  background-size:26px 35px;
}
#recruit .catch{
  text-align: center;
}
#recruit .catch span{
  background-color: transparent;
  color:#ba2f1a;
  font-size:20px;
}
#recruit .flex .img{
  box-sizing: border-box;
  width:50%;
  padding:10px;
}
#recruit .flex .img img{
  width:100%;
}
#recruit .flex .text{
  width:70%;
  padding:10px;
}
#recruit .flex > p{ 
  width:100%; 
} 
#recruit .btn{  
  padding:20px; 
  box-sizing: border-box;
} 
#recruit .btn_cap{  
  display: inline-block;  
  width:100%; 
  text-align: center; 
  font-size: 12px;  
} 
#recruit .special{  
  background-color:#f3a333; 
  border-color:white; 
  color:white;  
} 
#recruit .staff .btn{ 
  box-sizing: border-box;
  width:100%;  
  max-width:400px;
  margin-right:auto;  
  margin-left:auto; 
}

/*ポイントカード*/
#point img{
  /*display: block;*/
  margin: auto;
}
#point .catch img{
  width:640px;
}
#point .ttl_img h2{
  background-color: transparent;
  width:480px;
  margin:15px auto;
}
#point .exp{
  margin:50px auto;
}
#point .exp img{
  width:780px;
}
#point .flex .half{
  background-color:#FFF9E7;
  border-radius: 5px;
  box-shadow: 2px 3px 0px #CACACA;
  margin:10px;
}
#point .point_box{
  position: relative;
  padding:25px;
}
#point .point01,
#point .point02{
  margin:40px auto 20px;
}
#point .point02{
  width:90%;
}
#point .point03{
  margin-top:15px;
}
#point h3{
  text-align: center;
  color:white;
  padding:8px;
  font-size:28px;
  border-radius: 40px;
  width:250px;
  position: absolute;
  top:-36px;
  right: 0;
  left:0;
  margin: auto;
  border:6px solid #fff;
}
#point h3.green{
  background-color: #067D42;
}
.attention{
  font-size: 12px;
  margin-top: 20px
}
#point .rules_box{
  height:200px;
  overflow-y: auto;
  border:1px solid #4D4D4D;
  padding-left:20px;
}
#point .rules_box strong{
  display: inline-block;
  padding:10px 0;
}
#point .rules_box p{
  margin:20px 0;
  text-align: right;
}

/*環境活動*/
#environment .icon_ttl:before{
  background: url(../common/ico_env.png) #fff no-repeat top center;
  background-size:34px 27px;
}
#environment .catch h3,
#environment .about h3{
  color:#067D42;
}
#environment .catch strong{
  display: block;
  color: #fff;
  background-color: #00B900;
  border-radius: 5px;
  padding:10px 0;
  text-align: center;
  font-weight: bold;
}
#environment figure img{
  display: block;
  max-width:650px;
  margin-right: auto;
  margin-left: auto;
  width:100%;
}
#environment figure.poster img{
  width:auto;
} 
#environment .btn{
  margin:20px auto 0;
}

/*LINE公式アカウント*/
#line .icon_ttl:before{
  background: url(../common/ico_line.png) #fff no-repeat top center;
  background-size:42px 22px;
  width:45px;
  height:25px;
  vertical-align: text-top;
}
#line .catch strong img{
  display: block;
  max-width:650px;
  margin:25px auto;
}
#line .catch .flex{
  max-width:700px;
  margin:10px auto;
  padding:0;
  align-items: center; 
  -ms-flex-pack: center;
}
#line .catch .half:first-child{
  width:60%;
}
#line .catch .half:nth-child(2){
  width:40%;
}
#line .catch .half:first-child p,
#line .catch .half:first-child .line_btn{
  margin:20px auto;
}

#line section:not(.normal){
  padding:0;
}
#flyer h3{
  text-align: center;
  /*color:#666666;*/
  color: #fff;
  background-color: #E96106;
  border-radius: 5px 5px 0 0 ;
  padding:15px;
  margin:0 0 20px;
}
#flyer figure{
  max-width:300px;
  padding:0 20px 20px;
}
#flyer figcaption{
  padding:10px;
  font-size:14px;
}
#flyer img.type_b{
  display: block;
  width:70%;
  margin:auto;
}
#method h3{
  color:#E96106;
  text-align: center;
  font-size:24px;
}
#method .normal_box.web{
  padding:20px;
  margin-bottom:25px;
}
#method .normal_box.search{
  padding:20px 40px 30px;
}
#method .flex{
  padding:0;
}
#method .half{
  padding:10px 20px;
}
#method .half:first-child{
  width:20%;
}
#method .half:nth-child(2){
  width:80%;
}
#method h4{
  font-size:18px;
  margin:13px 0;
}
#method h4:before{
  content:'';
  display: inline-block;
  width: 9px;
  height: 9px;
  border-top: 2px solid #4D4D4D;
  border-right: 2px solid #4D4D4D;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  margin-right:10px;
}
#method .line_btn{
  margin:10px auto 20px;
}

/*ページネーション*/
#newsList ul.page-numbers{
  display: flex; 
  display: -ms-flexbox; /*IE9~用*/
  margin:20px auto;
  justify-content: center;
  -ms-flex-pack: center;
}
#newsList .page-numbers li{
  margin:0;
  /*background-color:#FFF9E7;*/
  border-radius: 50%;
  border:none;
  width:40px;
  height:40px;
  line-height:40px;
  margin:0 8px;
  text-align: center;
  padding: 0;
}
#newsList .page-numbers li.li_current{
  /*background-color:#dcdcdc;*/
  border:2px solid #ba2f1a;
}
#newsList .page-numbers li a{
  color:#808080;
}
#newsList .page-numbers li span.current{
  color:#ba2f1a;
}


/*お問い合わせフォーム*/
#contact .icon_ttl:before{
  background: url(../common/ico_mail.png) #fff no-repeat top center;
  background-size:28px 19px;
  margin-top:10px;
}
#contact .icon_ttl{
  padding-bottom:0;
}
#contact input[type="text"],
#contact input[type="email"],
#contact textarea{
  padding:6px;
  border:2px solid #CACACA;
  border-radius: 4px;
  box-sizing: border-box;
  font-size: 16px;
}
#contact select{
  border:2px solid #CACACA;
  border-radius: 4px;
  vertical-align: middle;
  height:26px;
  background-color: white;
  font-size:14px;
  height:36px;
  width:100%;
  max-width:300px;
  padding-left:7px;
}
#contact textarea{
  width:100%;
  resize: none;
}
#contact .inner_table td{
  padding:5px;
}
#contact .error,
#contact .kome{
  color:#fc0d0c;
}
#contact button.confirm.btn{
  width:340px;
  margin:10px auto 0;
  padding:20px 7px;
}
#contact button.confirm.btn,
#contact input.back.btn{
  background-color:#067D42;
  color:white;
  border: none;
  font-weight:normal;
}
#contact input.back.btn,
#contact button.submit.btn{
  width:100%;
  padding:20px 7px;
  border-radius: 7px;
  line-height:1.6em;/*IE対策*/
}
#contact button.submit.btn{
  background-color:#ba2f1a;
  color:white;
  border: none;
  font-weight:normal;
}
/*#contact .kanagawa,
#contact .shizuoka{
  display: none;
}*/
#contact select{
  min-width:230px;
}

/*お知らせ・キャンペーンの単体ページ下部の別記事へのリンク*/
#newsDetail #another_article .next,
#newsDetail #another_article .prev{
  position: relative;
  width:50%;
  border:2px solid #4d4d4d;
  padding:15px;
  margin:5px;
  background-color:#FFF9E7;
  border-radius: 5px;
  box-sizing: border-box;
}
#another_article.flex{
  flex-direction: row;
  -ms-flex-direction: row;
  width:100%;
  max-width:800px;
  margin:40px auto 20px;
  padding:0;
}
#another_article .next a,
#another_article .prev a{
  display: block;
  padding-left:40px;
}
#newsDetail #another_article .next:before{
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  top: 20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 8px 6px 0;
  border-color: transparent #4d4d4d transparent transparent;
}
#newsDetail #another_article .prev:before{
  content: "";
  display: block;
  position: absolute;
  right: 20px;
  top: 20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #4d4d4d;
}
#newsDetail .back_allList{
  width:100%;
  max-width:800px;
  text-align: center;
  padding:15px;
  margin:10px auto;
  box-sizing: border-box;
  border-radius: 5px;
  background-color: #4d4d4d;
}
#newsDetail .back_allList a{
  display: block;
  color:white;
}

/*Googleマップの余分な情報を消す*/
.gm-style .place-card .address,
.gm-style .place-card div.review-box{
  display: none!important;
}

/*店舗一覧に出す店舗のお知らせ*/
#shop_list .shop_info{
  background-color: #FFF9E7;
}
#shop_list .shop_info td{
  border-top:none;
  text-align: left;
  padding:15px 30px;
  font-size:13px;
  color: #efa023;
}
#shop_list .shop_info td span{
  display: inline-block;
  background-color: #efa023;
  border-radius: 2px;
  padding:0 10px;
  margin-bottom: 5px;
  color:white;
  font-size:11px;
}
.shop_info a{
  color: #efa023;
  border-bottom:solid 1px #efa023;
}
#shop_list .sanwa .normal_table  .shop_info td a:hover{
  color: #efa023;
  opacity:0.8;
}
#shop_list .fd .normal_table  .shop_info td a:hover{
  color: #efa023;
  opacity:0.8;
}

/*  
店舗詳細ページ　20200123追記  
・お届けサービス・メニューサポート実施店舗 
・お知らせ表示 
*/  
.menu-support,  
.delivery-service{  
  color:white;  
  border-radius: 3px; 
  padding:8px 12px; 
  font-size:15px; 
} 
.menu-support{  
  background-color:#f3a333; 
} 
.delivery-service{  
  background-color:#34a7b2; 
} 
#shop_detail .shop_info{  
  border: 2px solid #efa023;  
  border-radius: 8px; 
  padding:15px 20px;  
} 
#shop_detail .shop_info strong{ 
  color: #efa023; 
  display: block; 
  font-weight: bold;  
  text-align: center; 
  padding-bottom:10px;  
  border-bottom:2px solid;  
} 
#shop_detail .shop_info .flex .half{  
  padding:20px; 
} 
#shop_detail .shop_info_text{ 
  padding:20px 10px;  
}

/*  
店舗物件募集　20200210追記 
・テナント情報　  
*/  

.simple_table{  
  width:100%; 
} 
.simple_table th, 
.simple_table td{ 
  border:1px solid #cdcdcd; 
  padding:10px; 
} 
.simple_table th{ 
  background-color: #cdcdcd;  
  border-color:white; 
  width:20%;  
} 
#tenant_info .inner:nth-child(n + 2){ 
  margin-top:30px;  
  padding:0;
}
#property .link.sanwa{
  display: inline;
  color: #ba2f1a;
  border-bottom:1px solid #ba2f1a;
}
#property .link.food-one{
  display: inline;
  color:#067D42;
  border-bottom:1px solid #067D42;
}

.ico_service{
  display: inline-block;
  width:95px;
  margin-bottom:20px;
}

/*店舗サービスのご案内　20200820追記*/
.block_ttl{
  border-left: 12px solid #ba2f1a;
    padding-left: 10px;
    margin:10px 0;
    line-height:1.5;
}
#service ul li{
  list-style: none;
}
#service figure{
  text-align: center;
}
#service figure img{
  max-width:850px;
  width:100%;
}
#service .main_img{
  margin-bottom:20px;
}
#service .block{
  padding: 20px 0 30px;
    border-bottom: 1px solid #cdcdcd;
}
.ico_link:hover{
  opacity:0.7;
}

/*会社沿革*/
#history .normal_table{
  border:1px solid #cdcdcd;
}
#history .normal_table th{
  border-right:1px solid #cdcdcd;
  border-bottom:1px solid #cdcdcd;
}
#history .normal_table th.month{
  width:60px;
  min-width:60px;
}
#history .normal_table td{
  padding: 10px 20px;
  border-bottom: 1px solid #cdcdcd;
}

