@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=DM+Serif+Display:400,400i&display=swap");
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP:400,600,900&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=M+PLUS+Rounded+1c:500,800&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=Kosugi+Maru&display=swap&subset=japanese");
.notoserif {
  font-family: 'Noto Serif JP', serif; }

.dmserif {
  font-family: 'DM Serif Display', serif; }

.rounded1c {
  font-family: 'M PLUS Rounded 1c', sans-serif; }

.kosugimaru {
  font-family: 'Kosugi Maru', sans-serif; }

/*----------------------------------------------------*/
/* Reset style
-----------------------------------------------------*/
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
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; }

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;
  transition: all .3s; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

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

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

li {
  list-style: none; }

img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
  height: auto;
  max-width: 100%;
  transition: all .3s; }

/*----------------------------------------------------*/
/* Base style
-----------------------------------------------------*/
html {
  font-size: 62.5%;
  /* sets the base font to 10px for easier math */ }

body {
  background: #362e2b;
  color: #444444;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", sans-serif;
  font-size: 1.6rem;
  font-weight: 500; }

a:link {
  color: #444444;
  text-decoration: underline; }

a:visited {
  color: #444444;
  text-decoration: underline; }

a:hover {
  color: #444444;
  text-decoration: underline; }

a:active {
  color: #444444;
  text-decoration: underline; }

.sp {
  display: none; }

@media only screen and (max-width: 1024px) {
  .sp {
    display: block !important; }

  .pc {
    display: none; } }
@media only screen and (max-width: 767px) {
  html, body {
    min-width: 0; }

  body {
    font-size: 1.4rem; }

  .sp {
    display: block !important; }

  .pc {
    display: none; } }
/*----------------------------------------------------*/
/* Reset style
-----------------------------------------------------*/
/*----------------------------------------------------*/
/* header
-----------------------------------------------------*/
#fixedheader {
  font-size: 14px;
  width: 100%;
  margin: 0 auto 0;
  padding: 0 0 10px;
  line-height: 1;
  z-index: 999;
  top: 0;
  position: fixed;
  background: #362e2b; }
  #fixedheader .inner {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1440px;
    padding: 0 1rem;
    margin: 0 auto; }
  #fixedheader .name {
    text-align: center; }
    #fixedheader .name img {
      width: 40vw;
      max-width: 483px;
      min-width: 200px; }
  #fixedheader .menutel {
    display: flex;
    justify-content: flex-start;
    align-items: center; }
  #fixedheader .call {
    color: #FFF;
    font-weight: bold;
    font-size: 2.2vw;
    letter-spacing: -1px;
    font-family: "M PLUS Rounded 1c";
    padding-left: 2rem; }
    #fixedheader .call span {
      display: block;
      font-size: 1.6vw; }
  #fixedheader .submenu li {
    display: inline-block;
    margin: 0 0.8vw;
    font-family: "M PLUS Rounded 1c";
    font-weight: bold;
    font-size: 1.6vw;
    line-height: 1.2;
    white-space: nowrap; }
    #fixedheader .submenu li a {
      color: #FFF;
      display: block;
      text-align: center;
      text-decoration: none; }
      #fixedheader .submenu li a span {
        display: block;
        font-size: 1.2rem; }

/* Toggle Button */
#nav-toggle {
  cursor: pointer;
  z-index: 101;
  width: 40px; }
  #nav-toggle div {
    left: 0;
    top: 8px;
    width: 40px;
    position: relative;
    height: 46px; }
  #nav-toggle span {
    display: block;
    position: absolute;
    height: 5px;
    width: 100%;
    background: #FFF;
    left: 0;
    transition: .35s ease-in-out;
    border-radius: 4px; }
    #nav-toggle span:nth-child(1) {
      top: 0; }
    #nav-toggle span:nth-child(2) {
      top: 11px; }
    #nav-toggle span:nth-child(3) {
      top: 22px; }
  #nav-toggle .title {
    color: #FFF; }

/* #nav-toggle 切り替えアニメーション */
.open #nav-toggle span:nth-child(1) {
  top: 11px;
  -webkit-transform: rotate(315deg);
  -moz-transform: rotate(315deg);
  transform: rotate(315deg); }

.open #nav-toggle span:nth-child(2) {
  width: 0;
  left: 50%; }

.open #nav-toggle span:nth-child(3) {
  top: 11px;
  -webkit-transform: rotate(-315deg);
  -moz-transform: rotate(-315deg);
  transform: rotate(-315deg); }

/* global-nav */
#global-nav {
  position: fixed;
  top: -1500px;
  background: #000;
  width: 100%;
  text-align: center;
  padding: 10px 0;
  transition: .5s ease-in-out; }
  #global-nav ul {
    list-style: none;
    position: static;
    font-family: 'DM Serif Display', serif;
    font-size: 18px;
    letter-spacing: 1px; }
    #global-nav ul a {
      width: 100%;
      display: block;
      color: #fff;
      padding: 15px 0;
      text-decoration: none; }

/* #global-nav スライドアニメーション */
.open #global-nav {
  top: 0;
  left: 0;
  position: fixed; }

@media only screen and (min-width: 1440px) {
  #fixedheader .call {
    font-size: 3.0rem; }
    #fixedheader .call span {
      font-size: 1.8rem; }

  #fixedheader .submenu li {
    font-size: 1.8rem; } }
