@charset "UTF-8";
.badge {
  flex-shrink: 0;
  display: inline-block;
  width: 1rem;
  height: 1rem;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 50%;
}
.badge.auth-local {
  background-image: url(../images/new/auth_icon_b.svg);
}
.badge.auth-kfoba {
  background-image: url(../images/new/auth_icon_k.svg);
}
.badge.auth-default {
  background-image: url(../images/new/auth_icon_d.svg);
}

.local-bs {
  display: none;
}

@media screen and (min-width: 1200px) {
  .local-bs {
    flex: 0 0 302px;
    height: 400px;
    display: flex;
    flex-direction: column;
    padding: 4rem 1rem;
    gap: 1.75rem;
    border-radius: 0.625rem;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    background: url(../images/new/bg_local_bs.png) center no-repeat;
    background-size: 100%;
  }
  .local-bs_finder {
    position: relative;
  }
  .local-bs_finder .tooltip {
    position: absolute;
    right: -6px;
    bottom: 32px;
  }
  .local-bs_finder label {
    display: block;
    color: #ffffff;
    font-size: 1.125rem;
    line-height: 1.5rem;
    margin-bottom: 0.5rem;
  }
  .local-bs_finder .btn,
  .local-bs_finder .select {
    width: 100%;
  }
  .local-bs_cnt {
    color: #F5F5F5;
    font-size: 2rem;
    line-height: 2.5rem;
    font-weight: 400;
    text-shadow: 0 4px 4px rgba(0, 0, 0, 0.5);
  }
  .local-bs_cnt strong {
    color: #ffe100;
    font-weight: 600;
  }
}
.bookstore-search .search-form {
  flex: 1 0 99%;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  padding: 1rem;
}
.bookstore-search .search-form .select {
  flex: 1 0 45%;
}
.bookstore-search .search-form .text-box {
  flex: 1 0 99%;
}
.bookstore-search .filters {
  width: 100%;
  min-width: 0;
  flex: 1 1 100%;
  padding: 0.5rem 1rem;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  /* 스크롤은 유지, 스크롤바만 숨김 */
  scrollbar-width: none;
  -ms-overflow-style: none;
  background-color: #EEEEEE;
  border-top: 1px solid #E0E0E0;
  border-bottom: 1px solid #E0E0E0;
}
.bookstore-search .filters::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}
.bookstore-search .filters.scroll-x {
  overscroll-behavior-x: contain;
}
.bookstore-search .filters-inner {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.125rem;
  width: max-content;
  min-height: 2rem;
}
.bookstore-search button {
  margin-left: auto;
}
.bookstore-lists {
  height: calc(100vh - 96px);
  display: flex;
  flex-wrap: wrap;
}
.bookstore-lists .bs-area {
  position: relative;
  flex: 0 0 50%;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.bookstore-lists .bs-area_item {
  background-color: #FAFAFA;
  border-right: 1px solid #EEEEEE;
  border-bottom: 1px solid #EEEEEE;
  position: relative;
  z-index: 2;
  height: 2.5rem;
}
.bookstore-lists .bs-area_item .btn-text {
  text-decoration: none;
  color: #757575;
  font-weight: 400;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  padding: 0.625rem;
  width: 100%;
}
.bookstore-lists .bs-area_item.on {
  border-right-color: #ffffff;
  background-color: #ffffff;
}
.bookstore-lists .bs-area_item.on .btn-text {
  color: #7E37BE !important;
  font-weight: 500;
}
.bookstore-lists .bs-area_fav {
  flex: 0 0 auto;
}
.bookstore-lists .bs-area_box {
  display: flex;
  flex: 1;
  min-height: 0;
}
.bookstore-lists .bs-area_sido, .bookstore-lists .bs-area_sigungu {
  height: 100%;
  min-height: 0;
  overflow-y: auto;
  position: relative;
}
.bookstore-lists .bs-area_sido {
  flex: 0 1 44%;
  min-width: 5rem;
}
.bookstore-lists .bs-area_sido::after {
  content: "";
  position: absolute;
  width: 1px;
  height: 100%;
  background-color: #EEEEEE;
  right: 0;
}
.bookstore-lists .bs-area_sido.expand {
  flex: 1 0 100%;
}
.bookstore-lists .bs-area_sigungu {
  flex: 1;
}
.bookstore-lists .bs-area_sigungu .bs-area_item {
  background-color: #ffffff;
}
.bookstore-lists .bs-area_sigungu .bs-area_item .btn-text {
  color: #000000;
}
.bookstore-lists .bs-lists {
  flex: 1;
  height: 100%;
  overflow-y: auto;
}
.bookstore-lists .bs-lists .bs-info {
  border-bottom: 1px solid #EEEEEE;
}
.bookstore-lists .bs-lists .bs-mini_set {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0 0.625rem;
  font-size: 0.8125rem;
  height: 2.5rem;
  border-bottom: 1px solid #EEEEEE;
}
.bookstore-lists .bs-lists .bs-mini_set em {
  font-weight: 500;
  color: #7E37BE;
}
.bookstore-map {
  position: relative;
  height: calc(100vh - 202px);
  overflow: hidden;
}
.bookstore-map #map {
  position: relative;
  z-index: 1;
}
.bookstore-map .btn-map.abs {
  position: absolute;
  z-index: 5;
  left: 50%;
  transform: translateX(-50%);
}
.bookstore-map .btn-map.abs.dark {
  bottom: 0.625rem;
}
.bookstore-map .btn-map.abs.light {
  top: 0.625rem;
}
.bookstore-map .btn-map.abs.circle {
  left: auto;
  right: 1rem;
  transform: translateX(0);
}
.bookstore-map .btn-map.abs.circle.fav {
  bottom: 3.5rem;
}
.bookstore-map .btn-map.abs.circle.loc {
  bottom: 0.625rem;
}
.bookstore-cards {
  position: relative;
}

