


/* ==================== 상품 상세 ==================== */
.product__detail {
  padding-bottom: 12rem;
}
.product__header-thumb {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 113.6%;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #eaeaea;
}
.product__header-thumb .thumb--image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.product__detail-section {
  padding: 3.6rem 1.6rem;
  border-bottom: 4px solid #f4f7fb;
}
.product__detail-meta {
  padding: 3.6rem 1.6rem;
}
.detail__section-title {
  margin-bottom: 1.6rem;
  color: #222;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.33;
}


/* 상품 상세 헤더 */
.product__header-label {
  position: relative;
  display: flex;
  margin-bottom: 1.6rem;
  justify-content: space-between;
  align-items: center;
}
.product__header-label .product__item--label {
  position: relative;
  left: 0;
  top: 0;
}
.product__header-label .review-page__btn {
  color: #ff5b07;
  text-align: right;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
  text-decoration-line: underline;
  text-underline-position: under;
  text-underline-offset: 0;
}




/* 상품 이름 */
.product__header-title {
  position: relative;
  padding-right: 4.8rem;
  margin-bottom: 2.4rem;
}
.product__header-title .product__title {
  margin-bottom: 0.8rem;
  color: #222;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.33;
}
.product__header-title .product__subtitle {
  color: #999;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.2857;
}
.product__header-title .button__share {
  position: absolute;
  right: 0;
  top: 0;
}




/* 상품(도서) - 글쓴이, 그림 */
.product__header-author {
  display: flex;
  flex-flow: column;
  gap: .8rem;
  margin-bottom: 2.4rem;
}
.product__author--item {
  display: flex;
  flex-wrap: wrap;
}
.product__author--name {
  margin-right: 1.6rem;
  color: #222;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.57;
  text-decoration-line: underline;
  text-underline-position: under;
  text-underline-offset: 0;
}
.product__author--meta {
  margin-right: 0.8rem;
  color:#999;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
}
.product__author--link {
  color:#999;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
  text-decoration-line: underline;
  text-underline-position: under;
  text-underline-offset: 0;
}
.product__author--buyback {
  color:#307e00;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.57;
  text-decoration-line: underline;
  text-underline-position: under;
  text-underline-offset: 0;
}