@media only screen and (max-width: 768px) {
  #nav-toggle {
    position: fixed;
    left: 1em;
    top: .25rem; }
    #nav-toggle div {
      height: 32px;
      width: 30px; }
    #nav-toggle span {
      height: 3px; }
      #nav-toggle span:nth-child(1) {
        top: 0; }
      #nav-toggle span:nth-child(2) {
        top: 8px; }
      #nav-toggle span:nth-child(3) {
        top: 16px; }
    #nav-toggle .title {
      font-size: 1.0rem; }

  #fixedheader {
    width: 100%;
    margin: 0 auto 0;
    padding: 10px 0 10px;
    top: 0;
    background: #362e2b; }
    #fixedheader .inner {
      display: block; }
    #fixedheader .call,
    #fixedheader .submenu {
      display: none; }

  /* global-nav */
  #global-nav {
    width: calc(100% - 2rem);
    padding: 1rem 1rem; }
    #global-nav ul {
      font-size: 1.2rem; } }
/*----------------------------------------------------*/
/* main
-----------------------------------------------------*/
#main {
  padding: 8rem 0 8rem 0; }

article {
  max-width: 1400px;
  margin: 0 auto;
  background: #FFFFFF;
  box-sizing: border-box;
  padding: 100px 100px; }

@media only screen and (max-width: 1400px) {
  article {
    max-width: 90%;
    margin: 0 auto;
    background: #FFFFFF;
    padding: 20px 20px; } }
h1.type01 {
  background: #362e2b;
  padding: 10px 20px;
  color: #FFF;
  font-size: 3.0rem;
  font-family: 'DM Serif Display', serif;
  border-radius: 10px 10px;
  margin-bottom: 40px; }

h2.type02 {
  border-bottom: 10px solid #362e2b;
  padding: 0 0 5px;
  color: #362e2b;
  font-size: 2.4rem;
  margin-bottom: 40px; }

.btnbox a {
  display: block;
  text-align: center;
  padding: 1.5em 1em;
  color: #FFF;
  background: #362e2b;
  border-radius: 15px;
  font-weight: bold;
  font-size: 2.0rem;
  text-decoration: none;
  margin: 2em 0;
  transition-duration: 1s;
  transition-timing-function: ease-in-out; }

.btnbox a:hover {
  opacity: 0.8;
  background: #ee3997; }

@media only screen and (max-width: 767px) {
  h1.type01 {
    font-size: 2.4rem; }

  h2.type02 {
    font-size: 1.8rem; } }
/*----------------------------------------------------*/
/* footer
-----------------------------------------------------*/
#pagetop {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 1000;
  width: 60px; }

@media only screen and (max-width: 767px) {
  #pagetop {
    position: fixed;
    bottom: 5rem;
    width: 50px; } }
footer {
  max-width: 1400px;
  max-width: 90%;
  margin: 6rem auto;
  background: #FFFFFF;
  box-sizing: border-box;
  padding: 20px 0 20px; }
  footer p.copyright {
    background: #362e2b;
    padding: 3px 15px;
    text-align: right;
    font-size: 1.4rem;
    font-family: "M PLUS Rounded 1c";
    color: #FFF; }
    footer p.copyright span {
      display: inline-block; }
  footer #footermenu {
    padding: 20px 40px; }
    footer #footermenu a:hover {
      text-decoration: none; }
    footer #footermenu .mainnav {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      margin-bottom: -15px; }
      footer #footermenu .mainnav li {
        width: 48%;
        margin-bottom: 15px; }
        footer #footermenu .mainnav li a {
          display: inline;
          padding-left: 25px;
          text-indent: -25px; }
          footer #footermenu .mainnav li a:before {
            width: 20px;
            height: 20px;
            content: "";
            display: inline-block;
            vertical-align: middle;
            margin-right: 5px;
            background: url(/lib_v2/images/cmn/icon_heart.png) no-repeat 0 0;
            background-size: contain; }

#fixedfooter {
  display: none; }

@media only screen and (max-width: 768px) {
  footer {
    margin: 0 auto;
    background: #FFFFFF; }
    footer p.copyright {
      padding: 3px 0px;
      font-size: 1.0rem;
      font-family: "M PLUS Rounded 1c";
      color: #FFF;
      text-align: center; }
      footer p.copyright span {
        display: inline; }
    footer #footermenu {
      display: block;
      padding: 20px 10px; }
      footer #footermenu .mainnav {
        display: block; }
        footer #footermenu .mainnav li {
          width: 100%;
          margin-bottom: 15px;
          line-height: 1.2; }
          footer #footermenu .mainnav li a {
            display: block;
            padding-left: 20px;
            text-indent: -20px; }
            footer #footermenu .mainnav li a:before {
              width: 15px;
              height: 15px; } }
@media only screen and (max-width: 768px) {
  #fixedfooter {
    display: block;
    z-index: 100;
    position: fixed;
    left: 0;
    bottom: 0;
    background: #362e2b;
    transition: top 0.65s ease-in;
    width: 100%;
    padding: 10px 15px;
    box-sizing: border-box; }
    #fixedfooter .submenu {
      display: flex;
      justify-content: space-between; }
      #fixedfooter .submenu li {
        margin: 0 0.8vw;
        font-family: "M PLUS Rounded 1c";
        font-weight: normal;
        font-size: 3.5vw;
        line-height: 1.2;
        color: #FFF; }
        #fixedfooter .submenu li a {
          color: #FFF;
          display: block;
          text-align: center;
          text-decoration: none; }
          #fixedfooter .submenu li a span {
            display: block; } }
