@charset "UTF-8";
/* reset
-------------------------------------*/
html {
  background: #fff; }

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, input, textarea, p, blockquote, th, td, figure {
  margin: 0;
  padding: 0; }

table {
  border-collapse: separate;
  border-spacing: 0; }

fieldset, img {
  border: 0; }

img {
  vertical-align: top;
  pointer-events: none; }

address, caption, em, strong, th {
  font-style: normal;
  font-weight: normal; }

ol, ul, li {
  list-style: none; }

caption, th, td {
  text-align: left; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

sup {
  vertical-align: super;
  font-size: 84%; }

sub {
  vertical-align: sub;
  font-size: 84%; }

input, textarea, select {
  font-family: inherit;
  font-size: inherit; }

/* setting
-------------------------------------*/
html {
  font-size: 62.5%; }

body {
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
  text-rendering: auto;
  color: #222;
  font-family: 'Quicksand', '游ゴシック体', 'YuGothic',"游ゴシック", "Yu Gothic", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 'メイリオ', 'Meiryo', 'Osaka', "ＭＳ Ｐゴシック", "MS PGothic", 'sans-serif', 'sans-serif','游明朝体', 'Yu Mincho','游明朝', 'YuMincho',"ヒラギノ明朝 Pro", 'Hiragino Mincho Pro', 'MS P明朝', 'MS PMincho';
  width: 100%;
  -webkit-font-feature-settings: “palt” 1;
  font-feature-settings: “palt” 1;
  margin: auto;
  background-size: 100%;
  background-color: #fff;
  font-size: 100%;
  line-height: 1.7rem; }

main {
  display: block; }

a {
  display: block;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

a, a:visited {
  color: inherit;
  text-decoration: none; }

a:hover {
  text-decoration: none; }

table {
  width: 100%; }

p, a, ul, li {
  text-align: justify; }

img {
  max-width: 100%;
  height: auto; }

iframe {
  max-width: 100%; }

@media (min-width: 751px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none; } }
body {
  width: 100%;
  min-width: 1120px;
  font-feature-settings: "pkna" 1;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 1.2px; }
  body .ctn {
    width: 1080px;
    margin: auto; }
  body .ic-line::before, body .ic-mail::before {
    content: '';
    display: block;
    background-size: contain; }
  body .ic-line::before {
    width: 22px;
    height: 16px;
    background-image: url("/img/common/ic-line.png"); }
  body .ic-mail::before {
    width: 20px;
    height: 13px;
    background-image: url("/img/common/ic-mail.png"); }
  body .f-min {
    font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho Pro', 'MS PMincho', serif;
    font-weight: 500; }
  @media (max-width: 768px) {
    body .gmap iframe {
      height: 250px; } }
  body .btn-tel {
    font-size: 32px;
    font-size: 3.2rem;
    line-height: 32px; }
    body .btn-tel::before {
      content: '';
      display: inline-block;
      width: 18px;
      height: 24px;
      background-image: url("/img/top/ic-tel.png");
      background-size: contain;
      vertical-align: top;
      margin-right: 10px; }
  body .sp {
    display: none; }
  @media (max-width: 768px) {
    body {
      font-size: 14px;
      font-size: 1.4rem;
      min-width: 100%; }
      body .ctn {
        width: 100%;
        padding: 0 20px; }
      body p {
        line-height: 26px; }
      body .btn-tel {
        font-size: 28px;
        font-size: 2.8rem; }
      body .pc {
        display: none; }
      body .sp {
        display: block; } }

/*--------------------------------
	header
--------------------------------*/
header {
  background: #fff;
  padding: 20px;
  position: relative; }
  header h1 {
    font-size: 12px;
    font-size: 1.2rem; }
  header .logo {
    margin-top: 15px; }
  header nav #menu-btn {
    width: 80px;
    height: 80px;
    background: #a6937c;
    padding: 20px 16px;
    position: fixed;
    top: 20px;
    right: 20px; }
    header nav #menu-btn .inner {
      display: -webkit-box;
      display: flex;
      display: -webkit-flex;
      display: -ms-flexbox;
      flex-direction: column;
      -webkit-flex-direction: column;
      -ms-flex-direction: column;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      align-items: center;
      -webkit-align-items: center;
      -ms-flex-align: center;
      -webkit-box-align: center; }
      header nav #menu-btn .inner span {
        width: 48px;
        height: 2px;
        background: #fff; }
        header nav #menu-btn .inner span:not(:first-child) {
          margin-top: 8px; }
    header nav #menu-btn p {
      font-size: 17px;
      font-size: 1.7rem;
      color: #fff;
      font-weight: 500;
      text-align: center;
      margin-top: 10px; }
    header nav #menu-btn.active .top {
      -webkit-transform: translateY(9px) translateX(0) rotate(45deg);
      transform: translateY(9px) translateX(0) rotate(45deg); }
    header nav #menu-btn.active .middle {
      opacity: 0; }
    header nav #menu-btn.active .bottom {
      -webkit-transform: translateY(-12px) translateX(0) rotate(-45deg);
      transform: translateY(-12px) translateX(0) rotate(-45deg); }
  header nav #gnav {
    max-width: 500px;
    background: #fff;
    border-left: solid 1px #ddd; }
  header nav ol {
    padding: 120px 20px 20px; }
    header nav ol li {
      width: 48%;
      border-bottom: solid 1px #a6937c; }
      header nav ol li a {
        padding: 15px; }
  @media (max-width: 768px) {
    header {
      padding: 10px; }
      header h1, header .logo {
        max-width: calc(100% - 60px); }
      header h1 {
        font-size: 12px;
        font-size: 1.2rem;
        letter-spacing: 0;
        line-height: 16px; }
      header .logo {
        margin-top: 10px; }
      header nav #menu-btn {
        width: 50px;
        height: 50px;
        padding: 5px;
        top: 10px;
        right: 10px;
        display: -webkit-box;
        display: flex;
        display: -webkit-flex;
        display: -ms-flexbox;
        justify-content: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        -webkit-box-pack: center;
        align-items: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        -webkit-box-align: center;
        flex-direction: column;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal; }
        header nav #menu-btn .inner span {
          width: 30px; }
          header nav #menu-btn .inner span:not(:first-child) {
            margin-top: 5px; }
        header nav #menu-btn p {
          font-size: 12px;
          font-size: 1.2rem;
          line-height: 12px;
          margin-top: 5px;
          letter-spacing: 0; }
        header nav #menu-btn.active .top {
          -webkit-transform: translateY(7px) translateX(0) rotate(45deg);
          transform: translateY(7px) translateX(0) rotate(45deg); }
        header nav #menu-btn.active .bottom {
          -webkit-transform: translateY(-8px) translateX(0) rotate(-45deg);
          transform: translateY(-8px) translateX(0) rotate(-45deg); }
      header nav ol {
        padding: 100px 20px 20px; }
        header nav ol li:nth-child(n+3) {
          margin-top: 15px; }
        header nav ol li a {
          font-size: 13px;
          font-size: 1.3rem;
          line-height: 24px;
          letter-spacing: 0;
          text-align: center;
          padding: 0 0 10px 0; } }

