@charset "UTF-8";
/*=============================================================

	Date: 2026-01-21
	CSS Document ： el:ment×アトリエシムラ

=============================================================*/
/*
<div class="dummy">
    <img src="/liveincomfort/list/uraboapants/images/uraboa_pc02.png?$staticlink$" alt="ダミー" width="" height="" fetchpriority="high"> 
</div> 
*/
.dummy {
  position: absolute;
  top: 982px;
  left: 0;
  width: 100%;
  opacity: 0.3;
  pointer-events: none;
  display: flex;
  justify-content: center;
  /* align-items: center; */
  text-align: center;
  z-index: 10000;
  filter: grayscale(90%);
}
.dummy img {
  display: block;
  margin: 0 auto;
  /* max-width: max-content; */
}
/* ---------------------------------

キーカラー指定
color: var(--theme-color);	
font-family: var(--font-syuei-M);
font-family: var(--font-syuei-B);
--------------------------------- */ :root {
  --theme-color: #000000; /* キーカラー指定 */
  --bg-color: #ded8ce; /* 背景カラー指定 */
  --font-syuei-M: "秀英明朝 M", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  --font-syuei-B: "秀英明朝 B", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
/*------------------------------------
仮想LP用ベース
------------------------------------*/
.fca_cat-hero, .sr_page-shopping-result__free {
  overflow: visible !important;
}
.fca_cat-hero .sr_page-shopping-result__free .fca_container__in {
  max-width: 100%;
}
.fca_cat-hero .sr_page-shopping-result__free .fca_container {
  padding: 0;
}
.fca_page-shop-category__body {
  margin-top: 0;
}
/*==================================

ルビ

==================================*/
[data-ruby] {
  position: relative;
  margin-top: 0.2em;
  display: inline-block;
}
[data-ruby]::before {
  content: attr(data-ruby);
  position: absolute;
  text-align: center;
  top: -0.5em;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 0.3em;
  letter-spacing: 0.0em;
  white-space: nowrap;
}
/*------------------------------------

ベース

------------------------------------*/
.pc {
  display: block;
}
.sp {
  display: none;
}
.bold_ct {
  font-weight: bold;
}
#wrapper {
  width: 100%;
  color: #333333;
  line-height: 1.7;
  letter-spacing: 0.04em;
  text-align: justify;
  /* background: #FFF; */
  opacity: 0;
  animation: fadeIn_ct 1.5s 0.0s both;
  position: relative;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "chws"1;
  letter-spacing: 0.05em;
}
#wrapper p {
  font-family: var(--font-syuei-M);
}
#wrapper-inner {
  margin: 0 auto;
}
#wrapper img {
  height: auto;
  max-width: 100%;
  width: 100%;
}
/* hover */
#wrapper a:hover {
  text-decoration: none;
}
#wrapper a {
    transition: all 0.3s;
  }
@media (hover: hover) {
  #wrapper a:hover {
    opacity: 0.8;
  }
}

@media (hover: none) {
	#wrapper a:active {
    opacity: 0.7;
  }
}

/*------------------------------------

タイトル

------------------------------------*/
.fv-wrap {
  container-type: inline-size;
}
/* FV画像 */
#fv-image {
  position: sticky;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
