.elementor-389 .elementor-element.elementor-element-5af2c4a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-389 .elementor-element.elementor-element-5af2c4a:not(.elementor-motion-effects-element-type-background), .elementor-389 .elementor-element.elementor-element-5af2c4a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#4C91FF;}.elementor-389 .elementor-element.elementor-element-fa3f9b5{width:100%;max-width:100%;}.elementor-389 .elementor-element.elementor-element-b98f043{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-389 .elementor-element.elementor-element-9c5cae0{--display:flex;--min-height:264px;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;}.elementor-389 .elementor-element.elementor-element-9c5cae0:not(.elementor-motion-effects-element-type-background), .elementor-389 .elementor-element.elementor-element-9c5cae0 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-389 .elementor-element.elementor-element-676c5f0{--display:flex;--min-height:0px;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--border-radius:26px 26px 26px 26px;--margin-top:18px;--margin-bottom:18px;--margin-left:18px;--margin-right:18px;}.elementor-389 .elementor-element.elementor-element-676c5f0:not(.elementor-motion-effects-element-type-background), .elementor-389 .elementor-element.elementor-element-676c5f0 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#E1F4FF;}.elementor-389 .elementor-element.elementor-element-4e9415a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--border-radius:41px 41px 41px 41px;--margin-top:15px;--margin-bottom:15px;--margin-left:15px;--margin-right:15px;}.elementor-389 .elementor-element.elementor-element-4e9415a:not(.elementor-motion-effects-element-type-background), .elementor-389 .elementor-element.elementor-element-4e9415a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFCFC;}.elementor-widget-fluent-form-widget .fluentform-widget-description{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-size:var( --e-global-typography-accent-font-size );font-weight:var( --e-global-typography-accent-font-weight );text-transform:var( --e-global-typography-accent-text-transform );font-style:var( --e-global-typography-accent-font-style );text-decoration:var( --e-global-typography-accent-text-decoration );line-height:var( --e-global-typography-accent-line-height );letter-spacing:var( --e-global-typography-accent-letter-spacing );word-spacing:var( --e-global-typography-accent-word-spacing );}.elementor-389 .elementor-element.elementor-element-18a7e75 .fluentform-widget-wrapper{background-color:#E1F4FF;border-radius:17px 17px 17px 17px;}.elementor-389 .elementor-element.elementor-element-18a7e75 > .elementor-widget-container{margin:0px 0px 5px 0px;}.elementor-389 .elementor-element.elementor-element-18a7e75 .fluentform-widget-wrapper .ff-el-group .ff-btn-submit{background-color:#1a7efb !important;color:#ffffff !important;}.elementor-389 .elementor-element.elementor-element-4e9ef18{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}@media(min-width:768px){.elementor-389 .elementor-element.elementor-element-9c5cae0{--content-width:1238px;}.elementor-389 .elementor-element.elementor-element-676c5f0{--width:52%;}.elementor-389 .elementor-element.elementor-element-4e9415a{--width:50%;}}@media(max-width:1024px){.elementor-widget-fluent-form-widget .fluentform-widget-description{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );letter-spacing:var( --e-global-typography-accent-letter-spacing );word-spacing:var( --e-global-typography-accent-word-spacing );}}@media(max-width:767px){.elementor-widget-fluent-form-widget .fluentform-widget-description{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );letter-spacing:var( --e-global-typography-accent-letter-spacing );word-spacing:var( --e-global-typography-accent-word-spacing );}}/* Start custom CSS for html, class: .elementor-element-fa3f9b5 */.topik-desktop {/* ============================================================
   ETOPIK — FULL CSS CLEAN VERSION (COPY 1 LẦN LÀ CHẠY)
   ============================================================ */

