


/* ==================== 상품 상세 ==================== */
.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; */
    position: relative;
    width: 100%;
    height: auto;
    transform: none;
    top: auto;
    left: auto;
}
.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;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: none;
}


/* 책소개 */
.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;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    transform: translate(-50%, -50%);
    object-fit: cover;
    object-position: center;
}








/* 리뷰 영역 */
.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: none;
    width: 100%;
    padding: 10rem 0;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.coupon__empty.on {
    display: flex;
}


.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: fixed;
    bottom: 0;
    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%;
    padding: 2.4rem 1.6rem;
}

/* ==================== 상품 문의 ==================== */
.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: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    transform: translate(-50%, -50%);
    object-fit: cover;
    object-position: center;
}
.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: cover;
    object-position: center;
}
.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;
}