@charset "utf-8";

/*--------------------------------
 *  Initialize
 */

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin:0;
  padding:0;
  border:0;
  outline:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
}
body {
  line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
  display:block;
}
nav ul {
  list-style:none;
}
blockquote, q {
  quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
  content:'';
  content:none;
}
a {
  margin:0;
  padding:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
}
/* change colours to suit your needs */
ins {
  background-color:#ff9;
  color:#000;
  text-decoration:none;
}
/* change colours to suit your needs */
mark {
  background-color:#ff9;
  color:#000;
  font-style:italic;
  font-weight:bold;
}
del {
  text-decoration: line-through;
}
abbr[title], dfn[title] {
  border-bottom:1px dotted;
  cursor:help;
}
table {
  border-collapse:collapse;
  border-spacing:0;
}
/* change border colour to suit your needs */
hr {
  display:block;
  height:1px;
  border:0;
  border-top:1px solid #cccccc;
  margin:1em 0;
  padding:0;
}
input, select {
  vertical-align:middle;
}
ol, ul {
  list-style: none;
}
img {
  vertical-align: bottom;
}

body {
  font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, 'メイリオ', Osaka, 'MS PGothic', arial, helvetica, sans-serif;
  font-size: 100%;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
}

a:link,
a:visited {
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}

a:hover img {
  opacity: 0.8;
}

/*
 * "Vollkorn" is lisenced under the SIL Open Font License 1.1
 * https://fonts.google.com/attribution
 * http://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&id=OFL
 */
@font-face {
  font-family: "Vollkorn";
  src: url(../fonts/Vollkorn-Regular.ttf);
  font-style: normal;
  font-weight: normal;
}
@font-face {
  font-family: "Vollkorn";
  src: url(../fonts/Vollkorn-Italic.ttf);
  font-style: italic;
  font-weight: normal;
}
@font-face {
  font-family: "Vollkorn";
  src: url(../fonts/Vollkorn-Medium.ttf);
  font-style: normal;
  font-weight: 600;
}
@font-face {
  font-family: "Vollkorn";
  src: url(../fonts/Vollkorn-Mediumitalic.ttf);
  font-style: italic;
  font-weight: 600;
}
@font-face {
  font-family: "Vollkorn";
  src: url(../fonts/Vollkorn-Bold.ttf);
  font-style: normal;
  font-weight: bold;
}
@font-face {
  font-family: "Vollkorn";
  src: url(../fonts/Vollkorn-Bolditalic.ttf);
  font-style: italic;
  font-weight: bold;
}

/*
 * "Sacramento" is lisenced under the SIL Open Font License 1.1
 * https://fonts.google.com/attribution
 * http://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&id=OFL
 */
@font-face {
  font-family: "Sacramento";
  src: url(../fonts/Sacramento-Regular.ttf);
}

/* animation */
@keyframes line-slide {
  0% { background-position: 0 center; }
  100% { background-position: -3512px center; }
}

@keyframes line-slide-sp {
  0% { background-position: 0 center; }
  100% { background-position: -2565px center; }
}

@keyframes sprite-text {
  to {
    background-position: 0 -4800px;
  }
}

@keyframes sprite-text-sp {
  to {
    background-position: 0 -2400px;
  }
}

/*-------------------------------------------
 *  Common Style
 */

a.disabled {
  text-decoration: none !important;
  cursor: pointer !important;
}

.site-wrapper img {
  max-width: 100%;
  height: auto;
}

.f-vollkorn {
  font-family: "Vollkorn", serif;
}

.f-sacramento {
  font-family: "Sacramento", cursive;
}

.view-wrapper {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 15px;
}

.inblock {
  display: inline-block;
}

.googlemap {
  width: 100%;
  height: 310px;
}

.prt-header1 {
  margin: 52px 0 34px;
  padding: 20px 5px 12px;
  background: url(../img/common/bg-heading1.png) no-repeat center;
  background-size: contain;
  color: #31392a;
  font-size: 13px;
  text-align: center;
}
.prt-header1:first-child {
  margin-top: 0;
}

.prt-header1 .heading {
  color: #080808;
  font-family: "Sacramento", cursive;
  font-size: 72px;
  font-weight: normal;
  line-height: 1;
}

.prt-header1 p {
  margin: -7px 0 0;
  line-height: 1.5;
}

.prt-header2 {
  margin-bottom: 26px;
  font-size: 16px;
  text-align: center;
}

.prt-header2 .heading {
  color: #fff;
  font-family: "Sacramento", cursive;
  font-size: 72px;
  font-weight: normal;
  line-height: 1;
}

.prt-header2 p {
  font-size: 13px;
  line-height: 1.2;
}

.prt-header3 {
  margin-bottom: 30px;
  font-size: 13px;
  text-align: center;
}

.prt-header3 .heading {
  color: #080808;
  font-family: "Sacramento", cursive;
  font-size: 59px;
  line-height: 1;
}

.prt-header3 p {
  color: #31392a;
  line-height: 1.2;
}


.prt-header4 {
  margin: 0 0 22px;
  padding: 15px 24px 12px;
  background: url(../img/common/bg-heading2.png) no-repeat center;
  background-size: 100% 100%;
  color: #d8d7d7;
  font-size: 14px;
  font-weight: normal;
}

.prt-header4 > strong {
  display: inline-block;
  margin: 0 18px 0 0;
  color: #fff;
  font-family: "Sacramento", cursive;
  font-size: 36px;
  font-weight: normal;
  line-height: 1;
  vertical-align: middle;
}

.prt-header4 > span {
  display: inline-block;
  vertical-align: middle;
}

.header_navi {
  margin: 70px auto 0;
  max-width: 1000px;
}

.header_navi li {
  float: left;
  font-size: 12px;
}

.header_navi a {
  text-decoration: underline;
  color: #FFFFFF;
}

.category_list {
  display:-webkit-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 15px;
  margin-bottom: 25px;
}

.category_panel {
  margin-right: 15px;
  margin-bottom: 10px;
}
.category_list .category_panel {
  opacity: 0.4;
}
.category_list .category_panel.current {
  opacity: 1;
}

.category_panel .box.all {
  background-color: #1E1E1E;
  color: #FFFFFF;
}

.category_panel .box.lunch {
  background-color: #5D9238;
  color: #FFFFFF;
}

.category_panel .box.column {
  background-color: #6165AE;
  color: #FFFFFF;
}

.category_panel .box.media {
  background-color: #EBCC26;
  color: #FFFFFF;
}

.category_panel .box.other {
  background-color: #92918F;
  color: #FFFFFF;
}

.category_panel>.box-wrapper {
  display: inline-block;
  height: 32px;
}

.category_panel a {
  display: inline-block;
  font-size: 15px;
  text-align: center;
  width: 110px;
  height: 32px;
}

.jump_list {
  display:-webkit-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content:center;
  justify-content: center;
  margin-top: 45px;
}

.jump_list div:first-child {
  margin-left: 0;
}

.jump_list div {
  display: inline-block;
  margin-left: 5px;
  margin-bottom: 20px;
}

.jump_list a {
  padding: 10px 15px 8px;
  border: 1px solid #626262;
  color: #000000;
}

.jump_list .number {
  color: #FFFFFF;
  background-color: #313131;
}

.archive_panel {
  background-image: url(../img/blog/bg-archive.png);
  background-position: center center;
  border-radius: 5px;
  height: 52px;
  text-align: center;
}

.archive_panel p {
  font-size: 17px;
  padding-top: 10px;
  padding-left: 25px;
  color: #FFFFFF;
  text-align: left;
  vertical-align: middle;
}

.archive_year {
  background-image: url(../img/common/bg-border.png);
  color: #FFFFFF;
  position: relative;
  height: 37px;
  margin-top: 12px;
}

.archive_year p {
  color: #000000;
  background-color: #FFFFFF;
  font-size: 15px;
  position: absolute;
  top: 1px;
  left: 1px;
  right: 1px;
  bottom: 1px;
  padding-top: 3px;
  padding-left: 10px;
}

.archive_month ul {
  padding-top: 5px;
}

.archive_month li {
  background-image: url("../img/common/icon-arrow.png");
  background-repeat: no-repeat;
  background-position: 5px center;
  padding: 5px 0 5px 30px;
  border-bottom: 1px solid #D4D3BF;
}

.archive_month a {
  color: #000000;
  font-size: 14px;
}

.blog-wrap {
  overflow: hidden;
}

.blog-sub {
  float: right;
  width: 210px;
}

.blog-main {
  float: left;
  width: calc(100% - 250px);
  margin: 0;
}

.prt-button1 {
  display: inline-block;
  min-width: 246px;
  padding: 14px 10px 13px;
  background: url(../img/common/bg-button2.png) no-repeat center;
  background-size: 100% 100%;
  color: #050505;
  font-size: 18px;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
}
.prt-button1:hover {
  text-decoration: none;
  opacity: 0.8;
}

.prt-columns:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  font-size: 0;
  visibility: hidden;
}

.prt-columns .item {
  float: left;
}

.prt-columns.col2 .item {
  width: 48%;
  margin: 20px 0 0 4%;
}
.prt-columns.col2 .item:first-child,
.prt-columns.col2 .item:first-child + .item {
  margin-top: 0;
}
.prt-columns.col2 .item:nth-of-type(2n+1) {
  margin-left: 0;
}

.prt-label {
  display: inline-block;
  min-width: 95px;
  padding: 3px 5px;
  color: #fff;
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
}
.prt-label.lunch {
  background: #27ae60;
}
.prt-label.column {
  background: #e67e22;
}
.prt-label.news {
  background: #72a247;
}
.prt-label.media {
  background: #f6a025;
}
.prt-label.other {
  background: #92918F;
}

.prt-menu-list {
  display:-webkit-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  margin: 24px 0;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: start;
  justify-content: flex-start;
}

.prt-menu-list li {
  position: relative;
  width: 32.4%;
  margin: 0 0 20px 1.4%;
  border-radius: 3px;
  background: #fff url(../img/common/bg-menu-item.png) no-repeat bottom center;
  background-size: 100% 100%;
}
.prt-menu-list li:nth-of-type(3n+1) {
  margin-left: 0;
}
.prt-menu-list.shadow li {
  box-shadow: 0 4px 4px rgba(175, 178, 180, 0.34);
  background-image: none;
}

.prt-menu-list li a {
  text-decoration: none;
}

.prt-menu-list li a:hover {
  opacity: 0.8;
}

.prt-menu-list li dl {
  padding: 20px 20px 65px;
}

.prt-menu-list li dl dt {
  color: #100f0f;
  font-size: 20px;
  line-height: 1.3;
}

.prt-menu-list li dl dd {
  position: absolute;
  bottom: 8px;
  left: 8px;
}

.prt-menu-list li dl dd {
  position: absolute;
  bottom: 8px;
  left: 8px;
  color: #709e3a;
}

.prt-menu-list li dl dd i {
  display: inline-block;
  width: 40px;
  height: 40px;
  margin: 0 5px 0 0;
  padding: 11px 0 0;
  border: 2px solid #709e3a;
  border-radius: 50%;
  box-sizing: border-box;
  font-style: normal;
  font-size: 12px;
  line-height: 1.2;
  text-align: center;
  vertical-align: middle;
}

.prt-menu-list li dl dd span {
  display: inline-block;
  font-size: 12px;
  vertical-align: middle;
}

.prt-menu-list li dl dd span strong {
  font-size: 18px;
  font-weight: normal;
}

.prt-status1 {
  margin: 25px 0 0;
  padding: 16px 0 0;
  border-top: 1px solid #cfd1cc;
  overflow: hidden;
}

.prt-status1 .carb {
  float: left;
  color: #709e3a;
  font-size: 12px;
  line-height: 1.2;
}

.prt-status1 .carb i {
  display: inline-block;
  width: 40px;
  height: 40px;
  margin: 0 5px 0 0;
  padding: 11px 0 0;
  border: 2px solid #709e3a;
  border-radius: 50%;
  box-sizing: border-box;
  font-style: normal;
  font-size: 12px;
  text-align: center;
  vertical-align: middle;
}
.prt-status1 .carb span {
  display: inline-block;
  vertical-align: middle;
}

.prt-status1 .carb strong {
  font-size: 18px;
  font-weight: normal;
}

.prt-status1 .value {
  float: right;
  color: #121111;
  font-size: 20px;
  text-align: right;
}

.prt-pager {
  margin: 35px 0 0;
}

.prt-pager ul {
  display:-webkit-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

.prt-pager li {
  width: 182px;
  margin: 0 8px;
}

.prt-pager li a {
  display: block;
  position: relative;
  padding: 12px 15px 10px 10px;
  border: 1px solid #626262;
  background: #fff;
  color: #040404;
  font-size: 14px;
  line-height: 1.5;
  text-align: center;
}
.prt-pager li a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  width: 10px;
  height: 10px;
  margin: -2px 0 0;
  border-bottom: 2px solid #000;
  -webkit-transform: rotate(-45deg) translate(0, -50%);
  transform: rotate(-45deg) translate(0, -50%);
}
.prt-pager li.prev a {
  padding: 12px 10px 10px 15px;
}
.prt-pager li.prev a:before {
  left: 10px;
  border-left: 2px solid #000;
  -webkit-transform: rotate(45deg) translate(0, -50%);
  transform: rotate(45deg) translate(0, -50%);
}
.prt-pager li.next a {
  padding: 12px 10px 10px 15px;
}
.prt-pager li.next a:before {
  right: 10px;
  border-right: 2px solid #000;
  -webkit-transform: rotate(-45deg) translate(0, -50%);
  transform: rotate(-45deg) translate(0, -50%);
}


/*-------------------------------------------
 *  Layout
 */

/* Wrapper */
.site-wrapper {
  position: relative;
  background: url(../img/common/bg-contents1.png) center top;
  overflow: hidden;
}

/* Header */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding: 25px 0 34px;
  background: url(../img/common/bg-header.png) repeat-x center top;
  z-index: 1000;
}
.site-header.ready {
  position: absolute;
}
.site-header.set {
  -webkit-transform: translate(0, -100%);
  transform: translate(0, -100%);
}
.site-header.anime {
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
}

.site-header .logo {
  position: absolute;
  top: 7px;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}

