 .pricing-section {
            background: linear-gradient(179.37deg, #FFFFFF 24.09%, #957BFF 128.18%);
        }
        :root {
            --primary-color: #4F46E5;
            --dark-color: #111827;
            --gray-color: #6B7280;
            --light-gray-color: #F3F4F6;
            --green-color: #10B981;
            --teal-color: #2DD4BF;
            --purple-color: #8B5CF6;
        }
        body, button, input, select, textarea {
            font-family: 'Quicksand', sans-serif;
        }
        body {
            color: var(--dark-color);
        }

        .btn-primary {
            background: -webkit-linear-gradient(left, var(--primary-color), var(--purple-color));
            border-radius: 999px;
            border-color: -webkit-linear-gradient(left, var(--primary-color), var(--purple-color));
            padding: 12px 24px;
            font-weight: 600;
        }
        .btn-primary:hover {
            background-color: #4338CA;
            border-color: #4338CA;
        }
        .btn-outline-primary {
            padding: 12px 24px;
            font-weight: 600;
            border-radius: 999px;
            --bs-btn-color: var(--primary-color);
            --bs-btn-border-color: var(--primary-color);
            --bs-btn-hover-color: #fff;
            --bs-btn-hover-bg: var(--primary-color);
            --bs-btn-hover-border-color: var(--primary-color);
            --bs-btn-focus-shadow-rgb: 13, 110, 253;
            --bs-btn-active-color: #fff;
            --bs-btn-active-bg: var(--purple-color);
            --bs-btn-active-border-color: var(--primary-color);
            --bs-btn-active-shadow
            inset 0 3px 5px rgba(0, 0, 0, 0.125)
            : inset 0 3px 5px rgba(0, 0, 0, 0.125);
            --bs-btn-disabled-color: var(--primary-color);
            --bs-btn-disabled-bg: transparent;
            --bs-btn-disabled-border-color: var(--primary-color);
            --bs-gradient: none;
                }
        .nav-link {
            color: var(--dark-color);
            font-weight: 500;
        }
        .nav-link:hover,
        .nav-link:active {
            color: var(--primary-color);
            font-weight: 500;
        }
        .navbar .nav-link.active {
            color: var(--primary-color) !important;
            font-weight: 700;
        }
        [id] {
          scroll-margin-top: 87px;
        }
        .hero-section {
            padding: 80px 0;
            background-image: url('asset-graphic_hyperetail/bg_hero-section.png');
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
            scroll-margin-top: 40px;
        }
        .hero-section h1 {
            font-size: 3rem;
            font-weight: 700;
        }
        .hero-section p {
            color: var(--gray-color);
            font-size: 1.125rem;
            max-width: 600px;
            margin-left: 5px;
            margin-right: auto;
        }
        .section {
            padding: 80px 0;
            scroll-margin-top: 40px;
        }
        .section-title {
            font-size: 2.25rem;
            font-weight: 700;
        }
        .section-subtitle {
            color: var(--teal-color);
            font-weight: 600;
            margin-bottom: 0.5rem;
        }

        .feature-card h4 {
            font-size: 1.25rem;
            font-weight: 600;
        }
        .feature-card p {
            color: var(--gray-color);
        }

        .benefits-section {
            background-color: #F9FAFA;
        }
        .benefits-section .nav-pills .nav-link {
            color: var(--gray-color);
            background-color: white;
            margin: 0 5px;
            padding: 10px 20px;
            border-radius: 8px;
        }
        .benefits-section .nav-pills .nav-link.active {
            background-color: var(--primary-color);
            color: white;
        }
        .benefit-card {
            background: white;
            border-radius: 16px;
            padding: 2rem;
            height: 100%;
            border: 1px solid #E5E7EB;
            border-top-width: 4px;
        }
        .benefit-card.teal-border {
            border-top-color: var(--teal-color);
        }
        .benefit-card.purple-border {
            border-top-color: var(--purple-color);
        }

        .benefit-icon {
            height: 48px;
            width: 48px;
            object-fit: contain;
        }
        .benefit-card h5 {
            font-weight: 600;
        }
        .benefit-card ul {
            list-style-type: none;
            padding-left: 0;
        }
        .benefit-card ul li {
            display: flex;
            align-items: center;
            margin-bottom: 1rem;
            color: var(--gray-color);
        }
        .benefit-card ul li img {
            margin-right: 10px;
        }
        .value-prop-section {
            background: linear-gradient(180deg, #FFFFFF -31.57%, #F9FAFA 100%);
        }
        .value-prop-section p {
            font-size: 1.1rem;
        }
        .quote-card {
            background-color: #F8FAFC;
            border: 1px solid #E2E8F0;
            border-radius: 12px;
            padding: 1.5rem;
            margin-bottom: 1rem;
            box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
        }

        .quote-card p {
            position: relative;
            padding-left: 2rem;
        }

        .quote-card p::before {
            content: '❝';
            position: absolute;
            left: 0;
            top: 0;
            font-size: 1.5rem;
            color: var(--purple-color);
            line-height: 1;
        }
        .quote-card p::after {
            content: '❞';
            position: absolute;
            right: 0;
            bottom: 0;
            font-size: 1.5rem;
            color: var(--purple-color);
            line-height: 1;
        }
        .source-text {
            padding-left: 1rem;
            border-left: 3px solid var(--teal-color);
        }

        .pricing-section {
            background-color: #F5F3FF;
        }
        .pricing-card {
            background: white;
            border-radius: 16px;
            padding: 2rem;
            box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
        }
        .pricing-card ul {
            list-style: none;
            padding: 0;
        }
        .pricing-card ul li {
            margin-bottom: 1rem;
            display: flex;
            align-items: center;
        }
        .pricing-card ul li::before {
            content: '✔';
            color: var(--primary-color);
            margin-right: 10px;
            font-size: 1.2rem;
        }
        .pricing-card-main {
            background-color: #F8FAFC;
            border: 1px solid #E2E8F0;
            border-radius: 12px;
            padding: 2rem;
        }

        .pricing-card-main ul li img {
            width: 24px;
            height: 24px;
            object-fit: contain;
        }

        .pricing-card-main ul li {
            color: var(--gray-color);
        }
        .gradient-text {
            background: -webkit-linear-gradient(left, var(--teal-color), var(--purple-color));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
        }

        .gradient-btnnavbar {
            background: -webkit-linear-gradient(left, var(--purple-color), var(--primary-color));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
        }

        .cta-section {
            padding: 60px 0;
        }
        .footer {
            padding: 60px 0 30px;
            background-color: #F9FAFA;
        }
        .footer a {
            color: var(--gray-color);
            text-decoration: none;
        }
        .footer a:hover {
            color: var(--dark-color);
        }
        .footer h5 {
            font-size: 1rem;
            font-weight: 600;
            margin-bottom: 1rem;
        }
        .modal-content {
          border-radius: 12px;
          overflow: hidden;
        }
        .bottom-sheet {
          position: fixed;
          inset: 0;
          display: none;           /* hidden by default */
          z-index: 1050;
          pointer-events: none;    /* supaya tidak intercept scroll saat hidden */
        }
        .bottom-sheet.active {
          display: block;
          pointer-events: auto;
        }
        /* Overlay */
        .sheet-overlay {
          position: absolute;
          inset: 0;
          background: rgba(0, 0, 0, 0.4);
        }

        /* Sheet Container */
        .sheet-container {
          position: absolute;
          bottom: -100%; /* hidden position */
          left: 0;
          right: 0;
          background: #fff;
          border-radius: 16px 16px 0 0;
          padding: 20px;
          max-height: 80vh;
          overflow-y: auto;
          transition: bottom 0.3s ease-in-out;
        }

        .bottom-sheet.active .sheet-container {
          bottom: 0; /* slide up */
        }

        /* Close button */
        .sheet-header {
          display: flex;
          justify-content: flex-end;
          margin-bottom: 10px;
        }

        .btn-close-circle {
          background: transparent;
          border: 0;
          padding: 0;
          cursor: pointer;
          width: 1.5rem;   /* sama dengan btn-close bawaan */
          height: 1.5rem;
          display: inline-flex;
          align-items: center;
          justify-content: center;
        }
        .btn-close-circle i {
          font-size: 1.5rem;
          line-height: 1;
          color: var(--primary-color);
        }

        .btn-close-circle:focus {
          outline: none;
          box-shadow: none;
        }
        .responsive-margin{
            margin-right: 165px;
        }
        @media (max-width: 1024px) {
          .responsive-margin {
            margin-right: 65px;}
        }
        @media (max-width: 960px) {
          .cta-buttons {
            justify-content: center !important;
          }

        }
        @media (max-width: 1023.98px) {
          .bottom-sheet {
            display: none;
          }
          .hero .btn {
            margin-bottom: 0.75rem;
          }
        }
        @media (min-width: 1024px) {
          .bottom-sheet {
            display: none !important;
          }
        }