/*--------------------------------
	mv
--------------------------------*/
#mv .main {
  display: -webkit-box;
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-box-pack: center; }
  #mv .main a {
    width: 630px;
    height: 85vh;
    min-height: calc(280px + 9vh);
    max-width: 100%;
    padding: 20px;
    position: relative; }
    #mv .main a:not(:first-child) {
      margin-left: 15px; }
    #mv .main a.box1 {
      background: url("/img/common/mv-01.png") center center no-repeat;
      background-size: cover; }
    #mv .main a.box2 {
      background: url("/img/common/mv-02.png") center center no-repeat;
      background-size: cover; }
    #mv .main a.box3 {
      background: url("/img/common/mv-03.png") center center no-repeat;
      background-size: cover; }
    #mv .main a:hover {
      opacity: .8; }
  #mv .main p {
    text-align: center;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 9vh; }
#mv .sub {
  background: url("/img/common/sv.png") center center no-repeat;
  background-size: cover;
  height: 400px; }
  #mv .sub .ctn {
    height: 100%;
    display: -webkit-box;
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: flex-end;
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    -webkit-box-pack: end;
    align-items: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    -webkit-box-align: center; }
  #mv .sub p {
    background: url("/img/common/sv-base.png") center center no-repeat;
    background-size: cover;
    width: 460px;
    height: 200px;
    max-width: 100%;
    display: -webkit-box;
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    align-items: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    -webkit-box-align: center; }
@media (max-width: 768px) {
  #mv .main {
    display: block;
    padding: 0 10px; }
    #mv .main a {
      width: 100%;
      height: 30vh;
      padding: 20px; }
      #mv .main a:not(:first-child) {
        margin-left: 0;
        margin-top: 10px; }
      #mv .main a p {
        bottom: 5vh; }
        #mv .main a p img {
          height: 25vh; }
  #mv .sub {
    height: 250px; }
    #mv .sub .ctn {
      justify-content: center;
      -webkit-justify-content: center;
      -ms-flex-pack: center;
      -webkit-box-pack: center; }
    #mv .sub p {
      background-size: contain;
      padding: 15px; } }