.site-header .logo a {
  display: block;
  width: 86px;
  height: 102px;
  background: url(../img/common/site-logo2.png) no-repeat center;
  background-size: contain;
  font-size: 0;
  text-indent: -10000px;
  overflow: hidden;
}
.site-header .logo a:hover {
  opacity: 0.8;
}

.site-header .view-wrapper {
  max-width: 1400px;
}

.site-header .social-button {
  float: left;
  font-size: 0;
  line-height: 1;
}

.site-header .social-button a {
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  font-size: 0;
  text-indent: -10000px;
  vertical-align: middle;
  overflow: hidden;
}

.site-header .social-button a + a {
  margin-left: 28px;
}

.site-header .social-button a:hover {
  opacity: 0.8;
}

.site-header .social-button .fb {
  width: 11px;
  height: 19px;
  background-image: url(../img/common/icon-fb2.png);
}

.site-header .social-button .twitter {
  width: 24px;
  height: 20px;
  background-image: url(../img/common/icon_twitter.svg);
}

.site-header .social-button .insta {
  width: 20px;
  height: 20px;
  background-image: url(../img/common/icon_instagram.svg);
}

.site-header .links {
  float: right;
  font-size: 0;
  text-align: right;
}

.site-header .links li {
  float: right;
  margin: 0 0 0 28px;
}

.site-header .links li.shop {
  display: none;
}

.site-header .links li a i {
  display: inline-block;
  margin: -4px 6px 0 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  font-size: 0;
  vertical-align: middle;
}

.site-header .links li .tel i {
  width: 20px;
  height: 20px;
  background-image: url(../img/common/icon-tel2.png);
}

.site-header .links li .map i {
  width: 10px;
  height: 14px;
  background-image: url(../img/common/icon-map2.png);
}

.site-header .links li .blog i {
  width: 15px;
  height: 16px;
  background-image: url(../img/common/icon-blog.png);
}


.site-header .links li .reservation i {
  width: 16px;
  height: 16px;
  background-image: url(../img/common/icon-reservation2.png);
}

.site-header .links li .franchise span {
  font-style: normal;
}

.site-header .links li a span {
  display: inline-block;
  color: #000;
  font-style: italic;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.429;
  vertical-align: middle;
}

.site-header .links li a:hover span {
  text-decoration: underline;
}

/* Globalnav */
.site-globalnav {
  clear: both;
  padding: 32px 0 0;
}
.site-globalnav:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  font-size: 0;
  visibility: hidden;
}

.site-globalnav ul {
  display:-webkit-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  float: right;
  width: 37.7%;
  -webkit-box-pack:justify;
  -ms-flex-pack:justify;
  -webkit-justify-content:space-between;
  justify-content: space-between;
}
.site-globalnav ul:first-child {
  float: left;
}
.site-globalnav ul.for-sp {
  display: none;
}

.site-globalnav ul li .submenu {
  display: none;
}

.site-globalnav ul li a {
  color: #000;
  font-size: 17px;
  font-weight: 600;
}

.site-globalnav ul li.location {
  position: relative;
}
.site-globalnav ul li.location:hover .submenu {
  display: block;
}

.site-globalnav ul li.location .submenu {
  position: absolute;
  top: 0;
  left: -80px;
  width: 242px;
  padding: 40px 0 0;
}
.site-globalnav ul li.location .submenu li {
  background: #1b1b1b;
  padding: 10px;
}
.site-globalnav ul li.location .submenu li a {
  display: block;
  padding: 0 0 10px;
  color: #fff;
  font-size: 20px;
  border-bottom: 1px dotted #757373;
}
.site-globalnav ul li.location .submenu li img {
  margin: 0 0 10px;
}
.site-globalnav ul li.location .submenu li .name {
  display: inline-block;
  padding: 0 0 0 23px;
}
.site-globalnav ul li.location .submenu li.takatsuki .name {
  background: url(../img/common/icon-arrow1.png) no-repeat left center;
}
.site-globalnav ul li.location .submenu li.kitahorie .name {
  background: url(../img/common/icon-arrow2.png) no-repeat left center;
}
.site-globalnav ul li.location .submenu li.nishishinsaibashi .name,
.site-globalnav ul li.location .submenu li.franchise .name {
  background: url(../img/common/icon-arrow3.png) no-repeat left 6px;
}
.site-globalnav ul li.location .submenu li a:hover {
  text-decoration: none;
}
.site-globalnav ul li.location .submenu li a .sub {
  display: block;
  padding: 0 0 0 25px;
  font-size: 11px;
}
.site-globalnav ul li.location .submenu li.takatsuki a .sub {
  color: #79b4cd;
}
.site-globalnav ul li.location .submenu li.kitahorie a .sub {
  color: #edecb5;
}
.site-globalnav ul li.location .submenu li.nishishinsaibashi a .sub {
  color: #edecb5;
}
.site-globalnav ul li.location .submenu li.franchise a .sub {
  color: #c6edb5;
}

.site-globalnav ul li.location .sub-menu-detail {
  margin-top: 10px;
  display: flex;
  align-items: center;
}

.site-globalnav ul li.location .sub-menu-detail .img {
  width: 77px;
  height: 70px;
  margin: 0 12px 0 0;
  display: block;
  flex: none;
}

.site-globalnav ul li.location .sub-menu-detail .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.site-globalnav ul li.location .sub-menu-detail .name {
  padding-left: 0 !important;
  background: none !important;
  font-size: 18px !important;
}

.site-globalnav ul li.location .sub-menu-detail .sub {
  padding-left: 0 !important;
}

.site-globalnav ul li.location .sub-menu-detail .nishishinsaibashi .sub {
  color: #edecb5 !important;
}

.site-globalnav ul li.location .sub-menu-detail .other .sub {
  color: #a8aca7 !important;
}


/* MainVisual */
.site-mainvisual {
  position: relative;
  height: 326px;
  margin-top: 110px;
  padding: 122px 15px 126px;
  box-sizing: border-box;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  color: #fff;
  font-size: 18px;
  text-align: center;
}
.site-mainvisual:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 28px;
  background: url(../img/common/bg-mainvisual-bottom2.png) repeat-x center top;
  z-index: 2;
}

.site-mainvisual .heading {
  margin: 0 0 12px;
  font-family: "Vollkorn", serif;
  font-size: 36px;
  font-weight: normal;
  line-height: 1;
}

/* Contents */
.site-contents {
  padding: 20px 0 150px;
  font-size: 15px;
  line-height: 2.1333;
}

.site-contents.takatsuki + .site-footer .links.kitahorie {
  display: none;
}

.site-contents.kitahorie + .site-footer .links.takatsuki {
  display: none;
}

/* Footer */
.site-footer {
  background: url(../img/common/bg-footer1.png) center top;
  color: #e8e4e4;
}

.site-footer a {
  color: #e8e4e4;
}

.site-footer .contents-footer {
  position: relative;
  padding-top: 75px;
  padding-bottom: 60px;
}

.site-footer .links {
  position: relative;
  padding: 24px 55px 0;
  overflow: hidden;
}

.site-footer .links li {
  float: left;
  width: 19.2%;
  margin: 14px 0 0 1%;
}
.site-footer .links li:nth-child(5n+1) {
  clear: left;
  margin-left: 0;

}

.site-footer .links li a {
  display: block;
  padding: 15px 5px 14px;
  background: url(../img/common/bg-button1.png) no-repeat center;
  background-size: 100% 100%;
  color: #fff;
  font-size: 14px;
  text-align: center;
  text-decoration: none;
}
.site-footer .links li a:hover {
  opacity: 0.8;
}

.site-footer figure {
  position: absolute;
  left: 15px;
  bottom: 60px;
  font-size: 0;
}

.site-footer figure div {
  display: inline-block;
  margin: 0 14px 0 0;
  font-size: 0;
  vertical-align: middle;
}

.site-footer figure figcaption {
  display: inline-block;
  margin: 12px 0 0;
  color: #d7d5d5;
  font-size: 15px;
  line-height: 1.867;
  vertical-align: middle;
}

.site-footer .pagetop {
  display: block;
  position: absolute;
  right: 0;
  bottom: 84px;
  font-family: "Sacramento", cursive;
  font-size: 24px;
  line-height: 1;
  text-decoration: none;
}
.site-footer .pagetop:hover {
  opacity: 0.8;
}

.site-footer .pagetop i {
  display: inline-block;
  width: 34px;
  height: 34px;
  margin: -5px 0 0 18px;
  background: url(../img/common/bg-pagetop.png) no-repeat center;
  background-size: contain;
  vertical-align: middle;
}

.site-footer .copyright {
  margin: 136px 0 0;
  color: #d7d5d5;
  font-size: 11px;
  text-align: right;
}

/*-------------------------------------------
 *  Contents
 */

/* Information Section */
.sect-information {
  padding: 56px 0 0;
  background: #fff;
  color: #fff;
  font-size: 14px;
  line-height: 1.857;
}

.sect-information .prt-header2 {
  padding: 17px 0;
  background: url(../img/common/bg-information-title.png) no-repeat center top;
}
.sect-information .prt-header2 h2 {
  color: #669947;
}
.sect-information .prt-header2 p {
  color: #20221f;
}

.sect-information .info {
  overflow: hidden;
  font-size: 16px;
  text-align: center;
}
.sect-information .info .kitahorie {
  float: left;
  width: 50%;
  overflow: hidden;
}
.sect-information .info .kitahorie .inner {
  padding: 100px 0;
  background: url(../img/common/bg-information-nishishinsaibashi.png) no-repeat center center;
  background-size: cover;
}
.sect-information .info .takatsuki {
  /* float: right; */
  width: 100%;
  overflow: hidden;
}
.sect-information .info .takatsuki .inner {
  padding: 100px 0;
  background: url(../img/common/bg-information-takatsuki.png) no-repeat center center;
  background-size: cover;
}

.sect-information p {
  line-height: 1;
}
.sect-information .t1 {
  margin: 0 0 10px;
  font-size: 36px;
}
.sect-information .kitahorie .t1 a {
  color: #f1ef5f;
}
.sect-information .takatsuki .t1 a {
  color: #8edafa;
}
.sect-information .t1 span {
  position: relative;
  display: inline-block;
}
.sect-information .t1 .new {
  position: absolute;
  top: -80px;
  left: -130px;
}

.sect-information .t2 {
  margin: 0 0 20px;
  font-size: 14px;
}
.sect-information .t3 {
  margin: 0 0 20px;
}
.sect-information .t3 a {
  color: #fff;
  font-size: 24px;
}
.sect-information .t4 {
  width: 270px;
  margin: 0 auto 15px;
  font-size: 15px;
  line-height: 1.4;
  text-align: center;
}
.sect-information .t5 {
  /* width: 270px; */
  margin: 0 auto;
  color: #d0f48b;
  font-size: 16px;
  line-height: 1.4;
  text-align: center;
}
.sect-information .kitahorie .t5 {
  width: 310px;
}

.sect-information .map {
  width: 100%;
  height: 430px;
}


.box-wrapper {
  background-image: url(../img/common/bg-border.png);
  border-radius: 5px;
  padding: 1px !important;
}

.box-wrapper>.box {
  background-color: #FFFFFF;
  border-radius: 5px;
}

/* LINE Section */
.sect-line {
  position: relative;
  padding: 50px 0 55px 380px;
  border-top: 1px solid rgba(51, 52, 51, 0.83);
  border-bottom: 1px solid rgba(51, 52, 51, 0.83);
  font-size: 14px;
}

.sect-line .heading {
  margin: 0 0 30px;
  font-size: 65px;
  font-weight: normal;
  line-height: 1;
}

.sect-line p {
  font-weight: normal;
  line-height: 2.571;
}

.sect-line .line {
  position: absolute;
  top: -66px;
  left: 0;
  width: 380px;
  height: 449px;
  background: url(../img/common/footer-image2.png) no-repeat center top;
  background-size: 100% auto;
  font-size: 0;
}

.sect-line .shop-name img {
  width: 100%;
}

.sect-line .qr-code {
  width: 98px;
}
.sect-line .qr-code img {
  width: 100%;
}

.sect-line .shop1 .shop-name {
  position: absolute;
  width: 99px;
  top: 94px;
  left: 58px;
}

.sect-line .shop2 .shop-name {
  position: absolute;
  width: 79px;
  top: 100px;
  left: 222px;
  transform: rotate(4deg);
}

.sect-line .shop1 .qr-code {
  position: absolute;
  top: 134px;
  left: 60px;
}

.sect-line .shop2 .qr-code {
  position: absolute;
  top: 141px;
  left: 206px;
  transform: rotate(4deg);
}


.sect-line .shop1 .banner {
  position: absolute;
  top: 249px;
  left: 45px;
}

.sect-line .shop2 .banner {
  position: absolute;
  top: 254px;
  left: 189px;
  transform: rotate(4deg);
}




/*-------------------------------------------
 * Pages
 */

/* TopPage */
/*
#home .site-header {
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}
#home .site-header.ready {
  top: 0;
  width: 100%;
  max-width: 1400px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
  background: none;
}
#home .site-header.set {
  -webkit-transform: translate(-50%, -100%);
  transform: translate(-50%, -100%);
}

#home .site-header.ready .logo a {
  background-image: url(../img/common/site-logo1.png);
}

#home .site-header.ready .social-button .fb {
  background-image: url(../img/common/icon-fb1.png);
}

#home .site-header.ready .social-button .insta {
  background-image: url(../img/common/icon-insta1.png);
}

#home .site-header.ready .links li a span,
#home .ready .site-globalnav ul li a {
  color: #fff;
}

#home .site-header.ready .links li .tel i {
  background-image: url(../img/common/icon-tel1.png);
}
#home .site-header.ready .links li .map i {
  background-image: url(../img/common/icon-map1.png);
}
#home .site-header.ready .links li .reservation i {
  background-image: url(../img/common/icon-reservation1.png);
}
*/

#home .site-mainvisual {
  position: relative;
  height: 880px;
  margin: 0;
  background: #fff;
  text-align: left;
}
#home .site-mainvisual:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 136px;
  left: 50%;
  width: 25px;
  height: 41px;
  background: url(../img/index/mainvisual-icon1.png) no-repeat center;
  background-size: contain;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  z-index: 2;
}
#home .site-mainvisual:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 120px;
  background: url(../img/index/mainvisual-frame.png) no-repeat center bottom;
  background-size: cover;
  z-index: 0;
}