/* 상품 금액 */
.product__header-price {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.product__header-price .item__origin--price {
  color: #999;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  text-decoration-line: line-through;
}
.product__header-price .item__sale--per {
  margin-right: 0.8rem;
  color: #ff3b00;
  font-size: 2.2rem;  
  font-weight: 800;
  line-height: 1.45;
}
.product__header-price .item__sale--price {
  color: #222;
  font-size: 2.2rem;
  font-weight: 800;
  line-height: 1.45;
}
.product__header-price .product__coupon {
  display: flex;
  min-width: 8.5rem;
  height: 32px;
  padding: 0 1.6rem;
  border-radius: 6px;
  border: 1px solid #dde4ed;
  background: #FFF;
  color: #222;
  font-size: 1.4rem;
  font-weight: 500;
  align-items: center;
  justify-content: center;
}




/* 멤버쉽 혜택 */
.product__header-benefit {
  display: flex;
  flex-flow: column;
  margin-top: 1.6rem;
  padding: 1.6rem;
  border-radius: 10px;
  background: #f4f7fb;
}
.product__header-benefit .benefit__box--header {
  display: flex;
  margin-bottom: 1.4rem;
  justify-content: space-between;
  align-items: center;
}
.benefit__box--header .benefit__box--title {
  color:#222;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.57;
}
.benefit__box--header .benefit__box--compare {
  padding-right: 1.8rem;
  color: #222;
  text-align: right;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
  background: url(../../images/icon/ico_arrow_next_black.svg) right 0rem/ 1.6rem   no-repeat;
}
.product__header-benefit .benefit__box--content {
  display: flex;
  flex-flow: column;
  gap: 0.4rem;
}
.product__header-benefit .benefit__box--item {
  display: flex;
  gap: .6rem;
  color: #222;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
  align-items: center;
  justify-content: flex-start;
} 
.benefit__box--item .benefit__box--highlight {
  color: #ff3b00;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.57; 
}



/* 상품 - 구매 적립금, 결제혜택, 배송사, 배송비 등등 */
.product__info-box {
  display: flex;
  flex-flow: column;
  gap: 1.2rem;
}
.product__info--item {
  position: relative;
  display: flex;
  width: 100%;
  gap: 1.6rem;
  color: #666;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
}
.product__info-box .product__info--label {
  display: flex;
  flex: 0 0 10rem;
}
.product__info-box .product__info--label .alert-icon {
  position: relative;
  margin-left: 0.4rem;
  top: -0.1rem;
  display: inline-block;
  width: 1.8rem;
  height: 1.8rem;
  background: url(../../images/icon/ico_info.svg) 100% no-repeat;
}
.product__info-box .product__info--value b {
  color:#444;
  font-weight: 700;
  line-height: 1.57;
}
.product__info-box .product__info--link {
  display: flex;
  align-items: center;
  text-decoration-line: underline;
  text-underline-position: under;
  text-underline-offset: 0;
}
.product__info-box .product__info--link--arr {
  position: relative;
  padding-right: 1.6rem;
  background: url(../../images/icon/ico_arrow_next_black.svg) right 0.1rem/ 1.6rem   no-repeat;
}

.product__info--value .product__info--delivery {  
  display: inline-flex;
  margin-left: 0.8rem;
  padding: .2rem 1.2rem;
  background: #fff;
  border-radius: 30px;
  border: 1px solid #e3e6f1;
  color: #222;
  font-size: 1.2rem;
  font-weight: 500;
  align-items: center;
  justify-content: center;
}

.product__info--toggle {
  display: flex;
  padding: 1rem 0;
  border-radius: 6px;
  border: 1px solid #dde4ed;
  background: #fff;
  color: #222;
  font-size: 1.4rem;
  font-weight: 500;
  align-items: center;
  justify-content: center;
}
.product__info--toggle--icon {
  display: inline-block;
  margin-left: 1.6rem;
  width: 1.6rem;
  height: 1.6rem;
  background: url(../../images/icon/ico_arrow_down.svg) center center /1.6rem 1.6rem no-repeat;
}
.product__info--toggle.on .product__info--toggle--icon {
  transform: rotate(-180deg);
}

.product__info-box .product__info--link .product__brand-icon {
  position: relative;
  display: inline-block;
  margin-right: .8rem;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 30px;
  background: #f4f7fb;
  overflow: hidden;
}
.product__info-box .product__info--link .product__brand-icon > .product__brand-img {
  position: absolute;
  max-width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* 관련 기획전,이벤트 */
.product-detail__swiper{
  overflow: hidden;
}
.product-detail__swiper--item {
  width: 44.53%;
}
.product-detail__swiper--thumb {
  width: 100%;
  height: 0;
  padding-bottom: 113.78%;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: .4rem;
  background: #f4f7fb;
  overflow: hidden;
}
.product-detail__swiper--thumb .thumb--image {
  position: absolute;
  top: 0;
  width: auto;
  height: 100%;
  object-fit: cover;
}


/* 책소개 */
.product__book-wrap .product__book--title {
  margin-bottom: .8rem;
  color: #222;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.33;
}
.product__book-wrap .product__book--sub-title {
  margin-bottom: 1.6rem;
  color: #666;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5; 
}
.product__book-wrap .product__book--content {
  margin-bottom: 2.4rem;
  color: #222;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
}
.product__book-wrap .product__book--video {
  position: relative;
  width: 100%;
  padding-bottom: 58.6%;
  margin-bottom: 2.4rem;
}
.product__book-wrap .product__book--video .product__book--video-layout {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.product__book-wrap .product__book--image {
  margin-bottom: 1.6rem;
}
.product__book-wrap .product__book--image .product-detail__swiper--item{
  width: 42.67%;
}
.product__book-wrap .product__book--image .product-detail__swiper--thumb{
  padding-bottom: 125%;  
}
.product__book-wrap .product__book--link {
  margin-top: 1.6rem;
}

.product__link-btn {
  display: flex;
  width: 100%;
  padding: 1rem 0;
  border-radius: 6px;
  border: 1px solid #dde4ed;
  background: #fff;
  color: #222;
  font-size: 1.4rem;
  font-weight: 500;
  align-items: center;
  justify-content: center;
}

.product__book--detail-img {
  margin-bottom: 1.6rem;
  background-color: #f4f7fb;
}
.product__book--detail-img > img {
  width: 100%;
}

/* 상세 설명 */
.product__book-overview--wrap .product__book-overview--item {
  margin-bottom: 3.6rem;
}
.product__book-overview--wrap .product__book-overview--content {
  margin-bottom: 1.6rem;
}
.product__book-overview--wrap .product__book-overview--item:last-child,
.product__book-overview--wrap .product__book-overview--content:last-child {
  margin-bottom: 0;
}
.product__book-overview--wrap .product__book-overview--title {
  margin-bottom: 1.6rem;
  color: #222;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.33;
}
.product__book-overview--wrap .product__book-overview--sub-title {
  margin-bottom: 0.8rem;
  color: #222;
  font-size: 1.63rem;
  font-weight: 600;
  line-height: 1.5
}
.product__book-overview--wrap .product__book-overview--text {
  margin-bottom: 0.8rem;
  color: #222;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5
}
.product__book-overview--wrap .product__book-overview--text:last-child {
  margin-bottom: 0;
}
.product__book-overview--wrap .product__book-overview--img {
  position: relative;
  width: 15rem;
  height: 15rem;
  border-radius: 0.8rem;
  background: #f4f7fb;
  overflow: hidden;
  margin: 0 auto;
}
.product__book-overview--wrap .product__book-overview--img .overview__img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}








/* 리뷰 영역 */
.product__detail-section.product__detail-review {
  padding: 0;
  border-bottom: none;
}
.product__detail-section.product__detail-review .product__review--title {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.product__review--title .review__btn-link {
  background: none;
  color: #ff3b00;
  text-align: right;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
}



/* 상품 하단 영역 - 상품정보제공고시 / 상품 문의 등등 */
.product__detail-bottom .product__detail-popup--btn {
  position: relative;
  display: flex;
  min-height: 5.6rem;
  padding: 1rem 3.8rem 1rem 1.6rem;
  justify-content: flex-start;
  align-items: center;
  color: #222;
  font-size: 1.8rem;
  font-weight: 700;
  border-bottom: 1px solid #ececec;
}
.product__detail-bottom .product__detail-popup--btn::after {
  content: '';
  display: block;
  position: absolute;  
  right: 1.6rem;
  width: 2.2rem;
  height: 2.4rem;
  background: url(../../images/icon/ico_arrow_next_black.svg) center center / 2.2rem 2.4rem no-repeat;
}

.product__legal-notice {
  padding: 1.6rem;
  background: var(--f-4-f-7-fb, #F4F7FB);
}
.product__legal-notice--title {
  margin-bottom: 0.8rem;
  color: #222;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.57;
}
.product__legal-notice--text {
  color: #666;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.5;
}


.coupon__submit{
  margin-bottom: .7rem;
  color: #666;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.57;
  background: none;
}
.coupon__empty {
  display: flex;
  width: 100%;
  padding: 10rem 0;
  flex-flow: column;
  align-items: center;
  justify-content: center;
}
.dialog__coupon-book .coupon__empty-text {
  color: #222;
  text-align: center;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1.5
}

.dialog__talk-input {
  margin-bottom: 3.2rem;
}



/* ==================== 상품 리뷰 ==================== */

.dialog__photo-review .review__btn-group {
  display: none;
  border: none;
}
.dialog__photo-review.on .review__btn-group {
  display: flex;
}

.dialog__list.--review .dialog__list--item .item--image {
  width: 6rem;
  height: 6rem;
}
.dialog__list.--review  .dialog__list--item .item--text {
  font-size: 1.4rem;
}
.dialog__list--item.first-review {
  position: relative;
}
.dialog__list--item.first-review::after {
  content: '첫 리뷰시!';
  position: absolute;
  display: block;
  top: 4.8rem;
  width: 4rem;
  height: 1.2rem;
  border-radius: 20px;
  background: #ff3b00;
  color: #FFF;
  text-align: center;
  font-size: .8rem;
  font-weight: 500;
  line-height: 1.25
}
.review__filter-btn {
  display: flex;
  position: relative;
  color: #222;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.2857;
  padding-right: 2.8rem;
  margin-right: 1.6rem;
  align-items: center;
}
.review__filter-btn::after {
  content: '';
  position: absolute;
  right: 0;
  top:0;
  display: block;
  width: 2.4rem;
  height: 2.4rem;
  background: url(../../images/icon/ico_filter.svg) center center no-repeat;
}

#dialog__review-filter .dialog__wrap {
  align-items: unset;
}
.dialog__filter-box {
  width: 100%;
  margin-bottom: 3.2rem;
  text-align: left;
}
.dialog__filter-tit {
  display: block;
  color: #222;
  font-size: 1.6rem;
  margin-bottom: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}

.dialog__filter-box .filter__check {
  display: flex;
  gap: 1.6rem 1.2rem ;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.dialog__filter-box .filter__check-item {
  display: flex;
  flex: 0 1 8.5rem;  
  height: 4.2rem;
}

.dialog__filter-box .filter__check-label {
  display: flex;
  width: 100%;
  height: 100%;
  padding: .7rem 0;
  border-radius: 6px;
  background: #f8f8f8;
  border: 1px solid #f8f8f8;
  align-items: center;
  justify-content: center;
  color: #222;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.57;
}
.dialog__filter-box input:checked + .filter__check-label {
  border: 1px solid #222;
  background: #fff;
  color: #222;
}

.dialog__filter-box.col2 .filter__check {
  display: flex;
  gap: 1.6rem 1.1rem ;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.dialog__filter-box.col2 .filter__check-item {
  display: flex;
  flex: 0 1 13.4rem;  
}


/* 포토리뷰 상세 */
.dialog__photo-detail {
  background-color: #000;
}
.dialog__photo-detail .dialog__contents {
  width: 100%;
  /* overflow: hidden; */
}
.dialog__photo-detail .dialog__wrap {
  padding: 6.8rem 0rem 2.4rem;
  background-color: #000;
}
.dialog__photo-detail .dialog__header {
  background-color: #000;
}

.dialog__photo-detail .review__rating {
  margin-bottom: .8rem;
}
.dialog__photo-detail .review__author {
  margin-bottom: 1.6rem;
}
.dialog__photo-detail .review__author .review__author--item {
  color: #fff;
}
.dialog__photo-detail .review__content {
  margin-bottom: 2.4rem;
}
.dialog__photo-detail .review__text-toggle {
  color: #fff;
}
.dialog__photo-detail .review__toggle-btn {
  color: #fff;
}
.dialog__photo-detail .dialog__photo-review {
  position: absolute;
  bottom: 0rem;
  left: 0;
  width: 100%;
  padding: 2.3rem 1.6rem 4.8rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.20) 19.25%, #000 96.27%);
  z-index: 2;
}
.dialog__photo-detail .review__product-name {
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}

#dialog__photo-list .dialog__wrap {
  padding: 6rem 1.6rem 2.4rem;
}
#dialog__photo-list .dialog__contents {
  width: 100%;
}

/* ==================== 상품 문의 ==================== */
.question--wrap {
  height: 100%;
  padding-bottom: 9.6rem;
}
.question__list {
  display: flex;
  flex-flow: column;  
  justify-content: space-between;
}
.question__list--item {
  border-bottom: 1px solid #f4f7fb;
  background: #FFF;
}
.question__list--item.secret {
  border-bottom: 1px solid #f4f7fb;
  background: #FFF;
}
.question__item--question,.question__item--answer {
  padding: 1.6rem 2.4rem;
}
.question__item--tit {
  position: relative;
  margin-bottom: 1.2rem;
  color: #222;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
}

.question__author--box {
  display: flex;
  gap: .8rem;
  justify-content: flex-start;
  align-items: center;
}
.question__author--content {
  position: relative;
  padding-right: .8rem;
  color: #999;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.57;
  background: none;
}
.question__author--content::after {
  content: '';
  position: absolute;
  display: block;
  right: 0;
  top: .4rem;
  width: 1px;
  height: 1.2rem;
  background-color: #ececec;
}
.question__author--content:last-child:after {
  display: none;
}



/* 비밀글 */
.question__list--item.secret .question__item--tit {
  padding-left: 2.3rem;
  color: #999;
  background: url(../../images/icon/ico_lock.svg) left top .4rem/1.6rem 1.6rem no-repeat;
}

/* 답변완료 */
.question__list--item.answered .question__author--box {
  position: relative;
}
.question__list--item.answered .question__author--box::after {
  content: '';
  position: absolute;
  display: block;
  right: 0;
  top: 0;
  width: 2.2rem;
  height: 2.2rem;
  background: url(../../images/icon/ico_arrow_down_gray.svg);
}

.question__list--item.answered .question__item--tit {
  color: #222;
}
.question__list--item.answered .question__author--state {
  color: #222;
  font-weight: 600;
}
.question__list--item.answered.secret .question__item--tit {
  color: #999;
}
.question__list--item.answered.secret .question__author--state {
  color: #999;
}
.question__list--item.my_question.secret .question__author--state {
  color: #222;
}
.question__list--item.my_question.secret .question__item--tit {
  color: #222;
}

.question__list--wrap .data__no--box {
  height: 100vh;
  padding-bottom: 15rem;  
  justify-content: center;
}

/* 내글 */
.question__list--item.my_question .question__item--tit {
  margin-left: 4.9rem;
}
.question__list--item.my_question .question__item--tit::before {
  content: '내글';
  position: absolute;
  left: -4.9rem;
  top: .2rem;
  display: flex;
  width: 3.7rem;
  height: 2rem;
  justify-content: center;
  align-items: center;
  color: #FFF;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.5;
  border-radius: 10px;
  background: #666;
}

.question__item--answer {
  display: none;
}
.question__answer--author {
  display: inline-flex;
  margin-bottom: 1.2rem;
  height: 2rem;
  padding: 1px 8px;
  justify-content: center;
  align-items: center;
  text-align: center;  
  color: #fff;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.5;
  border-radius: 10px;
  background: #222;
}
.question__answer--content {
  color: #222;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
}


.question__list--item.active .question__item--answer {
  display: block;
}
.question__list--item.secret .question__author--box::after {
  display: none;
}

.question__list--item.secret.my_question .question__author--box::after {
  display: block;
}
/* .question__list--item.answered .question__author--box::after {
  transform: rotate(180deg);
} */ 

.question__list--item.active {
  background-color: #fbfbfb;
}
.question__list--item.active .question__item--question {
  border-bottom: 1px solid #f4f7fb;
}

.question__list--item.active .question__author--box::after {
  transform: rotate(180deg);
}

.question__write--wrap {
  padding: 1.6rem 2.4rem;
}
.question__write--tit {
  margin-bottom: 1.6rem;
  color: #222;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.33;  
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.text-area__box {
  display: flex;
  width: 100%;
  height: 20.4rem;
  padding: 1.6rem;
  margin-bottom: 1.6rem;  
  border-radius: 4px;
  flex-flow: column ;
  border: 1px solid #ececec;
  background: #fff;
}

.sort__checkbox {
  margin-bottom: 2.4rem;
}
.check-box__secret label {
  color: #222;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.2857;
}
.sort__checkbox.check-box__secret label:before {
  width: 2.4rem;
  height: 2.4rem;
  background-image: url(../../images/icon/ico_check_default.svg);
}
.sort__checkbox.check-box__secret input:checked + label::before {
  background-image: url(../../images/icon/ico_check_press.svg) ;
}
.dot__list--item {
  position: relative;
  padding-left: 1.1rem;
  margin-bottom: .8rem;
  color: #666;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5;
}
.dot__list--item::before {
  content: '';
  position: absolute;
  left: 0;
  top: .6rem;
  width: .3rem;
  height: .3rem;
  border-radius: 50%;
  background: #666;
  overflow: hidden;   
}



/* 상품 리뷰 신고 팝업 */
.review__report--wrap {
  padding-bottom: 9rem;
}
.review__report--title {
  margin-bottom: 1.6rem;
  color: #222;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.33;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-flow: column;
}
#dialog__review-report .sort__radio--wrap {
  padding-bottom: 2.4rem;
  margin-bottom: 2.4rem;
  border-bottom: 1px solid #ececec;
}
.review__report--wrap .text-area__box {
  display: none;
  height: 17rem;
}


/* 리뷰 없을때 */
.review__empty {
  display: flex;
  flex-flow: column;
  width: 100%;
  height: 100%;
  min-height: 30rem;
  align-items: center;
  justify-content: center;
}
.review__empty-image {
  width: 4.8rem;
  height: 4.8rem;
  margin-bottom: 1.6rem;
}

/* 쿠폰 받기 */
.coupon__detail {
  padding: 0 2.4rem 13rem;
}

/* ==================== 작성 가능한 리뷰 ==================== */
.review-to-write__wrap,.review-written__wrap {
  padding-top: 4.5rem;
  flex-flow: column;
}
.review-to-write__wrap .review-to-write__header {
  width: 100%;
  padding: 2.4rem;
}
.review-to-write__wrap .review-to-write__header-inner { 
  width: 100%;
  padding-bottom: 2.4rem;
  border-bottom: 1px solid #ececec;
}
.review-to-write__wrap .text__list--dot.text__list--fz14 .text__list--item {
  color: #444;
}
.review-to-write__wrap .text__list--dot.text__list--fz14 .text__list--item::before {
  background-color: #444;
}
.review-to-write__wrap .text__list--dot.text__list--fz14 .text__list--item:last-of-type {
  margin-bottom: 0;
}
.review-to-write__body {
  padding: 0 1.6rem 4.8rem;
}
.review__product-total {
  color: #222;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.57;
}
.review__product-list {
  display: flex;
  flex-flow: column;
  gap: 1.6rem;
}
.review__product-list--item {
  display: flex;
  gap: 0.8rem;
}
.review__product-list--info {
  flex: 1 1 100%;
  position: relative;
  min-width: 0;
}
.review__product-list--thumb {
  flex: 0 0 7.4rem;
  position: relative;
  display: flex;
  width: 7.4rem;
  height: 8.4rem;
  background-color: #f4f7fb;
  border: .1rem solid #f2f2f2;
  overflow: hidden;
  justify-content: center;
  align-items: center;
}
.thumb--image {
  position: absolute;
  top: 0;
  width: auto;
  height: 100%;
  object-fit: cover;
}
.review__product-list--title {
  color: #222;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.review__product-list--limit {
  color: #222;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.57;
}
.review__product-list--limit-gray {
  color: #999;
  font-weight: 400;
  line-height: 1.28;
}
.review__product-list--bottom-info {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
.review__product-list--bottom-info .button__outline {
  flex: 0 0 auto;
}
.no-content {
  display: flex;
  padding: 12rem 0;
  flex-flow: column;
  gap: 1.6rem;
  align-items: center;
  justify-content: center;
}
.no-content .no-content--image {
  width: 4.8rem;
  height: 4.8rem;
}

/* ==================== 작성한 리뷰 ==================== */
.review-written__wrap {
  padding: 7rem 1.6rem 4.8rem;
}
.review__product {
  display: flex;
  justify-content: flex-start;
  min-width: 0;
  align-items: center;
  gap: 0.8rem;
  border-bottom: 1px solid #ececec;
  padding-bottom: 1.6rem;
  margin-bottom: 2.4rem;
}
.review__product--thumb {
  position: relative;
  display: flex;
  width: 4rem;
  height: 4.5rem;
  background-color: #f4f7fb;
  border: .1rem solid #f2f2f2;
  overflow: hidden;
  justify-content: center;
  align-items: center;
  flex: 0 0 4rem;
}
.review__product--thumb .thumb--image {
  position: absolute;
  top: 0;
  width: auto;
  height: 100%;
  object-fit: cover;
}
.review__product--name {
  flex: 1 1 100%;
  color: #222;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.review-written__wrap .review__list-wrap {
  display: flex;
  flex-flow: column;
  gap: 2.4rem;
}
.review-written__wrap .review__btn-group {
  padding-bottom: 0;
  border-bottom: none;
}
.review-written__wrap .button__outline {
  width: 7.7rem;
}

.review__write-title {
  margin-bottom: 1.8rem;
}
.review__write-column {
  display: flex;
  padding: 2.4rem 0;
  border-top: 1px solid #ececec;
}
.review__write-column:last-child {
  margin-bottom: 9rem;
}
.rating__write {
  flex-flow: column;
  gap: 0.8rem;
}
.rating__write .rating__write-item {
  display: flex;
  justify-content: flex-start;
  align-items: center;  
  gap: 0.7rem;
}
.rating__write .rating__write-label {
  flex: 0 1 7rem;
  color: #222;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
}
.rating__write .rating__write-stars {
  flex: 0 0;
  display: flex;
  gap: 0.4rem;
}
.rating__write .rating__write-stars .review__rating-star {
  width: 3rem;
  height: 3rem;
  background: url(../../images/icon/ico_star_off.svg ) left / cover no-repeat;
}
.rating__write .rating__write-stars .review__rating-star.active {  
  background: url(../../images/icon/ico_star_on.svg ) left / cover no-repeat;
}

.rating__write .rating__write-text {
  flex: 0 0 8rem;
  color: #fe9d00;
  text-align: right;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
}
.review__write-column {
  display: flex;
  flex-flow: column;
}

.review__write-column--title {
  margin-bottom: 1.6rem;
  color: #222;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}
.age__check {
  display: flex;
  gap: 1.6rem 1.2rem ;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.age__check-item {
  display: flex;
  flex: 0 0 calc((100%/2) - 1.2rem);  
  height: 4.2rem;
}
.age__check-label {
  display: flex;
  width: 100%;
  height: 100%;
  padding: .7rem 0;
  border-radius: 6px;
  background: #f8f8f8;
  border: 1px solid #f8f8f8;
  align-items: center;
  justify-content: center;
  color: #222;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.57;
}
.age__check-label.on {
  border: 1px solid #222;
  background: #fff;
  color: #222;
}
.review__write-text-area {
  margin-bottom: 1.6rem;
}
.photo__upload-list .review__photo-item {
  position: relative;
  flex: 0 1 calc((100% - .6rem)/4);
  overflow: hidden;
  margin-bottom: 1.6rem;
}
.photo__upload-list .review__photo-item .review__thumb{
  position: relative;
  width: 100%;
  padding-bottom: 100%;
  background: #f4f7fb;
  overflow: hidden;
  z-index: 1;
}
.photo__upload-list .review__photo-item .review__thumb .review__image{
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
  object-fit: contain;
}
.photo__upload-list .review__photo-item .photo__upload-delete {
  position: absolute;
  right: .4rem;
  top: .4rem;
  display: block;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.7) url(../../images/icon/ico_arrow_close_white.svg) center center / 1.6rem 1.6rem no-repeat;
  z-index: 2;
}

.photo__upload-text {
  color: #666;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.28;
}
.dialog__photo-detail .dialog__title {
  color: #fff;
}
.photo-review__swiper-bottom {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 21rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.20) 19.25%, #000 96.27%);
  z-index: 2;
}
.dialog__photo-detail .photo-review__swiper-bottom .swiper-pagination-bullets.photo-review__pagination {
  top: auto;
  bottom: 10rem;
  z-index: 2;
}
.dialog__photo-detail .photo-review__swiper-bottom .swiper-pagination-bullets.photo-review__pagination .swiper-pagination-bullet {
  width: .6rem;
  height: .6rem;
}