@charset "utf-8";

/*reset css
---------------------------------------------------*/

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: normal;
  vertical-align: baseline;
  font-feature-settings: "palt";
}

img {
  vertical-align: bottom;
  border: 0px;
  -ms-interpolation-mode: bicubic;
  vertical-align: text-bottom;
  border: none;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block;
}

html {
  overflow-y: scroll;
  font-size: 62.5%;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}

body {
  font-family: 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro",
    "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック",
    "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 1.6;
  letter-spacing: 0.1rem;
  color: #000000;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-style: normal;
  font-weight: normal;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

input,
textarea {
  margin: 0;
  padding: 0;
}

ol,
ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption,
th {
  text-align: left;
}

a {
  text-decoration: none;
  color: #717171;
  transition-property: all;
  transition: 0.3s linear;
}

a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}

a:focus {
  outline: none;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

.ellipsis {
  white-space: nowrap;
  overflow: hidden;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
}
.indent {
  text-indent: -1em;
  padding-left: 1em;
}

/*WEBフォントを読み込むときに使用*/
html {
  visibility: hidden;
  overflow-y: scroll;
  font-size: 62.5%;
}
html.wf-active {
  visibility: visible;
}

/*margin
---------------------------------------------------*/
.mr25 {
  margin-right: 25px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mb110 {
  margin-bottom: 110px !important;
}

.mb120 {
  margin-bottom: 120px !important;
}

.mb125 {
  margin-bottom: 125px !important;
}

.mb150 {
  margin-bottom: 150px !important;
}

/*cleafix
/------------------------------------------------------------*/
.cf:before,
.cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

/* For IE 6/7 (trigger hasLayout) */
.cf {
  zoom: 1;
}

/*フォント装飾
/------------------------------------------------------------*/
.bold {
  font-weight: bold;
}

/*縦書き
/------------------------------------------------------------*/
.tate,
.tate_smp_r {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -moz-font-feature-settings: "vkrn", "vpal";
  -webkit-font-feature-settings: "vkrn", "vpal";
  font-feature-settings: "vkrn", "vpal";
}

/* スマホ用非表示
---------------------------------------------------*/
.smp {
  display: none;
}

/*flex(均等配置)
---------------------------------------------------*/
/*折り返し*/
.flexbox {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

/*折り返し無し*/
.flexbox02 {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: flex;
}

/*要素の間をあける、端は除く、垂直方向ベースライン揃え*/
.flexbox-container {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: flex;
  -webkit-box-pack: justify;
  -moz-box-pack: justify;
  -webkit-flex-pack: justify;
  -moz-flex-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
}

.flexbox-reverse {
  display: -webkit-box; /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox; /*--- IE10 ---*/
  display: -webkit-flex; /* Safari */
  display: flex;
  -webkit-box-direction: reverse; /*--- Androidブラウザ用 ---*/
  -ms-flex-direction: reverse; /*--- IE10用 ---*/
  -webkit-flex-direction: row-reverse; /* Safari */
  flex-direction: row-reverse;
}

.flex_box {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.flex_box article:nth-child(1) {
  width: 51%;
}
.flex_box article:nth-child(2) {
  width: 45%;
}
.flex_box article:nth-child(2) img {
  max-width: 100%;
  height: auto;
  margin: 0 auto 0;
}

@media only screen and (max-width: 900px) {
  footer .left {
    margin: 0 auto 0;
  }

  .flex_box {
    margin: 0 auto 0;
  }

  .flex_box article:nth-child(1) {
    width: 100%;
    margin-bottom: 20px;
  }
  .flex_box article:nth-child(2) {
    width: 100%;
  }
}

/*画像
---------------------------------------------------*/
.img100 {
  width: 100%;
  height: auto;
}

/*テキスト
---------------------------------------------------*/
.text-underline {
  text-decoration: underline;
}

/* 共通リンク
---------------------------------------------------*/
.link01 {
  display: block;
  background-color: #b93737;
  color: #fff;
  font-size: 1.8rem;
  padding: 10px 50px;
  letter-spacing: 2px;
}

/* 見出し
---------------------------------------------------*/
.midashi {
  position: relative;
  color: #fff;
  background-image: url("../img/top/title_bg.png");
  display: inline-block;
  max-width: 94px;
  width: 100%;
  height: 464px;
  text-align: center;
  padding-top: 20px;
}

.midashi h2 {
  display: inline-block;
  text-align: left;
  font-family: "a-otf-ryumin-pr6n";
  font-size: 32px;
}

/*main
---------------------------------------------------*/
.w1181 {
  max-width: 1181px;
  width: 100%;
  padding: 0 0.8em;
  margin: 0px auto;
}

/*bg
---------------------------------------------------*/
.bg {
  background-image: url("../img/common/bg.jpg");
}

/*common_bnr
---------------------------------------------------*/
.common_bnr {
  margin-bottom: 50px;
}

.common_bnr a {
  display: block;
  max-width: 48.5%;
  width: 100%;
  height: 238px;
  -webkit-background-size: cover;
  background-size: cover;
  text-align: center;
  padding-top: 95px;
}

.common_bnr a span {
  color: #fff;
  font-family: "a-otf-ryumin-pr6n";
  font-size: 3.5rem;
  text-shadow: rgba(0, 0, 0, 0.8) 0px 0px 5px;
}

.common_bnr .dish {
  background-image: url("../img/common/bnr_yuzen.jpg");
}

.common_bnr .yawaragi {
  background-image: url("../img/common/bnr_yawaragi.jpg");
}

/* footer
---------------------------------------------------*/
footer {
  background-color: rgba(0, 0, 0, 0.85);
  color: #fff;
  padding-top: 60px;
}

footer nav {
  display: inline-block;
  margin: 0 auto 1.5rem;
}

footer nav ul {
  margin-left: 50px;
}

footer nav ul li {
  margin-right: 0.5rem;
  margin-left: 0.5rem;
}

footer nav ul li a {
  color: #fff;
  font-size: 1.6rem;
}

footer p.copy {
  margin-top: 2rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  text-align: center;
  font-size: 1.3rem;
}

.footer-logo {
  max-width: 230px;
  height: auto;
}