#home .site-mainvisual .opening {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/index/mainvisual.jpg) no-repeat center;
  background-size: cover;
  opacity: 0;
  -webkit-transition: opacity 1s ease-in 0.5s;
  transition: opacity 1s ease-in 0.5s;
}
#home .site-mainvisual .opening:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(1, 1, 1, 0.2);
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-out 3s;
  transition: opacity 0.5s ease-out 3s;
}

#home .site-mainvisual .opening img {
  position: absolute;
  top: 50%;
  left: 50%;
  max-width: 98.1%;
  height: auto;
  opacity: 0;
  -webkit-transform: translate(-50%, -60%);
  transform: translate(-50%, -60%);
  -webkit-transition: opacity 0.8s ease-in 4.3s, -webkit-transform 0.8s ease-in 4.3s;
  transition: opacity 0.8s ease-in 4.3s, transform 0.8s ease-in 4.3s;
}
#home .site-mainvisual .opening.ready,
#home .site-mainvisual .opening.ready:before,
#home .site-mainvisual .opening.ready img {
  opacity: 1;
}

#home .site-mainvisual .opening.ready img {
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

#home .site-mainvisual li {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
  overflow: hidden;
}
#home .site-mainvisual li:before {
  content: "";
  display:block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(1, 1, 1, 0.25);
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in 1.2s;
  transition: opacity 0.5s ease-in 1.2s;
}
#home .site-mainvisual li.current:before {
  opacity: 1;
}
#home .site-mainvisual li.item1 {
  background-image: url(../img/index/mainvisual1.jpg);
}
#home .site-mainvisual li.item2 {
  background-image: url(../img/index/mainvisual2.jpg);
}
#home .site-mainvisual li.item3 {
  background-image: url(../img/index/mainvisual3.jpg);
}

#home .site-mainvisual li .info {
  position: absolute;
  left: 50%;
  bottom: 160px;
  width: 404px;
  margin: 0 0 0 8.7%;
}

#home .site-mainvisual li .name {
  padding: 0 0 0 100px;
  opacity: 0;
  -webkit-transform: translate(0, -5px);
  transform: translate(0, -5px);
  -webkit-transition: opacity 0.5s ease-in 2.2s, -webkit-transform 0.5s ease-in 2.2s;
  transition: opacity 0.5s ease-in 2.2s, transform 0.5s ease-in 2.2s;
}

#home .site-mainvisual li.current .name {
  opacity: 1;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}

#home .site-mainvisual li .info .carb {
  position: relative;
  padding: 16px 0 0 94px;
}

#home .site-mainvisual li .info .carb i {
  display: block;
  position: absolute;
  width: 90px;
  height: 90px;
  padding: 30px 0 0;
  border: 2px solid #fff;
  border-radius: 50%;
  box-sizing: border-box;
  color: #fff;
  font-style: normal;
  font-size: 26px;
  line-height: 1;
  text-align: center;
  opacity: 0;
  -webkit-transform: translate(0, -5px);
  transform: translate(0, -5px);
  -webkit-transition: opacity 0.5s ease-in 3.2s, -webkit-transform 0.5s ease-in 3.2s;
  transition: opacity 0.5s ease-in 3.2s, transform 0.5s ease-in 3.2s;
}
#home .site-mainvisual li .info .carb.val4 i {
  bottom: 20px;
  left: 0;
}
#home .site-mainvisual li .info .carb.val2 i {
  top: 40px;
  right: 0;
}
#home .site-mainvisual li.current .info .carb i {
  opacity: 1;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}

#home .site-mainvisual li .info .carb .val {
  display: block;
  width: 296px;
  height: 300px;
  background-repeat: no-repeat;
  background-position: 0 0;
}
#home .site-mainvisual li .info .carb.val4 .val {
  background-image: url(../img/index/mainvisual-val1.png);
}
#home .site-mainvisual li .info .carb.val2 .val {
  background-image: url(../img/index/mainvisual-val2.png);
}
#home .site-mainvisual li.current .info .carb .val {
  animation: sprite-text 1.5s 3.8s steps(16) forwards;
}

#home .latest-news {
  position: absolute;
  top: 706px;
  left: calc((100% - 1400px) / 2);
  max-width: 600px;
  padding: 0 15px;
  color: #fff;
  z-index: 10;
}

#home .latest-news .name {
  padding: 0 0 0 15px;
  font-size: 24px;
  line-height: 1;
}

#home .latest-news .cont {
  background: #242624;
  line-height: 22px;
}

#home .latest-news .cont time {
  display: inline-block;
  width: 95px;
  font-size: 16px;
  text-align: center;
  vertical-align: middle;
}

#home .latest-news .cont span {
  display: inline-block;
  padding: 0 5px;
  color: #fff;
  font-size: 14px;
}

#home .site-contents {
  position: relative;
  padding-top: 0;
  padding-bottom: 40px;
  color: #3f3e3e;
  font-size: 17px;
}

#home .sect-welcome {
  position: relative;
  padding: 20px 0 55px;
  background: #fff;
}
#home .sect-welcome:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1411px;
  height: 799px;
  background: url(../img/index/welcome-bg.png) no-repeat center;
  background-size: contain;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

#home .sect-welcome .view-wrapper {
  position: relative;
}

#home .sect-welcome h2 {
  margin: 0 0 20px;
  color: #669947;
  font-size: 60px;
  font-weight: normal;
  line-height: 1;
  text-align: center;
}

#home .sect-welcome .lead {
  margin: 0 0 30px;
  font-size: 0;
  text-align: center;
}

#home .sect-welcome .text {
  margin: 0 0 30px;
  text-align: center;
}

#home .sect-welcome .text span {
  line-height: 1.882;
  text-align: left;
}

#home .sect-welcome .button {
  text-align: center;
}

#home .line-slide {
  position: relative;
  width: 100%;
  height: 234px;
  background: url(../img/index/slide.png) repeat-x 0 center;
  background-size: cover;
  animation-name: line-slide;
  animation-duration: 70s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

#home .line-slide .slideframe {
  position: relative;
}

#home .line-slide ul {
  position: absolute;
  top: 0;
  left: 0;
  width: 100000px;
  font-size: 0;
  overflow: hidden;
}

#home .line-slide ul li {
  float: left;
}

#home .sect-concept {
  position: relative;
  padding: 100px 0 60px;
  background: #fff url(../img/index/concept-bg.png) no-repeat center;
}

#home .sect-concept .image {
  position: relative;
  float: left;
  margin: 0 0 28px;
  z-index: 2;
}
#home .sect-concept .image img:first-child {
  position: relative;
  z-index: 2;
}
#home .sect-concept .image img:last-child {
  position: absolute;
  right: -436px;
  bottom: -80px;
  z-index: 1;
}

#home .sect-concept .lead {
  clear: left;
  margin: 0 0 26px;
  overflow: hidden;
}

#home .sect-concept .lead p {
  float: left;
  width: 647px;
  font-size: 0;
  text-align: left;
}

#home .sect-concept .lead p img {
  max-width: 100%;
  height: auto;
}

#home .sect-concept .lead .button {
  float: right;
  width: calc(100% - 657px);
  padding: 90px 0 0;
  box-sizing: border-box;
  text-align: center;
}

#home .sect-concept .text {
  line-height: 2.353;
}

#home .sect-concept h2 {
  float: left;
  padding: 16px 26px;
  color: #474746;
  font-size: 60px;
  font-weight: normal;
  line-height: 1;
}

#home .sect-blog {
  padding: 30px 0 90px;
  background: url(../img/common/bg-contents1.png) center top;
}

#home .sect-blog .item figure {
  position: relative;
  margin: 0 0 25px;
}

#home .sect-blog .item figure div {
  position: relative;
  padding-top: 75%;
}

#home .sect-blog .item figure div img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  object-fit: contain;
  font-family: 'object-fit: contain;';
}

#home .sect-blog .item figcaption {
  position: absolute;
  bottom: 0;
  left: 0;
}

#home .sect-blog .item header p {
  margin: 0 0 6px;
  color: #2d2d2c;
  font-size: 14px;
  line-height: 1.5;
}

#home .sect-blog .item header h3 {
  font-size: 18px;
  line-height: 1.7777;
}

#home .sect-blog .item header h3 a {
  color: #070707;
}

#home .sect-blog .item .text {
  margin: 10px 0 22px;
  color: #464744;
  font-size: 16px;
  line-height: 1.5;
}

#home .sect-blog .item .topost a {
  display: inline-block;
  border-bottom: 1px solid #2d2d2c;
  color: #2d2d2c;
  font-size: 18px;
  line-height: 1.75;
  text-decoration: none;
}
#home .sect-blog .item .topost a:hover {
  border-color: transparent;
}

#home .feed-wrap {
  padding-top: 70px;
  padding-bottom: 40px;
}

#home .sect-news li {
  padding: 30px 0 12px;
  border-bottom: 1px solid #b1b1b1;
}

#home .sect-news li a {
  color: #060606;
}

#home .sect-news li time {
  display: inline-block;
  margin: 0 18px 0 0;
  color: #61635f;
  font-size: 15px;
  line-height: 1.5;
}

#home .sect-news li .prt-label {
  font-size: 14px;
  line-height: 1;
}

#home .sect-news .button {
  margin: 45px 0 0;
  text-align: center;
}

#home .sect-facebook .cont {
  text-align: center;
}

#home .sect-facebook .cont .fb_iframe_widget > span {
  padding: 0 0 20px;
}

#home .site-footer {
  position: relative;
  padding-top: 58px;
}

#home .site-footer:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 58px;
  background: url(../img/index/footer-frame.png) no-repeat center bottom;
  background-size: 100% 100%;
}


/* menu */
#menu .site-mainvisual {
  background-image: url(../img/menu/mainvisual.jpg);
}

#menu .anchor-list {
  display: flex;
  margin: 30px 0 0;
  justify-content: center;
}

#menu .anchor-list li {
  margin: 0 15px;
}

#menu .anchor-list li a {
  display: inline-block;
  border-bottom: 1px solid #e1df29;
  color: #e1df29;
  font-family: "Sacramento", cursive;
  font-size: 36px;
  line-height: 1;
  text-decoration: none;
}
#menu .anchor-list li a:hover {
  border: none;
}

#menu .site-contents {
  padding-bottom: 75px;
}

#menu .sect-course {
  margin-bottom: 40px;
}

#menu .sect-course .prt-header1 {
  margin-bottom: 20px;
}

#menu .course-slide {
  position: relative;
  max-width: 1245px;
  margin: 0 auto;
  padding: 0 76px;
  box-sizing: border-box;
  background: url(../img/menu/course-bg.png) no-repeat center;
  background-size: 100% 100%;
  overflow: hidden;
}

#menu .course-slide .slideframe {
  position: relative;
  max-width: 1092px;
  height: 600px;
  margin: 0 auto;
  overflow: hidden;
}

#menu .course-slide .slideframe .slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 10000px;
}

#menu .course-slide .slideframe .slider li {
  position: relative;
  float: left;
  width: 1092px;
  margin: 0 176px 0 0;
  padding: 90px 0 110px 66px;
  box-sizing: border-box;
  color: #e6e7e5;
  font-size: 16px;
  line-height: 1.25;
}

#menu .course-slide .slideframe section {
  padding-top: 26px;
}

#menu .course-slide .slideframe section:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  font-size: 0;
  visibility: hidden;
}

#menu .course-slide .slideframe header,
#menu .course-slide .slideframe .cont {
  float: left;
  width: 365px;
  box-sizing: border-box;
}


#menu .course-slide .slideframe header {
  margin: 0 0 10px;
}

#menu .course-slide .slideframe header p {
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.222;
  text-align: center;
}
#menu .course-slide .slideframe .zen header p {
  color: #b7d596;
}
#menu .course-slide .slideframe .niku header p {
  color: #f8f47f;
}

#menu .course-slide .slideframe header h3 {
  font-size: 32px;
  font-weight: normal;
  line-height: 1.125;
  text-align: center;
}

#menu .course-slide .slideframe .image {
  float: right;
  width: calc(100% - 426px);
  padding: 10px 0 0;
}

#menu .course-slide .slideframe section .cont > p {
  margin: 10px 0 0;
  font-size: 16px;
  line-height: 1.75;
}

#menu .course-slide .slideframe section .cont > p:first-child {
  margin: 0;
}

#menu .course-slide .slideframe section .cont .course-contents {
  margin: 10px 0;
  padding: 10px 20px;
  border-color: #fff;
  border-style: solid;
  border-width: 1px;
  -webkit-border-image: url(../img/common/bg-border.png) 1 1 round;
  -moz-border-image: url(../img/common/bg-border.png) 1 1 round;
  -ms-border-image: url(../img/common/bg-border.png) 1 1 round;
  border-image: url(../img/common/bg-border.png) 1 1 round;
  font-size: 16px;
  line-height: 1.75;
}

#menu .course-slide .slideframe .status {
  margin: 10px 0 0;
  color: #fff;
  font-size: 0;
}

#menu .course-slide .slideframe .status div {
  display: inline-block;
  vertical-align: middle;
}

#menu .course-slide .slideframe .status .carb {
  margin: 0 34px 0 0;
  font-size: 16px;
  line-height: 1.2;
}

#menu .course-slide .slideframe .status .carb i {
  display: inline-block;
  width: 54px;
  height: 54px;
  margin: 0 8px 0 0;
  padding: 19px 0 0;
  border: 2px solid #fff;
  border-radius: 50%;
  box-sizing: border-box;
  font-style: normal;
  font-size: 13px;
  text-align: center;
  vertical-align: middle;
}

#menu .course-slide .slideframe .status .carb span {
  display: inline-block;
  vertical-align: middle;
}

#menu .course-slide .slideframe .status .carb span strong {
  font-size: 24px;
  font-weight: normal;
}

#menu .course-slide .slideframe .status .value {
  font-size: 13px;
}

#menu .course-slide .slideframe .status .value span {
  color: #dbd6d6;
  margin: 0 10px 0 0;
}

#menu .course-slide .slideframe .status .value strong {
  font-style: italic;
  font-size: 26px;
  font-weight: normal;
  letter-spacing: 1px;
}