/*--------------------------------
	footer
--------------------------------*/
footer {
  border-top: solid 1px #a6937c; }
  footer section {
    width: 50%; }
  footer .box {
    display: -webkit-box;
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    align-items: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    -webkit-box-align: center;
    flex-direction: column;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal; }
    footer .box p, footer .box a {
      line-height: 24px;
      text-align: center; }
    footer .box ol li:not(:first-child) {
      border-left: solid 1px #ddd;
      margin-left: 20px;
      padding-left: 20px; }
    footer .box ol li a {
      font-size: 14px;
      font-size: 1.4rem;
      color: #a6937c; }
    footer .box small {
      display: block;
      font-size: 12px;
      font-size: 1.2rem;
      text-align: center; }
      footer .box small span, footer .box small a {
        display: inline-block; }
      footer .box small a {
        color: #333;
        margin: 0 5px; }
  footer #fix_btn {
    position: fixed;
    right: 10px;
    bottom: 20px;
    z-index: 90;
    transition: none;
    transition: .4s; }
    footer #fix_btn .inner a {
      width: 90px;
      height: 60px;
      color: #fff;
      font-size: 12px;
      font-size: 1.2rem;
      letter-spacing: .8px;
      text-align: center;
      display: -webkit-box;
      display: flex;
      display: -webkit-flex;
      display: -ms-flexbox;
      justify-content: center;
      -webkit-justify-content: center;
      -ms-flex-pack: center;
      -webkit-box-pack: center;
      align-items: center;
      -webkit-align-items: center;
      -ms-flex-align: center;
      -webkit-box-align: center;
      flex-direction: column;
      -webkit-flex-direction: column;
      -ms-flex-direction: column;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal; }
      footer #fix_btn .inner a::before {
        margin-bottom: 5px; }
      footer #fix_btn .inner a.btn-line {
        background: #d1c0a5; }
      footer #fix_btn .inner a.btn-mail {
        background: #a6937c; }
    footer #fix_btn #page_top {
      border: solid 1px #dbd4cb;
      border-radius: 50rem; }
    footer #fix_btn img {
      transition: none; }
    footer #fix_btn.slide-none {
      transition: .4s;
      right: -240px; }
  @media (max-width: 768px) {
    footer .wrap {
      flex-direction: column;
      -webkit-flex-direction: column;
      -ms-flex-direction: column;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      flex-direction: row-reverse;
      -ms-flex-direction: column-reverse;
      -webkit-box-direction: reverse;
      -webkit-flex-direction: column-reverse; }
    footer section {
      width: 100%; }
    footer .box {
      padding: 50px 20px; }
      footer .box ol li:not(:first-child) {
        margin-left: 10px;
        padding-left: 10px; }
    footer small {
      font-size: 10px;
      font-size: 1rem;
      letter-spacing: 0; }
      footer small span, footer small a {
        font-size: 10px;
        font-size: 1rem;
        letter-spacing: 0; }
    footer #fix_btn {
      align-items: flex-end;
      -webkit-align-items: flex-end;
      -ms-flex-align: end;
      -webkit-box-align: end; }
      footer #fix_btn #page_top {
        width: 40px; } }

