/* --- 變數與基礎設定 --- */
: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));z-index: 0;}
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: var(--blue-50);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); }
.header-cta:hover a{color:white;}
/* --- 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; }
.title-minimalist{
    margin-bottom: 0rem;
}
}

.coJanbox{padding: 1vw 0 1vw;}
#about{padding-bottom: 10vw;}

/* --- About Section Cards --- */
	.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;}

/* 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 { --transition: all 0.4s cubic-bezier(0.2,1,0.3,1); }
/* --- 2. 基礎樣式與佈局 (以 #features 開頭) --- */
#features { font-family: 'Noto Sans TC',sans-serif; background-color: var(--bg-white); color: var(--slate-900); line-height: 1.6; overflow-x: hidden; padding: 100px 0; }
#features .container {max-width: 1200px;margin: 0 auto;padding: 0 40px;}
/* --- 3. 標題與 Header 區塊 --- */
#features .features-header { text-align: center; max-width: 800px; margin: 0 auto 60px; }
#features .badge {display: inline-block;padding: 6px 20px;background: linear-gradient(90deg,var(--primary-pureJ),var(--secondary-blue));color: #fff;font-size: 12px;font-weight: 700;letter-spacing: 2px;text-transform: uppercase;border-radius: 50px;}
#features .main-title { font-size: 42px; font-weight: 900; margin-bottom: 20px; line-height: 1.2; }
#features .main-title span { color: var(--primary-pureJ); }
#features .title-line { width: 80px; height: 6px; background: linear-gradient(90deg,var(--primary-pureJ),var(--secondary-blue)); margin: 0 auto 30px; border-radius: 10px; }
#features .sub-desc { font-size: 18px; color: var(--slate-500); }
/* --- 4. 功能卡片網格 --- */
#features .features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; margin-bottom: 100px; }
#features .feature-card { background: #fff; padding: 50px 40px; border-radius: 40px; border: 1px solid var(--slate-100); box-shadow: 0 10px 30px rgba(0,0,0,0.03); position: relative; transition: var(--transition); overflow: hidden; display: flex; flex-direction: column; align-items: flex-start; }
#features .feature-card:hover {transform: translateY(-15px);border-color: var(--secondary-pureJ);box-shadow: 0 25px 50px -12px rgba(0,194,255,0.15);}
#features .card-number { position: absolute; top: -20px; right: -20px; font-size: 120px; font-weight: 900; color: var(--slate-50); z-index: 1; line-height: 1; transition: var(--transition); }
#features .feature-card:hover .card-number { color: #f0f4ff; }
#features .icon-box {width: 70px;height: 70px;background-color: #f2edff;color: var(--primary-pureJ);border-radius: 16px;display: flex;align-items: center;justify-content: center;position: relative;z-index: 2;transition: var(--transition);}
#features .feature-card:hover .icon-box { background: linear-gradient(135deg,var(--primary-pureJ),var(--secondary-pureJ)); color: #fff; }
#features .card-title {font-size: 24px;font-weight: 700;margin-bottom: 10px;position: relative;z-index: 2;transition: var(--transition);}
#features .feature-card:hover .card-title { color: var(--primary-pureJ); }
#features .feature-card:hover .icon-box svg{
    fill: var(--slate-50);
}
#features .card-text {color: var(--bg-dark);margin-bottom: 25px;position: relative;z-index: 2;}
#features .feature-list { list-style: none; position: relative; z-index: 2; padding-inline-start: 0; }
#features .feature-list li { font-size: 16px; color: var(--slate-600); margin-bottom: 12px; display: flex; align-items: center; }
#features .feature-list li::before { content: ""; width: 8px; height: 8px; background: linear-gradient(90deg,var(--primary-pureJ),var(--secondary-blue)); border-radius: 50%; margin-right: 12px; }
#features .icon-box svg{
    fill: var(--report-purple);
    width: 36px;
}
/* --- 5. 底部展示區域 --- */
#features .team-showcase { text-align: center; position: relative; }
#features .image-wrapper { display: inline-block; position: relative; max-width: 1000px; width: 100%; }
#features .glow-bg { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 80%; height: 80%; background: radial-gradient(circle,rgba(61,18,171,0.1) 0%,transparent 70%); z-index: 0; filter: blur(60px); }
#features .main-img {width: 100%;height: auto;border-radius: 40px;position: relative;z-index: 2;animation: floating 6s ease-in-out infinite;}
#features .corner-decoration { position: absolute; width: 80px; height: 80px; border: 5px solid var(--secondary-blue); z-index: 3; }
#features .top-left { top: -15px; left: -15px; border-right: none; border-bottom: none; border-radius: 40px 0 0 0; }
#features .bottom-right { bottom: -15px; right: -15px; border-left: none; border-top: none; border-radius: 0 0 40px 0; }
/* --- 6. 裝飾與動畫 --- */
@keyframes floating {
0%,100% { transform: translateY(0); }
50% { transform: translateY(-20px); }
}
/* --- 7. 響應式佈局 (RWD) --- */
@media (max-width:1024px) {
#features .features-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width:768px) {
#features { padding: 60px 0; }
#features .main-title { font-size: 32px; }
#features .features-grid {grid-template-columns: 1fr;margin-bottom: 40px;}
#features .feature-card { padding: 40px 30px; }
#features .image-wrapper {width: 100%;}
#features .corner-decoration { display: none; }
}