@media screen and (min-width: 1200px) {
  .bookstore-search {
    border: 1px solid #EEEEEE;
    margin-bottom: 1rem;
  }
  .bookstore-search .search-form {
    flex-wrap: nowrap;
  }
  .bookstore-search .search-form .select {
    flex: 0 0 15rem;
    height: 3rem;
  }
  .bookstore-search .search-form .text-box {
    flex: 1;
  }
  .bookstore-search .filters-inner {
    gap: 0.25rem;
  }
  .bookstore-search .filters .checkbox-b input[type=checkbox] + span {
    height: 2.5rem;
  }
  .bookstore-cards {
    height: auto !important;
    display: flex;
    flex-wrap: wrap;
    gap: 0 1.5rem;
  }
  .bookstore-cards .bs-list_item {
    flex: 1 0 48%;
  }
  .bookstore-cards.has-open-time {
    align-items: flex-start;
  }
}
.bs-finder2 {
  display: flex;
}
.bs-finder2 .bookstore-lists {
  display: none;
  flex: 1;
  height: calc(100vh - 218px);
  overflow-y: auto;
}
.bs-finder2 .bookstore-lists .bs-info {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.bs-finder2 .bookstore-map {
  flex: 1;
}

@media screen and (min-width: 1200px) {
  .bs-finder2 {
    border: 1px solid #E0E0E0;
  }
  .bs-finder2 .bookstore-lists {
    max-height: 43.75rem;
    height: 43.75rem;
    display: block;
    flex: 0 0 22.5rem;
    border-right: 1px solid #E0E0E0;
  }
  .bs-finder2 .bookstore-map {
    max-height: 43.75rem;
  }
}
.m-area_box .btn-area, .m-area_box .btn-area2 {
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  color: #757575;
  background-color: #FAFAFA;
  padding: 0 0.625rem;
  height: 2.5rem;
  cursor: pointer;
  display: block;
  width: 100%;
}
.m-area_box .btn-area2 {
  color: #000000;
  background-color: #ffffff;
}
.m-area_box .area-lists {
  display: flex;
  flex-wrap: wrap;
}
.m-area_box .area-lists li {
  flex: 1 0 48%;
  border-bottom: 1px solid #EEEEEE;
}
.m-area_box .area-lists li:last-of-type, .m-area_box .area-lists li:nth-last-of-type(2) {
  border-bottom: 0;
}
.m-area_box .area-lists li.on .btn-area2 {
  color: #7E37BE;
  font-weight: 500;
}
.m-area_box .aoi-box {
  background-color: #ffffff;
  border-top: 1px solid #EEEEEE;
  border-bottom: 1px solid #EEEEEE;
  padding: 1rem 0;
  margin-left: -1rem;
  margin-right: -1rem;
}
.m-area_box .aoi-box_hd {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0 0.625rem 0.5rem;
}
.m-area_box .aoi-box_hd .ttl {
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
}
.m-area_box .aoi-box_hd .icon {
  cursor: pointer;
}
.m-area_box .aoi-box .aoi-list {
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0 0.625rem;
}
.m-area_box .aoi-box .aoi-list .btn {
  height: 2.5rem;
  flex: 0 0 auto;
}
.m-area_box .aoi-box .empty-txt {
  padding: 0.625rem 0;
  color: #757575;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.m-area_txt {
  color: #424242;
  margin: 0.5rem 0 0.625rem;
  font-size: 0.75rem;
  line-height: 1rem;
}
.m-area_items {
  display: flex;
  border: 1px solid #EEEEEE;
  height: 52.6vh;
}
.m-area_item {
  border-bottom: 1px solid #EEEEEE;
  border-right: 1px solid #EEEEEE;
}
.m-area_item:last-of-type {
  border-bottom: 0;
}
.m-area_item.on {
  border-right: 1px solid #ffffff;
}
.m-area_item.on .btn-area {
  background-color: #ffffff;
  color: #7E37BE;
  font-weight: 500;
}
.m-area_d1 {
  flex: 1;
  max-width: 100px;
  overflow-y: auto;
}
.m-area_d2 {
  flex: 1;
  overflow-y: auto;
}

@media screen and (min-width: 1200px) {
  .m-area_items {
    height: 38vh;
  }
}
.bs-target {
  background-color: #282D38;
  color: #ffffff;
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.375rem;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 500;
}
.bs-target .info {
  flex: 1;
  min-width: 0;
}
.bs-target .info-grp {
  margin-bottom: 4px;
}
.bs-target .info .empty {
  font-size: 1rem;
  color: #ffffff;
}
.bs-target .info .name {
  display: block;
  width: 100%;
  font-size: 1rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bs-target .info .lb {
  display: none;
}
.bs-target .info .addr {
  display: block;
  font-size: 0.8125rem;
  color: #EEEEEE;
}
.bs-target .btn-text {
  flex-shrink: 0;
  color: #ffffff;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
}

@media screen and (min-width: 1200px) {
  .bs-target {
    background-color: #F5F3FE;
    border: 1px solid #EDE7F6;
    border-radius: 10px;
    position: relative;
  }
  .bs-target .info-grp {
    display: flex;
    align-items: center;
  }
  .bs-target .info .empty {
    font-size: 0.8125rem;
    line-height: 1.0625rem;
    color: #643BC6;
  }
  .bs-target .info .lb {
    display: block;
    color: #757575;
    font-size: 0.8125rem;
    line-height: 1.0625rem;
    font-weight: 400;
    margin-bottom: 4px;
  }
  .bs-target .info .name {
    width: auto;
    align-items: center;
    color: #643BC6;
  }
  .bs-target .info .addr {
    color: #643BC6;
  }
  .bs-target .btn-text {
    color: #424242;
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
}
.bs-status {
  display: inline-flex;
  align-items: center;
  font-weight: 500;
  font-size: 0.8125rem;
  gap: 3px;
}
.bs-status::before {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
}
.bs-status.open::before {
  background-color: #4CAF50;
}
.bs-status.closed::before {
  background-color: #757575;
}
.bs-status.holiday::before {
  background-color: #B71C1C;
}

.map-store {
  position: relative;
  padding-bottom: 4px;
  filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.14));
  z-index: 50;
}
.map-store_inner {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background-color: #ffffff;
  border-radius: 1.25rem;
  padding: 0.375rem 0.625rem;
  font-size: 0.75rem;
  font-weight: 400;
  position: relative;
  z-index: 2;
}
.map-store_inner .stock {
  font-weight: 500;
  color: #7E37BE;
}
.map-store::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-radius: 3px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  background-color: #ffffff;
  z-index: 1;
}
.map-store.active {
  z-index: 100;
}
.map-store.active .map-store_inner {
  background-color: #8A64E6;
  color: #ffffff;
  font-weight: 500;
}
.map-store.active .map-store_inner .stock {
  color: #FFE100;
}
.map-store.active::after {
  background-color: #8A64E6;
}
.map-store.off .map-store_inner {
  background-color: #CED3E0;
  color: #757575;
}
.map-store.off::after {
  background-color: #CED3E0;
}

