@charset "UTF-8";
/* background-image ratina対応 */
/* メディアクエリの設定 */
/* ====================================================== */
/* [標準スタイル定義]                                     */
/* ====================================================== */
* {
  margin: 0;
  padding: 0;
  font: inherit;
  -webkit-text-size-adjust: none;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch; }

html, body {
  font-family: 'Roboto', "Helvetica", Verdana, "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  width: 100%;
  height: 100%;
  margin: 0;
  color: #777;
  background-color: #fff;
  -webkit-text-size-adjust: 100%;
  font-size: 16px;
  line-height: 2.0;
  min-width: 1080px; }

a {
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease; }

a:hover,
a.button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover,
button:hover,
.btnOpacity:hover,
a:active,
a.button:active,
input[type="submit"]:active,
input[type="reset"]:active,
input[type="button"]:active,
button:active,
.btnOpacity:active {
  filter: alpha(opacity=50);
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=50);
  opacity: 0.5;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease; }

img {
  border: none;
  max-width: 100%;
  outline: none; }

img.ofi {
  object-fit: cover;
  font-family: 'object-fit: cover;'; }

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

.nowrap {
  word-break: keep-all;
  white-space: nowrap; }

p {
  word-wrap: break-word; }

span.serif {
  font-family: serif; }

/*===========================
スマホ・PC切り替え
===========================*/
.pc-cnt {
  display: block !important; }

.pc-cnt.index-only {
  display: none !important; }

#index .pc-cnt.index-only {
  display: block !important; }

.sp-cnt {
  display: none !important; }

/* table */
/* ------------------------------------------------------ */
table {
  border-collapse: collapse;
  border-spacing: 0px;
  border: none;
  width: 100%; }

table th {
  border-top: 1px solid #cccccc;
  border-bottom: 1px solid #cccccc;
  background-color: #f9f5f2;
  text-align: center;
  vertical-align: middle;
  width: 160px;
  font-weight: bold; }