.dowcould{position:absolute;bottom: 0;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: -20px;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: 2rem;}
	.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 { --primary-pureJ: #3d12ab; --secondary-pureJ: #784eef; --primary-blue: #004aad; --secondary-blue: #00c2ff; --report-purple: #3d12ab; --bg-white: #ffffff; --slate-50: #f8fafc; --slate-100: #f1f5f9; --slate-200: #e2e8f0; --slate-400: #94a3b8; --slate-500: #64748b; --slate-800: #1e293b; --slate-900: #0f172a; --transition: all 0.5s cubic-bezier(0.2,1,0.3,1); }
/* --- 2. 基礎佈局 --- */
#report { position: relative; overflow: hidden; padding: 80px 0; background-color: var(--bg-white); }
#report .container {max-width: 1366px;margin: 0 auto;padding: 0 30px;position: relative;z-index: 10;}
#report .bg_JJimg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
#report .bg_JJimg img { width: 100%; height: 100%; object-fit: cover; }
#report .report_fly { position: absolute; inset: 0; pointer-events: none; z-index: 2; }
#report .reportJ_item01,#report .reportJ_item02 { position: absolute; animation: floating 6s ease-in-out infinite; }
#report .reportJ_item01 { width: 7vw; right: 31vw; top: 5vw; }
#report .reportJ_item02 { width: 7vw; bottom: 3vw; left: 5vw; }
/* --- 3. 標題設計 --- */
#report .title-side { margin-bottom: 80px; display: flex; align-items: flex-start; gap: 25px; position: relative; }
#report .line {width: 6px;height: 90px;background: linear-gradient(to bottom,var(--report-purple),var(--secondary-blue));border-radius: 10px;}
#report .text-group p {color: var(--report-purple);font-size: 14px;font-weight: 800;letter-spacing: 2px;margin-bottom: 8px;font-family: 'JetBrains Mono',monospace;}
#report .text-group h2 { font-size: 42px; font-weight: 900; color: var(--slate-900); letter-spacing: -1.5px; margin-bottom: 20px; }
/* --- 4. 核心功能卡片 (3張) --- */
#report .report-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; margin-bottom: 80px; }
#report .report-card { background: #ffffff; padding: 50px 40px; border-radius: 40px; box-shadow: 0 20px 50px rgba(0,0,0,0.03); border: 1px solid var(--slate-100); transition: var(--transition); display: flex; flex-direction: column; align-items: center; text-align: center; position: relative; }
#report .report-card:hover { transform: translateY(-15px); box-shadow: 0 40px 80px rgba(61,18,171,0.12); border-color: var(--primary-pureJ); }
#report .report-card-header { display: flex; align-items: center; gap: 12px; margin-bottom: 30px; width: 100%; justify-content: center; }
#report .report-card-title { font-size: 28px; font-weight: 800; color: var(--slate-900); }
#report .report-card-chart { width: 100%; height: 160px; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; background: var(--slate-50); border-radius: 25px; padding: 20px; }
#report .card-stats { display: flex; gap: 10px; margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--slate-300); width: 100%; flex-wrap: wrap; justify-content: center; }
#report .stat-pill {flex: 1;min-width: calc(50% - 10px);font-size: 15px;font-weight: 600;color: var(--slate-600);background: rgb(67 67 67 / 4%);padding: 8px 4px;border-radius: 12px;font-family: 'JetBrains Mono',monospace;border: 1px solid rgba(61,18,171,0.08);white-space: nowrap;}
#report .report-card-desc { color: var(--slate-600); font-size: 16px; line-height: 1.9; margin-bottom: 12px; text-align: left; }
#report .report-card-desc b { color: var(--slate-800); display: block; margin-top: 10px; margin-bottom: 5px; font-size: 18px; }
#report .report-card-highlight {font-size: 18px;font-weight: 700;color: var(--primary-pureJ);margin-top: 15px;display: block;}
/* --- 5. 系統有效性對比 --- */
#report .system-effectiveness { margin-bottom: 120px; padding: 60px 60px; background: linear-gradient(135deg,var(--slate-50) 0%,#ffffff 100%); border: 1px solid var(--slate-200); border-radius: 60px; color: var(--slate-900); position: relative; overflow: hidden; box-shadow: 0 20px 40px rgba(0,0,0,0.02); display: none; }
#report .eff-bg-decor { position: absolute; inset: 0; background: radial-gradient(circle at 10% 20%,rgba(61,18,171,0.05) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgb(241 241 249) 0%,transparent 40%); z-index: 1; }
#report .eff-header { text-align: center; margin-bottom: 60px; position: relative; z-index: 2; }
#report .eff-header h3 { font-size: 38px; font-weight: 900; margin-bottom: 15px; color: var(--slate-900); letter-spacing: -1px; margin-top: 0; }
#report .eff-header p { font-size: 18px; color: var(--slate-500); font-weight: 500; }
#report .eff-comparison { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; position: relative; z-index: 2; align-items: stretch; }
#report .eff-vs { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 70px; height: 70px; background: var(--primary-pureJ); border: 4px solid #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'JetBrains Mono',monospace; font-weight: 900; font-size: 20px; color: #fff; z-index: 10; box-shadow: 0 10px 20px rgba(61,18,171,0.3); }
#report .comp-card { background: #ffffff; padding: 30px 40px; border-radius: 40px; position: relative; transition: var(--transition); border: 1px solid var(--slate-100); }
/* 傳統學習卡片色彩 */
#report .comp-card.traditional { background: #fff; border: 1px solid var(--slate-200); opacity: 0.8; }
/* AI 系統卡片色彩 */
#report .comp-card.ai-system { background: #fff; border: 1px solid rgba(0,194,255,0.2); box-shadow: 0 25px 50px -12px rgba(61,18,171,0.1); }
#report .comp-card.ai-system::after { content: ""; position: absolute; inset: -1px; border-radius: 40px; padding: 2px; background: linear-gradient(135deg,var(--primary-pureJ),var(--secondary-blue)); -webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
#report .comp-card h5 { font-size: 22px; font-weight: 900; margin-bottom: 40px; color: var(--slate-900); margin: 10px 0 30px; }
#report .comp-card ul { padding-inline-start: 0; }
#report .comp-list li { font-size: 16px; margin-bottom: 20px; display: flex; align-items: center; gap: 15px; padding: 12px 18px; border-radius: 15px; color: var(--slate-500); transition: var(--transition); }
#report .comp-card.traditional li { background: var(--slate-50); }
#report .comp-card.traditional li:last-child { color: #d97706; background: #fffbeb; }
#report .comp-card.ai-system li { background: rgba(61,18,171,0.02); color: var(--slate-800); }
#report .comp-card.ai-system li:last-child { background: rgba(0,194,255,0.05); font-weight: 800; color: var(--primary-pureJ); }
#report .status-icon i { width: 20px; height: 20px; }
#report .eff-footer { text-align: center; margin-top: 60px; padding: 30px; background: #ffffff; border-radius: 25px; border: 1px solid var(--slate-100); position: relative; z-index: 2; }
#report .eff-footer .slogan { font-size: 24px; font-weight: 900; color: var(--slate-900); letter-spacing: 1px; }
#report .eff-footer .slogan span { color: var(--primary-pureJ); position: relative; }
#report .eff-footer .slogan span::after { content: ""; position: absolute; bottom: 2px; left: 0; width: 100%; height: 8px; background: rgba(0,194,255,0.2); z-index: -1; }
/* --- 6. 數據深度分析區 --- */
#report .extra-insights { background: #ffffff; border: 1px solid var(--slate-200); border-radius: 40px; padding: 70px 60px; display: grid; grid-template-columns: 1.2fr 1.8fr; gap: 60px; align-items: start; box-shadow: 0 10px 30px rgba(0,0,0,0.02); position: relative; }
#report .insights-summary h3 { font-size: 36px; font-weight: 900; color: var(--slate-900); margin-bottom: 30px; line-height: 1.2; margin-top: 0; }
#report .insights-summary .h3-sub {font-size: 22px;font-weight: 600;color: #7c56d1;margin-bottom: 25px;display: block;}
#report .insights-summary p { color: var(--slate-500); margin-bottom: 30px; line-height: 1.8; font-size: 16px; }
#report .insights-summary .slogan-highlight { font-size: 20px; font-weight: 900; color: var(--primary-pureJ); display: block; border-left: 4px solid var(--primary-pureJ); padding-left: 15px; margin-top: 20px; }
#report .insights-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 25px; }
#report .insight-item { background: var(--slate-50); padding: 25px; border-radius: 25px; display: flex; flex-direction: column; align-items: flex-start; gap: 28px; transition: var(--transition); border: 1px solid transparent; }
#report .insight-item:hover { transform: translateY(-5px); background: #f8fafc; border-color: var(--primary-pureJ); box-shadow: 0 15px 30px rgba(0,0,0,0.05); }
#report .insight-icon-row { display: flex; align-items: center; gap: 15px; width: 100%; }
#report .insight-icon {width: 60px;height: 60px;background: #7c56d1;color: var(--report-purple);border-radius: 12px;display: flex;align-items: center;justify-content: center;box-shadow: 0 5px 15px rgba(0,0,0,0.05);flex-shrink: 0;}
#report .insight-icon svg{
    color: #fff;
}
#report .insight-info .val { display: block; font-size: 22px; font-weight: 600; color: var(--report-purple); font-family: 'JetBrains Mono',monospace; line-height: 1; }
#report .insight-info .label { font-size: 20px; font-weight: 700; color: var(--slate-900); margin-top: 4px; display: block; }
#report .insight-detail { font-size: 17px; color: var(--slate-800); line-height: 1.5; position: relative; padding-left: 30px; }
#report .insight-detail::before { content: "→"; position: absolute; left: 0; color: var(--slate-400); font-weight: 900; }
/* --- 7. 動畫 --- */
#report .bar-anim { transform-origin: bottom; animation: barGrow 1.5s ease-out forwards; scale: 1 0; }
@keyframes barGrow {
  to { scale: 1 1; }
}
#report .radar-anim { transform-origin: center; animation: radarScale 1.2s cubic-bezier(0.175,0.885,0.32,1.275) forwards; scale: 0; }
@keyframes radarScale {
  to { scale: 1; }
}
#report .circle-anim { stroke-dasharray: 251.2; stroke-dashoffset: 251.2; animation: circleFill 2s ease-in-out forwards; }
@keyframes circleFill {
  to { stroke-dashoffset: 50.24; }
}
#report .text-anim { opacity: 0; animation: fadeIn 1s ease-out 1s forwards; }
@keyframes fadeIn {
  to { opacity: 1; }
}
@keyframes floating {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}
/* --- 8. 響應式佈局 --- */
@media (max-width:1100px) {
  #report .report-grid {grid-template-columns: repeat(2,1fr);margin-bottom: 50px;}
  #report .extra-insights {grid-template-columns: 1fr;padding: 40px 30px;gap: 40px;}
  #report .eff-comparison { grid-template-columns: 1fr; gap: 80px; }
  #report .eff-vs { top: auto; bottom: -35px; left: 50%; }
#report{
    padding: 80px 0 40px;
}
}
@media (max-width:768px) {
  #report .report-grid,#report .extra-insights,#report .insights-grid { grid-template-columns: 1fr; }
  #report .text-group h2,#report .insights-summary h3 {font-size: 30px;}
    #report .title-side{
    margin-bottom: 40px;
}
  #report .system-effectiveness { padding: 60px 25px; }
  #report .comp-card { padding: 40px 25px; }
  #report .eff-header h3 { font-size: 28px; }
  #report .stat-pill { min-width: 100%; }
}


/* --- 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); }
}
@media (max-width: 768px) {
    #testimonials{
    padding-bottom: 2rem;
}
}

.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,.contact-method-value a {font-size: 1.25rem;font-weight: 900;color: var(--slate-800);margin: 0;}
.contact-method-value a{text-decoration: none;}        
.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);}
}