/* ----------------------------------------------
   1) WRAPPER
------------------------------------------------ */
.topik-wrap {
    max-width: 1150px;
    margin: 20px auto;
    padding: 30px;
    font-family: "montserrat", sans-serif;
    background: linear-gradient(to bottom, #0b63e6, #0a52c4);
    color: #fff;
    border-radius: 18px;
}

/* ----------------------------------------------
   2) HEADER TEXT
------------------------------------------------ */
.header h2 {
    margin: 0 0 14px;
    font-size: 36px;
    font-weight: 900;
}
.header p {
    margin: 0 0 18px;
    font-size: 17px;
    color: #e0e9ff;
}

/* ----------------------------------------------
   3) SELECTOR – 2 CỘT SONG SONG
------------------------------------------------ */
..elementor-389 .elementor-element.elementor-element-fa3f9b5-grid {
    display: flex;
    gap: 26px;
    justify-content: center;
    align-items: stretch;
    flex-wrap: nowrap !important;   /* ép luôn 2 cột song song */
}

..elementor-389 .elementor-element.elementor-element-fa3f9b5-grid .col {
    flex: 1 1 50%;
    min-width: 320px;
}

.col .title {
    background: rgba(255,255,255,0.10);
    padding: 12px;
    text-align: center;
    border-radius: 12px;
    font-weight: 800;
    margin-bottom: 12px;
}

/* OPTION BUTTONS */
.btn-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.option {
    background: #082a63;
    color: #fff;
    padding: 15px 18px;
    border-radius: 999px;
    text-align: center;
    font-weight: 800;
    border: 2px solid rgba(255,255,255,0.08);
    transition: .2s;
    cursor: pointer;
    font-size: 20px;
}
.option:hover { transform: translateY(-3px); }

.option.active {
    background: #fff;
    color: #0A2140;
}

.option.disabled {
    opacity: 0.35;
    pointer-events: none;
}

@media(max-width: 768px){
    ..elementor-389 .elementor-element.elementor-element-fa3f9b5-grid {
        flex-direction: column !important;
    }
    .option { font-size: 17px; }
}

/* ----------------------------------------------
   4) RESULT CARD
------------------------------------------------ */
.result-card {
    margin-top: 22px;
    padding: 18px;
    background: rgba(255,255,255,0.1);
    border-radius: 16px;
}

.path-title {
    font-size: 28px;
    font-weight: 900;
    text-align: center;
    margin-bottom: 6px;
}

.path-desc {
    text-align: center;
    color: #deebff;
    font-size: 18px;
    margin: 0 auto 12px;
    max-width: 780px;
}

/* ----------------------------------------------
   5) PRICE SECTION – 3 CỘT BẰNG NHAU
------------------------------------------------ */
.topik-desktop .price-row {
    display: flex !important;
    justify-content: center !important;
    align-items: stretch !important;
    gap: 22px !important;
    flex-wrap: nowrap !important;
}

.price-card {
    flex: 1 1 0 !important;
    max-width: 33.333% !important;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 20px;
    padding: 24px 26px;
    border: 1px solid rgba(10,33,64,0.08);
    box-shadow: 0 8px 26px rgba(10,33,64,0.09);

    display: flex;
    flex-direction: column;
    min-height: 100%;
}

/* Highlight PRO */
.price-card.highlight {
    border: 3px solid #FFD24D;
}

/* ----------------------------------------------
   6) TITLE + DESC + VALUES
------------------------------------------------ */
.price-title {
    font-size: 20px;
    font-weight: 900;
    color: #0A2140;
    margin-bottom: 6px;
    display: flex;
    gap: 8px;
    align-items: center;
}

.plan-sub-inline {
    background: #eaf1ff;
    padding: 3px 8px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 700;
}

.price-desc {
    color: #6b7280;
    font-size: 12px;
    margin-bottom: 12px;
}

.price-values {
    display: flex;
    gap: 1px;
    margin-bottom: 8px;
    align-items: center;
}

.price-old {
    text-decoration: line-through;
    color: #9aa0af;
}

.price-val {
    font-size: 18px !important;
    font-weight: 900;
    color: #0A2140;
}

.discount-tag {
    background: #ffdcae;
    padding: 4px 8px;
    border-radius: 8px;
    font-weight: 800;
    color: #0A2140;
}

/* ----------------------------------------------
   7) COUPON
------------------------------------------------ */
.coupon-row {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}

.coupon-row input {
    flex: 1;
    padding: 10px;
    border-radius: 12px;
    border: 1px solid #d9d9d9;
}

.coupon-row button {
    padding: 10px 14px;
    border-radius: 12px;
    background: #0A2140;
    color: #fff;
    border: none;
    font-weight: 700;
    cursor: pointer;
}

/* ----------------------------------------------
   8) ĐĂNG KÝ BUTTON
------------------------------------------------ */
.register-btn {
    margin-top: auto;
    background: #0b63e6;
    color: #fff;
    padding: 14px 0;
    border-radius: 12px;
    text-align: center;
    font-weight: 800;
    text-decoration: none;
}

/* ----------------------------------------------
   9) BENEFITS – CHỈ 1 BULLET ICON
------------------------------------------------ */
.benefits ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.benefits li {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
    color: #0A2140;
}

.benefits li::before {
    content: none !important; /* CHẶN BULLET MẶC ĐỊNH */
}
/* Thu nhỏ chữ mô tả quyền lợi */
.topik-desktop .benefits li {
    font-size: 14px !important;
    line-height: 1.45 !important;
}

.benefits .bullet {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #FFD24D;
    color: #0A2140;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    flex-shrink: 0;
    margin-top: 4px;
}

.benefits .bullet.gray {
    background: #e6e6e6;
    color: #9aa0ad;
}

/* ----------------------------------------------
   11) MOBILE – CỘT GIÁ XUỐNG 1 CỘT
------------------------------------------------ */
@media(max-width: 900px){
    .price-row {
        flex-direction: column !important;
    }
    .price-card {
        width: 100%;
    }
}
/* ===== WRAPPER 2 CỘT ===== */
.etopik-select {
    display: flex;
    justify-content: space-between;
    gap: 32px;
    margin: 30px auto;
}

/* ===== mỗi cột 50% ===== */
.select-col {
    flex: 1 1 50%;
}

/* ===== TIÊU ĐỀ ===== */
.select-title {
    text-align: center;
    font-weight: 800;
    background: rgba(255,255,255,0.12);
    padding: 12px 18px;
    border-radius: 14px;
    margin-bottom: 16px;
    font-size: 22px;
    color: #fff;
}

/* ===== DANH SÁCH ===== */
.select-options {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* ===== OPTION ===== */
.select-options .option {
    background: #092b63;
    color: #fff;
    padding: 16px 20px;
    border-radius: 999px;
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    cursor: pointer;
    border: 2px solid rgba(255,255,255,0.08);
    transition: .25s ease;
}

.select-options .option:hover {
    transform: translateY(-4px);
}

.select-options .option.active {
    background: #fff;
    color: #0A2140;
}

/* DISABLED */
.select-options .option.disabled {
    opacity: .35;
    pointer-events: none;
}

/* ===== MOBILE ===== */
@media (max-width: 768px) {
    .etopik-select {
        flex-direction: column;
    }
    .select-options .option {
        font-size: 16px;
        padding: 12px 16px;
    }
}

.price-card {
    flex: 1 !important; /* ép mỗi cột = nhau */
    width: auto !important;
}
#cardMonthly {
    flex: 1 !important;
    max-width: 100% !important;
}


.price-card {
    flex: 1 1 0 !important;
    max-width: 33.333% !important;
}
.extra-row {
    justify-content: center !important;
}

#testBtn {
    background: #FFD24D !important;
    color: #0A2140 !important;
    font-weight: 900 !important;
    border-radius: 30px;
    padding: 16px 28px;
    font-size: 20px;
}
.extra-row {
    text-align: center !important;
    width: 100%;
}
.extra-row .test-btn {
    display: inline-block;
}
.register-btn {
    margin-top: auto !important;
}
#cardSelf .coupon-row,
#cardTeacher .coupon-row {
    display: none !important;
}
.topik-desktop .own-tag {
    background: #fff8db;
    border-left: 5px solid #ffc933;
    padding: 6px 10px !important;   /* nhỏ như bạn muốn */
    border-radius: 10px;
    color: #0A2140;
    font-weight: 700;
    margin-bottom: 14px;
    display: inline-flex;
    align-items: center;
    font-size: 12px !important;
    line-height: 1.3 !important;
}
.topik-desktop #ownTimeBox,
.topik-desktop #ownTimeBoxPro,
.topik-desktop #valSelf,
.topik-desktop #valTeacher {
    display: inline-flex !important;
}

