/* --- 變數與基礎設定 --- */
        :root {--primary-pureJ: #3d12ab;--secondary-pureJ: #784eef;--primary-blue: #004aad;--secondary-blue: #00c2ff;--bg-dark: #0a192f;--text-light: #f8fafc;--text-main: #334155;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-800: #1e293b;--slate-900: #0f172a;--blue-50: #eff6ff;--blue-600: #2563eb;--line-green: #44b83c;--report-purple: #3d12ab;}
        * { box-sizing: border-box;box-sizing: border-box;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;}
        html { /* Lenis 會處理 scroll-behavior */ }
        html.lenis { height: auto; }
        .lenis.lenis-smooth { scroll-behavior: auto; }
        .lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
        .lenis.lenis-stopped { overflow: hidden; }
        .lenis.lenis-scrolling iframe { pointer-events: none; }
        body { font-family: 'Noto Sans TC', sans-serif; background-color: #fff; color: var(--text-main); margin: 0; padding: 0; transition: overflow 0.3s ease; overflow-x: hidden; line-height: 1.5; }
		img{max-width:100%;}
        /* --- 通用工具類 (取代部分 Tailwind 功能) --- */
        .container {position: relative;width: 100%;margin-right: auto;margin-left: auto;padding-right: 1.5rem;padding-left: 1.5rem;z-index: 1;}
        @media (min-width: 768px) {
            .container { max-width: 768px; }
        }
        @media (min-width: 1024px) {
            .container { max-width: 1024px; }
        }
        @media (min-width: 1280px) {
            .container { max-width: 1280px; }
        }
        .max-w-7xl { max-width: 80rem; }

        /* --- 進場動畫類別 (Scroll Reveal) --- */
        .reveal-up {opacity: 1;transform: translateY(0px);transition: all 1s cubic-bezier(0.165, 0.84, 0.44, 1);}
        .reveal-up.is-visible { opacity: 1; transform: translateY(0); }
        .reveal-delay-100 { transition-delay: 0.1s; }
        .reveal-delay-200 { transition-delay: 0.2s; }
        .reveal-delay-300 { transition-delay: 0.3s; }
        .reveal-delay-400 { transition-delay: 0.4s; }

        .bg_JJimg{position:absolute;width: 100%;height: 100%;top: 0;overflow: hidden;}
	    .bg_JJimg img{height: 100%;width: 100%;object-fit: cover;object-position: 50% 20%;}
		.bg_JJimg:before{content:"";position: absolute;width: 100%;height: 100%;background: linear-gradient(to bottom, rgb(255 255 255 / 0%), rgb(248 250 252));}
		section{position:relative;}

        /* --- Header Styles --- */
        .l-header { position: fixed; top: 0; left: 0; width: 100%; z-index: 1100; transition: padding 0.6s cubic-bezier(0.22, 1, 0.36, 1), background 0.4s ease; background: transparent; padding: 40px 0; }
        .l-header.is-scrolled {background: #260e66;backdrop-filter: blur(20px);padding: 16px 0;box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05);border-bottom: #7a53de 1px solid;}
        .header-content { display: flex; justify-content: space-between; align-items: center; height: 100%; }
        .header-logo-group { display: flex; align-items: center; gap: 0.5rem; position: relative; z-index: 1100; cursor: pointer; }
        .header-logo-box { width: 2.5rem; height: 2.5rem; background-color: rgba(255, 255, 255, 0.1); backdrop-filter: blur(4px); border-radius: 0.5rem; display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1); transition: all 0.3s; border: 1px solid rgba(255, 255, 255, 0.2); }
        .header-logo-group:hover .header-logo-box { transform: scale(1.05); }
        .header-logo-icon { color: white; transition: color 0.3s; }
        .header-logo-text { font-size: 1.25rem; font-weight: 700; letter-spacing: 0.1em; color: white; transition: color 0.3s; padding-left: 0.5rem; }
        .header-right { display: flex; align-items: center; gap: 2rem; }
        .nav-desktop { display: flex; align-items: center; gap: 2rem; }
        .nav-link { position: relative; color: #fff; font-weight: 500; font-size: 0.9rem; letter-spacing: 0.05em; transition: opacity 0.3s ease; padding: 8px 0; text-decoration: none; }
        .nav-link:hover {color: #00c2ff;}
        .l-header.is-scrolled .nav-link {color: var(--slate-100);}
        .l-header.is-scrolled .nav-link:hover {color: #00c2ff;opacity: 1;}
		@media (max-width: 768px){
			.l-header{padding: 10px 0;}
			.l-header .looog-img{width: min(280px , 100%);}
		}
        /* --- Header CTA Button --- */
        .header-cta { padding: 10px 28px; background: #00c2ff; color: white; border-radius: 9999px; font-weight: 700; font-size: 0.875rem; letter-spacing: 0.05em; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1); box-shadow: 0 4px 15px rgba(0, 194, 255, 0.3); text-decoration: none; display: none; }
        @media (min-width: 768px) {
            .header-cta { display: inline-block; }
        }
        .l-header.is-scrolled .header-cta {background: #0babdd;box-shadow: 0 4px 15px rgba(0, 74, 173, 0.2);}
        .header-cta:hover { transform: scale(1.05); box-shadow: 0 6px 20px rgba(0, 194, 255, 0.4); }

        /* --- Burger Menu Styles --- */
        .c-hamburger { display: none; width: 44px; height: 44px; position: relative; z-index: 1100; cursor: pointer; border-radius: 50%; background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.15); transition: all 0.3s ease; }
        .l-header.is-scrolled .c-hamburger {background: transparent;border-color: rgb(255 255 255 / 65%);}
        .l-header.is-scrolled .c-hamburger.is-active span{}
        .c-hamburger span { display: block; width: 20px; height: 2px; background: #fff; position: absolute; left: 50%; transform: translateX(-50%); transition: 0.3s cubic-bezier(0.22, 1, 0.36, 1); }
        .l-header.is-scrolled .c-hamburger span {background: #ffffffba;}
        .c-hamburger span:nth-child(1) { top: 15px; }
        .c-hamburger span:nth-child(2) { top: 21px; }
        .c-hamburger span:nth-child(3) { top: 27px; }
        .c-hamburger.is-active { border-color: transparent; background: transparent; }
        .c-hamburger.is-active span {background: #ffffff;}
        .c-hamburger.is-active span:nth-child(1) { top: 21px; transform: translateX(-50%) rotate(45deg); }
        .c-hamburger.is-active span:nth-child(2) { opacity: 0; }
        .c-hamburger.is-active span:nth-child(3) { top: 21px; transform: translateX(-50%) rotate(-45deg); }

        /* --- Mobile Menu --- */
        .l-mobile-menu {position: fixed;top: 105px;right: -100%;width: 100%;max-width: min(365px , 90%);height: calc(100vh - 105px);background: #221d5f;z-index: 1050;transition: 0.5s cubic-bezier(0.19, 1, 0.22, 1);padding: 50px 40px 40px;display: flex;flex-direction: column;gap: 24px;box-shadow: -10px 0 40px rgba(0, 0, 0, 0.05);}
        .l-mobile-menu.is-open { right: 0; }
        .mobile-link {font-size: 1.2rem;font-weight: 700;color: #ffffff;text-decoration: none;transition: color 0.3s;}
        .mobile-link:hover {color: var(--secondary-blue);}
        .mobile-cta {margin-top: 1rem;padding: 1rem 2rem;background-color: var(--secondary-blue);color: white;text-align: center;border-radius: 0.75rem;font-weight: 700;text-decoration: none;}
        .l-overlay { position: fixed; inset: 0; background: rgba(10, 25, 47, 0.6); backdrop-filter: blur(4px); z-index: 1040; opacity: 0; pointer-events: none; transition: 0.3s; }
        .l-overlay.is-visible { opacity: 1; pointer-events: auto; }
        @media (max-width: 1024px) {
            .c-hamburger { display: block; }
            .nav-desktop { display: none !important; }
        }
		@media (max-width: 768px){
			.l-mobile-menu{top: 85px;height: calc(100vh - 85px);}
			.mobile-link{font-size: 1.1rem;font-weight:500;}
		}

        /* --- Banner Section --- */
        .section-banner {position: relative;height: 100vh;display: flex;align-items: center;justify-content: center;background: linear-gradient(to bottom, var(--primary-pureJ), #3b2283);overflow: hidden;}
        .banner-bg-container {position: absolute;inset: 0;opacity: 0.3;}
        .banner-blob-1 {position: absolute;top: 5rem;left: 2.5rem;width: 24rem;height: 24rem;background-color: #ffffff;border-radius: 9999px;filter: blur(120px);animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;}
        .banner-blob-2 {position: absolute;bottom: 2.5rem;right: 2.5rem;width: 20rem;height: 20rem;background-color: #ffffff;border-radius: 9999px;filter: blur(100px);animation: bounce 1s infinite;animation-duration: 10s;}
        .banner-content { position: relative; z-index: 10; text-align: center; }
        .banner-badge { display: inline-block; padding: 0.375rem 1rem; background-color: rgba(0, 194, 255, 0.2); color: var(--secondary-blue); border-radius: 9999px; font-size: 0.875rem; font-weight: 700; margin-bottom: 1.5rem; letter-spacing: 0.1em; text-transform: uppercase; }
        .banner-title {font-size: 3rem;line-height: 1.3;font-weight: 700;color: white;margin-bottom: 1.5rem;margin-top: 1rem;}
        .section-banner .cool_bg{position: absolute;display: flex;align-items: center;height: 100%;z-index: 3;top: 0;width: 100%;}
        .section-banner .cool_bg .coll_item{position:absolute;opacity: 1;}
        .section-banner .cool_bg .coll_item.banner-see_01{left: 14vw;transform: rotate(-14deg);}
        .section-banner .cool_bg .coll_item.banner-see_02{right: 19vw;z-index: 1;padding-top: 21vw;transform: rotate(13deg);}
		.section-banner .cool_bg .coll_item.banner-see_01 img{width: 30vw;}
        .section-banner .cool_bg .coll_item.banner-see_02 img{width: 25vw;}

        /*banner_videoo*/
        .banner_videoo{position:absolute;width:100%;height:100%;top: 0;z-index: 0;}
        .banner_videoo video{width:100%;object-fit:cover;opacity: 0.4;height: 100%;}
        
        /* Updated Banner Title Styles for Wave Effect */
        .banner-title-highlight { color: transparent; background-clip: text; -webkit-background-clip: text; background-image: linear-gradient(to right, var(--secondary-blue), var(--primary-blue)); }
        .banner-title .wave-char {display: inline-block;animation: wave-text 3s cubic-bezier(0.45, 0.05, 0.55, 0.95) infinite;animation-delay: calc(var(--i) * 0.1s);transform-origin: bottom center;}
        .banner-desc { color: var(--slate-400); font-size: 1.125rem; max-width: 42rem; margin-left: auto; margin-right: auto; margin-bottom: 2.5rem; line-height: 1.625; }
        

        @media (min-width: 768px) {
            .banner-title { font-size: 4.5rem; }
        }
        .banner-title-highlight .wave-char {color: transparent;background-clip: text;-webkit-background-clip: text;background-image: linear-gradient(to right, var(--secondary-blue), #65d8ff);}
        .banner-desc {color: #ffffff;font-size: 1.125rem;max-width: 42rem;margin-left: auto;margin-right: auto;margin-bottom: 2.5rem;line-height: 1.625;}
        @media (min-width: 768px) {
            .banner-desc { font-size: 1.25rem; }
        }
        .banner-actions { display: flex; flex-direction: column; gap: 1rem; justify-content: center; }
        @media (min-width: 768px) {
            .banner-actions { flex-direction: row; }
        }
		@media (max-width: 768px){
			.banner-bg-container{opacity:0.2;}
			.banner-title{font-size: 2.4rem;}
			.banner-desc{font-size: 1rem;}
		}
        .btn-banner-primary { padding: 1rem 2.5rem; background-color: var(--secondary-blue); color: white; border-radius: 9999px; font-size: 1.125rem; font-weight: 700; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25); transition: all 0.3s; text-decoration: none; }
        .btn-banner-primary:hover { background-color: var(--primary-blue); transform: translateY(-0.25rem); }
        .btn-banner-outline {padding: 1rem 2.5rem;border: 1px solid #cccfd2;color: white;border-radius: 9999px;font-size: 1.125rem;font-weight: 700;transition: all 0.3s;text-decoration: none;}
        .btn-banner-outline:hover { background-color: rgba(255, 255, 255, 0.05); }

        /* --- Section Common Styles --- */
        .section-padding { padding-top: 6rem; padding-bottom: 6rem; }
        .bg-white { background-color: white; }
        .bg-slate-50 { background-color: var(--slate-50); }
        .grid-3-col { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); gap: 2rem; }
        @media (min-width: 768px) {
            .grid-3-col { grid-template-columns: repeat(3, minmax(0, 1fr)); }
        }
		@media (max-width: 640px){
			.section-padding{padding:3rem 0;}
		}

        /* --- Titles --- */
        /* Minimalist Flow */
        .title-minimalist { text-align: center; margin-bottom: 4rem; }
        .title-minimalist .label {display: inline-block;color: var(--primary-pureJ);font-size: 0.875rem;font-weight: 700;letter-spacing: 0.25em;margin-bottom: 0.75rem;text-transform: uppercase;}
        .title-minimalist h2 {font-size: 2.5rem;font-weight: 700;color: var(--slate-900);position: relative;display: flex;flex-direction: column;margin-top: 0;}
        .title-minimalist h2::after {content: "";display: block;width: 48px;height: 4px;background: var(--primary-pureJ);margin: 1.5rem auto 0;border-radius: 10px;}
        /* Layered Typography */
        .title-layered { position: relative; text-align: center; padding-top: 30px; margin-bottom: 4rem; }
        .title-layered .bg-text { position: absolute; top: 0; left: 50%; transform: translateX(-50%); font-size: 6.5rem; font-weight: 900; color: rgba(0, 74, 173, 0.04); white-space: nowrap; z-index: 1; user-select: none; letter-spacing: -0.02em; }
        .title-layered .content { position: relative; z-index: 2; }
        .title-layered h2 { font-size: 2.25rem; font-weight: 700; color: var(--slate-800); margin-bottom: 0.75rem; }
        .title-layered p { color: var(--slate-500); font-size: 1.125rem; max-width: 600px; margin: 0 auto; }
        /* Side Accent */
        .title-side { display: flex; align-items: center; gap: 24px; margin-bottom: 3rem; }
        .title-side .line {width: 6px;height: 54px;background: linear-gradient(to bottom, var(--primary-pureJ), var(--secondary-pureJ));border-radius: 100px;}
        .title-side .text-group h2 {font-size: 2rem;font-weight: 700;color: var(--slate-900);line-height: 1.2;margin: 7px 0;}
        .title-side .text-group p {color: var(--primary-pureJ);font-weight: 700;font-size: 0.9rem;letter-spacing: 0.1em;margin-bottom: 2px;}
        @media (max-width: 768px) {
            .title-layered .bg-text {font-size: 3rem;top: 10px;}
            .title-minimalist h2 { font-size: 1.8rem; }
            .title-side .text-group h2 { font-size: 1.6rem; }
        }

		.coJanbox{padding: 1vw 0 1vw;}
		#about{padding-bottom: 10vw;}

        /* --- About Section Cards --- */
        .feature-card {padding: 2rem;background-color: #ffffff;border-radius: 1.5rem;border: 3px solid #9d9be9;text-align: center;transition: all 0.3s;background: linear-gradient(135deg, #a9a9ff, #3d257d);overflow: hidden;}
        .feature-card:before{content:"";position: absolute;width: 100%;height: 100%;left: 0;top: 0;background: url(/images/38/iconJJ_box.png);z-index: 0;animation: linePulse 1.6s ease-in-out infinite;transform-origin: center;opacity: 0.7;}
		.feature-card:hover {background-color: white;box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);background: linear-gradient(85deg, #6143b1, #3d257d);}
        .feature-card-icon-box {width: 4rem;height: 4rem;background-color: white;border-radius: 1rem;display: flex;align-items: center;justify-content: center;margin-left: auto;margin-right: auto;margin-bottom: 1.5rem;box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);transition: transform 0.3s;z-index: 2;position: relative;}
        .feature-card:hover .feature-card-icon-box { transform: scale(1.1); }
        .feature-card-icon {color: var(--primary-pureJ);width: 2rem;height: 2rem;}
        .feature-card-title {font-size: 1.25rem;font-weight: 700;margin-bottom: 0.75rem;color: white;z-index: 2;position: relative;}
        .feature-card-desc {color: #ffffff;z-index: 2;position: relative;}
		.feature-card:nth-child(1):before{
    animation: linePulse 2s ease-in-out infinite;
}
        .feature-card:nth-child(2):before{
    animation: linePulse 2.5s ease-in-out infinite;
}
        .feature-card:nth-child(3):before{
    animation: linePulse 3s ease-in-out infinite;
}
        @keyframes linePulse {
          0%, 100% {transform: scaleY(1);}
          50% {transform: scaleY(1.1);}
        }

		/* Certificate Buttons */
        .about-actions {display: flex;justify-content: center;gap: 1rem;margin-top: 5rem;flex-wrap: wrap;padding: 2rem 0 2rem;}
        .btn-certificate {position: relative;padding: 0.75rem 2rem;border: 2px solid #dedede00;color: #464646;background: transparent;border-radius: 9999px;font-weight: 700;cursor: pointer;transition: all 0.3s;font-size: 1rem;width: min(400px , 100%);display: flex;flex-direction: column;align-items: center;gap: 5px;}
        .btn-certificate:hover {background: var(--primary-pureJ);color: white;transform: translateY(-3px);box-shadow: 0 10px 20px -5px rgba(0, 74, 173, 0.3);}
        .btn-certificate .icctitle{padding: 0;margin: 0;font-size: 1.1rem;}
        .btn-certificate span{font-weight:300;color:#6f6f6f}
        .btn-certificate:hover *{color:white;}
		
		.btn-certificate:before{content:"";position:absolute;width: 59px;aspect-ratio: 137/299;background: url(/images/38/sotore-1.png);background-size: cover;left: 10px;bottom: 0;}
        .btn-certificate:after{content:"";position:absolute;width: 59px;aspect-ratio: 137/299;background: url(/images/38/sotore-2.png);background-size: cover;right: 10px;bottom: 0;}
        .btn-certificate:hover:before , .btn-certificate:hover:after{display: none;}

		/* Certificate Modal */
        .cert-modal { position: fixed; inset: 0; z-index: 2000; background: rgba(15, 23, 42, 0.9); backdrop-filter: blur(5px); display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; padding: 2rem; }
        .cert-modal.is-open { opacity: 1; pointer-events: auto; }
        .cert-modal-content { position: relative; max-width: 90%; max-height: 90vh; }
        .cert-modal-img { max-width: 100%; max-height: 80vh; border-radius: 0.5rem; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5); }
        .cert-modal-close { position: absolute; top: -3rem; right: 0; color: white; cursor: pointer; font-size: 2rem; transition: color 0.3s; background: none; border: none; display: flex; align-items: center; justify-content: center; }
        .cert-modal-close:hover { color: var(--secondary-blue); }
		@media (max-width: 1024px){
			.about-actions{display:flex;flex-direction: column;align-items: center;gap: 50px;margin-top: 2rem;}
		}

        /* --- Features Section --- */

		#features{padding-top: 0;padding-bottom: 21rem;background: linear-gradient(to bottom, rgb(248 250 252), rgb(226 234 243));}
        .features-grid { display: grid; grid-template-columns: 1fr; gap: 3rem; }
		@media (min-width: 1024px) {
            .features-grid { grid-template-columns: repeat(2, 1fr); }
	        .features-grid:hover .team_boximg{margin-top: -2vw;}
		}
        .features-list { display: flex; flex-direction: column; gap: 1.5rem; }
        .feature-item { display: flex; gap: 1.5rem; padding: 1.5rem; background-color: white; border-radius: 1rem; box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05); transition: all 0.3s; cursor: default; }
        .feature-item:hover { box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }
        .feature-item-icon-box {flex-shrink: 0;width: 3rem;height: 3rem;background-color: #f6f4fb;border-radius: 0.75rem;display: flex;align-items: center;justify-content: center;}
        .feature-item-icon {color: var(--primary-pureJ);}
        .feature-item-title { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.5rem; }
        .feature-item-desc { color: var(--slate-500); }
        .feature-demo-box { background-color: white; border-radius: 1.5rem; padding: 1rem; box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06); border: 1px solid var(--slate-200); min-height: 300px; display: flex; align-items: center; justify-content: center; color: var(--slate-300); font-style: italic; }
		#features .team_boximg{position:absolute;width: 25vw;display: flex;top: -4vw;right: 4vw;}
		#features .team_boximg img{width:100%;}
		.dowcould{position:absolute;bottom: -10px;z-index: 0;height: 100%;width: 100%;overflow: hidden;}
		.dowcould img{width:100%;}
		.dowcould .doitem01{position:absolute;left: -8vw;width: 30vw;top: 5%;}
		.dowcould .doitem02{position:absolute;width: 31vw;right: -5vw;top: 0;}
		.dowcould .doitem03{position:absolute;bottom: 0;width: 100%;}
		
		
		/* Video Player Box (Updated) */
        #video_JJbox { padding: 0; overflow: hidden; cursor: pointer; display: flex; align-items: center; justify-content: center; position: relative; background-color: black; border-radius: 1.5rem; transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
        #video_JJbox.is-animating { transform: scale(0.98); }
        #video_JJbox video { width: 100%; height: 100%; object-fit: cover; border-radius: 1.5rem; display: block; }
        .video-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; background-color: rgba(0,0,0,0.2); transition: background-color 0.3s, opacity 0.3s; z-index: 10; border-radius: 1.5rem; opacity: 1; pointer-events: none; }
        #video_JJbox:hover .video-overlay { background-color: rgba(0,0,0,0.1); }
        .video-play-btn { width: 5rem; height: 5rem; background-color: rgba(255, 255, 255, 0.95); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--primary-blue); transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
        .video-play-btn i { width: 2rem; height: 2rem; margin-left: 0.25rem; fill: currentColor; }
        #video_JJbox:hover .video-play-btn { transform: scale(1.1); background-color: white; }
        @keyframes pulse-btn {
            0% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.7); }
            70% { box-shadow: 0 0 0 20px rgba(255, 255, 255, 0); }
            100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0); }
        }
        .video-play-btn { animation: pulse-btn 2s infinite; }

		@media (max-width: 640px){
			#features{padding-bottom: 11rem;}
			.features-grid{display:flex;flex-direction: column;align-items: center;gap: 2rem;}
			#features .team_boximg{position:relative;width: 90%;right: auto;top: 0;}
			.features-list{order:2;}
			.dowcould .doitem03{width: 150vw;}
		}
        /* --- Report Section --- */

		#report{z-index:3}
        .report-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
        @media (min-width: 768px) {
            .report-grid { grid-template-columns: repeat(2, 1fr); }
        }
        @media (min-width: 1024px) {
            .report-grid { grid-template-columns: repeat(3, 1fr); }
        }
        .report-card { background-color: var(--slate-50); padding: 2rem; border-radius: 1.5rem; border: 1px solid transparent; transition: all 0.3s; }
        .report-card:hover {border-color: rgb(189 165 240);}
        .report-card-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.5rem; }
        .report-card-title { font-weight: 700; }
        .report-card-chart {height: 12rem;background-color: white;border-radius: 0.75rem;margin-bottom: 1rem;box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);padding: 1rem 0;}
        .report-card-desc { font-size: 0.875rem; color: var(--slate-500); }
        .report_fly{position:absolute;width:100%;height:100%;}
		.report_fly .reportJ_item01{position:absolute;width: 7vw;right: 31vw;top: -4vw;filter: blur(0px);animation: bounce 1s infinite;animation-duration: 9s;}
		.report_fly .reportJ_item02{position:absolute;width: 6vw;bottom: -5vw;left: 19vw;filter: blur(0px);animation: bounce 1s infinite;animation-duration: 6s;}
		.report_fly:before {content:"";position: absolute;bottom: 0.5rem;right: 1.5rem;width: 20rem;height: 20rem;background-color: rgb(124 86 209 / 57%);border-radius: 9999px;filter: blur(90px);animation: bounce 1s infinite;animation-duration: 10s;opacity: 0.5;}
       
		.report_fly img{width:100%}
	
        /* SVG Chart Animations - Updated with transform-box */
        /* SVG Chart Animations */
	.bar-anim { transform-origin: bottom; transform: scaleY(0); transform-box: fill-box; }
	.report-card-chart.is-active .bar-anim { animation: barGrow 1s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
	@keyframes barGrow { to { transform: scaleY(1); } }
	
	.radar-anim { transform-origin: center; transform: scale(0); opacity: 0; transform-box: fill-box; }
	.report-card-chart.is-active .radar-anim { animation: radarGrow 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards; animation-delay: 0.2s; }
	@keyframes radarGrow { to { transform: scale(1); opacity: 0.8; } }
	
	.circle-anim { stroke-dasharray: 251px; stroke-dashoffset: 251px; transform-origin: center; transform-box: fill-box; }
	.report-card-chart.is-active .circle-anim { animation: circleFill 1.5s cubic-bezier(0.16, 1, 0.3, 1) forwards; animation-delay: 0.2s; }
	@keyframes circleFill { to { stroke-dashoffset: 30px; } }

	.text-anim { opacity: 0; transform: scale(0.5); transform-origin: center; transform-box: fill-box; }
	.report-card-chart.is-active .text-anim { animation: textPop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; animation-delay: 1s; }
	@keyframes textPop { to { opacity: 1; transform: scale(1); } }
        
		@media (max-width: 640px) {
			.report_fly .reportJ_item01{width:25vw;right: 8vw;top: -29vw;}
			.report_fly .reportJ_item02{width: 20vw;left:-1vw;bottom: -5vw;}
		}

        
        /* --- Testimonials Section (New) --- */
		#testimonials{background: linear-gradient(to bottom, rgb(248 250 252), rgb(226 234 243));padding-bottom: 10rem;padding-top: 1rem;}
        #testimonials .container { max-width: 100%; padding: 0 2rem; }
        .testimonials-wrapper { position: relative; max-width: 100%; width: 100%; margin: 0 auto; overflow: hidden; padding: 2rem 0; }
        .testimonials-track { display: flex; transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1); gap: 2rem; }
        .testimonial-card {flex: 0 0 100%;min-width: 100%;background-color: white;padding: 3rem 2rem;border-radius: 2rem;box-shadow: 0 20px 40px -10px rgba(0,0,0,0.08);text-align: center;border: 1px solid var(--slate-100);}
         @media (min-width: 768px) {
            .testimonial-card { flex: 0 0 calc(50% - 1rem); min-width: calc(50% - 1rem); }
        }
        @media (min-width: 1280px) {
            .testimonial-card { flex: 0 0 calc(33.333% - 1.333rem); min-width: calc(33.333% - 1.333rem); }
        }
        @media (min-width: 1440px) {
            .testimonial-card { flex: 0 0 calc(25% - 1.5rem); min-width: calc(25% - 1.5rem); }
        }
        @media (min-width: 1441px) {
             .testimonial-card { flex: 0 0 calc(20% - 1.6rem); min-width: calc(20% - 1.6rem); }
        }
        .testimonial-avatar { width: 5rem; height: 5rem; border-radius: 50%; object-fit: cover; margin: 0 auto 1.5rem; border: 4px solid var(--blue-50); }
        .testimonial-stars { display: flex; justify-content: center; gap: 0.25rem; margin-bottom: 1.5rem; color: var(--yellow-400); }
        .testimonial-stars svg {width: 1.25rem;height: 1.25rem;fill: #e0ab6a;stroke: #e0ab6a;}
        .testimonial-text {font-size: 0.85rem;line-height: 1.75;color: var(--slate-600);font-style: italic;margin-bottom: 1.5rem;}
        .testimonial-author { font-weight: 700; color: var(--slate-900); font-size: 1rem; }
        .testimonial-nav { display: flex; justify-content: center; gap: 1rem; margin-top: 2rem; align-items: center; }
        .testimonial-btn { width: 3rem; height: 3rem; border-radius: 50%; border: 1px solid var(--slate-200); background: white; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s; color: var(--slate-500); }
        .testimonial-btn:hover { border-color: var(--primary-blue); color: var(--primary-blue); background-color: var(--blue-50); }
        .testimonial-dots { display: flex; gap: 0.5rem; }
        .testimonial-dot {width: 0.75rem;height: 0.75rem;border-radius: 50%;background-color: #d8d8d8;cursor: pointer;transition: all 0.3s;}
        .testimonial-dot.is-active {background-color: var(--primary-pureJ);width: 2rem;border-radius: 99px;}


        
        /* --- Tutorial Section --- */
        .section-tutorial {background-color: #241170;color: white;position: relative;z-index: 20;padding: 13rem 0 11rem;background-image: url(/images/38/set_bg.jpg);background-size: cover;}
        .section-tutorial .title-minimalist .label{color:white;}
		.section-tutorial .title-minimalist h2::after{background:white;}
		.tutorial-grid {display: grid;grid-template-columns: 1fr;gap: 1.5rem;padding: 1.5rem 0;}
       .section-tutorial:before{content:"";position: absolute;background:url(/images/38/rooobat001.png);width: 31vw;aspect-ratio: 1/1;right: 1vw;top: -10vw;background-size: cover;animation: bounce2 4s infinite;animation-duration: 3s;z-index: 6;}
		
		.section-tutorial .brinbrin::before,.section-tutorial .brinbrin::after{content:"";position:absolute;left:0;width:100%;height:2px;background:linear-gradient(
    90deg,transparent,#b26cff,#d19bff,#b26cff,transparent
  );box-shadow:0 0 8px rgba(178,108,255,0.8),0 0 16px rgba(178,108,255,0.6),0 0 32px rgba(178,108,255,0.4)}
		.section-tutorial .brinbrin::before{top:0}
		.section-tutorial .brinbrin::after{bottom:0}
		@media (min-width: 768px) {
            .tutorial-grid { grid-template-columns: repeat(4, 1fr); }
        }
        .tutorial-item {position: relative;padding: 2rem;background-color: rgb(255 255 255 / 85%);border: 1px solid rgba(255, 255, 255, 0.1);border-radius: 1rem;text-align: center;transition: all 0.3s;cursor: none;border-bottom: #a078f7 3px solid;}
        .tutorial-item:hover {border-color: rgba(255, 255, 255, 0.3);}
        .tutorial-badge {position: absolute;top: -1rem;left: 50%;transform: translateX(-50%);width: 2.5rem;height: 2.5rem;background-color: #7c56d1;border: #e2dcf2 2px solid;border-radius: 9999px;display: flex;align-items: center;justify-content: center;font-weight: 700;box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);}
        .tutorial-title {margin-top: 1rem;font-weight: 700;margin-bottom: 0.5rem;font-size: 1.25rem;color: var(--primary-pureJ);}
        .tutorial-desc {color: #606060;font-size: 0.875rem;}
        .tutorial-mobile-img {display: none;width: 100%;height: auto;object-fit: cover;border-radius: 0.5rem;margin-bottom: 1.5rem;margin-top: 1rem;}
        @media (max-width: 768px) {
            .tutorial-cursor { display: none !important; }
            .tutorial-item { cursor: default; }
            .tutorial-mobile-img { display: block; }
			.section-tutorial{padding: 5rem 0 5rem;background-image: unset;}
        }

        /* --- Contact Section --- */
        .contact-layout {display: flex;flex-direction: column;gap: 5rem;align-items: center;}
        @media (min-width: 1024px) {
            .contact-layout { flex-direction: row; }
        }
        .contact-info { flex: 1; }
        .contact-desc {font-size: 1rem;color: var(--slate-600);margin-bottom: 2.5rem;line-height: 1.625;font-weight: 500;}
        .contact-methods { display: flex; flex-direction: column; gap: 2rem; }
        .contact-method-item { display: flex; align-items: center; gap: 1.5rem; }
        .contact-icon-box {width: 3.5rem;height: 3.5rem;background-color: #ffffff;border-radius: 1rem;display: flex;align-items: center;justify-content: center;color: var(--primary-pureJ);transition: all 0.3s;}
        .contact-method-item:hover .contact-icon-box {background-color: var(--secondary-pureJ);color: white;}
        .contact-method-label {font-size: 0.875rem;color: var(--slate-400);font-weight: 700;text-transform: uppercase;letter-spacing: 0.05em;margin: 0;}
        .contact-method-value {font-size: 1.25rem;font-weight: 900;color: var(--slate-800);margin: 0;}
        .contact-form-container {flex: 1;background-color: white;padding: 3rem;border-radius: 2.5rem;border: 3px solid #5a30c8;box-shadow: 0 25px 50px -12px rgb(134 134 134 / 25%);position: relative;}
        .form-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
        @media (min-width: 768px) {
            .form-grid { grid-template-columns: repeat(2, 1fr); }
        }
        .form-group { margin-bottom: 1.5rem; }
        .form-label { font-size: 0.75rem; font-weight: 900; color: var(--slate-400); text-transform: uppercase; letter-spacing: 0.05em; display: block; margin-bottom: 0.5rem; }
        .form-input { width: 100%; border: none; border-bottom: 2px solid var(--slate-100); padding: 0.75rem; transition: border-color 0.3s; background-color: transparent; }
        .form-input:focus { outline: none; border-color: var(--blue-600); }
        .form-btn {width: 100%;padding-top: 0;padding-bottom: 0;background-color: var(--primary-pureJ);color: white;border-radius: 0.75rem;font-weight: 700;border: none;cursor: pointer;transition: all 0.3s;box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);}
        .form-btn:hover {background-color: var(--secondary-pureJ);transform: translateY(-0.25rem);}
		.form-btn a{color:white;width: 100%;display: flex;flex-direction: column;align-items: center;padding: 1rem 0;}
        #Checknum{padding: 11px;border: #e7e7e7 1px solid;margin: 0;}
		.checknum{display:flex;gap: 10px;flex-wrap: wrap;}
		.checknum font{display:flex;align-items: center;gap: 10px;}
		.contavt_JJ_boox{display:flex;overflow: hidden;flex-direction: column;align-items: center;position: absolute;top: 1vw;}
		.contavt_JJ_boox img{position: relative;width: 141vw;margin: 0 auto;max-width: unset;object-fit: cover;left: -40vw;opacity: 0.22;animation: rotate360 17.2s linear infinite;}
		
		@media (max-width: 640px){
			.contavt_JJ_boox img{left: auto;right: -41vw;top: 0;}
		}

		/* --- Footer (Enhanced) --- */
		#contact{padding: 8rem 0;overflow: hidden;background: linear-gradient(to bottom, rgb(237 237 237), rgb(226 234 243));}
        .site-footer {background-color: var(--primary-pureJ);background: linear-gradient(135deg, #260e66, #483380);padding-top: 5rem;padding-bottom: 2rem;color: var(--slate-400);border-top: 1px solid rgba(255, 255, 255, 0.05);}
        .footer-grid { display: grid; gap: 3rem; grid-template-columns: 1fr; margin-bottom: 4rem; }
        @media (min-width: 768px) {
            .footer-grid { grid-template-columns: repeat(2, 1fr); }
        }
        @media (min-width: 1024px) {
            .footer-grid { grid-template-columns: 2fr 1fr 1.5fr; }
        }
        .footer-brand { display: flex; flex-direction: column; gap: 1rem; }
        .footer-logo { display: flex; align-items: center; gap: 0.5rem; color: white; margin-bottom: 0.5rem; justify-content: flex-start; }
        .footer-logo-text { font-size: 1.5rem; font-weight: 700; }
        .footer-tagline {font-size: 1rem;line-height: 1.6;max-width: 300px;color: #ffffff;}
        .btn-footer-line {display: inline-flex;align-items: center;gap: 0.5rem;background-color: #2ebeea;color: white;padding: 0.5rem 1.25rem;border-radius: 9999px;font-weight: 700;text-decoration: none;transition: all 0.3s;margin-top: 1rem;box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);width: fit-content;width: min(328px , 100%);justify-content: center;}
        .btn-footer-line:hover { background-color: #05b34c; transform: translateY(-2px); box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1); }
        
		.btn-footer-line svg { width: 1.25rem; height: 1.25rem; fill: currentColor; }
        .footer-heading { color: white; font-weight: 700; font-size: 1.125rem; margin-bottom: 1.5rem; letter-spacing: 0.05em; }
        .footer-links ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.75rem; }
        .footer-links a {color: #e2e5e8;text-decoration: none;transition: color 0.3s;}
        .footer-links a:hover {color: #2ebde9;}
        .contact-item { margin-bottom: 1.5rem; }
        .contact-label {display: block;font-size: 0.875rem;font-weight: 700;color: #2ebde9;margin-bottom: 0.5rem;text-transform: uppercase;}
        .contact-text { color: white; line-height: 1.7; display: block; }
        .contact-text a { color: white; text-decoration: none; transition: color 0.3s; }
        .contact-text a:hover {color: #2ebde9;}
        .footer-copyright { padding-top: 2rem; border-top: 1px solid rgba(255, 255, 255, 0.1); text-align: center; font-size: 0.875rem; }
		.footer-copyright *{color:white;}
		@media (max-width: 1024px){
			.footer-links ul{display: grid;grid-template-columns: repeat(3, 1fr);}
		}
		@media (max-width: 640px){
			#contact{padding: 5rem 0;}
		}
        
        /* --- Tutorial Cursor Styles --- */
        .tutorial-cursor {position: fixed;top: 0;left: 0;width: min(550px , 90%);height: auto;aspect-ratio: 1/1;pointer-events: none;z-index: 9999;opacity: 0;transform: translate(-50%, -50%) scale(0.5);transition: opacity 0.3s cubic-bezier(0.25, 1, 0.5, 1), transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);will-change: transform, left, top;}
        .tutorial-cursor.is-visible { opacity: 1; transform: translate(-50%, -50%) scale(1); }
        .tutorial-cursor-inner {position: relative;width: 100%;height: 100%;overflow: hidden;border-radius: 12px;}
        .tutorial-cursor img {width: 100%;height: 100%;object-fit: cover;transform: scale(1);}
        .tutorial-cursor-label { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(0, 74, 173, 0.8); backdrop-filter: blur(4px); color: white; padding: 8px 20px; border-radius: 30px; font-weight: 700; font-size: 14px; letter-spacing: 0.1em; text-transform: uppercase; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); }

        /* --- Floating Actions --- */
        .floating-actions { position: fixed; bottom: 2rem; right: 2rem; z-index: 1000; display: flex; flex-direction: column; gap: 1rem; }
        .float-btn { width: 3.5rem; height: 3.5rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; cursor: pointer; transition: all 0.3s; box-shadow: 0 4px 15px rgba(0,0,0,0.2); border: none; text-decoration: none; }
        .float-btn:hover { transform: translateY(-5px); }
        .btn-line { background-color: var(--line-green); }
        .btn-top {background-color: var(--secondary-pureJ);opacity: 0;pointer-events: none;transform: translateY(20px);}
        .btn-top.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
        .btn-top.is-visible:hover { transform: translateY(-5px); }

        /* --- Animations --- */
        @keyframes pulse {
            0%, 100% { opacity: 1; }
            50% { opacity: .5; }
        }
        @keyframes bounce {
            0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(0.8, 0, 1, 1); }
            50% { transform: none; animation-timing-function: cubic-bezier(0, 0, 0.2, 1); }
        }
		@keyframes bounce2 {
            0%, 100% { transform: translateY(-20px); animation-timing-function: cubic-bezier(0.8, 0, 1, 1); }
            50% { transform: none; animation-timing-function: cubic-bezier(0, 0, 0.2, 1); }
        }

		@keyframes wave-text {
            0%, 60%, 100% { transform: translateY(0); }
            10% { transform: translateY(-20px); }
            20% { transform: translateY(0); }
        }
        @keyframes rotate360 {
          from {transform: rotate(0deg);}
          to {transform: rotate(360deg);}
        }