
/* ==========================================================================
初期設定
========================================================================== */

@media only screen and (min-width: 768px) and (max-width: 1600px) {
	html {
		font-size: calc(10 * (100vw / 1600)) !important;
	}
}
@media (max-width: 767px) {
	.lp * {
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
}
  html {
    font-size: 62.5%;
  }

  :where(.UU231107) img,
  :where(.UU231107) video,
  :where(.UU231107) svg {
    width: 100%;
    height: auto;
  }

  body {
    background-color: #E4E4E4;
  }

  .UU231107 .sp_only {
    display: block;
  }

  .UU231107 .pc_only {
    display: none;
  }

  .UU231107 {
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;;
    font-weight: normal;
    font-feature-settings: "palt";
    color: #555555;
    font-weight: 500;
    background-color: #E3E3E3;
  }

/************** js **************/
  /* fade */
  .fade {
    transition-property: opacity, transform;
    transition-duration: 1.5s;
    opacity: 0;
    transform: translateY(1.5rem);
  }

  .fade.onView {
    opacity: 1;
    transform: translateY(0);
  }

  /* border */
  @keyframes border_anime {
    0%{
      width: 0%;
    }
    100%{
      width: 100%;
    }
  }

  .sec_ttl_border {
    position: relative;
    border-bottom: solid 1px #989898;
  }

  .sec_ttl_border.border_bottom {
    position: relative;
  }


  /* ===========### font ###=========== */

  .UU231107 h2 p,
  .UU231107 .sec01 h3 {
    font-family: "jaf-bernina-sans", sans-serif;
    font-weight: 400;
    font-style: normal;
  }


/* ==========================================================================
編集エリア
========================================================================== */

/************** common **************/
  .lp {
    padding-bottom: calc(68* (100vw /750));
  }

  .UU231107 {
    padding-bottom: 0;
    isolation: isolate;
  }

  .UU231107 .flex_box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row;
  }

  .UU231107 .flex_box_inverse {
    flex-direction: row-reverse;
  }

  /*** sec ***/
  .UU231107 .sec {
    width: calc(660* (100vw /750));
  }

  /*** sec_text ***/
  .UU231107 .sec_text {
    font-size: calc(24* (100vw /750));
    letter-spacing: 0.075em;
    line-height: 2;
    font-weight: 500;
    text-align: justify;
    color: #555;
  }

  /*** sec_tax ***/
  .sec_tax {
    margin-top: calc(46* (100vw /750));
    font-size: calc(20* (100vw /750));
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 2;
  }

  /*** h3 ***/
  .UU231107 h3 {
    letter-spacing: 0.1em;
    font-weight: 500;
  }

  .UU231107 .sec_ttl {
    font-size: calc(30* (100vw /750));
    color: #989898;
  }

  /* .sec_ttl_border {
    padding-bottom: calc(28* (100vw /750));
  } */
  
/************** mv **************/
  .UU231107 .mv {
    margin: 0 auto calc(129* (100vw /750));
  }

  .UU231107 .mv_img {
    margin-bottom: calc(83* (100vw /750));
    width: 100%;
  }

  .UU231107 .mv h2 {
    margin-bottom: calc(50* (100vw /750));
    text-align: center;
    font-weight: 500;
  }

  .UU231107 .mv h2 p:first-child {
    margin-left: 0.16em;
    margin-bottom: calc(44* (100vw /750));
    font-size: calc(29* (100vw /750));
    letter-spacing: 0.16em;
  }

  .UU231107 .mv h2 p:last-child {
    margin: 0 auto;
    padding-bottom: calc(10* (100vw /750));
    width: max-content;
    font-size: calc(39* (100vw /750));
    letter-spacing: 0.16em;
    line-height: 1;
    font-weight: 400;
    border-bottom: 2px solid #555;
  }

  .UU231107 .mv_text {
    font-size: calc(24* (100vw /750));
    letter-spacing: 0.1em;
    line-height: 2;
    text-align: center;
    font-weight: 500;
  }

