 body {
      background: #0b0b0b;
      color: #fff;
    }

    .section {
      padding: 70px 15px;
    }

    .container-narrow {
      max-width: 900px;
      margin: auto;
    }

    .card-dark {
      background: #111;
      border-radius: 18px;
      padding: 40px;
      border: 1px solid rgba(255,255,255,0.08);
    }

    .badge-yellow {
      background: #ffc107;
      color: #000;
      font-weight: 700;
      border-radius: 30px;
      padding: 6px 16px;
      font-size: 0.75rem;
    }

    h1, h2 {
      font-weight: 700;
    }

    .text-muted {
      color: #bbb !important;
    }

    /* SERVICES */
    .service-item {
      background: #141414;
      border-radius: 14px;
      padding: 20px;
      border: 1px solid rgba(255,255,255,0.08);
      height: 100%;
    }

    /* STEPS */
    .step {
      display: flex;
      gap: 15px;
      margin-bottom: 20px;
    }

    .step-number {
      width: 34px;
      height: 34px;
      background: #ffc107;
      color: #000;
      font-weight: 700;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    /* CTA */
    .cta-box {
      background: linear-gradient(135deg, #ffc107, #ffcd38);
      color: #000;
      border-radius: 20px;
      padding: 40px;
      text-align: center;
    }

    .cta-box a {
      background: #000;
      color: #fff;
      padding: 12px 30px;
      border-radius: 30px;
      font-weight: 700;
      text-decoration: none;
      display: inline-block;
      margin-top: 15px;
    }

    @media (max-width: 576px) {
      .card-dark {
        padding: 28px;
      }
    }
        /* INTRO HERO UPGRADE */
    .intro-hero {
      padding-top: 90px;
      padding-bottom: 70px;
    }

    .hero-title {
      font-size: clamp(1.8rem, 3vw, 2.6rem);
      font-weight: 800;
      letter-spacing: -0.5px;
    }

    .hero-subtext {
      font-size: 1.05rem;
      color: #ccc;
      max-width: 700px;
      margin: 0 auto;
    }

    .hero-subtext .highlight {
      color: #ffc107;
      font-weight: 600;
    }

    .hero-divider {
      width: 80px;
      height: 4px;
      background: #ffc107;
      border-radius: 10px;
      margin: 30px auto 0;
    }

    /* ABOUT CARD UPGRADE */
    .about-card {
      position: relative;
      padding: 45px;
      background:
        linear-gradient(180deg, rgba(255,193,7,0.05), transparent),
        #111;
    }

    .about-header {
      display: flex;
      align-items: center;
      gap: 14px;
    }

    .about-accent {
      width: 6px;
      height: 42px;
      background: #ffc107;
      border-radius: 4px;
    }

    /* RESPONSIVE TUNING */
    @media (max-width: 576px) {
      .intro-hero {
        padding-top: 70px;
        padding-bottom: 50px;
      }

      .about-card {
        padding: 30px;
      }

      .hero-divider {
        margin-top: 22px;
      }
    }
        /* LICENCE CTA SECTION */
    .licence-cta-section {
      padding-top: 40px;
      padding-bottom: 80px;
    }

    .licence-cta-box {
      background:
        linear-gradient(135deg, rgba(255,193,7,0.12), rgba(255,193,7,0.02)),
        #111;
      border-radius: 20px;
      padding: 55px 45px;
      text-align: center;
      border: 1px solid rgba(255,193,7,0.25);
    }

    .licence-cta-box h3 {
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
    }

    .cta-desc {
      color: #ccc;
      max-width: 620px;
      margin: 0 auto;
      font-size: 1rem;
      line-height: 1.7;
    }

    .licence-cta-btn {
      background: #ffc107;
      color: #000;
      font-weight: 700;
      padding: 14px 36px;
      border-radius: 40px;
      text-decoration: none;
      display: inline-block;
    }

    .licence-cta-btn:hover {
      background: #000;
      color: #ffc107;
      border: 2px solid #ffc107;
    }

    .cta-note {
      font-size: 0.85rem;
      color: #999;
    }

    /* MOBILE */
    @media (max-width: 576px) {
      .licence-cta-box {
        padding: 40px 25px;
      }
    }
    /* SERVICE CARDS */
    .service-card {
      background: #111;
      border-radius: 16px;
      padding: 28px;
      height: 100%;
      border: 1px solid rgba(255,193,7,0.18);
      transition: all 0.3s ease;
    }

    .service-card h5 {
      color: #ffc107;
      font-weight: 700;
      margin-bottom: 10px;
    }

    .service-card p {
      color: #bbb;
      font-size: 0.95rem;
      margin-bottom: 0;
    }

    .service-card:hover {
      transform: translateY(-6px);
      border-color: #ffc107;
    }

    /* PROCESS CARD */
    .process-card {
      padding: 45px;
      display: grid;
      gap: 26px;
    }

    /* PROCESS STEP */
    .process-step {
      display: flex;
      align-items: center;
      gap: 16px;
    }

    .step-circle {
      width: 42px;
      height: 42px;
      background: #ffc107;
      color: #000;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 800;
    }

    .process-step p {
      margin: 0;
      color: #ddd;
      font-size: 1rem;
    }

    /* MOBILE */
    @media (max-width: 576px) {
      .service-card {
        padding: 22px;
      }

      .process-card {
        padding: 30px;
      }
    }
    /* FINAL CTA */
    .final-cta-section {
      padding-bottom: 90px;
    }

    .final-cta-box {
      background:
        radial-gradient(circle at top, rgba(255,193,7,0.15), transparent 60%),
        #111;
      border-radius: 24px;
      padding: 60px 50px;
      text-align: center;
      border: 1px solid rgba(255,193,7,0.3);
    }

    .cta-badge {
      background: #ffc107;
      color: #000;
      font-weight: 700;
      padding: 6px 18px;
      border-radius: 20px;
      font-size: 0.8rem;
    }

    .final-cta-box h2 {
      font-size: clamp(1.6rem, 3vw, 2.2rem);
      font-weight: 800;
    }

    .cta-desc {
      color: #ccc;
      max-width: 650px;
      margin: 0 auto;
      font-size: 1.05rem;
      line-height: 1.7;
    }

    .final-cta-btn {
      background: #ffc107;
      color: #000;
      font-weight: 800;
      padding: 15px 42px;
      border-radius: 45px;
      text-decoration: none;
      display: inline-block;
      transition: all 0.3s ease;
    }

    .final-cta-btn:hover {
      background: #000;
      color: #ffc107;
      border: 2px solid #ffc107;
    }

    .cta-trust {
      font-size: 0.85rem;
      color: #999;
    }

    /* MOBILE */
    @media (max-width: 576px) {
      .final-cta-box {
        padding: 42px 26px;
      }
    }
    
    /* FOOTER */
    .site-footer {
      padding: 18px 12px;
      text-align: center;
      background: #0b0b0b;
      border-top: 1px solid rgba(255,255,255,0.08);
    }

    .site-footer p {
      margin: 0;
      font-size: 0.85rem;
      color: #aaa;
    }

    .site-footer a {
      color: #ffc107;
      font-weight: 600;
      text-decoration: none;
    }

    .site-footer a:hover {
      text-decoration: underline;
    }

    /* MOBILE */
    @media (max-width: 576px) {
      .site-footer p {
        font-size: 0.8rem;
        line-height: 1.5;
      }
    }
    body {
      background: #0b0b0b;
      color: #fff;
    }

    .portal-wrapper {
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 40px 15px;
    }

    .portal-form {
      background: #ffffff;
      color: #000;
      border-radius: 18px;
      max-width: 720px;
      width: 100%;
      padding: 35px;
      box-shadow: 0 25px 60px rgba(0,0,0,0.6);
      height: 135%;
    }

    .portal-form h2 {
      font-weight: 700;
      margin-bottom: 8px;
    }

    .portal-form p {
      color: #555;
      font-size: 0.95rem;
      margin-bottom: 25px;
    }

    .form-label {
      font-weight: 600;
      font-size: 0.9rem;
    }

    .form-control,
    .form-select {
      border-radius: 10px;
      padding: 10px 12px;
    }

    .submit-btn {
      background: #ffc107;
      color: #000;
      font-weight: 700;
      border-radius: 30px;
      padding: 12px;
      border: none;
    }

    .submit-btn:hover {
      background: #000;
      color: #fff;
    }

    .note-text {
      font-size: 0.8rem;
      color: #666;
    }

    .hidden {
      display: none;
    }

    @media (max-width: 576px) {
      .portal-form {
        padding: 25px;
        border-radius: 14px;
      }
    }

    /* SERVICE PRICE BOX */
    .service-price-box {
      background: #f8f9fa;
      border-radius: 14px;
      padding: 18px;
      border: 1px dashed #ddd;
    }
    
    /* FLIP CARD */
    .flip-container {
      perspective: 1200px;
      width: 100%;
      max-width: 720px;
      margin: 0 auto;
    }

    .flip-card {
      position: relative;
      min-height: 1000px;
      width: 100%;
      height: 100%;
      transition: transform 0.8s ease;
      transform-style: preserve-3d;
    }

    .flip-container.is-flipped .flip-card {
      transform: rotateY(180deg);
    }

    .flip-front,
    .flip-back {
      backface-visibility: hidden;
      position: absolute;
      width: 100%;
      height: 100%;
      top: 40px;
      left: 0;

      /* IMPORTANT */
      background: #ffffff;
      border-radius: 18px;
    }


    .flip-back {
      transform: rotateY(180deg);
    }
    
    /* Make sure portal-form has relative positioning */
    .portal-wrapper {
      position: relative;
      min-height: auto;
      padding: 0;
    }
    
    /* Fix for form display */
    .flip-container .portal-form {
      position: relative;
    }
    /* PAYMENT PANEL */
.payment-panel {
  min-height: 100%;
  padding: 45px 40px;
}

/* HEADER */
.payment-header h2 {
  font-size: 1.9rem;
}

/* QR */
.qr-box {
  width: 375px;
  height: 330px;
  border-radius: 20px;
  border: 2px solid #e6e6e6;
  background: #fafafa;
  display: flex;
  align-items: center;
  justify-content: center;
}

.qr-box img {
  width: 300px;
  max-width: 100%;
}

/* BANK DETAILS */
.bank-card {
  background: #f9f9f9;
  border-radius: 18px;
  padding: 26px;
  border: 1px solid #eee;
}

.bank-card .label {
  font-size: 0.8rem;
  font-weight: 700;
  color: #777;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.bank-card p {
  font-size: 1.05rem;
  margin: 2px 0 0;
  font-weight: 600;
}

/* INFO */
.payment-info {
  background: #fffbe6;
  border-radius: 14px;
  padding: 16px;
  border: 1px dashed #ffe58f;
}

/* BUTTONS */
.payment-actions .btn {
  border-radius: 40px;
}

/* MOBILE */
@media (max-width: 576px) {
  .payment-panel {
    padding: 32px 22px;
  }

  .qr-box {
    width: 200px;
    height: 200px;
  }

  .qr-box img {
    width: 290px;
  }

  .payment-header h2 {
    font-size: 1.5rem;
  }
}
.payment-steps {
  background: #f8f9fa;
  border-radius: 18px;
  padding: 22px;
  border: 1px solid #eee;
}

.payment-steps .step {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
}

.step-number {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #ffc107;
  color: #000;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
}

.payment-steps p {
  margin: 0;
  font-weight: 500;
}
.swal-dark-theme {
  border-radius: 14px;
  box-shadow: 0 10px 40px rgba(245, 197, 24, 0.25);
}

.swal-confirm-btn {
  font-weight: 600;
  padding: 10px 26px;
  border-radius: 8px;
  color: #000 !important;
}