#menu .course-slide .slideframe .cont .notes {
  margin: 6px 0 0;
  padding: 0 0 0 1em;
  font-size: 15px;
  line-height: 1.5;
  text-indent: -1em;
}

#menu .course-slide .indicator {
  position: absolute;
  bottom: 70px;
  left: 0;
  width: 100%;
  font-size: 0;
  text-align: center;
  z-index: 2;
}

#menu .course-slide .indicator li {
  display: inline-block;
  margin: 0 5px;
}

#menu .course-slide .indicator li a {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #d5d4d4;
  font-size: 0;
  text-indent: -10000px;
  overflow: hidden;
}

#menu .course-slide .indicator li a.on {
  background: #b7d596;
}

#menu .course-slide .controller li {
  position: absolute;
  top: 280px;
  right: 8px;
  z-index: 2;
}
#menu .course-slide .controller li:first-child {
  right: auto;
  left: 8px;
}

#menu .course-slide .controller li a {
  display: block;
  width: 69px;
  height: 68px;
  background: url(../img/menu/slide-next.png) no-repeat center;
  background-size: cover;
  font-size: 0;
  text-indent: -10000px;
  overflow: hidden;
}
#menu .course-slide .controller li:first-child a {
  background-image: url(../img/menu/slide-prev.png);
}
#menu .course-slide .controller li a:hover {
  opacity: 0.8;
}

#menu .sect-dinner .prt-menu-list {
  margin-bottom: 34px;
}

#menu .sect-lunch {
  margin-bottom: 50px;
}

#menu .sect-lunch section.always {
  position: relative;
  margin: 26px -40px 0;
  padding: 65px 65px 60px;
  background: url(../img/menu/lunch-bg.png) no-repeat center;
  background-size: 100% 100%;
  color: #3e3c3c;
  font-size: 15px;
  line-height: 2;
  overflow: hidden;
}

#menu .sect-lunch section.always h3 {
  float: right;
  width: 292px;
  margin: 0 0 3px;
  padding: 24px 0 33px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  color: #121111;
  font-size: 24px;
  font-weight: normal;
  line-height: 1.333;
  text-align: center;
}
#menu .sect-lunch section.always:nth-of-type(3n+1) h3 {
  background-image: url(../img/menu/header-bg1.png);
}
#menu .sect-lunch section.always:nth-of-type(2n) h3 {
  background-image: url(../img/menu/header-bg2.png);
}
#menu .sect-lunch section.always:nth-of-type(3n) h3 {
  background-image: url(../img/menu/header-bg3.png);
}

#menu .sect-lunch section.always .image {
  float: left;
  width: calc(100% - 328px);
}

#menu .sect-lunch section.always .cont {
  float: right;
  width: 292px;
  padding: 0 12px;
  box-sizing: border-box;
}

#menu .sect-lunch section.todays-lunch {
  margin: 40px 0 0;
  color: #464744;
  font-size: 16px;
  line-height: 1.125;
}
#menu .sect-lunch section.todays-lunch a {
  color: #070707;
}

#menu .sect-lunch section.todays-lunch h3 {
}

#menu .sect-lunch section.todays-lunch .box {
  padding: 1px;
  border-radius: 3px;
  background: url(../img/common/bg-border.png);
  overflow: hidden;
}

#menu .sect-lunch section.todays-lunch .box article {
  padding: 20px 24px 35px;
  background: #fff;
  overflow: hidden;
}

#menu .sect-lunch section.todays-lunch .box header,
#menu .sect-lunch section.todays-lunch .box .cont {
  float: right;
  width: calc(100% - 326px);
}

#menu .sect-lunch section.todays-lunch .label {
  margin: 0 0 10px;
  font-size: 16px;
  line-height: 1.5;
}

#menu .sect-lunch section.todays-lunch .label .todays {
  display: inline-block;
  padding: 3px 4px;
  background: #27ae60;
  color: #fff;
  line-height: 1.5;
  text-align: center;
}

#menu .sect-lunch section.todays-lunch .date {
  margin: 0 0 6px;
  line-height: 1.5;
}

#menu .sect-lunch section.todays-lunch .date time {
  color: #2d2d2c;
  font-size: 14px;
}

#menu .sect-lunch section.todays-lunch h4 {
  color: #070707;
  font-size: 20px;
  line-height: 1.6;
}

#menu .sect-lunch section.todays-lunch .cont {
  margin: 25px 0 0;
}

#menu .sect-lunch section.todays-lunch p {
  margin: 20px 0 0;
}

#menu .sect-lunch section.todays-lunch .box .image {
  float: left;
  width: 293px;
}

#menu .sect-dessert .button {
  margin: 50px 0 0;
  text-align: center;
}

/* menu detail */
#menu-detail .site-mainvisual {
  background-image: url(../img/menu/mainvisual.jpg);
}

#menu-detail .site-contents {
  padding: 20px 0 75px;
}

#menu-detail .button {
  margin: 40px 0 0;
  text-align: center;
}

#menu-detail .detail-slide {
  position: relative;
  max-width: 920px;
  margin: 0 auto 40px;
  padding: 1px;
  background: url(../img/common/bg-border.png);
}

#menu-detail .detail-slide .wrap {
  padding: 40px 46px;
  background: #fff;
}

#menu-detail .detail-slide .slideframe {
  position: relative;
  overflow: hidden;
}

#menu-detail .detail-slide .slideframe ul {
  position: absolute;
  top: 0;
  left: 0;
  width: 10000px;
  overflow: hidden;
}

#menu-detail .detail-slide .slideframe li {
  float: left;
}

#menu-detail .detail-slide .slideframe li h3 {
  margin: 0 0 20px;
  padding: 20px 30px 18px;
  background: url(../img/menu/detail-header.png) center;
  color: #fff;
  font-size: 23px;
  line-height: 1.391;
}

#menu-detail .detail-slide .slideframe li .image {
  margin: 0 0 18px;
  text-align: center;
}

#menu-detail .detail-slide .slideframe li .desc {
  color: #3e3c3c;
  font-size: 15px;
  line-height: 2;
}

#menu-detail .detail-slide .slideframe li .combi-desc {
  display: none;
}

#menu-detail .detail-slide .controller li {
  position: absolute;
  top: 420px;;
  left: 100%;
}
#menu-detail .detail-slide .controller li:first-child {
  right: 100%;
  left: auto;
}

#menu-detail .detail-slide .controller li img {
  width: auto;
  max-width: none;
}

#menu-detail .sect-combination .prt-header4 > span {
  color: #fff;
  font-size: 18px;
  margin-left: 10px;
}

#menu-detail .sect-combination .prt-header4 > span .carb {
  margin: 0 5px;
  color: #f8f47f;
  font-size: 20px;
  font-weight: bold;
}

#menu-detail .sect-combination li {
  display: none;
  margin: 0 0 20px 1.4%;
}
#menu-detail .sect-combination .visible {
  display: block;
}
#menu-detail .sect-combination .visible.row-first {
  margin-left: 0;
}

#menu-detail .sect-list {
  margin: 90px 0 0;
}


/* Blog */
#blog .site-mainvisual {
  background-image: url(../img/blog/mainvisual.jpg);
}

#blog .site-contents .view-wrapper {
  overflow: hidden;
}

#blog .blog_article {
  margin-bottom: 15px;
  height: 100%;
}

#blog .article_area {
  display:-webkit-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  padding: 25px;
}

#blog .article_image {
  width: 218px;
  margin-right: 25px;
}

#blog .article_image img {
  max-width: 100%;
  height: auto;
}

#blog .article_content {
  -webkit-flex: 1 1 0%;
  -ms-flex: 1 1 0%;
  flex: 1 1 0%;
}

#blog .content_text h4 {
  margin: 5px 0 10px;
  font-size: 20px;
  line-height: 1.4;
}

#blog .content_text h4 a {
  color: #070707;
}

#blog .content_text p {
  font-size: 14px;
  line-height: 1.4;
  overflow:hidden;
}

#blog .content_text p.detail {
  display: none;
}

/* Blog詳細 */
#blog_detail .site-mainvisual {
  background-image: url(../img/blog/mainvisual.jpg);
}

#blog_detail .article_detail .category_panel {
  float: left;
}

#blog_detail .article_date {
	font-size: 18px;
}

#blog_detail .article_title {
  margin-top: 20px;
}

#blog_detail .article_title h2 {
  border-left: 3px solid #A5C525;
  line-height: 1.8;
  margin-top: 10px;
  padding-left: 25px;
  font-size: 24px;
}

#blog_detail .article_detail_content {
  margin-top: -15px;
  padding-bottom: 25px;
}

#blog_detail .article_detail_content img {
  display: block;
  margin: 0 auto;
  width: 100%;
}

#blog_detail .article_detail_content p {
  font-size: 16px;
  margin-top: 25px;
  margin-bottom: 25px;
  line-height: 2.3em;
}

#blog_detail .article_detail_content iframe {
  display: block;
  max-width: 100%;
  margin: 0 auto;
}

#blog_detail .jump_list {
  margin-top: 75px;
  -webkit-box-pack:justify;
  -ms-flex-pack:justify;
  -webkit-justify-content:space-between;
  justify-content: space-between;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
}

#blog_detail .jump_list a {
  border: 1px solid #626262;
  box-sizing: border-box;
  display: inline-block;
  -webkit-flex-grow: 2;
  -ms-flex-positive: 2;
  flex-grow: 2;
  text-align: center;
  width: 175px;
  min-width: 112px;
}
#blog_detail .jump_list a.disabled {
  visibility: hidden;
  cursor: default;
}

#blog_detail .jump_list .back {
  padding-right: 5px;
  padding-left: 15px;
}

#blog_detail .jump_list .back:before {
  content: '←';
  float: left;
}

#blog_detail .jump_list .return {
  background-color: #4a4d4d;
  color: #FFFFFF;
  margin: 0 15px;
  width: 215px;
  padding-left: 5px;
  padding-right: 5px;
}

#blog_detail .jump_list .next {
  padding-right: 15px;
  padding-left: 5px;
}

#blog_detail .jump_list .next:after {
  content: '→';
  float: right;
}

#blog_detail .same_category {
  padding-bottom: 30px;
}

#blog_detail .same_category .category_panel>.box-wrapper {
  height: 24px;
  position: relative;
  width: 80px;
}

#blog_detail .same_category .category_panel a {
  font-size: 13px;
  height: 24px;
  position: absolute;
  top: 1px;
  width: 80px;
}

#blog_detail .same_category .article_title {
  margin-top: 35px;
  padding-bottom: 10px;
}

#blog_detail .same_category_article {
  padding-top: 10px;
}

#blog_detail .same_article_area {
  border-bottom: 1px solid #C1CDB9;
  padding-bottom: 30px;
  overflow: hidden;
}

#blog_detail .same_article_image {
  float: left;
  max-width: 120px;
  margin-top: 30px;
  margin-right: 20px;
}

#blog_detail .same_article_image img {
  max-width: 100%;
  height: auto;
}

#blog_detail .same_category .article_date {
  font-size: 16px;
}

#blog_detail .same_category .category_panel {
  float: none;
}

#blog_detail .same_category .text p {
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 10px;;
}

#blog_detail .article_content {
  overflow: hidden;
}

#blog_detail .article_content h4 {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 10px;
}

#blog_detail .article_content h4 a {
  color: #070707;
}

#blog_detail .article_detail {
  border-radius: 0;
}

#blog_detail .article_detail>.box {
  border-radius: 0;
  padding: 50px 55px;
}

#blog_detail hr {
  color: #D2D2D2;
}

#blog_detail .strong {
  border-width: 2px 0 0 0;
  margin-top: 65px;
}

#blog_detail .archive_panel {
  margin-top: 0px;
}

#blog_detail .archive_month {
	margin-top: 5px;
}

/* News */
#news .news_list p a {
  color: #3e7d05;
}

#news .site-mainvisual {
  background-image: url(../img/news/mainvisual.jpg);
}

#news .news_info {
  background-color: #31630C;
  color: #FFFFFF;
}

#news .media {
  background-color: #EB8B25;
  color: #FFFFFF;
}

#news .news_list {
  padding: 40px 30px;
}

#news .news_list .category_panel {
  float: left;
}

#news .news_list .category_panel a {
  width: 80px;
}

#news .news {
  padding-bottom: 15px;
}

#news .news_content {
  border-bottom: 1px solid #C1CDB9;
  padding-bottom: 20px;
}

#news .news_content h4 {
  font-size: 20px;
  line-height: 1.5;
  margin: 15px 0;
}

#news .news_content p {
  font-size: 16px;
  line-height: 1.8;
}

#news .category_panel_s {
  float: left;
  margin-right: 10px;
  font-size: 12px;
  padding: 1px;
}

#news .news_content .news_date {
  font-size: 14pt;
}

#news .news_title {
  margin-top: 8px;
  margin-bottom: 5px;
}

#news .text {
  margin-bottom: 2px;
}

#news .jump_list {
  margin-top: 70px;
  margin-bottom: 20px;
}

/* コンセプト */
#ourstory .site-mainvisual {
  background-image: url(../img/concept/mainvisual.jpg);
}

#ourstory .site-contents img {
}

#ourstory .site-contents a:hover {
  text-decoration: none;
}

#ourstory .box-wrapper {
  border-radius: 0;
}

#ourstory .box-wrapper>.box {
  border-radius: 0;
}

#ourstory span.box-wrapper, #ourstory span.box {
  display: block;
}

#ourstory article {
  background-color: #FFFFFF;
  padding: 45px 40px 30px;
  margin: 10px 0 10px;
}

#ourstory article:first-child {
  margin-top: 20px;
}

#ourstory .h2-wrapper {
  margin-bottom: 15px;
}

#ourstory article h2 {
  background: linear-gradient(#FFFFFF, #F6FAFC 80%, #F6F8F2);
  color: #73A866;
  font-size: 26px;
  line-height: 1.6;
  padding: 12px 10px 8px;
  text-align: center;
}

#ourstory article .h3-wrapper {
  padding: 1px 0 !important;
  margin-bottom: 25px;
}

#ourstory article h3 {
  font-size: 26px;
  font-weight: normal;
  line-height: 1.6;
  padding: 10px 10px 6px;
  text-align: center;
}