#fv-image img {}
#fv-image .fv-pc {
  background-image: url(../images/fv_image01_pc.webp);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 100%;
  margin: 0 auto;
  height: 100vh;
  display: block;
}
#fv-image .fv-sp {
  display: none;
}
/* テキスト */
#lead-wrap {
  position: relative;
  margin: -67vh auto 0;
  width: 82%;
  padding-bottom: 5em;
}
/* タイトル */
#title {
  width: 63%;
}
#title .title-sub {
  display: block;
  width: 81%;
  position: relative;
}
#title .title-sub::after {
  display: block;
  width: 0%;
  animation: title-line 3.8s 0.5s both;
  height: 1px;
  content: '';
  background: #FFF;
  position: absolute;
  top: 98%;
  left: -70%;
  opacity: 0.5;
}
@keyframes title-line {
  0% {
    width: 0%;
  }
  100% {
    width: 170%;
  }
}
#title .title-sub source {}
#title .title-sub img {
  animation: blur_ct 1.8s 1.5s both;
  will-change: filter;
}
#title .title-main {
  display: block;
  margin: 2.7em 0;
  animation: blur_ct 1.8s 1.5s both;
  opacity: 0;
}
#title .title-main source {}
#title .title-main img {}
#lead {
  opacity: 0;
  color: #FFF;
  margin: 27cqw 3em 3em;
  font-size: 120%;
  line-height: 2;
  /* letter-spacing: 0.05em; */
  white-space: nowrap;
  font-family: var(--font-syuei-M);
  will-change: filter;
}
#lead.active {
  animation: blur_ct 1.8s 0s both;
}
#lead span {
  letter-spacing: 0;
}
#lead-wrap .icon-60th {
  width: 3.5em;
  margin-left: 3.5em;
}
/*------------------------------------

PC固定タイトル

------------------------------------*/
#contents-wrapper .fixd-title {
  position: sticky;
  top: 0;
  left: 0; /* display: flex; */ /* justify-content: center; */ /* align-items: flex-start; */ z-index: 5;
  width: 0;
  height: 100vh;
}
#contents-wrapper .fixd-title::after {
  display: block;
  width: 1.2em;
  height: 100vh;
  content: '';
  background-image: url(../images/fixd_title.svg);
  background-repeat: no-repeat;
  background-position: center bottom 5%;
  background-size: contain;
  position: absolute;
  top: 0;
  left: 1em;
}

