@charset "UTF-8";

/* 全ての要素に適用 */

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: normal;
  line-break: strict;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
img, svg {
  max-width: 100%;
  height: auto;
  border-style: none;
}

/* 全てのボディに適用 */
body {
  -webkit-font-smoothing: antialiased;
  color: #333;
}

#wrap {
  position: relative;
  overflow: hidden;
  background-color: #fff0dd;
}

/* 全てのヘッダーに適用 */
#header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 2;
}

.l-header {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  background-color: #fff0dd;
}

.l-header__logo {
  width: 100%;
  height: 64px;
  display: block;
}

.l-hdr_logo {
  display: block;
  width: 192px;
  height: 64px;
  margin: 0 auto;
}

.l-hdr_logo img {
  width: 192px;
  height: 64px;
  object-fit: cover;
}

.l-hdr_logo__link {
  text-align: center;
}

.l-header__nav {
  display: block!important;
  height: 46px;
  background: #ffdcb1;
}

.l-hdr_nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  margin: 0 auto;
  width: 84vw;
  list-style-type: none;
}

.l-hdr_nav__item {
  list-style: none;
  position: relative;
  float: left;
  width: 14vw;
  height: 46px;
}

.l-hdr_nav__item a:hover {
  background-color: #ffac47;
}

.l-hdr_nav__item:first-of-type::before {
  position: absolute;
  display: block;
  content: "";
  top: 25%;
  left: 0px;
  width: 1px;
  height: 50%;
  background-color: #331C00;
}

.l-hdr_nav__item::after {
  position: absolute;
  display: block;
  content: "";
  top: 25%;
  right: 0px;
  width: 1px;
  height: 50%;
  background-color: #331C00;
}

.l-hdr_nav__link {
  font-size: 10px;
  display: flex;
  padding: 9px 2vw;
  color: #735240;
  text-align: center;
  text-decoration: none;
  justify-content: center;
  align-items: center;   
  height: 46px;
}

/* 全てのメインに適用 */
#main {
  width: 100%;
  background-color: #fff0dd;
  z-index: 1;
}

#page-contents {
  padding-top: 110px;
  position: relative;
}

.index-main {
  position: relative;
  width: 100%;
}

.index-main__slider {
  position: relative;
  width: 80vw;
  margin: 0 auto;
}

.index-main__slider img {
  width: 80%;
  margin: 0 10%;
}

.index-hexagon_imageslist {
  margin-right: 35vw;
}

.index-hexagon img {
  width: 15vw;
}

.index-hexagon_images {
  display: flex;
  justify-content: center;
}

.index-hexagon_images_middle {
  display: flex;
  justify-content: center;
}
.index-hexagon_images_middle img {
  margin: 0 7.5vw;
}

.c-section {
  margin: 30px 0;
  font-family: "American Typewriter", "ヒラギノ丸ゴ Pro W4", "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HG丸ｺﾞｼｯｸM-PRO", "HGMaruGothicMPRO", sans-serif;
}

.c-section_head {
  display: flex;
  align-items: center;
  padding: 0 30px;
  font-size: 4vw;
  font-weight: bold;
  color: #735240;
}

.c-section__body {
  margin-top: 24px;
  position: relative;
}

.c-inner-default-pc {
  width: 87.5vw;
  margin: 0 auto;
  box-sizing: content-box;
}

.index-news {
  position: relative;
}

.index-news__article:first-child {
  margin-top: 0;
}

.index-news__article {
  margin-top: 30px;
}

.index-news_article__date {
  color: grey;
  font-size: 2vw;
  font-weight: normal;
  margin: 0;
}

.index-news_article__ttl {
  color: #000;
  margin-top: 5px;
  font-size: 3vw;
  line-height: 1.6;
  font-weight: normal;
}

.c-section_btns {
  display: flex;
  align-items: center;
  justify-content: center;
}

.c-section_btns__btn {
  flex-basis: 240px;
  min-width: 240px;
  max-width: 240px;
}

.c-btn {
  height: 60px;
  border-radius: 30px;
  background-color: #F9DDB6;
  color: #735240;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  font-size: 15px;
}

.themes-main {
  position: relative;
  width: 100%;
  justify-content: center;
}