#ourstory article dt {
  font-size: 22px;
  font-weight: bold;
  padding-left: 5px;
  margin-top: 5px;
  margin-bottom: 10px;
}

#ourstory article img {
  margin: 5px;
}

#ourstory article a {
  color: #6E91AC;
  display: inline-block;
  text-decoration: underline;
  margin: 15px 0 10px;
  line-height: 1.177;
}
#ourstory article .prt-button1 {
  color: #050505;
  text-decoration: none;
}

#ourstory article hr {
  background-image: url(../img/common/bg-border.png);
  border-width: 0;
  height: 1px;
  margin-bottom: 25px;
}

#ourstory article .content {
  display:-webkit-box;
  display:-ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  margin-bottom: 15px;
}

#ourstory article .image-wrapper {
  margin: 10px 20px 10px 10px;
}

#ourstory article .image-info {
  color: #7E6C6C;
  font-size: 12px;
  margin-top: 5px;
}

#ourstory article .description {
  -webkit-flex: 1 1 0%;
  -ms-flex: 1 1 0%;
  flex: 1 1 0%;
  font-size: 17px;
  margin-left: 15px;
}

#ourstory article .description dd {
  font-size: 17px;
}

#ourstory article .carbohydrate,
#ourstory article .fiber, #ourstory article .sugariness,
#ourstory article .book, #ourstory article .strong,
#ourstory article .book, #ourstory article .underline1 {
  font-weight: bold;
  display: inline-block;
  line-height: 1;
  white-space: nowrap;
  word-break: break-all;
  word-wrap: break-word;
}

#ourstory article .carbohydrate {
  background-image: linear-gradient(transparent 70%, #A6BEE2 0%);
}

#ourstory article .fiber {
  background-image: linear-gradient(transparent 70%, #80C269 0%);
}

#ourstory article .sugariness {
  background-image: linear-gradient(transparent 70%, #FFF100 0%);
}

#ourstory article .book {
  background-image: linear-gradient(transparent 70%, #E66F6F 0%);
}

#ourstory article .strong {
  background-image: linear-gradient(transparent 80%, #FFF100 0%);
}

#ourstory article .underline1 {
  background-image: linear-gradient(transparent 70%, #ea7878 0%);
}

#ourstory .image-wrapper .box.think {
  padding: 18px 0px 15px;
  width: 268px;
  max-width: 100%;
  min-width: 100%;
  font-size: 0;
}

#ourstory .image-wrapper .box.think>.carbohydrate-area {
  width: 100%;
  font-size: 22px;
  margin-bottom: 2px;
  text-align: center;
}

#ourstory #locabo {
  display:-webkit-box;
  display:-ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

#ourstory #locabo .carbohydrate {
  padding: 0 10px;
}

#ourstory #locabo>.sugariness-area, #ourstory #locabo>.fiber-area {
  border-radius: 50%;
}

#ourstory #locabo>.sugariness-area>.box, #ourstory #locabo>.fiber-area>.box {
  border-radius: 50%;
  box-sizing: border-box;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  padding-top: 25px;
  height: 85px;
  width: 85px;
}

#ourstory #locabo>.sugariness-area>.box {
  background-color: #FFF100;
}

#ourstory #locabo>.fiber-area>.box {
  background-color: #80C269;
}

#ourstory #locabo>.plus {
  font-size: 28px;
  margin: 5px;
}

#ourstory #think img {
  margin: 25px 25px 15px;
}

#ourstory #think .content, #ourstory #sugar .content {
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

#ourstory #food .info {
  font-size: 14px;
}

#ourstory #patissier h3 {
  text-align: left;
}

#ourstory #patissier dt {
  font-size: 24px;
}

#ourstory #patissier .image-wrapper {
  margin-left: 0;
}

#ourstory #patissier .cakes {
  -webkit-box-pack:justify;
  -ms-flex-pack:justify;
  -webkit-justify-content:space-between;
  justify-content: space-between;
}

#ourstory #patissier .cakes .image-wrapper {
  margin: 0;
}
#ourstory #patissier .cakes .image-wrapper:first-child {
  margin-right: 20px;
}

#ourstory #patissier .cakes .image-wrapper .box {
  padding: 5px;
  box-sizing: border-box;
}

#ourstory #patissier .cakes .image-wrapper .box img {
  width: 100%;
  margin: 0;
}

#ourstory #patissier .patissier.image-wrapper {
  background-image: url("../img/concept/bg-patissier.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  margin-right: -30px;
  margin-top: -10px;
  margin-bottom: 50px;
}

#ourstory #patissier .patissier img {
  margin: 50px 70px 20px 110px;
}

#ourstory #patissier h3 {
  padding: 18px 10px 14px;
}

#ourstory #patissier .f-sacramento {
  color: #45889B;
  display: block;
  font-size: 30px;
  margin-bottom: -25px;
  margin-left: -10px;
}

#ourstory .site_button {
  border-radius: 5px;
  margin-left: -5px;
  margin-top: 15px;
}
#ourstory .site_button:hover {
  opacity: 0.8;
}

#ourstory .site_button>.box {
  background-image: url("../img/concept/bg-site-button.png");
  border-radius: 5px;
  box-sizing: border-box;
  color: #000000;
  display: block;
  font-size: 14px;
  padding: 16px 0 14px;
  text-align: center;
  text-decoration: none;
  margin: 0;
  width: 246px;
}


/* SubPage(テンプレート用のスタイルです) */
#subpage .site-mainvisual {
  background-image: url(../img/subpage/mainvisual.jpg);
}

#subpage .prt-header1 p {
  margin-left: 45px;
}


/*-------------------------------------------
 * Media Queries
 */

@media screen and (max-width: 1415px) {
  #home .latest-news {
    top: 730px;
    left: 0;
  }
}

@media screen and (min-width: 1301px) {
  /* Header */
  .site-header .social-button {
    padding: 0 0 0 50px;
  }

  .site-header .links {
    padding: 0 50px 0 0;
  }

  .site-globalnav {
    padding: 35px 50px 0;
  }
}

@media screen and (max-width: 1030px) {
  #home .site-mainvisual li .info {
    right: 10px;
    left: auto;
    margin: 0;
  }

  #home .sect-concept .lead p {
    float: none;
    width: auto;
  }

  #home .sect-concept .lead .button {
    float: none;
    width: auto;
    padding-top: 30px;
  }
}

@media screen and (max-width: 990px){
  #menu .course-slide {
    padding: 0;
    background: url(../img/menu/course-bg-sp.png) repeat-x left center;
    background-size: auto 100%;
  }


  #menu .course-slide .slideframe .slider li {
    margin-right: 130px;
    padding: 46px 30px 36px;
  }

  #menu .course-slide .slideframe section {
    padding: 0;
  }
  #menu .course-slide .slideframe section:after {
    display: none;
  }

  #menu .course-slide .slideframe header,
  #menu .course-slide .slideframe .image,
  #menu .course-slide .slideframe .cont {
    float: none;
    width: auto;
  }

  #menu .course-slide .slideframe header {
    margin-bottom: 38px;
  }

  #menu .course-slide .slideframe header p {
    margin: 0 0 5px;
    font-size: 12px;
  }

  #menu .course-slide .slideframe header h3 {
    font-size: 23px;
  }

  #menu .course-slide .slideframe .image {
    margin: 0 0 12px;
    padding: 0;
    text-align: center;
  }

  #menu .course-slide .slideframe section .cont > p {
    font-size: 15px;
    line-height: 1.6333;
  }

  #menu .course-slide .slideframe section .cont .course-contents {
    margin: 12px 0 23px;
    padding: 11px 17px 7px;
  }

  #menu .course-slide .slideframe .status {
    overflow: hidden;
  }

  #menu .course-slide .slideframe .status .carb {
    float: left;
    margin: 0;
    font-size: 11px;
  }

  #menu .course-slide .slideframe .status .carb i {
    width: 39px;
    height: 39px;
    padding: 13px 0 0;
    font-size: 10px;
    line-height: 1;
  }

  #menu .course-slide .slideframe .status .carb span strong {
    font-size: 17px;
  }

  #menu .course-slide .slideframe .status .value {
    float: right;
    margin: 0;
    font-size: 11px;
  }

  #menu .course-slide .slideframe .status .value strong {
    font-size: 22px;
  }

  #menu .course-slide .slideframe .cont .notes {
    margin: 11px 0 0;
  }

  #menu .course-slide .indicator {
    bottom: auto;
    top: 105px;
  }

  #menu .course-slide .indicator li {
    margin: 0 3px;
  }

  #menu .course-slide .indicator li a {
    width: 7px;
    height: 7px;
  }

  #menu .course-slide .controller li {
    top: 178px;
    right: 0;
  }
  #menu .course-slide .controller li:first-child {
    left: 0;
  }

  #menu .course-slide .controller li a {
    width: 25px;
    height: 110px;
    background-image: url(../img/menu/slide-next-sp.png);
  }
  #menu .course-slide .controller li:first-child a {
    background-image: url(../img/menu/slide-prev-sp.png);
  }

  #menu .sect-lunch section.always {
    margin: 26px 0px 0;
    padding: 45px 35px 40px;
  }
}

@media screen and (min-width: 751px) {
  /* Common */
  .for-sp {
    display: none;
  }

  /* Globalnav */
  .site-globalnav .wrap {
    display: block !important;
  }

  .archive_contents {
    display: block !important;
  }
}