@media screen and (min-width: 1170px) {
#contents-wrapper .fixd-title{
    left: calc(50vw - (1170px/2));
}
}
/*------------------------------------

メインコンテンツ

------------------------------------*/
#contents-wrapper {
  /* container-type: inline-size; */
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
#contents-main {
  font-size: 120%;
  width: 100%;
  overflow: hidden;
}
.contents-inner {
  /* container-type: inline-size; */
  max-width: 640px;
  margin: 0 auto;
  width: 100%;
  /* overflow: hidden; */
}
.contents-box {
  margin: 4.9em 0 5.6em;
}
.main-midashi {
  font-family: var(--font-syuei-M);
  font-size: 152%;
  /* display: flex; */
  /* justify-content: flex-start; */
  /* align-items: center; */
  position: relative;
  width: 90%;
  margin: 0 0 1.2em 5%;
  line-height: 1.45;
  padding-left: 1.0em;
  letter-spacing: 0.0em;
  max-width: 640px;
}
.main-midashi::before {
  display: block;
  width: 1px;
  height: 100%;
  background: #000;
  content: '';
  top: 0;
  left: 0;
  position: absolute;
}
.yakumono {
  text-indent: -0.5em;
  display: inline-block;
}
.open-btn {
  background: #FFF;
  width: 1.3em;
  display: inline-block;
  aspect-ratio: 1;
  border-radius: 50%;
  position: relative;
  transition: all 0.3s;
}
.open-btn::after {
  display: block;
  width: 1px;
  height: 60%;
  content: '';
  background: #000;
  position: absolute;
  top: 20%;
  left: 48%;
  opacity: 0.5;
  transition: all 0.8s;
}
.open-btn::before {
  display: block;
  width: 60%;
  height: 1px;
  content: '';
  background: #000;
  position: absolute;
  top: 48%;
  left: 20%;
  opacity: 0.5;
}
.link-image {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2%;
}
.link-image a {
  width: 38%;
}
.link-image a img {}
.link-text {
  width: max-content;
  margin: 1.5em auto;
}
.link-text a {
  font-family: var(--font-syuei-M);
  display: block;
}
.link-text a .item-name {}
.link-text a .item-price {
  display: block;
}
.link-text a .link-btn {
  color: #FFF;
  background: #000;
  padding: 0.3em 1.5em;
  letter-spacing: 0.15em;
  margin: 0.4em 0 0;
  line-height: 1;
  display: block;
  width: max-content;
}
@media (hover: hover) {
  #item02 .earcuff-detail .earcuff-box .earcuff-title:hover .open-btn, #item01 .dress-introduction .dress-title:hover .open-btn, .overlay-close:hover {
    transform: scale(1.2);
  }
}
/*------------------------------------

アイテム詳細

------------------------------------*/
#item-wrap {}
/* == ワンピース == */
#item01 .main-midashi {}
#item01 .dress-introduction {
  position: relative;
}
#item01 .dress-introduction .dress-title {
  line-height: 1.3;
  display: inline-block;
  margin: 0;
  text-align: start;
  white-space: nowrap;
  letter-spacing: .05em;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-feature-settings: 'vert'on;
  font-family: var(--font-syuei-M);
  font-size: 134%;
  position: absolute;
  top: 2.0em;
  left: 8%;
  z-index: 1;
  cursor: pointer;
}
#item01 .dress-introduction .dress-title span {
  margin-top: 0.6em;
}
#item01 .dress-introduction .dress-bg {
  overflow: hidden;
}
#item01 .dress-introduction .dress-bg img {}
#item01 .dress-introduction .dress-main {
  position: absolute;
  top: 10%;
  left: 10%;
  width: 80%;
  background: #FFF;
}
#item01 .dress-introduction .dress-main a{
    display: block;
    /* opacity: 1; */
}
#item01 .dress-introduction .dress-main img.dress-model {}
#item01 .dress-introduction .dress-text {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  line-height: 1.9;
  padding: 2.3em 3.0em 2em 6.0em;
  background: rgba(255, 255, 255, 0.8);
  transition: opacity 0.8s;
  pointer-events: none;
}
#item01 .dress-introduction .dress-text p {}
#item01 .dress-sub {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 4%;
  margin: 2em 0 5em;
}
#item01 .dress-sub .sub-item {
  width: 43%;
}
#item01 .dress-sub .sub-item:first-child {
  margin-top: 2em;
}
#item01 .dress-sub .sub-item img {}
#item01 .dress-detail {}
#item01 .dress-detail .detail-box {
  width: 90%;
  margin: 0 0 4.5em;
}
#item01 .dress-detail .detail-box img {}
#item01 .dress-detail .detail-box p {
  /* width: 90%; */
  margin: 1em 0 0 5%;
}
#item01 .dress-detail .detail-box p span {}
#item01 .dress-detail .detail-box:nth-child(2n) {
  margin-left: 10%;
}
#item01 .dress-detail .detail-box:nth-child(2n) p {
  margin: 1em 5% 0 0;
}
/*------------------------------------

詳細オープン

------------------------------------*/
.close-item .open-btn {}
.close-item .open-btn::after {}
.close-item .dress-text {
  opacity: 0;
}
.open-item .open-btn {}
.open-item .open-btn::after {
  transform: rotate(90deg);
  opacity: 0;
}
#item01 .dress-introduction .open-item .dress-text {
  opacity: 1;
  pointer-events: auto;
}
/*------------------------------------

イヤカフ

------------------------------------*/
#item02 {}
/* = 横スクロールエリア = */
#item02 .horizontal-wrap {
  position: relative;
  /* height: 100vh; */
  display: flex;
  justify-content: center;
  align-items: flex-start;
  /* flex-wrap: wrap; */
  flex-direction: column;
  container-type: inline-size;
}
/* 見出し */
#item02 .main-midashi {
  font-size: 145%;
  margin-top: 1em;
  /* margin-left: 5%; */
}
#item02 .horizontal-wrap .horizontal-box {
  display: flex;
  /* height: 100%; */
  align-items: center;
  gap: 5cqw;
  padding: 0 5cqw;
}
#item02 .horizontal-wrap .horizontal-box .panel {
  width: 90cqw;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  max-width: 55vh;
}
#item02 .horizontal-wrap .horizontal-box img {
  width: 100%;
  max-width: none;
}
/* = 横スクロールエリア = */
/* 詳細 */
#item02 .earcuff-detail {
  width: 90%;
  margin: 2em auto 0;
}
/*  */
#item02 .earcuff-detail .earcuff-box {
  position: relative;
  opacity: 0;
}
#item02 .earcuff-detail .earcuff-box .earcuff-main {}
#item02 .earcuff-detail .earcuff-box .earcuff-main a{
  display:block;
}
#item02 .earcuff-detail .earcuff-box .earcuff-main img {}
#item02 .earcuff-title {
  font-family: var(--font-syuei-M);
  position: absolute;
  font-size: 94%;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.3em;
  opacity: 0;
}
#item02 .earcuff-title span.open-btn {
  width: 1em;
}
#item02 .earcuff-detail .earcuff-box .earcuff-title.earcuff01 {
  top: 59%;
  left: 5%;
}
#item02 .earcuff-detail .earcuff-box .earcuff-title.earcuff02 {
  top: 78%;
  left: 54%;
}
#item02 .earcuff-detail .earcuff-box .earcuff-title.earcuff03 {
  top: 17%;
  left: 69%;
}
#item02 .earcuff-detail .earcuff-box.active {
  animation: fadeInBlur_ct 1.2s 0.0s both;
}
#item02 .earcuff-detail .earcuff-box.active .earcuff-title {
  animation: fadeInBlur_ct 1.2s 0.5s both;
}
#item02 .earcuff-detail .earcuff-box.active .earcuff-title.earcuff02 {
  animation-delay: 0.7s;
}
#item02 .earcuff-detail .earcuff-box.active .earcuff-title.earcuff03 {
  animation-delay: 0.9s;
}
/* オーバーレイ表示 */
#item02 .earcuff-detail .earcuff-box .overlay-item {
  position: absolute;
  top: 0;
  left: 0;
  /* display: none; */
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 1);
  z-index: 1;
  border: 1px solid #ccc;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.8s;
}
#item02 .earcuff-detail .earcuff-box .overlay-item.open-item {
  opacity: 1;
  pointer-events: auto;
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  height: 100%;
  gap: 4%;
  width: 95%;
  margin: 0 auto;
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner img {
  width: 36%;
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner .overlay-text {
  margin-right: 5%;
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner .overlay-text .overlay-title {
  font-size: 135%;
  font-family: var(--font-syuei-M);
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner .overlay-text .material {
  font-family: var(--font-syuei-M);
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner .overlay-text .material span {}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-inner .overlay-text p {
  margin-top: 0.5em;
  font-size: 85%;
  letter-spacing: 0;
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-close {
  background: #FFF;
  width: 1.5em;
  display: inline-block;
  aspect-ratio: 1;
  border-radius: 50%;
  position: absolute;
  transition: all 0.3s;
  top: 0.9em;
  right: 5%;
  cursor: pointer;
}
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-close::after {
  display: block;
  width: 100%;
  height: 1px;
  content: '';
  background: #000;
  position: absolute;
  top: 48%;
  left: 0;
  opacity: 1;
  transition: all 0.8s;
}
#item02 .earcuff-detail > p {
  margin: 1em 0 2em;
}
#item02 .link-text {}
#item02 .link-text a {}
#item02 .link-text a .item-name {}
#item02 .link-text a .item-price {}
#item02 .link-text a .link-btn {}
/* ミモザ */
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-item.earcuff01 {}
/* 桜 */
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-item.earcuff02 {}
/* ヒヤシンス */
#item02 .earcuff-detail .earcuff-box .overlay-item .overlay-item.earcuff03 {}
/*------------------------------------

内容スクロール

------------------------------------*/
#article {
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  max-width: 1170px;
}
#article .main-midashi {}
#article .scroll-visual {
  background: #f2f2f2;
  padding: 4em 0 3.5em;
}
#article .scroll-visual .scroll-wrap {
  cursor: grab;
  width: 100%;
  overflow-x: scroll;
  writing-mode: vertical-rl;
}
.scroll-wrap::-webkit-scrollbar {
  display: none;
}
.scroll-wrap.is-dragging {
  cursor: grabbing;
  user-select: none;
}
#article .scroll-visual .scroll-wrap .scroll-track {
  line-height: 1.3;
  display: inline-block;
  margin: 0;
  text-align: start;
  /* white-space: nowrap; */
  letter-spacing: .05em;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-feature-settings: 'vert'on;
  height: 500px;
  max-height: 80vh;
  padding-left: 50%;
  padding-right: 50%;
}
.normal-dash {
    /* text-orientation: mixed; letter-spacing: 0;*/
    width: 1px;
    background: #000;
    height: 2em;
    display: inline-block;
    margin: 0.15em auto 0;
}