/************** sec01 **************/
  .UU231107 .sec01 {
    margin: 0 auto calc(133* (100vw /750));
    mix-blend-mode: darken;
  }

  .UU231107 .sec01 h3 {
    margin: 0 auto calc(38* (100vw /750));
    width: max-content;
    padding: 0 calc(8* (100vw /750)) calc(17* (100vw /750));
  }

  /*** sec_box01 ***/
  .UU231107 .sec01 .sec_box01 {
    margin: 0 auto;
    width: calc(670* (100vw /750));
    gap: calc(60* (100vw /750)) 0;
    align-items: end;
  }

  .UU231107 .sec01 .sec_box01 li a {
    width: calc(320* (100vw /750));
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: calc(15* (100vw /750)) 0;
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(2),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(3),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(4) {
    width: calc(315* (100vw /750));
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(5),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(6) {
    margin-top: calc(12* (100vw /750));
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(1),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(2) {
    margin-top: calc(-15* (100vw /750));
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(1) {
    margin-right: calc(10* (100vw /750));
    width: calc(310* (100vw /750));
  }

  .UU231107 .sec01 .sec_box01 li p {
    font-size: calc(26* (100vw /750));
    letter-spacing: 0.125em;
    color: #555555;
    width: max-content;
    text-align: center;
    line-height: 2;
  }

/************** all_item **************/
  .UU231107 .all_item {
    margin: 0 auto;
    width: calc(540* (100vw /750));
  }

/************** last_img **************/
  .UU231107 .last_img {
    margin: 0 auto;
  }


  
/* ===============================================### 
PC用デザイン
###=============================================== */
@media screen and (min-width:768px) {
  .UU231107 .sp_only {
    display: none;
  }

  .UU231107 .pc_only {
    display: block;
  }


/************** common **************/
  .lp {
    padding: 0;
  }

  .UU231107 {
    margin: 0 auto;
    padding-bottom: 12rem;
    width: 90rem;
  }

  /*** sec ***/
  .UU231107 .sec {
    width: 66.0rem;
  }

  /*** sec_text ***/
  .UU231107 .sec_text {
    margin: -.6rem 0;
    font-size: 1.4rem;
    letter-spacing: 0.085em;
  }

  /*** sec_tax ***/
  .sec_tax {
    margin-top: 3.2rem;
    font-size: 1.2rem;
  }

  /*** h3 ***/
  .UU231107 h3 {
    letter-spacing: 0.1em;
    font-weight: 500;
  }

  .UU231107 .sec_ttl {
    font-size: 1.6rem;
    color: #989898;
  }

  /* .sec_ttl_border {
    padding-bottom: 2.8rem;
  } */
  
/************** mv **************/
  .UU231107 .mv {
    margin: 0 auto 11.3rem;
  }

  .UU231107 .mv_img {
    margin-bottom: 8.1rem;
    width: 100%;
  }

  .UU231107 .mv h2 {
    margin-bottom: 3.7rem;
    text-align: center;
    font-weight: 500;
  }

  .UU231107 .mv h2 p:first-child {
    margin-left: 0.16em;
    margin-bottom: 2.5rem;
    font-size: 1.8rem;
    letter-spacing: 0.16em;
  }

  .UU231107 .mv h2 p:last-child {
    margin: 0 auto;
    padding-bottom: .6rem;
    width: max-content;
    font-size: 2.5rem;
    letter-spacing: 0.14em;
    line-height: 1;
    font-weight: 400;
    border-bottom: 2px solid #555;
  }

  .UU231107 .mv_text {
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    line-height: 2;
    text-align: center;
    font-weight: 500;
  }

/************** sec01 **************/
  .UU231107 .sec01 {
    margin: 0 auto 11.7rem;
    mix-blend-mode: darken;
  }

  .UU231107 .sec01 h3 {
    margin: 0 auto 2.8rem;
    width: max-content;
    padding: 0 .5rem 1.1rem;
  }

  /*** sec_box01 ***/
  .UU231107 .sec01 .sec_box01 {
    margin: 0 auto;
    width: 44rem;
    gap: 3rem 0;
    align-items: end;
  }

  .UU231107 .sec01 .sec_box01 li a {
    width: 19rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .7rem 0;
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(2),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(3),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(4) {
    margin-top: .5rem;
    width: 19rem;
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(5),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(6) {
    margin-top: 1rem;
    width: 20rem;
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(5) a,
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(6) a {
    width: 20rem;
  }


  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(1),
  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(2) {
    margin-top: 0;
  }

  .UU231107 .sec01 .sec_box01 li:nth-last-of-type(1) {
    margin-right: 0;
    width: 19rem;
  }

  .UU231107 .sec01 .sec_box01 li p {
    font-size: 1.4rem;
    letter-spacing: 0.125em;
    color: #555555;
    width: max-content;
    text-align: center;
    line-height: 2;
  }

/************** all_item **************/
  .UU231107 .all_item {
    margin: 0 auto;
    width: 44rem;
  }

}