.about-main__inner {
  display: block;
  box-sizing: content-box;
  margin: 40px 0 80px;
  padding: 2px;
  width: 87.5vw;
  height: auto;
  min-height: 400px;
  background: radial-gradient(circle at top left, transparent 60px, #735240 0) top left,
    radial-gradient(circle at top right, transparent 60px, #735240 0) top right,
    radial-gradient(circle at bottom right, transparent 60px, #735240 0) bottom right,
    radial-gradient(circle at bottom left, transparent 60px, #735240 0) bottom left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
}

#borderused {
  display: block;
  box-sizing: content-box;
  margin: 0;
  padding: 50px;
  width: calc(87.5vw - 100px);
  height: calc(100% - 100px);
  ;
  background: radial-gradient(circle at top left, transparent 60px, #fff0dd 0) top left,
    radial-gradient(circle at top right, transparent 60px, #fff0dd 0) top right,
    radial-gradient(circle at bottom right, transparent 60px, #fff0dd 0) bottom right,
    radial-gradient(circle at bottom left, transparent 60px, #fff0dd 0) bottom left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
}

.about-main__ttl {
  margin: 0 auto;
  font-size: 40px;
  line-height: 1.15;
  font-family: "Alice";
  font-weight: lighter;
  color: #735240;
  border-bottom: 3px dashed;
  width: fit-content;
  padding-bottom: 5px;
}

.about-main__body {
  padding: 20px 20px;
}

.about-main__txt {
  margin-bottom: 50px;
  font-size: 12px;
  color: #735240;
}

.prof-main__txt {
  margin-bottom: 50px;
  color: #735240;
}

.prof-main__txt h1 {
  font-size: 15px;
}

.about-main__tips {
  color: #735240;
  font-size: 12px;
}

.about-main__tips a {
  color: #735240;
  font-size: 12px;
}

.blog-main {
  margin-top: 20px;
}

.blog-main__articles {
  width: 60vw;
  margin-bottom: 60px;
  color: #735240;
}

#blog-inner {
  width: 96vw;
  display: flex;
  justify-content: space-between;
  margin-bottom: 60px;
  padding: 0 2vw;
  margin: 0 auto
}

.blog-main__title {
  border: #735240 solid 1px;
  border-left: #735240 solid 10px;
  padding: 1vw;
  background: #fff0dd;
  font-size: 80%;
}

.article-ttl {
  font-size: 2vw;
  color: #735240;
  text-align: center;
}

.blog-main__date {
  padding-left: 3vw;
  display: flex;
  justify-content: flex-start;
  font-size: 2vw;
}

.blog-main__section {
  text-align: center;
  margin-bottom: 60px;
  color: #735240;
}

.blog-main__dates {
  width: 36vw;
  padding: 1vw;
  box-sizing: border-box;
}

.blog-main__txt {
  padding: 5px 3vw 30px;
  font-size: 2vw;
}

.blog-main__archive {
  font-size: 2vw;
  font-weight: bold;
  margin-bottom: 2.5vw;
}

.l-blg_nav__list {
  border-bottom: solid 1px #777;
  border-color: #AC826C;
  margin: 2.5vw;
  padding: 0;
}

.l-blg_nav__list li {
  list-style: none;
  font-size: 2vw;
  border-top: solid 1px #777;
  padding: 2vw 1vw;
  text-align: left;
}

.l-blg_nav__list li a {
  color: #735240;
}
#linkstips {
  font-size: 12px;
}

/* 全てのフッターに適用 */
#footer {
  position: relative;
  display: block;
  top: 0;
  left: 0;
  width: 100vw;
  height: auto;
  color: #331C00;
  background-color: #ffdcb1;
  font-size: 10px;
  overflow: hidden;
}

.l-footer {
  width: auto;
  margin: 2vw;
  background-color: #ffdcb1;
}

.l-footer__main {
  width: 100%;
  height: 24px;
}

.l-ftr_ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
}

.l-ftr_li:first-child {
  padding-left: 0;
  border: none;
}

.l-ftr_li {
  margin: 0;
  padding: 0 10px;
  border-left: 1px #331C00 solid;
}

.l-ftr_li a {
  color: #331C00;
  text-decoration: none;
}

.l-ftr_li a:hover {
  text-decoration: underline;
}

.l-footer__copyright {
  padding-top: 1vw;
  height: 24px;
}

.l-ftr_copyright__main {
  margin: 0;
}







/* widthが770px以上の場合 */
@media screen and (min-width: 769px) {

  /* 全てのボディに適用 */
  #wrap {
    min-width: 1200px;
    margin: 0 auto;
  }

  /* 全てのヘッダーに適用 */
  #header {
    min-width: 1200px;
    margin: 0 auto;
  }

  .l-header {
    height: 80px;
  }

  .l-header__logo {
    margin: 0 auto;
    width: 240px;
    height: 80px;
  }

  .l-hdr_logo {
    width: 240px;
    height: 80px;
  }

  .l-hdr_logo img {
    width: 240px;
    height: 80px;
    object-fit: cover;
  }

  .l-header__nav {
    height: 58px;
  }
  

  .l-hdr_nav__list {
    max-width: 720px;
    min-width: 720px;
  }

  .l-hdr_nav__item {
    width: 120px;
    height: auto;
  }

  .l-hdr_nav__link {
    display: block;
    font-size: 16px;
    padding: 17px 10px;
    height: auto;
  }

  /* 全てのメインに適用 */

  #page-contents {
    padding-top: 138px;
  }

  .index-main__slider {
    width: 80%;
  }
  .index-hexagon img {
    width: 216px;
  }
  
  .index-hexagon_images {
    display: flex;
    justify-content: center;
  }
  
  .index-hexagon_images_middle {
    display: flex;
    justify-content: center;
  }
  .index-hexagon_images_middle img {
    margin: 0 108px;
  }
  .c-section_head {
    display: flex;
    align-items: center;
    padding: 0 30px;
    font-size: 30px;
  }
  .index-news_article__date {
    font-size: 16px;
  }
  .index-news_article__ttl {
    font-size: 16px;
  }
  .c-inner-default-pc {
    width: 1050px;
    padding: 0 60px;
    margin: 0 auto;
    box-sizing: content-box;
  }
  #indexarticle {
    margin: 0;
  }
  .about-main__inner {
    margin: 40px 0 80px;
    padding: 2px;
    width: 1050px;
    height: auto;
    background: radial-gradient(circle at top left, transparent 60px, #735240 0) top left,
      radial-gradient(circle at top right, transparent 60px, #735240 0) top right,
      radial-gradient(circle at bottom right, transparent 60px, #735240 0) bottom right,
      radial-gradient(circle at bottom left, transparent 60px, #735240 0) bottom left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
  }
  
  #borderused {
    display: block;
    box-sizing: content-box;
    margin: 0;
    padding: 50px;
    width: calc(1050px - 100px);
    height: calc(100% - 100px);
    ;
    background: radial-gradient(circle at top left, transparent 60px, #fff0dd 0) top left,
      radial-gradient(circle at top right, transparent 60px, #fff0dd 0) top right,
      radial-gradient(circle at bottom right, transparent 60px, #fff0dd 0) bottom right,
      radial-gradient(circle at bottom left, transparent 60px, #fff0dd 0) bottom left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
  }

  .about-main__ttl {
    margin: 0;
    font-size: 60px;
  }
  .about-main__body {
    padding: 60px 100px;
  }
  .about-main__txt {
    margin-bottom: 50px;
    font-size: 16px;
  }
  .prof-main__txt h1 {
    font-size: 25px;
  }
  .about-main__tips {
    font-size: 16px;
  }
  .about-main__tips a {
    color: #735240;
    font-size: 16px;
  }
  #linkstips {
    font-size: 16px;
  }
  #blog-inner {
    width: 1200px;
    padding: 0 16px;
  }
  .blog-main__title {
    border-left: #735240 solid 10px;
    background: #fff0dd;
    font-size: 80%;
    padding: 10px;
  }
  .article-ttl {
    font-size: 24px;
    margin: 10px 0 15px 0;
    color: #735240;
    text-align: center;
  }
  .blog-main__date {
    padding-left: 40px;
    font-size: 0.875rem;
  }
  .blog-main__txt {
    padding: 10px 40px 30px 40px;
    font-size: 16px;
  }
  .blog-main__dates {
    width: 33%;
    padding: 20px;
    box-sizing: content-box;
  }
  .blog-main__articles {
    width: 65%;
  }
  .blog-main__archive {
    font-size: 1.125rem;
    font-weight: bold;
    margin-bottom: 30px;
  }
  .l-blg_nav__list {
    border-bottom: solid 1px #777;
    border-color: #AC826C;
    margin: 40px;
    padding: 0;
  }

  .l-blg_nav__list li {
    list-style: none;
    font-size: 0.875rem;
    border-top: solid 1px #777;
    padding: 20px;
    text-align: left;
  }
  /* 全てのフッターに適用 */
  #footer {
   font-size: 16px;
   width: 100%;
  }
  .l-footer {
    margin: 30px;
  }
  .l-ftr_li {
    padding: 0 20px;
  }
  .l-footer__copyright {
    padding-top: 20px;
  }
}