/*--------------------------------
	common
--------------------------------*/
#main {
  padding-bottom: 150px; }
  @media (max-width: 768px) {
    #main {
      padding-bottom: 50px; } }

#main p, #sub p {
  line-height: 30px; }
#main .button, #sub .button {
  margin-top: 50px; }
  #main .button a, #sub .button a {
    width: 200px;
    max-width: 100%;
    background: #fff;
    border: solid 1px #a6937c;
    font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho Pro', 'MS PMincho', serif;
    font-weight: 500;
    text-align: center;
    line-height: 16px;
    padding: 20px;
    position: relative; }
    #main .button a::before, #sub .button a::before {
      content: '';
      display: block;
      width: 60px;
      height: 1px;
      background: #a6937c;
      position: absolute;
      top: 0;
      left: -30px;
      bottom: 0;
      margin: auto 0; }
    #main .button a:hover, #sub .button a:hover {
      opacity: .8;
      background: #f7f4ef; }
  @media (max-width: 768px) {
    #main .button, #sub .button {
      margin-top: 30px; }
      #main .button a, #sub .button a {
        margin: 0 auto; } }
#main .list-news a, #sub .list-news a {
  display: -webkit-box;
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  align-items: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
  padding: 0 50px 0 20px;
  position: relative;
  border-bottom: solid 1px #a6937c;
  padding-bottom: 20px; }
  #main .list-news a::after, #sub .list-news a::after {
    font-family: "Font Awesome 5 Free";
    content: '\f054';
    font-weight: 900;
    color: #999;
    position: absolute;
    top: calc(50% - 15px);
    right: 20px; }
  #main .list-news a time, #sub .list-news a time {
    display: block; }
  #main .list-news a .tag, #sub .list-news a .tag {
    display: -webkit-box;
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: 10px; }
    #main .list-news a .tag span, #sub .list-news a .tag span {
      display: block;
      font-size: 13px;
      font-size: 1.3rem;
      white-space: nowrap;
      line-height: 13px;
      padding: 5px 15px;
      background: #999;
      color: #fff;
      margin: 2.5px 2.5px 2.5px 0; }
  #main .list-news a:not(:first-child), #sub .list-news a:not(:first-child) {
    margin-top: 20px; }
  #main .list-news a p, #sub .list-news a p {
    margin-left: 30px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }
@media (max-width: 768px) {
  #main .list-news a, #sub .list-news a {
    display: block;
    padding: 0 20px 0 0; }
    #main .list-news a::after, #sub .list-news a::after {
      right: 0; }
    #main .list-news a .tag, #sub .list-news a .tag {
      margin-left: 0;
      margin-top: 10px; }
      #main .list-news a .tag span, #sub .list-news a .tag span {
        margin: 0 5px 5px 0; }
        #main .list-news a .tag span:not(:first-child), #sub .list-news a .tag span:not(:first-child) {
          margin: 0 5px 5px 0; }
    #main .list-news a p, #sub .list-news a p {
      margin-left: 0; } }
