
    :root {
      --pink: #f36fa2;
      --pink-dark: #cf4079;
      --mint: #9ee5dc;
      --yellow: #ffd66b;
      --green: #6fb26c;
      --cream: #fff8ef;
      --brown: #5c3d2e;
      --ink: #302630;
      --muted: #71636d;
      --white: #ffffff;
      --shadow: 0 24px 70px rgba(48, 38, 48, .16);
    }

    * {
      box-sizing: border-box;
    }

    html {
      width: 100%;
      max-width: 100%;
      overflow-x: hidden;
      scroll-behavior: smooth;
    }

    body {
      width: 100%;
      max-width: 100%;
      overflow-x: hidden;
      margin: 0;
      font-family: "Nunito", sans-serif;
      color: var(--ink);
      background: var(--cream);
    }

    h1, h2, h3, .brand {
      font-family: "Baloo 2", cursive;
    }

    .navbar {
      background: rgba(255, 248, 239, .92);
      backdrop-filter: blur(14px);
      border-bottom: 1px solid rgba(92, 61, 46, .08);
    }

    .brand {
      font-size: 1.65rem;
      font-weight: 800;
      color: var(--pink-dark);
      text-decoration: none;
      line-height: 1;
    }

    .brand small {
      display: block;
      font-family: "Nunito", sans-serif;
      font-size: .72rem;
      color: var(--muted);
      font-weight: 900;
      margin-top: 4px;
    }

    .nav-link {
      font-weight: 800;
      color: var(--brown);
    }

    .nav-link:hover {
      color: var(--pink-dark);
    }


    .hero {
      min-height: auto !important;
      padding-top: 150px !important;
      padding-bottom: 60px !important;
    }

    .hero {
      min-height: 92vh;
      display: flex;
      align-items: center;
      background:
        radial-gradient(circle at 12% 20%, rgba(158, 229, 220, .55), transparent 30%),
        radial-gradient(circle at 88% 18%, rgba(255, 213, 230, .78), transparent 32%),
        linear-gradient(90deg, #eefbf6 0%, #fff8ef 48%, #ffeaf2 100%);
    }

    .badge-soft {
      display: inline-flex;
      align-items: center;
      gap: .45rem;
      padding: .55rem .9rem;
      border-radius: 999px;
      background: var(--white);
      color: var(--pink-dark);
      font-weight: 900;
      box-shadow: 0 12px 30px rgba(48, 38, 48, .10);
    }

    .hero h1 {
      max-width: 760px;
      margin: 18px 0;
      font-size: clamp(2.8rem, 6vw, 5.7rem);
      line-height: .92;
      font-weight: 800;
      color: var(--brown);
    }

    .hero h1 span {
      color: var(--pink-dark);
    }

    .hero p {
      max-width: 680px;
      font-size: 1.22rem;
      color: var(--muted);
      font-weight: 700;
      line-height: 1.6;
    }

    .hero-panel {
      background: rgba(255, 255, 255, .9);
      border: 1px solid rgba(92, 61, 46, .08);
      border-radius: 28px;
      padding: 24px;
      box-shadow: var(--shadow);
    }

    .hero-card {
      min-height: 390px;
      border-radius: 24px;
      padding: 24px;
      background:
        radial-gradient(circle at 20% 18%, var(--mint) 0 11%, transparent 12%),
        radial-gradient(circle at 86% 20%, #ffd5e6 0 12%, transparent 13%),
        linear-gradient(145deg, #fff, #fff0f6);
      position: relative;
      overflow: hidden;
    }

    .hero-icons {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      margin-bottom: 22px;
    }

    .hero-icon {
      width: 68px;
      height: 68px;
      display: grid;
      place-items: center;
      border-radius: 22px;
      background: var(--white);
      color: var(--pink-dark);
      font-size: 2rem;
      box-shadow: 0 12px 28px rgba(48, 38, 48, .10);
    }

    .hero-card strong {
      display: block;
      font-family: "Baloo 2", cursive;
      font-size: 2rem;
      color: var(--brown);
      line-height: 1;
    }

    .btn-main,
    .btn-soft {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: .5rem;
      min-height: 54px;
      padding: .85rem 1.25rem;
      border-radius: 999px;
      font-weight: 900;
      text-decoration: none;
      transition: .2s ease;
    }

    .btn-main {
      border: 0;
      background: var(--pink);
      color: var(--white);
      box-shadow: 0 16px 34px rgba(243, 111, 162, .34);
    }

    .btn-main:hover {
      background: var(--pink-dark);
      color: var(--white);
      transform: translateY(-2px);
    }

    .btn-soft {
      background: var(--white);
      color: var(--pink-dark);
      border: 1px solid rgba(207, 64, 121, .18);
    }

    .btn-soft:hover {
      background: #fff1f7;
      color: var(--pink-dark);
      transform: translateY(-2px);
    }

    section {
      padding: 82px 0;
    }

    .section-title {
      max-width: 760px;
      margin: 0 auto 34px;
      text-align: center;
    }

    .section-title h2 {
      font-size: clamp(2.2rem, 4vw, 3.5rem);
      color: var(--brown);
      font-weight: 800;
    }

    .section-title p {
      color: var(--muted);
      font-size: 1.08rem;
      font-weight: 700;
      line-height: 1.6;
    }

    .course-card {
      height: 100%;
      padding: 26px;
      border-radius: 8px;
      background: var(--white);
      border: 1px solid rgba(92, 61, 46, .08);
      box-shadow: 0 18px 50px rgba(48, 38, 48, .08);
    }

    .icon-box {
      width: 54px;
      height: 54px;
      display: grid;
      place-items: center;
      border-radius: 16px;
      background: #fff1f7;
      color: var(--pink-dark);
      font-size: 1.6rem;
      margin-bottom: 18px;
    }

    .course-card h3 {
      font-size: 1.6rem;
      color: var(--brown);
      font-weight: 800;
    }

    .course-card p {
      color: var(--muted);
      font-weight: 700;
      margin-bottom: 0;
      line-height: 1.55;
    }

    .status {
      display: inline-flex;
      align-items: center;
      gap: .35rem;
      margin-top: 18px;
      padding: .42rem .7rem;
      border-radius: 999px;
      background: #e7fbf7;
      color: #32756d;
      font-weight: 900;
      font-size: .88rem;
    }

    .steps {
      background: #ffffff;
    }

    .step {
      display: flex;
      gap: 16px;
      padding: 22px;
      border-radius: 8px;
      border: 1px solid rgba(92, 61, 46, .08);
      background: #fffaf4;
      height: 100%;
    }

    .step-number {
      flex: 0 0 auto;
      width: 44px;
      height: 44px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      background: var(--mint);
      color: var(--brown);
      font-weight: 900;
    }

    .step h3 {
      font-size: 1.35rem;
      color: var(--brown);
      font-weight: 800;
      margin-bottom: 6px;
    }

    .step p {
      color: var(--muted);
      font-weight: 700;
      margin-bottom: 0;
      line-height: 1.45;
    }

    .product-band {
      background:
        linear-gradient(135deg, rgba(158, 229, 220, .34), rgba(255, 214, 107, .28)),
        #fff8ef;
    }

    .product-pill {
      display: flex;
      align-items: center;
      gap: .65rem;
      padding: 15px 18px;
      border-radius: 999px;
      background: var(--white);
      color: var(--brown);
      font-weight: 900;
      border: 1px solid rgba(92, 61, 46, .08);
      box-shadow: 0 12px 28px rgba(48, 38, 48, .07);
    }

    .cta {
      background: var(--brown);
      color: var(--white);
    }

    .cta h2 {
      color: var(--white);
      font-size: clamp(2.1rem, 4vw, 3.4rem);
      font-weight: 800;
    }

    .cta p {
      color: rgba(255, 255, 255, .78);
      font-weight: 700;
    }

    footer {
      padding: 30px 0;
      background: #2a201d;
      color: rgba(255, 255, 255, .72);
      font-weight: 700;
    }

    @media (max-width: 991px) {
      .hero {
        padding-top: 120px;
      }

      .hero-panel {
        margin-top: 28px;
      }
    }

    @media (max-width: 575px) {
      .hero {
        min-height: auto;
        padding: 100px 0 56px;
      }

      .hero h1 {
        font-size: clamp(2.35rem, 12vw, 3.4rem);
        line-height: .95;
      }

      .hero p {
        font-size: 1.05rem;
      }

      .badge-soft {
        max-width: 100%;
        white-space: normal;
      }

      .btn-main,
      .btn-soft {
        width: 100%;
        max-width: 100%;
      }

      .hero-panel {
        padding: 16px;
        border-radius: 22px;
      }

      .hero-card {
        min-height: auto;
        padding: 20px;
        border-radius: 20px;
      }

      .hero-icon {
        width: 60px;
        height: 60px;
        font-size: 1.75rem;
      }

      .hero-card strong {
        font-size: 1.65rem;
      }

      .text-center.bg-white.rounded-3.p-3 {
        padding: .75rem .45rem !important;
        font-size: .88rem;
      }

      section {
        padding: 64px 0;
      }

      .section-title h2 {
        font-size: 2.15rem;
      }
    }


    footer {
      padding: 46px 0 24px;
      background: #2a201d;
      color: rgba(255, 255, 255, .72);
      font-weight: 700;
    }

    .footer-brand {
      margin-bottom: 10px;
      font-size: 1.85rem;
      color: var(--white);
      font-weight: 800;
    }

    footer h4 {
      margin-bottom: 12px;
      color: var(--white);
      font-size: 1.1rem;
      font-weight: 900;
    }

    footer p {
      max-width: 390px;
      margin-bottom: 0;
      line-height: 1.6;
    }

    .footer-links {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 8px;
    }

    .footer-links a {
      color: rgba(255, 255, 255, .72);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: .45rem;
    }

    .footer-links a:hover {
      color: var(--white);
    }

    .footer-bottom {
      margin-top: 34px;
      padding-top: 18px;
      border-top: 1px solid rgba(255, 255, 255, .12);
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      gap: 10px;
      color: rgba(255, 255, 255, .52);
    }


.extra-course {
  transition: opacity .35s ease, transform .35s ease;
}

.extra-course.d-none {
  display: none !important;
}

.extra-course.course-enter {
  opacity: 0;
  transform: translateY(14px);
}

.extra-course.course-visible {
  opacity: 1;
  transform: translateY(0);
}

.brand-logo {
  width: 220px;
  height: auto;
  display: block;
}