#article .scroll-visual .scroll-wrap .scroll-track .writing-title {
  font-family: var(--font-syuei-B);
  font-size: 130%;
  display: inline-block;
  margin-right: 2em;
  line-height: 1.6;
}
#article .scroll-visual .scroll-wrap .scroll-track .writing-title .title-line {
  border-right: 1px solid #000;
}
#article .scroll-visual .scroll-wrap .scroll-track p {
  margin: 0 1em;
  line-height: 1.7;
  text-align: justify;
}
#article .scroll-visual .scroll-wrap .scroll-track .writing-image {}
#article .scroll-visual .scroll-wrap .scroll-track .writing-image img {
  height: 100%;
  width: auto;
}
/*------------------------------------

プログレスバー

------------------------------------*/
.progress-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45em;
  margin: 3.5em auto 0em;
  max-width: 640px;
  font-size: 80%;
}
.progress-nav *:focus {
  outline: none;
}
.progress-prev, .progress-next{
  position:relative;
  background: none;
  border:0;
  width: 1.9em;
  aspect-ratio:1;
}
.progress-prev::after, .progress-next::after {
  background: none;
  cursor: pointer;
  /* padding: 0.2em 0.4em; */
  line-height: 1;
  border: 0.075em solid #4c4c4c;
  width: 50%;
  aspect-ratio:1;
  aspect-ratio: 1;
  transform-origin: center center;
  transform: rotate(45deg);
  position:absolute;
  content: '';
  top: 25%;
  left: 25%;
}
.progress-next::after {
   left: auto;
   right: 25%;
}