table th + td {
  border-top: 1px solid #cccccc;
  border-bottom: 1px solid #cccccc; }

table td {
  background-color: #ffffff;
  border-top: 1px solid #cccccc;
  border-bottom: 1px solid #cccccc;
  vertical-align: middle; }

table tr + tr > th {
  border-top: none;
  border-bottom: 1px solid #cccccc; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: top; }

th, td {
  padding: 1em 1.4em; }

caption {
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 10px; }

table th p,
table td p,
table th textarea,
table td textarea {
  font-size: 100%; }

.table {
  display: table !important; }

.td {
  display: table-cell !important;
  vertical-align: middle; }

table.unv-tbl {
  width: auto; }
  table.unv-tbl tr {
    border-top: none !important;
    border-bottom: none !important;
    border-right: none !important;
    border-left: none !important; }
  table.unv-tbl th, table.unv-tbl td {
    padding: 0px;
    width: auto !important;
    text-align: left; }
  table.unv-tbl th {
    border-top: none !important;
    border-bottom: none !important;
    border-right: none !important;
    border-left: none !important;
    background-color: transparent; }
  table.unv-tbl td {
    border-top: none !important;
    border-bottom: none !important;
    border-right: none !important;
    border-left: none !important;
    background-color: transparent; }

/* list */
/* ------------------------------------------------------ */
ul {
  list-style: none; }

ul.unv-li li {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap; }
  ul.unv-li li p:first-child {
    color: #000;
    margin-right: 1em; }

/* float 制御
--------------------------------------------------------- */
*.left {
  float: left; }

*.right {
  float: right; }

.clr:after {
  content: " ";
  display: block;
  visibility: hidden;
  clear: both;
  height: 0.1px;
  font-size: 0.1em;
  line-height: 0; }

.clr {
  display: inline-block; }

/* no ie mac \*/
* html .clr {
  height: 1%; }

.clr {
  display: block; }

/* */
*.clear {
  clear: both; }

br.clear {
  clear: both;
  display: inline; }

div.clear {
  font: 1px/1px sans-serif;
  line-height: 1px;
  height: 1px; }

/* flex 制御
---------------------------*/
.flex {
  display: flex !important;
  flex-wrap: wrap; }

.fl-l {
  justify-content: left; }

.fl-r {
  justify-content: right; }

.fl-sb {
  justify-content: space-between; }

.fl-sb3-left {
  justify-content: space-between; }

.fl-sb3-left::after {
  display: block;
  content: "";
  height: 0; }

.fl-sb4-left {
  justify-content: space-between; }

.fl-sb4-left::after {
  display: block;
  content: "";
  height: 0; }

.fl-sb4-left::before {
  display: block;
  content: "";
  height: 0;
  order: 1; }

.fl-sa {
  justify-content: space-around; }

.fl-ev {
  justify-content: space-evenly; }

/*===========================
表示スタイル定義
===========================*/
.wrapper {
  width: 100%;
  position: relative;
  height: auto !important;
  /*IE6対策*/
  height: 100%;
  /*IE6対策*/
  min-height: 100%;
  margin: 0px;
  padding: 0px; }

h1, h2, h3, h4, h5, h6 {
  font-family: "Volkhov", "Shippori Mincho", "Hiragino Mincho ProN", "YuMincho", "Yu Mincho", "MS PMincho", serif; }

h1 {
  font-size: 50px;
  line-height: 1em;
  font-weight: bold;
  color: #555; }
  h1 span.en {
    color: #c0ab9a;
    font-size: 30px;
    line-height: 1em;
    display: block;
    margin-bottom: 30px; }

h2 {
  font-size: 30px;
  color: #c0ab9a;
  font-weight: bold;
  line-height: 1.4em; }

h3 {
  font-size: 24px;
  color: 555;
  font-weight: bold;
  line-height: 1.8em; }

h4 {
  font-size: 20px;
  color: 555;
  font-weight: bold;
  line-height: 1.8em; }

/* HEADER
---------------------------*/
header {
  width: 100%; }
  header .container {
    width: 100%;
    padding: 25px 25px 0 0; }
  header .h-logo {
    width: 160px; }
    header .h-logo img {
      display: block;
      width: 92px;
      margin: 0 auto; }
  header .gnav {
    font-family: "Volkhov", "Shippori Mincho", "Hiragino Mincho ProN", "YuMincho", "Yu Mincho", "MS PMincho", serif;
    font-size: 24px;
    color: #000;
    align-items: start; }
    header .gnav li + li {
      margin-left: 40px; }
    header .gnav li:nth-last-child(2) {
      color: #c0ab9a; }
    header .gnav li:last-child {
      font-size: 18px;
      line-height: 1em; }
      header .gnav li:last-child a {
        display: block;
        padding: 18px 36px;
        background-color: #c0ab9a;
        color: #fff; }

#hamburger {
  display: none; }

/* CONTENTS - common
---------------------------*/
.cnt-wrap {
  min-height: 100vh;
  position: relative;
  padding-bottom: 80px;
  box-sizing: border-box; }

.container {
  width: 980px;
  margin: 0 auto;
  position: relative; }

section + section {
  margin-top: 80px; }

.mw-sns-group {
  position: absolute;
  bottom: 40px;
  left: 40px; }
  .mw-sns-group img {
    width: 95px;
    display: block;
    margin: 0 auto 20px; }
  .mw-sns-group .sns-logo {
    width: 80px;
    margin: 0 auto; }
    .mw-sns-group .sns-logo i {
      width: 30px;
      color: #000;
      display: block;
      font-size: 30px; }

.bc-li {
  margin: 20px auto;
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap; }
  .bc-li li {
    position: relative;
    height: 1em;
    line-height: 1em;
    padding-right: 25px; }
    .bc-li li a {
      color: #c0ab9a; }
  .bc-li li:before {
    content: "\f054";
    display: block;
    position: absolute;
    top: 0px;
    bottom: 0px;
    right: 10px;
    margin: auto;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 7px; }
  .bc-li li:last-child {
    padding-right: 0px; }
  .bc-li li:last-child::before {
    display: none; }

.ttl-group {
  margin-bottom: 60px; }

.gmap {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative; }
  .gmap iframe {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%; }

/* FOOTER
---------------------------*/
footer {
  background-color: #000;
  color: #fff;
  font-size: 12px;
  min-height: 65px;
  max-height: 65px;
  padding: 20px 0; }
  footer .container {
    align-items: center; }
  footer li i {
    margin-right: 10px; }
  footer li + li {
    margin-left: 30px;
    position: relative; }
  footer a {
    color: #fff; }

/* 2nd-floor */
.foot-group {
  position: fixed;
  bottom: 0px;
  width: 100%;
  align-items: flex-end;
  pointer-events: none;
  bottom: 40px; }
  .foot-group .mw-sns-group {
    position: inherit;
    bottom: unset;
    left: unset; }
    .foot-group .mw-sns-group a {
      pointer-events: auto; }
  .foot-group .l-cnt {
    margin-left: 40px; }
  .foot-group .gotop {
    margin-right: 40px;
    pointer-events: auto; }

/* BREADCRUMBS
---------------------------*/
#breadcrumbs {
  width: 100%;
  line-height: 40px;
  background-color: #f2f2f2; }
  #breadcrumbs li + li {
    padding-left: 30px;
    background: url(/image/common/icon_arrow_breadcrumbs.png) no-repeat 15px center; }

/*===========================
共通パーツ
===========================*/
/*ボタン*/
.btn a {
  display: block;
  margin: 0 auto;
  font-weight: bold;
  text-align: center; }
  .btn a i {
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-right: 10px; }

.btn-mid a {
  width: 300px;
  padding: 20px 0; }

.btn-sml a {
  width: 180px;
  padding: 10px 0; }

.btn-bk a {
  background: #000;
  color: #fff; }

.btn-wh a {
  background: #fff;
  color: #000; }

.btn-wh-bd a {
  background: #fff;
  color: #000;
  border: 1px solid #000; }

/* ページャー */
.pager .wp-pagenavi {
  margin: 40px 0 0;
  padding: 25px 20px;
  border-top: 1px #ccc solid;
  border-bottom: 1px #ccc solid;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center; }
.pager a {
  display: inline-block;
  position: relative;
  text-align: center;
  height: 40px;
  line-height: 40px; }
.pager a.page {
  width: 40px; }
.pager a.first, .pager a.last {
  background: #ddd; }
.pager a.first,
.pager a.previouspostslink {
  margin-right: 15px;
  padding: 0 10px; }
.pager a.last,
.pager a.nextpostslink {
  margin-left: 15px;
  padding: 0 10px; }
.pager a.previouspostslink,
.pager a.nextpostslink {
  background: #777;
  color: #fff; }
.pager a.first .pager-text,
.pager a.previouspostslink .pager-text {
  margin-left: 10px; }
.pager a.last .pager-text,
.pager a.nextpostslink .pager-text {
  margin-right: 10px; }
.pager .is-current {
  width: 40px;
  height: 40px;
  text-align: center;
  line-height: 40px;
  background-color: #c1ab9a;
  color: #fff;
  border-radius: 20px; }
.pager .wp-pagenavi.single {
  display: block; }
  .pager .wp-pagenavi.single a {
    width: auto; }
  .pager .wp-pagenavi.single a::before {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    font-family: "Font Awesome 5 Free";
    font-weight: 900; }
  .pager .wp-pagenavi.single .next a {
    text-align: right;
    padding-right: 15px; }
  .pager .wp-pagenavi.single .next a::before {
    content: "\f105";
    right: 0px; }
  .pager .wp-pagenavi.single .prev a {
    text-align: left;
    padding-left: 15px; }
  .pager .wp-pagenavi.single .prev a::before {
    content: "\f104";
    left: 0px; }

.pager + * {
  margin-top: 40px; }

/* ニュースリスト */
.news-list-box
ul {
  width: 100%;
  margin: 0 auto; }
  .news-list-box
  ul li {
    padding: 20px 0;
    font-weight: bold; }
    .news-list-box
    ul li span {
      width: 100%; }
    .news-list-box
    ul li .date {
      color: #c0ab9a; }
    .news-list-box
    ul li .date + span {
      display: inline-block; }
  .news-list-box
  ul li + li {
    border-top: 1px dotted #929292; }

/*===========================
フォント定義
===========================*/
strong, .bold {
  font-weight: bold; }

.sans-serif {
  font-family: sans-serif !important; }

/*===========================
文字揃え
===========================*/
.co-tac {
  text-align: center; }

.co-tal {
  text-align: left; }

.co-tar {
  text-align: right; }

/*# sourceMappingURL=common.css.map */