@media screen and (max-width: 750px) {
  /* Common */
  .for-pc {
    display: none;
  }

  .site-wrapper img {
    max-width: 100%;
    height: auto;
  }

  .prt-header1 {
    margin: 40px 0 20px;
  }
  .prt-header1:first-child {
    margin-top: 0;
  }

  .prt-header1 .heading {
    font-size: 36px;
  }

  .prt-header2 {
    margin-bottom: 20px;
    font-size: 14px;
    text-align: center;
  }

  .prt-header2 .heading {
    font-size: 61px;
  }

  .prt-header3 .heading {
    font-size: 48px;
  }

  .prt-header4 {
    position: relative;
    margin: 0 0 58px;
  }

  .prt-header4 > span {
    position: absolute;
    top: 100%;
    left: 0;
    margin: 10px 0 0;
    color: #333;
    line-height: 1.5;
  }

  .prt-columns:after {
    display: none;
  }

  .prt-columns .item {
    float: none;
  }
  .prt-columns.col2 .item {
    width: auto;
    margin-left: 0;
  }

  .prt-columns.col2 .item:first-child + .item {
    margin-top: 40px;
  }

  .prt-menu-list li {
    width: 49%;
    margin-left: 2%;
  }
  .prt-menu-list li:nth-child(3n+1) {
    margin-left: 2%;
  }
  .prt-menu-list li:nth-child(2n+1) {
    margin-left: 0;
  }

  .prt-menu-list li img {
    width: 100%;
    height: auto;
  }

  .prt-button1 {
    font-size: 16px;
  }
  .prt-button1.f-vollkorn {
    font-size: 18px;
  }

  .archive_panel {
    position: relative;
    height: auto;
    cursor: pointer;
  }
  .archive_panel:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 15px;
    width: 8px;
    height: 8px;
    border-bottom: 2px solid #fff;
    border-left: 2px solid #fff;
    transform: translate(0, -5px) rotate(-45deg);
  }
  .archive_panel.on:before {
    transform: translate(0, -5px) rotate(135deg);
  }

  .archive_contents {
    display: none;
    padding: 0 5px;
  }

  .archive_panel p {
    padding: 16px 10px 15px;
    font-size: 15px;
    text-align: center;
  }

  .blog-wrap {
    overflow: visible;
  }

  .blog-sub,
  .blog-main {
    float: none;
    width: auto;
  }

  .blog-main {
    margin: 15px 0 0;
  }

  .category_list {
    margin-top: 0;
    margin-bottom: 15px;
  }

  .category_panel {
    margin-right: 5px;
    font-size: 12px;
    line-height: 1.25;
  }

  .category_panel>.box-wrapper {
    height: auto;
    border-radius: 3px;
    font-size: 12px;
    line-height: 1.25;
  }

  .category_panel a {
    width: auto;
    height: auto;
    padding: 5px 12px 4px;
    border-radius: 3px;
    font-size: 12px;
    line-height: 1.25;
  }

  /* Wrapper */
  .site-wrapper .menu-overlay {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: rgba(255,255,255,0.97);
    z-index: 100;
  }

  /* Header */
  .site-header {
    height: 124px;
    padding: 16px 0 20px;
    box-sizing: border-box;
    background: url(../img/common/bg-header-sp.png) repeat-x center top;
    background-size: 750px auto;
  }
  .site-header.ready {
    position: fixed;
  }

  .site-header .logo {
    position: relative;
    top: auto;
    left: auto;
    padding: 0 15px;
    font-size: 0;
    text-align: center;
    -webkit-transform: none;
    transform: none;
  }

  .site-header .logo a {
    display: inline-block;
    width: 72px;
    height: 87px;
  }

  .site-header .view-wrapper {
    padding-top: 0;
    text-align: center;
  }

  .site-header .social-button {
    display: none;
  }

  .site-header .links {
    position: absolute;
    top: 25px;
    left: 10px;
    float: none;
    text-align: left;
  }

  .site-header .links li {
    display: none;
    float: none;
    margin: 0 0 6px;
  }

  .site-header .links li.access-map {
    display: block;
  }
  .site-header .links li.access-map i {
    display: none;
  }
  .site-header .links li.shop {
    display: block;
  }


  .site-header .links li a i {
    margin-right: 4px;
  }

  .site-header .links li a span {
    font-size: 13px;
  }

  .site-header .links li a.reservation {
    display: none;
  }
  .site-header.ready .links li a.reservation {
    display: block;
  }

  .site-globalnav {
    padding: 0;
    overflow: visible;
  }

  .site-globalnav .menu-button {
    position: absolute;
    top: 32px;
    right: 15px;
  }

  .site-globalnav .menu-button a {
    display: inline-block;
    color: #000;
    font-size: 14px;
    line-height: 1.2;
    text-decoration: none;
  }

  .site-globalnav .menu-button .text {
    display: block;
    margin: 5px 0 0;
    line-height: 1;
  }
  .opened .site-globalnav .menu-button .text:before {
    content: "Close";
    display: inline-block;
  }
  .opened .site-globalnav .menu-button .text span {
    display: none;
  }

  .site-globalnav .menu-button .icon {
    display: block;
    position: relative;
    width: 100%;
    height: 20px;
    -webkit-transition: -webkit-transform 0.2s ease-in;
    transition: transform 0.2s ease-in;
  }
  .opened .site-globalnav .menu-button .icon {
    -webkit-transform: translate(0, -5px);
    transform: translate(0, -5px);
  }
  .site-globalnav .menu-button .icon:before,
  .site-globalnav .menu-button .icon:after,
  .site-globalnav .menu-button .icon i {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 2px;
    background: #010101;
    -webkit-transition: -webkit-transform 0.2s ease-in;
    transition: transform 0.2s ease-in;
  }
  .site-globalnav .menu-button .icon:before {
    -webkit-transform: translate(-50%, -9px);
    transform: translate(-50%, -9px);
  }
  .site-globalnav .menu-button .icon:after {
    -webkit-transform: translate(-50%, 7px);
    transform: translate(-50%, 7px);
  }
  .site-globalnav .menu-button .icon i {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  .opened .site-globalnav .menu-button .icon:before,
  .opened .site-globalnav .menu-button .icon:after {
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
    transform: translate(-50%, -50%) rotate(-45deg);
  }

  .opened .site-globalnav .menu-button .icon i {
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
  }

  .site-globalnav .wrap {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: -webkit-calc(100vh - 124px);
    height: calc(100vh - 124px);
    padding: 20px 15px;
    box-sizing: border-box;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .site-globalnav .wrap ul,
  .site-globalnav .wrap ul li {
    display: block;
    float: none;
    width: auto;
    text-align: left;
  }

  .site-globalnav .wrap ul {
    margin: 0;
  }

  .site-globalnav .wrap ul li {
    margin: 0 0 8px;
  }

  .site-globalnav .wrap ul li a {
    display: block;
    padding: 16px 10px 15px;
    background: url(../img/common/bg-nav1.png);
    background-size: 100% 100%;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
  }

  .site-globalnav .wrap ul li a.franchise {
    padding-top: 19px;
    padding-bottom: 18px;
    font-size: 14px;
  }

  .site-globalnav .wrap ul li.reservation > a {
    margin: 0 0 10px;
    background: url(../img/common/bg-nav2.png);
    background-size: 100% 100%;
  }
  .site-globalnav .wrap ul li.reservation p {
    margin: 0 0 20px;
    font-size: 12px;
  }
  .site-globalnav .wrap ul li.reservation ol {
    margin: 0 0 30px;
    overflow: hidden;
  }
  .site-globalnav .wrap ul li.reservation ol li.kitahorie {
    float: left;
    width: 48%;
    background: url(../img/common/header-kitahorie-bg.png);
    background-size: 100% 100%;
  }
  .site-globalnav .wrap ul li.reservation ol li.takatsuki {
    float: right;
    width: 48%;
    background: url(../img/common/header-takatsuki-bg.png);
    background-size: 100% 100%;
  }
  .site-globalnav .wrap ul li.reservation ol li a {
    padding: 20px 0;
    background: none;
    background-size: 100% 100%;
    font-size: 18px;
    text-align: center;
    text-decoration: none;
  }
  .site-globalnav .wrap ul li.reservation ol li .name {
    display: block;
    width: 100%;
    font-size: 20px;
    font-weight: bold;
  }
  .site-globalnav .wrap ul li.reservation ol li .tel {
    display: inline-block;
    padding: 0 0 0 25px;
    background: url(../img/common/icon-tel2.png) no-repeat left center;
    background-size: 20px auto;
    font-size: 15px;
  }

  .site-globalnav .wrap ul li.location {
    display: none;
  }

  .site-globalnav .wrap > ul li.takatsuki a {
    background: url(../img/common/bg-nav2.png);
    background-size: 100% 100%;
  }

  .site-globalnav .wrap ul li .submenu {
    display: block;
    margin: 12px 0 14px;
  }

  .site-globalnav .wrap ul li .submenu li a {
    border-radius: 3px;
    background: #d2e1c1;
  }

  .site-globalnav .wrap .close {
    display: block;
    margin: 42px 0 0;
    padding: 16px 10px 15px;
    border-radius: 2px;
    background: #e6eae4;
    color: #080707;
    font-size: 18px;
    text-decoration: none;
  }

  .site-globalnav .social-button {
    width: 100%;
    margin-top: 30px;
    float: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .site-globalnav .social-button a {
    display: inline-block;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    font-size: 0;
    text-indent: -10000px;
    vertical-align: middle;
    overflow: hidden;
  }

  .site-globalnav .social-button a + a {
    margin-left: 24px;
  }

  .site-globalnav .social-button .twitter {
    width: 24px;
    height: 20px;
    background-image: url(../img/common/icon_twitter.svg);
  }

  .site-globalnav .social-button .insta {
    width: 20px;
    height: 20px;
    background-image: url(../img/common/icon_instagram.svg);
  }

  /* MainVisual */
  .site-mainvisual {
    height: 188px;
    margin-top: 100px;
    padding: 70px 0;
  }

  .site-mainvisual:after {
    height: 14px;
    background-size: auto 100%;
  }

  .site-mainvisual p {
    font-size: 14px;
  }

  .header_navi {
    display: none;
  }

  /* Contents */
  .site-contents {
    padding: 20px 0 60px;
  }

  /* Footer */
  .site-footer .contents-footer {
    padding-top: 30px;
    padding-bottom: 20px;
  }

  .site-footer .links {
    margin: 0 0 20px;
    padding: 20px 0 0;
    overflow: visible;
  }

  .site-footer .links li {
    float: none;
    width: auto;
    margin: 0 0 10px;
  }

  .site-footer figure {
    position: relative;
    left: auto;
    bottom: auto;
    text-align: center;
  }

  .site-footer figure div {
    max-width: 16%;
    margin-right: 0;
    padding-right: 2%;
  }

  .site-footer figure figcaption {
    max-width: 82%;
    text-align: left;
  }

  .site-footer .pagetop {
    position: relative;
    right: auto;
    bottom: auto;
    float: right;
    margin: 20px 0;
    font-size: 18px;
  }

  .site-footer .copyright {
    clear: right;
    margin: 20px 0 0;
    text-align: left;
  }

  /* Information Section */
  .sect-information {
    padding: 30px 0;
    font-size: 16px;
  }

  .sect-information .info .kitahorie,
  .sect-information .info .takatsuki {
    float: none;
    width: 100%;
  }

  .sect-information .info .kitahorie .inner,
  .sect-information .info .takatsuki .inner {
    padding: 55px 0 50px;
  }

  .sect-information .t1 .new {
    width: 90px;
    top: -48px;
    left: -94px;
  }

  .sect-information .map {
    height: 215px;
  }


  /* LINE Section */
  .sect-line {
    padding: 30px 0 40px;
    text-align: center;
  }

  .sect-line .heading {
    margin: 0 0 20px;
    font-size: 36px;
  }

  .sect-line .line {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    height: auto;
    margin: 0;
    background: none;
  }

  .sect-line .line ul {
    overflow: hidden;
  }

  .sect-line .line ul li {
    float: left;
    width: 50%;
  }

  .sect-line .inblock {
    display: inline;
  }

  .sect-line .shop-name img {
    width: 50%;
  }

  .sect-line .shop1 .shop-name img {
    width: 60%;
  }

  .sect-line .qr-code img {
    width: 60%;
  }

  .sect-line .shop1 .shop-name,
  .sect-line .shop1 .qr-code,
  .sect-line .shop1 .banner,
  .sect-line .shop2 .shop-name,
  .sect-line .shop2 .qr-code,
  .sect-line .shop2 .banner {
    position: relative;
    top: auto;
    left: auto;
    width: auto;
    transform: none;
  }

  .sect-line .shop-name {
    margin: 0 0 15px;
  }

  .sect-line .qr-code {
    margin: 0 0 15px;
  }

  .sect-line .banner img {
    width: 80%;
  }

  .sect-line > p {
    margin: 0 5px 20px;
    font-size: 10px;
    line-height: 1.5;
    text-align: left;
  }

  /*** Pages ***/

  /* TopPage */
/*
  #home .site-header {
    left: 0;
    -webkit-transform: none;
    transform: none;
  }
  #home .site-header.ready {
    position: absolute;
    height: auto;
    padding: 16px 0 8px;
    background: none;
  }
  #home .site-header.set {
    -webkit-transform: translate(0, -100%);
    transform: translate(0, -100%);
  }
  #home.opened .site-header.set {
    -webkit-transform: none;
    transform: none;
  }

  #home .ready .site-globalnav .menu-button a {
    color: #fff;
  }

  #home .ready .site-globalnav .menu-button .icon:before,
  #home .ready .site-globalnav .menu-button .icon:after,
  #home .ready .site-globalnav .menu-button .icon i {
    background: #fff;
  }
*/

  #home .site-mainvisual {
    position: relative;
    height: 540px;
    text-align: left;
  }
  #home .site-mainvisual:before {
    display: none;
  }

  #home .site-mainvisual:after {
    height: 60px;
  }

  #home .site-mainvisual li .info {
    width: 202px;
    bottom: 52px;
    margin: 0 0 0 -65px;
  }

  #home .site-mainvisual li .name {
    padding: 0 0 0 50px;
  }

  #home .site-mainvisual li .info .carb {
    position: relative;
    padding: 8px 0 0 47px;
  }

  #home .site-mainvisual li .info .carb i {
    width: 45px;
    height: 45px;
    padding: 15px 0 0;
    font-size: 13px;
  }
  #home .site-mainvisual li .info .carb.val4 i {
    bottom: 10px;
  }
  #home .site-mainvisual li .info .carb.val2 i {
    top: 20px;
  }

  #home .site-mainvisual li .info .carb .val {
    width: 143px;
    height: 150px;
    background-size: auto 2550px;
  }
  #home .site-mainvisual li.current .info .carb .val {
    animation: sprite-text-sp 1.5s 3.8s steps(16) forwards;
  }

  #home .site-mainvisual li .name {
    bottom: 100%;
    right: auto;
    left: 0;
    text-align: left;
  }

  #home .latest-news {
    display: none;
  }

  #home .site-contents {
    font-size: 16px;
    line-height: 1.875;
  }

  #home .sect-welcome {
    padding: 0 0 40px;
  }
  #home .sect-welcome:before {
    content: "";
    position: absolute;
    top: -120px;
    width: 705px;
    height: 398px;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }

  #home .sect-welcome h2 {
    font-size: 45px;
  }

  #home .sect-welcome .lead {
    padding: 28.21% 0 0;
    background: url(../img/index/welcome-lead-sp.png) no-repeat center;
    background-size: contain;
  }
  #home .sect-welcome .lead img {
    display: none;
  }

  #home .sect-welcome .text {
    text-align: left;
  }

  #home .sect-welcome .text span {
    line-height: inherit;
  }

  #home .line-slide {
    height: 171px;
    animation-name: line-slide-sp;
  }

  #home .sect-concept {
    position: relative;
    padding: 90px 0 120px;
    background-position: center top;
    background-size: 842px auto;
  }

  #home .sect-concept h2 {
    position: absolute;
    top: 30px;
    left: 0;
    float: none;
    width: 100%;
    padding: 0;
    font-size: 40px;
    text-align: center;
  }

  #home .sect-concept .image {
    position: relative;
    float: none;
    margin: 0 0 15px;
  }

  #home .sect-concept .image img:last-child {
    display: none;
  }

  #home .sect-concept .lead {
    margin: 0 0 12px;
  }

  #home .sect-concept .lead p {
    float: none;
    width: auto;
    padding: 45.21% 0 0;
    background: url(../img/index/concept-text-sp.png) no-repeat center;
    background-size: contain;
    font-size: 0;
  }

  #home .sect-concept .lead p img {
    display: none;
  }

  #home .sect-concept .lead .button {
    position: absolute;
    bottom: 40px;
    left: 0;
    float: none;
    width: 100%;
    padding: 0 15px;
    box-sizing: border-box;
    text-align: center;
  }

  #home .sect-concept .text {
    line-height: inherit;
  }

  #home .sect-blog {
    padding: 20px 0 40px;
  }

  #home .feed-wrap {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  #home .sect-news .prt-header3 {
    margin: 0;
  }

  #home .sect-news li {
    padding-top: 20px;
  }

  #home .sect-news .button {
    margin: 45px 0 0;
    text-align: center;
  }

  #home .sect-facebook {
    margin: 60px 0 0;
  }

  #home .sect-facebook .cont {
    padding: 0 30px;
  }

  #home .site-footer {
    padding-top: 29px;
  }

  #home .site-footer:before {
    height: 29px;
  }

  /* Menu */
  #menu .anchor-list {
    display: none;
  }

  #menu .site-contents {
    padding-bottom: 60px;
  }

  #menu .course-slide .slideframe .status .carb i {
    border-width: 1px;
  }

  #menu .sect-lunch section.always {
    margin: 0 -15px;
    padding: 40px 20px;
  }

  #menu .sect-lunch section.always h3,
  #menu .sect-lunch section.always .image,
  #menu .sect-lunch section.always .cont {
    float: none;
    width: auto;
  }

  #menu .sect-lunch section.always h3 {
    padding: 16px 0 24px;
    font-size: 20px;
  }

  #menu .sect-lunch section.always .image {
    margin: 0 0 10px;
    text-align: center;
  }

  #menu .sect-lunch section.always .cont {
    padding: 0;
  }

  #menu .sect-lunch section.todays-lunch .box article {
    padding: 20px 15px;
  }

  #menu .sect-lunch section.todays-lunch .box header,
  #menu .sect-lunch section.todays-lunch .box .image,
  #menu .sect-lunch section.todays-lunch .box .cont {
    float: none;
    width: auto;
  }

  #menu .sect-lunch section.todays-lunch .label {
    margin: 0 0 5px;
  }

  #menu .sect-lunch section.todays-lunch .image {
    margin: 10px 0 0;
    text-align: center;
  }

  #menu-detail .site-contents {
    padding: 20px 15px 60px;
  }

  #menu-detail .detail-slide .wrap {
    padding: 20px 22px;
  }

  #menu-detail .sect-combination .prt-header4 > span {
    margin: 0;
    color: #333;
    font-size: 100%;
  }

  #menu-detail .sect-combination .prt-header4 > span .carb {
    color: #333;
  }

  #menu-detail .detail-slide .slideframe li h3 {
    padding: 10px 15px 9px;
    font-size: 18px;
  }

  #menu-detail .detail-slide .controller li {
    top: 180px;
    width: 30px;
    margin-left: -20px;
  }
  #menu-detail .detail-slide .controller li:first-child {
    margin-right: -20px;
    margin-left: 0;
  }

  #menu-detail .detail-slide .controller li img {
    width: 100%;
  }

  #menu-detail .sect-combination li,
  #menu-detail .sect-combination .visible.row-first{
    margin-left: 2%;
  }
  #menu-detail .sect-combination .visible.col2-row-first {
    margin-left: 0;
  }

  #menu-detail .sect-list {
    display: none;
  }

  /* Blog */
  #blog .site-mainvisual {
    background-image: url(../img/blog/mainvisual-sp.jpg);
  }

  #blog .article_area {
    display: block;
  }

  #blog .blog_article {
    background-image: none;
    margin-bottom: 30px;
  }

  #blog .article_area {
    background-color: transparent;
    margin: 0 !important;
    padding: 0;
  }

  #blog .article_image {
    margin: 0;
    width: 100%;
  }

  #blog .article_image img {
    width: 100%;
  }

  #blog .article_content {
    position: relative;
  }

  #blog .article_content .box-wrapper {
    background-image: none;
    border-radius: 0;
  }

  #blog .article_content .box {
    border-radius: 0;
    margin: 0px !important;
  }

  #blog .article_content .category_panel {
    top: -44px;
    height: auto;
    overflow: hidden;
    position: absolute;
    margin: 0;
  }

  #blog .article_content .category_panel a {
    font-size: 12px;
    line-height: 2.083;
    width: 150px;
  }

  #blog .article_content .category_panel .lunch {
    background-color: #27AE60;
  }

  #blog .content_text p.date {
    margin-top: 10px;
    margin-bottom: 0;
    font-size: 15px;
    line-height: 1.6;
  }

  #blog .content_text h4 {
    font-size: 15px;
    line-height: 1.533;
  }

  #blog .content_text p {
    margin-bottom: 13px;
  }

  #blog .content_text p.detail {
    display: block;
    margin: 0;
  }

  #blog .content_text p.detail a {
    color: #000;
    text-decoration: underline;
  }

  #blog .jump_list {
    margin-top: 40px;
  }

  /* Blog詳細 */
  #blog_detail .site-mainvisual {
    background-image: url(../img/blog/mainvisual-sp.jpg);
  }

  #blog_detail .strong {
    margin-top: 105px;
  }

  #blog_detail .same_category_article {
    padding: 0;
  }

  #blog_detail .same_article_area {
    padding-top: 20px;
    padding-bottom: 20px;
    overflow: hidden;
  }
  #blog_detail .same_article_area:first-child {
    padding-top: 0;
  }

  #blog_detail .article_content {
    padding: 0;
  }

  #blog_detail .article_detail .category_panel a {
    font-size: 12px;
  }

  #blog_detail .article_detail>.box {
    padding: 25px 15px;
  }

  #blog_detail .article_date {
    font-size: 18px;
    line-height: 1.6;
  }

  #blog_detail .article_title h2 {
    font-size: 18px;
    margin-top: 20px;
    padding: 7px 10px 7px;
  }

  #blog_detail .article_detail_content {
    padding-bottom: 0;
  }

  #blog_detail .article_detail_content p {
    font-size: 15px;
    line-height: 2;
  }

  #blog_detail .same_category .article_date {
    font-size: 12px;
  }

  #blog_detail .article_content h4 {
    font-size: 15px;
  }

  #blog_detail .same_category .category_panel>.box-wrapper {
    width: auto;
    height: auto;
  }

  #blog_detail .same_category .category_panel a {
    position: relative;
    top: auto;
    left: auto;
    font-size: 12px;
    line-height: 1.6;
    width: auto;
    height: auto;
  }

  #blog_detail .same_category .text p {
    font-size: 12px;
    margin-top: 10px;
    margin-bottom: 0;
  }

  #blog_detail .jump_list {
    display: block;
    position: relative;
  }

  #blog_detail .jump_list .back {
    box-sizing: border-box;
    font-size: 12px;
    max-width: none;
    padding-top: 15px;
    padding-bottom: 15px;
    position: absolute;
    top: 0;
    left: 0;
    line-height: 1;
    width: calc(50% - 10px);
  }

  #blog_detail .jump_list .return {
    box-sizing: border-box;
    font-size: 15px;
    line-height: 1.5;
    margin: 60px 0 0;
    max-width: none;
    padding: 17px 10px 18px;
    width: 100%;
  }

  #blog_detail .jump_list .next {
    box-sizing: border-box;
    font-size: 12px;
    max-width: none;
    padding-top: 15px;
    padding-bottom: 15px;
    position: absolute;
    top: 0;
    right: 0;
    line-height: 1;
    width: calc(50% - 10px);
  }

  #blog_detail .same_category {
    clear: both;
  }

  #blog_detail .same_article_image {
    margin-top: 10px;
    width: 40%;
  }

  #blog_detail .same_article_image img {
    width: 100%;
  }

  /* News */
  #news .site-mainvisual {
    background-image: url(../img/news/mainvisual-sp.jpg);
  }

  #news .news_list {
    padding: 35px 10px 30px;
  }

  #news .news_content h4 {
    font-size: 18px;
    margin-top: 15px;
    line-height: 1.444;
  }

  #news .news_content p {
    font-size: 15px;
    line-height: 1.6;
  }

  #news .news_content .category_panel {
    display: inline-block;
    float: none;
    margin-right: 4px;
    margin-bottom: 0;
    vertical-align: middle;
  }

  #news .news_content .category_panel .box-wrapper {
    height: auto;
    border-radius: 3px;
    font-size: 12px;
    line-height: 1.25;
  }

  #news .news_list .category_panel a {
    width: auto;
    height: auto;
    padding: 5px 12px 4px;
    border-radius: 3px;
    font-size: 12px;
    line-height: 1.25;
  }

  #news .news_content .news_date {
    display: inline-block;
    font-size: 12px;
    vertical-align: middle;
  }

  #news .news {
    padding-bottom: 20px;
  }

  #news .jump_list {
    margin-top: 28px;
    margin-bottom: 0;
  }

  .jump_list div {
    margin-bottom: 5px;
  }

  .jump_list a {
    padding: 6px 7px 5px;
    font-size: 9px;
  }

  /* コンセプト */
  #ourstory .site-mainvisual {
    background-image: url(../img/concept/mainvisual-sp.jpg);
  }

  #ourstory #locabo {
    width: 100%;
  }

  #ourstory article .h3-wrapper {
    margin-bottom: 13px;
  }

  #ourstory article {
    margin-bottom: 20px;
  }
  #ourstory article:last-child {
    margin-bottom: 0;
  }

  #ourstory article img {
    margin: 8px;
  }

  #ourstory article .content {
    display: block;
  }

  #ourstory .site_button {
    margin-bottom: 0;
    padding-top: 20px;
    width: 100%;
  }

  #ourstory .site_button>.box {
    width: 100%;
  }

  #ourstory article {
    padding: 18px 15px;
  }
  #ourstory article:first-child {
    margin-top: 0;
  }

  #ourstory article .image-wrapper {
    margin: 0;
    width: 100%;
  }

  #ourstory #patissier .cakes .image-wrapper {
    margin: 10px 0 0;
  }
  #ourstory #patissier .cakes .image-wrapper:first-child {
    margin: 0;
  }

  #ourstory article .image-wrapper>.box-wrapper {
    width: 100%;
  }

  #ourstory article .image-wrapper .box {
    width: 100%;
  }

  #ourstory article .image-wrapper img {
    width: calc(100% - 16px);
  }

  #ourstory article .description {
    display: block;
    font-size: 15px;
    margin-left: 0;
    margin-top: 10px;
    line-height: 1.6;
  }

  #ourstory article h2 {
    box-sizing: border-box;
    font-size: 18px;
    line-height: 1.6;
    padding: 18px 10px 16px;
  }

  #ourstory article h3 {
    font-size: 17px;
    line-height: 1.6;
    padding: 11px 10px 9px;
  }

  #ourstory article a {
    font-size: 14px;
    margin-top: 10px;
    margin-bottom: 20px;
  }

  #ourstory article .button {
    text-align: center;
  }

  #ourstory .image-info {
    display: none;
  }

  #ourstory #patissier .patissier img {
    display: block;
    margin: 50px auto;
    width: 60%;
  }

  #ourstory #patissier .patissier.image-wrapper {
    margin: 0;
  }

  #ourstory article .description dt {
    font-size: 18px;
    margin-bottom: 15px;
  }

  #ourstory article .description dd {
    font-size: 15px;
  }

  #ourstory #patissier .f-sacramento {
    margin-bottom: -10px;
    margin-left: 0;
  }
}

