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

@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(.UU230628newcolor) img,
  :where(.UU230628newcolor) video,
  :where(.UU230628newcolor) svg {
    width: 100%;
    height: auto;
  }

  body {
    background-color: #E4E4E4;
  }

  .UU230628newcolor .sp_only {
    display: block;
  }

  .UU230628newcolor .pc_only {
    display: none;
  }

  .UU230628newcolor {
    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: #E4E4E4;
  }

/************** 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;
  }

  .sec_ttl_border.border_bottom {
    position: relative;
  }

  .sec_ttl_border.border_bottom::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    border-bottom: solid 1px #555555;
    animation: border_anime 1.8s ease forwards;
    animation-delay: 0.5s;
  }

  /* ===========### font ###=========== */
  .UU230628newcolor {
    --bernino-sans: "jaf-bernino-sans", sans-serif;
    font-style: normal;
    font-weight: 400;
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div p {
    background-color: var(--bernino-sans);
  }

  /************** slick（矢印がある場合） **************/
  .UU230628newcolor .slider_arrow picture {
    position: relative;
  }
  
  .UU230628newcolor .slider_arrow .prev-arrow {
    width: calc(23* (100vw/750));
    height: calc(45* (100vw/750));
    top: 38.8%;
    left: -11.2%;
    position: absolute;
    content: "";
    display: block;
    z-index: 9999;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url(../img/sp/prev.svg);
  }
  
  .UU230628newcolor .slider_arrow .next-arrow {
    width: calc(23* (100vw/750));
    height: calc(45* (100vw/750));
    top: 38.8%;
    right: -11.2%;
    position: absolute;
    content: "";
    display: block;
    z-index: 9999;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url(../img/sp/next.svg);
  }


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

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

  .UU230628newcolor {
    padding-bottom: 0;
  }

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

  /*** sec_text ***/
  .UU230628newcolor .sec_text {
    font-size: calc(24* (100vw /750));
    letter-spacing: 0.08em;
    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 ***/
  .UU230628newcolor h3 {
    letter-spacing: 0.1em;
    font-weight: 500;
  }

  .UU230628newcolor .sec_ttl {
    font-size: calc(32* (100vw /750));
  }

  .sec_ttl_border {
    padding-bottom: calc(28* (100vw /750));
  }

  /*** h4 ***/
  .UU230628newcolor h4 {
    margin: calc(66* (100vw /750)) 0 calc(52* (100vw /750));
    font-size: calc(32* (100vw /750));
    letter-spacing: 0.075em;
    line-height: 1.875;
    text-align: center;
    font-weight: 500;
    font-feature-settings: normal;
  }

  .UU230628newcolor h4 span:nth-of-type(1) {
    font-size: calc(38* (100vw /750));
    line-height: 1.6;
  }

  .UU230628newcolor h4 span:nth-of-type(2) {
    line-height: 2;
  }
  
/************** mv **************/
  .UU230628newcolor .mv {
    margin: 0 auto calc(124* (100vw /750));
  }

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

  .UU230628newcolor .mv h2 {
    text-align: center;
    font-weight: 500;
  }

  .UU230628newcolor .mv h2 p:first-child {
    margin-bottom: calc(28* (100vw /750));
    font-size: calc(30* (100vw /750));
    letter-spacing: 0.16em;
  }

  .UU230628newcolor .mv h2 p:last-child {
    font-size: calc(35.5* (100vw /750));
    letter-spacing: 0.085em;
    line-height: 2;
  }

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

/************** sec01 **************/
  .UU230628newcolor .sec01 {
    margin: 0 auto calc(127* (100vw /750));
  }

  .UU230628newcolor .sec01 h3 {
    margin-bottom: calc(60* (100vw /750));
  }

  /*** sec_box01 ***/
  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box01 {
    margin: 0 auto;
    width: calc(540* (100vw /750));
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div {
    margin: calc(80* (100vw /750)) 0 calc(44* (100vw /750));
    padding-left: calc(8* (100vw /750));
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0 calc(26* (100vw /750));
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div span {
    width: calc(80* (100vw /750));
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div p {
    font-size: calc(32* (100vw /750));
    letter-spacing: 0.1em;
  }

/************** sec02 **************/
  .UU230628newcolor .sec02 {
    margin: 0 auto calc(132* (100vw /750));
  }

  .UU230628newcolor .sec02 h3 {
    margin-bottom: calc(60* (100vw /750));
  }

  /*** sec_box01 ***/
  .UU230628newcolor .sec02 .sec_box01 {
    margin: 0 auto calc(132* (100vw /750));
  }

  /*** sec_box02 ***/
  .UU230628newcolor .sec02 .sec_box02 {
    margin: 0 auto calc(130* (100vw /750));
  }

  /*** sec_box03 ***/
  .UU230628newcolor .sec02 .sec_box03 {
    margin: 0 auto calc(135* (100vw /750));
    width: calc(540* (100vw /750));
  }
  
  .UU230628newcolor .sec02 .sec_box03 .sec_tax {
    margin-top: calc(18* (100vw /750));
    text-align: center;
  }

  /*** sec_box04 ***/
  .UU230628newcolor .sec02 .sec_box04 h4 {
    margin-bottom: calc(30* (100vw /750));
  }


/************** sec03 **************/
  .UU230628newcolor .sec03 {
    margin: 0 auto calc(140* (100vw /750));
  }

  .UU230628newcolor .sec03 h3 {
    margin-bottom: 0;
  }

  /*** sec_box01 ***/
  .UU230628newcolor .sec03 .sec_box01 {
    margin: 0 auto calc(126* (100vw /750));
  }

  .UU230628newcolor .sec03 .sec_box01 .flex_box {
    display: flex;
    align-items: center;
    flex-direction: column-reverse;
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_tax {
    margin-top: calc(20* (100vw /750));
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_sub_box02 h4 {
    margin-bottom: calc(62* (100vw /750));
  }

  /*** sec_box02 ***/
  .UU230628newcolor .sec03 .sec_box02 {
    margin: 0 auto calc(130* (100vw /750));
  }

  .UU230628newcolor .sec03 .sec_box02 .sec_sub_box01 {
    margin-bottom: calc(160* (100vw /750));
  }

  .UU230628newcolor .sec03 .sec_box02 .sec_sub_box02 .flex_box {
    margin-bottom: calc(68* (100vw /750));
  }

  /*** sec_box03 ***/
  .UU230628newcolor .sec03 .sec_box03 {
    margin: 0 auto calc(128* (100vw /750));
  }

  .UU230628newcolor .sec03 .sec_box03 .sec_sub_box01 h4 {
    margin-bottom: calc(30* (100vw /750));
  }

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



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

  .UU230628newcolor .pc_only {
    display: block;
  }

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

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


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

  .UU230628newcolor {
    padding-bottom: 12rem;
  }

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

  /*** sec_text ***/
  .UU230628newcolor .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 ***/
  .UU230628newcolor h3 {
    letter-spacing: 0.1em;
    font-weight: 500;
  }

  .UU230628newcolor .sec_ttl {
    font-size: 2rem;
  }

  .sec_ttl_border {
    padding-bottom: 1.4rem;
  }

  /*** h4 ***/
  .UU230628newcolor h4 {
    margin: 0 0 5rem;
    font-size: 1.8rem;
    letter-spacing: 0.075em;
    line-height: 1.55;
    text-align: center;
    font-weight: 500;
    font-feature-settings: normal;
  }

  .UU230628newcolor h4 span:nth-of-type(1) {
    font-size: 2.2rem;
    line-height: 1.45;
  }

  .UU230628newcolor h4 span:nth-of-type(2) {
    line-height: 1.77;
  }

/************** mv **************/
  .UU230628newcolor .mv {
    margin: 0 auto 6.7rem;
    width: 90rem;
  }

  .UU230628newcolor .mv_img {
    margin-bottom: 8.0rem;
    width: 100%;
  }

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

  .UU230628newcolor .mv h2 p:last-child {
    font-size: 2.3rem;
    letter-spacing: 0.125em;
    line-height: 2;
  }
  

/************** sec01 **************/
  .UU230628newcolor .sec01 {
    margin: 0 auto 12rem;
  }

  .UU230628newcolor .sec01 h3 {
    margin-bottom: 3rem;
  }

  /*** sec_box01 ***/
  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box01 {
    margin: 0;
    width: 30rem;
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 {
    margin: auto 0 0 ;
    width: 31.5rem;
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div {
    margin: 0 0 2.9rem;
    padding-left: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0 2rem;
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div span {
    width: 4.8rem;
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 div p {
    font-size: 2rem;
    letter-spacing: 0..85em;
  }

  .UU230628newcolor .sec01 .sec_box01 .sec_sub_box02 .sec_text {
    letter-spacing: 0.045em;
  }


/************** sec02 **************/
  .UU230628newcolor .sec02 {
    margin: 0 auto 11.5rem;
  }

  .UU230628newcolor .sec02 h3 {
    margin-bottom: 3rem;
  }

  /*** sec_box01 ***/
  .UU230628newcolor .sec02 .sec_box01 {
    margin: 0 auto 12rem;
  }

  .UU230628newcolor .sec02 .sec_box01 .sec_sub_box01 {
    width: 30rem;
  }
  
  .UU230628newcolor .sec02 .sec_box01 .sec_sub_box02 {
    margin: auto  0 -.5rem;
    width: 31.5rem;
  }

  .UU230628newcolor .sec02 .sec_box01 .sec_text {
    letter-spacing: 0.05em;
  }

  /*** sec_box02 ***/
  .UU230628newcolor .sec02 .sec_box02 {
    margin: 0 auto 11.45rem;
  }

  .UU230628newcolor .sec02 .sec_box02 h4 {
    margin: 4rem 0 3rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
  }

  .UU230628newcolor .sec02 .sec_box02 .sec_sub_box01 .item_img {
    width: 32rem;
  }

  /*** sec_box03 ***/
  .UU230628newcolor .sec02 .sec_box03 {
    margin: 0 auto 11.4rem;
    width: 100%;
  }

  .UU230628newcolor .sec02 .sec_box03 .item_img {
    width: 32rem;
  }

  .UU230628newcolor .sec02 .sec_box03 .sec_tax {
    margin-top: 1.4rem;
    text-align: center;
  }

  /*** sec_box04 ***/
  .UU230628newcolor .sec02 .sec_box04 h4 {
    margin: 4rem 0 3.2rem;
  }

  .UU230628newcolor .sec02 .sec_box04 .item_img {
    width: 32rem;
  }


/************** sec03 **************/
  .UU230628newcolor .sec03 {
    margin: 0 auto 12.0rem;
  }

  .UU230628newcolor .sec03 h3 {
    margin-bottom: 3rem;
  }

  /*** sec_box01 ***/
  .UU230628newcolor .sec03 .sec_box01 {
    margin: 0 auto 8.2rem;
  }

  .UU230628newcolor .sec03 .sec_box01 .flex_box {
    display: flex;
    align-items: center;
    flex-direction: row;
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_sub_box01 {
    width: 30rem;
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_sub_box02 {
    width: max-content;
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_tax {
    margin-top: 1.4rem;
    letter-spacing: 0.05em;
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_sub_box02 h4 {
    margin: 0 .7rem .4rem 0;
    font-size: 1.8rem;
    line-height: 2;
  }

  .UU230628newcolor .sec03 .sec_box01 .sec_sub_box02 h4 span:nth-of-type(1),
  .UU230628newcolor .sec03 .sec_box01 .sec_sub_box02 h4 span:nth-of-type(2) {
    font-size: 1.8rem;
    line-height: 2;
  }

  /*** sec_box02 ***/
  .UU230628newcolor .sec03 .sec_box02 {
    margin: 0 auto 11.3rem;
  }

  .UU230628newcolor .sec03 .sec_box02 .sec_sub_box01 {
    margin-bottom: 12.0rem;
  }

  .UU230628newcolor .sec03 .sec_box02 .sec_sub_box02 .flex_box {
    margin-bottom: 4.4rem;
  }

  .UU230628newcolor .sec03 .sec_box02 .sec_sub_box02 .flex_box .item_img {
    width: 32rem;
  }

  /*** sec_box03 ***/
  .UU230628newcolor .sec03 .sec_box03 {
    margin: 0 auto 11.6rem;
  }

  .UU230628newcolor .sec03 .sec_box03 .item_img {
    width: 32rem;
  }

  .UU230628newcolor .sec03 .sec_box03 .sec_sub_box01 h4 {
    margin: 4rem 0 3.2rem;
  }

/************** all_item **************/
  .UU230628newcolor .all_item {
    margin: 0 auto;
    width: 44.0rem;
  }

}

