@charset "utf-8";
@import url('font.css');
@import url('default.css');
@import url('motion.css');

* {
  word-break: break-all;
  word-wrap: break-word;
}
.hidden {
  visibility: hidden;
}
.hide {
  display: none;
}
html {
  font-family: "Pretendard", Pretendard, "Roboto", Roboto, -apple-system, BlinkMacSystemFont, system-ui, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
  font-size: 22px;
  font-size: 3.05555556vw;
  font-weight: 400;
}
#wrap {
  overflow-x: hidden;
  min-height: 100%;
}
.inr-c {
  margin-left: 38px;
  margin-left: 5.27777778vw;
  margin-right: 38px;
  margin-right: 5.27777778vw;
}
html,
body {
  min-height: 100%;
  color: #6c6c6c;
  letter-spacing: -0.01em;
}
a,
button,
select.select1 {
  color: #2C3041;
}
#header {
  z-index: 100;
  position: fixed;
  left: 0px;
  left: 0vw;
  top: 0px;
  top: 0vw;
  width: 100%;
  height: 55px;
  height: 7.63888889vw;
  padding: 40px 0px;
  padding: 5.55555556vw 0vw;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.6);
  -webkit-transition: all 200ms ease-in-out;
  -moz-transition: all 200ms ease-in-out;
  -ms-transition: all 200ms ease-in-out;
  -o-transition: all 200ms ease-in-out;
  transition: all 200ms ease-in-out;
}
#header.popup {
	background-color: rgba(255, 255, 255, 0);
}
#header .inr-c {
  position: relative;
}
#header .logo {
  display: inline-block;
}
#header .logo a {
  display: block;
  width: 113px;
  width: 15.69444444vw;
  height: 55px;
  height: 7.63888889vw;
}
#header .btn_dm_header {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin-left: 10px;
  margin-left: 1.38888889vw;
}
#header .btn_dm_header img {
  width: 65px; width: 9.03vw;
  height: 72px; height: 9.93vw;
  vertical-align: top;
}
#header .dm_badge_header {
  position: absolute;
  top: -2px;
  right: -4px;
  display: inline-block;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: #e30707;
  border-radius: 8px;
  font-size: 10px;
  color: #fff;
  text-align: center;
  line-height: 16px;
  font-style: normal;
  z-index: 1;
}
#header .llink {
  position: absolute;
  left: 0px;
  left: 0vw;
  top: 0px;
  top: 0vw;
}
#header .llink > a {
  margin-right: 10px;
  margin-right: 1.38888889vw;
  vertical-align: middle;
}
#header .llink > button {
  margin-right: 10px;
  margin-right: 1.38888889vw;
  vertical-align: middle;
}
#header .llink .on {
  position: relative;
}
#header .llink .on:after {
  content: "";
  position: absolute;
  left: -7px;
  left: -0.97222222vw;
  top: 4px;
  top: 0.55555556vw;
  width: 14px;
  width: 1.94444444vw;
  height: 14px;
  height: 1.94444444vw;
  background-color: #e30707;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  border-radius: 8px;
  -webkit-border-radius: 1.11111111vw;
  -moz-border-radius: 1.11111111vw;
  border-radius: 1.11111111vw;
}
#footer {
  z-index: 100;
  position: fixed;
  left: 0;
  bottom: 40px;
  bottom: 5.55555556vw;
  width: 100%;
  padding: 0px 30px;
  padding: 0vw 4.16666667vw;
  font-size: 0;
  display: flex;
  justify-content: space-between;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
#footer a {
  z-index: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  width: 13.88888889vw;
  height: 100px;
  height: 13.88888889vw;
}
#footer a.cen {
  margin: 0px 50px;
  margin: 0vw 6.94444444vw;
  width: 108px;
  width: 15vw;
  height: 108px;
  height: 15vw;
  background-image: url("../images/ico_footer3.png");
  background-size: 100% 100%;
}
#footer .i-ico {
  display: inline-block;
  vertical-align: top;
  width: 50px;
  width: 6.94444444vw;
  height: 50px;
  height: 6.94444444vw;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