@media screen and (max-width: 480px) {
  .prt-menu-list {
    display: block;
  }

  .prt-menu-list li {
    width: auto;
    margin-left: 0;
  }
  .prt-menu-list li:nth-child(3n+1) {
    margin-left: 0;
  }
  .prt-menu-list li:nth-child(2n+1) {
    margin-left: 0;
  }

  /* Menu */
  #menu .sect-course .prt-header1 {
    margin: 0;
  }

  #menu-detail .sect-combination li,
  #menu-detail .sect-combination .visible.row-first,
  #menu-detail .sect-combination .visible.col2-row-first {
    margin-left: 0;
  }
}


/* profile */
#profile .site-mainvisual.takatsuki {
  background-image: url(../img/profile/takatsuki/mainvisual.jpg);
}
#profile .site-mainvisual.kitahorie {
  background-image: url(../img/profile/takatsuki/mainvisual.jpg);
}
#profile .site-mainvisual.nishishinsaibashi {
  background-image: url(../img/profile/nishishinsaibashi/mainvisual.jpg);
}

#profile article {
  background-color: #FFFFFF;
  padding: 45px 40px 30px;
  margin: 10px 0 10px;
}

#profile article:first-child {
  margin-bottom: 50px;
}

#profile .h2-wrapper {
  margin-bottom: 48px;
}

#profile article h2 {
  background: linear-gradient(#FFFFFF, #F6FAFC 80%, #F6F8F2);
  color: #73A866;
  font-size: 26px;
  line-height: 1.6;
  padding: 12px 10px 8px;
  text-align: center;
}


#profile .site-footer {
  position: relative;
  padding-top: 58px;
}

#profile .site-footer:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 58px;
  background: url(../img/index/footer-frame.png) no-repeat center bottom;
  background-size: 100% 100%;
}

#profile article .shop-images {
  margin: 0 0 10px;
}
#profile article .shop-images ul {
  overflow: hidden;
}
#profile article .shop-images li {
  float: left;
}
#profile article .shop-images li img {
  width: 100%;
}
#profile article .shop-images li {
  margin: 0 0 calc(26 / 920 * 100%);
}
#profile .takatsuki article .shop-images li.img01 {
  width: calc(585 / 920 * 100%);
}
#profile .takatsuki article .shop-images li.img02 {
  float: right;
  width: calc(310 / 920 * 100%);
}
#profile .takatsuki article .shop-images li.img03 {
  width: calc(448 / 920 * 100%);
}
#profile .takatsuki article .shop-images li.img04 {
  float: right;
  width: calc(449 / 920 * 100%);
}

#profile .kitahorie article .shop-images li.img01 {
  width: calc(585 / 920 * 100%);
}
#profile .kitahorie article .shop-images li.img02 {
  float: right;
  width: calc(310 / 920 * 100%);
}
#profile .kitahorie article .shop-images li.img03 {
  width: calc(290 / 920 * 100%);
}
#profile .kitahorie article .shop-images li.img04 {
  float: left;
  margin-left: calc(25 / 920 * 100%);
  width: calc(290 / 920 * 100%);
}
#profile .kitahorie article .shop-images li.img05 {
  float: right;
  width: calc(290 / 920 * 100%);
}

#profile .nishishinsaibashi article .shop-images li.img01 {
  width: 100%;
}
#profile .nishishinsaibashi article .shop-images li.img02 {
  width: calc(448 / 920 * 100%);
}
#profile .nishishinsaibashi article .shop-images li.img03 {
  width: calc(448 / 920 * 100%);
  float: right;
}

#profile article .info {
  margin: 0 0 50px;
}
#profile article .info .googlemap-takatsuki,
#profile article .info .googlemap-kitahorie,
#profile article .info .googlemap-nishishinsaibashi,
#profile article .info .googlemap-franchise {
  margin: 0 0 20px;
  width: 100%;
  height: 400px;
}
#profile article .info .walk {
}
#profile article .info .walk span {
  color: #72a247;
  font-weight: bold;
}

#profile article .detail-table {
  background-image: url(../img/common/bg-border.png);
  border-radius: 5px;
}
#profile article .detail-table table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 1px;
}
#profile article .detail-table table th {
  padding: 5px;
  background: #f2f6ee;
  font-size: 18px;
  font-weight: normal;
  font-family: "Vollkorn", serif;
  vertical-align: middle;
}
#profile article .detail-table table td {
  background: #fff;
  padding: 15px 15px;
  vertical-align: middle;
}

#profile section.todays-lunch {
  position: relative;
  z-index: 10;
}
#profile article.contact-block {
  position: relative;
  z-index: 1;
  margin: -30px 0 60px;
}
#profile article.contact-block ul {
  overflow: hidden;
}
#profile article.contact-block ul li {
  float: left;
  width: 48%;
  background-image: url(../img/common/bg-border.png);
  border-radius: 5px;
  padding: 1px;
}
#profile article.contact-block ul li:nth-child(2n) {
  float: right;
}
#profile article.contact-block ul li .inner {
  overflow: hidden;
  background: #f2f6ee;
}
#profile article.contact-block ul li.qr {
  display: table;
}
#profile article.contact-block ul li.qr .qr-code {
  display: table-cell;
  width: 88px;
  padding: 14px;
  vertical-align: middle;
}
#profile article.contact-block ul li.qr p {
  display: table-cell;
  width: calc(100% - 88px);
  padding: 10px 4px;
  line-height: 1.5;
  vertical-align: middle;
}
#profile article.contact-block ul li.web * {
  box-sizing: border-box;
}
#profile article.contact-block ul li.web .button {
   background: #fff;
}
#profile article.contact-block ul li.web .prt-button1 {
  width: 100%;
  padding: 44px 0;
  background-image: url(../img/profile/kitahorie/btn.png);
  background-size: cover;
}
#profile article.contact-block ul li.web .prt-button1 span {
  display: inline-block;
  padding: 0 0 0 30px;
  background: url(../img/common/icon-reservation2.png) no-repeat left center;
  background-size: 20px auto;
}

