@charset "utf-8";

html { 
  scroll-behavior: smooth; 
}
#globalMain, #globalContents{ overflow: visible; }
#globalWrapper { box-sizing: border-box; }


/* Variables & Setup -------------------- */
:root {
  scroll-padding-top: 150px;
}

.allparts-container-wrapper {
  container-type: inline-size;
  container-name: allparts-container-wrapper;
}

.allparts-container * { box-sizing: border-box; }

:root .allparts-container {
  --color-black: #000;
  --color-gray: #777;
  --color-white: #fff; 
   
  --color-primary: #EDE7E1;
  --color-anchor: #C6BFB7;
  --color-secondary: #FEF565 ;
  --color-accent: #c00;
  /* --color-darkbrown: #66492F; */
  /* --color-brown: #7A5A3A; */
  
  /* --color-subaccent: ; */

  --pdin-common: 1.5rem;
  --hover-opacity: 0.7;
  --transitionall: all 0.3s ease;
  /* --gen-boxshadow: 5px 5px .3rem #00000011; */
}


/* common -------------------- */ 
.allparts-container {
  font-family: "Zen Kaku Gothic New", sans-serif;
  max-width: 1420px;
  margin-inline: auto;
  background-color: var(--color-primary);
  color: var(--color-black);
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 0.05em;
@container allparts-container-wrapper (max-width: 768px) {
  font-size: 14px;
}
@container allparts-container-wrapper (max-width: 350px) {
  font-size: 13px;
}
  & section{
    padding-block: 3rem;
  }

  & .inner{
    max-width: 1200px;
    margin-inline: auto;
    padding-inline: var(--pdin-common);
  }

  & figure{ 
    text-align: center;
    overflow: hidden;
  }

  & img{
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
  }

  & a{
    color: inherit;
    text-decoration: none;
  }

  & span{
    color: inherit;
    font-weight: inherit;
  }

  & hr{
    margin-block: .5rem .25rem;
    height: 1px;
    border: none;
    background-color: var(--color-anchor);
  }
}


/* PC用
#globalContents  */

/* スマホ用
#wrapper */

@container allparts-container-wrapper (max-width: 【幅】px) {
  
}


/* element -------------------- */
/* TOPページの見出しはindex側に記載中（様子でglobalに昇格） */

/* CTAボタン */
.allparts-container .ui-btncta{
	display: block;
  width: fit-content;
  margin-inline: auto;
  padding-block: .25rem .4rem;
  padding-inline: 1.5rem;
  border-radius: 100vmax;
  background-color: var(--color-black);
  color: var(--color-white);
  text-align: center;
  &:hover{
    opacity: var(--hover-opacity);
  }

}

/* 文字リンク */
.allparts-container .el-tlink{
  display: inline-block;
  padding-inline: .3em;
  border-radius: .25em;
  color: var(--color-link);
  font-weight: bold;

  &:hover{
    background-color: var(--color-link);
    color: var(--color-white);
  }
}

/* 視覚的に非表示 */
.allparts-container .el-visually-hidden{
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* img：祖先要素ホバーで拡大 */
.allparts-container .fx-expansion{
 
  & img {
    transition: var(--transitionall);
  }

  &:hover img {
    transform: scale(1.03);
  }
} 

/* テキスト：ホバーでスペース広 */
.allparts-container .fx-widespacing{
  transition: var(--transitionall);
  &:hover{
    letter-spacing: 0.1em;
  }
}

/* 文章 */
.allparts-container .paragraph{
  line-height: 1.7;
  /* text-align: justify; */

  & + .paragraph{
    margin-top: .5rem;
  }
}

/* 2行以上で... */
.allparts-container .textellipsis-2{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
  line-clamp: 2;
	-webkit-line-clamp: 2;
}

/* 3行以上で... */
.allparts-container .textellipsis-3{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
  line-clamp: 3;
	-webkit-line-clamp: 3;
}

/* 動画のabsoアイコン（aにクラス名つける）*/
.allparts-container .icon-movie{
	display: block;
	width: 100%;
	position: relative;

  &::after { position: absolute; display: block;	content: ""; width: 100%; height: 0; padding-top: 56.25%;top: 0;	left: 0;	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="100%" version="1.1" viewBox="0 0 68 48" width="100%" fill="%23ffffff"><path d="M66.52,7.74c-0.78-2.93-2.49-5.41-5.42-6.19C55.79,.13,34,0,34,0S12.21,.13,6.9,1.55 C3.97,2.33,2.27,4.81,1.48,7.74C0.06,13.05,0,24,0,24s0.06,10.95,1.48,16.26c0.78,2.93,2.49,5.41,5.42,6.19 C12.21,47.87,34,48,34,48s21.79-0.13,27.1-1.55c2.93-0.78,4.64-3.26,5.42-6.19C67.94,34.95,68,24,68,24S67.94,13.05,66.52,7.74z" fill="%23f00"></path><path d="M 45,24 27,14 27,34" fill="%23fff"></path></svg>') no-repeat center center;	background-size: 20%; }
}


/* library ---------------------------------------- */
/* swiper -------------------- */
:root .allparts-container{
  --swiper-pagination-color:#000;
  --swiper-pagination-bullet-size: 1rem;
  --swiper-navigation-size: 4.5rem;
}

.allparts-container .swiper-button-next,
.allparts-container .swiper-button-prev {
  top: 35%;
}

.allparts-container .swiper-button-next:after,
.allparts-container .swiper-button-prev:after {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  background: url("../img/assets/chevron-circle.png") no-repeat center / contain;
}

.allparts-container .swiper-button-prev:after{
  transform: rotate(180deg);
}

/* gLightbox -------------------- */
:root {
  --plyr-color-main: #ff0000;
}

.goverlay {
	background: rgba(0, 0, 0, .7);
}


/* common parts ==================== */
/* 【上部固定コンテンツ】-------------------- */
.allparts-container .ui-fixtopconntents{
  position: sticky;
  top: 63px;
  z-index: 3;
}
/* おしらせバー */
.allparts-container .ui-infobar{
  background-color: var(--color-secondary);
  & > a{
    display: flex;
    justify-content: center;
    align-items: center;
    padding-block: .3rem .25rem;
    padding-inline: 5px;
    &:hover{
      letter-spacing: 0.1em;
    }
  }
}

/* 特集ページ内ヘッダー */
.allparts-container .ui-pageheader{
  padding-block: .5rem;
  padding-inline: var(--pdin-common);
  background-color: var(--color-black);
  color: var(--color-white);
  & > ul{
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 1.5rem;
    width: fit-content;
    margin-left: auto;
    & a:hover{
      font-weight: bold;
    }
  }
@container allparts-container-wrapper (max-width: 600px) {
  padding-block: 1rem;
  & > ul{
    margin-inline: auto;
  }
}
@container allparts-container-wrapper (max-width: 450px) {
  & > ul{
    font-size: 85%;
    gap: .5rem 1rem;
  }
}
}






/* 背景画像のショートハンド */
.test{
  background: url("画像パス") no-repeat center / contain;
}