@media (max-width: 768px) {
  .wrapper {
    max-width: 620px !important;
  }

  .profile-wrapper,
  .data-wrapper,
  .roulette-wrapper,
  .ticker-wrapper,
  .review-wrapper,
  .coupon-wrapper,
  .sales-wrapper,
  .subsc-button-wrapper,
  .competi-wrapper {
    padding: 0 24px;
  }
  .hero-background {
    background-image: url("../assets/mobile-mockup.png");
    background-size: cover;
    background-repeat: no-repeat; /* 이미지 반복 없음 */
  }
  .hero-brand-wrapper {
    padding: 120px 24px;
  }
  .hero-button-wrapper {
    width: 200px;
  }

  .hero-app-icon-wrapper {
    max-width: 68px;
  }
  .hero-logo-wrapper {
    max-width: 220px;
  }
  .hero-brand-text {
    font-size: 24px;
  }
  .hero-free-button {
    font-size: 18px;
  }

  .video-scroll-wrapper {
    display: none;
  }

  .ticker-container {
    padding: 48px 0;
  }
  .text-item {
    font-size: 86px;
  }

  .ticker-link-image-wrapper {
    max-width: 200px;
  }

  .headline-subtext-wrapper {
    padding-top: 0px;
  }
  .headline-subtext-wrapper p {
    line-height: 1.5;
  }

  .profile-container {
    padding: 48px 0;
  }

  .profile-content {
    padding-bottom: 24px;
  }
  .profile-item-wrapper {
    flex-direction: column;
  }
  .needs-section {
    justify-content: flex-start;
    padding-top: 12px;
  }

  .profile-needs::before {
    top: 46%;
  }

  .profile-list {
    height: auto;
  }
  .profile-card {
    padding: 16px;
    border-radius: 12px;
  }

  .profile-item-wrapper {
    padding: 24px 0;
  }
  .profile-image-container {
    width: 96px;
    height: 96px;
    max-width: 96px;
  }
  .profile-card {
    height: auto;
  }
  .profile-text {
    font-size: 14px;
  }
  .profile-review {
    width: 100px;
    font-size: 16px;
  }

  .purple-box-textwrapper {
    font-size: 18px;
  }
  .purple-box-image-wrapper {
    max-width: 24px;
  }
  .needs-title {
    font-size: 14px;
  }
  .needs-content {
    font-size: 14px;
  }

  .mockup-container {
    height: 60%;
  }
  .mockup-wrapper {
    background-image: url("../assets/service/mobile-nova.png");
    background-size: contain;
    background-attachment: scroll;
  }

  .mockup-image-wrapper {
    max-width: 240px;
  }
  .mockup-image-wrapper img {
    width: 100%;
  }

  /* roulette */

  .roulette-container {
    padding: 48px 0;
  }

  .roulette-flex {
    flex-direction: column;
  }
  .roulette-left {
    text-align: center;
    aspect-ratio: 0;
    padding-bottom: 24px;
  }
  .roulette-left > h2:nth-of-type(1) {
    line-height: 1.5;
  }

  .roulette-right {
    aspect-ratio: 0;
    justify-content: center;
    align-items: center;
    padding: 0;
  }

  /* review  */

  .scroll-text-right {
    animation: scrollRight 5s linear infinite;
  }

  .scroll-text-left {
    animation: scrollLeft 5s linear infinite;
    margin-top: 30px;
  }
  .review-flex {
    flex-direction: column;
  }

  .review-right,
  .review-left {
    aspect-ratio: 0; /* 공통 속성 */
  }
  .review-right-wrapper {
    padding: 0;
    text-align: center;
    justify-content: center;
    align-items: center;
  }
  .review-right-wrapper br {
    display: none;
  }
  .subsc-title-wrapper {
    padding: 48px 0;
  }

  .review-right-wrapper .body-text {
    padding-top: 24px;
    padding-bottom: 36px;
    max-width: 280px;
    margin: 0 auto;
  }

  .sales-bar {
    width: 30px; /* w-12 equivalent */
  }

  .sales-container {
    height: auto;
    padding: 72px 0;
    padding-bottom: 48px;
  }

  .info-box,
  .speech-bubble {
    width: 58px;
    height: 48px;
    font-size: 10px;
    margin-top: 12px;
    border-radius: 10px;
  }

  .bar-star {
    width: 12px;
    top: 18px !important;
  }
  .chart-bar {
    bottom: 28%;
    width: 364px;
    height: 1px;
    background-color: #e6e6e6;
  }
  .sales-body-text-wrapper {
    max-width: 100%;
  }

  .chart-container {
    min-height: 200px;
    padding-top: 36px;
    gap: 12px;
  }

  /* coupon */
  .coupon-container {
    height: auto;
    padding: 72px 0;
    overflow: hidden;
  }
  .coupon-wrapper {
    background-image: none;
  }
  .coupon-box {
    padding: 0;
  }
  .coupon-subtitle-wrapper {
    display: flex;
    text-align: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
  }
  .coupon-item-area-wrapper {
    padding-top: 36px;
  }
  .coupon-item-wrapper {
    max-width: 280px;
    padding-right: 36px;
  }
  .coupon-black-ball-wrapper {
    width: 110px;
    height: 110px;
    right: 36px;
    bottom: 12px;
  }

  .coupon-vector-left {
    max-width: 86px;
    top: 13px;
    left: -17px;
  }
  .coupon-vector-right {
    max-width: 130px;
    top: -13px;
    right: -54px;
  }
  .black-ball-text-wrapper p {
    font-size: 16px;
  }
  /* data */
  .data-container {
    padding: 72px 0;
    height: auto;
  }

  .data-flex-box {
    display: flex;
    flex-direction: column-reverse;
  }

  .data-right-wrapper {
    flex: 0;
    justify-content: center;
    padding-top: 48px;
  }
  .data-image-wrapper {
    max-width: 480px;
  }
  .data-text-wrapper {
    padding-top: 24px;
  }
  .data-text-wrapper .body-text {
    line-height: 1.2 !important;
  }

  .data-textarea-wrapper {
    text-align: center;
    padding: 0;
    flex: 0;
  }

  /* competi */
  .competi-container {
    padding: 48px 0;
    height: auto;
  }

  .competi-vector-desktop {
    display: none;
  }
  .competi-vector-mobile {
    display: block;
  }
  .competi-reviewer-wrapper {
    max-width: 180px;
    bottom: 24px;
    left: -24px;
    transform: rotate(-15deg);
  }

  .competi-body-text-wrapper {
    max-width: 360px;
    margin: 0 auto;
  }

  .competi-body-text-wrapper .body-text {
    line-height: 1.8;
  }
  .competi-black-ball-wrapper {
    width: 110px;
    height: 110px;
    right: 8%;
    top: 10%;
  }
  .competi-vector-mobile {
    width: 100%;
  }
  .competi-image-wrapper {
    width: 340px;
    height: 220px;
  }
  .subsc-button.headline5 {
    font-size: 18px;
  }
  .subsc-wrapper {
    padding: 48px 24px;
    background: linear-gradient(180deg, #4571e6 0%, #5b45e6 100%);
  }
  .subsc-area {
    padding: 0;
  }
  .subsc-twik-wrapper {
    max-width: 24px;
    top: -6px;
  }

  .subsc-explain-item-wrapper {
    width: 100%;
    height: 50px;
  }
  .subsc-vertical-desktop {
    display: none;
  }
  .subsc-vertical-mobile {
    display: block;
  }

  .subsc-button {
    width: 100%;
    height: 50px;
  }
  .competi-explain-wrapper {
    max-width: 200px;
    padding: 0 0 12px 0;
  }
  .competi-subtext-wrapper.mobile .body-text {
    line-height: 1.5;
    word-break: keep-all;
  }

  .footer-wrapper {
    padding: 24px;
  }
  .footer-wrapper a {
    font-weight: bold;
    cursor: pointer;
  }
  .footer-desktop {
    display: none;
  }

  .footer-textarea-wrapper {
    padding: 40px 0 0 0;
  }

  .footer-explain-wrapper {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .footer-text-wrapper {
    flex-direction: column;
  }

  .footer-bottom-wrapper {
    display: none;
  }

  .go-to-top-button-mobile {
    width: 100%;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #e6e6e6;
    cursor: pointer;
  }
  .footer-button-wrapper {
    padding-bottom: 24px;
    display: flex;
  }

  .footer-link-mobile {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .tmap-icon {
    left: 0px;
    top: 180px;
    width: 100px;
    height: 100px;
  }

  .naver-icon {
    left: -38px;
    top: 180px;
    width: 72px;
    height: 72px;
  }
  .google-icon {
    width: 124px;
    height: 124px;
    right: -15px;
    top: 175px;
  }

  .kakao-icon {
    width: 124px;
    height: 124px;
    right: -68px;
    top: 140px;
  }
}