.progress-prev::after {
  border-right: 0;
  border-top: 0;
}
.progress-next::after {
  border-left: 0;
  border-bottom: 0;
}
.progress-prev:active, .progress-next:active {
  opacity: 0.7;
}
.progress-prev:disabled, .progress-next:disabled {
  opacity: 0.2;
  cursor: default;
}
.custom-progressbar {
  width: 40%;
  /* margin: 3em auto 1em; */
  height: 0.12em;
  background: #b5bbc7;
  display: block;
  direction: rtl;
  /* text-align: right; */
}
.custom-progressbar-fill {
  height: 100%;
  background: #4c4c4c;
  width: 0%;
  position: relative;
  transition: width 0.05s linear;
  display: block;
}
.custom-progressbar-fill::after {
  display: block;
  width: 0.5em;
  height: 0.5em;
  content: '';
  background: #000;
  border-radius: 50%;
  position: absolute;
  top: -0.67em;
  left: -0.67em;
  border: 0.5em #FFF solid;
  box-sizing: initial;
  mix-blend-mode: multiply;
}
.custom-progressbar-fill:active::after {
  cursor: grabbing;
}
/*------------------------------------

イベント案内

------------------------------------*/
#event-wrap {
  background: #d7d6e0;
  padding: 4.26em 5% 4em;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  max-width: 1170px;
}
#event-wrap .event-ttl {
  text-align: center;
}
#event-wrap .event-ttl img {}
#event-wrap .event-ttl span {
  font-family: var(--font-syuei-M);
  font-size: 131%;
  margin: 0.7em 0 1em;
  display: inline-block;
}
#event-wrap .event-image {}
#event-wrap p {
  font-family: var(--font-syuei-M);
  font-size: 95%;
  text-align: justify;
  letter-spacing: 0;
  line-height: 2;
  width: 89%;
  margin: 1.5em auto 0;
}
#event-wrap .event-schedule {
  font-family: var(--font-syuei-M);
  border: 2px solid #FFF;
  padding: 0.5em 1.5em;
  margin: 1em 0 1.5em;
}
#event-wrap .event-schedule .event-item {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0.6em;
  margin: 0.8em 0;
}
#event-wrap .event-schedule .event-item .event-head {
  white-space: nowrap;
  line-height: 1.3;
}
#event-wrap .event-schedule .event-item p {
  margin: 0;
  line-height: 1.3;
}
#event-wrap .event-schedule .event-item p .min-text {
  font-size: 77%;
}
/*------------------------------------

お申し込みボタン

------------------------------------*/
#event-wrap .link-btn, #event-wrap .closed-btn {
  background: #000;
  color: #FFF;
  font-family: var(--font-syuei-M);
  line-height: 1;
  padding: 1em;
  font-size: 123%;
  letter-spacing: 0.05em;
  min-width: 13em;
  text-align: center;
  width: max-content;
  display: block;
  margin: 1.8em auto 0;
}
#event-wrap .link-btn .link-name {}
#event-wrap .closed-btn {
  background: #b2b2b2;
}
#event-wrap .closed-btn .link-name {}
/*------------------------------------

copyright

------------------------------------*/
#contents-main .copyright {
  text-align: right;
  width: 90%;
  margin: 0.3em auto;
  max-width: 1170px;
}
#contents-main .copyright img {
  width: 10em;
}
/*------------------------------------

60周年バナー

------------------------------------*/
#contents-main .felissimo-60th-area {
  border: 1px solid #7a7a80;
  width: 90%;
  margin: 2.3em auto 4.5em;
  padding: 1.2em;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 1em;
  /* max-width: 640px; */
  /* margin: 0 auto; */
  /* width: 100%; */
}
#contents-main .felissimo-60th-area .icon-60th {
  width: 2.9em;
}
#contents-main .felissimo-60th-area p {
  margin: 0;
  font-size: 84%;
  white-space: nowrap;
  letter-spacing: 0;
  font-family: var(--font-syuei-M);
}
/*------------------------------------

FAQ

------------------------------------*/
#faq {
  padding: 0.5em 0 1.7em;
  text-align: center;
  /* max-width: 700px; */
  margin: 0 auto;
}
#faq h3 {
  font-family: var(--font-syuei-M);
  font-size: 140%;
}
#wrapper #faq .h3-ttl .sub-ttl-image {
  width: 10%;
}
#faq .faq-box {
  width: 90%;
  margin: 0 auto 2em;
}
#faq .faq-wrap {
  margin-top: 1em;
}
#faq .faq-box .faq-q, #faq .faq-box .faq-a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.8em;
  padding: 0.6em 1em 0.5em;
  font-size: 110%;
  /* background: #f2f2f2; */
  font-family: var(--font-syuei-M);
  position: relative;
}
#faq .faq-box .faq-a {
  border-bottom: 2px solid #FFF;
}
#faq .faq-box .faq-q::before, #faq .faq-box .faq-a::before {
  display: block;
  width: 1.5em;
  height: 1.5em;
  content: '';
  background-image: url(../images/icon_q.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
#faq .faq-box .faq-a::before {
  background-image: url(../images/icon_a.svg);
}
#faq .faq-box .faq-q::after {
  background: #000;
  display: block;
  width: 1px;
  height: 0.8em;
  content: '';
  position: absolute;
  top: 2.45em;
  left: 1.73em;
  opacity: 0.5;
  z-index: 2;
}
#faq .faq-box p {
  margin: 0.4em 1em 0;
  text-align: justify;
  font-size: 94%;
}
#faq .faq-box p a {
  font-size: 110%;
  margin-top: 0.8em;
  font-weight: bold;
  text-decoration: underline;
  display: block;
}
#list-anchor {
  text-align: center;
  font-family: var(--font-syuei-M);
  font-size: 115%;
  margin-bottom: 0.7em;
}
/*------------------------------------

アニメーション

------------------------------------*/
.fade_item {
  opacity: 0;
}
.fade_item.active {
  animation: fadeInBottom_ct 1.0s 0.0s both;
}
.sub-item img {
  opacity: 0;
}
.dress-sub.active .sub-item img {
  animation: fadeInLeftBlur_ct 1.2s 0.0s both;
}
.dress-sub.active .sub-item.sub02 img {
  animation-delay: 0.3s;
}
.detail-box.anime_item {
  opacity: 0;
}
.detail-box.anime_item.active {
  animation: fadeInBlur_ct 1.2s 0.0s both;
}
@keyframes fadeIn_ct {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeInBottom_ct {
  0% {
    transform: translateY(0.5em);
    opacity: 0;
  }
  100% {
    transform: translateY(0px);
    opacity: 1;
  }
}
@keyframes blur_ct {
  0% {
    filter: blur(1em);
    opacity: 0;
  }
  100% {
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes fadeInBlur_ct {
  0% {
    filter: blur(1em);
    transform: translateY(1em);
    opacity: 0;
  }
  100% {
    filter: blur(0);
    transform: translateY(0px);
    opacity: 1;
  }
}
@keyframes fadeInLeftBlur_ct {
  0% {
    filter: blur(1em);
    transform: translateX(0.5em);
    opacity: 0;
  }
  100% {
    filter: blur(0);
    transform: translateX(0px);
    opacity: 1;
  }
}
@keyframes fadeInLeft_ct {
  0% {
    transform: translateX(20px);
    opacity: 0;
  }
  100% {
    transform: translateX(0px);
    opacity: 1;
  }
}
@keyframes fadeInRight_ct {
  0% {
    transform: translateX(-20px);
    opacity: 0;
  }
  100% {
    transform: translateX(0px);
    opacity: 1;
  }
}
/*===================================

スマホ
@media screen and (orientation: portrait) {
===================================*/
@media screen and (orientation: portrait) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  #wrapper {
    font-size: 3.0vw;
  }
  #wrapper-bg {
    display: none;
  }
  #contents-main {}
  .contents-inner, .main-midashi {
    max-width: none;
    /* overflow: hidden; */
  }
  .progress-nav{
    font-size:100%;
  }
  /*------------------------------------

タイトル

------------------------------------*/
  .fv-wrap {}
  /* FV画像 */
  #fv-image {}
  #fv-image img {}
  #fv-image .fv-pc {
    display: none;
  }
  #fv-image .fv-sp {
    background-image: url(../images/fv_image01_sp.webp);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    max-width: none;
    margin: 0 auto;
    height: 100vh;
    display: block;
    width: 100%;
  }
  #fv-image .fv-sp .fv-sp02 {
    display: none;
    background-image: url(../images/fv_image02_sp.webp);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    max-width: none;
    margin: 0 auto;
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
  }
  #fv-image .fv-sp .fv-sp02.active {}
  /* テキスト */
  #lead-wrap {
    margin: -92vh auto 0;
  }
  /* タイトル */
  #title {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  #title .title-sub {
    order: 1;
    width: 8%;
  }
  #title .title-sub::after {
    height: 0;
    width: 1px;
    opacity: 0.5;
    right: 95%;
    left: auto;
    top: -70%;
    animation: title-line-sp 3.8s 0.5s both;
  }
  #title .title-sub source {}
  #title .title-sub img {}
  #title .title-main {
    width: 9.2%;
    margin: 0 2%;
  }
  #title .title-main source {}
  #title .title-main img {}
  #lead {
    margin: 42vw 4% 4.5em;
  }
  #lead span {}
  #lead-wrap .icon-60th {
    margin-left: 1.2em;
  }
  #article .scroll-visual .scroll-wrap .scroll-track {
    padding-left: 2em;
    padding-right: 2em;
    height: 90cqw;
    font-size: 108%;
  }
  #contents-wrapper .fixd-title {
    display: none;
  }
}
@keyframes title-line-sp {
  0% {
    height: 0%;
  }
  100% {
    height: 170%;
  }
}