#profile article.contact-block ul li.tel {
  text-align: center;
}
#profile article.contact-block ul li.tel a {
  display: block;
  padding: 30px 0;
  color: #72a247;
  font-size: 26px;
}

#profile .menu-block {
  display: table;
  max-width: 775px;
  margin-right: auto;
  margin-left: auto;
  width: 100%;
  height: 548px;
  background-image: url(../img/profile/bg_menu.jpg);
  background-size: cover;
  text-align: center;
}
#profile .menu-block a {
  display: table-cell;
  width: 100%;
  vertical-align: middle;
}
#profile .menu-block a:hover {
  opacity: 0.8;
}
#profile .menu-block a span {
  display: inline-block;
  padding: 20px 50px;
  background: rgba(85, 129, 46, 0.8);
  border: 1px solid #55812e;
  border-radius: 20px;
  color: #fdfdfd;
  font-size: 16px;
}

@media screen and (max-width: 750px) {

  #profile article {
    background-color: #FFFFFF;
    padding: 15px;
    margin: 10px 0 10px;
  }

  #profile article:first-child {
    margin-bottom: 50px;
  }

  #profile .h2-wrapper {
    margin-bottom: 20px;
  }

  #profile article h2 {
    font-size: 18px;
    line-height: 1.6;
  }

  #profile article .shop-images li {
    margin: 0 0 calc(26 / 630 * 100%);
  }
  #profile .takatsuki article .shop-images li.img01 {
    width: 100%;
  }
  #profile .takatsuki article .shop-images li.img02 {
    width: calc(310 / 630 * 100%);
  }
  #profile .takatsuki article .shop-images li.img03 {
    width: calc(293 / 630 * 100%);
  }
  #profile .takatsuki article .shop-images li.img04 {
    width: calc(293 / 630 * 100%);
    float: left;
  }
  #profile .kitahorie article .shop-images li.img01 {
    width: 100%;
  }
  #profile .kitahorie article .shop-images li.img02 {
    width: calc(310 / 630 * 100%);
  }
  #profile .kitahorie article .shop-images li.img03 {
    width: calc(293 / 630 * 100%);
  }
  #profile .kitahorie article .shop-images li.img04 {
    width: calc(293 / 630 * 100%);
    margin: 0;
    float: left;
  }


  #profile article .info {
    margin: 0 0 20px;
  }
  #profile article .info .googlemap-takatsuki,
  #profile article .info .googlemap-kitahorie,
  #profile article .info .googlemap-nishishinsaibashi,
  #profile article .info .googlemap-franchise {
    margin: 0 0 20px;
    width: 100%;
    height: 250px;
  }
  #profile article .info .walk {
    line-height: 1.6;
  }
  #profile article .info .walk span {
  }

  #profile article .detail-table {
  }
  #profile article .detail-table table {
    display: block;
  }
  #profile article .detail-table table tbody,
  #profile article .detail-table table tr,
  #profile article .detail-table table th,
  #profile article .detail-table table td{
    display: block;
    width: 100%;
    box-sizing: border-box;
  }
  #profile article .detail-table table th {
    padding: 2px;
    font-size: 18px;
  }
  #profile article .detail-table table td {
    padding: 10px 15px;
    line-height: 1.6;
  }

  #profile .todays-lunch .prt-header4 {
    margin: 0;
  }
  #profile .todays-lunch .prt-header4 > span {
    position: relative;
    top: auto;
    left: auto;
    margin: auto;
    color: #fff;
    font-size: 10px;
    line-height: 1.5;
  }

  #profile article.contact-block {
    margin: -5px 0 30px;
    padding: 20px 15px 15px;
  }
  #profile article.contact-block ul {
    overflow: hidden;
  }
  #profile article.contact-block ul li {
    float: none;
    width: 100%;
    margin: 0 0 20px;
    box-sizing: border-box;
  }
  #profile article.contact-block ul li:nth-child(2n) {
    float: none;
    margin: 0;
  }
  #profile article.contact-block ul li.web .prt-button1 {
    padding: 30px 0;
  }
  #profile article.contact-block ul li.qr .qr-code {
    width: 70px;
    padding: 10px;
  }
  #profile article.contact-block ul li.qr p {
    width: calc(100% - 70px);
    font-size: 11px;
    padding: 10px 10px;
  }
  #profile article.contact-block ul li.tel a {
    padding: 10px 0;
  }

  #profile .menu-block {
    height: 65vw;
  }
  #profile .menu-block a span {
    padding: 8px 24px;
    border-radius: 10px;
    font-size: 12px;
  }


}

/* Franchise */
#profile .site-mainvisual.franchise {
  background-image: url(../img/profile/franchise/mainvisual.jpg);
}

#profile .site-mainvisual.franchise .heading {
  color: #d0f48b;
}

.prt-header4.area-headline {
  font-size: 24px;
  line-height: 1.4;
  color: #d0f48b;
}

#profile .franchise-content h2 {
  padding: 26px 10px 24px;
}

#profile .franchise-content .info2 {
  margin: 50px 0 0;
}

#profile .franchise-content .shop-images .img-list {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}

#profile .area-navi {
  margin-bottom: 30px;
}

#profile .area-navi ul {
  display: flex;
  flex-wrap: wrap;
}

#profile .area-navi ul li {
  min-width: 124px;
  padding: 1px !important;
  background-image: url(../img/common/bg-border.png);
}

#profile .area-navi ul li:not(:last-child) {
  margin-right: 15px;
}

#profile .area-navi ul a {
  width: 100%;
  padding: 6px 15px;
  color: #55812e;
  background-color: #FFF;
  background-image: url(../img/common/icon-arrow-bottom.png);
  background-repeat: no-repeat;
  background-position: right 15px center;
  background-size: 10px 6px;
  display: block;
  box-sizing: border-box;
}

.fc-contact-link {
  width: 493px;
  max-width: 100%;
  margin: 78px auto 0;
  display: block;
}

@media screen and (max-width: 750px) {
  .prt-header4.area-headline {
    font-size: 18px;
    margin-bottom: 20px;
  }
  #profile .area-navi {
    margin-bottom: 20px;
  }
  #profile .area-navi ul {
    margin-bottom: -4%;
    align-items: center;
    justify-content: space-between;
  }
  #profile .area-navi ul li {
    width: 48%;
    margin-bottom: 4%;
  }
  #profile .area-navi ul li:not(:last-child) {
    margin-right: 0;
  }
}


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

/* リンクボタン追加 2019.06.06 */
#profile article.contact-block ul.link_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
#profile article.contact-block ul.link_wrap li {
  width: 158px;
  margin: 0 6px;
  float: none;
  text-align: center;
}
#profile article.contact-block ul.link_wrap li:nth-child(2n) {
  float: none;
}
#profile article.contact-block ul.link_wrap li a {
  padding: 16px 0;
  display: block;
  color: #2d2d2c;
  font-size: 16px;
  position: relative;
}
#profile article.contact-block ul.link_wrap li a:before,
#profile article.contact-block ul.link_wrap li a:after {
  content: '';
  width: 8px;
  height: 8px;
  display: block;
  position: absolute;
  border: 1px solid #000;
}
#profile article.contact-block ul.link_wrap li a:before {
  top: 8px;
  right: 12px;
}
#profile article.contact-block ul.link_wrap li a:after {
  top: 12px;
  right: 8px;
}
/* Facebook */
#profile article.contact-block ul.link_wrap li.link01 .inner {
  background: rgb(231,239,248);
  background: linear-gradient(0deg, rgba(231,239,248,1) 0%, rgba(253,253,253,1) 100%);
}
#profile article.contact-block ul.link_wrap li.link01 a:before,
#profile article.contact-block ul.link_wrap li.link01 a:after {
  border-color: #2a3b93;
}
/* Instagram */
#profile article.contact-block ul.link_wrap li.link02 .inner {
  background: rgb(254,246,226);
  background: linear-gradient(0deg, rgba(254,246,226,1) 0%, rgba(248,239,251,1) 100%);
}
#profile article.contact-block ul.link_wrap li.link02 a:before {
  border-color: #2a3b93;
}
#profile article.contact-block ul.link_wrap li.link02 a:after {
  border-color: #dd5c53;
}
/* 食べログ */
#profile article.contact-block ul.link_wrap li.link03 .inner {
  background: rgb(253,238,203);
  background: linear-gradient(0deg, rgba(253,238,203,1) 0%, rgba(253,253,253,1) 100%);
}
#profile article.contact-block ul.link_wrap li.link03 a:before,
#profile article.contact-block ul.link_wrap li.link03 a:after {
  border-color: #dd5c53;
}
/* ぐるなび */
#profile article.contact-block ul.link_wrap li.link04 .inner {
  background: rgb(254,235,237);
  background: linear-gradient(0deg, rgba(254,235,237,1) 0%, rgba(253,253,253,1) 100%);
}
#profile article.contact-block ul.link_wrap li.link04 a:before,
#profile article.contact-block ul.link_wrap li.link04 a:after {
  border-color: #d90303;
}
/* ホットペッパー */
#profile article.contact-block ul.link_wrap li.link05 .inner {
  background: rgb(254,224,226);
  background: linear-gradient(0deg, rgba(254,224,226,1) 0%, rgba(253,253,253,1) 100%);
}
#profile article.contact-block ul.link_wrap li.link05 a:before,
#profile article.contact-block ul.link_wrap li.link05 a:after {
  border-color: #bf0202;
}
@media screen and (max-width: 750px) {
  #profile article.contact-block ul.link_wrap {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  #profile article.contact-block ul.link_wrap li {
    width: 48%;
    margin: 0 0 4%;
  }
  #profile article.contact-block ul li:nth-child(2n) {
    margin: 0 0 4%;
  }
}


/* Contact */
#contact .site-mainvisual {
  background-image: url(../img/profile/franchise/mainvisual.jpg);
}

#contact .site-mainvisual .heading {
  color: #FFF;
}

#contact article {
  background-color: #FFFFFF;
  padding: 45px 40px 30px;
  margin: 10px 0 10px;
}

#contact article h2 {
  background: linear-gradient(#FFFFFF, #F6FAFC 80%, #F6F8F2);
  color: #73A866;
  font-size: 26px;
  line-height: 1.6;
  padding: 12px 10px 8px;
  text-align: center;
}

#contact .form-area {
  max-width: 724px;
  margin: 62px auto;
}

#contact .form-lead {
  margin-bottom: 80px;
  text-align: center;
}

#contact .required {
  color: #b11616;
}

*:focus {
  outline: none;
}

input::-webkit-input-placeholder {
  color: var(--placeholder-color, #bbbcba);
}
input:-ms-input-placeholder {
  color: var(--placeholder-color, #bbbcba);
}
input::-moz-placeholder {
  color: var(--placeholder-color, #bbbcba);
}
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
}

textarea {
  vertical-align: bottom;
}
textarea::-webkit-input-placeholder {
  color: var(--placeholder-color, #bbbcba);
}
textarea:-ms-input-placeholder {
  color: var(--placeholder-color, #bbbcba);
}
textarea::-moz-placeholder {
  color: var(--placeholder-color, #bbbcba);
}
textarea:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
}

.form-box {
  margin-bottom: 30px;
}

.form-box dt {
  margin-bottom: 20px;
  font-weight: bold;
}

.form-box dt .required {
  font-weight: 400;
  margin-left: .5em;
}

.form-box dd {
  border-bottom: 2px solid #d5d7d5;
}

.form-control {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;

  width: 100%;
  font-size: 16px;
}

textarea.form-control {
  height: 150px;
  resize: none;
}

.form-submit {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
  
  display: block;
  min-width: 246px;
  margin: 0 auto 0;
  padding: 14px 10px 13px;
  background: url(../img/common/arrow.png) no-repeat right 18px center / 12px, url(../img/common/bg-button2.png) no-repeat center / 100%;
  color: #050505;
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  position: relative;
}

#contact .wpcf7-not-valid-tip {
  font-size: 14px;
}

#contact .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
}

#contact .wpcf7-list-item {
  margin-right: 10px;
  margin-bottom: 10px;
  margin-left: 0;
  line-height: 1;
}

#contact .wpcf7-list-item input[type=radio] {
  position: absolute;
  opacity: 0;
}

#contact .wpcf7-list-item input[type=radio] + .wpcf7-list-item-label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: 1;
}

#contact .wpcf7-list-item input[type=radio] + .wpcf7-list-item-label:before {
  content: "";
  width: 18px;
  height: 18px;
  flex: none;
  margin-right: 0.5em;
  position: relative;
  top: 0;
  display: inline-block;
  border: 1px solid #ccc;
  border-radius: 100%;
  background-color: #fff;
  vertical-align: top;
  text-align: center;
  cursor: pointer;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}

#contact .wpcf7-list-item input[type=radio]:checked + .wpcf7-list-item-label:before {
  border-color: #73A866;
  background-color: #73A866;
  -webkit-box-shadow: inset 0 0 0 4px #fff;
          box-shadow: inset 0 0 0 4px #fff;
}

@media screen and (max-width: 750px) {
  #contact article {
    background-color: #FFFFFF;
    padding: 15px;
    margin: 10px 0 10px;
  }
  #contact article h2 {
    font-size: 18px;
    line-height: 1.6;
  }
  #contact .form-area {
    margin: 30px auto;
  }
  #contact .form-lead {
    margin-bottom: 40px;
    font-size: 14px;
  }
  .form-box dt {
    margin-bottom: 10px;
  }
  #contact .wpcf7-list-item {
    margin-bottom: 15px;
  }
}