#main article.contact section, #sub article.contact section {
  width: 50%;
  padding: 60px 20px;
  overflow: hidden; }
  #main article.contact section.box1, #sub article.contact section.box1 {
    background: #ece5da;
    position: relative;
    z-index: 1; }
    #main article.contact section.box1::before, #sub article.contact section.box1::before {
      content: '';
      display: inline-block;
      width: 342px;
      height: 110px;
      background-image: url("/img/top/contact-ttl.png");
      background-size: contain;
      position: absolute;
      top: 20px;
      left: 20px;
      z-index: -1; }
    #main article.contact section.box1 p.ttl, #sub article.contact section.box1 p.ttl {
      font-size: 18px;
      font-size: 1.8rem;
      line-height: 28px; }
    #main article.contact section.box1 .info, #sub article.contact section.box1 .info {
      font-size: 15px;
      font-size: 1.5rem;
      text-align: center;
      line-height: 26px; }
      #main article.contact section.box1 .info span::after, #sub article.contact section.box1 .info span::after {
        content: '\FF1A';
        display: inline-block; }
  #main article.contact section.box2, #sub article.contact section.box2 {
    background: rgba(236, 229, 218, 0.5);
    display: -webkit-box;
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    align-items: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    -webkit-box-align: center;
    flex-direction: column;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal; }
    #main article.contact section.box2 a, #sub article.contact section.box2 a {
      color: #fff;
      text-align: center;
      width: 320px;
      max-width: 100%;
      margin: 0 auto;
      font-weight: 500;
      padding: 20px;
      position: relative; }
      #main article.contact section.box2 a.btn-line, #sub article.contact section.box2 a.btn-line {
        background: #d1c0a5; }
      #main article.contact section.box2 a.btn-mail, #sub article.contact section.box2 a.btn-mail {
        background: #a6937c;
        margin-top: 40px; }
      #main article.contact section.box2 a::before, #sub article.contact section.box2 a::before {
        position: absolute;
        top: 0;
        left: 20px;
        bottom: 0;
        margin: auto 0; }
      #main article.contact section.box2 a::after, #sub article.contact section.box2 a::after {
        font-family: "Font Awesome 5 Free";
        content: '\f054';
        font-weight: 900;
        color: #fff;
        position: absolute;
        top: calc(50% - 6px);
        right: 20px; }
@media (max-width: 768px) {
  #main article.contact .ctn, #sub article.contact .ctn {
    display: block; }
  #main article.contact section, #sub article.contact section {
    width: 100%;
    padding: 30px 20px; }
    #main article.contact section.box1 .info, #sub article.contact section.box1 .info {
      margin-top: 0; }
      #main article.contact section.box1 .info span, #sub article.contact section.box1 .info span {
        display: block;
        max-width: 200px;
        background: #f7f4ef;
        padding: 3px 10px;
        margin: 10px auto 5px auto; }
        #main article.contact section.box1 .info span::after, #sub article.contact section.box1 .info span::after {
          content: none; }
    #main article.contact section.box2 a.btn-mail, #sub article.contact section.box2 a.btn-mail {
      margin-top: 20px; } }

/*--------------------------------
	news
--------------------------------*/
#main article.news {
  background: #f7f4ef;
  padding: 100px 0; }
  #main article.news .ttl {
    min-width: 240px;
    height: 240px;
    max-width: 100%;
    background: #dbd4cb;
    display: -webkit-box;
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    align-items: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    -webkit-box-align: center;
    flex-direction: column;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal; }
    #main article.news .ttl h2::before {
      content: '';
      display: block;
      width: 139px;
      height: 49px;
      margin: 0 auto;
      margin-bottom: 15px;
      background-image: url("/img/top/news-ttl.png");
      background-size: contain; }
  #main article.news .list-news {
    width: 800px;
    max-width: 100%; }
  #main article.news .button a {
    margin-left: auto; }
  @media (max-width: 768px) {
    #main article.news {
      padding: 50px 0; }
      #main article.news .wrap {
        display: block; }
      #main article.news .ttl {
        min-width: inherit;
        width: 200px;
        height: 200px;
        margin: 0 auto;
        margin-bottom: 30px; }
      #main article.news .list-news {
        width: 100%;
        margin-left: 0;
        margin-top: 20px; } }