.topik-desktop #oldSelf,
.topik-desktop #oldTeacher,
.topik-desktop #tagSelf,
.topik-desktop #tagTeacher {
    display: inline-block !important;
}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-80ef910 *//* ================================
   WRAPPER
================================ */
.comic-wrap {
  max-width: 380px;
  margin: 0 auto;
  text-align: center;
  position: relative;
}


/* ================================
   BUBBLE CHÍNH
================================ */
.comic-bubble {
  background: #ffffff;
  border: 3px solid #000;
  padding: 24px 22px 30px;
  border-radius: 28px;
  font-size: 18px;
  line-height: 1.55;
  font-weight: 600;
  position: relative;
  display: inline-block;
  text-align: center;

  box-shadow: 8px 14px 0px #ffcedb; /* bóng hồng */
}

/* ĐUÔI BUBBLE */
.comic-bubble::after {
  content: "";
  position: absolute;
  bottom: -22px;
  left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 22px solid #ffffff;

  /* viền đen */
  filter: drop-shadow(0px 3px 0px #000);
}


/* ================================
   CTA — chữ hồng nhấp nháy
================================ */
.comic-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;

  background: #ffe3f0;
  padding: 10px 18px;
  border-radius: 16px;

  color: #ff2d81;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;

  animation: ctaBlink 1.3s infinite ease-in-out;
}