.user-marker {
  width: 50px;
  height: 50px;
  position: relative;
}
.user-marker::before, .user-marker::after {
  content: "";
  display: block;
  border-radius: 50%;
  position: absolute;
}
.user-marker::before {
  width: 6px;
  height: 6px;
  background-color: #ffffff;
  border: 9px solid #6938D3;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 2;
}
.user-marker::after {
  width: 100%;
  height: 100%;
  background: #B795FF;
  animation: pulse 1.4s ease-in-out infinite;
  z-index: 1;
}

@keyframes pulse {
  0% {
    transform: scale(0.6);
    opacity: 0.22;
  }
  50% {
    transform: scale(1);
    opacity: 0.35;
  }
  100% {
    transform: scale(0.62);
    opacity: 0.2;
  }
}
.bs-map-btm {
  position: fixed;
  z-index: 10;
  bottom: 10px;
  width: 100%;
  padding: 0 1rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.2s ease;
}
.bs-map-btm .btn-map.dark {
  position: absolute;
  z-index: 11;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
}
.bs-map-btm.active {
  transform: translateY(0);
}

@media screen and (min-width: 1200px) {
  .bs-map-btm {
    display: none;
  }
}
.bs-list_item {
  padding: 0.375rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.bs-slide {
  margin-top: 0.625rem;
}
.bs-slide_item {
  border-radius: 0.625rem;
  background-color: #ffffff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}

.bs-info {
  display: flex;
  flex-direction: column;
  padding: 0.625rem;
}
.bs-info_top {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.bs-info_top .radio .radio-text {
  padding-left: 1.25rem !important;
}
.bs-info_top .ttl {
  min-width: 0;
  font-weight: 500;
  font-size: 0.875rem;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.bs-info_top .btn-favorite {
  flex-shrink: 0;
  margin: 0 4px;
  margin-left: auto;
}
.bs-info_top .btn-text {
  margin-left: auto;
}
.bs-info_top .distance {
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  color: #424242;
  display: inline-flex;
}
.bs-info_cont {
  position: relative;
  margin-top: 0.25rem;
}
.bs-info_cont .op-info {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 0.25rem 0.375rem;
}
.bs-info_cont .op-info .btn-time-toggle {
  flex-shrink: 0;
  transition: transform 0.25s ease;
}
.bs-info_cont .op-info.is-time-open .btn-time-toggle {
  transform: rotate(270deg);
}
.bs-info_cont .op-info .time-list-panel {
  flex: 1 0 100%;
  width: 100%;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}
.bs-info_cont .op-info.is-time-open .time-list-panel {
  max-height: 17.5rem;
}
.bs-info_cont .time {
  color: #424242;
  font-size: 0.8125rem;
}
.bs-info_cont .time-list {
  margin: 0;
  padding: 0.375rem 0 0;
  list-style: none;
  color: #424242;
  font-size: 0.8125rem;
  line-height: 1.45;
}
.bs-info_cont .time-list li + li {
  margin-top: 0.125rem;
}
.bs-info_cont .addr {
  color: #757575;
  font-size: 0.75rem;
  margin-bottom: 0.25rem;
}
.bs-info_cont .tel {
  margin-bottom: 0.25rem;
}
.bs-info_cont .stock {
  width: 1.5rem;
  text-align: center;
  font-size: 1rem;
  font-weight: 500;
  color: #7E37BE;
  position: absolute;
  right: 0;
}
.bs-info_cont .stock.zero {
  color: #757575;
}
.bs-info_btns {
  margin-top: 1rem;
  display: flex;
  align-items: center;
  gap: 0.125rem;
}
.bs-info.card .bs-info_top {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding-bottom: 0.5rem;
  margin-bottom: 0.25rem;
}
.bs-info.card .bs-info_top .ttl {
  font-size: 1rem;
}
.bs-info.list .bs-info_top {
  margin-bottom: 0.25rem;
}
.bs-info.list .bs-info_top .ttl {
  font-size: 1rem;
}
.bs-info.list.selected {
  box-shadow: inset 0 0 0 2px #8A64E6;
}
.bs-info.result {
  padding: 0;
}
.bs-info.result .bs-info_top {
  margin-bottom: 0.5rem;
}
.bs-info.result .bs-info_cont .addr, .bs-info.result .bs-info_cont .tel {
  color: #424242;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
}

@media screen and (min-width: 1200px) {
  .bs-info.list {
    padding: 1.5rem 1rem;
  }
  .bs-info.list .bs-info_top .ttl {
    font-size: 1.125rem;
    line-height: 1.5rem;
  }
}
.bs-info_empty {
  min-height: 423px;
}

.bs-favorite_footer {
  padding: 1rem;
}

.badges {
  display: flex;
  align-items: center;
  gap: 2px;
}

.cont-area {
  margin-top: 2.5rem;
}
.cont-area.no-mrgn {
  margin: 0;
}
.cont-area.sm-mrgn {
  margin-top: 2rem;
}
.cont-area > * {
  padding: 0 1rem;
}
.cont-area_hd {
  margin-bottom: 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.cont-area_hd .ttl {
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.cont-area_hd .ttl-lg {
  font-size: 1.75rem;
  line-height: 2.125rem;
  font-weight: 500;
}
.cont-area_hd .ttl-b {
  font-weight: 600;
  color: #643BC6;
}
.cont-area_hd .ttl-sub {
  flex: 1 0 98%;
  font-size: 1rem;
  line-height: 1.375rem;
  color: #643BC6;
  margin-top: 0.5rem;
}
.cont-area_hd .exp {
  flex: 1 0 100%;
  margin-top: 1rem;
  font-size: 1rem;
  line-height: 1.375rem;
}
.cont-area_hd button, .cont-area_hd a {
  margin-left: auto;
}
.cont-area .cont-swp {
  margin-right: -1rem;
  margin-left: -1rem;
}

@media screen and (min-width: 1200px) {
  .cont-area {
    margin-top: 3rem;
  }
  .cont-area > * {
    padding: 0;
  }
  .cont-area_hd .ttl {
    font-size: 1.5rem;
  }
  .cont-area_hd button.btn-text, .cont-area_hd a.btn-text {
    display: none;
  }
  .cont-area_hd .swiper-nav {
    margin-left: auto;
  }
  .cont-area .cont-swp {
    margin-right: 0;
    margin-left: 0;
  }
}
.search-container .search-form {
  padding: 1rem;
}
.search-option {
  position: relative;
}
.search-option .options {
  position: absolute;
  left: 0.625rem;
  top: 50%;
  transform: translateY(-50%);
  min-width: 3.1875rem;
  font-size: 0.8125rem;
  border: none;
  font-family: "S-Core Dream";
  background: #ffffff url(../images/new/icon_arrow_down_d.svg) right center no-repeat;
  appearance: none;
}
.search-option .input {
  padding-left: 4.0625rem;
}
.search-result {
  font-size: 0.875rem;
  margin-top: 1rem;
}
.search-result_hd {
  display: flex;
  align-items: center;
  padding: 0 1rem 0.5rem;
}
.search-result_hd h3 {
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.search-result_hd .btn-text {
  margin-left: auto;
}
.search-result_hd .info-text {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin-left: auto;
}
.search-result_bd {
  display: block;
}
.search-result_bd .list-empty.sm {
  flex: 1;
  height: auto;
  padding: 3.125rem 0;
}
.search-result_item {
  padding: 1rem;
  border-bottom: 1px solid #EEEEEE;
}
.search-result_item:first-of-type {
  border-top: 1px solid #EEEEEE;
}
.search-result_item .book {
  border-bottom: none;
  position: relative;
  flex-wrap: wrap;
}
.search-result_item .book .book-btns {
  position: absolute;
  right: 0;
  bottom: 0;
}
.search-result_item .book-info {
  gap: 0.5rem !important;
}
.search-result_item .book-info .book-ctg {
  margin-bottom: -0.25rem;
}
.search-result_item .book-info .book-ctg .chip-info {
  font-size: 0.6875rem;
}
.search-result_item .book-info .book-author {
  font-size: 0.75rem;
  color: #424242;
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.search-result_item .book-info .book-birth {
  display: flex;
  align-items: center;
  font-size: 0.75rem;
  gap: 0.375rem;
  color: #424242;
  margin-top: -0.25rem;
}
.search-result_item .book-info .book-birth button {
  cursor: pointer;
}

@media screen and (min-width: 1200px) {
  .search-container .search-form {
    padding: 1rem 0;
    margin-bottom: 1.5rem;
  }
  .search-option .options {
    min-width: 5.375rem;
  }
  .search-option .input {
    padding-left: 6.25rem;
  }
  .search-result {
    margin-top: 2rem;
    margin-bottom: 3rem;
  }
  .search-result + .search-result {
    margin-bottom: 12.875rem;
  }
  .search-result_hd {
    padding: 0 0 0.875rem 0;
  }
  .search-result_hd h3 {
    font-size: 1rem;
    line-height: 1.375rem;
  }
  .search-result_bd {
    display: flex;
    flex-wrap: wrap;
    gap: 0 1.5rem;
  }
  .search-result_item {
    flex: 1 0 48%;
    max-width: 50%;
  }
  .search-result_item.book-container {
    flex: 0 0 calc(50% - 0.75rem);
    max-width: calc(50% - 0.75rem);
  }
  .search-result_item:nth-of-type(2) {
    border-top: 1px solid #EEEEEE;
  }
}
.keyword-rank {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.keyword-rank a {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  letter-spacing: -0.04em;
}
.keyword-rank a .rank {
  font-weight: 600;
  font-size: 0.875rem;
  min-width: 1.125rem;
  text-align: center;
}
.keyword-rank a .b-name {
  font-size: 0.8125rem;
}
.keyword-rank li:nth-of-type(1) .rank, .keyword-rank li:nth-of-type(2) .rank, .keyword-rank li:nth-of-type(3) .rank {
  color: #643BC6;
}

.word-items {
  margin-left: -1rem;
  margin-right: -1rem;
  padding: 0 1rem;
  flex: 1 1 100%;
  scrollbar-width: none;
  overflow-x: auto;
  overflow-y: hidden;
  overscroll-behavior-x: contain;
}
.word-items_inner {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0.25rem;
  font-size: 0.875rem;
  width: max-content;
}
.word-items .word-item {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.125rem;
  padding: 0.375rem 0.625rem;
  border: 1px solid #E0E0E0;
  border-radius: 86px;
  white-space: nowrap;
}

.culture-swiper {
  height: 20.625rem;
}
.culture-swiper .swiper-slide {
  width: auto;
}

.culture-item {
  border-radius: 0.625rem;
  background-color: rgba(0, 0, 0, 0.2);
  overflow: hidden;
  cursor: pointer;
  height: 100%;
  position: relative;
}
.culture-status {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 2px;
  z-index: 5;
  left: 4px;
  top: 4px;
}
.culture-thumb {
  position: relative;
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  overflow: hidden;
  width: 100%;
  height: 100%;
}
.culture-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.culture-thumb p {
  position: absolute;
  z-index: 6;
  bottom: 3.875rem;
  color: #ffffff;
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
  min-height: 2.5rem;
  padding: 0 1.5rem;
  text-align: center;
}
.culture-info {
  position: absolute;
  width: 100%;
  bottom: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.625rem;
  text-align: center;
  color: #fff7b6;
  font-size: 0.8125rem;
  background-color: rgba(0, 0, 0, 0.4);
}
.culture-info .txt + .icon {
  margin-left: 0.5rem;
}
.culture-tip {
  display: inline-flex;
  align-items: center;
  font-size: 0.6875rem;
  line-height: 0.9375rem;
  padding: 0 0.25rem;
  color: #ffffff;
  border-radius: 4px;
  height: 1.375rem;
}
.culture-tip.a {
  background-color: #304162;
}
.culture-tip.b {
  background-color: rgba(115, 57, 180, 0.7);
}
.culture-tip.c {
  background-color: #9E9E9E;
}

.banner-container {
  padding: 0 1rem;
  margin-top: 2.5rem;
}
.banner-container .banner {
  background-color: #F5F5F5;
  border-radius: 0.625rem;
  padding: 0 0.625rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 4.375rem;
}
.banner-container .banner > .icon {
  width: 2.5rem;
  height: 2.5rem;
}
.banner-container .banner .comment > * {
  display: block;
}
.banner-container .banner .comment small {
  font-size: 0.8125rem;
  line-height: 1.0625rem;
}
.banner-container .banner .comment strong {
  display: block;
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.banner-container .banner .btn-text {
  margin-left: auto;
}
.banner-container .banner .noti {
  font-size: 0.875rem;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.banner-container .banner.bs-finder {
  background-color: #F5F3FE;
}
.banner-container .banner.our-bs {
  background-color: #F8ECF8;
}
.banner-container .banner.noti {
  min-height: auto;
}
.banner-container .banner.noti > .icon {
  width: 2rem;
  height: 2rem;
}

.notice-swiper {
  height: 3.25rem;
  overflow: hidden;
  margin-bottom: 3rem;
}
.notice-swiper .swiper-wrapper {
  height: 100%;
}
.notice-swiper .swiper-slide {
  height: 3.25rem;
}

@media screen and (min-width: 1200px) {
  .notice-swiper {
    height: 4.375rem;
  }
  .notice-swiper .swiper-slide {
    height: 4.375rem;
  }
  .banner-container {
    margin-top: 3rem;
  }
  .banner-container .banner.noti {
    margin-bottom: 0;
  }
}
.visual-swiper {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 30rem;
}
.visual-swiper .swiper-wrapper {
  height: 100%;
}
.visual-swiper .swiper-slide {
  height: 100%;
}
.visual-swiper .swiper-nav {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1000;
}
.visual-item {
  height: 100%;
  position: relative;
}
.visual-item a {
  display: block;
  height: 100%;
}
.visual-item img {
  display: block;
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  object-position: center;
}
.visual-item_info {
  position: absolute;
  text-align: center;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
}
.visual-item_info .ttl {
  white-space: nowrap;
  font-size: 1.125rem;
  line-height: 1.5rem;
  font-weight: 500;
  color: #ffffff;
}
.visual-item_info p {
  margin-top: 0.25rem;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  color: #EEEEEE;
}

@media screen and (min-width: 1200px) {
  .visual-swiper {
    border-radius: 10px;
    overflow: hidden;
    height: 400px;
  }
  .visual-item_info {
    bottom: 2.625rem;
  }
  .visual-item_info .ttl {
    font-size: 1.5rem;
    line-height: 1.875rem;
    font-weight: 600;
  }
  .visual-item_info p {
    font-size: 1rem;
    line-height: 1.375rem;
    font-weight: 500;
  }
}
.main-menus {
  margin-top: 2.5rem;
}
.main-menus .res-inner {
  display: flex;
  padding: 0 1rem;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.main-menus .menu-link {
  cursor: pointer;
  border-radius: 0.625rem;
  padding: 1.5rem 0.875rem;
  min-height: 11.25rem;
}
.main-menus .menu-link span {
  font-size: 0.8125rem;
  line-height: 1.125rem;
  position: relative;
  z-index: 10;
}
.main-menus .menu-link strong {
  position: relative;
  z-index: 10;
}
.main-menus .menu-link::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 9;
  isolation: isolate;
}
.main-menus .menu-link {
  flex: 1 0 45%;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  color: #ffffff;
  position: relative;
  overflow: hidden;
}
.main-menus .menu-link strong {
  font-size: 1.25rem;
  font-weight: 600;
}
.main-menus .menu-link.on-info {
  background: linear-gradient(180deg, #B4976F 0%, #9A7F5B 100%);
}
.main-menus .menu-link.on-info::after {
  max-width: 100%;
  background: url(../images/new/img_bg_oninfo.png) right bottom no-repeat;
  background-size: 100% auto;
}
.main-menus .menu-link.re-info {
  background: linear-gradient(180deg, #515280 0%, #3B3C5F 100%);
}
.main-menus .menu-link.re-info::after {
  max-width: 90%;
  background: url(../images/new/img_bg_reinfo.png) right bottom no-repeat;
  background-size: 100% auto;
}
.main-menus .menu-link.sp-info {
  background: linear-gradient(180deg, #5B519C 0%, #3C3664 100%);
}
.main-menus .menu-link.sp-info::after {
  max-width: 56%;
  background: url(../images/new/img_bg_spinfo.png) right bottom no-repeat;
  background-size: 100% auto;
}
.main-menus .menu-link.st-info {
  background: linear-gradient(180deg, #9FCC99 0%, #41643C 100%);
}
.main-menus .menu-link.st-info::after {
  max-width: 68%;
  background: url(../images/new/img_bg_stinfo.png) right bottom no-repeat;
  background-size: 100% auto;
}
.main-menus .menu-name {
  color: #424242;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  white-space: nowrap;
  text-align: center;
}
.main-menus .menu-quick {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  color: #424242;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  padding: 0 6px;
  flex: 0 1 4.625rem;
}
.main-menus .menu-quick .icon {
  width: 2rem;
  height: 2rem;
}
.main-menus .menu-quick_w {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.75rem;
  height: 3.75rem;
  background-color: #F5F5F5;
  border-radius: 0.875rem;
  position: relative;
}
.main-menus .menu-quick_w.new::before {
  position: absolute;
  right: 0;
  top: 0;
  content: "NEW";
  color: #ffffff;
  background-color: #7E37BE;
  font-size: 0.5rem;
  border-radius: 3px;
  width: 24px;
  height: 13px;
  line-height: 13px;
  text-align: center;
}
.main-menus_sm {
  gap: 0.5rem;
  flex: 1 0 99%;
  padding: 0 0.5rem;
  margin-top: 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media screen and (min-width: 1200px) {
  .main-menus {
    padding: 0;
    margin-top: 4rem;
  }
  .main-menus .res-inner {
    flex-wrap: nowrap;
    gap: 1.5rem;
    padding: 0;
  }
  .main-menus .res-inner > * {
    padding: 0;
    flex: 1;
  }
  .main-menus .menu-link {
    padding: 2rem;
    font-size: 1rem;
  }
  .main-menus .menu-link strong {
    font-size: 1.5rem;
  }
  .main-menus .menu-link.on-info::after {
    max-width: 64%;
  }
  .main-menus .menu-link.re-info::after {
    max-width: 64%;
  }
  .main-menus .menu-link.sp-info::after {
    max-width: 48%;
  }
  .main-menus .menu-link.st-info::after {
    max-width: 54%;
  }
  .main-menus .menu-quick {
    border: 1px solid #E0E0E0;
    flex: 1 0 45%;
    flex-direction: row;
    border-radius: 0.625rem;
    padding: 0.625rem;
  }
  .main-menus .menu-name {
    font-size: 1rem;
  }
  .main-menus_sm {
    flex-wrap: wrap;
    margin-top: 0;
    gap: 1rem 1.5rem;
  }
}
.book-swiper {
  display: flex;
  justify-content: flex-start;
  gap: 1rem;
}
.book-swiper .book {
  position: relative;
  min-width: clamp(100px, 100px + 92 * (100vw - 360px) / 840, 192px);
  height: auto;
}
.book-swiper .book-thumb {
  width: 100%;
  height: clamp(144px, 144px + 134 * (100vw - 360px) / 840, 278px);
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 0 10px 10px 0;
  overflow: hidden;
}
.book-swiper .book-thumb img {
  width: 100%;
  height: 100%;
  object-position: center;
  display: block;
}
.book-swiper .book-rank {
  display: block;
  position: absolute;
  left: 1px;
  top: 1px;
  width: clamp(24px, 2vw, 40px);
  height: clamp(24px, 2vw, 40px);
  text-align: center;
  background-color: rgba(0, 0, 0, 0.8);
  color: #ffffff;
  font-weight: 800;
  font-size: 0.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.book-swiper .book-info {
  margin-top: 0.5rem;
}
.book-swiper .book-info_btm {
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  margin-top: 0.25rem;
  color: #424242;
  display: none;
}
.book-swiper .book-title {
  font-size: 0.875rem;
  width: 100%;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media screen and (min-width: 1200px) {
  .book-swiper .book {
    min-width: 192px;
  }
  .book-swiper .book-thumb {
    height: 278px;
  }
  .book-swiper .book-info_btm {
    display: block;
  }
  .book-swiper .book-title {
    white-space: wrap;
    max-height: 2.75rem;
    min-height: 2.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}
.new-book-swiper {
  height: 11.875rem;
}
.new-book-swiper .swiper-slide {
  width: auto;
  height: auto;
}

.new-book {
  display: flex;
  border-radius: 0.625rem;
  padding: 1.25rem;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
}
.new-book::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: inherit;
  background-size: cover;
  background-position: center;
  filter: blur(15px);
  transform: scale(1);
  z-index: 0;
  background-image: var(--bg);
}
.new-book::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(219, 219, 219, 0.8);
  z-index: 1;
}
.new-book > * {
  position: relative;
  z-index: 2;
}
.new-book_thumb {
  width: 100px;
  height: 150px;
  border-radius: 0 6px 6px 0;
  box-shadow: 0 0 14px rgba(0, 0, 0, 0.2);
  overflow: hidden;
}
.new-book_thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.new-book_pre {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.new-book_pre .ttl {
  min-height: 80px;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.new-book_pre .ttl strong {
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.new-book_pre .ttl .author {
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  font-weight: 400;
  display: block;
}
.new-book_pre .pre-txt {
  margin-top: 1rem;
  font-size: 0.8125rem;
  line-height: 1.125rem;
  display: -webkit-box;
  -webkit-line-clamp: 3; /* 3줄까지 */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media screen and (min-width: 1200px) {
  .new-book-swiper {
    height: 15.625rem;
  }
  .new-book {
    padding: 2rem 1.25rem;
  }
  .new-book_thumb {
    flex: 0 0 120px;
    width: 120px;
    height: 180px;
  }
}
.ui-form {
  padding-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.user-agree {
  display: flex;
  align-items: center;
  margin-top: 1rem;
}
.user-agree .btn-text {
  margin-left: auto;
}

.auth-complete {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.social-item {
  padding: 0.625rem 0;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
}
.social-item + .social-item {
  margin-top: 0.25rem;
}
.social-item .toggle {
  margin-left: auto;
}

.addr-item {
  padding: 1rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.addr-item_top {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.addr-item_top .radio .radio-text {
  padding-left: 1rem !important;
}
.addr-item_top .ttl {
  font-weight: 500;
  font-size: 1rem;
}
.addr-item_top .btn-text {
  margin-left: auto;
}
.addr-item_cont {
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  color: #424242;
}
.addr-item_cont .tel {
  margin-top: 0.25rem;
}
.addr-item:last-of-type {
  border-bottom: 0;
}

.mini-guide {
  margin-top: 0.5rem;
  background: #EEEEEE;
  padding: 1rem;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  color: #424242;
}

.book-container .book-rank {
  background-color: rgba(0, 0, 0, 0.7);
  color: #ffffff;
  position: absolute;
  left: 0;
  top: 0;
  font-size: 0.5625rem;
  font-weight: 700;
  width: 1.25rem;
  height: 1.25rem;
  line-height: 1.125rem;
  padding: 1px 0;
  text-align: center;
}

.tab-content .inner {
  padding: 1rem;
}

.collabo .guide {
  background-color: #F5F5F5;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  padding: 0.625rem;
  border-radius: 0.625rem;
}
.collabo-info dl dt {
  margin-top: 1.5rem;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.375rem;
}
.collabo-info dl dd {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.collabo-info dl dd ul li {
  position: relative;
  padding-left: 1.25rem;
}
.collabo-info dl dd ul li::before {
  content: "";
  display: block;
  width: 3px;
  height: 3px;
  background-color: #000;
  border-radius: 100%;
  position: absolute;
  top: 50%;
  transform: translateY(-2px);
  left: 8px;
}
.collabo-info dl dd button {
  width: 100%;
  margin-top: 0.5rem;
}

.support-item {
  border: 1px solid #E0E0E0;
  border-radius: 10px;
  display: flex;
  gap: 0.5rem;
  padding: 0.625rem;
}
.support-item_lists {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.support-item .thumb {
  border-radius: 10px;
  overflow: hidden;
  height: 5.625rem;
  width: 5.625rem;
  flex: 0 0 90px;
}
.support-item .thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.support-item .info {
  display: flex;
  flex-direction: column;
  flex: 1;
  justify-content: center;
}
.support-item .info .badges {
  display: flex;
  gap: 2px;
  align-items: center;
  margin-bottom: 4px;
}
.support-item .info .ttl {
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.support-item .info .date {
  margin-top: 0.5rem;
  font-size: 0.75rem;
  line-height: 1rem;
  color: #424242;
}

@media screen and (min-width: 1200px) {
  .support-item {
    flex: 1;
  }
  .support-item_lists {
    flex-direction: row;
    gap: 1.5rem;
  }
  .support-item_lists > li {
    flex: 1;
  }
  .support-item .thumb {
    height: 7.5rem;
    width: 7.5rem;
    flex: 0 0 120px;
  }
  .support-item .info .ttl {
    font-size: 1rem;
    line-height: 1.375rem;
  }
  .support-item .info .date {
    font-size: 0.8125rem;
    line-height: 1.0625rem;
  }
}
.main.my-order-container .order-section_header {
  padding: 0;
}
.main.my-order-container .order-status {
  height: 3.5rem;
}

.order-flex {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin-top: 1.5rem;
}

@media screen and (min-width: 1200px) {
  .main.my-order-container .order-status {
    height: 6.25rem;
  }
  .order-flex {
    gap: 1.5rem;
  }
}
.insight-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 500px;
  padding: 0 1.5rem;
  gap: 2rem;
}
.insight-banner .ttl {
  font-size: 3.5rem;
  line-height: 3.875rem;
  font-weight: 600;
  color: #ffffff;
}
.insight-banner p {
  text-align: center;
  color: #ffffff;
}
.insight-banner p.insight-d1 {
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
}
.insight-banner p.insight-d2 {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.insight-banner.intro {
  background: url(../images/new/bg_intro_banner.png) center no-repeat;
  background-size: cover;
}
.insight-banner.re-drm {
  padding: 1rem;
  min-height: 156px;
  margin-left: -1rem;
  margin-right: -1rem;
  background: url(../images/new/bg_redream_banner.png) center no-repeat;
  background-size: cover;
  color: #ffffff;
  align-items: flex-start;
}
.insight-banner.re-drm dt {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.875rem;
  margin-bottom: 0.5rem;
}
.insight-banner.re-drm dd {
  font-size: 1rem;
  line-height: 1.375rem;
}

@media screen and (min-width: 1200px) {
  .insight-banner p.insight-d1 {
    font-size: 2rem;
    line-height: 2.375rem;
  }
  .insight-banner p.insight-d2 {
    font-size: 1rem;
    line-height: 1.375rem;
  }
}
.service-info {
  margin-top: 2.5rem;
}
.service-info_lb {
  font-size: 0.875rem;
  line-height: 1.25rem;
  display: inline-block;
  background-color: #321C66;
  color: #ffffff;
  padding: 0.5rem 1rem;
  border-radius: 2.5rem;
  margin-bottom: 1rem;
  margin-left: 1rem;
}
.service-info_lb.type-b {
  background-color: #643BC6;
}
.service-info_visual {
  width: 100%;
  height: 100vw;
  overflow: hidden;
  padding: 0 1rem;
}
.service-info_visual img {
  width: 100%;
  height: 100%;
  border-radius: 2.5rem;
  object-fit: cover;
  object-position: center;
}
.service-info_lists {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.service-info_item {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  background-color: #ffffff;
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  border-radius: 1.25rem;
}
.service-info_item .visual-icon {
  flex-basis: 4rem;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background-color: #EDE7F6;
  display: flex;
  justify-content: center;
  align-items: center;
}
.service-info_item .visual-icon .icon {
  width: 2rem;
  height: 2rem;
}
.service-info_item dl {
  flex: 1;
}
.service-info_item dl dt {
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.service-info_item dl dd {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.service-info_item dl .guide {
  color: #757575;
}
.service-info.pos {
  background: url(../images/new/bg_insight_pos.png) center no-repeat;
  background-size: cover;
  justify-content: center;
  padding: 0;
  height: auto;
}
.service-info.pos .res-inner {
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 2.5rem 1rem;
  gap: 2rem;
}
.service-info.pos .res-inner .service-info_lb {
  margin: 0 0 1rem;
}
.service-info.pos .res-inner .service-info_visual {
  display: none;
  width: 524px;
  height: auto;
}
.service-info.pos .res-inner .service-info_visual img {
  width: 100%;
  height: auto;
}
.service-info.pos .cont-area_hd .ttl-lg {
  color: #ffffff;
}
.service-info.pos .cont-area_hd .ttl-sub {
  color: #EDE7F6;
}
.service-info.local {
  margin-bottom: 2.5rem;
  text-align: center !important;
}
.service-info.local .cont-area_hd {
  justify-content: center;
}
.service-info.local .cont-area_hd .ttl-sub {
  text-align: center;
}
.service-info_cards {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.5rem;
}
.service-info_card {
  flex: 1 0 344px;
  border: 1px solid #F5F5F5;
  border-radius: 1.25rem;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}
.service-info_card .img {
  width: 100%;
  height: 15rem;
  overflow: hidden;
}
.service-info_card .img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.service-info_card dl {
  padding: 1rem;
  text-align: left;
}
.service-info_card dl dt {
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
  margin-bottom: 0.5rem;
}
.service-info_card dl dd {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media screen and (min-width: 1200px) {
  .service-info {
    display: flex;
    gap: 2rem;
    padding: 0 6.25rem;
    margin-top: 2.5rem;
  }
  .service-info .cont-area {
    flex: 1;
  }
  .service-info_visual {
    flex: 0 1 524px;
    max-height: 550px;
    padding: 0;
  }
  .service-info_lb {
    margin-left: 0;
  }
  .service-info:nth-of-type(even) {
    flex-direction: row-reverse;
  }
  .service-info.local {
    margin-bottom: 3.125rem;
  }
  .service-info.local .service-info_lb {
    margin: 0 auto 1rem;
  }
  .service-info.local .service-info_cards {
    flex-direction: row;
  }
  .service-info.local .cont-area {
    text-align: center;
  }
  .service-info.pos {
    height: 750px;
  }
  .service-info.pos .res-inner {
    flex-direction: row;
  }
  .service-info.pos .res-inner > * {
    flex: 1 !important;
    max-width: 524px;
  }
  .service-info.pos .res-inner .service-info_visual {
    display: block;
  }
}
.re-dream {
  margin: 0 0.5rem;
  padding: 1.5rem 0;
}
.re-dream + .re-dream {
  border-top: 1px solid #EEEEEE;
}
.re-dream .ttl {
  font-size: 1.125rem;
  line-height: 1.5rem;
  font-weight: 500;
  color: #424242;
  margin-bottom: 1rem;
}
.re-dream .use-step {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  padding-top: 9px;
}
.re-dream .use-step .step > .icon {
  display: none;
}
.re-dream .use-step .step {
  position: relative;
}
.re-dream .use-step .step-item {
  width: 4rem;
  height: 4rem;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin: 0 auto;
  margin-bottom: 0.5rem;
}
.re-dream .use-step .step-item .icon {
  width: 2rem;
  height: 2rem;
}
.re-dream .use-step .step .lb {
  border-radius: 14px;
  color: #ffffff;
  background-color: #E0E0E0;
  position: absolute;
  left: -8px;
  top: -9px;
  font-size: 0.6875rem;
  line-height: 0.9375rem;
  padding: 0.25rem 0.5rem;
  text-align: center;
}
.re-dream .use-step .step .lb.step1 {
  background-color: #8C3114;
}
.re-dream .use-step .step .lb.step2 {
  background-color: #D3542C;
}
.re-dream .use-step .step .lb.step3 {
  background-color: #FF8A65;
}
.re-dream .use-step dl {
  text-align: center;
}
.re-dream .use-step dl dt {
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
}
.re-dream .use-step dl dd {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.re-dream .use-step dl em {
  font-weight: 500;
  color: #EF5F32;
}

.benefit-item {
  background-color: #FDF7F2;
  border-radius: 1.25rem;
  padding: 1rem;
}
.benefit-item dt {
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
  color: #8C3114;
}
.benefit-item dd {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.benefit-item + .benefit-item {
  margin-top: 0.5rem;
}

@media screen and (min-width: 1200px) {
  .re-dream .use-step {
    flex-direction: row;
  }
  .re-dream .use-step .step {
    flex: 1;
  }
  .re-dream .use-step .step > .icon {
    display: block;
    position: absolute;
    right: -24px;
    top: 50%;
    transform: translateY(-50%);
  }
}
.alarm-items > li {
  border-bottom: 1px solid #EEEEEE;
}
.alarm-item {
  padding: 1rem;
}
.alarm-item_ttl {
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
  margin: 0.25rem 0 0.5rem;
}
.alarm-item_info .date {
  color: #424242;
  font-size: 0.75rem;
  line-height: 1rem;
}

.ci-text {
  margin: 5rem 0;
  text-align: center;
}
.ci-text h1 {
  font-size: 2rem;
  line-height: 2.5rem;
  font-weight: 500;
  margin-bottom: 1.5rem;
}
.ci-text h1 em {
  color: #7E37BE;
}
.ci-text p {
  font-size: 1rem;
  line-height: 1.375rem;
}
.ci-box {
  margin-bottom: 5rem;
}
.ci-box_wrap {
  display: flex;
  gap: 1.5rem;
  flex-direction: column;
}
.ci-box_item {
  border: 1px solid #E0E0E0;
  border-radius: 10px;
  padding: 1.25rem;
  height: 15rem;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.ci-box_item .lb {
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: #757575;
  position: absolute;
  left: 1.25rem;
  top: 1.25rem;
}
.ci-box_item.color {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1.5rem;
  padding: 2.5rem;
}
.ci-box_item.color .color-box {
  width: 8.75rem;
  height: 8.75rem;
  border-radius: 10px;
}
.ci-box_item.color .color-box.primary {
  background-color: #3D086D;
}
.ci-box_item.color .color-box.secondary {
  background-color: #8b9398;
}
.ci-box_item.color ul {
  font-size: 0.875rem;
  line-height: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.ci-img {
  max-width: 160px;
}
.ci-img img {
  display: block;
  width: 100%;
  height: auto;
}
.ci-down {
  padding: 0rem 1rem 5.5rem;
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.875rem;
  font-weight: 500;
}
.ci-down p {
  margin-bottom: 2rem;
}
.ci-down p br {
  display: none;
}
.ci-down em {
  color: #7E37BE;
}
.ci-down a, .ci-down button {
  display: inline-flex;
  width: 200px;
}
.ci-down a:hover, .ci-down button:hover {
  color: white;
}

@media screen and (min-width: 1200px) {
  .ci-box_wrap {
    flex-direction: row;
  }
  .ci-box_item {
    flex: 1;
  }
  .ci-down {
    padding: 0rem 1rem 4.25rem;
  }
  .ci-down p br {
    display: inline;
  }
  .ci-down button {
    width: 340px;
  }
}
.auth {
  margin-top: 1.75rem;
}
.auth .ttl {
  text-align: center;
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
.auth .ttl em {
  color: #643BC6;
}
.auth .ttl-sm {
  color: #6B7177;
  font-weight: 500;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
}
.auth-item {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 1rem 0;
}
.auth-item .icon-box {
  flex: 0 0 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background-color: #F5F5F5;
  display: flex;
  align-items: center;
  justify-content: center;
}
.auth dl {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.auth dl dt {
  font-weight: 500;
}
.auth dl dd {
  color: #424242;
}
.auth dl.path {
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  padding: 0 0.625rem;
}
.auth .warn {
  color: #424242;
  font-size: 0.8125rem;
  line-height: 1.0625rem;
  padding: 1rem 0.625rem 0;
  margin-bottom: 0.625rem;
}

.agree {
  margin-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.agree .warn {
  font-size: 1rem;
  line-height: 1.375rem;
}
.agree .warn em {
  color: #643BC6;
  font-weight: 500;
}
.agree .warn-sub {
  font-size: 0.75rem;
  line-height: 1rem;
  color: #424242;
}
.agree .round-box {
  border: 1px solid #E0E0E0;
  border-radius: 0.625rem;
  background-color: #FAFAFA;
  padding: 0.875rem 0.625rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.agree .round-box.group {
  justify-content: flex-start;
}
.agree .round-box.group .checkbox {
  min-width: 6.25rem;
}
.agree .round-box.group .checkbox-text {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media screen and (min-width: 1200px) {
  #popupAgreement .popup {
    max-width: 400px;
    height: 22.125rem;
  }
  #popupAgreement .popup .popup-btns .btn {
    min-width: 11.375rem;
  }
}
/*# sourceMappingURL=style_p.css.map */