#footer .i-ico.i_footer1 {
  background-image: url("../images/ico_footer1.png");
}
#footer .i-ico.i_footer2 {
  background-image: url("../images/ico_footer2.png");
}
#footer .i-ico.i_footer4 {
  background-image: url("../images/ico_footer4.png");
}
#footer .i-ico.i_footer5 {
  background-image: url("../images/ico_footer5.png");
}
#footer .on .i-ico.i_footer1 {
  background-image: url("../images/ico_footer1_on.png");
}
#footer .on .i-ico.i_footer2 {
  background-image: url("../images/ico_footer2_on.png");
}
#footer .on .i-ico.i_footer4 {
  background-image: url("../images/ico_footer4_on.png");
}
#footer .on .i-ico.i_footer5 {
  background-image: url("../images/ico_footer5_on.png");
}
#footer::after {
  content: "";
  position: absolute;
  left: 0;
  top: -1px;
  width: 39%;
  height: 100%;
  -webkit-border-radius: 0px 50px 50px 0px;
  -moz-border-radius: 0px 50px 50px 0px;
  border-radius: 0px 50px 50px 0px;
  -webkit-border-radius: 0vw 6.94444444vw 6.94444444vw 0vw;
  -moz-border-radius: 0vw 6.94444444vw 6.94444444vw 0vw;
  border-radius: 0vw 6.94444444vw 6.94444444vw 0vw;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
  background-color: #fff;
}
#footer::before {
  content: "";
  position: absolute;
  right: 0;
  top: -1px;
  width: 39%;
  height: 100%;
  -webkit-border-radius: 50px 0px 0px 50px;
  -moz-border-radius: 50px 0px 0px 50px;
  border-radius: 50px 0px 0px 50px;
  -webkit-border-radius: 6.94444444vw 0vw 0vw 6.94444444vw;
  -moz-border-radius: 6.94444444vw 0vw 0vw 6.94444444vw;
  border-radius: 6.94444444vw 0vw 0vw 6.94444444vw;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  background-color: #fff;
}
#container {
  padding-top: 143px;
  padding-top: 19.86111111vw;
  padding-bottom: 160px;
  padding-bottom: 22.22222222vw;
}
/* 앱에서는 Flutter AppBar가 있으므로 상단 여백 제거 */
body.is-app #container {
  padding-top: 0;
  padding-bottom: 120px; /* Flutter BottomNav 여백 */
}
/* 앱에서는 웹 footer 숨김 (Flutter BottomNav 사용) */
body.is-app #footer {
  display: none !important;
}
/* 앱에서는 웹 header도 숨김 (Flutter AppBar 사용) */
body.is-app #header {
  display: none !important;
}
/* 앱에서 DM 플로팅 버튼 */
.app_dm_btn {
  position: fixed !important;
  right: 12px;
  top: -3px;
  z-index: 2147483647;
}
.app_dm_btn a {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: #fff;
  color: #2C3041;
  font-size: 12px;
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  font-family: Pretendard, sans-serif;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.app_dm_btn a img {
  width: 16px;
  height: 18px;
  flex-shrink: 0;
}
.dm_badge_app {
  display: inline-block;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  margin-left: 6px;
  background: #e30707;
  border-radius: 8px;
  font-size: 10px;
  color: #fff;
  text-align: center;
  line-height: 16px;
  font-style: normal;
}
/* 앱: 내정보 간격 축소 */
body.is-app .wrap_info {
  padding: 20px 4.72222222vw;
  padding-top: 2.5vw;
  border-radius: 4vw;
}
body.is-app .wrap_info .lst_info .grade_icon {
  width: 18vw;
  margin-top: 1.5vw;
  padding: 12px;
}
body.is-app .wrap_info .lst_info .h1 {
  margin-top: 1.5vw;
}
body.is-app .myinfo-badges {
  margin: 6px 0;
}
body.is-app .wrap_info .lst_info .card a {
  margin-top: 1vw;
  padding: 7px 20px;
  font-size: 1em;
}
body.is-app .wrap_info .lst_info .grade_graph {
  margin-top: 2.5vw;
  margin-bottom: 2.5vw;
}
body.is-app .wrap_info .lst_info .lst1 {
  padding: 2vw 0;
}
body.is-app .wrap_info .lst_info .b1 {
  margin-top: 2.5vw;
}
body.is-app .wrap_info .lst_info .b2 {
  margin-top: 2.5vw;
  padding-top: 2.5vw;
}

/* 앱에서 댓글 팝업 기본 상태 (닫힌 상태) */
body.is-app .layerPopup_botm.pop_comment {
  top: auto !important; /* top 초기화 - bottom만으로 위치 제어 */
  bottom: -150% !important; /* 화면 밖으로 숨김 */
  max-height: 92vh;
  overflow: hidden;
  pointer-events: none; /* 닫힌 상태에서 터치 이벤트 차단 */
  visibility: hidden; /* 닫힌 상태에서 완전히 숨김 */
}
/* 앱에서 댓글 팝업 열린 상태 */
body.is-app .layerPopup_botm.pop_comment.active {
  top: 8vh !important; /* 상단에서 8% 아래에 고정 (AppBar 영역 확보) */
  bottom: 0 !important;
  max-height: none; /* top/bottom으로 높이 결정 */
  overflow: hidden;
  pointer-events: auto; /* 열린 상태에서 터치 이벤트 활성화 */
  visibility: visible; /* 열린 상태에서 표시 */
}
/* 앱에서 댓글 팝업 닫기 버튼 고정 */
body.is-app .layerPopup_botm.pop_comment .btn_botm_close {
  flex-shrink: 0;
  position: relative;
  z-index: 100;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
/* 앱에서 댓글 팝업 타이틀 고정 */
body.is-app .layerPopup_botm.pop_comment .ptit {
  flex-shrink: 0;
}
/* 앱에서 댓글 스크롤 영역 - flex로 남은 공간 채우기 */
body.is-app .layerPopup_botm.pop_comment .scrollY {
  flex: 1;
  max-height: none; /* 기존 max-height 제거, flex로 관리 */
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
/* 앱에서 댓글 입력창 고정 + Flutter BottomNav 여백 */
body.is-app .layerPopup_botm.pop_comment .botm_send {
  flex-shrink: 0;
  padding-bottom: 120px;
  padding-bottom: 16vw;
}
/* 피드 상세 팝업 - flex 레이아웃 (웹+앱 공통) */
.layerPopup_botm.pop_feed_detail {
  display: flex;
  flex-direction: column;
}
.layerPopup_botm.pop_feed_detail .btn_botm_close {
  flex-shrink: 0;
}
.layerPopup_botm.pop_feed_detail .fd_scroll_area {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  min-height: 0;
}
.layerPopup_botm.pop_feed_detail .botm_send {
  flex-shrink: 0;
}
/* 앱에서 피드 상세 팝업 */
body.is-app .layerPopup_botm.pop_feed_detail {
  top: auto !important;
  bottom: -150% !important;
  max-height: 92vh;
  overflow: hidden;
  pointer-events: none;
  visibility: hidden;
}
body.is-app .layerPopup_botm.pop_feed_detail.active {
  top: 0 !important;
  bottom: 0 !important;
  max-height: none;
  overflow: hidden;
  pointer-events: auto;
  visibility: visible;
}
body.is-app .layerPopup_botm.pop_feed_detail .btn_botm_close {
  flex-shrink: 0;
  position: relative;
  z-index: 100;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
body.is-app .layerPopup_botm.pop_feed_detail .fd_scroll_area {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  min-height: 0;
}
body.is-app .layerPopup_botm.pop_feed_detail .botm_send {
  flex-shrink: 0;
  padding-bottom: 120px;
  padding-bottom: 16vw;
}
body.is-app .layerPopup_botm.pop_write {
  bottom: -150% !important;
  visibility: hidden;
  pointer-events: none;
  padding-bottom: 30px;
  padding-bottom: 4vw;
}
body.is-app .layerPopup_botm.pop_write.active {
  bottom: 0 !important;
  visibility: visible;
  pointer-events: auto;
}
/* 앱에서 textarea 스크롤 가능하게 */
body.is-app .layerPopup_botm.pop_write .textarea1 {
  height: 280px;
  height: 38vw;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
}
/* 앱에서 설문 페이지 조정 - 녹색 배경 제거, 흰색 카드만 표시 */
body.is-app .wrap_search {
  background-color: #fff;
  padding-top: 0;
  padding-bottom: 100px;
  min-height: auto;
}
body.is-app .wrap_search .logo {
  display: none;
}
body.is-app .wrap_search .cont {
  margin: 0;
  padding: 20px;
  border-radius: 0;
  min-height: auto;
  background: transparent;
  box-shadow: none;
  border: none;
}
body.is-app .wrap_search .h1 {
  padding-top: 20px;
  margin-bottom: 15px;
}
body.is-app .wrap_search .h2 {
  margin-bottom: 20px;
}
body.is-app .wrap_search .btns {
  padding-bottom: 80px;
}
.btn_inp_del {
  display: none;
}
.act_inp .inp_txt {
  background-color: #F3F4F6;
}
.act_inp .btn_inp_del {
  display: block;
}
.wrap_intro {
  overflow: hidden;
  position: relative;
  height: 100%;
  height: 100vh;
  min-height: 550px;
  min-height: 76.38888889vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background-color: #fff;
}
.wrap_intro .logo {
  width: 113px;
  width: 15.69444444vw;
  height: 55px;
  height: 7.63888889vw;
  margin: 0 auto;
  margin-bottom: 115px;
  margin-bottom: 15.97222222vw;
}
.wrap_intro .btns {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-left: 80px;
  margin-left: 11.11111111vw;
  margin-right: 80px;
  margin-right: 11.11111111vw;
}
.wrap_intro .btns .btn-pk {
  width: 100%;
  margin-bottom: 30px;
  margin-bottom: 4.16666667vw;
}
.wrap_intro .link {
  padding-top: 200px;
  padding-top: 27.77777778vw;
  margin-bottom: 100px;
  margin-bottom: 13.88888889vw;
  text-align: center;
  font-size: 24px;
  font-size: 3.33333333vw;
  font-weight: 600;
}

.campaign_list {
	display: flex;
	flex-wrap: wrap;
	gap:5px;
}

.campaign_list .list_con {
	width: calc(50% - 1%); /* 2개씩 정렬 + gap 보정 */
	box-sizing: border-box;
	margin-bottom: 0;
}

.campaign_list .list_con .con {
	height:260px;
	background-color:#000;
	display: flex;
    align-items: center;
    justify-content: center;
	margin-bottom: 0;
}

.loading {position:absolute;}

.list_con {
  margin-bottom: 35px;
  margin-bottom: 4.86111111vw;
}

.list_con .con {
  overflow: hidden;
  margin-bottom: 25px;
  margin-bottom: 3.47222222vw;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  -webkit-border-radius: 2.77777778vw;
  -moz-border-radius: 2.77777778vw;
  border-radius: 2.77777778vw;
  font-size: 22px;
  font-size: 3.35555556vw;
  line-height: 1.5;
  color: #6e6e6e;
  background-color: #edeeec;
}
.list_con .con .im {
  overflow: hidden;
  position: relative;
}
.list_con .con .im img {
  width: 100%;
  height: auto;
  display: block;
}
.list_con .con .tx {
  margin: 20px 25px;
  margin: 2.77777778vw 3.47222222vw;
  color: #6e6e6e;
  white-space: pre-line;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.4em;
  transition: all .3s ease;
}
.list_con .con .tx.expanded {
  -webkit-line-clamp:unset;
  overflow:visible;
}
.list_con.no-photo .con .tx {
  -webkit-line-clamp:unset;
  overflow:visible;
}
.list_con .con .tx-more {
  margin: 0 25px 10px;
  margin: 0 3.47222222vw 1.38888889vw;
  font-size:12px;
  color:#23bf94;
  cursor:pointer;
  font-weight:600;
}
.list_con .con .swiper-pagination {
  width: auto;
  left: auto;
  right: 20px;
  right: 2.77777778vw;
  bottom: 20px;
  bottom: 2.77777778vw;
  padding: 0px 15px;
  padding: 0vw 2.08333333vw;
  background-color: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 22px;
  font-size: 3.05555556vw;
  line-height: 34px;
  line-height: 4.72222222vw;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  border-radius: 30px;
  -webkit-border-radius: 4.16666667vw;
  -moz-border-radius: 4.16666667vw;
  border-radius: 4.16666667vw;
}
.list_con .botm {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 28px;
  font-size: 3.88888889vw;
  font-weight: 500;
  line-height: 50px;
  line-height: 6.94444444vw;
}
.list_con .botm .lft em img {
  width: 20px;
  width: 5.25252525vw;
}
.list_con .botm .lft > .user-id-link {
  border-bottom: 1px solid #000;
}
.list_con .botm .lft .badge-stack {
  border-bottom: none;
}
.list_con .botm .lft {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.list_con .botm .lft button {
  margin-right: 20px;
  margin-right: 4.77777778vw;
  width: 60px;
  width: 3.33333333vw;
  height: 50px;
  height: 6.94444444vw;
}
.list_con .botm .rgh {
  margin-right: 30px;
  margin-right: 4.16666667vw;
  flex-shrink: 0;
}
.list_con .botm .rgh button {
  margin-left: 20px;
  margin-left: 2.77777778vw;
  color: #6e6e6e;
  font-weight: 500;
}
.wrap_search {
  background-color: #23bf94;
  min-height: 100vh;
  padding-bottom: 40px;
  padding-bottom: 5.55555556vw;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.wrap_search .logo {
  text-align: center;
  padding: 44px 0px;
  padding: 6.11111111vw 0vw;
}
.wrap_search .logo img {
  width: 113px;
  width: 15.69444444vw;
  height: 55px;
  height: 7.63888889vw;
}
.wrap_search .cont {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: calc(100vh - 25.41666667vw);
  background-color: #fff;
  -webkit-border-radius: 45px;
  -moz-border-radius: 45px;
  border-radius: 45px;
  -webkit-border-radius: 6.25vw;
  -moz-border-radius: 6.25vw;
  border-radius: 6.25vw;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
  padding: 50px;
  padding: 6.94444444vw;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.wrap_search .h1 {
  margin-bottom: 30px;
  margin-bottom: 4.16666667vw;
  padding-top: 100px;
  padding-top: 13.88888889vw;
  font-weight: 900;
  font-size: 68px;
  font-size: 9.44444444vw;
  color: #999;
}
.wrap_search .h2 {
  margin-bottom: 30px;
  margin-bottom: 4.16666667vw;
  font-size: 45px;
  font-size: 6.25vw;
  color: #000;
  line-height: 1.2;
  white-space: pre-line;
}
.wrap_search .h3 {
  margin-bottom: 28px;
  margin-bottom: 3.88888889vw;
  font-weight: 700;
  font-size: 30px;
  font-size: 4.16666667vw;
}
.wrap_search .t1 {
  margin-top: 70px;
  margin-top: 9.72222222vw;
  font-weight: 600;
  text-align: center;
  font-size: 24px;
  font-size: 3.33333333vw;
}
.wrap_search .btn-pk {
  width: 100%;
}

.graph {font-size:5.25vw;font-weight:600;color:#000;width:100%;}
.graph span {font-size:4.2vw;color:#999;}
.graph .an_1 {margin-bottom:50px;}
.graph .gp {margin-top:5px;height:30px;background-color:#23bf94;}

.wrap_info {
  background-color: #f3f3f3;
  min-height: calc(100vh - 58.33333333vw);
  -webkit-border-radius: 45px;
  -moz-border-radius: 45px;
  border-radius: 45px;
  -webkit-border-radius: 6.25vw;
  -moz-border-radius: 6.25vw;
  border-radius: 6.25vw;
  padding: 55px 34px;
  padding: 7.63888889vw 4.72222222vw;
  font-size: 28px;
  font-size: 3.88888889vw;
  color: #6e6e6e;
}
.wrap_info .tit {
  margin-bottom: 70px;
  margin-bottom: 9.72222222vw;
  font-weight: 700;
  text-align: center;
  font-size: 36px;
  font-size: 5vw;
  color: #000;
}

.wrap_info .lst_info .card {
	text-align:center;
}

.wrap_info .lst_info .card a {
  display:inline-block;
  color:#FFF;
  font-size:1.15em;
  font-weight:900;
  border-radius:20px;
  margin-top: 15px;
  margin-top: 2.08vw;
  padding:10px 26px;
  box-shadow: 0 6px 20px rgba(35, 190, 147, 0.5);
  border: 2px solid #1a9e7a;
  background: linear-gradient(90deg, #23be93, #1abc9c, #16a085, #1abc9c, #23be93);
  background-size: 200% 100%;
  animation: shineBorder 3s linear infinite;
}
.wrap_info .lst_info .card a:active {
  transform: scale(0.9);
  box-shadow: 0 2px 10px rgba(35, 190, 147, 0.4);
}

.wrap_info .lst_info .grade_icon {

	width:23vw;
	margin:0 auto;
	margin-top: 30px;
	margin-top: 4.1666667vw;
	background-color:#FFF;
	border-radius:50%;
	border:solid 3px #23bf94;
	box-sizing:border-box;
	padding:20px 20px;

}

.wrap_info .lst_info .h1 {
  text-align:center;
  margin-top: 30px;
  margin-top: 4.1666667vw;
}


.wrap_info .lst_info .h1 .l {
  font-size: 28px;
  font-size: 3.88888889vw;
  color: #000;
}
.wrap_info .lst_info .h1 .d {
  font-size: 20px;
  font-size: 2.77777778vw;
  color: #6e6e6e;
}
.wrap_info .lst_info .lst1 {
  border-top: 1px dotted #d8d8d8;
  border-bottom: 1px dotted #d8d8d8;
  padding: 30px 0px;
  padding: 4.16666667vw 0vw;
}
.wrap_info .lst_info .lst1 li {
  padding: 10px 0px;
  padding: 1.38888889vw 0vw;
}
.wrap_info .lst_info .lst1 .btn-pk {
  float: right;
  margin-top: -6px;
  margin-top: -0.83333333vw;
}
.wrap_info .lst_info .b1 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 40px;
  margin-top: 5.55555556vw;
  font-size: 24px;
  font-size: 3.33333333vw;
  font-weight: 500;
}


.wrap_info .lst_info .b2 {
color:#000;
  border-top: 1px dotted #d8d8d8;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 40px;
  margin-top: 5.55555556vw;
  font-size: 24px;
  font-size: 3.33333333vw;
  font-weight: 700;
  padding-top:30px;
  padding-top: 4.25555556vw;
}

.wrap_info .lst_info .b1 .c-black {
  font-weight: 700;
}


.wrap_info .lst_info .grade_graph {
	color:#000;
	margin-top: 40px;
	margin-top: 5.55555556vw;
	margin-bottom: 40px;
	margin-bottom: 5.55555556vw;
}

.wrap_info .lst_info .grade_graph li {
	color:#23bf94;
	margin-top:10px;
	font-size: 24px;
	font-size: 3.33333333vw;
	font-weight: 700;
}

.wrap_info .lst_info .grade_graph li .graph {
	background-color:#c7c7c7;
	height:7px;
	border-radius:3.5px;
	margin-top: 5px;
	margin-top: 0.6944vw;
	overflow: hidden;
}

.wrap_info .lst_info .grade_graph li .graph span {
	display: block;
	background-color:#23bf94;
	width:0%;
	height:100%;
	font-size:0;
}

.wrap_message {
  position: relative;
  padding-top: 135px;
  padding-top: 18.75vw;
}
.wrap_message .head {
  z-index: 1;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.6);
}
.wrap_message .head .tit {
  text-align: center;
  font-weight: 700;
  font-size: 36px;
  font-size: 5vw;
  color: #000;
  line-height: 135px;
  line-height: 18.75vw;
}
.wrap_message .head .btn_back {
  position: absolute;
  left: 0;
  top: 0;
  width: 160px;
  width: 22.22222222vw;
  height: 135px;
  height: 18.75vw;
}
.wrap_message .cont .li {
  position: relative;
  margin: 30px 0px 30px 30px;
  margin: 4.16666667vw 0vw 4.16666667vw 4.16666667vw;
  padding-left: 70px;
  padding-left: 9.72222222vw;
}
.wrap_message .cont .li::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 52px;
  width: 7.22222222vw;
  height: 52px;
  height: 7.22222222vw;
  background-size: cover;
  border: 1px solid #999;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  border-radius: 10px;
  -webkit-border-radius: 1.38888889vw;
  -moz-border-radius: 1.38888889vw;
  border-radius: 1.38888889vw;
}
.wrap_message .cont .lft span {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 52px;
  width: 7.22222222vw;
  height: 52px;
  height: 7.22222222vw;
  background-size: cover;
  border: 1px solid #999;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  border-radius: 10px;
  -webkit-border-radius: 1.38888889vw;
  -moz-border-radius: 1.38888889vw;
  border-radius: 1.38888889vw;
}
.wrap_message .cont .li.li_feed::after {
  background-image: url('../images/ico_message_feed.png');
}
.wrap_message .cont .li.li_recover {
  opacity: 0.6;
}
.wrap_message .cont .li.li_recover .t1 {
  color: #e74c3c;
}
.wrap_message .cont .li.li_recover::after {
  background-image: url('../images/ico_message_feed.png');
}
.wrap_message .cont .li.li_comment::after {
  background-image: url('../images/ico_message_comment.png');
}
.wrap_message .cont .li.li_like::after {
  background-image: url('../images/ico_message_like.png');
}
.wrap_message .cont .li.li_survey::after {
  background-image: url('../images/ico_message_survey.png');
}
.wrap_message .cont .li.li_welcome::after {
  background-image: url('../images/ico_message_welcom.png');
}
.wrap_message .cont .li.li_invite::after {
  background-image: url('../images/ico_message_invite.png');
}
.wrap_message .cont .li.li_walk::after {
  background-image: url('../images/ico_message_walk.png');
}
.wrap_message .cont .li.li_grade::after {
  background-image: url('../images/ico_message_grade.png');
}
.wrap_message .cont .li.li_follow::after {
  background-image: url('../images/ico_message_follow.png');
}
.wrap_message .cont .li.li_guestbook::after {
  background-image: url('../images/ico_message_guestbook.png');
}
.wrap_message .cont .li.li_nickname::after {
  background-image: url('../images/ico_message_grade.png');
}
.wrap_message .cont .li.li_campaign::after {
  background-image: url('../images/ico_message_grade.png');
}
.wrap_message .cont .li.li_prompt::after {
  background-image: url('../images/ico_message_prompt.png');
}
.wrap_message .cont .li.li_hottopic::after {
  background-image: url('../images/ico_message_hottopic.png');
}
.wrap_message .cont .li.li_comeback::after {
  background-image: url('../images/ico_message_comeback.png');
}
.wrap_message .cont .li.li_firstpost::after {
  background-image: url('../images/ico_message_firstpost.png');
}
.wrap_message .cont .li.li_streak::after {
  background-image: url('../images/ico_message_streak.png');
}
.wrap_message .cont .li.li_checklist::after {
  background-image: url('../images/ico_message_checklist.png');
}
.wrap_message .cont .li.li_supporter::after {
  background-image: url('../images/ico_message_supporter.png');
}
.wrap_message .cont .li.li_rps::after {
  content: '✊';
  background: #FFF5F5;
  background-image: none;
  background-size: auto;
  font-size: 24px;
  line-height: 52px;
  line-height: 7.22222222vw;
  text-align: center;
  border-color: #FF6B6B;
}
.wrap_message .cont .li.li_wallet::after {
  content: '💸';
  background: #F0FFF4;
  background-image: none;
  background-size: auto;
  font-size: 24px;
  line-height: 52px;
  line-height: 7.22222222vw;
  text-align: center;
  border-color: #38A169;
}
.wrap_message .cont .t1 {
  margin-bottom: 15px;
  margin-bottom: 2.08333333vw;
  font-weight: 500;
  font-size: 26px;
  font-size: 3.61111111vw;
  color: #4d4d4d;
}
.wrap_message .cont .t2 {
  font-size: 20px;
  font-size: 2.77777778vw;
  color: #6e6e6e;
}

.wrap_wallet .balance {
  background-color: #23bf94;
  -webkit-border-radius: 45px;
  -moz-border-radius: 45px;
  border-radius: 45px;
  -webkit-border-radius: 6.25vw;
  -moz-border-radius: 6.25vw;
  border-radius: 6.25vw;
  padding: 34px 34px;
  padding: 5.72222222vw 5.72222222vw;
  font-size: 28px;
  font-size: 3.88888889vw;
  color: #FFF;
}

.wrap_wallet .balance p {font-size:18px;font-weight:600;line-height:100%;margin-top:20px;}
.wrap_wallet .balance p span {font-size:32px;font-size: 9.88888889vw;font-weight:800;}


.wrap_wallet .points {
  background-color: #70c2d4;
  -webkit-border-radius: 45px;
  -moz-border-radius: 45px;
  border-radius: 45px;
  -webkit-border-radius: 6.25vw;
  -moz-border-radius: 6.25vw;
  border-radius: 6.25vw;
  padding: 34px 34px;
  padding: 5.72222222vw 5.72222222vw;
  font-size: 28px;
  font-size: 3.88888889vw;
  color: #FFF;
  margin-bottom:20px;
}

.wrap_wallet .points p {font-size:18px;;font-weight:600;line-height:100%;margin-top:20px;}
.wrap_wallet .points p span {font-size:32px;font-size: 9.88888889vw;font-weight:800;}
.wrap_wallet .points a {float:right;}

.wrap_wallet .w_address {
  background-color: #e9e9e9;
  -webkit-border-radius: 45px;
  -moz-border-radius: 45px;
  border-radius: 45px;
  -webkit-border-radius: 6.25vw;
  -moz-border-radius: 6.25vw;
  border-radius: 6.25vw;
  padding: 34px 34px;
  padding: 3.22222222vw 5.22222222vw;
  font-size: 25px;
  font-size: 2.8vw;
  color: #000;
  margin:20px 0;
  position:relative;
}

.wrap_wallet .w_address .copys {position:absolute;right:3vw;width:4vw;margin-top:-2px;}


.popup_dim {
  z-index: 1000;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
}
.alertPopup {
  z-index: 1002;
  overflow-y: auto;
  display: none;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-width: 8px;
  border-width: 1.11111111vw;
  border-style: solid;
  border-color: #23be93;
  -webkit-border-radius: 35px;
  -moz-border-radius: 35px;
  border-radius: 35px;
  -webkit-border-radius: 4.86111111vw;
  -moz-border-radius: 4.86111111vw;
  border-radius: 4.86111111vw;
  /*
  .bd(8,solid,transparent);
  background-image: linear-gradient(#fff, #fff), 
  linear-gradient(to right, #23be93 0%,  #23be70 100%);
  background-origin: border-box;
  background-clip: content-box, border-box;
  */
}
.alertPopup .popup {
  width: 580px;
  width: 80.55555556vw;
  padding: 48px 20px 30px 20px;
  padding: 6.66666667vw 2.77777778vw 4.16666667vw 2.77777778vw;
  font-size: 22px;
  font-size: 3.05555556vw;
  line-height: 1.3;
  color: #838383;
}
.alertPopup .popup .txt {
  min-height: 100px;
  min-height: 13.88888889vw;
  text-align: center;
}
.alertPopup .popup .txt strong {
  font-size: 33px;
  font-size: 4.58333333vw;
  line-height: 1.5;
  color: #000;
  font-weight: 600;
}

.alertPopup .popup .txt .tin {
	margin-top: 10px;
}

.alertPopup .popup .txt .mt {
  margin-top: 25px;
  margin-top: 3.47222222vw;
}
.alertPopup .popup .botm {
  display: flex;
  margin-top: 40px;
  margin-top: 5.55555556vw;
}
.alertPopup .popup .botm .bt {
  flex: 1;
  height: 70px;
  height: 9.72222222vw;
  font-weight: 500;
  font-size: 33px;
  font-size: 4.58333333vw;
  line-height: 1.5;
}
.alertPopup .popup .select_reason {
	margin-top:10px;
	text-align:center;
}

.alertPopup .popup .txt .mt .inp_txt {
  width: 86%;
  height: 90px;
  height: 12.5vw;
  padding: 0px 130px 0px 40px;
  padding: 0vw 5.55555556vw 0vw 5.55555556vw;
  line-height: 88px;
  line-height: 12.22222222vw;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
  border-radius: 50px;
  -webkit-border-radius: 6.94444444vw;
  -moz-border-radius: 6.94444444vw;
  border-radius: 6.94444444vw;
  font-size: 24px;
  font-size: 6.33333333vw;
  text-align:right;
}

.alertPopup .popup .txt .mt::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 98%;
  width: 100%;
  height: 100px;
  height: 13.88888889vw;
  background: #FFFFFF;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #ffffff 100%);
}

.popup_dim2 {
  z-index: 1000;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
}

.layerPopup {
	background-color:#000;
	width:100vw;
	height:100vh;
	position: fixed;
	color:#FFF;
	left: 0px;
	left: 0vw;
	top: 0px;
	overflow: hidden;
	z-index: 1001;
	display:none;
}

.layerPopup2 {
	background-color:#FFF;
	width:100vw;
	height:100vh;
	position: fixed;
	color:#FFF;
	left: 0px;
	left: 0vw;
	top: 0px;
	overflow: hidden;
	z-index: 1001;
	display:none;
}

.layerPopup3 {
	background-color:#FFF;
	width:100vw;
	height:100vh;
	position: fixed;
	color:#FFF;
	left: 0px;
	left: 0vw;
	top: 0px;
	overflow: hidden;
	z-index: 1001;
	display:none;
}

.pop_photo {
	height:100%;
}
.pop_photo .viewer {
  height: 100%;  
  align-items: center;
}
.pop_photo .swiper-horizontal {height:100%;}
.pop_photo .swiper-slide {
  display: flex;
  justify-content: center;   /* 가로 중앙 (선택사항) */
  align-items: center;       /* 세로 중앙! 핵심! */
  height: 100%;              /* 필요 시 강제 지정 */
}

.pop_photo .swiper-slide img {
  display: block;
  max-height: 100%;
  max-width: 100%;           /* 필요 시 가로도 제한 */
  height: auto;              /* 비율 유지 */
}

.post-swiper {height:100%;}
.post-swiper .swiper-wrapper, .post-swiper .swiper-slide {height: 100% !important;}


.photo_cont {
	position: fixed;
	bottom:0;
	left: 0;
	right: 0;
	font-size:15px;
	margin:20px;
	z-index:900;
	cursor: pointer;
	pointer-events: auto;
	transition: transform .3s ease, opacity .3s ease;
}

.photo_cont .photo_text {
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.4em;
  transition: all .3s ease;
}

.photo_cont.active {
	transform: translateY(-10%);
}

.photo_cont.active .photo_text {
  -webkit-line-clamp: unset;
  overflow: visible;
}

.dim_layer {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.5);  /* 반투명 검정 */
  z-index: 899;                 /* .photo_cont(900)보다 아래 */
  display: none;
}

.close-btn {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 35px;
  height: 35px;
  cursor: pointer;
  font-size:0;
  z-index:1002;
}

.close-btn::before,
.close-btn::after {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 100%;
  height: 2px;
  background-color: #fff;
  transform-origin: center;
}

.close-btn::before {
  transform: rotate(45deg);
}

.close-btn::after {
  transform: rotate(-45deg);
}


.layerPopup_botm {
  z-index: 1001;
  overflow: hidden;
  position: fixed;
  left: 0px;
  left: 0vw;
  right: 0;
  bottom: -150%;
  display: flex;
  flex-direction: column;
  width: 100%;
  background-color: #fff;
  box-shadow: 0px -2px 4px 0px rgba(0, 0, 0, 0.15);
  -webkit-border-radius: 45px 45px 0px 0px;
  -moz-border-radius: 45px 45px 0px 0px;
  border-radius: 45px 45px 0px 0px;
  -webkit-border-radius: 6.25vw 6.25vw 0vw 0vw;
  -moz-border-radius: 6.25vw 6.25vw 0vw 0vw;
  border-radius: 6.25vw 6.25vw 0vw 0vw;
  -webkit-transition: all 200ms ease-in-out;
  -moz-transition: all 200ms ease-in-out;
  -ms-transition: all 200ms ease-in-out;
  -o-transition: all 200ms ease-in-out;
  transition: all 200ms ease-in-out;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.layerPopup_botm .btn_botm_close {
  width: 100%;
  padding: 30px 0px;
  padding: 4.16666667vw 0vw;
  font-size: 0;
}
.layerPopup_botm .btn_botm_close span {
  display: block;
  width: 77px;
  width: 10.69444444vw;
  height: 9px;
  height: 1.25vw;
  margin: 0 auto;
  background-color: #b9b9b9;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  -webkit-border-radius: 2.77777778vw;
  -moz-border-radius: 2.77777778vw;
  border-radius: 2.77777778vw;
}
.layerPopup_botm .ptit {
  margin-bottom: 50px;
  margin-bottom: 6.94444444vw;
  padding-top: 20px;
  padding-top: 2.77777778vw;
  text-align: center;
  font-weight: 700;
  font-size: 36px;
  font-size: 5vw;
  color: #000;
}
.layerPopup_botm.active {
  bottom: -1px;
  bottom: -0.13888889vw;
}
.layerPopup_botm.pop_comment .scrollY {
  max-height: calc(100vh - 69.44444444vw);
  overflow-y: auto;
}
.layerPopup_botm.pop_comment .botm_send {
  position: relative;
  padding: 20px 46px 50px 46px;
  padding: 2.77777778vw 6.38888889vw 6.94444444vw 6.38888889vw;
}
.layerPopup_botm.pop_comment .botm_send .replyBox {display:none;}

.layerPopup_botm.pop_comment .botm_send .replyBox .reply_box {
	position:relative;
	padding:5px 20px;
	border-radius: 50px;
	-webkit-border-radius: 6.94444444vw;
	-moz-border-radius: 6.94444444vw;
	border-radius: 6.94444444vw;
	background-color:#23BF94;
	color:#FFF;
	margin-bottom:5px;
	display: flex;
	align-items: center;
	line-height: 1.4;
}

.layerPopup_botm.pop_comment .botm_send .replyBox .reply_box span {
	margin-left: auto;   /* ✅ 우측 끝으로 밀기 */
	font-size: 1.5em;
	cursor: pointer;
	line-height: 1;
}
.layerPopup_botm.pop_comment .botm_send .inp_txt {
  width: 100%;
  height: 90px;
  height: 12.5vw;
  padding: 0px 130px 0px 40px;
  padding: 0vw 18.05555556vw 0vw 5.55555556vw;
  line-height: 88px;
  line-height: 12.22222222vw;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
  border-radius: 50px;
  -webkit-border-radius: 6.94444444vw;
  -moz-border-radius: 6.94444444vw;
  border-radius: 6.94444444vw;
  font-size: 24px;
  font-size: 3.33333333vw;
}
.layerPopup_botm.pop_comment .botm_send .btn_send {
  position: absolute;
  right: 46px;
  right: 6.38888889vw;
  width: 130px;
  width: 18.05555556vw;
  height: 90px;
  height: 12.5vw;
}
.layerPopup_botm.pop_comment .botm_send::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 98%;
  width: 100%;
  height: 100px;
  height: 13.88888889vw;
  background: #FFFFFF;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #ffffff 100%);
}
.layerPopup_botm.pop_comment .lst_comment {
  padding: 0px 46px 10px 46px;
  padding: 0vw 6.38888889vw 1.38888889vw 6.38888889vw;
  font-size: 24px;
  font-size: 3.33333333vw;
  color: #6e6e6e;
  line-height: 1.3;
}
.layerPopup_botm.pop_comment .lst_comment .li {
  margin-bottom: 50px;
  margin-bottom: 6.94444444vw;
}

.layerPopup_botm.pop_comment .lst_comment .li.reply {
  margin-bottom:0;
  margin-top: 25px;
  margin-top: 3.4666666vw;
}

.layerPopup_botm.pop_comment .lst_comment .li .tit {
  /*display: flex;*/
  align-items: end;
  margin-bottom: 22px;
  margin-bottom: 3.05555556vw;
}
.layerPopup_botm.pop_comment .lst_comment .li .tit .l {
  margin-right: 30px;
  margin-right: 4.16666667vw;
  font-size: 28px;
  font-size: 3.88888889vw;
  color: #000;
}
.layerPopup_botm.pop_comment .lst_comment .li .tit .l .uid {
  border-bottom: 1px solid #000;
}
.layerPopup_botm.pop_comment .lst_comment .li .tit .r {
  font-size: 20px;
  font-size: 2.77777778vw;
  color: #6e6e6e;
}

.layerPopup_botm.pop_comment .lst_comment .li .tit .rt {
	float:right;
	color:#FF0000;
}

.layerPopup_botm.pop_comment .lst_comment .li .tit .rt span {
	color:#000000;
}

.layerPopup_botm.pop_comment .lst_comment .li .im {
  margin-bottom: 18px;
  margin-bottom: 2.5vw;
  max-width: 320px;
  max-width: 44.44444444vw;
}
/* 피드 상세 팝업 - 댓글 영역 스타일 (pop_comment 패턴 재사용) */
.layerPopup_botm.pop_feed_detail .scrollY {
  max-height: calc(100vh - 69.44444444vw);
  overflow-y: auto;
}
.layerPopup_botm.pop_feed_detail .botm_send {
  position: relative;
  padding: 20px 46px 50px 46px;
  padding: 2.77777778vw 6.38888889vw 6.94444444vw 6.38888889vw;
}
.layerPopup_botm.pop_feed_detail .botm_send .replyBox {display:none;}
.layerPopup_botm.pop_feed_detail .botm_send .replyBox .reply_box {
  position:relative;
  padding:5px 20px;
  border-radius: 50px;
  -webkit-border-radius: 6.94444444vw;
  -moz-border-radius: 6.94444444vw;
  border-radius: 6.94444444vw;
  background-color: #f2f2f2;
  font-size:22px;
  font-size:3.0555vw;
  display:flex;
  align-items:center;
  margin-bottom:10px;
}
.layerPopup_botm.pop_feed_detail .botm_send .replyBox .reply_box span {
  margin-left: auto;
  font-size: 1.5em;
  cursor: pointer;
  line-height: 1;
}
.layerPopup_botm.pop_feed_detail .botm_send .inp_txt {
  width: 100%;
  height: 90px;
  height: 12.5vw;
  padding: 0px 130px 0px 40px;
  padding: 0vw 18.05555556vw 0vw 5.55555556vw;
  border: 1px solid #e0e0e0;
  border-radius: 50px;
  -webkit-border-radius: 6.94444444vw;
  -moz-border-radius: 6.94444444vw;
  border-radius: 6.94444444vw;
  font-size: 26px;
  font-size: 3.61111111vw;
}
.layerPopup_botm.pop_feed_detail .botm_send .btn_send {
  position: absolute;
  right: 46px;
  right: 6.38888889vw;
  width: 130px;
  width: 18.05555556vw;
  height: 90px;
  height: 12.5vw;
}
.layerPopup_botm.pop_feed_detail .botm_send::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 98%;
  width: 100%;
  height: 30px;
  background: linear-gradient(transparent, rgba(255,255,255,0.9));
  pointer-events: none;
}
.layerPopup_botm.pop_feed_detail .lst_comment {
  padding: 0px 46px 10px 46px;
  padding: 0vw 6.38888889vw 1.38888889vw 6.38888889vw;
  font-size: 24px;
  font-size: 3.33333333vw;
  color: #6e6e6e;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li {
  margin-bottom: 50px;
  margin-bottom: 6.94444444vw;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li.reply {
  margin-bottom:0;
  margin-top: 25px;
  margin-top: 3.4666666vw;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li .tit {
  align-items: end;
  margin-bottom: 22px;
  margin-bottom: 3.05555556vw;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li .tit .l {
  margin-right: 30px;
  margin-right: 4.16666667vw;
  font-size: 28px;
  font-size: 3.88888889vw;
  color: #000;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li .tit .l .uid {
  border-bottom: 1px solid #000;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li .tit .r {
  font-size: 20px;
  font-size: 2.77777778vw;
  color: #6e6e6e;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li .tit .rt {
  float:right;
  color:#FF0000;
}
.layerPopup_botm.pop_feed_detail .lst_comment .li .tit .rt span {
  color:#000000;
}
.layerPopup_botm.pop_feed_detail .lst_comment .badge-wrap {
  display: inline-flex;
  vertical-align: middle;
  margin-right: 5px;
  margin-right: 0.69444444vw;
  gap: 1px;
}
.layerPopup_botm.pop_feed_detail .lst_comment .badge-wrap em img {
  width: 18px;
  width: 5vw;
  height: auto;
}
/* 댓글 내 뱃지 스택 겹침 */
.lst_comment .badge-stack .badge-icon {
  margin-left: -4px;
}
.lst_comment .badge-stack .badge-icon:first-child {
  margin-left: 0;
}
.lst_comment .badge-stack .badge-icon img {
  width: 16px;
  height: 16px;
}
.layerPopup_botm.pop_write .write_con {
  
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.layerPopup_botm.pop_write .btn_send {
  position: absolute;
  right: 40px;
  right: 5.55555556vw;
  top: -100px;
  top: 10.88888889vw;
  width: 60px;
  width: 8.33333333vw;
  height: 60px;
  height: 8.33333333vw;
}
.layerPopup_botm.pop_write .textarea1 {
  border: 0;
  height: 450px;
  height: 52.22222222vw;
  padding: 0px 46px;
  padding: 0vw 6.38888889vw;
  overflow-y: scroll;
  font-size: 30px;
  font-size: 4.16666667vw;
  line-height: 1.5;
}
.layerPopup_botm.pop_write .lst_photo {
  position: relative;
  background-color: #dedede;
  border-top: 1px solid #979797;
  display: flex;
  flex-direction: row-reverse;
  height: 120px;
  height: 16.66666667vw;
}
.layerPopup_botm.pop_write .lst_photo .filebtn {
  min-width: 130px;
  min-width: 18.05555556vw;
}
.layerPopup_botm.pop_write .lst_photo .file_list {
  overflow-x: auto;
  width: 100%;
  padding: 16px 0px;
  padding: 2.22222222vw 0vw;
  display: inline-flex;
  white-space: nowrap;
}
.layerPopup_botm.pop_write .lst_photo .file_list .filebox {
  position: relative;
  margin-left: 20px;
  margin-left: 2.77777778vw;
  min-width: 84px;
  min-width: 11.66666667vw;
  height: 84px;
  height: 11.66666667vw;
  border: 1px solid #23be93;
}
.layerPopup_botm.pop_write .lst_photo .file_list .filebox > span {
  display: block;
  width: 100%;
  height: 100%;
  background-position: center center;
  background-size: cover;
}
.layerPopup_botm.pop_write .lst_photo .file_list .btn_close_del {
  position: absolute;
  right: -10px;
  right: -1.38888889vw;
  top: -10px;
  top: -1.38888889vw;
}
.layerPopup_botm.pop_terms {
  padding-bottom: 5vh;
}
.layerPopup_botm.pop_terms .terms_con {
  padding: 0 5%;
  font-size: 26px;
  font-size: 3.61111111vw;
  line-height: 1.6;
  white-space: pre-line;
  height: 65vh;
  overflow-y: auto;
}
.filebtn {
  position: relative;
  display: inline-block;
  vertical-align: top;
  width: 100px;
  width: 13.88888889vw;
  height: 120px;
  height: 16.66666667vw;
  background-image: url("../images/ico_fileadd.png");
  background-position: center center;
  background-repeat: no-repeat;
  font-size: 0;
  -webkit-background-size: 69px;
  background-size: 69px;
  -webkit-background-size: 9.58333333vw;
  background-size: 9.58333333vw;
}
.filebtn input[type="file"] {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.filebtn label {
  display: block;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.inp_btn {display:flex;margin-top:30px;text-align:center;}

.inp_checkbox input + label {color:#FF0000;}

.inp_radiotx input + span {text-align:center;}

#loginProcessingOverlay {
  display: none;
  position: fixed;
  z-index: 9999;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  text-align: center;
  padding-top: 30vh;
  color: #fff;
}

.spinner {
  width: 48px;
  height: 48px;
  margin: 0 auto;
  border: 5px solid #fff;
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom:10px;
}

@keyframes expandBox {
	0% { opacity: 0; }
	100% { opacity: 1; }
}

.campaign {
	opacity: 0;
	animation: expandBox 0.6s ease-out forwards;
}

.campaign_box {
	background-color:#23bf94;
	border-radius:20px;
	border-radius:2.77777778vw;
	margin-bottom:35px;
	margin-bottom:4.86111111vw;
	padding-bottom:20px;
	padding-bottom:2.77777778vw;
	color:#FFF;
}

.campaign_box .tit {
	margin: 0 25px;
    margin: 0 3.47222222vw;
	padding: 27px 0;
	padding: 3.75vw 0;
	font-size: 35px;
	font-size: 4.861111vw;
	font-weight:700;
	border-bottom:solid 1px rgba(0, 0, 0, 0.1);
}

.campaign_box .cont {
	margin: 0 25px;
    margin: 0 3.47222222vw;
	padding: 20px 0;
	padding: 2.77777778vw 0;
	font-size: 22px;
    font-size: 3.35555556vw;
}

.campaign_box .tags {
	margin: 0 25px;
    margin: 0 3.47222222vw;
	padding: 20px 0;
	padding: 2.77777778vw 0;
	font-size: 32px;
	font-size: 4.44444444vw;
}

.campaign_box .btns {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px; 
	margin: 0 25px;
    margin: 0 3.47222222vw;
}

.campaign_box .btns .col {
	text-align:center;
	background: #9becd5;
	border-radius:15px;
	border-radius: 2.08333333vw;
	font-size: 27px;
	font-size: 3.75vw;
	padding: 20px 0;
	padding: 2.77777778vw 0;
	color:#0f6e54;
	font-weight:600;
}

.campaign_box .stats {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 10px; 
	margin: 0 25px;
    margin: 0 3.47222222vw;
	border-top:solid 1px #6ad4b6;
	padding-top:10px;
}

.campaign_box .stats .col {
	padding: 3px 0;
	padding: 0.5vw 0;
	font-size: 25px;
    font-size: 3.95555556vw;
	background-repeat:no-repeat;
	background-size:auto 100%;
	padding-left:26px;
}

.campaign_box .stats .col:first-child {
	background-image:url('/images/stat_icon_01.png');
}
.campaign_box .stats .col:nth-child(2) {
  background-image:url('/images/stat_icon_02.png');
}
.campaign_box .stats .col:last-child {
	background-image:url('/images/stat_icon_03.png');
}

.camp_color1 {background-color:#23bf94;}
.camp_color1 a {color:#FFF;}

.camp_color2 {background-color:#8fcce6;}
.camp_color2 a {color:#FFF;}

.camp_color3 {background-color:#9da1ea;}
.camp_color3 a {color:#FFF;}

.camp_color4 {background-color:#c19ae6;}
.camp_color4 a {color:#FFF;}

.camp_color5 {background-color:#bf23ac;}
.camp_color5 a {color:#FFF;}

.camp_color6 {background-color:#f2a8e0;}
.camp_color6 a {color:#FFF;}

.camp_color7 {background-color:#f29caf;}
.camp_color7 a {color:#FFF;}

.camp_color8 {background-color:#f2eb8c;}
.camp_color8 a {color:#000;}

.camp_color9 {background-color:#9ce6a8;}
.camp_color9 a {color:#FFF;}


.confetti{ position:absolute; top:0; transform: translateY(-10vh); will-change: transform, opacity;}
.confetti .sway{ display:inline-block; will-change: transform; }
.confetti .piece{ display:block; border-radius:2px; opacity:1; will-change: transform, opacity; }

.coin_box {
	text-align:center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width:90vw;
}
.coin_box .coins {width:30%;margin:0 auto;}
.coin_box .txts {
	text-align:center;
	font-size: 35px;
	font-size: 4.861111vw;
	color:#000;
	margin-top:45px;
	margin-top:8.47222222vw;
}
.coin_box .points {
	text-align:center;
	font-size: 35px;
	font-size: 4.861111vw;
	font-weight: 900;
	color:#999999;
	margin-top:25px;
	margin-top:4.47222222vw;
}

.coin_box .points span {
	font-size: 11.3333vw;
	color:#23bf94;
}

.coin_box .btn-pk {
	position:relative;
	width: 80%;
	margin-top: 8.47222222vw;
	margin-bottom: 4.16666667vw;
}

.btn_pop_close {display:block;width: 50px; height: 50px;margin:0 auto; margin-top:25px;font-size: 0; background-color: #23bf94;border-radius:50%;}
.btn_pop_close span {position: relative; width: 30px; height: 2px; background-color: #FFF; transform:rotate(45deg);}
.btn_pop_close span:after {content:""; position: absolute; left: 0; top: 0; width: 100%; height: 2px; background-color: #FFF; transform:rotate(-90deg);}

.upgrade_box {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width:90vw;
}
.upgrade_box .grade_img {
	position:absolute;
	width:30vw;
	left:50%;
	top:-15vw;
	transform: translateX(-50%);
	background-color:#FFF;
	border-radius:50%;
	box-sizing:border-box;
	padding:20px 20px;
	box-shadow: 0 7px 6px 4px rgba(0,0,0,0.2);
}

.upgrade_box .green_box {
	padding:7vw;
	background-color:#23bf94;
	border-radius:20px;
	color:#FFF;
	font-size: 30px;
	font-size: 4.167vw;
}

.upgrade_box .green_box h2 {
	margin-top:30px;
	margin-bottom:20px;
	display: flex;
	align-items: center;
	font-size: 30px;
	font-size: 4.167vw;
	font-weight: 700;
}
.upgrade_box .green_box h2 .line {
  flex: 1;
  height: 1px;
  background: #FFF;
}
.upgrade_box .green_box h2 .text {
  margin: 0 10px;
  white-space: nowrap;
}

.upgrade_box p {
	text-align:center;
	margin-top:50px;
}

.benefit_box li {
	background-color:#FFF;
	display: flex;
	justify-content: space-between; /* 좌우 끝으로 배치 */
	align-items: center;            /* 세로 중앙 정렬 */
	padding: 10px 15px;                /* 양옆 여백 */
	border-radius:20px;
	color:#000;
	font-size: 24px;
	font-size: 3.272vw;
	font-weight:700;
	margin:10px 0;
}

.benefit_box li b {color:#23bf94;}
.benefit_box li .point {color:#939393;}

/*카드 섹션*/


.card_container {
	min-height: 100vh;          /* 화면 전체 높이 */
  display: flex;
  justify-content: center;    /* 가로 중앙 */
  align-items: center;        /* 세로 중앙 */
  margin: 0; 
}

.iframe_container {
   height: 100%;
  margin: 0;
  overflow: auto;  /* hidden → auto: 3:4 비율 폰에서 스크롤 가능 */
}

.iframe_container .iframe-full{
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  border: 0;
  overflow: auto;  /* iframe 내부 스크롤 허용 */
}

.card_stage{
  position: relative;
  display: inline-block;
}

.wrap_card{
  grid-area: 1 / 1;           /* 아래 card_box와 같은 그리드 영역에 겹침 */
}
.wrap_card img{
  width: 100vw;               /* 가로 꽉 */
  height: auto;               /* 비율 유지 */
  display: block;
}

.card_box{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;            /* wrap_card 이미지 높이와 동일 */
  box-sizing: border-box;
  color: #fff;
}

.box-glass{
  background: rgba(0,0,0,0.45); /* 반투명 */
  -webkit-backdrop-filter: saturate(120%) blur(2px);
  backdrop-filter: saturate(120%) blur(2px);
  border-radius: 10px;
  box-shadow: 0 6px 16px rgba(0,0,0,0.18);
  color: #fff;                /* 텍스트는 불투명 */
}



.c_box_border {
  border: 3px solid transparent;       
  border-radius: 20px;                    
  
  background:
    linear-gradient(rgba(255,255,255,0.1), rgba(255,255,255,0.1)) padding-box,
    linear-gradient(
      135deg,
      #d9d9d9 0%,
      #f5f5f5 20%,
      #c0c0c0 40%,
      #ffffff 60%,
      #bfbfbf 80%,
      #e6e6e6 100%
    ) border-box; 

  /* 입체감 (엠보스) */
  box-shadow:
    inset -1px -1px 2px rgba(255,255,255,0.6), 
    inset 1px 1px 2px rgba(0,0,0,0.4),     
    2px 2px 6px rgba(0,0,0,0.3);              

  background-size: 200% 200%;
}


.c_box_head{
  position: absolute;
  inset: 10px 10px auto 10px;
  padding: 12px 14px;
  font-weight: 700;
  font-size: 1.7rem;
  border-radius: 35px;
  color: #109a56;
  animation: shineBorder 7s linear infinite;
  text-align:center;
	background-image:
	linear-gradient(rgba(255,255,255,0.45), rgba(255,255,255,0.45)), 
	linear-gradient(
	  120deg,
	  #d9d9d9,
	  #f5f5f5,
	  #c0c0c0,
	  #ffffff,
	  #bfbfbf,
	  #e6e6e6
	); /* 은박 느낌 */
}
.c_box_head{ composes: box-glass; }


.c_box_foot{
  --gap: 8px;
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  display: flex;
  flex-direction: column;   
  gap: var(--gap);
}
.c_box_foot > .foot_profile,
.c_box_foot > .foot_txt{
	background: rgba(255,255,255,0.6);
	color:#525252;
	padding: 10px 12px;
	border-radius: 20px;
	line-height: 1.45;
	font-size: 1.1rem;
  animation: shineBorder 7s linear infinite;
}

.c_box_foot > .foot_profile p,
.c_box_foot > .foot_txt p {
	font-size:1.3em;
  color: #109a56;
}

.c_box_items{
  position: relative;
  width: 30%;
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-left:auto;
}
.c_box_items > div{
  background: rgba(0,0,0,0.45);
  border-radius: 10px;
  backdrop-filter: saturate(120%) blur(2px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.18);
  padding: 8px 10px;
  text-align: center;
  font-size: 0.9rem;
}


.uploadModal {position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.8); z-index:999999; align-items:center; justify-content:center;}
.uploadModal .up_pop {background:#fff; padding:40px 50px; border-radius:15px; text-align:center;font-size:15px; color:#666;}
.uploadModal .up_pop p {font-size:20px; font-weight:bold; margin-bottom:15px;}

/* 뱃지 스택 (메달 겹침 효과) */
.badge-stack {
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  vertical-align: middle;
}
.badge-stack .badge-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: -6px;
  position: relative;
  font-style: normal;
  cursor: pointer;
}
.badge-stack .badge-icon:first-child {
  margin-left: 0;
}
.badge-stack .badge-icon img {
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1.5px solid #fff;
  box-shadow: 0 1px 2px rgba(0,0,0,0.1);
  object-fit: contain;
  background: #fff;
}

/* 프로필/내정보 뱃지 */
.myinfo-badges {
  text-align: center;
  margin: 15px 0;
}
.myinfo-badges .badge-stack .badge-icon {
  margin-left: -14px;
}
.myinfo-badges .badge-stack .badge-icon:first-child {
  margin-left: 0;
}
.myinfo-badges .badge-stack .badge-icon img,
.myinfo-badges em img {
  width: 50px !important;
  height: 50px !important;
  border-width: 2.5px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.12);
}

/* ========================================
   Solflare 지갑 연동 페이지
   ======================================== */
.wrap_solflare .sol_points {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 6.25vw;
  padding: 5.72222222vw;
  font-size: 3.88888889vw;
  color: #FFF;
  margin-bottom: 20px;
}
.wrap_solflare .sol_points p {
  font-size: 18px;
  font-weight: 600;
  line-height: 100%;
  margin-top: 20px;
}
.wrap_solflare .sol_points p span {
  font-size: 32px;
  font-size: 9.88888889vw;
  font-weight: 800;
}
.wrap_solflare .sol_wallet {
  background-color: #1a1a2e;
  border-radius: 6.25vw;
  padding: 5.72222222vw;
  color: #FFF;
  margin-bottom: 20px;
}
.wrap_solflare .sol_wallet .sol_title {
  font-size: 3.6vw;
  font-weight: 600;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.wrap_solflare .sol_wallet .sol_title img {
  width: 24px;
  height: 24px;
}
.wrap_solflare .sol_address {
  background-color: rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 12px 15px;
  font-size: 2.8vw;
  color: #ccc;
  margin-bottom: 15px;
  position: relative;
  word-break: break-all;
}
.wrap_solflare .sol_address .sol_copy {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 4vw;
  cursor: pointer;
  opacity: 0.7;
}
.wrap_solflare .sol_address .sol_copy:hover {
  opacity: 1;
}
.wrap_solflare .sol_buttons {
  display: flex;
  gap: 10px;
}
.wrap_solflare .sol_buttons button {
  flex: 1;
  padding: 12px 0;
  border-radius: 12px;
  border: none;
  font-size: 3.2vw;
  font-weight: 600;
  cursor: pointer;
}
.wrap_solflare .btn_sol_install {
  background: linear-gradient(135deg, #FF6B35, #FFC107);
  color: #FFF;
  padding: 14px 0;
  border-radius: 12px;
  border: none;
  font-size: 3.6vw;
  font-weight: 700;
  cursor: pointer;
  width: 100%;
}
.wrap_solflare .btn_sol_connect {
  background: linear-gradient(135deg, #9945FF, #14F195);
  color: #FFF;
  padding: 14px 0;
  border-radius: 12px;
  border: none;
  font-size: 3.6vw;
  font-weight: 700;
  cursor: pointer;
  width: 100%;
}
.wrap_solflare .btn_sol_withdraw {
  background-color: #14F195;
  color: #000;
}
.wrap_solflare .btn_sol_disconnect {
  background-color: rgba(255,255,255,0.15);
  color: #aaa;
}
.wrap_solflare .sol_back {
  text-align: center;
  margin-top: 20px;
}
.wrap_solflare .sol_back a {
  color: #888;
  font-size: 2.8vw;
  text-decoration: none;
}

/* Solflare 출금 팝업 */
.alertPopup .sol_fee_info {
  background-color: #f5f5f5;
  border-radius: 10px;
  padding: 12px 15px;
  margin-top: 12px;
  font-size: 13px;
  color: #555;
  line-height: 1.6;
}
.alertPopup .sol_fee_info .fee_row {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
}
.alertPopup .sol_fee_info .fee_row:last-child {
  margin-bottom: 0;
}
.alertPopup .sol_fee_info .fee_label {
  color: #888;
}
.alertPopup .sol_fee_info .fee_value {
  font-weight: 600;
  color: #333;
}

/* Solflare 출금 프로그레스 */
.sol_progress_wrap {
  padding: 0 10px;
}
.sol_progress_bar {
  width: 100%;
  height: 8px;
  background: #e8e5f3;
  border-radius: 4px;
  overflow: hidden;
}
.sol_progress_fill {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, #AB9FF2, #8B7FD2);
  border-radius: 4px;
  transition: width 0.3s ease;
  position: relative;
}
.sol_progress_fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  animation: sol_shimmer 1.5s infinite;
}
@keyframes sol_shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.sol_progress_pct {
  margin-top: 8px;
  font-size: 3.6vw;
  font-weight: 700;
  color: #AB9FF2;
}