/*--------------------------------
	greeting
--------------------------------*/
#main article.greeting {
  background: #dbd4cb;
  padding-bottom: 140px;
  position: relative;
  overflow: hidden; }
  #main article.greeting::before {
    content: '';
    width: 100%;
    height: 80px;
    background: #f7f4ef;
    position: absolute;
    top: 0;
    left: 0; }
  #main article.greeting .ctn {
    position: relative;
    z-index: 1; }
    #main article.greeting .ctn::before {
      content: '';
      display: block;
      width: 1821px;
      height: 199px;
      background-image: url("/img/top/greeting-ttl.png");
      background-size: contain;
      position: absolute;
      top: 140px;
      left: -320px;
      z-index: -1; }
  #main article.greeting .wrap {
    width: 510px;
    max-width: 100%;
    margin-top: 330px; }
    #main article.greeting .wrap .ttl {
      font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho Pro', 'MS PMincho', serif;
      font-size: 24px;
      font-size: 2.4rem;
      line-height: 30px; }
      #main article.greeting .wrap .ttl p {
        padding: 10px;
        text-align: center; }
      #main article.greeting .wrap .ttl p:first-child {
        background: #a6937c;
        color: #fff; }
      #main article.greeting .wrap .ttl p:last-child {
        background: #ece5da;
        margin-top: 10px; }
    #main article.greeting .wrap p.body {
      font-size: 15px;
      font-size: 1.5rem;
      letter-spacing: 0; }
  #main article.greeting figure {
    margin-top: -140px;
    margin-left: 120px; }
  @media (max-width: 768px) {
    #main article.greeting {
      padding-bottom: 50px; }
      #main article.greeting::before {
        height: 40px; }
      #main article.greeting .ctn {
        flex-direction: column;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        flex-direction: row-reverse;
        -ms-flex-direction: column-reverse;
        -webkit-box-direction: reverse;
        -webkit-flex-direction: column-reverse; }
      #main article.greeting .ctn::before {
        width: 645px;
        height: 69px;
        top: 50px;
        left: 20px;
        z-index: 1; }
      #main article.greeting figure {
        text-align: right;
        width: 80%;
        max-width: 420px;
        margin-top: 0;
        margin-left: auto;
        margin-right: -20px; }
      #main article.greeting .wrap {
        margin-top: -40px;
        position: relative;
        z-index: 1; }
        #main article.greeting .wrap p.body {
          text-align: left; }
          #main article.greeting .wrap p.body br {
            display: none; } }

/*--------------------------------
	menu
--------------------------------*/
#main article.menu {
  background: url("/img/top/esthe-bg.png") center center no-repeat;
  background-size: cover;
  overflow: hidden;
  position: relative;
  z-index: 1; }
  #main article.menu::before {
    content: '';
    display: block;
    width: 100%;
    height: 50px;
    background: #dbd4cb;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1; }
  #main article.menu .ctn2 img {
    margin-top: 50px;
    margin-left: -120px; }
  #main article.menu section:not(:first-child) {
    margin-top: 130px; }
  #main article.menu section h2 {
    font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho Pro', 'MS PMincho', serif;
    font-size: 32px;
    font-size: 3.2rem;
    margin-bottom: 50px; }
    #main article.menu section h2::before {
      content: '';
      display: block;
      background-size: contain;
      margin-bottom: -20px;
      margin-left: -30px; }
  #main article.menu section .box {
    width: 340px;
    max-width: 100%;
    margin-top: 160px; }
    #main article.menu section .box ol li {
      font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho Pro', 'MS PMincho', serif;
      font-size: 24px;
      font-size: 2.4rem;
      line-height: 36px; }
    #main article.menu section .box ol, #main article.menu section .box p {
      padding-left: 20px; }
    #main article.menu section .box .button a {
      margin-left: auto; }
  #main article.menu section.esthe figure {
    margin-left: -420px; }
  #main article.menu section.esthe ol {
    border-left: solid 3px #f19241; }
  #main article.menu section.esthe .box h2::before {
    width: 303px;
    height: 84px;
    background-image: url("/img/top/esthe-ttl.png"); }
  #main article.menu section.lesson figure {
    margin-right: -120px; }
  #main article.menu section.lesson ol {
    border-left: solid 3px #386093; }
  #main article.menu section.lesson .box h2::before {
    width: 294px;
    height: 84px;
    background-image: url("/img/top/lesson-ttl.png"); }
  #main article.menu section.cosme {
    position: relative;
    z-index: 2; }
    #main article.menu section.cosme::before, #main article.menu section.cosme::after {
      content: '';
      display: block;
      background-size: contain;
      position: absolute; }
    #main article.menu section.cosme::before {
      width: 100%;
      height: 390px;
      background: rgba(231, 239, 226, 0.4);
      left: 0;
      bottom: 0;
      z-index: -2; }
    #main article.menu section.cosme h2 {
      text-align: center; }
      #main article.menu section.cosme h2::before {
        width: 376px;
        height: 85px;
        background-image: url("/img/top/cosme-ttl.png");
        margin: 0 auto;
        margin-bottom: -20px; }
    #main article.menu section.cosme .wrap-slider .slider {
      width: 80%;
      margin-left: auto;
      border-left: solid 3px #8eb56e; }
      #main article.menu section.cosme .wrap-slider .slider img {
        width: 220px;
        height: 30vh;
        object-fit: cover;
        font-family: 'object-fit:cover'; }
  @media (max-width: 768px) {
    #main article.menu {
      padding-top: 50px; }
      #main article.menu::before {
        content: none; }
      #main article.menu section:not(:first-child) {
        margin-top: 60px; }
      #main article.menu section h2 {
        margin-bottom: 30px; }
      #main article.menu section .box {
        width: 100%;
        margin-top: 20px; }
        #main article.menu section .box ol li {
          font-size: 18px;
          font-size: 1.8rem; }
        #main article.menu section .box p {
          padding: 0; }
      #main article.menu section.esthe .ctn, #main article.menu section.lesson .ctn {
        display: block; }
      #main article.menu section.esthe figure, #main article.menu section.lesson figure {
        margin: 0; }
      #main article.menu section.cosme .wrap-slider .slider {
        width: 100%;
        border: none; }
        #main article.menu section.cosme .wrap-slider .slider img {
          width: 200px;
          height: 25vh; }
      #main article.menu .ctn2 img {
        margin-left: 0;
        margin-top: 50px; } }