/* trái tim đập */
.comic-cta .heart {
  animation: heartBeat 1.1s infinite ease-in-out;
  display: inline-block;
}


/* ================================
   PERSON IMAGE
================================ */
.comic-person {
  width: 200px;
  margin-top: 40px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}


/* ================================
   ANIMATIONS
================================ */
@keyframes ctaBlink {
  0% { opacity: 1; }
  50% { opacity: 0.55; }
  100% { opacity: 1; }
}

@keyframes heartBeat {
  0%, 100% { transform: scale(1); }
  50%     { transform: scale(1.25); }
}/* End custom CSS */
/* Start custom CSS for fluent-form-widget, class: .elementor-element-18a7e75 *//* ===== KHỐI NỀN TRẮNG MỜ GỌN NGANG ===== */
.etopik-box-glass {
  max-width: 650px;                         /* giới hạn ngang gọn */
  margin: 0 auto 30px auto;                 /* căn giữa + tạo khoảng cách dưới */
  padding: 28px 32px;                       /* khoảng cách thoáng */
  
  background: rgba(255, 255, 255, 0.55);    /* trắng mờ */
  backdrop-filter: blur(12px);              /* hiệu ứng glass */
  -webkit-backdrop-filter: blur(12px);
  
  border-radius: 22px;                      /* bo cong xịn */
  border: 1px solid rgba(255, 255, 255, 0.7);

  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.08); /* bóng mềm */
}

/* ===== TIÊU ĐỀ ===== */
.etopik-title {
  color: #000000 !important;
  font-size: 23px !important;
  text-shadow: 
      0 2px 4px rgba(0,0,0,0.18);
  font-weight: 800;
  font-family: "Montserrat", sans-serif !important;
  text-align: center;
}
/* ===== SUB ===== */
.etopik-sub {
  font-size: 15px;
  line-height: 1.45;
  color: #333;
  opacity: 0.85;
  margin-bottom: 18px;
  text-align: left;
  text-align: center;
}

/* ===== CTA BUTTON NHẤP NHÁY ===== */
.etopik-cta-btn {
  display: inline-block;
  background: linear-gradient(90deg, #1875ff, #3a7bd5);
  padding: 10px 22px;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  border-radius: 14px;

  animation: etopikPulse 1.4s infinite ease-in-out;
  box-shadow: 0 4px 12px rgba(24, 117, 255, 0.28);
  transition: 0.2s;
}

.etopik-cta-btn:hover {
  transform: scale(1.06);
}

/* ===== ANIMATION ===== */
@keyframes etopikPulse {
  0%   { box-shadow: 0 0 0 rgba(24,117,255,0); }
  50%  { box-shadow: 0 0 18px rgba(24,117,255,0.55); }
  100% { box-shadow: 0 0 0 rgba(24,117,255,0); }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1866a78 *//* ==== FAQ WRAPPER ==== */
.etp-faq-wrapper {
    max-width: 880px;
    margin: 0 auto;
    padding: 20px;
    font-family: "Montserrat", sans-serif;
}

.etp-faq-title {
    text-align: center;
    font-size: px !important;
    color: #1875FF;
    font-weight: 800;
    margin-bottom: 25px;
}

/* ==== ITEM ==== */
.etp-faq-item {
    background: #ffffff;
    border-radius: 16px;
    padding: 18px 20px;
    margin-bottom: 15px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    border: 1px solid #d9e9ff;
    transition: 0.3s ease;
}

/* ==== QUESTION BAR ==== */
.etp-faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-size: 17px;
    font-weight: 600;
    color: #0c4cc9;
}

.etp-faq-icon {
    font-size: 24px;
    font-weight: 700;
    color: #0c4cc9;
    transition: 0.3s;
}

/* ==== ANSWER ==== */
.etp-faq-answer {
    font-size: 15px;
    line-height: 1.55;
    margin-top: 10px;
    display: none;
    color: #333;
}

/* ==== OPEN STATE ==== */
.etp-faq-item.active .etp-faq-answer {
    display: block;
}

.etp-faq-item.active .etp-faq-icon {
    transform: rotate(45deg);
}

/* ==== RESPONSIVE ==== */
@media(max-width: 768px) {
    .etp-faq-title {
        font-size: 22px;
    }

    .etp-faq-question {
        font-size: 15px;
    }

    .etp-faq-answer {
        font-size: 14px;
    }
}/* End custom CSS */