@charset "UTF-8";
.main-container-register {
  max-width: 1000px;
  margin-left: 8px;
  margin-right: 8px; }

.header-container {
  position: relative; }

.img-banner {
  border-radius: 10px;
  width: 100%; }

.container-img-bander {
  overflow: hidden;
  border-radius: 10px; }
  @media (max-width: 767.98px) {
    .container-img-bander {
      min-height: 150px; } }
  .container-img-bander img {
    max-height: 100%;
    width: 100%;
    object-fit: cover;
    overflow: hidden;
    border-radius: 10px; }

.section-landing-img img {
  border-radius: 0px !important; }

.section-landing-content {
  border-radius: 10px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background-color: rgba(0, 0, 0, 0.5);
  padding: 20px; }
  @media (max-width: 600px) {
    .section-landing-content {
      padding: 0px;
      padding-bottom: 10px; } }

.container-summary {
  position: fixed; }

.landing-event-banner-container {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 20px;
  width: 100%;
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25); }

.landing-event-banner {
  width: 100%;
  object-fit: contain; }

.landing-free-event-info-container {
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
  border-radius: 20px;
  width: 100%;
  padding-left: 3rem;
  padding-right: 3rem;
  padding-top: 3rem;
  padding-bottom: 3rem; }
  @media (max-width: 767.98px) {
    .landing-free-event-info-container {
      border: none;
      border-radius: none;
      box-shadow: none;
      padding-left: 1.5rem;
      padding-right: 1.5rem;
      padding-top: 0px;
      padding-bottom: 0px; } }
  .landing-free-event-info-container .info-box {
    border: 1px solid #e7e7e7;
    border-radius: 10px;
    text-align: center;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem; }
  .landing-free-event-info-container .info-text {
    font-weight: 400;
    font-size: 14px;
    line-height: 22px; }
  .landing-free-event-info-container .info-title {
    font-weight: 400;
    font-size: 16px;
    line-height: 22px;
    color: #a6a6a6; }

.landing-event-info-container {
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
  border-radius: 20px;
  width: 100%;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  padding-top: 1rem;
  padding-bottom: 1rem; }
  @media (max-width: 767.98px) {
    .landing-event-info-container {
      border: none;
      border-radius: none;
      box-shadow: none;
      padding: 1rem;
      padding-bottom: 0rem; } }
  @media (max-width: 767.98px) {
    .landing-event-info-container .info-box {
      border: 1px solid #e7e7e7;
      border-radius: 10px;
      text-align: center;
      padding-top: 0.5rem;
      padding-bottom: 0.5rem; } }
  .landing-event-info-container .info-text {
    font-weight: 400;
    font-size: 14px;
    line-height: 22px; }
  .landing-event-info-container .info-title {
    font-weight: 400;
    font-size: 16px;
    line-height: 22px; }
    @media (max-width: 767.98px) {
      .landing-event-info-container .info-title {
        color: #a6a6a6; } }

.landing-select-ticket-container {
  box-shadow: 0px 4px 14px rgba(0, 0, 0, 0.25);
  border-radius: 30px;
  width: 100%;
  position: relative;
  padding-bottom: 1.5rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  padding-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  flex-direction: column; }
  @media (max-width: 767.98px) {
    .landing-select-ticket-container {
      box-shadow: none;
      padding: 1rem;
      padding-bottom: 0px; } }

.landing-select-ticket-title {
  font-size: 22px;
  line-height: 33px; }
  @media (max-width: 767.98px) {
    .landing-select-ticket-title {
      display: none; } }
  .landing-select-ticket-title.center {
    text-align: center;
    font-weight: 700; }

.landing-event-banner-title {
  font-size: 16px;
  line-height: 22px;
  display: none; }
  @media (max-width: 767.98px) {
    .landing-event-banner-title {
      display: block; } }
  .landing-event-banner-title.mobile {
    font-size: 18px;
    font-weight: 700;
    line-height: normal; }

.select-ticket-buy-button {
  width: 100%;
  color: white;
  background-color: black;
  border-radius: 10px;
  border: none;
  bottom: -4px;
  left: 0px;
  font-weight: 600;
  font-size: 20px;
  height: 56px; }
  @media (max-width: 767.98px) {
    .select-ticket-buy-button {
      border-radius: 20px 20px 0px 0px;
      font-size: 16px;
      z-index: 199;
      background-color: transparent;
      padding-left: 1.5rem;
      padding-right: 1.5rem;
      height: auto; } }

.landing-select-ticket-counting-box {
  border-radius: 10px;
  border: 1px solid black;
  width: 50px;
  height: 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1; }
  .landing-select-ticket-counting-box.early {
    border: 1px solid #b70909;
    color: #b70909; }
  .landing-select-ticket-counting-box.no-border {
    width: 36px;
    height: auto;
    border: none; }
  .landing-select-ticket-counting-box .count-num {
    font-weight: 700;
    font-size: 19px;
    margin-bottom: 0px; }
  .landing-select-ticket-counting-box .count-title {
    font-weight: 300;
    font-size: 9px;
    margin-bottom: 0px; }
  @media (max-width: 767.98px) {
    .landing-select-ticket-counting-box {
      color: white;
      background-color: black;
      width: 44px;
      height: 44px; }
      .landing-select-ticket-counting-box.no-border {
        width: 31px;
        border: none;
        color: black;
        background-color: white; }
      .landing-select-ticket-counting-box.early {
        background-color: #b70909;
        color: white; } }

.landing-select-ticket-counting-box-container {
  display: flex; }
  @media (max-width: 767.98px) {
    .landing-select-ticket-counting-box-container {
      flex-wrap: wrap; } }

@media (max-width: 767.98px) {
  .landing-event-description {
    margin-bottom: 84px; } }

.landing-select-ticket-list {
  max-height: 470px;
  overflow-y: scroll; }

.landing-select-ticket-item {
  border-radius: 10px; }
  .landing-select-ticket-item.even {
    background-color: #ffff; }
  .landing-select-ticket-item.odd {
    background-color: #F4F6FF; }
  .landing-select-ticket-item .select-ticket-type {
    line-height: 11px;
    font-weight: 700;
    font-size: 18px; }
    .landing-select-ticket-item .select-ticket-type.free {
      margin-bottom: 0px !important; }
  .landing-select-ticket-item .select-ticket-time-container {
    display: flex;
    align-items: center;
    justify-content: end; }
    @media (max-width: 767.98px) {
      .landing-select-ticket-item .select-ticket-time-container {
        flex-wrap: wrap; } }
    .landing-select-ticket-item .select-ticket-time-container .select-ticket-time-icon i {
      font-size: 20px;
      width: 36px;
      color: black; }
  .landing-select-ticket-item .select-ticket-input-container {
    display: flex;
    justify-content: space-between; }
    .landing-select-ticket-item .select-ticket-input-container .select-ticket-input-number {
      line-height: 22px;
      font-weight: 700;
      font-size: 19px;
      border-bottom: 1px solid black;
      margin-left: 10px;
      margin-right: 10px;
      min-width: 20px;
      display: flex;
      justify-content: center; }
      .landing-select-ticket-item .select-ticket-input-container .select-ticket-input-number.l-low {
        border-bottom: 0px;
        line-height: 35px;
        text-decoration-line: underline;
        text-decoration-style: solid;
        text-underline-offset: 4px; }
    .landing-select-ticket-item .select-ticket-input-container .select-ticket-input-button {
      color: white;
      background-color: black;
      border: none;
      border-radius: 4px;
      width: 20px;
      height: 20px;
      display: flex;
      justify-content: center;
      align-items: center; }
      .landing-select-ticket-item .select-ticket-input-container .select-ticket-input-button.disabled {
        background: #D9D9D9; }
      .landing-select-ticket-item .select-ticket-input-container .select-ticket-input-button:disabled {
        background: #D9D9D9; }
      .landing-select-ticket-item .select-ticket-input-container .select-ticket-input-button.large {
        width: 36px;
        height: 36px; }
  .landing-select-ticket-item .select-ticket-old-price {
    font-size: 12px;
    font-weight: 600;
    color: #A7AEB8;
    text-decoration: line-through; }
  .landing-select-ticket-item .select-ticket-price {
    line-height: 22px;
    font-weight: 600;
    font-size: 18; }
    .landing-select-ticket-item .select-ticket-price.discounted {
      color: #FF0019; }
    @media (max-width: 600px) {
      .landing-select-ticket-item .select-ticket-price {
        line-height: 12px;
        font-size: 14px; } }
  .landing-select-ticket-item .select-ticket-currency {
    line-height: 22px;
    font-weight: 275;
    font-size: 13px; }

.end-select-ticket-label {
  font-size: 13px;
  line-height: 22px;
  color: #a6a6a6; }
  .end-select-ticket-label.early {
    color: #b70909; }

.landing-header-bg {
  width: 100vw;
  height: 30vh;
  object-fit: cover;
  position: absolute;
  filter: blur(8px); }
  .landing-header-bg.mobile {
    height: 35vh; }

.imgBanner {
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 20px;
  width: 100%;
  transition: transform 1s; }

.imgBanner:hover {
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 20px; }

.card-payment-type {
  line-height: 22px;
  font-weight: 500;
  font-size: 19px;
  border: 2px solid #CCCCCC;
  border-radius: 10px;
  cursor: pointer;
  background-color: white;
  color: black; }
  .card-payment-type.active {
    border: 4px solid #4C5398 !important;
    color: #4C5398; }

.complete-event-banner-container {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 20px;
  width: 100%;
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  height: 400px; }

.complete-event-banner {
  width: 100%;
  object-fit: contain; }

.bar-register {
  background-color: black;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  display: none; }

.card-payment {
  border: 2px solid #4C5398;
  border-radius: 6px;
  background: white; }

.card-gbpay-cd {
  min-height: 530px !important; }

#gbprimepay-iframe {
  min-height: 540px !important; }

.card__border--none {
  border: none !important; }

.radius-6 {
  border-radius: 6px; }

.border--ticket__item {
  border: 1px solid #e2e2e2;
  transition: all .4s; }

.border--ticket__item:hover {
  background-color: #f4f6ff;
  border: 1px solid #f4f6ff; }

.fs-datetime {
  font-size: 16px;
  font-weight: 600; }

.fs-discrption-ticket {
  font-size: 16px; }

.section-select-ticket-zone .top {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background-color: white;
  padding: 14px;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  display: flex;
  flex-direction: row;
  align-items: center; }
  .section-select-ticket-zone .top.is-no-bottom {
    border-bottom-left-radius: 20px !important;
    border-bottom-right-radius: 20px !important; }
  .section-select-ticket-zone .top .image-container {
    width: 204px;
    height: 196px;
    border-radius: 20px;
    background-color: black;
    overflow: hidden; }
    .section-select-ticket-zone .top .image-container img {
      width: 100%;
      height: 100%;
      object-fit: contain; }
  .section-select-ticket-zone .top .title-container {
    margin-left: 30px; }
    @media (max-width: 768px) {
      .section-select-ticket-zone .top .title-container {
        margin-left: 0px; } }
    .section-select-ticket-zone .top .title-container .zone-name {
      font-size: clamp(18px, 3vw, 24px);
      font-weight: bold; }
    .section-select-ticket-zone .top .title-container .section-name {
      margin-top: 16px;
      margin-bottom: 16px;
      font-size: clamp(16px, 3vw, 24px);
      font-weight: normal; }
    .section-select-ticket-zone .top .title-container .price-all {
      font-size: 16px;
      font-weight: normal;
      display: flex;
      flex-direction: row;
      align-items: center; }

.section-select-ticket-zone .bottom {
  background-color: white;
  padding: 20px;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px; }

.section-select-ticket-zone .zone-time-container {
  width: 50%;
  display: flex;
  flex-wrap: wrap; }

.button-buy-section {
  font-size: clamp(14px, 3vw, 16px); }

.w-md-50 {
  width: 100%; }

.section-select-ticket {
  background-color: black;
  padding: 50px;
  padding-left: 40px;
  padding-right: 40px;
  border-radius: 20px; }
  .section-select-ticket .title {
    font-size: clamp(16px, 4vw, 32px);
    color: black;
    font-weight: 400; }
  .section-select-ticket .sub-title {
    color: #b6b9bd;
    font-size: clamp(14px, 3vw, 20px);
    font-weight: 700; }
  .section-select-ticket .section-container {
    margin-top: 8px; }
    .section-select-ticket .section-container .bg-screen {
      background-position: center;
      background-attachment: fixed;
      min-height: 100vh;
      background-size: cover; }
  .section-select-ticket .select-date-container {
    margin-top: 16px;
    padding-bottom: 16px;
    display: flex;
    overflow: auto; }
    .section-select-ticket .select-date-container .month {
      font-size: 10px; }
    .section-select-ticket .select-date-container .date {
      font-size: clamp(14px, 3vw, 20px);
      font-weight: 700; }
    .section-select-ticket .select-date-container .year {
      font-size: 10px;
      font-weight: 100; }
  .section-select-ticket .text-section {
    text-decoration-line: none !important;
    font-weight: 400 !important; }
  .section-select-ticket .button-ticket-section {
    border-radius: 40px !important;
    background-color: black; }
  .section-select-ticket .button-buy-ticket-section {
    border-radius: 10px;
    padding: 50px;
    padding-top: 14px;
    padding-bottom: 14px;
    font-size: 20px;
    font-weight: 700; }

.fix-text-white {
  color: white !important; }

.select-ticket--zone-seat-input-button {
  color: white !important;
  background-color: black !important;
  border: none;
  border-radius: 4px;
  width: 20px;
  height: 20px;
  display: flex;
  justify-content: center;
  align-items: center; }
  .select-ticket--zone-seat-input-button.disabled {
    background: #D9D9D9; }
  .select-ticket--zone-seat-input-button:disabled {
    background: #D9D9D9; }
  .select-ticket--zone-seat-input-button.large {
    width: 36px;
    height: 36px; }

.section-service-charge {
  display: flex;
  justify-content: center;
  color: #9091A7;
  margin-bottom: 10px; }

.sub-section-payment {
  background-color: white;
  border-radius: 8px;
  padding: 30px; }

@media (min-width: 768px) {
  .w-md-50 {
    width: 50%; } }

.font-24-responsive {
  font-size: clamp(16px, 3vw, 24px); }

.tab {
  border-bottom: 5px solid transparent;
  margin-bottom: 0px;
  font-weight: 200;
  width: 140px;
  text-align: center;
  cursor: pointer; }
  .tab.active {
    border-bottom: 5px solid white;
    font-weight: 400; }
  .tab:hover {
    border-color: white;
    font-weight: 400; }

html {
  scroll-behavior: smooth; }

.border-zone-seat-ticket__item {
  background-color: white;
  border: 1px solid white;
  transition: all .4s; }

.bg-screen-section {
  background-position: center;
  background-attachment: fixed;
  background-size: cover;
  background-repeat: no-repeat;
  min-height: 100vh; }

@media (max-width: 767.98px) {
  .sm-border-none {
    border: none !important; } }

@media (max-width: 767.98px) {
  .card-section-mb {
    flex-wrap: wrap; } }

@media (max-width: 767.98px) {
  .mb-sm-20 {
    margin-bottom: 20px; } }

.rounder {
  border-radius: 8px; }

.x-rounder {
  border-radius: 20px; }

.add-ticket-container {
  width: 100%;
  border-radius: 40px;
  overflow: hidden;
  box-shadow: 0px 4px 14px rgba(0, 0, 0, 0.25);
  display: none;
  background-color: white;
  padding-top: 1.5rem;
  padding-right: 1.5rem;
  padding-left: 1.5rem;
  padding-bottom: calc(1.5rem + 64px);
  position: relative; }
  .add-ticket-container.on-add {
    display: block; }
  .add-ticket-container .add-ticket-list {
    overflow-y: auto;
    height: calc(100% - 54px); }
  .add-ticket-container .add-ticket-title {
    text-align: center;
    font-size: 22px;
    line-height: 33px;
    font-weight: 500;
    margin-bottom: 1.5rem; }
  .add-ticket-container .add-ticket-button {
    width: 100%;
    color: white;
    background-color: #000000;
    position: absolute;
    bottom: 0px;
    left: 0px;
    border-radius: 0px 0px 40px 40px;
    border: none;
    height: 64px; }
    @media (max-width: 767.98px) {
      .add-ticket-container .add-ticket-button {
        height: 54px; } }
  @media (max-width: 767.98px) {
    .add-ticket-container {
      position: fixed;
      top: 10px;
      left: 10px;
      width: calc(100vw - 20px);
      height: calc(100vh - 20px);
      z-index: 199; } }

.ticket-cart-container {
  width: 100%;
  height: 100%;
  max-height: 80vh;
  border-radius: 20px;
  overflow-x: hidden;
  overflow-y: auto;
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25); }
  @media (max-width: 767.98px) {
    .ticket-cart-container {
      box-shadow: none;
      border: 1px solid black; } }
  .ticket-cart-container.on-add {
    display: none; }
    @media (max-width: 767.98px) {
      .ticket-cart-container.on-add {
        display: block; } }
  .ticket-cart-container .promo-input {
    display: flex;
    align-items: flex-end; }
    .ticket-cart-container .promo-input .apply-code-button {
      background: #EFEDED;
      border-radius: 4px 4px 0px 0px;
      font-size: 14px;
      font-weight: 300;
      border: none; }
    .ticket-cart-container .promo-input .apply-code-emt-button {
      background: #00CEB5;
      border-radius: 4px 4px 4px 4px;
      font-size: 14px;
      font-weight: 300;
      border: none;
      color: #FFFFFF;
      padding: 5px 10px;
      cursor: pointer; }
      .ticket-cart-container .promo-input .apply-code-emt-button:disabled {
        background: #D9D9D9;
        cursor: not-allowed; }
  .ticket-cart-container .promo-zone-seat-input {
    display: flex;
    align-items: flex-end; }
    .ticket-cart-container .promo-zone-seat-input .apply-code-button {
      background: #EFEDED;
      border-radius: 4px 4px 0px 0px;
      font-size: 14px;
      font-weight: 300;
      border: none; }
    .ticket-cart-container .promo-zone-seat-input .apply-code-emt-button {
      background: #00CEB5;
      border-radius: 4px 4px 4px 4px;
      font-size: 14px;
      font-weight: 300;
      border: none;
      color: #FFFFFF;
      width: 80px !important;
      cursor: pointer; }
      .ticket-cart-container .promo-zone-seat-input .apply-code-emt-button:disabled {
        background: #D9D9D9;
        cursor: not-allowed; }
    .ticket-cart-container .promo-zone-seat-input .display-promo-code {
      background: #FFFFFF;
      border-radius: 4px 4px 4px 4px;
      font-size: 1rem;
      font-weight: 300;
      color: #000000;
      border-radius: 6px !important;
      height: 32px !important;
      padding-right: 30px;
      padding-left: 15px;
      display: flex;
      align-items: center;
      flex-wrap: wrap; }
    .ticket-cart-container .promo-zone-seat-input .code-approve {
      border: 2px solid #1cbf0f !important; }
    .ticket-cart-container .promo-zone-seat-input .code-reject {
      border: 2px solid #d82e2c !important; }
  .ticket-cart-container .promo-approve {
    font-size: 12px;
    color: #1cbf0f;
    background-color: #e7f9e7;
    border-radius: 4px 4px 4px 4px;
    padding: 4px 10px;
    margin-top: 10px;
    font-weight: 500; }
  .ticket-cart-container .promo-error {
    font-size: 12px;
    color: #d82e2c;
    background-color: #ffeaed;
    border-radius: 4px 4px 4px 4px;
    padding: 4px 5px;
    margin-top: 10px;
    font-weight: 500; }
  .ticket-cart-container .ticket-cart-banner-container {
    width: 100%;
    height: 185px;
    overflow: hidden; }
    .ticket-cart-container .ticket-cart-banner-container .ticket-cart-banner {
      width: 100%;
      object-fit: cover; }
    @media (max-width: 767.98px) {
      .ticket-cart-container .ticket-cart-banner-container {
        display: none; } }
  .ticket-cart-container .ticket-cart-pay-button-container {
    position: relative; }
    .ticket-cart-container .ticket-cart-pay-button-container .ticket-cart-pay-button {
      border: none;
      width: 100%;
      height: 60px;
      background-color: #CC1F1F;
      font-weight: 500;
      font-size: 23px; }
      @media (max-width: 767.98px) {
        .ticket-cart-container .ticket-cart-pay-button-container .ticket-cart-pay-button {
          position: fixed;
          bottom: 0px;
          left: 0px;
          z-index: 199;
          border-radius: 20px 20px 0px 0px; } }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-title {
    font-weight: 500;
    font-size: 22px; }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-add-button {
    font-weight: 400;
    font-size: 10px;
    line-height: 15px;
    background-color: black;
    border: none;
    border-radius: 4px;
    color: white; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-add-button:hover {
      opacity: 0.8; }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-item {
    display: flex;
    justify-content: space-between; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-item .ticket-cart-item-name {
      width: 33%;
      text-align: left;
      font-weight: 500;
      font-size: 15px; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-item .ticket-cart-item-price {
      width: 33%;
      text-align: right;
      font-weight: 700;
      font-size: 15px; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-item .input-container {
      display: flex;
      justify-content: space-between; }
      .ticket-cart-container .ticket-cart-detail .ticket-cart-item .input-container .input-number {
        font-weight: 500;
        font-size: 15px;
        text-decoration: underline;
        margin-left: 10px;
        margin-right: 10px;
        min-width: 20px;
        text-align: center; }
      .ticket-cart-container .ticket-cart-detail .ticket-cart-item .input-container .input-button {
        color: white;
        background-color: rgba(0, 0, 0, 0.75);
        border: none;
        border-radius: 4px;
        width: 20px;
        height: 20px;
        display: flex;
        justify-content: center;
        align-items: center; }
        .ticket-cart-container .ticket-cart-detail .ticket-cart-item .input-container .input-button.disabled {
          background: #D9D9D9; }
        .ticket-cart-container .ticket-cart-detail .ticket-cart-item .input-container .input-button:disabled {
          background: #D9D9D9; }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-exclusive-item-container .cart-exclusive-item-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 15px;
    font-weight: 700;
    color: black;
    margin-bottom: 8px; }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-exclusive-item-container .cart-exclusive-item-list {
    font-size: 14px;
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    background-color: #F6F6F6;
    padding: 10px;
    color: black;
    width: 100%; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-exclusive-item-container .cart-exclusive-item-list .cart-exclusive-item {
      display: flex;
      justify-content: space-between;
      align-items: center; }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-promo-container {
    display: flex;
    justify-content: space-between;
    align-items: center; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-promo-container .promo-title {
      font-weight: bold;
      font-size: 15px; }
  .ticket-cart-container .ticket-cart-detail .ticket-cart-sum-container {
    display: flex;
    justify-content: space-between;
    align-items: center; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-sum-container .sum-title {
      font-weight: bold;
      font-size: 15px; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-sum-container .sum-price {
      font-weight: 500;
      font-size: 15px; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-sum-container #ticket-cart-req-bill {
      font-weight: 300;
      font-size: 15px; }
    .ticket-cart-container .ticket-cart-detail .ticket-cart-sum-container #ticket-cart-i-accept {
      font-weight: 300;
      font-size: 15px; }

.free-register-detail-title {
  background: #000000;
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
  border-radius: 30px;
  font-size: 24px;
  font-weight: 400;
  line-height: 24px;
  letter-spacing: 0em;
  text-align: left;
  height: 75px;
  color: white;
  display: flex;
  align-items: center; }
  @media (max-width: 767.98px) {
    .free-register-detail-title {
      display: none; } }

.free-ticket-cart-container {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  margin-bottom: 1.5rem; }
  @media (max-width: 767.98px) {
    .free-ticket-cart-container {
      margin-bottom: .5rem; } }
  .free-ticket-cart-container .free-ticket-cart-header {
    font-weight: 400;
    font-size: 24px; }
    @media (max-width: 767.98px) {
      .free-ticket-cart-container .free-ticket-cart-header {
        display: none; } }

.ticket-cart-header {
  border-radius: 20px;
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
  background-color: black;
  color: white;
  font-weight: 400;
  font-size: 24px;
  min-height: 75px;
  display: none;
  justify-content: space-between;
  align-items: center;
  cursor: pointer; }
  @media (max-width: 767.98px) {
    .ticket-cart-header {
      display: flex; } }
  .ticket-cart-header .ticket-cart-header-title {
    padding-left: 58px; }

.register-form-header {
  border-top: 1px solid #e7e7e7;
  border-left: 1px solid #e7e7e7;
  border-right: 1px solid #e7e7e7;
  background-color: white;
  color: black;
  font-weight: 400;
  font-size: 24px;
  padding-top: 24px;
  padding-bottom: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  border-radius: 8px 8px 0px 0px;
  cursor: pointer; }
  .register-form-header.expand {
    padding-bottom: 24px; }
  .register-form-header .payment-form-header-title {
    padding-left: 58px; }
  .register-form-header .bill-form-header-title {
    padding-left: 58px;
    font-weight: bold;
    font-size: 18px; }
  .register-form-header .person-form-header-title {
    display: flex;
    align-items: center; }
  .register-form-header .person-form-header-icon {
    display: none;
    align-items: center;
    color: white; }
    @media (max-width: 767.98px) {
      .register-form-header .person-form-header-icon {
        display: flex; } }
  .register-form-header .person-form-order {
    width: 58px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 75px;
    border-radius: 20px;
    background-color: #B70909; }
    @media (max-width: 767.98px) {
      .register-form-header .person-form-order {
        width: 38px; } }
  .register-form-header .person-form-select-copy {
    border-radius: 10px;
    width: 100%;
    flex-basis: 0px;
    flex-grow: 1;
    height: 42px;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: 0em;
    text-align: left;
    overflow: hidden;
    text-overflow: ellipsis;
    border: none;
    text-align: center;
    color: black;
    border: 1px solid black; }
    .register-form-header .person-form-select-copy:focus {
      outline: none; }
  .register-form-header .person-form-type {
    width: 130px;
    flex-basis: 0px;
    flex-grow: 1;
    height: 42px;
    background: #000000;
    border: 1px solid #FFFFFF;
    border-radius: 13px;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    text-transform: capitalize;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: 0em;
    padding-left: 0.5rem;
    padding-right: 0.5rem; }
    @media (max-width: 767.98px) {
      .register-form-header .person-form-type {
        width: 80px; } }

.ellipsis-text {
  min-width: 0px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden; }

.bill-form-container {
  margin-bottom: 1.5rem; }
  @media (max-width: 767.98px) {
    .bill-form-container {
      margin-bottom: 84px; } }

.box-card-shadow {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px; }

.register-form-body {
  border-bottom: 1px solid #e7e7e7;
  border-left: 1px solid #e7e7e7;
  border-right: 1px solid #e7e7e7;
  padding-left: 3rem;
  padding-right: 3rem;
  border-radius: 0px 0px 8px 8px; }
  .register-form-body.onsite {
    border: none;
    box-shadow: 0 0.15rem 1.75rem 0 rgba(58, 59, 69, 0.15);
    padding-left: 1rem;
    padding-right: 1rem;
    border-radius: 20px !important; }
  @media (max-width: 767.98px) {
    .register-form-body {
      padding-left: 1.5rem;
      padding-right: 1.5rem; } }
  .register-form-body .payment-form-method {
    border-radius: 20px;
    box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
    min-height: 82px;
    cursor: pointer;
    display: flex;
    align-items: center; }
    .register-form-body .payment-form-method .radio-button {
      width: 28px;
      height: 28px;
      min-width: 28px;
      border-radius: 50%;
      box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
      display: flex;
      justify-content: center;
      align-items: center; }
      .register-form-body .payment-form-method .radio-button .selected-dot {
        border-radius: 50%;
        background-color: black;
        width: 100%;
        height: 100%; }
    .register-form-body .payment-form-method .method-icon {
      height: 30px;
      object-fit: contain; }
    .register-form-body .payment-form-method .method-name {
      font-weight: 400;
      font-size: 18px; }
  .register-form-body .person-form-save-button {
    border-radius: 10px;
    background: #B70909;
    width: 100%;
    height: 38px;
    border: none; }

.page-prev-link,
.page-next-link {
  text-decoration: none;
  color: #000000;
  width: 40px;
  height: 40px;
  font-size: 14px;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center; }

.page-button {
  border-radius: 4px;
  width: 40px;
  height: 40px;
  font-size: 16px;
  font-weight: 600; }

@media (max-width: 767.98px) {
  .free-register-button-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 50px;
    border-radius: 10px 10px 0px 0px;
    background: white;
    font-size: 16px;
    font-weight: 600;
    padding-left: 1.5rem;
    z-index: 99999;
    padding-right: 1.5rem; } }

.free-register-button-container .free-register-button {
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 40px;
  width: 100%;
  border: none;
  background: #000000;
  color: white;
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 10px; }
  @media (max-width: 767.98px) {
    .free-register-button-container .free-register-button {
      border-radius: 40px;
      background: #000000;
      color: white;
      font-size: 16px;
      font-weight: 600;
      z-index: 99999;
      margin: 0px; } }

.free-register-button-container .change-bank-register-button {
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 40px;
  width: 100%;
  border: none;
  background: #000000;
  color: white;
  font-size: 18px;
  font-weight: 600; }
  @media (max-width: 767.98px) {
    .free-register-button-container .change-bank-register-button {
      display: none !important; } }

.change-bank-mb-register-button {
  display: none !important; }
  @media (max-width: 767.98px) {
    .change-bank-mb-register-button {
      padding: 10px;
      display: flex !important;
      justify-content: center;
      align-items: center;
      border-radius: 10px;
      width: 100%;
      border: none;
      background: #000000;
      color: white;
      font-size: 18px;
      font-weight: 600; } }

.onsite-register-button-container {
  display: flex;
  justify-content: end;
  align-items: center; }
  .onsite-register-button-container .onsite-register-button {
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    border: none;
    background: #000000;
    color: white;
    height: 41px;
    min-width: 180px; }

.button-cart-pay {
  border: none;
  width: 100%;
  padding: 10px 30px;
  border-radius: 50px;
  font-weight: 500;
  font-size: 23px; }
  @media (max-width: 767.98px) {
    .button-cart-pay {
      position: fixed;
      bottom: 0px;
      left: 0px;
      z-index: 199;
      border-radius: 20px 20px 0px 0px; } }

.bill-form-title {
  font-weight: bold;
  font-size: 22px; }

.btn-buy-ticket {
  border-radius: 40px;
  padding: 10px 50px; }

.btn-buy-ticket-sm {
  border-radius: 40px;
  padding: 5px 50px;
  margin-bottom: 20px;
  margin-top: 20px; }

.clear-code-button {
  background: transparent;
  font-size: 16px;
  font-weight: 300;
  border: none; }

.clear-code-button {
  background: transparent;
  font-size: 17px;
  line-height: 20px;
  border: none; }

.clear-promocode-button {
  background: #d9d9d9;
  color: #FFFFFF;
  font-size: 10px;
  border: none;
  position: absolute;
  top: 50%;
  border-radius: 15px;
  right: -5px;
  transform: translate(-50%, -50%);
  text-align: center; }

.text-detail-bank {
  font-size: 14px;
  font-weight: 500; }

.contain-payment-type {
  background-color: #edf3fd; }

.disable-form-color {
  background-color: #e9ecef !important; }

.insight__buy--ticket {
  border-radius: 6px;
  padding: 5px 60px; }

.no-chevron select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none; }

.no-chevron i {
  right: 10px;
  bottom: 11px;
  pointer-events: none;
  font-size: 14px; }

.btn__onsite--register.outline {
  background-color: white;
  color: #4C5398; }

.btn__onsite--register {
  width: 154px;
  height: 56px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 6px;
  border-style: solid;
  border-color: #4C5398;
  background-color: #4C5398;
  color: white;
  font-weight: 600; }

.btn__onsite--register:hover {
  opacity: 0.8; }

.register__modal--otp {
  min-height: 70vh;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column; }
  .register__modal--otp .input-height {
    min-height: 80px; }
  .register__modal--otp .pincode-input-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    width: 100%; }
    .register__modal--otp .pincode-input-container .pincode-input-text {
      font-size: 28.8px;
      font-weight: 700;
      padding: 0 !important;
      margin: 0px !important;
      text-align: center !important;
      border: 1.2px solid rgba(66, 67, 72, 0.2) !important;
      background: transparent;
      height: 60px !important;
      width: 100% !important;
      max-width: 60px !important;
      min-width: 0px !important;
      flex-grow: 1;
      border-radius: 8px !important; }
    .register__modal--otp .pincode-input-container .pincode-input-text:focus {
      outline: none;
      box-shadow: none;
      border: 1px solid rgba(66, 67, 72, 0.5) !important; }
    .register__modal--otp .pincode-input-container .text-decoration-underline {
      text-decoration: underline !important; }

.animate-spin {
  animation: spin 1s linear infinite; }

@keyframes spin {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(360deg); } }

.register__otp {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: fixed;
  z-index: 12000;
  top: -100px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  background-color: #fff;
  transition: all .3s;
  border-radius: 20px;
  visibility: hidden;
  opacity: 0; }

.register__otp--show {
  visibility: visible;
  opacity: 1;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  border-radius: 0px;
  z-index: 99999999; }

.form-section-event-name-container {
  background-color: white;
  border-radius: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  font-size: 20px;
  font-weight: bold;
  color: #9091A7;
  min-height: 52px; }

.text-event-name-form {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 5px 15px; }

.section-pdpa-modal .modal-content {
  border-radius: 20px !important;
  position: relative; }
  .section-pdpa-modal .modal-content .button-close-pdpa {
    position: absolute;
    top: -10px;
    right: -30px;
    font-size: 28px;
    color: #ffffff; }
    @media (max-width: 767.98px) {
      .section-pdpa-modal .modal-content .button-close-pdpa {
        position: absolute;
        color: #000000;
        top: -68dvh;
        right: -41dvw;
        height: 100%;
        width: 100%;
        display: flex;
        justify-content: center;
        align-items: end;
        margin-top: 30px;
        z-index: 9999999; } }

.section-pdpa-modal .title-pdpa {
  padding-top: 40px;
  padding-left: 60px;
  padding-right: 60px;
  font-size: 18px;
  font-weight: bold; }
  @media (max-width: 767.98px) {
    .section-pdpa-modal .title-pdpa {
      padding-top: 30px;
      padding-left: 30px;
      padding-right: 30px;
      margin-bottom: 16px; } }

.section-pdpa-modal .content-pdpa {
  padding-left: 60px;
  padding-right: 60px;
  margin-bottom: 15px; }
  @media (max-width: 767.98px) {
    .section-pdpa-modal .content-pdpa {
      padding-left: 30px;
      padding-right: 30px; } }

.section-pdpa-modal .button-pdpa {
  display: flex;
  justify-content: center;
  padding-top: 30px;
  margin-bottom: 30px; }
  @media (max-width: 767.98px) {
    .section-pdpa-modal .button-pdpa {
      margin-bottom: 10px;
      padding-top: 0px; } }
  .section-pdpa-modal .button-pdpa button {
    width: 154px;
    height: 56px;
    font-weight: bold; }

.section-payment-container {
  background-color: white;
  padding: 30px;
  margin-top: 20px;
  border-radius: 8px;
  text-align: start; }
  .section-payment-container .section-payment-title {
    font-size: 20px;
    font-weight: bold; }
  .section-payment-container .section-payment-time-countdown {
    font-size: 20px;
    font-weight: 700;
    line-height: 25px;
    text-align: center;
    color: #C53637; }
  .section-payment-container .section-payment-description {
    font-size: 14px;
    color: #9091A7; }
  .section-payment-container .section-select-payment-container {
    margin-top: 20px; }
    .section-payment-container .section-select-payment-container .section-payment-type {
      padding: 20px;
      background-color: #F9F9F9;
      border-radius: 8px;
      display: flex;
      justify-content: center;
      padding: 20px;
      font-size: 16px;
      cursor: pointer;
      align-items: center; }
      .section-payment-container .section-select-payment-container .section-payment-type.active {
        background-color: #CC1F1F;
        color: white;
        font-weight: bold; }
      .section-payment-container .section-select-payment-container .section-payment-type .radio-payment {
        margin-right: 10px;
        width: 20px;
        height: 20px;
        border-radius: 20px;
        border: 2px solid #9091A7;
        display: flex;
        justify-content: center;
        align-items: center;
        background-color: white; }
        .section-payment-container .section-select-payment-container .section-payment-type .radio-payment .active {
          background-color: #CC1F1F;
          width: 8px;
          height: 8px;
          border-radius: 12px; }

.form-section-event-name-container {
  background-color: white;
  border-radius: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  font-size: 20px;
  font-weight: bold;
  color: #9091A7;
  min-height: 52px; }

.form-section-container {
  background-color: white;
  border-radius: 10px;
  padding: 32px;
  margin-top: 20px;
  width: 100%; }

.form-section {
  background-color: white;
  border-radius: 10px;
  padding: 32px; }
  @media (max-width: 740.98px) {
    .form-section {
      padding: 16px; } }
  .form-section .form-control {
    border: 1px solid #9091A7;
    border-radius: 10px; }
  .form-section .fr-view {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 8px; }
  .form-section .person-form-header-title {
    font-size: 20px;
    font-weight: bold; }
  .form-section .question-label-container {
    font-size: 16px;
    font-weight: bold;
    margin-top: 8px; }
  .form-section .text-danger {
    text-align: start; }
  .form-section .register-form-header {
    border-radius: 10px 10px 0px 0px;
    background-color: #FFFAFA;
    border: 1px transparent solid;
    padding-top: 20px;
    padding-left: 10px;
    padding-right: 10px; }
    .form-section .register-form-header.expand {
      background-color: transparent !important; }
  .form-section .register-form-body {
    border-radius: 0px 0px 10px 10px;
    background-color: transparent !important;
    border: 1px transparent solid;
    padding: 48px !important;
    padding-top: 0px !important;
    padding-bottom: 0px !important;
    padding-left: 10px;
    padding-right: 10px; }
    @media (max-width: 740.98px) {
      .form-section .register-form-body {
        padding: 16px !important;
        padding-top: 0px !important;
        padding-bottom: 0px !important; } }
    .form-section .register-form-body.form-section-expand {
      background-color: #FFFAFA !important; }
  .form-section .box-card-shadow {
    box-shadow: none;
    margin-bottom: 0px !important; }
  .form-section .expand-container {
    background-color: #FA8080;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    color: white;
    display: flex;
    justify-content: center;
    align-items: center; }
  .form-section .form-list-title-index {
    font-size: 20px;
    font-weight: bold; }
  .form-section .person-form-select-copy {
    border: 1px solid #9091A7 !important;
    border-radius: 10px !important; }
  .form-section .person-form-select-copy-container {
    padding-left: 2.3vw;
    padding-right: 2.3vw; }

.form-ticket-section .ticket-cart-container {
  border-radius: 10px; }

.form-ticket-section .ticket-cart-detail {
  padding: 30px !important; }

.form-ticket-section .ticket-cart-title {
  font-size: 20px !important;
  font-weight: bold !important; }

.form-ticket-section .input-number {
  font-weight: normal !important;
  font-size: 24px !important;
  text-decoration: none !important; }

.form-ticket-section .input-container {
  display: flex;
  align-items: center; }

.form-ticket-section .ticket-cart-item-name {
  flex-grow: 1; }

.form-ticket-section .ticket-cart-item {
  display: flex;
  align-items: center; }

.form-ticket-section .input-button {
  border-radius: 25px !important;
  width: 25px !important;
  height: 25px !important; }
  .form-ticket-section .input-button.disabled {
    background: #F3F3F3; }
  .form-ticket-section .input-button:disabled {
    background: #F3F3F3; }

.form-ticket-section .ticket-cart-promo-container {
  flex-direction: column !important;
  align-items: start !important;
  padding: 0px !important; }

.form-ticket-section .promo-title {
  font-size: 16px !important;
  margin-bottom: 8px; }

.form-ticket-section .promo-description {
  font-size: 12px;
  margin-bottom: 8px; }

.form-ticket-section .ticket-cart-list-container {
  padding: 0px !important; }

.form-ticket-section .input-emt-promo-code {
  border: 1px solid #9091A7 !important;
  border-radius: 6px !important;
  height: 32px !important; }

.form-ticket-section .apply-code-emt-button {
  border-radius: 6px !important;
  background-color: #CC1F1F !important;
  height: 32px !important; }
  .form-ticket-section .apply-code-emt-button:disabled {
    background: #D9D9D9 !important;
    cursor: not-allowed; }

.form-ticket-section .ticket-cart-sum-container {
  padding: 0px !important; }

.form-ticket-section .pdpa-text {
  font-size: 12px;
  text-align: start; }

.form-ticket-section .free-register-button-container {
  width: 100% !important; }

.form-ticket-section .free-register-button {
  border-radius: 6px !important; }

.bank-card-img {
  width: 41px;
  height: 41px;
  object-fit: cover;
  border-radius: 6px; }

.bank-card-name {
  margin-left: 1rem;
  font-size: 14px;
  font-weight: 600; }

.text-change-bank {
  color: #d50000;
  font-weight: bold;
  cursor: pointer;
  text-decoration: underline; }
  .text-change-bank:hover {
    text-decoration: none; }

.box-shadow-bg-white {
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25); }

.section-form-content {
  border-radius: 10px;
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(224px);
  padding: 20px; }
  @media (max-width: 600px) {
    .section-form-content {
      padding: 0px;
      padding-bottom: 10px; } }

.section-form-bg-content {
  background-color: #5f5f5f !important;
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px); }

.zone-content-for-link-form {
  padding: 20px;
  text-align: start;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  position: relative;
  border-radius: 10px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px); }
  .zone-content-for-link-form .datetimes-container {
    background-color: white;
    border-radius: 10px;
    padding: 24px;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
    flex-direction: row;
    align-items: center;
    height: 100%;
    justify-content: center;
    color: #9091A7;
    font-weight: bold; }
  .zone-content-for-link-form .zone-container {
    background-color: black;
    border-radius: 8px;
    padding: 16px;
    margin-top: 20px;
    width: 100%; }
    .zone-content-for-link-form .zone-container .title {
      font-size: 24px;
      font-weight: bold;
      color: white; }
    .zone-content-for-link-form .zone-container .description {
      font-size: 14px;
      color: white;
      margin-top: 16px; }
    .zone-content-for-link-form .zone-container .description-seat {
      display: flex;
      color: white;
      justify-content: space-evenly;
      font-weight: 700;
      margin-top: 16px; }
    .zone-content-for-link-form .zone-container .map-zone-seat {
      margin-top: 16px;
      padding-left: 30px;
      padding-right: 30px;
      position: relative; }
    .zone-content-for-link-form .zone-container .price-container {
      border-radius: 10px;
      background-color: white;
      padding: 30px;
      position: absolute;
      top: 0px;
      right: 30px; }
      .zone-content-for-link-form .zone-container .price-container .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content-for-link-form .zone-container .price-container .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content-for-link-form .zone-container .price-container .price-box .price {
          font-size: 16px;
          font-weight: bold; }
        .zone-content-for-link-form .zone-container .price-container .price-box .ticket-full {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #FFEAEA;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content-for-link-form .zone-container .price-container .price-box .ticket-sell {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #EFFFED;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }
    .zone-content-for-link-form .zone-container .price-container-mobile {
      border-radius: 10px;
      background-color: white;
      display: flex;
      flex-direction: column;
      padding: 16px;
      margin-top: 20px; }
      .zone-content-for-link-form .zone-container .price-container-mobile .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content-for-link-form .zone-container .price-container-mobile .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content-for-link-form .zone-container .price-container-mobile .price-box .price {
          font-size: 16px;
          font-weight: bold; }
        .zone-content-for-link-form .zone-container .price-container-mobile .price-box .ticket-full {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #FFEAEA;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content-for-link-form .zone-container .price-container-mobile .price-box .ticket-sell {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #EFFFED;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }

.btn:focus,
.btn:active {
  outline: none !important;
  box-shadow: none !important; }

#language-dropdown.dropdown-toggle:after {
  content: none !important;
  display: none; }

.dropdown-item:active {
  color: #16181b !important;
  text-decoration: none !important;
  background-color: #e9ecef !important; }

.complete-container {
  border-radius: 40px;
  background-color: white;
  position: relative;
  box-shadow: 0px 4px 14px rgba(0, 0, 0, 0.25);
  padding: 62px;
  display: flex;
  flex-direction: column;
  align-items: center; }
  @media (max-width: 575.98px) {
    .complete-container {
      box-shadow: none;
      padding-top: 32px;
      padding-bottom: 32px;
      padding-left: 0px;
      padding-right: 0px; } }
  .complete-container .close-complete-button {
    background: #FFFFFF;
    border: 1px solid #DADADA;
    border-radius: 12px;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 28px;
    right: 28px; }
    @media (max-width: 575.98px) {
      .complete-container .close-complete-button {
        top: 18px;
        right: 18px; } }
  .complete-container .complete-header {
    font-weight: 700;
    font-size: 46px;
    line-height: 57.5px;
    text-align: center;
    color: #1e232c;
    margin-bottom: 3rem; }
    @media (max-width: 575.98px) {
      .complete-container .complete-header {
        font-size: 16px;
        margin-bottom: 1.5rem;
        line-height: 20.5px; } }
  .complete-container .thanks-container {
    display: flex;
    justify-content: center;
    font-weight: 600;
    font-size: 26px;
    line-height: 125%;
    flex-wrap: wrap;
    text-align: center;
    color: #1e232c;
    margin-bottom: 3rem; }
    @media (max-width: 575.98px) {
      .complete-container .thanks-container {
        font-size: 11px;
        margin-bottom: 1.5rem; } }
    .complete-container .thanks-container .thanks-text {
      letter-spacing: 0.71em;
      white-space: nowrap;
      margin-right: 1.5rem; }
      @media (max-width: 575.98px) {
        .complete-container .thanks-container .thanks-text {
          margin-right: .5rem; } }
  .complete-container .barcode-container {
    width: 380px;
    height: 120px; }
    @media (max-width: 575.98px) {
      .complete-container .barcode-container {
        width: 153px;
        height: 48px; } }
    .complete-container .barcode-container .barcode-image {
      object-fit: contain;
      height: 100%;
      width: 100%; }
  .complete-container .qrcode-container {
    width: 421px;
    height: 421px; }
    @media (max-width: 575.98px) {
      .complete-container .qrcode-container {
        width: 256px;
        height: 256px; } }
    .complete-container .qrcode-container .qrcode-image {
      object-fit: contain;
      height: 100%;
      width: 100%; }
  .complete-container .qr-code-download-link {
    font-size: 23px;
    font-weight: 400;
    line-height: 125%;
    text-align: center;
    text-decoration-line: underline;
    color: #1e232c;
    border: none;
    background-color: transparent; }
    @media (max-width: 575.98px) {
      .complete-container .qr-code-download-link {
        font-size: 16px; } }
  .complete-container .complete-separator {
    border: 0.5px solid #CDCDCD;
    width: 60%;
    margin-top: 3rem;
    margin-bottom: 3rem; }
    @media (max-width: 575.98px) {
      .complete-container .complete-separator {
        width: 100%;
        height: 4px;
        background-color: #F7F7F7;
        border: 0.5px solid #F7F7F7;
        margin-top: 1.5rem;
        margin-bottom: 1.5rem; } }
  .complete-container .complete-manual-title {
    font-size: 23px;
    font-weight: 700;
    line-height: 28.5px;
    text-align: center;
    margin-bottom: 1.5rem; }
    @media (max-width: 575.98px) {
      .complete-container .complete-manual-title {
        font-size: 13px;
        margin-bottom: 1rem; } }
  .complete-container .complete-manual-subject {
    font-size: 23px;
    font-weight: 400;
    line-height: 28.5px;
    display: flex;
    align-items: center;
    text-align: left; }
    @media (max-width: 575.98px) {
      .complete-container .complete-manual-subject {
        font-size: 13px; } }
    .complete-container .complete-manual-subject .complete-manual-order {
      width: 24px;
      height: 24px;
      min-width: 24px;
      min-height: 24px;
      border-radius: 50%;
      background-color: #1e232c;
      color: white;
      display: flex;
      justify-content: center;
      align-items: center; }

.contain-html-complete {
  border-radius: 10px;
  background-color: white;
  box-shadow: 0px 4px 14px rgba(0, 0, 0, 0.25); }

#inner-dropzone {
  position: relative; }

.main-contain-complete {
  min-height: 20vh;
  max-height: 20vh;
  position: relative; }

.contain-complete {
  position: absolute;
  min-height: 15vh;
  top: 10vh; }

.contain-complete2 {
  position: absolute;
  min-height: 15vh;
  top: -10vh;
  padding: 0px !important; }

.contain-complete-card-html {
  position: absolute;
  margin-top: 15vh;
  padding: 0px !important; }

.border-10 {
  border-radius: 10px; }

.text-titel-bander {
  font-size: 20px;
  line-height: 30px;
  font-weight: 400; }
  @media (max-width: 575.98px) {
    .text-titel-bander {
      font-size: 16px;
      line-height: 20px; } }

.line-icon {
  text-align: center; }

.line-icon::before,
.line-icon::after {
  width: 25%;
  height: 1px;
  border-top: 1px solid #FFFFFF;
  display: inline-block;
  content: '';
  padding-top: 0.5em;
  margin-left: 5%;
  margin-right: 5%; }

.line-icon-3 {
  text-align: center; }

.line-icon-3::before,
.line-icon-3::after {
  width: 30%;
  height: 1px;
  border-top: 3px solid #FFFFFF;
  display: inline-block;
  content: '';
  padding-top: 0.5em;
  margin-left: 5%;
  margin-right: 5%; }

.bg-screen-complete {
  background-position: center;
  background-attachment: fixed;
  min-height: 100vh;
  overflow: auto; }

.bg-complete {
  filter: blur(8px) brightness(55%);
  height: 20vh;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  left: 0px;
  right: 0px; }

.bg-upload-complete {
  filter: blur(8px) brightness(55%);
  height: 50vh;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  left: 0px;
  right: 0px; }

.contain-regis-complete {
  margin-top: 8vh;
  padding-top: 0px; }
  @media (max-width: 575.98px) {
    .contain-regis-complete {
      margin-top: 5vh; } }

.contain-upload-slip-complete {
  padding-top: 0px; }
  @media (max-width: 575.98px) {
    .contain-upload-slip-complete {
      margin-top: 5vh; } }

.contain-upload-complete {
  margin-top: 35vh;
  padding-top: 0px; }
  @media (max-width: 575.98px) {
    .contain-upload-complete {
      margin-top: 40vh; } }

.ReactCrop {
  position: relative;
  display: inline-block;
  cursor: crosshair;
  overflow: hidden;
  max-width: 100%;
  border-radius: 8px; }

.ReactCrop *,
.ReactCrop *:before,
.ReactCrop *:after {
  box-sizing: border-box; }

.ReactCrop--disabled,
.ReactCrop--locked {
  cursor: inherit; }

.ReactCrop__child-wrapper {
  max-height: inherit; }

.ReactCrop__child-wrapper > img,
.ReactCrop__child-wrapper > video {
  display: block;
  max-width: 100%;
  max-height: inherit; }

.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper > img,
.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper > video {
  touch-action: none; }

.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection {
  touch-action: none; }

.ReactCrop__crop-selection {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateZ(0);
  cursor: move;
  box-shadow: 0 0 0 9999em #00000080; }

.ReactCrop--disabled .ReactCrop__crop-selection {
  cursor: inherit; }

.ReactCrop--circular-crop .ReactCrop__crop-selection {
  border-radius: 50%;
  box-shadow: 0 0 1px 1px #fff, 0 0 0 9999em #00000080; }

.ReactCrop--no-animate .ReactCrop__crop-selection {
  border: 1px dashed white; }

.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection) {
  animation: marching-ants 1.5s;
  background-image: linear-gradient(to right, #fff 50%, #444 50%), linear-gradient(to right, #fff 50%, #444 50%), linear-gradient(to bottom, #fff 50%, #444 50%), linear-gradient(to bottom, #fff 50%, #444 50%);
  background-size: 10px 1px, 10px 1px, 1px 10px, 1px 10px;
  background-position: 0 0, 0 100%, 0 0, 100% 0;
  background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;
  color: #fff;
  animation-play-state: running;
  animation-timing-function: linear;
  animation-iteration-count: infinite; }

@keyframes marching-ants {
  0% {
    background-position: 0 0, 0 100%, 0 0, 100% 0; }
  to {
    background-position: 40px 0, -40px 100%, 0 -40px, 100% 40px; } }

.ReactCrop__crop-selection:focus {
  outline: none;
  border-color: #00f;
  border-style: solid; }

.ReactCrop--invisible-crop .ReactCrop__crop-selection {
  display: none; }

.ReactCrop__rule-of-thirds-vt:before,
.ReactCrop__rule-of-thirds-vt:after,
.ReactCrop__rule-of-thirds-hz:before,
.ReactCrop__rule-of-thirds-hz:after {
  content: "";
  display: block;
  position: absolute;
  background-color: #fff6; }

.ReactCrop__rule-of-thirds-vt:before,
.ReactCrop__rule-of-thirds-vt:after {
  width: 1px;
  height: 100%; }

.ReactCrop__rule-of-thirds-vt:before {
  left: 33.3333%;
  left: 33.3333333333%; }

.ReactCrop__rule-of-thirds-vt:after {
  left: 66.6666%;
  left: 66.6666666667%; }

.ReactCrop__rule-of-thirds-hz:before,
.ReactCrop__rule-of-thirds-hz:after {
  width: 100%;
  height: 1px; }

.ReactCrop__rule-of-thirds-hz:before {
  top: 33.3333%;
  top: 33.3333333333%; }

.ReactCrop__rule-of-thirds-hz:after {
  top: 66.6666%;
  top: 66.6666666667%; }

.ReactCrop__drag-handle {
  position: absolute; }

.ReactCrop__drag-handle:after {
  position: absolute;
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background-color: #0003;
  border: 1px solid rgba(255, 255, 255, 0.7);
  outline: 1px solid transparent; }

.ReactCrop__drag-handle:focus:after {
  border-color: #00f;
  background: #2dbfff; }

.ReactCrop .ord-nw {
  top: 0;
  left: 0;
  margin-top: -5px;
  margin-left: -5px;
  cursor: nw-resize; }

.ReactCrop .ord-nw:after {
  top: 0;
  left: 0; }

.ReactCrop .ord-n {
  top: 0;
  left: 50%;
  margin-top: -5px;
  margin-left: -5px;
  cursor: n-resize; }

.ReactCrop .ord-n:after {
  top: 0; }

.ReactCrop .ord-ne {
  top: 0;
  right: 0;
  margin-top: -5px;
  margin-right: -5px;
  cursor: ne-resize; }

.ReactCrop .ord-ne:after {
  top: 0;
  right: 0; }

.ReactCrop .ord-e {
  top: 50%;
  right: 0;
  margin-top: -5px;
  margin-right: -5px;
  cursor: e-resize; }

.ReactCrop .ord-e:after {
  right: 0; }

.ReactCrop .ord-se {
  bottom: 0;
  right: 0;
  margin-bottom: -5px;
  margin-right: -5px;
  cursor: se-resize; }

.ReactCrop .ord-se:after {
  bottom: 0;
  right: 0; }

.ReactCrop .ord-s {
  bottom: 0;
  left: 50%;
  margin-bottom: -5px;
  margin-left: -5px;
  cursor: s-resize; }

.ReactCrop .ord-s:after {
  bottom: 0; }

.ReactCrop .ord-sw {
  bottom: 0;
  left: 0;
  margin-bottom: -5px;
  margin-left: -5px;
  cursor: sw-resize; }

.ReactCrop .ord-sw:after {
  bottom: 0;
  left: 0; }

.ReactCrop .ord-w {
  top: 50%;
  left: 0;
  margin-top: -5px;
  margin-left: -5px;
  cursor: w-resize; }

.ReactCrop .ord-w:after {
  left: 0; }

.ReactCrop__disabled .ReactCrop__drag-handle {
  cursor: inherit; }

.ReactCrop__drag-bar {
  position: absolute; }

.ReactCrop__drag-bar.ord-n {
  top: 0;
  left: 0;
  width: 100%;
  height: 6px;
  margin-top: -3px; }

.ReactCrop__drag-bar.ord-e {
  right: 0;
  top: 0;
  width: 6px;
  height: 100%;
  margin-right: -3px; }

.ReactCrop__drag-bar.ord-s {
  bottom: 0;
  left: 0;
  width: 100%;
  height: 6px;
  margin-bottom: -3px; }

.ReactCrop__drag-bar.ord-w {
  top: 0;
  left: 0;
  width: 6px;
  height: 100%;
  margin-left: -3px; }

.ReactCrop--new-crop .ReactCrop__drag-bar,
.ReactCrop--new-crop .ReactCrop__drag-handle,
.ReactCrop--fixed-aspect .ReactCrop__drag-bar,
.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,
.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,
.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,
.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w {
  display: none; }

@media (pointer: coarse) {
  .ReactCrop .ord-n,
  .ReactCrop .ord-e,
  .ReactCrop .ord-s,
  .ReactCrop .ord-w {
    display: none; }
  .ReactCrop__drag-handle {
    width: 24px;
    height: 24px; } }

@keyframes react-loading-skeleton {
  100% {
    transform: translateX(100%); } }

.react-loading-skeleton {
  --base-color: #ebebeb;
  --highlight-color: #f5f5f5;
  --animation-duration: 1.5s;
  --animation-direction: normal;
  --pseudo-element-display: block;
  /* Enable animation */
  background-color: var(--base-color);
  width: 100%;
  border-radius: 0.25rem;
  display: inline-flex;
  line-height: 1;
  position: relative;
  user-select: none;
  overflow: hidden;
  z-index: 1;
  /* Necessary for overflow: hidden to work correctly in Safari */ }

.react-loading-skeleton::after {
  content: ' ';
  display: var(--pseudo-element-display);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100%;
  background-repeat: no-repeat;
  background-image: linear-gradient(90deg, var(--base-color), var(--highlight-color), var(--base-color));
  transform: translateX(-100%);
  animation-name: react-loading-skeleton;
  animation-direction: var(--animation-direction);
  animation-duration: var(--animation-duration);
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@media (prefers-reduced-motion) {
  .react-loading-skeleton {
    --pseudo-element-display: none;
    /* Disable animation */ } }

.ticket-card .react-loading-skeleton {
  border-radius: 8px; }

.ticket-card .container-banner-event .react-loading-skeleton {
  border-radius: 8px 8px 0 0; }

@media (max-width: 767.98px) {
  .ticket-card {
    margin-bottom: 16px; }
    .ticket-card .event-details {
      padding: 12px !important; }
      .ticket-card .event-details .react-loading-skeleton:first-child {
        height: 20px !important; }
    .ticket-card .container-banner-event .react-loading-skeleton {
      height: 150px !important; }
    .ticket-card .event-info .react-loading-skeleton {
      height: 12px !important; } }

@media (max-width: 575.98px) {
  .ticket-card .container-banner-event .react-loading-skeleton {
    height: 120px !important; }
  .ticket-card .event-details {
    padding: 8px !important; }
  .ticket-card .event-info .react-loading-skeleton {
    height: 11px !important; } }

@media (max-width: 480px) {
  .ticket-card .container-banner-event .react-loading-skeleton {
    height: 100px !important; } }

@media (max-width: 767.98px) {
  .tickets-list.row .ticket-card {
    flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 12px; } }

@media (min-width: 768px) and (max-width: 991.98px) {
  .tickets-list.row .ticket-card {
    flex: 0 0 50%;
    max-width: 50%;
    margin-bottom: 16px; } }

@media (min-width: 992px) {
  .tickets-list.row .ticket-card {
    margin-bottom: 20px; } }

.event-ticket-card {
  margin-bottom: 16px; }
  .event-ticket-card .react-loading-skeleton {
    border-radius: 4px; }
  @media (max-width: 767.98px) {
    .event-ticket-card {
      margin-bottom: 12px; }
      .event-ticket-card .ticket-content-member {
        padding: 12px !important; }
        .event-ticket-card .ticket-content-member .ticket-actions {
          gap: 6px !important; }
          .event-ticket-card .ticket-content-member .ticket-actions .react-loading-skeleton {
            height: 32px !important; }
            .event-ticket-card .ticket-content-member .ticket-actions .react-loading-skeleton:first-child {
              width: 100px !important; }
            .event-ticket-card .ticket-content-member .ticket-actions .react-loading-skeleton:last-child {
              width: 70px !important; }
        .event-ticket-card .ticket-content-member .ticket-main-info .react-loading-skeleton:first-child {
          width: 100px !important;
          height: 16px !important; }
        .event-ticket-card .ticket-content-member .ticket-main-info .react-loading-skeleton:nth-child(2) {
          width: 160px !important;
          height: 14px !important; } }
  @media (max-width: 575.98px) {
    .event-ticket-card .ticket-content-member {
      padding: 10px !important; }
      .event-ticket-card .ticket-content-member .ticket-main-info .react-loading-skeleton:first-child {
        width: 80px !important;
        height: 14px !important; }
      .event-ticket-card .ticket-content-member .ticket-main-info .react-loading-skeleton:nth-child(2) {
        width: 120px !important;
        height: 12px !important; }
      .event-ticket-card .ticket-content-member .ticket-actions .react-loading-skeleton {
        height: 28px !important; }
        .event-ticket-card .ticket-content-member .ticket-actions .react-loading-skeleton:first-child {
          width: 80px !important; }
        .event-ticket-card .ticket-content-member .ticket-actions .react-loading-skeleton:last-child {
          width: 60px !important; } }

@media (max-width: 767.98px) {
  .send-card-modal {
    padding: 16px; }
    .send-card-modal .ticket-display-card .react-loading-skeleton:first-child {
      height: 200px !important;
      width: 200px !important; }
    .send-card-modal .accept-button-container .react-loading-skeleton {
      width: 100px !important;
      height: 40px !important; } }

@media (max-width: 575.98px) {
  .send-card-modal .ticket-display-card .react-loading-skeleton:first-child {
    height: 150px !important;
    width: 150px !important; } }

@media (max-width: 767.98px) {
  .profile-form-container .react-loading-skeleton[style*="height: 44px"] {
    height: 40px !important; }
  .profile-form-container .react-loading-skeleton[style*="height: 100px"] {
    height: 80px !important; } }

@media (max-width: 575.98px) {
  .profile-form-container .react-loading-skeleton[style*="height: 40px"] {
    height: 36px !important; } }

@media (max-width: 767.98px) {
  .payment-card-skeleton {
    padding: 16px !important;
    margin-bottom: 12px !important; }
    .payment-card-skeleton .react-loading-skeleton[style*="height: 20px"] {
      height: 18px !important; }
    .payment-card-skeleton .react-loading-skeleton[style*="height: 18px"] {
      height: 16px !important; }
    .payment-card-skeleton .react-loading-skeleton[style*="height: 36px"] {
      height: 32px !important; } }

@media (max-width: 575.98px) {
  .payment-card-skeleton {
    padding: 12px !important; }
    .payment-card-skeleton .react-loading-skeleton[style*="width: 250px"] {
      width: 200px !important; }
    .payment-card-skeleton .react-loading-skeleton[style*="width: 200px"] {
      width: 160px !important; }
    .payment-card-skeleton .react-loading-skeleton[style*="width: 180px"] {
      width: 140px !important; } }

@media (max-width: 767.98px) {
  .payment-list-skeleton {
    padding: 0 8px; } }

@media (max-width: 767.98px) {
  .member-dashboard .dashboard-body {
    flex-direction: column !important; }
    .member-dashboard .dashboard-body > div:first-child {
      width: 100% !important;
      border-right: none !important;
      border-bottom: 1px solid #e1e5e9 !important;
      padding: 12px 16px !important; }
      .member-dashboard .dashboard-body > div:first-child > div:first-child {
        text-align: center;
        margin-bottom: 12px !important; }
      .member-dashboard .dashboard-body > div:first-child > div:last-child {
        display: flex !important;
        justify-content: space-around;
        margin-top: 16px !important; }
        .member-dashboard .dashboard-body > div:first-child > div:last-child > div {
          margin-bottom: 0 !important;
          flex-direction: column !important;
          align-items: center !important;
          text-align: center; }
    .member-dashboard .dashboard-body .main-content {
      padding: 16px !important; } }

@media (max-width: 575.98px) {
  .member-dashboard .dashboard-body .main-content {
    padding: 12px !important; } }

/* fallback */
@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  font-weight: 100 700;
  src: url(https://fonts.gstatic.com/s/materialsymbolsoutlined/v122/kJEhBvYX7BgnkSrUwT8OhrdQw4oELdPIeeII9v6oFsLjBuVY.woff2) format("woff2"); }

.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased; }

.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 48; }

/* End Page Layout */
/* Style your payment form */
/* End Style your payment form */
/* Validate form handle */
/* /// Hide All error text */
/* /// Show error text */
.k-payment-container .content {
  position: relative;
  height: 100%;
  width: auto;
  max-width: 960px;
  margin: 0 auto;
  padding-top: 35px;
  flex-grow: 1; }

.k-payment-container .payment-block {
  margin: 0 auto;
  padding: 25px 40px;
  width: 500px;
  background: #fdfdfd;
  border-radius: .375rem;
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15); }

.k-payment-container .label {
  display: block;
  font-weight: 400; }

.k-payment-container .flied {
  margin-bottom: 20px; }

.k-payment-container .footer {
  margin-bottom: 0;
  text-align: end;
  color: #9E9E9E; }

.k-payment-container h1 {
  margin: 0 0 15px 0; }

.k-payment-container #card-name {
  display: block;
  padding: 6px 12px;
  border-bottom: 1px solid #ced4da; }

.k-payment-container #card-number {
  display: block;
  padding: 6px 12px;
  border-bottom: 1px solid #ced4da; }

.k-payment-container #card-expiry {
  display: block;
  padding: 6px 12px;
  border-bottom: 1px solid #ced4da; }

.k-payment-container #card-cvv {
  display: block;
  padding: 6px 12px;
  border-bottom: 1px solid #ced4da; }

.k-payment-container .card-detail {
  display: flex;
  justify-content: space-between; }
  .k-payment-container .card-detail .flied {
    width: calc(100% * (1.5/4) - 10px - 1px); }

.k-payment-container .pay-button {
  margin-top: .25rem;
  margin-bottom: .25rem;
  display: block;
  width: 100%;
  padding: .5rem 1rem;
  font-size: 1.25rem;
  line-height: 1.5;
  border-radius: .3rem;
  background-color: #47876f;
  color: #fff;
  border: 1px solid transparent;
  cursor: pointer; }

.k-payment-container #error-summary {
  display: none;
  margin: 0 0 15px;
  color: #e91e63; }

.k-payment-container #error-summary.show {
  display: block; }

.k-payment-container div#card-name.is-invalid {
  border-bottom: 1px solid #e91e63 !important; }

.k-payment-container div#card-number.is-invalid {
  border-bottom: 1px solid #e91e63 !important; }

.k-payment-container div#card-expiry.is-invalid {
  border-bottom: 1px solid #e91e63 !important; }

.k-payment-container div#card-cvv.is-invalid {
  border-bottom: 1px solid #e91e63 !important; }

.k-payment-container #card-name + label {
  display: none;
  color: #e91e63; }

.k-payment-container #card-number + label {
  display: none;
  color: #e91e63; }

.k-payment-container #card-expiry + label {
  display: none;
  color: #e91e63; }

.k-payment-container #card-cvv + label {
  display: none;
  color: #e91e63; }

.k-payment-container #card-name.is-invalid + label {
  display: block; }

.k-payment-container #card-number.is-invalid + label {
  display: block; }

.k-payment-container #card-expiry.is-invalid + label {
  display: block; }

.k-payment-container #card-cvv.is-invalid + label {
  display: block; }

.register-form-header-insight {
  color: black;
  font-weight: 400;
  font-size: 24px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  border-radius: 8px 8px 0px 0px; }
  .register-form-header-insight.expand {
    padding-bottom: 20px; }
  .register-form-header-insight .payment-form-header-title {
    padding-left: 58px; }
  .register-form-header-insight .bill-form-header-title {
    padding-left: 58px;
    font-weight: bold;
    font-size: 18px; }
  .register-form-header-insight .person-form-header-title {
    display: flex;
    align-items: center; }
  .register-form-header-insight .person-form-header-icon {
    display: none;
    align-items: center;
    color: white; }
    @media (max-width: 767.98px) {
      .register-form-header-insight .person-form-header-icon {
        display: flex; } }
  .register-form-header-insight .person-form-order {
    width: 58px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 75px;
    border-radius: 20px;
    background-color: #b70909; }
    @media (max-width: 767.98px) {
      .register-form-header-insight .person-form-order {
        width: 38px; } }
  .register-form-header-insight .person-form-select-copy {
    border-radius: 10px;
    width: 100%;
    flex-basis: 0px;
    flex-grow: 1;
    height: 42px;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: 0em;
    text-align: left;
    overflow: hidden;
    text-overflow: ellipsis;
    border: none;
    text-align: center;
    color: black;
    border: 1px solid black; }
    .register-form-header-insight .person-form-select-copy:focus {
      outline: none; }
  .register-form-header-insight .person-form-type {
    width: 130px;
    flex-basis: 0px;
    flex-grow: 1;
    height: 42px;
    background: #000000;
    border: 1px solid #ffffff;
    border-radius: 13px;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    text-transform: capitalize;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: 0em;
    padding-left: 0.5rem;
    padding-right: 0.5rem; }
    @media (max-width: 767.98px) {
      .register-form-header-insight .person-form-type {
        width: 80px; } }
  .register-form-header-insight .step-form {
    font-size: 16px; }
  @media (max-width: 667.98px) {
    .register-form-header-insight {
      font-size: 12px; }
      .register-form-header-insight .step-form {
        font-size: 12px; }
      .register-form-header-insight.expand {
        padding-bottom: 5px; } }

.register-form-body-insight {
  padding-top: 20px; }
  .register-form-body-insight.onsite {
    border: none;
    box-shadow: 0 0.15rem 1.75rem 0 rgba(58, 59, 69, 0.15);
    padding-left: 1rem;
    padding-right: 1rem;
    border-radius: 20px !important; }
  .register-form-body-insight .payment-form-method {
    border-radius: 20px;
    box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
    min-height: 82px;
    cursor: pointer;
    display: flex;
    align-items: center; }
    .register-form-body-insight .payment-form-method .radio-button {
      width: 28px;
      height: 28px;
      min-width: 28px;
      border-radius: 50%;
      box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
      display: flex;
      justify-content: center;
      align-items: center; }
      .register-form-body-insight .payment-form-method .radio-button .selected-dot {
        border-radius: 50%;
        background-color: black;
        width: 100%;
        height: 100%; }
    .register-form-body-insight .payment-form-method .method-icon {
      height: 30px;
      object-fit: contain; }
    .register-form-body-insight .payment-form-method .method-name {
      font-weight: 400;
      font-size: 18px; }
  .register-form-body-insight .person-form-save-button {
    border-radius: 10px;
    background: #b70909;
    width: 100%;
    height: 38px;
    border: none; }
  .register-form-body-insight .default-input-label {
    font-weight: 400;
    font-size: 17px;
    line-height: 26px; }
  @media (max-width: 667.98px) {
    .register-form-body-insight {
      font-size: 12px !important; }
      .register-form-body-insight .default-input-label {
        font-size: 12px !important; }
      .register-form-body-insight .file-upload-button {
        color: white !important;
        background-color: black !important;
        border-radius: 8px !important;
        font-size: 12px; }
      .register-form-body-insight .file-upload-area {
        display: flex;
        height: 221px; }
      .register-form-body-insight .single-file-upload-preview {
        display: flex;
        width: 320px;
        height: 221px; } }

.box-form-register {
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
  padding: 40px 82px 40px 82px;
  border-radius: 8px;
  background-color: #ffffff; }
  @media (max-width: 667.98px) {
    .box-form-register {
      padding: 20px; } }

@media (max-width: 767.98px) {
  .free-register-button-container-insightx {
    display: block;
    flex-direction: column;
    justify-content: center;
    border-radius: 10px 10px 0px 0px;
    left: 0px;
    bottom: 0px;
    right: 0px;
    background: white;
    font-size: 10px;
    font-weight: 600;
    z-index: 99999;
    height: 50px !important; } }

.free-register-button-container-insightx .free-register-button-insightx {
  height: 56px !important;
  padding: 8px 32px 6px 32px;
  border-radius: 3px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  border: none;
  background: #000000;
  color: white;
  font-size: 18px;
  font-weight: 400;
  box-shadow: rgba(0, 0, 0, 0.93) 1.5px 1.5px 1.5px; }
  @media (max-width: 767.98px) {
    .free-register-button-container-insightx .free-register-button-insightx {
      border-radius: 0px;
      left: 0px;
      bottom: 0px;
      right: 0px;
      height: 50px;
      background: #000000;
      color: white;
      font-size: 16px;
      font-weight: 600;
      z-index: 99999;
      margin: 0px; } }

.free-register-button-container-insightx .btn-gradient {
  background-image: linear-gradient(107.08deg, #12d5af 0.42%, #01619e 99.76%), linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.2) 100%) !important;
  background-repeat: no-repeat !important;
  transition: 0.5s !important;
  border: none !important;
  cursor: pointer; }
  .free-register-button-container-insightx .btn-gradient:hover {
    background-position: right center !important;
    text-decoration: none !important; }
  .free-register-button-container-insightx .btn-gradient:disabled {
    cursor: not-allowed !important;
    background-image: none !important;
    background: #999 !important; }

.free-register-button-container-insightx .h-48 {
  height: 48px !important; }

.free-register-button-container-insightx .w-154 {
  width: 154px !important; }

.contain-html-complete-insightx {
  border-radius: 6px;
  background-color: white;
  box-shadow: rgba(0, 0, 0, 0.08) 0px 4px 12px; }

.ticket-cart-container-insightx {
  width: 100%;
  border-radius: 6px; }
  @media (max-width: 767.98px) {
    .ticket-cart-container-insightx {
      box-shadow: none; } }
  .ticket-cart-container-insightx.on-add {
    display: none; }
    @media (max-width: 767.98px) {
      .ticket-cart-container-insightx.on-add {
        display: block; } }
  .ticket-cart-container-insightx .promo-input {
    display: flex;
    align-items: flex-end; }
    .ticket-cart-container-insightx .promo-input .apply-code-button {
      background: #efeded;
      border-radius: 4px 4px 0px 0px;
      font-size: 14px;
      font-weight: 300;
      border: none; }
  .ticket-cart-container-insightx .ticket-cart-banner-container {
    width: 100%;
    height: 185px;
    overflow: hidden; }
    .ticket-cart-container-insightx .ticket-cart-banner-container .ticket-cart-banner {
      width: 100%;
      object-fit: cover; }
    @media (max-width: 767.98px) {
      .ticket-cart-container-insightx .ticket-cart-banner-container {
        display: none; } }
  .ticket-cart-container-insightx .ticket-cart-pay-button-container {
    position: relative; }
    .ticket-cart-container-insightx .ticket-cart-pay-button-container .ticket-cart-pay-button {
      border: none;
      width: 100%;
      height: 60px;
      background-color: #cc1f1f;
      font-weight: 500;
      font-size: 23px; }
      @media (max-width: 767.98px) {
        .ticket-cart-container-insightx .ticket-cart-pay-button-container .ticket-cart-pay-button {
          position: fixed;
          bottom: 0px;
          left: 0px;
          z-index: 199;
          border-radius: 20px 20px 0px 0px; } }
  .ticket-cart-container-insightx .ticket-cart-detail {
    border-radius: 6px; }
    .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-title {
      font-weight: 500;
      font-size: 22px; }
    .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-add-button {
      font-weight: 400;
      font-size: 10px;
      line-height: 15px;
      background-color: black;
      border: none;
      border-radius: 4px;
      color: white; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-add-button:hover {
        opacity: 0.8; }
    .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item {
      align-items: center;
      display: flex;
      justify-content: space-between; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .ticket-cart-item-name {
        width: 33%;
        text-align: left;
        font-weight: 500;
        font-size: 15px; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .ticket-cart-item-price {
        width: 33%;
        text-align: right;
        font-weight: 700;
        font-size: 15px; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .input-container {
        display: flex;
        justify-content: space-between; }
        .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .input-container .input-number {
          font-weight: 500;
          font-size: 15px;
          text-decoration: underline;
          margin-left: 10px;
          margin-right: 10px;
          min-width: 20px;
          text-align: center; }
        .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .input-container .input-button {
          color: white;
          background-color: rgba(0, 0, 0, 0.75);
          border: none;
          border-radius: 4px;
          width: 20px;
          height: 20px;
          display: flex;
          justify-content: center;
          align-items: center; }
          .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .input-container .input-button.disabled {
            background: #d9d9d9; }
          .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-item .input-container .input-button:disabled {
            background: #d9d9d9; }
    .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-promo-container {
      display: flex;
      justify-content: space-between;
      align-items: center; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-promo-container .promo-title {
        font-weight: bold;
        font-size: 15px; }
    .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-sum-container {
      display: flex;
      justify-content: space-between;
      align-items: center; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-sum-container .sum-title {
        font-weight: bold;
        font-size: 15px; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-sum-container .sum-price {
        font-weight: 500;
        font-size: 15px; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-sum-container #ticket-cart-req-bill {
        font-weight: 300;
        font-size: 15px; }
      .ticket-cart-container-insightx .ticket-cart-detail .ticket-cart-sum-container #ticket-cart-i-accept {
        font-weight: 300;
        font-size: 15px; }

.text-not-found {
  font-size: 46px;
  font-weight: 700;
  color: #4c5398;
  text-transform: uppercase; }

.text-sry {
  font-size: 26px;
  font-weight: 700;
  color: #4c5398;
  text-transform: uppercase; }

.btn-back {
  padding: 6px 32px 6px 32px;
  border-radius: 3px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  border: none;
  background: #000000;
  color: white;
  font-size: 14px;
  font-weight: 400;
  height: 37px;
  box-shadow: rgba(0, 0, 0, 0.93) 1.5px 1.5px 1.5px; }

.select-ticket-buy-button-insightx {
  width: 100%;
  color: white;
  border: none;
  bottom: -4px;
  left: 0px;
  font-weight: 600;
  font-size: 20px; }

.btn-back-uploadSlip {
  width: 237px;
  height: 56px;
  align-items: center; }

.card--form {
  padding: 24px 24px 0 24px;
  margin-bottom: 1rem;
  transition: all 0.4s; }
  .card--form:hover {
    border-radius: 10px;
    background: #f4f6ff !important; }

.card--form__one {
  border-radius: 10px;
  padding: 24px 24px 12px 24px;
  margin-bottom: 1rem; }

.footer-connex {
  z-index: 1080;
  position: absolute;
  bottom: 0px; }

.header-form {
  background-color: #ffffff;
  text-align: center;
  padding: 20px 30px;
  width: 100%;
  z-index: 1020;
  position: static;
  top: 0px; }
  .header-form .text-header {
    font-size: 24px;
    font-weight: 700; }
  .header-form .text-detail {
    font-size: 16px; }
  @media (max-width: 767px) {
    .header-form .text-detail {
      font-size: 14px; } }

.input-field-style:focus {
  border: 1px #018abe solid !important;
  box-shadow: none !important; }

.input-field-style {
  border: 1px #E6E8E9 solid !important; }

.radius-main {
  border-radius: 8px !important; }

.file-upload-area-portal {
  display: flex;
  min-width: 400px;
  height: 221px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  background-color: #e6e7f1;
  background-image: url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='6' ry='6' stroke='DarkSlateBlue' stroke-width='4' stroke-dasharray='4%2c 14' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e");
  border-radius: 6px;
  position: relative; }
  @media (max-width: 800px) {
    .file-upload-area-portal {
      min-width: 380px; } }
  @media (max-width: 1100px) {
    .file-upload-area-portal {
      min-width: 330px; } }
  @media (max-width: 600px) {
    .file-upload-area-portal {
      min-width: 230px; } }

.contain-upload-img {
  min-width: 150px;
  height: 150px;
  border-radius: 12px;
  background-color: #e6e8e9; }

.icon-upload-style {
  object-fit: contain;
  height: 48px;
  width: 48px; }

.image-profile-style {
  object-fit: contain;
  height: 100%;
  width: 100%;
  border-radius: 12px; }

.edit-icon-style {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  gap: 8px;
  background-color: #4d5e64b2;
  display: flex;
  justify-content: center;
  align-items: center; }
  .edit-icon-style svg {
    width: 20px;
    height: 40px; }
    .edit-icon-style svg path {
      stroke: #fdfeff !important; }

.button-create-badge {
  padding: 10px 24px 10px 24px;
  border-radius: 12px;
  gap: 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: 0em;
  text-align: left;
  color: #FFFFFF;
  background-color: #018ABE; }
  .button-create-badge:hover {
    background-color: #016E97;
    color: #FFFFFF !important; }
  .button-create-badge:active {
    background-color: #015170;
    color: #FFFFFF !important; }

.button-cancel-badge {
  padding: 10px 24px 10px 24px;
  gap: 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: 0em;
  text-align: left;
  background-color: transparent;
  text-decoration: underline;
  text-decoration-color: #016E97;
  color: #016E97; }
  .button-cancel-badge:hover {
    background-color: transparent;
    color: #01A6E5 !important;
    text-decoration: underline;
    text-decoration-color: #01A6E5 !important; }
  .button-cancel-badge:active {
    background-color: transparent;
    color: #015170 !important;
    text-decoration: underline;
    text-decoration-color: #015170 !important; }

.text-detail-dialog {
  font-size: 16px;
  font-weight: 400;
  line-height: 21px;
  letter-spacing: 0em;
  text-align: left;
  color: #6f6f6f; }

.text-main-dialog {
  font-size: 18px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: 0em;
  text-align: left;
  color: #001922; }

.title-badge-pre {
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: 0em;
  text-align: left; }

.border-required-portal {
  border: 1px red solid !important;
  border-radius: 5px !important; }

.svg-icon-fill {
  cursor: pointer; }
  .svg-icon-fill svg path {
    fill: #66757A !important; }
  .svg-icon-fill:hover svg path {
    fill: #016E97 !important; }
  .svg-icon-fill:active svg path {
    fill: #015170 !important; }
  .svg-icon-fill:focus svg path {
    fill: #015170 !important; }

.text-field-color {
  color: #6F6F6F !important; }

.border-badge-ex #inner-dropzone {
  border: 1px #e3e6f0 solid; }

.text-title-name {
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: 0em;
  text-align: left;
  color: #001922; }

.show-hide-position {
  position: absolute;
  right: 0px; }

.show-hide-preview {
  width: 24px;
  height: 48px;
  border-radius: 6px 0px 0px 6px;
  border: 1px 0px 1px 1px;
  border-width: 1px 0px 1px 1px;
  border-style: solid;
  border-color: #e6e8e9;
  cursor: pointer;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center; }

.text-subject-mail {
  font-size: 11px;
  font-weight: 400;
  line-height: 16px;
  letter-spacing: 0em;
  text-align: left; }

.show-subjext-mail {
  padding: 8px 16px 8px 16px;
  border-radius: 6px;
  border: 1px;
  gap: 8px;
  border: 1px solid #E6E8E9;
  background-color: #FDFEFF;
  font-size: 14px;
  font-weight: 400;
  line-height: 21px;
  letter-spacing: 0em;
  text-align: left;
  color: #001922; }

.zone-nav-bar {
  color: #C2C2C2;
  font-size: 14px;
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-bottom: 10px;
  margin-top: 24px; }
  .zone-nav-bar .title {
    margin-right: 16px; }

.zone-set-bg {
  background-color: #5f5f5f !important; }

.zone-content {
  border-radius: 10px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background-color: #FFFFFF33;
  padding: 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%; }
  .zone-content .datetimes-container {
    background-color: white;
    border-radius: 10px;
    padding: 24px;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
    flex-direction: row;
    align-items: center;
    height: 100%;
    justify-content: center;
    color: #9091A7;
    font-weight: bold; }
  .zone-content .zone-container {
    background-color: black;
    border-radius: 8px;
    padding: 16px;
    margin-top: 20px;
    width: 100%;
    min-height: 500px; }
    .zone-content .zone-container .title {
      font-size: 24px;
      font-weight: bold;
      color: white; }
    .zone-content .zone-container .description {
      font-size: 14px;
      color: white;
      margin-top: 16px; }
    .zone-content .zone-container .description-seat {
      display: flex;
      color: white;
      justify-content: space-evenly;
      font-weight: 700;
      margin-top: 16px; }
    .zone-content .zone-container .map-zone-seat {
      margin-top: 16px;
      padding-left: 30px;
      padding-right: 30px;
      position: relative; }
    .zone-content .zone-container .zone-detail-container {
      position: absolute;
      top: 0px;
      right: 20px; }
    .zone-content .zone-container .price-container {
      border-radius: 10px;
      background-color: white;
      padding: 30px;
      max-height: 50vh;
      overflow: auto; }
      .zone-content .zone-container .price-container .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content .zone-container .price-container .price-box .section-color {
          width: 56px;
          height: 24px;
          border-radius: 6px;
          margin-right: 12px;
          box-shadow: 0px 2px 4px 0px #00000040; }
        .zone-content .zone-container .price-container .price-box .price {
          font-size: 14px;
          font-weight: bold;
          width: '100%'; }
        .zone-content .zone-container .price-container .price-box .ticket-full {
          border-radius: 6px;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content .zone-container .price-container .price-box .ticket-sell {
          border-radius: 6px;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }
    .zone-content .zone-container .price-container-mobile {
      border-radius: 10px;
      background-color: white;
      display: flex;
      flex-direction: column;
      padding: 16px;
      margin-top: 20px;
      overflow: auto; }
      .zone-content .zone-container .price-container-mobile .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content .zone-container .price-container-mobile .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content .zone-container .price-container-mobile .price-box .price {
          font-size: 14px;
          font-weight: bold; }
        .zone-content .zone-container .price-container-mobile .price-box .ticket-full {
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          color: #CC1F1F;
          font-size: 12px;
          font-weight: bold; }
        .zone-content .zone-container .price-container-mobile .price-box .ticket-sell {
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          color: #1CBF0E;
          font-size: 12px;
          font-weight: bold; }

.backdrop-zone {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 10px;
  background-color: rgba(255, 255, 255, 0.2);
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0; }

.zone-content-form {
  padding: 20px;
  text-align: start;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  position: relative;
  border-radius: 10px; }
  .zone-content-form .datetimes-container {
    background-color: white;
    border-radius: 10px;
    padding: 24px;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
    flex-direction: row;
    align-items: center;
    height: 100%;
    justify-content: center;
    color: #9091A7;
    font-weight: bold; }
  .zone-content-form .zone-container {
    background-color: black;
    border-radius: 8px;
    padding: 16px;
    margin-top: 20px;
    width: 100%; }
    .zone-content-form .zone-container .title {
      font-size: 24px;
      font-weight: bold;
      color: white; }
    .zone-content-form .zone-container .description {
      font-size: 14px;
      color: white;
      margin-top: 16px; }
    .zone-content-form .zone-container .description-seat {
      display: flex;
      color: white;
      justify-content: space-evenly;
      font-weight: 700;
      margin-top: 16px; }
    .zone-content-form .zone-container .map-zone-seat {
      margin-top: 16px;
      padding-left: 30px;
      padding-right: 30px;
      position: relative; }
    .zone-content-form .zone-container .price-container {
      border-radius: 10px;
      background-color: white;
      padding: 30px;
      position: absolute;
      top: 0px;
      right: 30px; }
      .zone-content-form .zone-container .price-container .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content-form .zone-container .price-container .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content-form .zone-container .price-container .price-box .price {
          font-size: 16px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container .price-box .ticket-full {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #FFEAEA;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container .price-box .ticket-sell {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #EFFFED;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }
    .zone-content-form .zone-container .price-container-mobile {
      border-radius: 10px;
      background-color: white;
      display: flex;
      flex-direction: column;
      padding: 16px;
      margin-top: 20px; }
      .zone-content-form .zone-container .price-container-mobile .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content-form .zone-container .price-container-mobile .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content-form .zone-container .price-container-mobile .price-box .price {
          font-size: 16px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container-mobile .price-box .ticket-full {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #FFEAEA;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container-mobile .price-box .ticket-sell {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #EFFFED;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }

.step-container {
  background-color: black;
  border-radius: 8px;
  padding: 19px;
  padding-left: 10px;
  padding-right: 10px; }
  @media (max-width: 767.98px) {
    .step-container {
      padding: 10px;
      padding-top: 12px;
      padding-bottom: 12px;
      margin-bottom: 8px; } }
  .step-container .step-progress {
    font-size: 14px;
    color: #C2C2C2;
    text-align: center; }
  .step-container .step-title {
    font-size: 20px;
    color: white;
    font-weight: bold;
    text-align: center; }

.seat-section {
  overflow: hidden;
  padding-left: 30px;
  padding-right: 30px;
  margin-top: 16px !important; }

.booking-detail-container {
  border-radius: 16px;
  background-color: white;
  padding: 30px;
  top: 0px;
  right: 30px; }

.seat-column-label, .seat-row-label {
  color: white !important; }

.main-container-section {
  max-width: 1209px;
  margin-left: 8px;
  margin-right: 8px; }

.payment-zone-content {
  border-radius: 10px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background-color: white;
  padding: 30px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin-top: 16px; }
  .payment-zone-content .image-complete-container {
    width: 100%;
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    overflow: hidden; }
    .payment-zone-content .image-complete-container .img-bg {
      position: absolute;
      height: 100%;
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      filter: brightness(0.3);
      min-width: 100%; }
    .payment-zone-content .image-complete-container .img-complete-banner {
      width: 100%;
      z-index: 1; }
  .payment-zone-content .register-success-icon {
    font-size: 44px;
    color: #D1FFCD; }
  .payment-zone-content .register-success-title {
    color: #1CBF0E;
    font-size: 20px;
    font-weight: 700;
    margin-top: 8px;
    margin-bottom: 16px; }
  .payment-zone-content .register-complete-detail {
    background-color: #FBFBFB;
    border-radius: 8px;
    border: 1px solid #E2E2E2;
    margin-top: 44px;
    width: 100%; }
    .payment-zone-content .register-complete-detail .event-description-container {
      padding: 20px;
      padding-left: 100px;
      display: flex;
      flex-direction: column;
      text-align: left;
      font-size: 16px; }
    .payment-zone-content .register-complete-detail .reference-no {
      background-color: #CC1F1F;
      display: flex;
      justify-content: center;
      padding: 15.5px;
      color: white; }
  .payment-zone-content .bar-code {
    width: 100%; }

.zone {
  background-color: black !important; }

.text-eventname {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
  word-wrap: break-word; }

.ticket-old-price {
  position: relative;
  font-size: 12px;
  font-weight: 600;
  color: black;
  text-decoration: line-through;
  text-decoration-color: #FF0019; }

.ticket-more-price {
  background-color: #FF0019;
  color: #FFFFFF;
  font-size: 16px;
  font-weight: 300;
  padding: 8px 10px;
  border-radius: 10px; }

.text-zone-ellipsis {
  max-width: 150px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis; }

.text-tiecket-ellipsis {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  /* จำนวนบรรทัดที่ต้องการแสดง */
  -webkit-box-orient: vertical;
  overflow: hidden; }

.aspect-ratio-16-9 {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: hidden; }
  .aspect-ratio-16-9 img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; }

.aspect-ratio-3-4 {
  position: relative;
  width: 100%;
  padding-top: 133.33%;
  overflow: hidden; }
  .aspect-ratio-3-4 img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; }

.switch {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 25px; }

.switch input {
  opacity: 0;
  width: 0;
  height: 0; }

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: 0.4s;
  transition: 0.4s; }

.slider:before {
  position: absolute;
  content: "";
  height: 17px;
  width: 17px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: 0.4s;
  transition: 0.4s; }

input:checked + .slider {
  background-color: #2196f3; }

input:focus + .slider {
  box-shadow: 0 0 1px #2196f3; }

input:checked + .slider.checked--gray {
  background-color: gray; }

input:checked + .slider:before {
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px); }

/* Rounded sliders */
.slider.round {
  border-radius: 34px; }

.slider.round:before {
  border-radius: 50%; }

.zone-nav-bar {
  color: #C2C2C2;
  font-size: 14px;
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-bottom: 10px;
  margin-top: 24px; }
  .zone-nav-bar .title {
    margin-right: 16px; }

.zone-set-bg {
  background-color: #5f5f5f !important; }

.zone-content {
  border-radius: 10px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background-color: #FFFFFF33;
  padding: 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%; }
  .zone-content .datetimes-container {
    background-color: white;
    border-radius: 10px;
    padding: 24px;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
    flex-direction: row;
    align-items: center;
    height: 100%;
    justify-content: center;
    color: #9091A7;
    font-weight: bold; }
  .zone-content .zone-container {
    background-color: black;
    border-radius: 8px;
    padding: 16px;
    margin-top: 20px;
    width: 100%;
    min-height: 500px; }
    .zone-content .zone-container .title {
      font-size: 24px;
      font-weight: bold;
      color: white; }
    .zone-content .zone-container .description {
      font-size: 14px;
      color: white;
      margin-top: 16px; }
    .zone-content .zone-container .description-seat {
      display: flex;
      color: white;
      justify-content: space-evenly;
      font-weight: 700;
      margin-top: 16px; }
    .zone-content .zone-container .map-zone-seat {
      margin-top: 16px;
      padding-left: 30px;
      padding-right: 30px;
      position: relative; }
    .zone-content .zone-container .zone-detail-container {
      position: absolute;
      top: 0px;
      right: 20px; }
    .zone-content .zone-container .price-container {
      border-radius: 10px;
      background-color: white;
      padding: 30px;
      max-height: 50vh;
      overflow: auto; }
      .zone-content .zone-container .price-container .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content .zone-container .price-container .price-box .section-color {
          width: 56px;
          height: 24px;
          border-radius: 6px;
          margin-right: 12px;
          box-shadow: 0px 2px 4px 0px #00000040; }
        .zone-content .zone-container .price-container .price-box .price {
          font-size: 14px;
          font-weight: bold;
          width: '100%'; }
        .zone-content .zone-container .price-container .price-box .ticket-full {
          border-radius: 6px;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content .zone-container .price-container .price-box .ticket-sell {
          border-radius: 6px;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }
    .zone-content .zone-container .price-container-mobile {
      border-radius: 10px;
      background-color: white;
      display: flex;
      flex-direction: column;
      padding: 16px;
      margin-top: 20px;
      overflow: auto; }
      .zone-content .zone-container .price-container-mobile .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content .zone-container .price-container-mobile .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content .zone-container .price-container-mobile .price-box .price {
          font-size: 14px;
          font-weight: bold; }
        .zone-content .zone-container .price-container-mobile .price-box .ticket-full {
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          color: #CC1F1F;
          font-size: 12px;
          font-weight: bold; }
        .zone-content .zone-container .price-container-mobile .price-box .ticket-sell {
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          color: #1CBF0E;
          font-size: 12px;
          font-weight: bold; }

.backdrop-zone {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 10px;
  background-color: rgba(255, 255, 255, 0.2);
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0; }

.zone-content-form {
  padding: 20px;
  text-align: start;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  position: relative;
  border-radius: 10px; }
  .zone-content-form .datetimes-container {
    background-color: white;
    border-radius: 10px;
    padding: 24px;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
    flex-direction: row;
    align-items: center;
    height: 100%;
    justify-content: center;
    color: #9091A7;
    font-weight: bold; }
  .zone-content-form .zone-container {
    background-color: black;
    border-radius: 8px;
    padding: 16px;
    margin-top: 20px;
    width: 100%; }
    .zone-content-form .zone-container .title {
      font-size: 24px;
      font-weight: bold;
      color: white; }
    .zone-content-form .zone-container .description {
      font-size: 14px;
      color: white;
      margin-top: 16px; }
    .zone-content-form .zone-container .description-seat {
      display: flex;
      color: white;
      justify-content: space-evenly;
      font-weight: 700;
      margin-top: 16px; }
    .zone-content-form .zone-container .map-zone-seat {
      margin-top: 16px;
      padding-left: 30px;
      padding-right: 30px;
      position: relative; }
    .zone-content-form .zone-container .price-container {
      border-radius: 10px;
      background-color: white;
      padding: 30px;
      position: absolute;
      top: 0px;
      right: 30px; }
      .zone-content-form .zone-container .price-container .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content-form .zone-container .price-container .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content-form .zone-container .price-container .price-box .price {
          font-size: 16px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container .price-box .ticket-full {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #FFEAEA;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container .price-box .ticket-sell {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #EFFFED;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }
    .zone-content-form .zone-container .price-container-mobile {
      border-radius: 10px;
      background-color: white;
      display: flex;
      flex-direction: column;
      padding: 16px;
      margin-top: 20px; }
      .zone-content-form .zone-container .price-container-mobile .price-box {
        display: flex;
        flex-direction: row;
        margin-top: 20px; }
        .zone-content-form .zone-container .price-container-mobile .price-box .section-color {
          width: 52px;
          height: 52px;
          border-radius: 10px;
          margin-right: 10px; }
        .zone-content-form .zone-container .price-container-mobile .price-box .price {
          font-size: 16px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container-mobile .price-box .ticket-full {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #FFEAEA;
          color: #CC1F1F;
          font-size: 14px;
          font-weight: bold; }
        .zone-content-form .zone-container .price-container-mobile .price-box .ticket-sell {
          width: 100%;
          border-radius: 6px;
          padding-top: 4px;
          padding-bottom: 4px;
          background-color: #EFFFED;
          color: #1CBF0E;
          font-size: 14px;
          font-weight: bold; }

.step-container {
  background-color: black;
  border-radius: 8px;
  padding: 19px;
  padding-left: 10px;
  padding-right: 10px; }
  @media (max-width: 767.98px) {
    .step-container {
      padding: 10px;
      padding-top: 12px;
      padding-bottom: 12px;
      margin-bottom: 8px; } }
  .step-container .step-progress {
    font-size: 14px;
    color: #C2C2C2;
    text-align: center; }
  .step-container .step-title {
    font-size: 20px;
    color: white;
    font-weight: bold;
    text-align: center; }

.seat-section {
  overflow: hidden;
  padding-left: 30px;
  padding-right: 30px;
  margin-top: 16px !important; }

.booking-detail-container {
  border-radius: 16px;
  background-color: white;
  padding: 30px;
  top: 0px;
  right: 30px; }

.seat-column-label, .seat-row-label {
  color: white !important; }

.main-container-section {
  max-width: 1209px;
  margin-left: 8px;
  margin-right: 8px; }

.payment-zone-content {
  border-radius: 10px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background-color: white;
  padding: 30px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin-top: 16px; }
  .payment-zone-content .image-complete-container {
    width: 100%;
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    overflow: hidden; }
    .payment-zone-content .image-complete-container .img-bg {
      position: absolute;
      height: 100%;
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      filter: brightness(0.3);
      min-width: 100%; }
    .payment-zone-content .image-complete-container .img-complete-banner {
      width: 100%;
      z-index: 1; }
  .payment-zone-content .register-success-icon {
    font-size: 44px;
    color: #D1FFCD; }
  .payment-zone-content .register-success-title {
    color: #1CBF0E;
    font-size: 20px;
    font-weight: 700;
    margin-top: 8px;
    margin-bottom: 16px; }
  .payment-zone-content .register-complete-detail {
    background-color: #FBFBFB;
    border-radius: 8px;
    border: 1px solid #E2E2E2;
    margin-top: 44px;
    width: 100%; }
    .payment-zone-content .register-complete-detail .event-description-container {
      padding: 20px;
      padding-left: 100px;
      display: flex;
      flex-direction: column;
      text-align: left;
      font-size: 16px; }
    .payment-zone-content .register-complete-detail .reference-no {
      background-color: #CC1F1F;
      display: flex;
      justify-content: center;
      padding: 15.5px;
      color: white; }
  .payment-zone-content .bar-code {
    width: 100%; }

.zone {
  background-color: black !important; }

.text-eventname {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
  word-wrap: break-word; }

.ticket-old-price {
  position: relative;
  font-size: 12px;
  font-weight: 600;
  color: black;
  text-decoration: line-through;
  text-decoration-color: #FF0019; }

.ticket-more-price {
  background-color: #FF0019;
  color: #FFFFFF;
  font-size: 16px;
  font-weight: 300;
  padding: 8px 10px;
  border-radius: 10px; }

.text-zone-ellipsis {
  max-width: 150px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis; }

.text-tiecket-ellipsis {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  /* จำนวนบรรทัดที่ต้องการแสดง */
  -webkit-box-orient: vertical;
  overflow: hidden; }

.aspect-ratio-16-9 {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: hidden; }
  .aspect-ratio-16-9 img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; }

.aspect-ratio-3-4 {
  position: relative;
  width: 100%;
  padding-top: 133.33%;
  overflow: hidden; }
  .aspect-ratio-3-4 img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; }

.font-family-account-member {
  font-family: 'poppins', 'line-seed-sans-th' !important; }

.slip-image-section {
  display: flex;
  justify-content: center;
  align-items: center; }
  .slip-image-section img {
    max-width: 100%;
    max-height: 400px;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); }

.status-badge-pending {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  background-color: #fff3cd;
  border: 1px solid #ffe69c;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
  color: #664d03; }
  .status-badge-pending svg {
    flex-shrink: 0; }
  .status-badge-pending .countdown-timer {
    font-weight: 700; }
    .status-badge-pending .countdown-timer.expired {
      color: #dc3545; }

.slip-detail-section .head-detail {
  color: #66aeda;
  font-weight: 700;
  font-style: Bold;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0%; }

.slip-detail-section .label-data {
  font-weight: 400;
  line-height: 24px;
  letter-spacing: 0.5%;
  color: #1f2937; }

.slip-detail-section .ans-slip {
  color: #6c7280;
  background: #f7fbfd;
  padding: 10px 15px;
  border-radius: 8px;
  font-size: 14px; }

.navbar-member {
  background: linear-gradient(90deg, #1d1b52 50%, #66aeda 100%);
  padding: 0 5vw;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  position: sticky;
  top: 0;
  z-index: 1000; }
  .navbar-member.scrolled {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(10px); }
  .navbar-member .navbar-brand .logo {
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 700;
    color: white; }
    .navbar-member .navbar-brand .logo .logo-text {
      font-size: 18px;
      letter-spacing: 1px; }
    .navbar-member .navbar-brand .logo .logo-circle {
      background: white;
      color: #3c4674;
      border-radius: 50%;
      width: 32px;
      height: 32px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 12px;
      font-weight: 700; }
      .navbar-member .navbar-brand .logo .logo-circle .logo-pass {
        font-size: 10px;
        letter-spacing: 0.5px; }
  .navbar-member .mobile-menu-container {
    display: none; }
  .navbar-member .hamburger-btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 10px;
    z-index: 10;
    border-radius: 8px;
    transition: background-color 0.2s ease; }
    .navbar-member .hamburger-btn:hover {
      background: rgba(255, 255, 255, 0.1); }
    .navbar-member .hamburger-btn:active {
      background: rgba(255, 255, 255, 0.2); }
    .navbar-member .hamburger-btn .hamburger-line {
      width: 22px;
      height: 2px;
      background: white;
      border-radius: 2px;
      transition: all 0.3s ease;
      transform-origin: center;
      margin: 2px 0; }
      .navbar-member .hamburger-btn .hamburger-line:nth-child(1).active {
        transform: translateY(6px) rotate(45deg); }
      .navbar-member .hamburger-btn .hamburger-line:nth-child(2).active {
        opacity: 0; }
      .navbar-member .hamburger-btn .hamburger-line:nth-child(3).active {
        transform: translateY(-6px) rotate(-45deg); }
  .navbar-member .mobile-menu-overlay {
    display: none;
    position: fixed;
    top: 60px;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 999; }
    .navbar-member .mobile-menu-overlay .mobile-menu {
      background: white;
      width: 100%;
      max-height: calc(100vh - 60px);
      height: calc(100vh - 60px);
      overflow-y: auto;
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1); }
      .navbar-member .mobile-menu-overlay .mobile-menu .mobile-user-info {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 24px 20px;
        background: linear-gradient(90deg, #1d1b52 50%, #66aeda 100%);
        color: white; }
        .navbar-member .mobile-menu-overlay .mobile-menu .mobile-user-info .user-avatar {
          width: 40px;
          height: 40px;
          border-radius: 50%;
          background: white;
          color: #3c4674;
          display: flex;
          align-items: center;
          justify-content: center;
          font-weight: 600;
          font-size: 16px; }
        .navbar-member .mobile-menu-overlay .mobile-menu .mobile-user-info .user-name {
          font-weight: 500;
          font-size: 16px; }
      .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items {
        padding: 8px 0; }
        .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item {
          display: flex;
          align-items: center;
          gap: 16px;
          width: 100%;
          padding: 16px 20px;
          border: none;
          background: none;
          cursor: pointer;
          font-size: 16px;
          color: #374151;
          text-align: left;
          transition: background-color 0.2s ease;
          font-weight: 500;
          min-height: 56px; }
          .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item:hover {
            background: #f8fafc; }
          .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item.sign-out {
            color: #ef4444; }
            .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item.sign-out:hover {
              background: #fef2f2; }
            .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item.sign-out svg {
              color: #ef4444; }
          .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item svg {
            width: 20px;
            height: 20px;
            color: #6b7280;
            flex-shrink: 0; }
        .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-divider {
          height: 1px;
          background: #e5e7eb;
          margin: 8px 20px; }
  .navbar-member .navbar-user {
    position: relative; }
    .navbar-member .navbar-user .user-dropdown {
      display: flex;
      align-items: center;
      gap: 12px;
      cursor: pointer;
      padding: 8px 16px;
      border-radius: 8px;
      transition: all 0.2s ease; }
      .navbar-member .navbar-user .user-dropdown:hover {
        background: rgba(255, 255, 255, 0.1); }
      .navbar-member .navbar-user .user-dropdown .user-avatar {
        width: 32px;
        height: 32px;
        border-radius: 50%;
        background: white;
        color: #3c4674;
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 600;
        font-size: 14px; }
      .navbar-member .navbar-user .user-dropdown .user-name {
        color: white;
        font-weight: 500;
        font-size: 14px; }
      .navbar-member .navbar-user .user-dropdown .dropdown-arrow {
        color: white;
        transition: transform 0.2s ease; }
        .navbar-member .navbar-user .user-dropdown .dropdown-arrow.open {
          transform: rotate(180deg); }
    .navbar-member .navbar-user .dropdown-menu.dropdown-entering {
      opacity: 0;
      transform: translateY(-10px); }
    .navbar-member .navbar-user .dropdown-menu {
      position: absolute;
      top: 100%;
      right: 50%;
      transform: translateX(50%);
      margin-top: 8px;
      background: white;
      border-radius: 16px;
      box-shadow: 0 12px 48px rgba(0, 0, 0, 0.15);
      padding: 20px;
      min-width: 280px;
      width: 280px;
      z-index: 1001;
      border: 1px solid #e5e7eb;
      opacity: 1;
      transform: translateY(0);
      transition: all 0.2s ease; }
      @media (max-width: 480px) {
        .navbar-member .navbar-user .dropdown-menu {
          min-width: 260px;
          width: calc(100vw - 40px);
          max-width: 320px;
          padding: 16px;
          right: 50% !important;
          left: auto !important;
          transform: translateX(50%) !important; } }
      @media (max-width: 375px) {
        .navbar-member .navbar-user .dropdown-menu {
          min-width: 240px;
          width: calc(100vw - 32px);
          max-width: 300px;
          padding: 12px;
          right: 50% !important;
          left: auto !important;
          transform: translateX(50%) !important; } }
      .navbar-member .navbar-user .dropdown-menu.dropdown-align-right {
        right: 0 !important;
        transform: none !important;
        left: auto !important; }
      .navbar-member .navbar-user .dropdown-menu.dropdown-align-left {
        left: 0 !important;
        transform: none !important;
        right: auto !important; }
      .navbar-member .navbar-user .dropdown-menu .dropdown-item {
        display: flex;
        align-items: center;
        gap: 16px;
        width: 100%;
        padding: 16px 24px;
        border: none;
        background: none;
        cursor: pointer;
        font-size: 16px;
        color: #374151;
        text-align: left;
        transition: all 0.2s ease;
        font-weight: 500;
        min-height: 56px; }
        .navbar-member .navbar-user .dropdown-menu .dropdown-item:hover {
          background: #f8fafc; }
        .navbar-member .navbar-user .dropdown-menu .dropdown-item.home-active {
          background: #dbeafe;
          color: #1e40af;
          border-radius: 12px; }
          .navbar-member .navbar-user .dropdown-menu .dropdown-item.home-active svg {
            color: #1e40af; }
          .navbar-member .navbar-user .dropdown-menu .dropdown-item.home-active:hover {
            background: #bfdbfe; }
        .navbar-member .navbar-user .dropdown-menu .dropdown-item.sign-out {
          color: #ef4444;
          margin-top: 8px; }
          .navbar-member .navbar-user .dropdown-menu .dropdown-item.sign-out:hover {
            background: #fef2f2; }
          .navbar-member .navbar-user .dropdown-menu .dropdown-item.sign-out svg {
            color: #ef4444; }
        .navbar-member .navbar-user .dropdown-menu .dropdown-item svg {
          width: 20px;
          height: 20px;
          color: #6b7280;
          flex-shrink: 0; }
      .navbar-member .navbar-user .dropdown-menu .dropdown-divider {
        height: 1px;
        background: #e5e7eb;
        margin: 12px 24px; }
  @media (max-width: 1200px) {
    .navbar-member {
      padding: 0 5vw; } }
  @media (max-width: 992px) {
    .navbar-member {
      padding: 0 5vw; } }
  @media (max-width: 768px) {
    .navbar-member {
      padding: 0 20px;
      height: 56px; }
      .navbar-member.scrolled {
        height: 48px;
        padding: 0 15px; }
        .navbar-member.scrolled .navbar-brand .logo {
          gap: 2px; }
          .navbar-member.scrolled .navbar-brand .logo .logo-text {
            font-size: 14px; }
          .navbar-member.scrolled .navbar-brand .logo .logo-circle {
            width: 28px;
            height: 28px;
            font-size: 11px; }
        .navbar-member.scrolled .mobile-user-info .user-avatar-image {
          width: 28px;
          height: 28px; }
          .navbar-member.scrolled .mobile-user-info .user-avatar-image span {
            font-size: 11px; }
      .navbar-member .navbar-brand .logo {
        gap: 3px; }
        .navbar-member .navbar-brand .logo .logo-text {
          font-size: 16px; }
        .navbar-member .navbar-brand .logo .logo-circle {
          width: 28px;
          height: 28px;
          font-size: 10px; }
          .navbar-member .navbar-brand .logo .logo-circle .logo-pass {
            font-size: 8px; }
      .navbar-member .mobile-menu-container {
        display: block !important; }
      .navbar-member .navbar-user {
        display: none !important; }
      .navbar-member .mobile-menu-overlay {
        display: block;
        top: 56px; }
      .navbar-member .navbar-user .user-dropdown {
        gap: 8px;
        padding: 6px 12px; }
        .navbar-member .navbar-user .user-dropdown .user-avatar {
          width: 28px;
          height: 28px;
          font-size: 12px; }
        .navbar-member .navbar-user .user-dropdown .user-name {
          font-size: 13px; }
        .navbar-member .navbar-user .user-dropdown .dropdown-arrow {
          width: 10px;
          height: 10px; }
      .navbar-member .navbar-user .dropdown-menu {
        min-width: 180px;
        margin-top: 6px;
        border-radius: 10px;
        right: 50%;
        transform: translateX(50%);
        left: auto; }
        .navbar-member .navbar-user .dropdown-menu .dropdown-item {
          padding: 10px 14px;
          font-size: 13px;
          gap: 10px; }
          .navbar-member .navbar-user .dropdown-menu .dropdown-item svg {
            width: 14px;
            height: 14px; } }
  @media (max-width: 480px) {
    .navbar-member {
      padding: 0 16px;
      height: 52px; }
      .navbar-member .navbar-brand .logo .logo-text {
        font-size: 14px; }
      .navbar-member .navbar-brand .logo .logo-circle {
        width: 24px;
        height: 24px; }
        .navbar-member .navbar-brand .logo .logo-circle .logo-pass {
          font-size: 7px; }
      .navbar-member .mobile-menu-container .hamburger-btn {
        width: 40px;
        height: 40px;
        padding: 8px; }
        .navbar-member .mobile-menu-container .hamburger-btn .hamburger-line {
          width: 20px; }
      .navbar-member .navbar-user {
        display: none !important; }
      .navbar-member .mobile-menu-overlay {
        top: 52px; }
        .navbar-member .mobile-menu-overlay .mobile-menu {
          max-height: calc(100vh - 52px); }
          .navbar-member .mobile-menu-overlay .mobile-menu .mobile-user-info {
            padding: 20px 16px; }
            .navbar-member .mobile-menu-overlay .mobile-menu .mobile-user-info .user-avatar {
              width: 36px;
              height: 36px;
              font-size: 14px; }
            .navbar-member .mobile-menu-overlay .mobile-menu .mobile-user-info .user-name {
              font-size: 15px; }
          .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item {
            padding: 14px 16px;
            font-size: 15px;
            min-height: 52px; }
            .navbar-member .mobile-menu-overlay .mobile-menu .mobile-menu-items .mobile-menu-item svg {
              width: 18px;
              height: 18px; }
      .navbar-member .navbar-user .user-dropdown {
        gap: 6px;
        padding: 4px 8px; }
        .navbar-member .navbar-user .user-dropdown .user-avatar {
          width: 24px;
          height: 24px;
          font-size: 11px; }
        .navbar-member .navbar-user .user-dropdown .user-name {
          font-size: 12px;
          max-width: 100px;
          overflow: hidden;
          text-overflow: ellipsis;
          white-space: nowrap; }
        .navbar-member .navbar-user .user-dropdown .dropdown-arrow {
          width: 8px;
          height: 8px; }
      .navbar-member .navbar-user .dropdown-menu {
        min-width: 160px;
        right: 50%;
        transform: translateX(50%);
        left: auto;
        width: calc(100vw - 32px);
        max-width: 280px; }
        .navbar-member .navbar-user .dropdown-menu .dropdown-item {
          padding: 10px 16px;
          font-size: 13px;
          min-height: 44px;
          display: flex;
          align-items: center; }
          .navbar-member .navbar-user .dropdown-menu .dropdown-item svg {
            width: 16px;
            height: 16px; } }
  @media (max-width: 375px) {
    .navbar-member {
      padding: 0 12px; }
      .navbar-member .navbar-user .user-dropdown .user-name {
        max-width: 80px; }
      .navbar-member .navbar-user .dropdown-menu {
        right: 50%;
        transform: translateX(50%);
        width: calc(100vw - 24px); } }
  @media (min-width: 769px) {
    .navbar-member .mobile-menu-container {
      display: none !important; }
    .navbar-member .navbar-user {
      display: block !important; }
    .navbar-member .mobile-menu-overlay {
      display: none !important; } }

.member-dashboard {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background-image: url("https://s3virtualexpo.eventpass.co/images/1758037773726-bg-member.png");
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  background-repeat: no-repeat; }
  .member-dashboard .dashboard-body {
    display: flex;
    flex: 1;
    position: relative;
    padding-left: 5vw;
    padding-right: 5vw; }
    .member-dashboard .dashboard-body .sidebar-section {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 12px;
      margin-top: 24px;
      margin-right: 24px; }
    .member-dashboard .dashboard-body .member-sidebar {
      width: 320px;
      height: auto;
      background: white;
      display: flex;
      flex-direction: column;
      border: 1px solid #e0e0e0;
      border-radius: 12px;
      box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
      overflow: hidden; }
      .member-dashboard .dashboard-body .member-sidebar .sidebar-content {
        flex: 1;
        padding: 24px 16px 38px;
        display: flex;
        flex-direction: column; }
        .member-dashboard .dashboard-body .member-sidebar .sidebar-content .profile-avatar {
          margin-bottom: 24px; }
          .member-dashboard .dashboard-body .member-sidebar .sidebar-content .profile-avatar .avatar {
            width: 64px;
            height: 64px;
            border-radius: 50%;
            background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
            color: white;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            font-weight: 600;
            box-shadow: 0 2px 8px rgba(63, 81, 181, 0.25); }
        .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav {
          display: flex;
          flex-direction: column;
          gap: 2px; }
          .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px 16px;
            border: none;
            background: transparent;
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s ease;
            font-size: 14px;
            font-weight: 400;
            color: #1f2937;
            text-align: left;
            width: 100%; }
            .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item:hover {
              background: #f3f4f6;
              color: #1f2937; }
            .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item.active {
              background: #dbeafe;
              color: #1d1b52;
              font-weight: 700; }
              .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item.active .menu-icon svg {
                color: #1d1b52; }
            .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item .menu-icon {
              width: 18px;
              height: 18px;
              display: flex;
              align-items: center;
              justify-content: center; }
              .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item .menu-icon svg {
                width: 18px;
                height: 18px;
                color: inherit; }
            .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item .menu-label {
              flex: 1;
              font-weight: inherit; }
      .member-dashboard .dashboard-body .member-sidebar .sidebar-footer {
        padding: 16px;
        border-top: 1px solid #f3f4f6;
        margin-top: auto; }
        .member-dashboard .dashboard-body .member-sidebar .sidebar-footer .sign-out-btn {
          width: 100%;
          padding: 10px 16px;
          border: 1px solid #d1d5db;
          background: white;
          border-radius: 8px;
          cursor: pointer;
          font-weight: 500;
          color: #6b7280;
          font-size: 14px;
          transition: all 0.2s ease; }
          .member-dashboard .dashboard-body .member-sidebar .sidebar-footer .sign-out-btn:hover {
            border-color: #9ca3af;
            background: #f9fafb;
            color: #374151; }
    .member-dashboard .dashboard-body .member-signout-container {
      width: 320px; }
      .member-dashboard .dashboard-body .member-signout-container .member-signout-btn {
        width: 100%;
        padding: 14px 16px;
        border: 2px solid transparent;
        background: linear-gradient(white, white) padding-box, linear-gradient(90deg, #1d1b52 0%, #66aeda 100%) border-box;
        border-radius: 8px;
        cursor: pointer;
        font-weight: 500;
        color: #374151;
        font-size: 14px;
        transition: all 0.2s ease;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        box-shadow: none;
        font-weight: 700;
        font-size: 18px; }
        .member-dashboard .dashboard-body .member-signout-container .member-signout-btn:hover {
          background: linear-gradient(#f9fafb, #f9fafb) padding-box, linear-gradient(90deg, #1d1b52 0%, #66aeda 100%) border-box;
          color: #1f2937; }
        .member-dashboard .dashboard-body .member-signout-container .member-signout-btn .sign-out-icon {
          width: 16px;
          height: 16px;
          color: #6b7280; }
    .member-dashboard .dashboard-body .member-auth-prompt {
      width: 320px;
      padding: 16px;
      background: white;
      border: 1px solid #e0e0e0;
      border-radius: 12px;
      text-align: center;
      box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); }
      .member-dashboard .dashboard-body .member-auth-prompt p {
        margin-bottom: 12px;
        font-size: 14px;
        color: #6b7280; }
      .member-dashboard .dashboard-body .member-auth-prompt .sign-in-btn {
        width: 100%;
        padding: 10px 16px;
        background: #4f46e5;
        color: white;
        border: none;
        border-radius: 8px;
        font-weight: 500;
        cursor: pointer;
        transition: all 0.2s ease; }
        .member-dashboard .dashboard-body .member-auth-prompt .sign-in-btn:hover {
          background: #4338ca; }
    .member-dashboard .dashboard-body .main-content {
      flex: 1;
      padding: 24px 0px 24px 0;
      overflow-y: auto;
      background: transparent; }
      .member-dashboard .dashboard-body .main-content .profile-content,
      .member-dashboard .dashboard-body .main-content .tickets-content,
      .member-dashboard .dashboard-body .main-content .payment-content {
        background: white;
        border-radius: 12px;
        padding: 24px;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
        border: 1px solid #e0e0e0;
        min-height: 60vh; }

.profile-content {
  background: white;
  border-radius: 16px;
  padding: 32px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); }
  .profile-content .profile-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 16px; }
    .profile-content .profile-header h1 {
      font-size: 28px;
      font-weight: 700;
      color: #1f2937;
      margin: 0;
      width: fit-content; }
  .profile-content .profile-description {
    margin-bottom: 32px;
    color: #6b7280;
    line-height: 1.6;
    font-size: 15px; }
  .profile-content .profile-details,
  .profile-content .login-info {
    margin-bottom: 32px; }
    .profile-content .profile-details .profile-field,
    .profile-content .login-info .profile-field {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 16px 0; }
      .profile-content .profile-details .profile-field:last-child,
      .profile-content .login-info .profile-field:last-child {
        border-bottom: none; }
      .profile-content .profile-details .profile-field .field-icon,
      .profile-content .login-info .profile-field .field-icon {
        font-size: 18px;
        width: 24px;
        color: #6b7280; }
      .profile-content .profile-details .profile-field .field-value,
      .profile-content .login-info .profile-field .field-value {
        font-size: 15px;
        color: #1f2937;
        font-weight: 500; }
  .profile-content .login-info h3 {
    font-size: 16px;
    color: #616161;
    margin-bottom: 16px;
    font-weight: 400; }

.tickets-content {
  background: white;
  border-radius: 16px;
  padding: 32px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); }
  .tickets-content .tickets-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    flex-wrap: wrap; }
    .tickets-content .tickets-header h1 {
      font-size: 28px;
      font-weight: 700;
      color: #1f2937;
      margin: 0;
      flex-shrink: 0; }
  .tickets-content .sort-dropdown select {
    padding: 8px 12px;
    border: none !important;
    border-radius: 6px;
    background: white;
    cursor: pointer;
    font-size: 14px;
    color: #374151; }
    .tickets-content .sort-dropdown select:focus {
      outline: none !important;
      border: none !important;
      box-shadow: none !important; }
  .tickets-content .tickets-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 24px; }
    .tickets-content .tickets-tabs .tab-btn {
      padding: 12px 16px;
      border: none;
      background: transparent;
      cursor: pointer;
      font-weight: 500;
      color: #6b7280;
      border-bottom: 2px solid transparent;
      transition: all 0.2s ease;
      font-size: 14px; }
      .tickets-content .tickets-tabs .tab-btn:hover {
        color: #3b82f6; }
      .tickets-content .tickets-tabs .tab-btn.active {
        color: #3b82f6;
        border-bottom-color: #3b82f6;
        font-weight: 600; }
  .tickets-content .tickets-header {
    margin-bottom: 24px; }
    .tickets-content .tickets-header h1 {
      font-size: 28px;
      font-weight: 700;
      color: #1f2937;
      margin: 0 0 20px 0; }
    .tickets-content .tickets-header .tabs-container {
      display: flex;
      gap: 0;
      border-bottom: 1px solid #e5e7eb;
      margin-bottom: 16px; }
      .tickets-content .tickets-header .tabs-container .tab {
        padding: 12px 24px;
        border: none;
        background: transparent;
        cursor: pointer;
        font-weight: 500;
        color: #6b7280;
        border-bottom: 2px solid transparent;
        transition: all 0.2s ease; }
        .tickets-content .tickets-header .tabs-container .tab.active {
          color: #3b82f6;
          border-bottom-color: #3b82f6; }
        .tickets-content .tickets-header .tabs-container .tab:hover:not(.active) {
          color: #374151; }
    .tickets-content .tickets-header .sort-container {
      display: flex;
      align-items: center;
      gap: 12px; }
      .tickets-content .tickets-header .sort-container select {
        padding: 8px 12px;
        border: 1px solid #d1d5db;
        border-radius: 6px;
        background: white;
        cursor: pointer;
        font-size: 14px;
        color: #374151; }
        .tickets-content .tickets-header .sort-container select:focus {
          outline: none;
          border-color: #3b82f6;
          box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1); }
  .tickets-content .tickets-list {
    display: flex;
    padding: 10px; }
    .tickets-content .tickets-list.row {
      display: flex;
      flex-wrap: wrap;
      margin: -8px; }
      .tickets-content .tickets-list.row .ticket-card {
        margin: 8px;
        flex: 0 0 calc(50% - 16px);
        box-shadow: 0px 1px 12px 0px #00000026; }
        @media (max-width: 768px) {
          .tickets-content .tickets-list.row .ticket-card {
            flex: 0 0 calc(100% - 16px);
            margin: 0 0 16px 0; } }
  .tickets-content .ticket-card {
    display: flex;
    gap: 16px;
    padding: 16px;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    transition: all 0.2s ease;
    background: white; }
    .tickets-content .ticket-card:hover {
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
      border-color: #3b82f6; }
    .tickets-content .ticket-card .event-image {
      width: 140px;
      height: 140px;
      border-radius: 16px;
      flex-shrink: 0;
      background: linear-gradient(135deg, #1d1b52 0%, #66aeda 100%); }
      @media (max-width: 768px) {
        .tickets-content .ticket-card .event-image {
          height: 80px;
          width: 80px; } }
      @media (max-width: 480px) {
        .tickets-content .ticket-card .event-image {
          height: 70px;
          width: 70px; } }
      .tickets-content .ticket-card .event-image .img-banner-event {
        height: 140px;
        width: 140px;
        object-fit: cover;
        filter: blur(8px);
        -webkit-filter: blur(8px); }
        @media (max-width: 768px) {
          .tickets-content .ticket-card .event-image .img-banner-event {
            height: 80px;
            width: 80px; } }
        @media (max-width: 480px) {
          .tickets-content .ticket-card .event-image .img-banner-event {
            height: 70px;
            width: 70px; } }
      .tickets-content .ticket-card .event-image .img-banner-event-inner {
        height: 140px;
        width: 140px;
        object-fit: contain;
        position: absolute;
        left: 0px;
        top: 0px; }
        @media (max-width: 768px) {
          .tickets-content .ticket-card .event-image .img-banner-event-inner {
            height: 80px;
            width: 80px; } }
        @media (max-width: 480px) {
          .tickets-content .ticket-card .event-image .img-banner-event-inner {
            height: 70px;
            width: 70px; } }
      .tickets-content .ticket-card .event-image .container-banner-event {
        position: relative;
        height: 140px;
        overflow: hidden;
        border-radius: 12px; }
        @media (max-width: 768px) {
          .tickets-content .ticket-card .event-image .container-banner-event {
            height: 80px;
            width: 80px;
            border-radius: 10px; } }
        @media (max-width: 480px) {
          .tickets-content .ticket-card .event-image .container-banner-event {
            height: 70px;
            width: 70px;
            border-radius: 8px; } }
      .tickets-content .ticket-card .event-image .no-image-placeholder {
        width: 140px;
        height: 140px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        color: #9ca3af;
        font-size: 12px;
        font-weight: 500;
        position: relative;
        z-index: 1;
        border-radius: 12px;
        gap: 8px;
        background: #f3f4f6;
        margin: auto auto; }
        .tickets-content .ticket-card .event-image .no-image-placeholder::before {
          font-size: 24px;
          opacity: 0.7; }
        @media (max-width: 768px) {
          .tickets-content .ticket-card .event-image .no-image-placeholder {
            height: 80px;
            width: 80px;
            border-radius: 10px; } }
        @media (max-width: 480px) {
          .tickets-content .ticket-card .event-image .no-image-placeholder {
            height: 70px;
            width: 70px;
            border-radius: 8px; } }
    .tickets-content .ticket-card .event-details {
      flex: 1;
      display: flex;
      flex-direction: column; }
      .tickets-content .ticket-card .event-details .event-title {
        font-size: 16px;
        font-weight: 600;
        color: #1f2937;
        margin: 0 0 8px 0; }
      .tickets-content .ticket-card .event-details .event-info {
        display: flex;
        flex-direction: column;
        gap: 4px; }
        .tickets-content .ticket-card .event-details .event-info .event-datetime {
          display: flex;
          flex-direction: column;
          gap: 2px; }
          .tickets-content .ticket-card .event-details .event-info .event-datetime .event-date,
          .tickets-content .ticket-card .event-details .event-info .event-datetime .event-time {
            font-size: 14px;
            color: #6b7280;
            display: flex;
            align-items: center;
            gap: 6px; }
        .tickets-content .ticket-card .event-details .event-info .event-location span {
          font-size: 14px;
          color: #6b7280;
          display: flex;
          align-items: center;
          gap: 6px; }
  .tickets-content .empty-state {
    text-align: center;
    padding: 60px 20px;
    color: #6b7280; }
  .tickets-content .transaction-group {
    margin-bottom: 16px;
    border-radius: 12px;
    padding: 16px;
    background: #ffffff; }
  .tickets-content .order-header {
    background: #ffffff;
    border-radius: 8px;
    font-size: 14px;
    color: #374151;
    margin-bottom: 16px;
    font-weight: 300; }
  .tickets-content .event-ticket-card {
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    background: white;
    padding: 16px;
    margin-bottom: 16px;
    box-shadow: 0px 1px 12px 0px #00000026;
    transition: all 0.2s ease; }
    .tickets-content .event-ticket-card:hover {
      box-shadow: 0px 1px 12px 0px #00000026;
      border-color: #3b82f6; }
    .tickets-content .event-ticket-card:last-child {
      margin-bottom: 0; }
    .tickets-content .event-ticket-card .event-image {
      width: 140px;
      height: 140px;
      border-radius: 8px;
      overflow: hidden;
      flex-shrink: 0; }
      .tickets-content .event-ticket-card .event-image img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
      .tickets-content .event-ticket-card .event-image .no-image-placeholder {
        width: 140px;
        height: 140px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: #f3f4f6;
        color: #9ca3af;
        font-size: 12px;
        font-weight: 500;
        border: 1px dashed #d1d5db;
        border-radius: 6px; }
        @media (max-width: 768px) {
          .tickets-content .event-ticket-card .event-image .no-image-placeholder {
            height: 80px;
            width: 80px;
            border-radius: 10px; } }
        @media (max-width: 480px) {
          .tickets-content .event-ticket-card .event-image .no-image-placeholder {
            height: 70px;
            width: 70px;
            border-radius: 8px; } }
    .tickets-content .event-ticket-card .event-details {
      flex: 1;
      display: flex;
      flex-direction: column; }
      .tickets-content .event-ticket-card .event-details .event-title {
        font-size: 16px;
        font-weight: 600;
        color: #1f2937;
        margin: 0 0 8px 0; }
      .tickets-content .event-ticket-card .event-details .event-info {
        display: flex;
        flex-direction: column;
        gap: 4px; }
        .tickets-content .event-ticket-card .event-details .event-info .event-datetime {
          display: flex;
          flex-direction: column;
          gap: 2px; }
          .tickets-content .event-ticket-card .event-details .event-info .event-datetime .event-date,
          .tickets-content .event-ticket-card .event-details .event-info .event-datetime .event-time {
            font-size: 14px;
            color: #6b7280;
            display: flex;
            align-items: center;
            gap: 6px; }
        .tickets-content .event-ticket-card .event-details .event-info .event-location span {
          font-size: 14px;
          color: #6b7280;
          display: flex;
          align-items: center;
          gap: 6px; }
    @media (max-width: 768px) {
      .tickets-content .event-ticket-card .event-image {
        width: 80px;
        height: 80px; }
        .tickets-content .event-ticket-card .event-image .no-image-placeholder {
          width: 80px;
          height: 80px;
          font-size: 9px; } }
    @media (max-width: 480px) {
      .tickets-content .event-ticket-card {
        padding: 12px;
        gap: 12px; }
        .tickets-content .event-ticket-card .event-image {
          width: 70px;
          height: 70px; }
          .tickets-content .event-ticket-card .event-image .no-image-placeholder {
            width: 70px;
            height: 70px;
            font-size: 8px; }
        .tickets-content .event-ticket-card .event-details .event-title {
          font-size: 14px;
          margin-bottom: 6px; }
        .tickets-content .event-ticket-card .event-details .event-info {
          gap: 3px; }
          .tickets-content .event-ticket-card .event-details .event-info .event-datetime .event-date,
          .tickets-content .event-ticket-card .event-details .event-info .event-datetime .event-time {
            font-size: 12px;
            gap: 4px; }
          .tickets-content .event-ticket-card .event-details .event-info .event-location span {
            font-size: 12px;
            gap: 4px; } }
  @media (max-width: 768px) {
    .tickets-content {
      padding: 16px;
      border-radius: 8px; }
      .tickets-content .tickets-list.row {
        display: block;
        margin: 0; }
        .tickets-content .tickets-list.row .ticket-card {
          display: flex;
          flex-direction: row;
          margin: 0 0 16px 0;
          width: 100%; }
      .tickets-content .tickets-header {
        margin-bottom: 16px; }
        .tickets-content .tickets-header h1 {
          font-size: 20px;
          margin-bottom: 12px; }
        .tickets-content .tickets-header .sort-dropdown select {
          font-size: 14px;
          padding: 6px 10px;
          border: none; }
      .tickets-content .tickets-tabs {
        margin-bottom: 16px; }
        .tickets-content .tickets-tabs .tab-btn {
          padding: 10px 16px;
          font-size: 14px; }
      .tickets-content .ticket-card {
        display: flex;
        flex-direction: row;
        padding: 16px;
        gap: 16px;
        margin-bottom: 16px; }
        .tickets-content .ticket-card .event-image {
          width: 80px;
          height: 80px;
          flex-shrink: 0; }
          .tickets-content .ticket-card .event-image .no-image-placeholder {
            font-size: 9px; }
        .tickets-content .ticket-card .event-details {
          flex: 1;
          display: flex;
          flex-direction: column; }
          .tickets-content .ticket-card .event-details .event-title {
            font-size: 16px;
            font-weight: 600;
            margin-bottom: 8px;
            line-height: 1.3; }
          .tickets-content .ticket-card .event-details .event-info {
            gap: 4px; }
            .tickets-content .ticket-card .event-details .event-info .event-datetime .event-date,
            .tickets-content .ticket-card .event-details .event-info .event-datetime .event-time {
              font-size: 14px;
              gap: 6px; }
            .tickets-content .ticket-card .event-details .event-info .event-location span {
              font-size: 14px;
              gap: 6px; }
      .tickets-content .empty-state {
        padding: 40px 16px; }
        .tickets-content .empty-state p {
          font-size: 14px; }
          .tickets-content .empty-state p.font-weight-bold {
            font-size: 16px; } }
  @media (max-width: 480px) {
    .tickets-content {
      padding: 12px; }
      .tickets-content .tickets-header {
        gap: 12px; }
        .tickets-content .tickets-header h1 {
          font-size: 20px;
          margin-bottom: 8px; }
        .tickets-content .tickets-header .sort-dropdown {
          align-self: flex-end; }
          .tickets-content .tickets-header .sort-dropdown select {
            font-size: 13px;
            padding: 6px 8px; }
      .tickets-content .tickets-tabs .tab-btn {
        flex: 1;
        padding: 8px 12px;
        font-size: 13px; }
      .tickets-content .ticket-card {
        display: flex;
        flex-direction: row;
        padding: 12px;
        gap: 12px;
        margin-bottom: 12px; }
        .tickets-content .ticket-card .event-image {
          width: 70px;
          height: 70px;
          flex-shrink: 0; }
          .tickets-content .ticket-card .event-image .no-image-placeholder {
            font-size: 8px; }
        .tickets-content .ticket-card .event-details {
          flex: 1;
          display: flex;
          flex-direction: column; }
          .tickets-content .ticket-card .event-details .event-title {
            font-size: 14px;
            font-weight: 600;
            margin-bottom: 6px;
            line-height: 1.3; }
          .tickets-content .ticket-card .event-details .event-info {
            gap: 3px; }
            .tickets-content .ticket-card .event-details .event-info .event-datetime .event-date,
            .tickets-content .ticket-card .event-details .event-info .event-datetime .event-time {
              font-size: 12px;
              gap: 4px; }
            .tickets-content .ticket-card .event-details .event-info .event-location span {
              font-size: 12px;
              gap: 4px; } }

.payment-content {
  background: white;
  border-radius: 16px;
  padding: 32px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); }
  .payment-content .payment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px; }
    .payment-content .payment-header h1 {
      font-size: 28px;
      font-weight: 700;
      color: #1f2937;
      margin: 0; }
    .payment-content .payment-header .sort-dropdown select {
      padding: 8px 12px;
      border: none;
      border-radius: 6px;
      background: white;
      cursor: pointer;
      font-size: 14px;
      color: #374151; }
  .payment-content .payment-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
    border-bottom: 1px solid #f3f4f6; }
    .payment-content .payment-tabs .tab-btn {
      padding: 12px 16px;
      border: none;
      background: transparent;
      cursor: pointer;
      font-weight: 500;
      color: #6b7280;
      border-bottom: 2px solid transparent;
      transition: all 0.2s ease;
      font-size: 14px; }
      .payment-content .payment-tabs .tab-btn:hover {
        color: #3b82f6; }
      .payment-content .payment-tabs .tab-btn.active {
        color: #3b82f6;
        border-bottom-color: #3b82f6;
        font-weight: 600; }
  .payment-content .payment-list .empty-state {
    text-align: center;
    padding: 80px 20px; }
    .payment-content .payment-list .empty-state .empty-icon {
      font-size: 64px;
      margin-bottom: 20px; }
    .payment-content .payment-list .empty-state h3 {
      font-size: 20px;
      font-weight: 600;
      color: #1f2937;
      margin-bottom: 12px; }
    .payment-content .payment-list .empty-state p {
      color: #6b7280;
      font-size: 15px; }

@media (max-width: 768px) {
  .member-dashboard .dashboard-body {
    padding-left: 5px;
    padding-right: 5px;
    flex-direction: column; }
    .member-dashboard .dashboard-body .sidebar-section {
      margin: 16px;
      gap: 12px; }
    .member-dashboard .dashboard-body .member-sidebar {
      width: 100%;
      height: auto;
      border: 1px solid #e0e0e0;
      background: white; }
      .member-dashboard .dashboard-body .member-sidebar .sidebar-content {
        padding: 20px 16px; }
        .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav {
          flex-direction: row;
          overflow-x: auto;
          gap: 8px; }
          .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item {
            min-width: 100px;
            text-align: center;
            flex-direction: column;
            gap: 6px;
            padding: 10px 12px; }
            .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item.active {
              font-weight: 700;
              background: #dbeafe;
              color: #1d1b52 !important; }
            .member-dashboard .dashboard-body .member-sidebar .sidebar-content .menu-nav .menu-item .menu-label {
              font-size: 12px; }
      .member-dashboard .dashboard-body .member-sidebar .sidebar-footer .sign-out-btn {
        border: 1px solid #d1d5db; }
        .member-dashboard .dashboard-body .member-sidebar .sidebar-footer .sign-out-btn:hover {
          border-color: #9ca3af;
          background: #f9fafb;
          color: #374151; }
    .member-dashboard .dashboard-body .member-signout-container {
      width: 100%; }
      .member-dashboard .dashboard-body .member-signout-container .member-signout-btn {
        padding: 12px 16px;
        font-size: 14px; }
    .member-dashboard .dashboard-body .member-auth-prompt {
      width: 100%; }
    .member-dashboard .dashboard-body .main-content {
      padding: 0px;
      padding-top: 16px; }
      .member-dashboard .dashboard-body .main-content .profile-content,
      .member-dashboard .dashboard-body .main-content .tickets-content,
      .member-dashboard .dashboard-body .main-content .payment-content {
        margin-right: 0; }
    .member-dashboard .dashboard-body .main-content {
      padding: 0px;
      padding-top: 16px; }
  .profile-content,
  .tickets-content,
  .payment-content {
    padding: 20px; }
    .profile-content .profile-header,
    .tickets-content .profile-header,
    .payment-content .profile-header {
      flex-direction: column;
      gap: 16px; }
      .profile-content .profile-header h1,
      .tickets-content .profile-header h1,
      .payment-content .profile-header h1 {
        font-size: 24px; }
  .ticket-card {
    flex-direction: column; }
    .ticket-card .ticket-image {
      width: 100%;
      height: 120px; } }

.profile-avatar {
  margin-bottom: 32px; }
  .profile-avatar .avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    font-weight: 600;
    box-shadow: 0 4px 20px rgba(63, 81, 181, 0.3); }

.menu-nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px; }
  .menu-nav .menu-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 20px;
    border: none;
    background: transparent;
    border-radius: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 16px;
    font-weight: 400;
    color: #666;
    text-align: left;
    width: 100%; }
    .menu-nav .menu-item:hover {
      background: rgba(63, 81, 181, 0.1);
      color: #3f51b5; }
    .menu-nav .menu-item.active {
      background: rgba(63, 81, 181, 0.15);
      color: #1d1b52;
      font-weight: 700; }
    .menu-nav .menu-item .menu-icon {
      font-size: 20px;
      width: 24px;
      text-align: center; }
    .menu-nav .menu-item .menu-label {
      flex: 1; }

.sign-out-btn {
  padding: 14px 24px;
  border: 2px solid #e0e0e0;
  background: white;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 500;
  color: #666;
  transition: all 0.3s ease; }

.profile-content {
  background: white;
  border-radius: 24px;
  padding: 32px;
  padding-right: 0px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1); }
  .profile-content .profile-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 16px; }
    .profile-content .profile-header h1 {
      font-size: 32px;
      font-weight: 700;
      color: #2c3e50;
      margin: 0; }
  .profile-content .profile-description {
    margin-bottom: 32px;
    color: #666;
    line-height: 1.6; }
  .profile-content .profile-details,
  .profile-content .login-info {
    margin-bottom: 32px; }
    .profile-content .profile-details .profile-field,
    .profile-content .login-info .profile-field {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 16px 0; }
      .profile-content .profile-details .profile-field:last-child,
      .profile-content .login-info .profile-field:last-child {
        border-bottom: none; }
      .profile-content .profile-details .profile-field .field-icon,
      .profile-content .login-info .profile-field .field-icon {
        font-size: 20px;
        width: 24px;
        color: #666; }
      .profile-content .profile-details .profile-field .field-value,
      .profile-content .login-info .profile-field .field-value {
        font-size: 16px;
        color: #2c3e50;
        font-weight: 500; }
  .profile-content .login-info {
    border-top: 1px solid #ebebeb;
    padding-top: 20px; }
    .profile-content .login-info h3 {
      font-size: 16px;
      color: #616161;
      margin-bottom: 16px;
      font-weight: 400; }

.edit-profile-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border: none;
  background: transparent;
  color: #1f2937;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  min-width: 152px;
  border-radius: 12px;
  border: 1px solid #e0e0e0; }

.tickets-content {
  background: white;
  border-radius: 24px;
  padding: 32px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1); }
  .tickets-content .tickets-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px; }
    .tickets-content .tickets-header h1 {
      font-weight: 700;
      color: #2c3e50;
      margin: 0; }
    .tickets-content .tickets-header .sort-dropdown select {
      padding: 8px 16px;
      border: none;
      border-radius: 8px;
      background: white;
      cursor: pointer; }
  .tickets-content .tickets-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 24px; }
    .tickets-content .tickets-tabs .tab-btn {
      padding: 12px 20px;
      border: none;
      background: transparent;
      cursor: pointer;
      font-weight: 500;
      color: #666;
      border-bottom: 2px solid transparent;
      transition: all 0.3s ease; }
      .tickets-content .tickets-tabs .tab-btn:hover {
        color: #3f51b5; }
      .tickets-content .tickets-tabs .tab-btn.active {
        color: #3f51b5;
        border-bottom-color: #3f51b5;
        font-weight: 600; }
  .tickets-content .tickets-list {
    display: flex; }
  .tickets-content .ticket-card {
    display: flex;
    gap: 20px;
    padding: 20px;
    border: 1px solid #f0f0f0;
    border-radius: 16px;
    transition: all 0.3s ease; }
    .tickets-content .ticket-card:hover {
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
      border-color: #3f51b5; }
    .tickets-content .ticket-card .ticket-image {
      width: 120px;
      height: 80px;
      border-radius: 12px;
      background: linear-gradient(135deg, #ff6b6b, #ee5a24);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 32px;
      flex-shrink: 0; }
    .tickets-content .ticket-card .ticket-details {
      flex: 1; }
      .tickets-content .ticket-card .ticket-details h3 {
        font-size: 20px;
        font-weight: 600;
        color: #2c3e50;
        margin: 0 0 12px 0; }
      .tickets-content .ticket-card .ticket-details .ticket-info p {
        margin: 4px 0;
        color: #666;
        display: flex;
        align-items: center;
        gap: 8px; }
  .tickets-content .empty-state {
    text-align: center;
    padding: 60px 20px;
    color: #666; }

.payment-content {
  background: white;
  border-radius: 24px;
  padding: 32px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1); }
  .payment-content .payment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px; }
    .payment-content .payment-header h1 {
      font-size: 32px;
      font-weight: 700;
      color: #2c3e50;
      margin: 0; }
    .payment-content .payment-header .sort-dropdown select {
      padding: 8px 16px;
      border: none;
      border-radius: 8px;
      background: white;
      cursor: pointer; }
  .payment-content .payment-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
    border-bottom: 1px solid #f0f0f0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none; }
    .payment-content .payment-tabs::-webkit-scrollbar {
      display: none; }
    .payment-content .payment-tabs .tab-btn {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 12px 20px;
      border: none;
      background: transparent;
      cursor: pointer;
      font-weight: 500;
      color: #666;
      border-bottom: 2px solid transparent;
      transition: all 0.3s ease;
      white-space: nowrap;
      flex-shrink: 0; }
      .payment-content .payment-tabs .tab-btn .tab-label {
        font-size: 14px; }
      .payment-content .payment-tabs .tab-btn .tab-counter {
        background: #e0e0e0;
        color: #666;
        border-radius: 12px;
        padding: 2px 8px;
        font-size: 12px;
        font-weight: 600;
        min-width: 20px;
        text-align: center;
        line-height: 1.2; }
      .payment-content .payment-tabs .tab-btn .tab-counter-pending {
        background: #ffb84d;
        color: white; }
      .payment-content .payment-tabs .tab-btn .tab-counter-successful {
        background: #34d399;
        color: white; }
      .payment-content .payment-tabs .tab-btn .tab-counter-cancelled {
        background: #f87171;
        color: white; }
      .payment-content .payment-tabs .tab-btn .tab-counter-expired {
        background: #e5e7eb;
        color: white; }
      .payment-content .payment-tabs .tab-btn .tab-counter-refund {
        background: #e5e7eb;
        color: white; }
      .payment-content .payment-tabs .tab-btn:hover {
        color: #3f51b5; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter {
          background: #e3f2fd;
          color: #3f51b5; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter-pending {
          background: #ffb84d !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter-successful {
          background: #34d399 !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter-cancelled {
          background: #f87171 !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter-expired {
          background: #e5e7eb !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter-refund {
          background: #e5e7eb !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn:hover .tab-counter-zero {
          background: #f3f4f6 !important;
          color: #9ca3af !important; }
      .payment-content .payment-tabs .tab-btn.active {
        color: #3f51b5;
        border-bottom-color: #3f51b5;
        font-weight: 600; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter {
          background: #3f51b5;
          color: white; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter-pending {
          background: #ffb84d !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter-successful {
          background: #34d399 !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter-cancelled {
          background: #f87171 !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter-expired {
          background: #e5e7eb !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter-refund {
          background: #e5e7eb !important;
          color: white !important; }
        .payment-content .payment-tabs .tab-btn.active .tab-counter-zero {
          background: #f3f4f6 !important;
          color: #9ca3af !important; }
    @media (max-width: 768px) {
      .payment-content .payment-tabs {
        gap: 4px;
        padding-bottom: 4px; }
        .payment-content .payment-tabs .tab-btn {
          padding: 10px 16px;
          gap: 6px; }
          .payment-content .payment-tabs .tab-btn .tab-label {
            font-size: 13px; }
          .payment-content .payment-tabs .tab-btn .tab-counter {
            padding: 1px 6px;
            font-size: 11px;
            min-width: 18px; } }
    @media (max-width: 480px) {
      .payment-content .payment-tabs .tab-btn {
        padding: 8px 12px;
        gap: 4px; }
        .payment-content .payment-tabs .tab-btn .tab-label {
          font-size: 12px; }
        .payment-content .payment-tabs .tab-btn .tab-counter {
          padding: 1px 5px;
          font-size: 10px;
          min-width: 16px; } }
  .payment-content .payment-list .empty-state {
    text-align: center;
    padding: 80px 20px; }
    .payment-content .payment-list .empty-state .empty-icon {
      font-size: 64px;
      margin-bottom: 20px; }
    .payment-content .payment-list .empty-state h3 {
      font-size: 24px;
      font-weight: 600;
      color: #2c3e50;
      margin-bottom: 12px; }
    .payment-content .payment-list .empty-state p {
      color: #666;
      font-size: 16px; }

.payment-card {
  background: white;
  border-radius: 16px;
  margin-bottom: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  transition: all 0.2s ease;
  overflow: hidden; }
  .payment-card.pending-card {
    border: 2px solid #ffb84d !important;
    background: #fff9e6; }
  .payment-card.successful-card {
    border: 2px solid #34d399 !important;
    background: #ecfdf5; }
  .payment-card.cancelled-card {
    border: 2px solid #fca5a5 !important;
    background: #fef2f2; }
  .payment-card.expired-card {
    border: 2px solid #d1d5db !important;
    background: #f9fafb;
    opacity: 0.7; }
  .payment-card.refund-card {
    border: 2px solid #d1d5db !important;
    background: #f9fafb;
    opacity: 0.7; }
  .payment-card .payment-card-desktop {
    display: block;
    padding: 20px; }
    @media (max-width: 768px) {
      .payment-card .payment-card-desktop {
        display: none; } }
  .payment-card .payment-card-mobile {
    display: none;
    padding: 16px; }
    @media (max-width: 768px) {
      .payment-card .payment-card-mobile {
        display: block; } }
  .payment-card .payment-header-desktop {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap; }
    .payment-card .payment-header-desktop .payment-info-left {
      display: flex;
      align-items: center;
      gap: 4px; }
      .payment-card .payment-header-desktop .payment-info-left .order-date-label {
        color: #666;
        font-size: 14px; }
      .payment-card .payment-header-desktop .payment-info-left .order-date-value {
        color: #333;
        font-size: 14px;
        font-weight: 600; }
    .payment-card .payment-header-desktop .payment-info-right {
      display: flex;
      align-items: center;
      gap: 12px; }
      .payment-card .payment-header-desktop .payment-info-right .order-no-label {
        color: #666;
        font-size: 14px; }
      .payment-card .payment-header-desktop .payment-info-right .order-no-value {
        color: #333;
        font-size: 14px;
        font-weight: 600; }
  .payment-card .payment-content-desktop .event-title {
    font-size: 18px;
    font-weight: 700;
    color: #333;
    margin-bottom: 16px;
    line-height: 1.3; }
  .payment-card .payment-content-desktop .event-detail-line {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap; }
    .payment-card .payment-content-desktop .event-detail-line .show-time-section .detail-text {
      color: #666;
      font-size: 14px; }
    .payment-card .payment-content-desktop .event-detail-line .separator {
      color: #ccc;
      font-size: 14px;
      margin: 0 4px; }
    .payment-card .payment-content-desktop .event-detail-line .zone-section,
    .payment-card .payment-content-desktop .event-detail-line .seat-section {
      display: flex;
      align-items: center;
      gap: 4px; }
      .payment-card .payment-content-desktop .event-detail-line .zone-section .zone-icon,
      .payment-card .payment-content-desktop .event-detail-line .zone-section .seat-icon,
      .payment-card .payment-content-desktop .event-detail-line .seat-section .zone-icon,
      .payment-card .payment-content-desktop .event-detail-line .seat-section .seat-icon {
        font-size: 14px; }
      .payment-card .payment-content-desktop .event-detail-line .zone-section .zone-text,
      .payment-card .payment-content-desktop .event-detail-line .zone-section .seat-text,
      .payment-card .payment-content-desktop .event-detail-line .seat-section .zone-text,
      .payment-card .payment-content-desktop .event-detail-line .seat-section .seat-text {
        color: #333;
        font-size: 14px;
        font-weight: 500; }
    .payment-card .payment-content-desktop .event-detail-line .ticket-section {
      display: flex;
      align-items: center;
      gap: 4px;
      margin-left: auto; }
      .payment-card .payment-content-desktop .event-detail-line .ticket-section .ticket-icon {
        font-size: 14px; }
      .payment-card .payment-content-desktop .event-detail-line .ticket-section .ticket-text {
        color: #66aeda;
        font-size: 14px;
        font-weight: 500; }
    .payment-card .payment-content-desktop .event-detail-line .price-section {
      min-width: 120px;
      text-align: right; }
      .payment-card .payment-content-desktop .event-detail-line .price-section .total-price {
        color: #66aeda;
        font-size: 16px;
        font-weight: 700; }
  .payment-card .payment-actions-desktop {
    border-top: 1px solid #e0e0e0;
    padding-top: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px; }
    .payment-card .payment-actions-desktop .payment-method-info {
      font-size: 14px;
      color: #666; }
      .payment-card .payment-actions-desktop .payment-method-info .change-payment-link {
        background: none;
        border: none;
        color: #66aeda;
        cursor: pointer;
        text-decoration: underline;
        padding: 0; }
        .payment-card .payment-actions-desktop .payment-method-info .change-payment-link:hover {
          color: #5a9bc4; }
    .payment-card .payment-actions-desktop .pay-again-btn {
      background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
      color: white;
      border: none;
      border-radius: 8px;
      padding: 12px 24px;
      font-size: 14px;
      font-weight: 600;
      cursor: pointer;
      transition: all 0.2s ease;
      min-width: 120px; }
      .payment-card .payment-actions-desktop .pay-again-btn:hover {
        background: linear-gradient(90deg, #161349 0%, #5a9bc4 100%);
        transform: translateY(-1px); }
  .payment-card .payment-header-mobile {
    margin-bottom: 12px; }
    .payment-card .payment-header-mobile .header-row {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 12px; }
      .payment-card .payment-header-mobile .header-row .order-info {
        flex: 1; }
        .payment-card .payment-header-mobile .header-row .order-info .order-date,
        .payment-card .payment-header-mobile .header-row .order-info .order-no {
          font-size: 13px;
          color: #666;
          margin-bottom: 2px; }
          .payment-card .payment-header-mobile .header-row .order-info .order-date:last-child,
          .payment-card .payment-header-mobile .header-row .order-info .order-no:last-child {
            margin-bottom: 0; }
  .payment-card .payment-content-mobile .event-title-mobile {
    font-size: 16px;
    font-weight: 700;
    color: #333;
    margin-bottom: 12px;
    line-height: 1.4; }
  .payment-card .payment-content-mobile .event-details-mobile .show-time-mobile {
    color: #666;
    font-size: 13px;
    margin-bottom: 8px; }
  .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 8px; }
    .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row .zone-info,
    .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row .seat-info {
      display: flex;
      align-items: center;
      gap: 4px;
      font-size: 13px;
      color: #333;
      font-weight: 500; }
      .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row .zone-info .zone-icon,
      .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row .zone-info .seat-icon,
      .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row .seat-info .zone-icon,
      .payment-card .payment-content-mobile .event-details-mobile .zone-seat-row .seat-info .seat-icon {
        font-size: 14px; }
  .payment-card .payment-content-mobile .event-details-mobile .ticket-price-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px; }
    .payment-card .payment-content-mobile .event-details-mobile .ticket-price-row .ticket-info {
      display: flex;
      align-items: center;
      gap: 4px; }
      .payment-card .payment-content-mobile .event-details-mobile .ticket-price-row .ticket-info .ticket-icon {
        font-size: 14px; }
      .payment-card .payment-content-mobile .event-details-mobile .ticket-price-row .ticket-info span {
        color: #66aeda;
        font-size: 13px;
        font-weight: 500; }
    .payment-card .payment-content-mobile .event-details-mobile .ticket-price-row .price-mobile .total-price-mobile {
      color: #66aeda;
      font-size: 14px;
      font-weight: 700; }
  .payment-card .payment-content-mobile .payment-actions-mobile {
    border-top: 1px solid #e0e0e0;
    padding-top: 12px; }
    .payment-card .payment-content-mobile .payment-actions-mobile .payment-method-mobile {
      font-size: 13px;
      color: #666;
      margin-bottom: 12px; }
      .payment-card .payment-content-mobile .payment-actions-mobile .payment-method-mobile .change-payment-link {
        background: none;
        border: none;
        color: #66aeda;
        cursor: pointer;
        text-decoration: underline;
        padding: 0; }
        .payment-card .payment-content-mobile .payment-actions-mobile .payment-method-mobile .change-payment-link:hover {
          color: #5a9bc4; }
    .payment-card .payment-content-mobile .payment-actions-mobile .pay-again-btn-mobile {
      background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
      color: white;
      border: none;
      border-radius: 8px;
      padding: 12px 24px;
      font-size: 14px;
      font-weight: 600;
      cursor: pointer;
      transition: all 0.2s ease;
      width: 100%; }
      .payment-card .payment-content-mobile .payment-actions-mobile .pay-again-btn-mobile:hover {
        background: linear-gradient(90deg, #161349 0%, #5a9bc4 100%); }
  .payment-card .payment-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 8px; }
    .payment-card .payment-card-header .payment-date-info,
    .payment-card .payment-card-header .payment-order-info {
      display: flex;
      flex-direction: column;
      gap: 4px; }
      .payment-card .payment-card-header .payment-date-info .payment-label,
      .payment-card .payment-card-header .payment-order-info .payment-label {
        font-size: 12px;
        color: #666;
        font-weight: 500; }
      .payment-card .payment-card-header .payment-date-info .payment-value,
      .payment-card .payment-card-header .payment-order-info .payment-value {
        font-size: 14px;
        color: #1f2937;
        font-weight: 600; }
    .payment-card .payment-card-header .status-badge {
      padding: 6px 12px;
      border-radius: 20px;
      font-size: 12px;
      font-weight: 600;
      text-align: center; }
      .payment-card .payment-card-header .status-badge.pending {
        background: #ff9800;
        color: white;
        font-size: 14px;
        font-weight: 700; }
      .payment-card .payment-card-header .status-badge.approved {
        background: #4caf50;
        color: white; }
      .payment-card .payment-card-header .status-badge.rejected {
        background: #f44336;
        color: white; }
      .payment-card .payment-card-header .status-badge.expired {
        background: #9e9e9e;
        color: white; }
  .payment-card .payment-card-body .event-info .event-title {
    font-size: 18px;
    font-weight: 700;
    color: #1f2937;
    margin-bottom: 16px;
    line-height: 1.3; }
  .payment-card .payment-card-body .event-info .event-details {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 16px; }
    .payment-card .payment-card-body .event-info .event-details .event-detail-item {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 14px; }
      .payment-card .payment-card-body .event-info .event-details .event-detail-item .detail-label {
        color: #666;
        min-width: 80px;
        font-weight: 500; }
      .payment-card .payment-card-body .event-info .event-details .event-detail-item .detail-value {
        color: #1f2937;
        font-weight: 600; }
  .payment-card .payment-card-body .event-info .payment-total {
    text-align: right;
    margin-bottom: 16px; }
    .payment-card .payment-card-body .event-info .payment-total .total-amount {
      font-size: 16px;
      font-weight: 700;
      color: #66aeda; }
  .payment-card .payment-card-body .payment-actions {
    border-top: 1px solid #f0f0f0;
    padding-top: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px; }
    .payment-card .payment-card-body .payment-actions .payment-method-info {
      font-size: 14px;
      color: #666; }
      .payment-card .payment-card-body .payment-actions .payment-method-info .change-payment-link {
        background: none;
        border: none;
        color: #66aeda;
        cursor: pointer;
        text-decoration: underline;
        padding: 0;
        margin-left: 4px; }
        .payment-card .payment-card-body .payment-actions .payment-method-info .change-payment-link:hover {
          color: #5a9bc4; }
    .payment-card .payment-card-body .payment-actions .pay-again-btn {
      background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
      color: white;
      border: none;
      border-radius: 8px;
      padding: 12px 24px;
      font-size: 14px;
      font-weight: 600;
      cursor: pointer;
      transition: all 0.2s ease; }
      .payment-card .payment-card-body .payment-actions .pay-again-btn:hover {
        background: linear-gradient(90deg, #161349 0%, #5a9bc4 100%);
        transform: translateY(-1px); }
  @media (max-width: 768px) {
    .payment-card {
      padding: 16px;
      margin-bottom: 12px; }
      .payment-card .payment-card-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px; }
        .payment-card .payment-card-header .status-badge {
          align-self: flex-end; }
      .payment-card .payment-card-body .event-info .event-title {
        font-size: 16px;
        margin-bottom: 12px; }
      .payment-card .payment-card-body .event-info .event-details {
        gap: 6px; }
        .payment-card .payment-card-body .event-info .event-details .event-detail-item {
          font-size: 13px; }
          .payment-card .payment-card-body .event-info .event-details .event-detail-item .detail-label {
            min-width: 70px; }
      .payment-card .payment-card-body .event-info .payment-total .total-amount {
        font-size: 14px; }
      .payment-card .payment-card-body .payment-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 12px; }
        .payment-card .payment-card-body .payment-actions .payment-method-info {
          text-align: center;
          font-size: 13px; }
        .payment-card .payment-card-body .payment-actions .pay-again-btn {
          width: 100%;
          padding: 12px; } }
  @media (max-width: 480px) {
    .payment-card {
      padding: 12px; }
      .payment-card .payment-card-header .payment-date-info .payment-label,
      .payment-card .payment-card-header .payment-order-info .payment-label {
        font-size: 11px; }
      .payment-card .payment-card-header .payment-date-info .payment-value,
      .payment-card .payment-card-header .payment-order-info .payment-value {
        font-size: 13px; }
      .payment-card .payment-card-header .status-badge {
        font-size: 11px;
        padding: 4px 8px; }
      .payment-card .payment-card-body .event-info .event-title {
        font-size: 15px; }
      .payment-card .payment-card-body .event-info .event-details .event-detail-item {
        font-size: 12px; }
        .payment-card .payment-card-body .event-info .event-details .event-detail-item .detail-label {
          min-width: 60px; }
      .payment-card .payment-card-body .event-info .payment-total .total-amount {
        font-size: 13px; } }

@media (max-width: 768px) {
  .member-dashboard {
    flex-direction: column; }
    .member-dashboard .member-sidebar {
      width: 100%;
      border-radius: 0 0 24px 24px;
      padding: 20px; }
      .member-dashboard .member-sidebar .menu-nav {
        flex-direction: row;
        overflow-x: auto;
        gap: 12px; }
        .member-dashboard .member-sidebar .menu-nav .menu-item {
          min-width: 120px;
          text-align: center;
          flex-direction: column;
          gap: 8px;
          padding: 12px 16px; }
          .member-dashboard .member-sidebar .menu-nav .menu-item .menu-label {
            font-size: 14px; }
    .member-dashboard .main-content {
      padding: 20px; }
  .profile-content,
  .tickets-content,
  .payment-content {
    padding: 15px !important; }
    .profile-content .profile-header,
    .tickets-content .profile-header,
    .payment-content .profile-header {
      flex-direction: column;
      gap: 16px; }
      .profile-content .profile-header h1,
      .tickets-content .profile-header h1,
      .payment-content .profile-header h1 {
        font-size: 24px; }
  .ticket-card {
    flex-direction: column; }
    .ticket-card .ticket-image {
      width: 100%;
      height: 120px; } }

@media (max-width: 768px) {
  .member-hide-mobile {
    display: none !important; } }

@media (min-width: 768px) {
  .member-hide-desktop {
    display: none !important; } }

.user-avatar-image {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background: white;
  color: #3c4674;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 16px; }

.btn-member-signup {
  border: 2px solid white !important;
  background: transparent !important;
  border-radius: 8px !important;
  padding: 8px 48px;
  color: white !important;
  cursor: pointer; }
  @media (max-width: 768px) {
    .btn-member-signup {
      padding: 8px 8px; } }

.text-color-member {
  background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text; }

.btn-cancel-edit-member {
  background: white !important;
  color: #374151 !important;
  border: 1px solid #d1d5db !important;
  border-radius: 16px !important;
  padding: 12px 32px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: all 0.2s ease !important;
  min-width: 120px !important;
  height: 48px !important; }
  .btn-cancel-edit-member:hover {
    background: #f9fafb !important;
    border-color: #9ca3af !important;
    color: #374151 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); }
  .btn-cancel-edit-member:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); }
  .btn-cancel-edit-member:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important; }
  .btn-cancel-edit-member:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    transform: none !important; }

.btn-save-edit-member {
  background: linear-gradient(135deg, #1d1b52 0%, #66aeda 100%) !important;
  color: white !important;
  border: none !important;
  border-radius: 16px !important;
  padding: 12px 32px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: all 0.2s ease !important;
  min-width: 120px !important;
  height: 48px !important;
  box-shadow: 0 4px 16px rgba(29, 27, 82, 0.3); }
  .btn-save-edit-member:hover {
    background: linear-gradient(135deg, #161349 0%, #5a9bc4 100%) !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(29, 27, 82, 0.4);
    color: white !important; }
  .btn-save-edit-member:active {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(29, 27, 82, 0.3); }
  .btn-save-edit-member:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(102, 174, 218, 0.3), 0 4px 16px rgba(29, 27, 82, 0.3) !important; }
  .btn-save-edit-member:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: 0 2px 8px rgba(29, 27, 82, 0.2) !important; }

.no-tickets {
  min-height: 400px;
  display: flex;
  justify-content: center;
  align-items: center; }

.event-header-controls {
  display: flex;
  align-items: center;
  gap: 12px; }

.back-button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  transition: background-color 0.2s ease; }
  .back-button:hover {
    background-color: #f3f4f6; }

.ticket-content-member {
  display: flex;
  justify-content: space-between;
  align-items: flex-start; }

.ticket-main-info {
  flex: 1; }

.ticket-serial {
  font-weight: 600;
  font-size: 16px;
  color: #1f2937;
  margin-bottom: 4px; }

.ticket-event-name {
  color: #6b7280;
  font-size: 14px;
  margin-bottom: 8px; }

.ticket-type-price {
  display: flex;
  align-items: center;
  gap: 8px; }

.ticket-type {
  color: #66aeda;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 4px; }

.pipe-y-line {
  border-left: 1px solid #616161;
  height: 14px; }

.ticket-price {
  color: #66aeda;
  font-weight: 600; }

.ticket-transfer-info {
  margin-top: 8px;
  font-size: 14px;
  color: #212121; }
  .ticket-transfer-info .recall-link {
    color: #991b1b;
    margin-left: 4px;
    cursor: pointer; }

.ticket-used-info {
  margin-top: 8px;
  font-size: 14px;
  color: #6b7280; }

.ticket-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end; }

.status-badge {
  padding: 4px 8px;
  font-size: 20px;
  font-weight: 500;
  text-align: center; }
  @media (max-width: 768px) {
    .status-badge {
      margin-top: 0px;
      font-size: 16px; } }
  .status-badge.used {
    color: #14b8a6; }
  .status-badge.expired {
    color: #6b7280; }

.action-btn {
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  transition: all 0.2s ease; }
  .action-btn.primary {
    background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
    color: white;
    font-weight: 600; }
  .action-btn.secondary {
    border: none;
    padding: 0px;
    font-size: 16px;
    font-weight: 600; }

.send-btn {
  background: transparent;
  color: #3b82f6;
  border: 1px solid #3b82f6;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px; }
  .send-btn:hover {
    background: #f0f9ff; }

.event-tickets-list {
  display: flex;
  flex-direction: column;
  gap: 0; }

@media (max-width: 768px) {
  .event-ticket-card {
    width: 100%; }
    .event-ticket-card .ticket-content-member {
      flex-direction: column;
      gap: 12px; }
    .event-ticket-card .ticket-actions {
      align-items: flex-start;
      flex-direction: row;
      justify-content: space-between; } }

.clickable-card {
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease; }
  .clickable-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12); }

.ticket-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10000;
  padding: 20px; }

.ticket-modal {
  background: white;
  border-radius: 24px;
  max-width: 400px;
  width: 100%;
  position: relative;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  overflow: hidden;
  animation: modalSlideIn 0.3s ease-out; }

.modal-close-btn {
  position: absolute;
  top: 16px;
  right: 16px;
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition: background 0.2s ease; }
  .modal-close-btn:hover {
    background: white; }

.ticket-modal-content {
  padding: 0; }

.modal-event-image {
  height: 200px;
  width: 100%;
  overflow: hidden;
  background: linear-gradient(135deg, #1d1b52 0%, #66aeda 100%);
  position: relative; }
  .modal-event-image img {
    width: 100%;
    height: 100%;
    object-fit: cover; }
  .modal-event-image .modal-no-image {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 16px;
    font-weight: 500; }

.modal-event-info {
  padding: 24px 24px 16px;
  text-align: center; }

.modal-event-title {
  font-size: 20px;
  font-weight: 700;
  color: #1f2937;
  margin: 0 0 16px 0;
  line-height: 1.3; }

.modal-event-details {
  display: flex;
  flex-direction: column;
  gap: 8px;
  color: #6b7280;
  font-size: 14px; }

.modal-event-date,
.modal-event-time,
.modal-event-location {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px; }

.modal-qr-code {
  display: flex;
  justify-content: center;
  padding: 24px;
  background: #f9fafb; }

.qr-placeholder {
  display: flex;
  justify-content: center;
  align-items: center; }

.modal-ticket-serial {
  padding: 16px 24px;
  text-align: center;
  background: #dbeafe;
  border-radius: 12px;
  width: 100%;
  display: flex;
  justify-content: center; }

.serial-code {
  font-size: 16px;
  font-weight: 700;
  color: white;
  letter-spacing: 1px;
  width: fit-content;
  text-align: center;
  background-color: #66aeda;
  padding: 5px 25px;
  border-radius: 50px; }

.modal-footer-member {
  background: linear-gradient(135deg, #1d1b52 0%, #66aeda 100%);
  padding: 16px 24px;
  text-align: center;
  margin-top: 24px; }

.footer-text {
  color: white;
  font-size: 16px;
  font-weight: 600; }

@keyframes modalSlideIn {
  from {
    opacity: 0;
    transform: scale(0.9) translateY(20px); }
  to {
    opacity: 1;
    transform: scale(1) translateY(0); } }

@media (max-width: 768px) {
  .ticket-modal-overlay {
    padding: 16px; }
  .ticket-modal {
    max-width: 350px;
    margin: 0 auto; }
  .modal-event-image {
    height: 160px; }
  .modal-event-info {
    padding: 20px 20px 12px; }
  .modal-event-title {
    font-size: 18px; }
  .modal-qr-code {
    padding: 20px; }
  .modal-ticket-serial {
    padding: 12px 20px; }
  .serial-code {
    font-size: 14px; }
  .modal-footer-member {
    padding: 12px 20px;
    margin-top: 20px; }
  .footer-text {
    font-size: 14px; } }

@media (max-width: 480px) {
  .ticket-modal {
    max-width: 320px; }
  .modal-event-image {
    height: 140px; }
  .modal-close-btn {
    width: 36px;
    height: 36px;
    top: 12px;
    right: 12px; } }

.tickets-detail-select.row {
  display: flex;
  flex-wrap: wrap;
  margin: -8px; }
  .tickets-detail-select.row .ticket-card {
    margin: 8px;
    flex: 0 0 calc(50% - 16px);
    box-shadow: 0px 1px 12px 0px #00000026; }
    @media (max-width: 768px) {
      .tickets-detail-select.row .ticket-card {
        flex: 0 0 calc(100% - 16px);
        margin: 0 0 16px 0; } }

.tickets-detail-select .event-image {
  width: 100px;
  height: 100px;
  border-radius: 16px;
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
  background: linear-gradient(135deg, #1d1b52 0%, #66aeda 100%); }
  @media (max-width: 768px) {
    .tickets-detail-select .event-image {
      width: 80px;
      height: 80px;
      border-radius: 12px; } }
  @media (max-width: 480px) {
    .tickets-detail-select .event-image {
      width: 70px;
      height: 70px;
      border-radius: 10px; } }
  .tickets-detail-select .event-image .container-banner-event {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden; }
    @media (max-width: 768px) {
      .tickets-detail-select .event-image .container-banner-event {
        border-radius: 12px;
        height: 80px;
        width: 80px; } }
    @media (max-width: 480px) {
      .tickets-detail-select .event-image .container-banner-event {
        border-radius: 10px;
        height: 70px;
        width: 70px; } }
    .tickets-detail-select .event-image .container-banner-event .img-banner-event {
      width: 100%;
      height: 100px;
      object-fit: cover;
      filter: blur(8px);
      -webkit-filter: blur(8px);
      z-index: 1; }
      @media (max-width: 768px) {
        .tickets-detail-select .event-image .container-banner-event .img-banner-event {
          height: 80px; } }
      @media (max-width: 480px) {
        .tickets-detail-select .event-image .container-banner-event .img-banner-event {
          height: 70px; } }
    .tickets-detail-select .event-image .container-banner-event .img-banner-event-inner {
      width: 100px !important;
      height: 100px !important;
      object-fit: contain;
      position: absolute;
      left: 0px;
      top: 0px;
      z-index: 2; }
      @media (max-width: 768px) {
        .tickets-detail-select .event-image .container-banner-event .img-banner-event-inner {
          height: 80px !important;
          width: 100% !important; } }
      @media (max-width: 480px) {
        .tickets-detail-select .event-image .container-banner-event .img-banner-event-inner {
          height: 70px !important;
          width: 100% !important; } }
  .tickets-detail-select .event-image .no-image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #9ca3af;
    font-size: 10px;
    font-weight: 500;
    border-radius: 16px;
    gap: 4px;
    background: #f3f4f6; }
    .tickets-detail-select .event-image .no-image-placeholder::before {
      font-size: 16px;
      opacity: 0.7; }
    @media (max-width: 768px) {
      .tickets-detail-select .event-image .no-image-placeholder {
        font-size: 9px;
        gap: 3px;
        border-radius: 12px; }
        .tickets-detail-select .event-image .no-image-placeholder::before {
          font-size: 14px; } }
    @media (max-width: 480px) {
      .tickets-detail-select .event-image .no-image-placeholder {
        font-size: 8px;
        gap: 2px; }
        .tickets-detail-select .event-image .no-image-placeholder::before {
          font-size: 12px; } }

.tickets-detail-select .event-details {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between; }
  .tickets-detail-select .event-details .event-title {
    font-size: 16px;
    font-weight: 600;
    color: #1f2937;
    margin: 0 0 8px 0; }
  .tickets-detail-select .event-details .event-info {
    display: flex;
    flex-direction: column;
    gap: 4px; }
    .tickets-detail-select .event-details .event-info .event-datetime {
      display: flex;
      flex-direction: column;
      gap: 2px; }
      .tickets-detail-select .event-details .event-info .event-datetime .event-date,
      .tickets-detail-select .event-details .event-info .event-datetime .event-time {
        font-size: 14px;
        color: #6b7280;
        display: flex;
        align-items: center;
        gap: 6px; }
    .tickets-detail-select .event-details .event-info .event-location span {
      font-size: 14px;
      color: #6b7280;
      display: flex;
      align-items: center;
      gap: 6px; }

.modal-member-container.send-modal-custom {
  border-radius: 24px; }
  .modal-member-container.send-modal-custom .modal-member-header {
    padding: 24px 24px 0; }
    .modal-member-container.send-modal-custom .modal-member-header .modal-member-title {
      font-size: 24px;
      font-weight: 700;
      color: #1f2937;
      margin: 0;
      text-align: left; }
      .modal-member-container.send-modal-custom .modal-member-header .modal-member-title .text-gradient {
        background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text; }
  .modal-member-container.send-modal-custom .send-modal-content {
    padding: 0 24px 24px; }
    .modal-member-container.send-modal-custom .send-modal-content .send-description {
      margin-bottom: 32px;
      line-height: 1.6; }
      .modal-member-container.send-modal-custom .send-modal-content .send-description p {
        margin: 0 0 8px 0;
        color: #374151;
        font-size: 15px; }
        .modal-member-container.send-modal-custom .send-modal-content .send-description p.send-note {
          color: #66aeda;
          font-weight: 500; }
        .modal-member-container.send-modal-custom .send-modal-content .send-description p:first-child {
          font-weight: 600;
          color: #1f2937;
          margin-bottom: 16px; }
    .modal-member-container.send-modal-custom .send-modal-content .share-options {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 10px;
      justify-items: center; }
      .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 12px;
        cursor: pointer;
        padding: 16px 12px;
        border-radius: 16px;
        transition: all 0.2s ease;
        text-align: center; }
        .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option:hover {
          background: #f8fafc;
          transform: translateY(-2px); }
        .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon {
          width: 56px;
          height: 56px;
          border-radius: 50%;
          display: flex;
          align-items: center;
          justify-content: center;
          transition: all 0.2s ease; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon.copy-link {
            background: #ef4444; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon.line {
            background: #00c300; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon.whatsapp {
            background: #25d366; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon.email {
            background: #f59e0b; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon svg {
            width: 24px;
            height: 24px; }
        .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-label {
          font-size: 14px;
          font-weight: 500;
          color: #374151; }
        .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option:hover .share-icon {
          transform: scale(1.1);
          box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15); }

@media (max-width: 768px) {
  .modal-member-container.send-modal-custom {
    border-radius: 0px; }
    .modal-member-container.send-modal-custom .send-modal-content {
      padding: 0 20px 20px; }
      .modal-member-container.send-modal-custom .send-modal-content .send-description {
        margin-bottom: 24px; }
        .modal-member-container.send-modal-custom .send-modal-content .send-description p {
          font-size: 14px; }
      .modal-member-container.send-modal-custom .send-modal-content .share-options {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px; }
        .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option {
          padding: 12px 8px; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon {
            width: 48px;
            height: 48px; }
          .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-label {
            font-size: 13px; } }

@media (max-width: 480px) {
  .modal-member-container.send-modal-custom {
    border-radius: 0px; }
    .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon {
      width: 44px;
      height: 44px; }
      .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-icon svg {
        width: 20px;
        height: 20px; }
    .modal-member-container.send-modal-custom .send-modal-content .share-options .share-option .share-label {
      font-size: 12px; } }

.disabled-card-ticket {
  background: #f7fbfd !important;
  cursor: not-allowed;
  opacity: 0.6 !important;
  box-shadow: none !important; }
  .disabled-card-ticket:hover {
    border: 1px solid #e5e7eb !important; }

.send-ticket-container {
  min-height: calc(100vh - 120px);
  padding: 40px 20px;
  display: flex;
  align-items: center;
  justify-content: center; }
  .send-ticket-container .send-card-modal {
    background: white;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
    padding: 40px;
    max-width: 800px;
    width: 100%; }
    .send-ticket-container .send-card-modal .send-card-header {
      margin-bottom: 30px; }
      .send-ticket-container .send-card-modal .send-card-header h2 {
        font-size: 28px;
        font-weight: 700;
        margin: 0;
        color: #1a1a1a; }
        .send-ticket-container .send-card-modal .send-card-header h2 .text-color-member {
          color: #66aeda; }
    .send-ticket-container .send-card-modal .ticket-display-card {
      border-radius: 12px;
      padding: 24px;
      margin-bottom: 30px;
      border: 1px solid #e2e8f0;
      box-shadow: 0px 1px 12px 0px #00000026; }
      .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container {
        display: flex;
        gap: 20px;
        align-items: flex-start; }
        .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-image {
          flex-shrink: 0;
          width: 120px;
          height: 80px;
          border-radius: 8px;
          overflow: hidden;
          background: #e2e8f0; }
          .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-image img {
            width: 100%;
            height: 100%;
            object-fit: cover; }
          .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-image .no-image-placeholder {
            display: flex;
            align-items: center;
            justify-content: center;
            height: 100%;
            color: #64748b;
            font-size: 12px;
            background: #f3f4f6; }
        .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details {
          flex: 1; }
          .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .ticket-serial {
            font-size: 18px;
            font-weight: 700;
            color: #1a1a1a;
            margin-bottom: 8px; }
          .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .event-name {
            font-size: 16px;
            font-weight: 600;
            color: #374151;
            margin-bottom: 12px; }
          .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .event-location {
            display: flex;
            align-items: center;
            gap: 6px;
            color: #64748b;
            font-size: 14px;
            margin-bottom: 12px; }
            .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .event-location svg {
              flex-shrink: 0; }
          .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info {
            display: flex;
            flex-direction: column;
            gap: 12px;
            font-size: 14px;
            color: #374151; }
            .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info .show-time-line {
              display: flex;
              align-items: center;
              gap: 4px; }
            .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info .ticket-zone-seat {
              display: flex;
              align-items: center;
              gap: 8px; }
            .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info .zone-info,
            .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info .seat-info {
              display: inline-flex;
              align-items: center;
              gap: 6px;
              background: #e0f2fe;
              color: #0277bd;
              padding: 6px 12px;
              border-radius: 6px;
              font-weight: 500;
              font-size: 13px; }
              .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info .zone-info svg,
              .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info .seat-info svg {
                flex-shrink: 0;
                width: 14px;
                height: 14px; }
  .send-ticket-container .loading-container {
    text-align: center;
    color: #64748b;
    font-size: 16px; }

@media (max-width: 768px) {
  .send-ticket-container {
    padding: 20px 16px; }
    .send-ticket-container .send-card-modal {
      padding: 24px 20px; }
      .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container {
        flex-direction: column; }
        .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-image {
          align-self: center;
          margin-bottom: 16px; }
        .send-ticket-container .send-card-modal .ticket-display-card .ticket-info-container .ticket-details .show-time-info {
          align-items: center; } }

.accept-button-container {
  display: flex;
  justify-content: center; }
  .accept-button-container .accept-button {
    background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
    color: white;
    border: none;
    border-radius: 8px;
    padding: 14px 40px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    min-width: 120px; }
    .accept-button-container .accept-button:hover {
      transform: translateY(-2px);
      box-shadow: 0 8px 25px rgba(29, 27, 82, 0.3); }
    .accept-button-container .accept-button:active {
      transform: translateY(0); }
    .accept-button-container .accept-button:disabled {
      opacity: 0.6 !important;
      cursor: not-allowed !important;
      transform: none !important; }

.confirm-transfer-modal-container .modal-overlay {
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(5px); }

.confirm-transfer-modal-container .modal-content {
  background: white;
  border-radius: 16px;
  padding: 0;
  max-width: 400px;
  width: 90%;
  margin: 0 auto;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15); }

.confirm-transfer-modal {
  padding: 40px 32px;
  text-align: center;
  border-radius: 16px;
  background: white; }
  .confirm-transfer-modal .confirm-icon {
    margin: 0 auto 24px;
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center; }
  .confirm-transfer-modal .confirm-title {
    font-size: 20px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 16px 0;
    line-height: 1.4; }
  .confirm-transfer-modal .confirm-message {
    font-size: 14px;
    color: #6b7280;
    line-height: 1.5;
    margin: 0 0 32px 0; }
  .confirm-transfer-modal .confirm-buttons {
    display: flex;
    gap: 12px; }
    .confirm-transfer-modal .confirm-buttons button {
      flex: 1;
      padding: 12px 20px;
      border-radius: 8px;
      border: none;
      font-size: 14px;
      font-weight: 500;
      cursor: pointer;
      transition: all 0.2s ease;
      min-height: 44px; }
      .confirm-transfer-modal .confirm-buttons button:hover {
        transform: translateY(-1px); }
      .confirm-transfer-modal .confirm-buttons button:active {
        transform: translateY(0); }
    .confirm-transfer-modal .confirm-buttons .decline-button {
      background: #f3f4f6;
      color: #374151; }
      .confirm-transfer-modal .confirm-buttons .decline-button:hover {
        background: #e5e7eb; }
    .confirm-transfer-modal .confirm-buttons .accept-ticket-button {
      background: linear-gradient(135deg, #1d1b52 0%, #3b4674 100%);
      color: white; }
      .confirm-transfer-modal .confirm-buttons .accept-ticket-button:hover {
        background: linear-gradient(135deg, #1a1749 0%, #323c66 100%);
        box-shadow: 0 4px 12px rgba(29, 27, 82, 0.3); }

.success-transfer-content {
  background: white;
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  max-width: 600px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border: 1px solid #f3f4f6; }
  .success-transfer-content .success-icon {
    margin: 0 auto 24px;
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center; }
  .success-transfer-content .success-title {
    font-size: 20px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 16px 0;
    line-height: 1.4; }
  .success-transfer-content .success-message {
    font-size: 14px;
    color: #6b7280;
    line-height: 1.5;
    margin: 0 0 32px 0; }
  .success-transfer-content .success-button .back-to-tickets-button {
    background: linear-gradient(135deg, #1d1b52 0%, #3b4674 100%);
    color: white;
    border: none;
    border-radius: 8px;
    padding: 14px 28px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 160px; }
    .success-transfer-content .success-button .back-to-tickets-button:hover {
      background: linear-gradient(135deg, #1a1749 0%, #323c66 100%);
      box-shadow: 0 4px 12px rgba(29, 27, 82, 0.3);
      transform: translateY(-1px); }
    .success-transfer-content .success-button .back-to-tickets-button:active {
      transform: translateY(0); }

.unavailable-transfer-content {
  background: white;
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  max-width: 600px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border: 1px solid #f3f4f6; }
  .unavailable-transfer-content .warning-icon {
    margin: 0 auto 24px;
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center; }
  .unavailable-transfer-content .warning-title {
    font-size: 20px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 16px 0;
    line-height: 1.4; }
  .unavailable-transfer-content .warning-message {
    font-size: 14px;
    color: #6b7280;
    line-height: 1.5;
    margin: 0 0 32px 0; }
  .unavailable-transfer-content .warning-button {
    margin-top: 16px; }
    .unavailable-transfer-content .warning-button .back-to-homepage-button {
      background: linear-gradient(135deg, #1d1b52 0%, #3b4674 100%);
      color: white;
      border: none;
      border-radius: 8px;
      padding: 14px 28px;
      font-size: 14px;
      font-weight: 500;
      cursor: pointer;
      transition: all 0.2s ease;
      min-width: 160px; }
      .unavailable-transfer-content .warning-button .back-to-homepage-button:hover {
        background: linear-gradient(135deg, #1a1749 0%, #323c66 100%);
        box-shadow: 0 4px 12px rgba(29, 27, 82, 0.3);
        transform: translateY(-1px); }
      .unavailable-transfer-content .warning-button .back-to-homepage-button:active {
        transform: translateY(0); }
  .unavailable-transfer-content .warning-message:last-child {
    margin-bottom: 0; }

.order-detail {
  background: white;
  border-radius: 24px;
  padding: 32px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  min-height: 70vh; }
  .order-detail .order-detail-header {
    margin-bottom: 32px;
    display: flex;
    align-items: start; }
    .order-detail .order-detail-header .btn-icon-back {
      background: #ffffffe0;
      box-shadow: 0px 1px 12px 0px #00000026;
      width: 32px;
      height: 32px;
      opacity: 1;
      border-radius: 100px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer; }
    .order-detail .order-detail-header .back-btn {
      background: none;
      border: none;
      font-size: 24px;
      font-weight: 600;
      color: #3f51b5;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 0; }
      .order-detail .order-detail-header .back-btn:hover {
        color: #303f9f; }
  .order-detail .order-detail-card {
    background: var(--Background-fill, #f7fbfd);
    box-shadow: 0px 1px 12px 0px rgba(0, 0, 0, 0.15);
    width: 100%;
    min-height: 236px;
    border-radius: 12px;
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 32px; }
    @media (max-width: 768px) {
      .order-detail .order-detail-card {
        max-width: 100%;
        padding: 16px;
        gap: 20px; } }
  .order-detail .order-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 32px; }
    .order-detail .order-info-grid .info-card {
      background-image: url("https://s3virtualexpo.eventpass.co/images/1758037773726-bg-member.png");
      background-size: cover;
      background-repeat: no-repeat;
      border-radius: 12px;
      padding: 20px; }
      .order-detail .order-info-grid .info-card .info-label {
        font-size: 14px;
        color: #666;
        margin-bottom: 8px; }
      .order-detail .order-info-grid .info-card .info-value {
        font-size: 16px;
        font-weight: 500;
        color: #66aeda; }
  .order-detail .event-info {
    margin-bottom: 32px; }
    .order-detail .event-info .event-title-detail {
      font-size: 20px;
      font-weight: 600;
      color: #2c3e50;
      margin-bottom: 16px;
      line-height: 1.3; }
    .order-detail .event-info .event-ticket-info,
    .order-detail .event-info .event-datetime,
    .order-detail .event-info .event-location {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 8px;
      font-size: 14px;
      color: #666; }
      .order-detail .event-info .event-ticket-info span:first-child,
      .order-detail .event-info .event-datetime span:first-child,
      .order-detail .event-info .event-location span:first-child {
        font-size: 16px; }
  .order-detail .ticket-breakdown .breakdown-header {
    display: flex;
    justify-content: space-between;
    padding: 16px 0;
    border-top: 1px solid;
    border-image: linear-gradient(90deg, #1d1b52, #66aeda) 1;
    font-weight: 600;
    color: #616161;
    margin-bottom: 16px;
    font-size: 12px; }
  .order-detail .ticket-breakdown .detail-data-exclusive {
    display: flex;
    justify-content: space-between;
    font-weight: 600;
    color: #616161;
    margin-bottom: 16px;
    font-size: 12px; }
  .order-detail .ticket-breakdown .ticket-item {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid #f5f5f5;
    font-size: 14px; }
    .order-detail .ticket-breakdown .ticket-item:last-child {
      border-bottom: none; }
  .order-detail .ticket-breakdown .cost-breakdown {
    border-top: 1px solid;
    border-image: linear-gradient(90deg, #1d1b52, #66aeda) 1;
    margin-top: 16px;
    padding-top: 16px; }
    .order-detail .ticket-breakdown .cost-breakdown .cost-item {
      display: flex;
      justify-content: space-between;
      padding: 8px 0;
      color: #666; }
  .order-detail .ticket-breakdown .grand-total {
    display: flex;
    justify-content: space-between;
    padding: 16px 0;
    border-top: 2px solid;
    border-image: linear-gradient(90deg, #1d1b52, #66aeda) 1;
    margin-top: 16px;
    font-size: 18px;
    font-weight: 600;
    color: #3f51b5; }
  .order-detail .ticket-breakdown .ticket-detail-section .breakdown-header {
    border-top: 1px solid;
    border-image: linear-gradient(90deg, #1d1b52, #66aeda) 1;
    margin-bottom: 0; }
  .order-detail .ticket-breakdown .ticket-detail-section .ticket-item-detail {
    padding: 16px 0; }
    .order-detail .ticket-breakdown .ticket-detail-section .ticket-item-detail .show-time-line {
      font-size: 14px;
      color: #666;
      margin-bottom: 8px; }
    .order-detail .ticket-breakdown .ticket-detail-section .ticket-item-detail .zone-seat-line {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 14px;
      color: #666; }
      .order-detail .ticket-breakdown .ticket-detail-section .ticket-item-detail .zone-seat-line .zone-icon,
      .order-detail .ticket-breakdown .ticket-detail-section .ticket-item-detail .zone-seat-line .seat-icon {
        font-size: 16px; }
      .order-detail .ticket-breakdown .ticket-detail-section .ticket-item-detail .zone-seat-line .separator {
        color: #ccc;
        margin: 0 4px; }
  .order-detail .event-header-line {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px; }
    .order-detail .event-header-line .event-title-detail {
      flex: 1;
      margin-right: 16px; }
    .order-detail .event-header-line .free-entry-badge {
      display: flex;
      align-items: center;
      gap: 4px;
      padding: 6px 12px;
      border-radius: 20px;
      font-size: 14px;
      font-weight: 500;
      white-space: nowrap;
      font-weight: 700;
      color: #66aeda; }
      .order-detail .event-header-line .free-entry-badge .ticket-icon {
        font-size: 18px; }
  @media (max-width: 768px) {
    .order-detail {
      padding: 20px; }
      .order-detail .order-info-grid {
        grid-template-columns: 1fr;
        gap: 12px; }
      .order-detail .order-detail-header .back-btn {
        font-size: 20px; }
      .order-detail .event-title-detail {
        font-size: 18px; } }

.payment-card.clickable {
  cursor: pointer;
  transition: all 0.3s ease; }
  .payment-card.clickable:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15); }

@media (max-width: 768px) {
  .confirm-transfer-modal {
    padding: 32px 24px; }
    .confirm-transfer-modal .confirm-title {
      font-size: 18px; }
    .confirm-transfer-modal .confirm-buttons {
      flex-direction: column; }
      .confirm-transfer-modal .confirm-buttons button {
        width: 100%; }
  .success-transfer-content {
    padding: 32px 24px; }
    .success-transfer-content .success-title {
      font-size: 18px; }
    .success-transfer-content .success-button .back-to-tickets-button {
      width: 100%;
      min-width: unset; }
  .unavailable-transfer-content {
    padding: 32px 24px; }
    .unavailable-transfer-content .warning-title {
      font-size: 18px; }
    .unavailable-transfer-content .warning-button .back-to-homepage-button {
      width: 100%;
      min-width: unset; } }

.icon-view-image-upload {
  width: 32px;
  height: 32px;
  background-color: #1d1b52;
  border-radius: 8px;
  padding: 4px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center; }

.status-badge-pending {
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  background: #ffb84d;
  color: #1d1b52;
  font-size: 14px;
  font-weight: 700;
  backdrop-filter: blur(56.25px);
  box-shadow: 0px 0px 1.13px 0px #f5f5f666 inset;
  display: flex;
  align-items: center;
  justify-content: center; }
  .status-badge-pending svg {
    margin-right: 5px; }

.view-ticket-section .show-time-section .detail-text {
  color: #616161;
  font-size: 14px; }

.view-ticket-section .separator {
  color: #ccc;
  font-size: 14px;
  margin: 0 4px; }

.view-ticket-section .zone-text {
  font-size: 14px;
  color: #352b26;
  margin-left: 5px; }

.event-image-sendticket {
  width: 100px;
  height: 100px;
  border-radius: 16px;
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
  background: linear-gradient(135deg, #1d1b52 0%, #66aeda 100%); }
  @media (max-width: 768px) {
    .event-image-sendticket {
      width: 80px;
      height: 80px;
      border-radius: 12px; } }
  @media (max-width: 480px) {
    .event-image-sendticket {
      width: 70px;
      height: 70px;
      border-radius: 10px; } }
  .event-image-sendticket .container-banner-event {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden; }
    @media (max-width: 768px) {
      .event-image-sendticket .container-banner-event {
        border-radius: 12px;
        height: 80px;
        width: 80px; } }
    @media (max-width: 480px) {
      .event-image-sendticket .container-banner-event {
        border-radius: 10px;
        height: 70px;
        width: 70px; } }
    .event-image-sendticket .container-banner-event .img-banner-event {
      width: 100%;
      height: 100px;
      object-fit: cover;
      filter: blur(8px);
      -webkit-filter: blur(8px);
      z-index: 1; }
      @media (max-width: 768px) {
        .event-image-sendticket .container-banner-event .img-banner-event {
          height: 80px; } }
      @media (max-width: 480px) {
        .event-image-sendticket .container-banner-event .img-banner-event {
          height: 70px; } }
    .event-image-sendticket .container-banner-event .img-banner-event-inner {
      width: 100px !important;
      height: 100px !important;
      object-fit: contain;
      position: absolute;
      left: 0px;
      top: 0px;
      z-index: 2; }
      @media (max-width: 768px) {
        .event-image-sendticket .container-banner-event .img-banner-event-inner {
          height: 80px !important;
          width: 100% !important; } }
      @media (max-width: 480px) {
        .event-image-sendticket .container-banner-event .img-banner-event-inner {
          height: 70px !important;
          width: 100% !important; } }
  .event-image-sendticket .no-image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #9ca3af;
    font-size: 10px;
    font-weight: 500;
    border-radius: 16px;
    gap: 4px;
    background: #f3f4f6; }
    .event-image-sendticket .no-image-placeholder::before {
      font-size: 16px;
      opacity: 0.7; }
    @media (max-width: 768px) {
      .event-image-sendticket .no-image-placeholder {
        font-size: 9px;
        gap: 3px;
        border-radius: 12px; }
        .event-image-sendticket .no-image-placeholder::before {
          font-size: 14px; } }
    @media (max-width: 480px) {
      .event-image-sendticket .no-image-placeholder {
        font-size: 8px;
        gap: 2px; }
        .event-image-sendticket .no-image-placeholder::before {
          font-size: 12px; } }

.show-time-info {
  margin-top: 40px; }
  .show-time-info .event-detail-line {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 0px;
    flex-wrap: wrap; }
    .show-time-info .event-detail-line .show-time-section .detail-text {
      color: #666;
      font-size: 14px; }
    .show-time-info .event-detail-line .separator {
      color: #ccc;
      font-size: 14px;
      margin: 0 4px; }
    .show-time-info .event-detail-line .zone-section,
    .show-time-info .event-detail-line .seat-section {
      display: flex;
      align-items: center;
      gap: 4px; }
      .show-time-info .event-detail-line .zone-section .zone-icon,
      .show-time-info .event-detail-line .zone-section .seat-icon,
      .show-time-info .event-detail-line .seat-section .zone-icon,
      .show-time-info .event-detail-line .seat-section .seat-icon {
        font-size: 14px; }
      .show-time-info .event-detail-line .zone-section .zone-text,
      .show-time-info .event-detail-line .zone-section .seat-text,
      .show-time-info .event-detail-line .seat-section .zone-text,
      .show-time-info .event-detail-line .seat-section .seat-text {
        color: #333;
        font-size: 14px;
        font-weight: 500; }
    .show-time-info .event-detail-line .ticket-section {
      display: flex;
      align-items: center;
      gap: 4px;
      margin-left: auto; }
      .show-time-info .event-detail-line .ticket-section .ticket-icon {
        font-size: 14px; }
      .show-time-info .event-detail-line .ticket-section .ticket-text {
        color: #66aeda;
        font-size: 14px;
        font-weight: 500; }
    .show-time-info .event-detail-line .price-section {
      min-width: 120px;
      text-align: right; }
      .show-time-info .event-detail-line .price-section .total-price {
        color: #66aeda;
        font-size: 16px;
        font-weight: 700; }

.logout-confirmation-modal .modal-content {
  max-width: 400px;
  width: 90%;
  margin: 0 auto; }

.logout-modal-content {
  text-align: center;
  padding: 40px 30px 30px; }
  .logout-modal-content .logout-icon {
    margin-bottom: 20px;
    display: flex;
    justify-content: center; }
  .logout-modal-content .logout-title {
    color: #1d1b52;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 12px; }
  .logout-modal-content .logout-message {
    color: #616161;
    font-size: 16px;
    margin-bottom: 30px;
    line-height: 1.4; }
  .logout-modal-content .logout-actions {
    display: flex;
    gap: 12px;
    justify-content: center; }
    .logout-modal-content .logout-actions .btn-cancel,
    .logout-modal-content .logout-actions .btn-signout {
      padding: 12px 24px;
      border-radius: 8px;
      font-size: 16px;
      font-weight: 600;
      border: none;
      cursor: pointer;
      min-width: 100px;
      transition: all 0.2s ease; }
      .logout-modal-content .logout-actions .btn-cancel:hover,
      .logout-modal-content .logout-actions .btn-signout:hover {
        transform: translateY(-1px); }
      .logout-modal-content .logout-actions .btn-cancel:active,
      .logout-modal-content .logout-actions .btn-signout:active {
        transform: translateY(0); }
    .logout-modal-content .logout-actions .btn-cancel {
      background-color: #f8f9fa;
      color: #6c757d;
      border: 1px solid #dee2e6; }
      .logout-modal-content .logout-actions .btn-cancel:hover {
        background-color: #e9ecef;
        color: #495057; }
    .logout-modal-content .logout-actions .btn-signout {
      background-color: #ff4757;
      color: white; }
      .logout-modal-content .logout-actions .btn-signout:hover {
        background-color: #e63946; }
      .logout-modal-content .logout-actions .btn-signout:active {
        background-color: #d62828; }

@media (max-width: 480px) {
  .logout-modal-content {
    padding: 30px 20px 25px; }
    .logout-modal-content .logout-title {
      font-size: 20px; }
    .logout-modal-content .logout-message {
      font-size: 14px; }
    .logout-modal-content .logout-actions {
      flex-direction: column;
      gap: 10px; }
      .logout-modal-content .logout-actions .btn-cancel,
      .logout-modal-content .logout-actions .btn-signout {
        width: 100%;
        padding: 14px 20px; } }

.color-status-send {
  color: #3ab6fa !important; }

.text-gray {
  color: gray !important; }

.text-black {
  color: #000 !important; }

.text-member-primary {
  color: #1D1B52 !important; }

.text-member-secondary {
  color: #616161 !important; }

.modal-member-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  padding: 16px;
  pointer-events: auto; }
  .modal-member-backdrop.modal-open {
    opacity: 1;
    visibility: visible; }

.modal-member-container {
  background-image: url("https://s3virtualexpo.eventpass.co/images/1758037773726-bg-member.png");
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  position: relative;
  transform: scale(0.95) translateY(20px);
  transition: transform 0.3s ease;
  outline: none;
  pointer-events: auto;
  user-select: text; }
  .modal-open .modal-member-container {
    transform: scale(1) translateY(0); }
  .modal-member-container .modal-member-header {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 24px 0 24px;
    margin-bottom: 24px; }
    .modal-member-container .modal-member-header .modal-member-title {
      font-size: 24px;
      font-weight: 700;
      color: #1e293b;
      margin: 0;
      display: flex;
      align-items: center;
      gap: 8px; }
  .modal-member-container .modal-member-close {
    border: none;
    background: none;
    cursor: pointer;
    border-radius: 8px;
    color: #64748b;
    transition: all 0.2s ease;
    flex-shrink: 0;
    position: absolute;
    right: -70px; }
    .modal-member-container .modal-member-close:active {
      transform: scale(0.95); }
  .modal-member-container .modal-member-content {
    padding: 0 24px 24px 24px;
    overflow-y: auto;
    overflow-x: hidden;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    scrollbar-width: thin;
    scrollbar-color: #1d1b52 rgba(29, 27, 82, 0.1); }
    .modal-member-container .modal-member-content::-webkit-scrollbar {
      width: 8px;
      background: transparent; }
    .modal-member-container .modal-member-content::-webkit-scrollbar-track {
      background: rgba(29, 27, 82, 0.1);
      border-radius: 8px;
      margin: 4px 0; }
    .modal-member-container .modal-member-content::-webkit-scrollbar-thumb {
      background: linear-gradient(180deg, #1d1b52 0%, #2d2b62 50%, #1d1b52 100%);
      border-radius: 8px;
      border: 2px solid transparent;
      background-clip: content-box;
      min-height: 20px;
      transition: all 0.2s ease; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:hover {
        background: linear-gradient(180deg, #2d2b62 0%, #1d1b52 50%, #0f0e3a 100%);
        background-clip: content-box; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:active {
        background: linear-gradient(180deg, #0f0e3a 0%, #1d1b52 50%, #2d2b62 100%);
        background-clip: content-box; }
    .modal-member-container .modal-member-content::-webkit-scrollbar-corner {
      background: transparent; }
  .modal-member-container .modal-footer-btn-mobile {
    position: absolute;
    bottom: 0px;
    width: 100vw;
    background-color: white;
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    z-index: 999; }
    .modal-member-container .modal-footer-btn-mobile .btn-save-mb {
      background: linear-gradient(90deg, #1D1B52 0%, #66AEDA 100%);
      color: white;
      border-radius: 8px;
      font-size: 14px;
      font-weight: 600;
      cursor: pointer; }
    .modal-member-container .modal-footer-btn-mobile .btn-cancel-mb {
      color: #1D1B52;
      border-radius: 8px;
      font-size: 14px;
      font-weight: 600;
      cursor: pointer; }

.modal-size-small {
  width: 100%;
  max-width: 400px; }

.modal-size-medium {
  width: 100%;
  max-width: 600px; }

.modal-size-large {
  width: 100%;
  max-width: 900px; }

.modal-size-fullscreen {
  width: 100vw;
  height: 100vh;
  max-width: none;
  max-height: none;
  border-radius: 0;
  margin: 0; }

@media (max-width: 768px) {
  .modal-member-backdrop {
    padding: 0;
    align-items: flex-start; }
  .modal-member-container {
    width: 100vw;
    height: 100vh;
    height: 100dvh;
    max-width: 100vw;
    max-height: 100vh;
    max-height: 100dvh;
    border-radius: 0;
    transform: translateY(100vh); }
    .modal-open .modal-member-container {
      transform: translateY(0); }
    .modal-member-container .modal-member-header {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px 20px 0 20px;
      margin-bottom: 20px;
      flex-shrink: 0; }
      .modal-member-container .modal-member-header .modal-member-title {
        font-size: 20px;
        flex: 1; }
      .modal-member-container .modal-member-header .modal-member-close {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        min-width: 44px;
        background: rgba(100, 116, 139, 0.1);
        border-radius: 8px;
        cursor: pointer; }
        .modal-member-container .modal-member-header .modal-member-close:hover {
          background: rgba(100, 116, 139, 0.2); }
    .modal-member-container .modal-member-content {
      padding: 20px 20px 20px 20px;
      height: calc(100dvh - 100px);
      overflow-y: auto;
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center; }
      .modal-member-container .modal-member-content::-webkit-scrollbar {
        width: 6px;
        background: transparent; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-track {
        background: rgba(29, 27, 82, 0.1);
        border-radius: 6px;
        margin: 8px 0; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-thumb {
        background: #1d1b52;
        border-radius: 6px;
        border: 1px solid transparent;
        background-clip: content-box; }
        .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:hover {
          background: #2d2b62;
          background-clip: content-box; }
        .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:active {
          background: #0f0e3a;
          background-clip: content-box; }
  .modal-size-small,
  .modal-size-medium,
  .modal-size-large,
  .modal-size-fullscreen {
    width: 100vw;
    height: 100vh;
    max-width: 100vw;
    max-height: 100vh;
    border-radius: 0; } }

@media (max-width: 480px) {
  .modal-member-backdrop {
    padding: 0; }
  .modal-member-container {
    width: 100vw;
    height: 100vh;
    height: 100dvh;
    max-width: 100vw;
    max-height: 100vh;
    max-height: 100dvh;
    border-radius: 0; }
    .modal-member-container .modal-member-header {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 16px 16px 0 16px;
      margin-bottom: 16px;
      flex-shrink: 0; }
      .modal-member-container .modal-member-header .modal-member-title {
        font-size: 18px;
        flex: 1; }
      .modal-member-container .modal-member-header .modal-member-close {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        min-width: 40px;
        background: rgba(100, 116, 139, 0.1);
        border-radius: 8px;
        cursor: pointer; }
        .modal-member-container .modal-member-header .modal-member-close:hover {
          background: rgba(100, 116, 139, 0.2); }
    .modal-member-container .modal-member-content {
      padding: 16px 16px 16px 16px;
      height: 100dvh;
      max-height: 100dvh;
      overflow-y: auto;
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center; }
      .modal-member-container .modal-member-content::-webkit-scrollbar {
        width: 4px;
        background: transparent; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-track {
        background: rgba(29, 27, 82, 0.08);
        border-radius: 4px;
        margin: 4px 0; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-thumb {
        background: #1d1b52;
        border-radius: 4px; }
        .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:hover {
          background: #2d2b62; }
        .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:active {
          background: #0f0e3a; } }

.modal-fade-in .modal-member-container {
  transform: scale(0.9);
  opacity: 0; }
  @media (max-width: 768px) {
    .modal-fade-in .modal-member-container {
      transform: translateY(100vh);
      opacity: 1; } }

.modal-fade-in.modal-open .modal-member-container {
  transform: scale(1);
  opacity: 1; }
  @media (max-width: 768px) {
    .modal-fade-in.modal-open .modal-member-container {
      transform: translateY(0); } }

.modal-slide-up .modal-member-container {
  transform: translateY(50px); }
  @media (max-width: 768px) {
    .modal-slide-up .modal-member-container {
      transform: translateY(100vh); } }

.modal-slide-up.modal-open .modal-member-container {
  transform: translateY(0); }

.modal-slide-down .modal-member-container {
  transform: translateY(-50px); }
  @media (max-width: 768px) {
    .modal-slide-down .modal-member-container {
      transform: translateY(100vh); } }

.modal-slide-down.modal-open .modal-member-container {
  transform: translateY(0); }

.modal-no-padding .modal-member-content {
  padding: 0; }

.modal-no-header .modal-member-header {
  display: none; }

@media (min-width: 769px) {
  .modal-member-backdrop {
    padding: 16px;
    align-items: center;
    justify-content: center; }
  .modal-member-container {
    transform: scale(0.95) translateY(20px);
    border-radius: 16px;
    width: auto;
    height: auto;
    max-height: 95vh; }
    .modal-open .modal-member-container {
      transform: scale(1) translateY(0); }
    .modal-member-container .modal-member-content {
      height: auto;
      max-height: calc(95vh - 60px);
      padding: 0 24px 24px 24px; }
      .modal-member-container .modal-member-content::-webkit-scrollbar {
        width: 10px;
        background: transparent; }
      .modal-member-container .modal-member-content::-webkit-scrollbar-track {
        background: rgba(29, 27, 82, 0.1);
        border-radius: 10px;
        margin: 8px 0;
        border: 1px solid rgba(29, 27, 82, 0.2); }
      .modal-member-container .modal-member-content::-webkit-scrollbar-thumb {
        background: linear-gradient(180deg, #1d1b52 0%, #2d2b62 50%, #1d1b52 100%);
        border-radius: 10px;
        border: 2px solid transparent;
        background-clip: content-box;
        min-height: 30px;
        box-shadow: inset 0 1px 3px rgba(29, 27, 82, 0.3); }
        .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:hover {
          background: linear-gradient(180deg, #2d2b62 0%, #1d1b52 50%, #0f0e3a 100%);
          background-clip: content-box;
          box-shadow: inset 0 2px 4px rgba(29, 27, 82, 0.4); }
        .modal-member-container .modal-member-content::-webkit-scrollbar-thumb:active {
          background: linear-gradient(180deg, #0f0e3a 0%, #1d1b52 50%, #2d2b62 100%);
          background-clip: content-box;
          box-shadow: inset 0 2px 6px rgba(29, 27, 82, 0.5); }
      .modal-member-container .modal-member-content::-webkit-scrollbar-corner {
        background: transparent; }
  .modal-size-small {
    width: 100%;
    max-width: 400px; }
  .modal-size-medium {
    width: 100%;
    max-width: 600px; }
  .modal-size-large {
    width: 100%;
    max-width: 900px; }
  .modal-size-fullscreen {
    width: 100vw;
    height: 100vh;
    max-width: none;
    max-height: none;
    border-radius: 0; } }

.login-form .login-header {
  text-align: center;
  margin-bottom: 32px; }
  .login-form .login-header h3 {
    font-size: 24px;
    font-weight: 700;
    color: #1e293b;
    margin: 0 0 8px 0; }
  .login-form .login-header p {
    color: #64748b;
    margin: 0;
    font-size: 16px; }

.login-form .form-group {
  margin-bottom: 20px; }
  .login-form .form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: #374151;
    font-size: 14px; }
  .login-form .form-group input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 16px;
    transition: border-color 0.2s ease; }
    .login-form .form-group input:focus {
      outline: none;
      border-color: #3b82f6;
      box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1); }
    .login-form .form-group input::placeholder {
      color: #9ca3af; }
  .login-form .form-group .forgot-password {
    display: inline-block;
    margin-top: 8px;
    color: #1c1c1c;
    text-decoration: none;
    font-size: 14px;
    text-align: right;
    border: none;
    background: transparent; }
    .login-form .form-group .forgot-password:hover {
      text-decoration: underline; }

.login-form .btn-signin {
  width: 100%;
  padding: 12px;
  background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  margin-bottom: 24px; }
  .login-form .btn-signin:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4); }
  .login-form .btn-signin:active {
    transform: translateY(0); }
  .login-form .btn-signin:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important; }

.register-link {
  text-align: center;
  color: #9091a7;
  font-size: 14px; }
  .register-link button {
    background: none;
    border: none;
    color: #1d1b52;
    cursor: pointer;
    padding: 0;
    margin-left: 4px; }
    .register-link button:hover {
      color: #1e40af; }
    .register-link button.back-to-signin {
      color: #1d1b52 !important; }

.info-content p {
  margin-bottom: 16px;
  line-height: 1.6;
  color: #374151; }

.info-content .modal-actions {
  margin-top: 32px;
  display: flex;
  justify-content: flex-end; }
  .info-content .modal-actions button {
    padding: 8px 20px;
    background: #3b82f6;
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 500; }
    .info-content .modal-actions button:hover {
      background: #2563eb; }

.fullscreen-content h3 {
  margin-top: 0;
  margin-bottom: 16px;
  color: #1e293b; }

.fullscreen-content p {
  margin-bottom: 24px;
  color: #374151;
  line-height: 1.6; }

.example-buttons {
  display: flex;
  gap: 12px;
  margin-bottom: 32px;
  flex-wrap: wrap; }
  .example-buttons button {
    padding: 10px 20px;
    background: #f1f5f9;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    cursor: pointer;
    font-weight: 500;
    transition: all 0.2s ease; }
    .example-buttons button:hover {
      background: #e2e8f0;
      border-color: #94a3b8; }

@media (max-width: 480px) {
  .login-form .login-header {
    margin-bottom: 24px; }
    .login-form .login-header h3 {
      font-size: 20px; }
    .login-form .login-header p {
      font-size: 14px; }
  .login-form .form-group {
    margin-bottom: 16px; }
    .login-form .form-group input {
      padding: 10px 14px;
      font-size: 14px; }
  .login-form .btn-signin {
    padding: 10px;
    font-size: 14px; }
  .example-buttons {
    flex-direction: column; }
    .example-buttons button {
      width: 100%;
      padding: 12px 16px; } }

.form-check-member {
  display: flex;
  align-items: flex-start;
  gap: 12px; }
  .form-check-member .form-check-input-member {
    width: 20px;
    height: 20px;
    min-width: 20px;
    min-height: 20px;
    border: 2px solid #d1d5db;
    border-radius: 4px;
    background: white;
    cursor: pointer;
    position: relative;
    appearance: none;
    transition: all 0.2s ease;
    margin: 0;
    flex-shrink: 0; }
    .form-check-member .form-check-input-member:checked {
      background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
      border-color: #1d1b52; }
      .form-check-member .form-check-input-member:checked::after {
        content: "\2713";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        color: white;
        font-size: 14px;
        font-weight: bold;
        line-height: 1; }
    .form-check-member .form-check-input-member:hover {
      border-color: #1d1b52;
      box-shadow: 0 0 0 3px rgba(29, 27, 82, 0.1); }
    .form-check-member .form-check-input-member:focus {
      outline: none;
      border-color: #1d1b52;
      box-shadow: 0 0 0 3px rgba(29, 27, 82, 0.2); }
  .form-check-member .form-check-label-member {
    font-size: 14px;
    line-height: 1.5;
    color: #374151;
    cursor: pointer;
    margin: 0;
    flex: 1; }
    .form-check-member .form-check-label-member .terms-link {
      color: #66aeda;
      text-decoration: none;
      font-weight: 500;
      border-bottom: 1px solid transparent;
      transition: all 0.2s ease; }
      .form-check-member .form-check-label-member .terms-link:hover {
        color: #66aeda;
        border-bottom-color: #66aeda;
        text-decoration: none; }
  .form-check-member .error-message {
    color: #dc2626;
    font-size: 12px;
    margin-top: 4px;
    display: block;
    width: 100%; }

@media (max-width: 480px) {
  .form-check-member {
    gap: 10px; }
    .form-check-member .form-check-input-member {
      width: 18px;
      height: 18px;
      min-width: 18px;
      min-height: 18px; }
    .form-check-member .form-check-label-member {
      font-size: 13px; } }

.terms-link-button {
  background: none;
  border: none;
  color: #1d1b52;
  text-decoration: none;
  font-weight: 500;
  border-bottom: 1px solid transparent;
  transition: all 0.2s ease;
  cursor: pointer;
  padding: 0;
  font-size: inherit; }
  .terms-link-button:hover {
    color: #66aeda;
    border-bottom-color: #66aeda;
    text-decoration: none; }

.terms-modal-content {
  display: flex;
  flex-direction: column;
  height: 60vh;
  max-height: 500px; }
  .terms-modal-content .terms-scroll-content {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    background: white;
    margin-bottom: 20px;
    scrollbar-width: thin;
    scrollbar-color: #1d1b52 rgba(29, 27, 82, 0.1); }
    .terms-modal-content .terms-scroll-content::-webkit-scrollbar {
      width: 8px;
      background: transparent; }
    .terms-modal-content .terms-scroll-content::-webkit-scrollbar-track {
      background: rgba(29, 27, 82, 0.1);
      border-radius: 8px;
      margin: 4px 0; }
    .terms-modal-content .terms-scroll-content::-webkit-scrollbar-thumb {
      background: linear-gradient(180deg, #1d1b52 0%, #66aeda 50%, #1d1b52 100%);
      border-radius: 8px;
      border: 2px solid transparent;
      background-clip: content-box; }
      .terms-modal-content .terms-scroll-content::-webkit-scrollbar-thumb:hover {
        background: linear-gradient(180deg, #66aeda 0%, #1d1b52 50%, #66aeda 100%);
        background-clip: content-box; }
  .terms-modal-content .terms-text {
    line-height: 1.6;
    color: #374151;
    font-size: 14px; }
    .terms-modal-content .terms-text p {
      margin-bottom: 12px; }
    .terms-modal-content .terms-text h3 {
      color: #1d1b52;
      font-size: 16px;
      font-weight: 600;
      margin: 20px 0 10px 0; }
      .terms-modal-content .terms-text h3:first-child {
        margin-top: 0; }
    .terms-modal-content .terms-text strong {
      color: #1d1b52;
      font-weight: 600; }
    .terms-modal-content .terms-text .terms-effective-date {
      text-align: center;
      margin-top: 30px;
      padding: 15px;
      background: rgba(29, 27, 82, 0.1);
      border-radius: 8px;
      border-left: 4px solid #1d1b52; }
    .terms-modal-content .terms-text .contact-table {
      width: 100%;
      border-collapse: collapse;
      margin: 20px 0;
      border: 1px solid #d1d5db;
      border-radius: 8px;
      overflow: hidden; }
      .terms-modal-content .terms-text .contact-table tbody tr:nth-child(even) {
        background-color: rgba(249, 250, 251, 0.5); }
      .terms-modal-content .terms-text .contact-table tbody tr:hover {
        background-color: rgba(29, 27, 82, 0.05); }
      .terms-modal-content .terms-text .contact-table td {
        padding: 12px 16px;
        border: 1px solid #d1d5db;
        vertical-align: top;
        line-height: 1.5; }
        .terms-modal-content .terms-text .contact-table td.contact-label {
          background-color: rgba(29, 27, 82, 0.1);
          font-weight: 600;
          color: #1d1b52;
          width: 30%;
          min-width: 120px; }
        .terms-modal-content .terms-text .contact-table td.contact-info {
          color: #374151;
          font-size: 14px;
          background-color: rgba(29, 27, 82, 0.039); }
          .terms-modal-content .terms-text .contact-table td.contact-info .email-link {
            color: #1d1b52;
            text-decoration: none;
            font-weight: 500;
            border-bottom: 1px solid transparent;
            transition: all 0.2s ease; }
            .terms-modal-content .terms-text .contact-table td.contact-info .email-link:hover {
              color: #66aeda;
              border-bottom-color: #66aeda;
              text-decoration: none; }

.terms-footer {
  padding: 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  text-align: end;
  background-color: white;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px; }
  .terms-footer .scroll-instruction {
    font-size: 14px;
    color: #64748b;
    margin-bottom: 15px;
    font-style: italic; }
  .terms-footer .btn-agree {
    padding: 12px 40px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
    min-width: 120px; }
    .terms-footer .btn-agree.enabled {
      background: linear-gradient(90deg, #1d1b52 0%, #66aeda 100%);
      color: white; }
      .terms-footer .btn-agree.enabled:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 15px rgba(29, 27, 82, 0.3); }
      .terms-footer .btn-agree.enabled:active {
        transform: translateY(0); }
    .terms-footer .btn-agree.disabled {
      background: #e5e7eb;
      color: #9ca3af;
      cursor: not-allowed; }
      .terms-footer .btn-agree.disabled:hover {
        transform: none;
        box-shadow: none; }

@media (max-width: 768px) {
  .terms-modal-content {
    height: 70vh;
    max-height: none; }
    .terms-modal-content .terms-scroll-content {
      padding: 16px; }
    .terms-modal-content .terms-text {
      font-size: 13px; }
      .terms-modal-content .terms-text h3 {
        font-size: 15px; }
      .terms-modal-content .terms-text .contact-table td {
        padding: 10px 14px;
        font-size: 13px; }
        .terms-modal-content .terms-text .contact-table td.contact-label {
          width: 32%;
          font-size: 12px; }
        .terms-modal-content .terms-text .contact-table td.contact-info {
          font-size: 13px; } }

.terms-footer .scroll-instruction {
  font-size: 13px; }

.terms-footer .btn-agree {
  padding: 10px 30px;
  font-size: 14px; }

@media (max-width: 480px) {
  .terms-modal-content {
    height: 75vh; }
    .terms-modal-content .terms-scroll-content {
      padding: 12px; }
    .terms-modal-content .terms-text {
      font-size: 12px; }
      .terms-modal-content .terms-text h3 {
        font-size: 14px; }
      .terms-modal-content .terms-text .contact-table td {
        padding: 8px 12px;
        font-size: 12px; }
        .terms-modal-content .terms-text .contact-table td.contact-label {
          width: 35%;
          font-size: 11px; }
        .terms-modal-content .terms-text .contact-table td.contact-info {
          font-size: 11px; } }

.fix-radius-16 {
  border-radius: 16px !important; }

@media (max-width: 768px) {
  .rounded-sm-none {
    border-radius: 0px !important; } }

.modal-mb-member-close {
  border: none;
  background: none;
  cursor: pointer;
  border-radius: 8px;
  color: #64748b;
  transition: all 0.2s ease;
  flex-shrink: 0;
  position: absolute;
  right: 15px;
  top: 15px; }
  .modal-mb-member-close:active {
    transform: scale(0.95); }

.text-field-member .form-control {
  display: block;
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  background-image: none;
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out; }
  .text-field-member .form-control:focus {
    color: #212529;
    background-color: #fff;
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25); }
  .text-field-member .form-control:disabled, .text-field-member .form-control[readonly] {
    background-color: #e9ecef;
    opacity: 1; }

.text-field-member .text-field-label {
  display: flex;
  align-items: baseline;
  margin-bottom: 0.5rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529; }
  .text-field-member .text-field-label .required-asterisk {
    color: #dc3545;
    margin-left: 0.25rem; }

.text-field-member .text-field-description {
  padding: 0;
  margin: 0;
  font-size: 0.875rem;
  color: #6b7280;
  margin-bottom: 0.5rem; }

.text-field-member .text-field-input-container {
  position: relative; }
  .text-field-member .text-field-input-container .text-field-input {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    font-size: 1rem;
    color: #212529;
    background-color: #ffffff;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    line-height: 1.5; }
    .text-field-member .text-field-input-container .text-field-input:focus {
      outline: 0;
      border-color: #86b7fe;
      box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25); }
    .text-field-member .text-field-input-container .text-field-input:disabled, .text-field-member .text-field-input-container .text-field-input[readonly] {
      background-color: #e9ecef;
      opacity: 1;
      cursor: not-allowed; }
    .text-field-member .text-field-input-container .text-field-input:-webkit-autofill, .text-field-member .text-field-input-container .text-field-input:-webkit-autofill:hover, .text-field-member .text-field-input-container .text-field-input:-webkit-autofill:focus, .text-field-member .text-field-input-container .text-field-input:-webkit-autofill:active {
      -webkit-box-shadow: 0 0 0 30px #ffffff inset !important;
      -webkit-text-fill-color: #212529 !important;
      background-color: #ffffff !important;
      border-color: #ced4da !important; }
    .text-field-member .text-field-input-container .text-field-input:-moz-autofill {
      background-color: #ffffff !important;
      color: #212529 !important; }
    .text-field-member .text-field-input-container .text-field-input.is-invalid {
      border-color: #dc3545; }
      .text-field-member .text-field-input-container .text-field-input.is-invalid:focus {
        border-color: #dc3545;
        box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25); }
    .text-field-member .text-field-input-container .text-field-input.no-spin-buttons::-webkit-outer-spin-button, .text-field-member .text-field-input-container .text-field-input.no-spin-buttons::-webkit-inner-spin-button {
      -webkit-appearance: none;
      margin: 0; }
    .text-field-member .text-field-input-container .text-field-input.no-spin-buttons[type="number"] {
      -moz-appearance: textfield;
      appearance: textfield; }
    .text-field-member .text-field-input-container .text-field-input.show-spin-buttons::-webkit-outer-spin-button, .text-field-member .text-field-input-container .text-field-input.show-spin-buttons::-webkit-inner-spin-button {
      -webkit-appearance: auto; }
    .text-field-member .text-field-input-container .text-field-input.has-icon {
      padding-left: 2.75rem; }
    .text-field-member .text-field-input-container .text-field-input.has-eye-icon {
      padding-right: 2.75rem; }
  .text-field-member .text-field-input-container .input-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1rem;
    height: 1rem;
    color: #6c757d;
    pointer-events: none;
    z-index: 2; }
  .text-field-member .text-field-input-container .eye-icon {
    position: absolute;
    right: 1rem;
    top: 35%;
    transform: translateY(-50%);
    width: 1rem;
    height: 1rem;
    color: #6c757d;
    cursor: pointer;
    z-index: 10; }
    .text-field-member .text-field-input-container .eye-icon:hover {
      color: #495057; }

@media (max-width: 768px) {
  .text-field-member .text-field-label {
    font-size: 0.8125rem; }
  .text-field-member .text-field-input {
    padding: 0.75rem;
    font-size: 1rem; }
  .text-field-member .input-icon,
  .text-field-member .eye-icon {
    width: 1.125rem;
    height: 1.125rem; } }

@media (max-width: 480px) {
  .text-field-member .text-field-input {
    padding: 0.625rem;
    font-size: 0.9375rem; } }

.text-field-member.dark-theme .text-field-label {
  color: #f9fafb; }

.text-field-member.dark-theme .text-field-input {
  background-color: #374151;
  border-color: #4b5563;
  color: #f9fafb; }
  .text-field-member.dark-theme .text-field-input:focus {
    border-color: #60a5fa;
    box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.1); }
  .text-field-member.dark-theme .text-field-input::placeholder {
    color: #9ca3af; }

.text-field-member.dark-theme .input-icon,
.text-field-member.dark-theme .eye-icon {
  color: #9ca3af; }
  .text-field-member.dark-theme .input-icon:hover,
  .text-field-member.dark-theme .eye-icon:hover {
    color: #f9fafb; }

.text-field-member.light-theme .text-field-label {
  color: #374151; }

.text-field-member.light-theme .text-field-input {
  background-color: #ffffff;
  border-color: #d1d5db;
  color: #020617; }

.text-field-error {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: #991b1b;
  text-align: center;
  display: block;
  width: 100%;
  background-color: #fee2e2;
  min-height: 24px;
  border-radius: 8px;
  padding: 5px; }

.password-checklist {
  font-size: 0.875rem;
  color: #6b7280;
  margin-top: 0.5rem; }
  .password-checklist .password-error {
    color: #dc2626;
    font-size: 0.875rem;
    margin-bottom: 0.5rem; }
  .password-checklist .password-symbol-error {
    color: #dc2626;
    font-size: 0.875rem;
    margin-bottom: 0.5rem;
    line-height: 1.4; }
  .password-checklist .password-requirements-title {
    margin-top: 0.25rem;
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: #374151; }
  .password-checklist .password-requirement-item {
    display: flex;
    align-items: center;
    margin-bottom: 0.25rem;
    font-size: 0.875rem;
    line-height: 1.4; }
    .password-checklist .password-requirement-item .requirement-icon {
      width: 1rem;
      height: 1rem;
      margin-right: 0.5rem;
      flex-shrink: 0; }
      .password-checklist .password-requirement-item .requirement-icon.valid {
        color: #22c55e; }
      .password-checklist .password-requirement-item .requirement-icon.invalid {
        color: #dc2626; }
    .password-checklist .password-requirement-item .requirement-text {
      color: #374151; }
      .password-checklist .password-requirement-item .requirement-text.valid {
        color: #16a34a; }
      .password-checklist .password-requirement-item .requirement-text.invalid {
        color: #dc2626; }
  .password-checklist.dark-theme {
    color: #9ca3af; }
    .password-checklist.dark-theme .password-requirements-title {
      color: #f9fafb; }
    .password-checklist.dark-theme .password-requirement-item .requirement-text {
      color: #d1d5db; }
      .password-checklist.dark-theme .password-requirement-item .requirement-text.valid {
        color: #22c55e; }
      .password-checklist.dark-theme .password-requirement-item .requirement-text.invalid {
        color: #f87171; }
  @media (max-width: 768px) {
    .password-checklist {
      font-size: 0.8125rem; }
      .password-checklist .password-requirement-item {
        font-size: 0.8125rem; }
        .password-checklist .password-requirement-item .requirement-icon {
          width: 0.875rem;
          height: 0.875rem;
          margin-right: 0.375rem; } }

.verify-otp-container {
  height: 100%;
  max-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 8px;
  justify-content: center;
  align-items: center;
  background-color: transparent;
  color: black; }
  .verify-otp-container.transparent {
    background-color: transparent; }
  .verify-otp-container .modal-close-button {
    position: absolute;
    top: 10px;
    right: 10px;
    background: none;
    border: none;
    font-size: 1.5rem;
    color: #6c757d;
    cursor: pointer; }
    .verify-otp-container .modal-close-button:hover {
      color: #495057; }
  .verify-otp-container .otp-content {
    background: transparent;
    width: 100%;
    margin: 0 auto;
    padding: 0.5rem;
    border-radius: 0.5rem; }
    @media (min-width: 640px) {
      .verify-otp-container .otp-content {
        padding: 2rem; } }
  .verify-otp-container .otp-title {
    text-align: center;
    font-size: 1.25rem;
    font-weight: bold !important;
    margin-bottom: 1rem; }
    @media (min-width: 640px) {
      .verify-otp-container .otp-title {
        font-size: 1.5rem; } }
  .verify-otp-container .otp-description {
    text-align: center;
    margin-bottom: 0.5rem; }
    .verify-otp-container .otp-description .sent-to-text {
      font-size: 15px;
      font-weight: normal;
      line-height: 22px;
      text-align: center;
      color: #616161; }
      @media (min-width: 640px) {
        .verify-otp-container .otp-description .sent-to-text {
          font-size: 16px;
          line-height: 24px; } }
    .verify-otp-container .otp-description .email-highlight {
      color: #1D1B52;
      font-weight: 700; }
  .verify-otp-container .reference-code {
    margin-top: 0.75rem;
    font-size: 15px;
    font-weight: normal;
    line-height: 22px;
    text-align: center;
    color: #9CA3AF; }
    @media (min-width: 640px) {
      .verify-otp-container .reference-code {
        font-size: 16px;
        line-height: 24px; } }
  .verify-otp-container .otp-input-container {
    width: 100%;
    margin: 0 auto; }
    .verify-otp-container .otp-input-container .loading-container {
      display: flex;
      align-items: center;
      justify-content: center; }
    .verify-otp-container .otp-input-container .otp-inputs {
      padding: 0.5rem;
      display: flex;
      justify-content: center;
      gap: 0.5rem; }
  .verify-otp-container .pincode-input-text {
    font-weight: bold !important;
    border-radius: 0.25rem !important;
    width: 38px !important;
    height: 48px !important;
    font-size: 18px !important;
    box-shadow: rgba(0, 0, 0, 0.05) 0px 1px 2px 0px !important;
    border: 1px solid #E5E7EB !important;
    text-align: center; }
    @media (min-width: 640px) {
      .verify-otp-container .pincode-input-text {
        width: 44px !important;
        height: 58px !important;
        font-size: 20px !important; } }
    .verify-otp-container .pincode-input-text:focus {
      border-color: #0EA5E9 !important;
      outline: none;
      box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.1) !important; }
    .verify-otp-container .pincode-input-text:disabled {
      background-color: #f9fafb;
      cursor: not-allowed; }
  .verify-otp-container .error-message {
    text-align: center;
    font-size: 15px;
    font-weight: normal;
    line-height: 22px;
    margin-bottom: 1rem;
    color: #dc3545; }
    @media (min-width: 640px) {
      .verify-otp-container .error-message {
        font-size: 16px;
        line-height: 24px; } }
  .verify-otp-container .countdown-container {
    margin-bottom: 0;
    font-size: 15px;
    font-weight: normal;
    line-height: 22px;
    text-align: center; }
    @media (min-width: 640px) {
      .verify-otp-container .countdown-container {
        font-size: 16px;
        line-height: 24px; } }
    .verify-otp-container .countdown-container .expire-text {
      color: #9CA3AF;
      margin-right: 0.25rem; }
    .verify-otp-container .countdown-container .countdown-time {
      color: #212121;
      font-weight: 700; }
  .verify-otp-container .resend-container {
    width: 100%;
    font-size: 15px;
    font-weight: normal;
    line-height: 22px;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin-top: 0.5rem;
    background: none;
    border: none;
    cursor: pointer; }
    @media (min-width: 640px) {
      .verify-otp-container .resend-container {
        font-size: 16px;
        line-height: 24px; } }
    .verify-otp-container .resend-container:disabled {
      cursor: not-allowed;
      opacity: 0.6; }
    .verify-otp-container .resend-container .didnt-receive-text {
      color: #9CA3AF;
      margin-right: 0.75rem; }
    .verify-otp-container .resend-container .resend-link {
      color: #212121;
      display: flex;
      align-items: center;
      justify-content: center;
      text-decoration: none; }
      .verify-otp-container .resend-container .resend-link:hover {
        color: #212121;
        text-decoration: none; }
      .verify-otp-container .resend-container .resend-link .resend-icon {
        margin-right: 0.25rem; }

@keyframes spin {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(360deg); } }

.animate-spin {
  animation: spin 1s linear infinite; }

.opacity-50 {
  opacity: 0.5; }

.opacity-75 {
  opacity: 0.75; }

.toast-member.toast-success {
  padding: 1rem !important;
  background-color: #ccfbf1 !important;
  color: #115e59 !important;
  box-shadow: none !important;
  border: none !important;
  border-top: 2px solid #14b8a6 !important;
  border-radius: 20px !important;
  font-size: 1.125rem !important;
  font-weight: 500 !important; }
  .toast-member.toast-success .swal2-icon {
    border: none !important; }

.toast-member.toast-warning {
  padding: 1rem !important;
  background-color: #fef9c3 !important;
  color: #854d0e !important;
  box-shadow: none !important;
  border: none !important;
  border-top: 2px solid #fef08a !important;
  border-radius: 20px !important;
  font-size: 1.125rem !important;
  font-weight: 500 !important; }
  .toast-member.toast-warning .swal2-icon {
    border: none !important; }

.toast-member.toast-error {
  padding: 1rem !important;
  background-color: #fee2e2 !important;
  color: #991b1b !important;
  box-shadow: none !important;
  border: none !important;
  border-top: 2px solid #ef4444 !important;
  border-radius: 20px !important;
  font-size: 1.125rem !important;
  font-weight: 500 !important; }
  .toast-member.toast-error .swal2-icon {
    border: none !important; }

.toast-member.toast-info {
  padding: 1rem !important;
  background-color: #dbeafe !important;
  color: #1e40af !important;
  box-shadow: none !important;
  border: none !important;
  border-top: 2px solid #3b82f6 !important;
  border-radius: 20px !important;
  font-size: 1.125rem !important;
  font-weight: 500 !important; }
  .toast-member.toast-info .swal2-icon {
    border: none !important; }

.toast-container {
  z-index: 9999 !important;
  margin-right: 20px !important;
  width: fit-content !important; }

.toast-container-modern {
  z-index: 9999 !important;
  margin-right: 20px !important;
  margin-top: 20px !important; }

.toast-modern-popup {
  border-radius: 16px !important;
  border: 1px solid rgba(16, 185, 129, 0.2) !important;
  width: auto !important;
  padding: 10px 30px !important; }
  .toast-modern-popup .swal2-html-container {
    margin: 0 !important;
    padding: 0 !important; }
  .toast-modern-popup .swal2-title {
    margin: 0 !important;
    padding: 0 !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    text-align: start !important;
    padding-left: 10px !important; }

.toast-modern-icon {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  width: auto !important;
  height: auto !important; }
  .toast-modern-icon .swal2-icon-content {
    display: flex !important;
    align-items: center !important;
    font-size: 24px !important; }

.toast-container-member {
  z-index: 9999 !important; }
  .toast-container-member .custom-toast {
    min-width: 250px;
    max-width: 400px;
    font-size: 1rem;
    font-weight: 500;
    border-radius: 12px;
    border: none;
    margin-bottom: 0.5rem;
    opacity: 1;
    transform: translateX(0);
    transition: all 0.3s ease; }
    .toast-container-member .custom-toast.fade {
      opacity: 0;
      transform: translateX(100%); }
    .toast-container-member .custom-toast.toast-success {
      background: linear-gradient(135deg, #ccfbf1 0%, #a7f3d0 100%);
      color: #115e59;
      border-left: 4px solid #14b8a6; }
      .toast-container-member .custom-toast.toast-success .toast-header {
        background-color: transparent;
        border-bottom: none;
        color: #115e59;
        font-weight: 600; }
      .toast-container-member .custom-toast.toast-success .btn-close {
        filter: invert(0.3) sepia(1) saturate(5) hue-rotate(180deg); }
    .toast-container-member .custom-toast.toast-warning {
      background: linear-gradient(135deg, #fef9c3 0%, #fde68a 100%);
      color: #854d0e;
      border-left: 4px solid #f59e0b; }
      .toast-container-member .custom-toast.toast-warning .toast-header {
        background-color: transparent;
        border-bottom: none;
        color: #854d0e;
        font-weight: 600; }
      .toast-container-member .custom-toast.toast-warning .btn-close {
        filter: invert(0.5) sepia(1) saturate(5) hue-rotate(25deg); }
    .toast-container-member .custom-toast.toast-error {
      background: linear-gradient(135deg, #fee2e2 0%, #fca5a5 100%);
      color: #991b1b;
      border-left: 4px solid #ef4444; }
      .toast-container-member .custom-toast.toast-error .toast-header {
        background-color: transparent;
        border-bottom: none;
        color: #991b1b;
        font-weight: 600; }
      .toast-container-member .custom-toast.toast-error .btn-close {
        filter: invert(0.2) sepia(1) saturate(5) hue-rotate(0deg); }
    .toast-container-member .custom-toast.toast-info {
      background: linear-gradient(135deg, #dbeafe 0%, #93c5fd 100%);
      color: #1e40af;
      border-left: 4px solid #3b82f6; }
      .toast-container-member .custom-toast.toast-info .toast-header {
        background-color: transparent;
        border-bottom: none;
        color: #1e40af;
        font-weight: 600; }
      .toast-container-member .custom-toast.toast-info .btn-close {
        filter: invert(0.3) sepia(1) saturate(5) hue-rotate(220deg); }
    .toast-container-member .custom-toast .toast-body {
      padding: 0.75rem 1rem;
      font-size: 0.875rem; }
    .toast-container-member .custom-toast .btn-close {
      font-size: 0.75rem;
      opacity: 0.7; }
      .toast-container-member .custom-toast .btn-close:hover {
        opacity: 1; }

/* Edit Profile Styles */
.edit-profile-form {
  padding: 20px;
  margin-top: 20px; }

.edit-profile-form .form-label {
  color: #1f2937;
  margin-bottom: 8px; }

.edit-profile-form .form-control {
  padding: 12px 16px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  font-size: 16px;
  transition: border-color 0.2s ease-in-out; }

.edit-profile-form .form-control:focus {
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
  outline: none; }

.edit-profile-form .form-control.is-invalid {
  border-color: #ef4444; }

.edit-profile-form .invalid-feedback {
  display: block;
  font-size: 14px;
  color: #ef4444;
  margin-top: 4px; }

.edit-profile-form .btn {
  padding: 12px 24px;
  border-radius: 8px;
  font-weight: 600;
  transition: all 0.2s ease-in-out; }

.edit-profile-form .btn-primary {
  background-color: #3b82f6;
  border-color: #3b82f6;
  color: white; }

.edit-profile-form .btn-primary:hover:not(:disabled) {
  background-color: #2563eb;
  border-color: #2563eb; }

.edit-profile-form .btn-outline-secondary {
  border-color: #6b7280;
  color: #6b7280; }

.edit-profile-form .btn-outline-secondary:hover:not(:disabled) {
  background-color: #6b7280;
  border-color: #6b7280;
  color: white; }

.edit-profile-form .btn:disabled {
  opacity: 0.6;
  cursor: not-allowed; }

.edit-profile-form .btn-link {
  color: #3b82f6;
  text-decoration: none; }

.edit-profile-form .btn-link:hover {
  color: #2563eb;
  text-decoration: underline; }

/* Responsive adjustments */
@media (max-width: 768px) {
  .edit-profile-form {
    padding: 15px;
    margin-top: 15px; }
  .edit-profile-form .d-flex.gap-3 {
    flex-direction: column; }
  .edit-profile-form .btn {
    width: 100%;
    margin-bottom: 10px; } }

.dropdown-field-member {
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem; }
  .dropdown-field-member .dropdown-field-label {
    margin-bottom: 6px;
    display: block;
    font-size: 1rem;
    line-height: 1.5;
    color: #212529; }
    .dropdown-field-member .dropdown-field-label .required-asterisk {
      color: #dc2626;
      margin-left: 2px; }
  .dropdown-field-member .dropdown-field-description {
    margin: 0 0 8px 0;
    color: #6b7280;
    font-size: 12px;
    line-height: 1.4; }
  .dropdown-field-member .dropdown-field-select-container {
    position: relative;
    display: flex;
    align-items: center; }
    .dropdown-field-member .dropdown-field-select-container .dropdown-field-icon {
      position: absolute;
      right: 12px;
      top: 50%;
      transform: translateY(-50%);
      color: #6b7280;
      pointer-events: none;
      z-index: 1;
      width: 16px;
      height: 16px; }
    .dropdown-field-member .dropdown-field-select-container .dropdown-field-select {
      width: 100%;
      height: 40px;
      padding: 8px 32px 8px 12px;
      border: 1px solid #d1d5db;
      border-radius: 8px;
      font-size: 14px;
      color: #374151;
      background-color: white;
      transition: all 0.2s ease;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      background-image: none;
      line-height: 1.5; }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select::placeholder {
        color: #9ca3af; }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select.has-placeholder {
        color: #9ca3af; }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select:focus {
        outline: none;
        border-color: #2563eb;
        box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1); }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select:hover:not(:disabled) {
        border-color: #9ca3af; }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select:disabled {
        background-color: #f3f4f6;
        color: #6b7280;
        cursor: not-allowed;
        border-color: #d1d5db; }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select.is-invalid {
        border-color: #dc2626; }
        .dropdown-field-member .dropdown-field-select-container .dropdown-field-select.is-invalid:focus {
          border-color: #dc2626;
          box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1); }
      .dropdown-field-member .dropdown-field-select-container .dropdown-field-select option {
        padding: 8px 12px;
        color: #374151;
        background-color: white; }
        .dropdown-field-member .dropdown-field-select-container .dropdown-field-select option:disabled {
          color: #9ca3af;
          font-style: italic; }
        .dropdown-field-member .dropdown-field-select-container .dropdown-field-select option:hover {
          background-color: #f3f4f6; }
        .dropdown-field-member .dropdown-field-select-container .dropdown-field-select option:selected {
          background-color: #2563eb;
          color: white; }
        .dropdown-field-member .dropdown-field-select-container .dropdown-field-select option:first-child {
          color: #9ca3af; }
  .dropdown-field-member .dropdown-field-error {
    color: #dc2626;
    font-size: 12px;
    margin-top: 4px;
    display: block;
    font-weight: 400; }

@media (max-width: 768px) {
  .dropdown-field-member .dropdown-field-select-container .dropdown-field-select {
    font-size: 16px;
    height: 44px; }
  .dropdown-field-member .dropdown-field-select-container .dropdown-field-icon {
    right: 16px;
    width: 18px;
    height: 18px; } }

.dropdown-field-member .dropdown-field-select-container .dropdown-field-select:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px; }

@media (hover: none) and (pointer: coarse) {
  .dropdown-field-member .dropdown-field-select-container .dropdown-field-select {
    min-height: 44px; } }

body:has(.landing__template--two) {
  background-color: #000000; }

.register-form-context-container {
  font-family: "Prompt"; }

.border-black {
  border: 1px solid black; }

.border-rounded-10-px {
  border-radius: 10px; }

.bordered-bottom-text-input {
  border-bottom: 1px solid #efeded;
  border-top: 0px;
  border-left: 0px;
  border-right: 0px;
  flex-grow: 0;
  min-width: 0px; }
  .bordered-bottom-text-input:focus {
    box-shadow: none !important;
    outline: none;
    border-bottom: 1px solid black; }
  .bordered-bottom-text-input.invalid {
    border-bottom: 1px solid #b70909 !important; }

.input-label {
  font-size: 18px;
  line-height: 18px;
  font-weight: 400; }

.country-select__control,
.timezone-select__control {
  border-radius: 50rem !important;
  border: 1px solid #e2e2e2 !important; }

.default-input {
  border-radius: 50rem;
  border: 1px solid #e2e2e2; }

textarea.default-input {
  border-radius: 0.25rem !important; }

.default-input-label {
  font-weight: 400;
  font-size: 17px;
  line-height: 26px; }

/* Customize the label (the container) */
.radio-container {
  display: flex;
  align-items: center;
  min-height: 25px;
  position: relative;
  padding-left: 35px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

/* Hide the browser's default radio button */
.radio-container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0; }

/* Create a custom radio button */
.radio-checkMark {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  background-color: #fff;
  border-radius: 50%;
  border: 1px solid black;
  display: flex;
  justify-content: center;
  align-items: center; }

.radio-container:hover input ~ .radio-checkMark {
  background-color: #fff; }

.radio-container input:checked ~ .radio-checkMark {
  background-color: white; }

.radio-checkMark:after {
  content: "";
  position: absolute;
  display: none; }

.radio-container input:checked ~ .radio-checkMark:after {
  display: block; }

.radio-container .radio-checkMark:after {
  width: 70%;
  height: 70%;
  border-radius: 50%;
  background: black; }

.invalid-field {
  border: 1px solid #b70909 !important; }
  .invalid-field .country-select__control,
  .invalid-field .timezone-select__control {
    border: 1px solid #b70909 !important; }

.focus-invalid {
  scroll-margin-top: 110px; }

.question-label-container > .fr-view > p {
  margin-bottom: 0px; }

.object-fit-contain {
  object-fit: contain; }

.question-image {
  object-fit: contain;
  height: auto;
  max-height: 50vh;
  width: 50%;
  max-width: 100%; }

.question-video {
  object-fit: contain;
  height: auto;
  max-height: 50vh;
  width: 100%; }

.answer-image {
  object-fit: contain;
  height: auto;
  width: 100%; }

.question-image-container {
  display: flex;
  justify-content: center; }

.cursor-pointer {
  cursor: pointer; }

.avatar-upload {
  position: relative;
  max-width: 205px; }
  .avatar-upload .avatar-preview {
    width: 192px;
    height: 192px;
    position: relative;
    border-radius: 100%;
    border: 6px solid #f8f8f8;
    box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1);
    overflow: hidden; }

.avatar-edit-button {
  border-radius: 50%;
  width: 30px;
  height: 30px;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  position: absolute;
  right: 36px;
  z-index: 1;
  bottom: 8px; }

.avatar-delete-button {
  border-radius: 50%;
  width: 30px;
  height: 30px;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  position: absolute;
  right: 36px;
  z-index: 1;
  top: 8px; }

.avatar-preview-img {
  width: 46px;
  height: 46px;
  object-fit: cover;
  border-radius: 50%; }

.profile-picker #video {
  border: none;
  border-radius: 8px;
  width: 100%;
  height: 100%; }

.profile-picker #photo {
  border: 1px solid black;
  width: 320px;
  height: 240px; }

.profile-picker #canvas {
  display: none; }

.profile-picker .camera {
  display: inline-block;
  width: 100%;
  height: 100%; }

.profile-picker .output {
  width: 340px;
  display: inline-block; }

.profile-picker #startbutton {
  display: block;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  bottom: 36px;
  padding: 5px;
  background-color: #6a67ce;
  border: 1px solid rgba(255, 255, 255, 0.7);
  font-size: 14px;
  color: white;
  cursor: pointer; }

.profile-picker .shutter-button {
  background-color: black;
  border-radius: 8px;
  color: white !important; }

.profile-picker .contentarea {
  max-width: 960px;
  max-height: 720px;
  min-width: 320px;
  min-height: 240px;
  position: relative; }

.crop-img-profile-container {
  border-radius: 8px; }
  .crop-img-profile-container #cropping-img-profile {
    object-fit: contain;
    width: 100%;
    max-width: 560px;
    max-height: 56vh; }
  .crop-img-profile-container .crop-button {
    background-color: black;
    border-radius: 8px;
    color: white; }

.crop-slider-container {
  /*progress support*/
  /*webkit*/
  /*mozilla*/
  /*ms*/ }
  .crop-slider-container input[type="range"].crop-slider {
    height: 29px;
    -webkit-appearance: none; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress {
    --range: calc(var(--max) - var(--min));
    --ratio: calc((var(--value) - var(--min)) / var(--range));
    --sx: calc(0.5 * 18px + var(--ratio) * (100% - 18px)); }
  .crop-slider-container input[type="range"].crop-slider:focus {
    outline: none; }
  .crop-slider-container input[type="range"].crop-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 16px;
    background: #ffffff;
    border: none;
    box-shadow: 1px 2px 4px #00000085;
    margin-top: -5px; }
  .crop-slider-container input[type="range"].crop-slider::-webkit-slider-runnable-track {
    height: 10px;
    border: 1px solid #b2b2b2;
    border-radius: 0.5em;
    background: #efefef;
    box-shadow: none; }
  .crop-slider-container input[type="range"].crop-slider::-webkit-slider-thumb:hover {
    background: #ffffff; }
  .crop-slider-container input[type="range"].crop-slider:hover::-webkit-slider-runnable-track {
    background: #e5e5e5;
    border-color: #9a9a9a; }
  .crop-slider-container input[type="range"].crop-slider::-webkit-slider-thumb:active {
    background: #ffffff; }
  .crop-slider-container input[type="range"].crop-slider:active::-webkit-slider-runnable-track {
    background: #f5f5f5;
    border-color: #c1c1c1; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress::-webkit-slider-runnable-track {
    background: linear-gradient(#000000, #000000) 0/var(--sx) 100% no-repeat, #efefef; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress:hover::-webkit-slider-runnable-track {
    background: linear-gradient(#000000, #000000) 0/var(--sx) 100% no-repeat, #e5e5e5; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress:active::-webkit-slider-runnable-track {
    background: linear-gradient(#000000, #000000) 0/var(--sx) 100% no-repeat, #f5f5f5; }
  .crop-slider-container input[type="range"].crop-slider::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 16px;
    background: #ffffff;
    border: none;
    box-shadow: 1px 2px 4px #00000085; }
  .crop-slider-container input[type="range"].crop-slider::-moz-range-track {
    height: 8px;
    border: 1px solid #b2b2b2;
    border-radius: 0.5em;
    background: #efefef;
    box-shadow: none; }
  .crop-slider-container input[type="range"].crop-slider::-moz-range-thumb:hover {
    background: #ffffff; }
  .crop-slider-container input[type="range"].crop-slider:hover::-moz-range-track {
    background: #e5e5e5;
    border-color: #9a9a9a; }
  .crop-slider-container input[type="range"].crop-slider::-moz-range-thumb:active {
    background: #ffffff; }
  .crop-slider-container input[type="range"].crop-slider:active::-moz-range-track {
    background: #f5f5f5;
    border-color: #c1c1c1; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress::-moz-range-track {
    background: linear-gradient(#000000, #000000) 0/var(--sx) 100% no-repeat, #efefef; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress:hover::-moz-range-track {
    background: linear-gradient(#000000, #000000) 0/var(--sx) 100% no-repeat, #e5e5e5; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress:active::-moz-range-track {
    background: linear-gradient(#000000, #000000) 0/var(--sx) 100% no-repeat, #f5f5f5; }
  .crop-slider-container input[type="range"].crop-slider::-ms-fill-upper {
    background: transparent;
    border-color: transparent; }
  .crop-slider-container input[type="range"].crop-slider::-ms-fill-lower {
    background: transparent;
    border-color: transparent; }
  .crop-slider-container input[type="range"].crop-slider::-ms-thumb {
    width: 18px;
    height: 18px;
    border-radius: 16px;
    background: #ffffff;
    border: none;
    box-shadow: 1px 2px 4px #00000085;
    margin-top: 0;
    box-sizing: border-box; }
  .crop-slider-container input[type="range"].crop-slider::-ms-track {
    height: 10px;
    border-radius: 0.5em;
    background: #efefef;
    border: 1px solid #b2b2b2;
    box-shadow: none;
    box-sizing: border-box; }
  .crop-slider-container input[type="range"].crop-slider::-ms-thumb:hover {
    background: #ffffff; }
  .crop-slider-container input[type="range"].crop-slider:hover::-ms-track {
    background: #e5e5e5;
    border-color: #9a9a9a; }
  .crop-slider-container input[type="range"].crop-slider::-ms-thumb:active {
    background: #ffffff; }
  .crop-slider-container input[type="range"].crop-slider:active::-ms-track {
    background: #f5f5f5;
    border-color: #c1c1c1; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress::-ms-fill-lower {
    height: 8px;
    border-radius: 0.5em 0 0 0.5em;
    margin: -1px 0 -1px -1px;
    background: #000000;
    border: 1px solid #b2b2b2;
    border-right-width: 0; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress:hover::-ms-fill-lower {
    background: #000000;
    border-color: #9a9a9a; }
  .crop-slider-container input[type="range"].crop-slider.slider-progress:active::-ms-fill-lower {
    background: #000000;
    border-color: #c1c1c1; }

.file-upload-area {
  display: flex;
  min-width: 300px;
  max-width: 400px;
  height: 221px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  background-color: #e6e7f1;
  background-image: url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='6' ry='6' stroke='DarkSlateBlue' stroke-width='4' stroke-dasharray='4%2c 14' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e");
  border-radius: 6px;
  position: relative; }
  @media (max-width: 800px) {
    .file-upload-area {
      min-width: 380px; } }
  @media (max-width: 1100px) {
    .file-upload-area {
      min-width: 330px; } }
  @media (max-width: 600px) {
    .file-upload-area {
      min-width: 200px; } }

.file-upload-area-connex {
  display: flex;
  min-width: 400px;
  max-width: 400px;
  height: 221px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  background-color: #e6e7f1;
  background-image: url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='6' ry='6' stroke='DarkSlateBlue' stroke-width='4' stroke-dasharray='4%2c 14' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e");
  border-radius: 6px;
  position: relative; }
  @media (max-width: 800px) {
    .file-upload-area-connex {
      min-width: 380px; } }
  @media (max-width: 1100px) {
    .file-upload-area-connex {
      min-width: 330px; } }
  @media (max-width: 600px) {
    .file-upload-area-connex {
      min-width: 0px; } }

.single-file-upload-preview {
  display: flex;
  width: 400px;
  height: 221px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  border-radius: 6px;
  border: 1px dashed black;
  background: #e6e7f1;
  position: relative;
  overflow: hidden; }
  @media (max-width: 600px) {
    .single-file-upload-preview {
      width: 100%; } }

.single-file-upload-preview-connex {
  display: flex;
  width: 400px;
  height: 221px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  border-radius: 6px;
  border: 1px dashed black;
  background: #e6e7f1;
  position: relative;
  overflow: hidden; }
  @media (max-width: 600px) {
    .single-file-upload-preview-connex {
      width: auto; } }

.file-upload-button {
  color: white !important;
  background-color: black !important;
  border-radius: 8px !important; }

.delete-selected-file-button {
  border-radius: 8px; }

.choose-file-option-button {
  border: 2px solid white;
  background-color: white;
  color: black;
  border-radius: 8px;
  padding: 6px 8px;
  display: flex;
  align-items: center; }
  .choose-file-option-button:hover {
    border: 2px solid black; }

.btn-pagination {
  padding: 8px 32px 8px 32px;
  border-radius: 6px;
  gap: 10px; }

.input-promo-code.border-w {
  border-width: 2px; }
  .input-promo-code.border-w:focus {
    border-bottom: 2px solid black; }

.input-promo-code {
  border: 1px solid #efeded;
  flex-grow: 0;
  min-width: 0px;
  border-radius: 5px; }
  .input-promo-code:focus {
    box-shadow: none !important;
    outline: none;
    border-bottom: 1px solid black; }
  .input-promo-code.invalid {
    border-bottom: 1px solid #b70909 !important; }

.input-emt-promo-code {
  border: 1px solid #000000;
  flex-grow: 0;
  min-width: 0px;
  border-radius: 5px;
  background-color: #fafafa; }
  .input-emt-promo-code:focus {
    box-shadow: 1px 1px black !important;
    outline: none;
    border-bottom: 1px solid black; }
  .input-emt-promo-code.invalid {
    border-bottom: 1px solid #b70909 !important; }

.text-decoration-link {
  text-decoration: underline;
  text-decoration-color: red; }

.text-primary-connex {
  color: #3ab6fa; }

.text-decoration-connex {
  text-decoration: underline;
  text-decoration-color: #3ab6fa; }

.bg-bander {
  filter: blur(10px) brightness(55%);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 110%;
  height: 110%;
  margin: -15px; }

.container-bg-banner {
  overflow: hidden;
  position: absolute;
  left: 0px;
  top: 0px;
  right: 0px;
  bottom: 0px; }

.hr-custom {
  border-top: 1px solid #f6fafa; }

.bg-screen {
  background-position: center;
  background-attachment: fixed;
  min-height: 100vh; }

.cart-fixed {
  right: 15vw;
  position: fixed;
  z-index: 999; }
  @media (max-width: 988.98px) {
    .cart-fixed {
      position: relative;
      right: 0vw;
      margin-top: 10px; } }

@media (max-width: 988.98px) {
  .contain-mx-auto {
    margin-left: auto;
    margin-right: auto; } }

@media (max-width: 767.98px) {
  .hide-size-mobile {
    display: none; } }

@media (max-width: 767.98px) {
  .cart-size-mobile {
    padding: 0px !important;
    margin-top: 10px;
    height: auto;
    border: 1px solid #e2e2e2;
    background-color: white;
    box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.25);
    border-radius: 8px;
    max-height: none !important; }
    .cart-size-mobile .ticket-cart-container {
      max-height: none !important; } }

.show-size-mobile {
  display: none; }
  @media (max-width: 767.98px) {
    .show-size-mobile {
      display: flex; } }

.cart-sticky {
  margin: 0;
  position: -webkit-sticky;
  position: sticky;
  top: 7vh;
  width: 100%;
  z-index: 9999;
  padding-left: 10vw;
  padding-right: 10vw; }

.position-relative {
  position: relative; }

.cart-sticky-new {
  background-color: black;
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  display: block; }

.contain-cart-sticky {
  position: absolute;
  top: 0px;
  right: 0px;
  display: block;
  justify-content: end; }

.radio-small-checkMark {
  position: absolute;
  top: 10;
  left: 10px;
  height: 15px;
  width: 15px;
  background-color: #fff;
  border-radius: 50%;
  border: 1px solid black;
  display: flex;
  justify-content: center;
  align-items: center; }

.radio-container:hover input ~ .radio-small-checkMark {
  background-color: #fff; }

.radio-container input:checked ~ .radio-small-checkMark {
  background-color: white; }

.radio-small-checkMark:after {
  content: "";
  position: absolute;
  display: none; }

.radio-container input:checked ~ .radio-small-checkMark:after {
  display: block; }

.radio-container .radio-small-checkMark:after {
  width: 70%;
  height: 70%;
  border-radius: 50%;
  background: black; }

.radio-flex {
  flex-wrap: nowrap !important; }

.font-error-bill {
  font-size: 16px; }

.input-num-hide-arr input::-webkit-outer-spin-button,
.input-num-hide-arr input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0; }

/* Firefox */
input[type="number"] {
  -moz-appearance: textfield; }

.btn-disable {
  padding: 8px 32px 8px 32px;
  border-radius: 6px;
  background: transparent !important;
  color: #a7aeb8 !important; }

.icon-disable {
  color: #a7aeb8 !important; }

.btn__dialog--confirm {
  background: #4c5398 !important;
  color: white; }

.btn__dialog--confirm:hover {
  color: white;
  opacity: 0.8; }

.icon-size {
  font-size: 40px; }

.container__radio {
  display: flex;
  align-items: center;
  min-height: 25px;
  position: relative;
  padding-left: 35px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

.container__radio input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0; }

.container__radio input ~ .radio-checkMark {
  border-color: #e5e7eb; }

.container__radio input:checked ~ .radio-checkMark {
  background-color: #3b82f6;
  border-color: #3b82f6; }

.container__radio input:checked ~ .radio-checkMark:after {
  display: block;
  border-color: #3b82f6; }

.container__radio .radio-checkMark:after {
  width: 50%;
  height: 50%;
  border-radius: 50%;
  background: #fff; }

.container__radio:hover input ~ .radio-small-checkMark {
  background-color: #3b82f6;
  border-color: #3b82f6; }

.container__radio input:checked ~ .radio-small-checkMark {
  background-color: #3b82f6;
  border-color: #3b82f6; }

.container__radio input:checked ~ .radio-small-checkMark:after {
  display: block;
  border-color: #3b82f6; }

.container__radio .radio-small-checkMark:after {
  width: 50%;
  height: 50%;
  border-radius: 50%;
  background: #fff; }

.not--allowed {
  pointer-events: auto !important;
  cursor: not-allowed !important; }

.border-event-red {
  border: 1px solid red; }

.border__language {
  border: 2px solid #4c5398;
  border-radius: 10px; }

.bg-emt-screen {
  background-position: center;
  background-attachment: fixed;
  min-height: 100vh;
  background-position: center;
  /* Center the image */
  background-repeat: no-repeat;
  /* Do not repeat the image */
  background-size: cover;
  overflow: auto; }

.p__language {
  padding: 6px; }

.btn__to--upload {
  width: 237px; }

.rounded--register {
  border-radius: 8px; }

.border--corder {
  color: #1c1c1c; }

.no-select-chevron {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none; }

.dialog--title {
  color: #4c5398; }

.dialog__btn--width {
  width: 154px;
  max-height: 48px; }

.dialog__title--fail {
  margin-top: -1.5rem; }

.checkbox--styled input {
  width: 20px;
  height: 20px; }

.checkbox--styled #checkbox-to-print:checked {
  accent-color: #4c5398; }

.fw-700 {
  font-weight: 700; }

.fs-24 {
  font-size: 24px; }

.fs-16 {
  font-size: 16px; }

.fs-12 {
  font-size: 12px; }

.fs-20 {
  font-size: 20px; }

.font-bold {
  font-weight: bold; }

.font-semi-bold {
  font-weight: Semi Bold; }

.padding--payment {
  padding: 28px 40px !important; }
  @media (max-width: 600px) {
    .padding--payment {
      padding: 1rem !important; } }

.padding--payment__bottom {
  padding-bottom: 28px !important; }

.text--insight {
  color: #4c5398; }

.border--upload {
  border-radius: 6px;
  border: 1px solid #ced4da; }
  .border--upload .width--70 {
    width: 80%; }

.width--200 {
  min-width: 200px !important; }

.hover--form {
  background-color: none;
  border-radius: 8px;
  transition: all 0.4s ease-out;
  z-index: 999; }

.hover--form:hover {
  background-color: #f4f6ff; }

.hover--form.active {
  background-color: #f4f6ff !important; }

.btn--apply {
  color: #1c1c1c !important;
  border-color: #1c1c1c !important; }

.btn--apply:hover {
  color: #fff !important; }

.bordered-text-input {
  border: 1px solid #ced4da !important;
  flex-grow: 0;
  min-width: 0px;
  border-radius: 0.25rem;
  padding: 0.375rem 0.75rem;
  line-height: 1.5;
  font-size: 1rem; }
  .bordered-text-input:focus {
    box-shadow: none !important;
    outline: none;
    border: 1px solid #ced4da !important; }
  .bordered-text-input.invalid {
    border-bottom: 1px solid #b70909 !important; }

.container__loading--70 {
  width: 70%; }
  @media (max-width: 1100px) {
    .container__loading--70 {
      width: 90%; } }
  @media (max-width: 600px) {
    .container__loading--70 {
      width: 100%; } }

.btn__buy--more {
  width: 25%;
  min-width: 190px; }

.font__size--ticket {
  font-size: 18px;
  font-weight: 700; }
  @media (max-width: 900px) {
    .font__size--ticket {
      font-size: 16px; } }
  @media (max-width: 600px) {
    .font__size--ticket {
      font-size: 14px; } }

.form--select__ticket {
  border-radius: 6px;
  background-color: #f4f6ff;
  padding: 10px 30px;
  margin: 0 24px; }
  @media (max-width: 600px) {
    .form--select__ticket {
      padding: 10px;
      margin: 0 16px; } }

.ellipsis--insight {
  width: 100%;
  overflow: hidden;
  display: inline-block;
  text-overflow: ellipsis;
  white-space: nowrap; }

.width--25 {
  width: 25%; }
  @media (max-width: 600px) {
    .width--25 {
      min-width: 140px; } }

.width__buy--ticket {
  width: 25%; }
  @media (max-width: 600px) {
    .width__buy--ticket {
      min-width: 200px; } }

@media (max-width: 600px) {
  .width--total__responsive {
    min-width: 60px; } }

.invalid-field-address .css-13cymwt-control {
  border-color: #B70909 !important; }

.form-control .form-control-border {
  border: 1px solid #d1d3e2; }

.w-fit-content {
  width: fit-content !important; }

.text-12px {
  font-size: 12px !important; }

.qr-code-img {
  width: 100%;
  padding: 0px;
  object-fit: contain; }

.connex-text-blue {
  color: #01619e !important; }

.pdpa-checkbox-connex {
  width: 24px;
  height: 24px;
  border-radius: 4px;
  border: 2px solid #B6B6B6; }

.contain-complete-online {
  padding-top: 2rem;
  width: 100%;
  z-index: 999; }

.img-complete-contain {
  z-index: 5;
  border-radius: 36px;
  max-height: 50vh;
  min-height: 40vh;
  box-shadow: rgba(0, 0, 0, 0.25) 0px 1px 4px 0px;
  margin-top: 2rem; }
  @media (max-width: 1100px) {
    .img-complete-contain {
      width: 100%;
      height: 100% !important;
      min-height: 0vh !important; } }

.img-upload-slip-contain {
  z-index: 5;
  border-radius: 15px;
  max-height: 20vh;
  min-height: 15vh;
  box-shadow: rgba(0, 0, 0, 0.25) 0px 1px 4px 0px; }
  @media (max-width: 1100px) {
    .img-upload-slip-contain {
      max-height: 30vh;
      min-height: 35vh;
      border-radius: 15px;
      width: 80%;
      object-fit: cover; } }

.font-item {
  word-break: break-word !important; }

.container-sig {
  height: 250px;
  width: 100% !important; }

.canvas-sig {
  width: 100% !important; }

.hcaptcha-modal {
  width: auto; }

.register-success-container {
  border-radius: 8px;
  background-color: #f6fff5;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin-bottom: 16px; }

.register-success-item {
  background-color: #FBFBFB;
  border-radius: 8px;
  padding: 20px;
  padding-left: 30px;
  padding-right: 30px;
  margin-bottom: 16px;
  width: 100%; }

.container-sig {
  height: 250px;
  width: 100% !important; }

.canvas-sig {
  width: 100% !important; }

.hcaptcha-modal {
  width: auto; }

.fix-max-height-tooltip {
  max-height: 200px !important;
  overflow-y: auto; }

.grid-container {
  display: grid;
  grid-template-columns: auto auto;
  /* สองคอลัมน์ที่ปรับกว้างอัตโนมัติ */
  gap: 1rem;
  /* ระยะห่างระหว่างคอลัมน์ */ }

.grid-item {
  padding: 10px;
  border: 1px solid #ccc; }

.hide-scrollbar {
  overflow-x: scroll;
  -ms-overflow-style: none;
  /* IE and Edge */
  scrollbar-width: none;
  /* Firefox */ }
  .hide-scrollbar::-webkit-scrollbar {
    display: none;
    /* Chrome, Safari, Opera */ }

@media (max-width: 768px) {
  .fig-hide-mobile {
    display: none !important; } }

@media (min-width: 768px) {
  .fig-hide-desktop {
    display: none !important; } }

.dynamic-grid-payment-type {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.5rem; }

/* สำหรับ 1-3 items ให้อยู่บรรทัดเดียวกัน */
.dynamic-grid-payment-type:has(> :nth-child(1):last-child) {
  grid-template-columns: 1fr; }

.dynamic-grid-payment-type:has(> :nth-child(2):last-child) {
  grid-template-columns: repeat(2, 1fr); }

.dynamic-grid-payment-type:has(> :nth-child(3):last-child) {
  grid-template-columns: repeat(3, 1fr); }

/* สำหรับ 4 items เฉพาะ */
.dynamic-grid-payment-type:has(> :nth-child(4):last-child) {
  grid-template-columns: repeat(2, 1fr); }

/* Mobile: แสดง item แยกบรรทัด */
@media (max-width: 767.98px) {
  .dynamic-grid-payment-type {
    grid-template-columns: 1fr !important;
    gap: 0.75rem; }
  /* Override กฎของ 4 items สำหรับ mobile */
  .dynamic-grid-payment-type:has(> :nth-child(4):last-child) {
    grid-template-columns: 1fr !important; } }

/* Tablet และ Desktop */
@media (min-width: 768px) {
  .dynamic-grid-payment-type {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.5rem; }
  .dynamic-grid-payment-type:has(> :nth-child(4):last-child) {
    grid-template-columns: repeat(2, 1fr); } }