/*--------------------------------
	contents
--------------------------------*/
#main article.contents {
  padding: 150px 0; }
  #main article.contents a {
    width: 320px;
    max-width: 100%;
    position: relative;
    z-index: 1; }
    #main article.contents a:not(:first-child) {
      margin-left: 40px; }
    #main article.contents a::after {
      content: "";
      display: inline-block;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 0 150px 150px;
      border-color: transparent transparent #cdc2b6 transparent;
      position: absolute;
      right: 0;
      bottom: 0;
      z-index: -1; }
    #main article.contents a.box1 .inner h2::before {
      width: 22px;
      height: 22px;
      background-image: url("/img/top/ic-glass.png"); }
    #main article.contents a.box2 .inner h2::before {
      width: 22px;
      height: 21px;
      background-image: url("/img/top/ic-img.png"); }
    #main article.contents a.box3 .inner h2::before {
      width: 22px;
      height: 18px;
      background-image: url("/img/top/ic-comment.png"); }
  #main article.contents figure {
    position: relative; }
    #main article.contents figure::before {
      content: '';
      display: block;
      width: 70px;
      height: 8px;
      background-image: url("/img/top/arrow-blk.png");
      background-size: contain;
      position: absolute;
      right: 40px;
      bottom: 20px; }
  #main article.contents .inner {
    padding: 20px; }
    #main article.contents .inner h2 {
      font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho Pro', 'MS PMincho', serif;
      font-size: 26px;
      font-size: 2.6rem;
      line-height: 30px;
      margin-bottom: 15px; }
      #main article.contents .inner h2::before {
        content: '';
        display: inline-block;
        background-size: contain;
        vertical-align: middle;
        margin-right: 10px; }
    #main article.contents .inner p {
      line-height: 26px; }
  @media (max-width: 768px) {
    #main article.contents {
      padding: 50px 0; }
      #main article.contents .ctn {
        display: block; }
      #main article.contents a {
        margin: 0 auto; }
        #main article.contents a:not(:first-child) {
          margin: 0 auto;
          margin-top: 30px; }
      #main article.contents .inner h2 {
        font-size: 20px;
        font-size: 2rem; } }

/*# sourceMappingURL=style.css.map */

.add_lesson_box .inbox{
   width: 100%;
}
.add_lesson_box p{
   text-align: center;
}
.add_lesson_box h3{
   text-align: center;
}

@media (max-width: 768px) {
  .add_lesson_box p{
     text-align: left;
  }
  .add_lesson_box h3{
     text-align: left;
  }
  }
