@charset "UTF-8";body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}:root{--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280}body{background-color:#f9fafb;background-color:var(--gray-50);color:#1f2937;color:var(--text-color);font-family:Noto Sans TC,sans-serif;line-height:1.6}.welcome-section{padding:4rem 0;text-align:center}.welcome-section h1{animation:fadeIn 1s ease-in;color:#3b82f6;color:var(--primary-color);font-size:3rem;margin-bottom:1rem}.welcome-section p{animation:fadeIn 1s ease-in .3s backwards;color:#1f2937;color:var(--text-color);font-size:1.2rem;margin-bottom:3rem}.skills-section{background:#fff;background:var(--bg-color);border-radius:15px;box-shadow:0 4px 6px #0000001a;margin:2rem 0;padding:4rem 0}.skills-section h2{animation:fadeIn 1s ease-in .6s backwards;color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:3rem;text-align:center}.skills-container{animation:fadeIn 1s ease-in .9s backwards;margin:0 auto;max-width:800px;padding:0 2rem}.skills-container .skill-bar{background:#f3f4f6;background:var(--gray-100);border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem;overflow:hidden;transition:all .3s ease}.skills-container .skill-bar:hover{box-shadow:0 4px 8px #00000026;transform:translateX(5px)}.skills-container .skill-bar .skill-name{color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.skills-container .skill-bar .skill-level{border-radius:6px;height:12px;transition:all .5s ease}.skills-placeholder{padding:2rem;text-align:center}.skills-placeholder p{color:#6b7280;color:var(--gray-500);font-size:1.2rem;margin-bottom:2rem}.skills-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0 auto;max-width:600px}.skill-item-preview{align-items:center;background:#f9fafb;background:var(--gray-50);border-left:4px solid #3b82f6;border-left:4px solid var(--primary-color);border-radius:10px;display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease}.skill-item-preview:hover{background:#f3f4f6;background:var(--gray-100);transform:translateX(5px)}.skill-item-preview .skill-name{color:#1f2937;color:var(--text-color);font-weight:600}.skill-item-preview .skill-level{background:#3b82f6;background:var(--primary-color);border-radius:999px;color:#fff;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.services-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));padding:2rem 0}.service-card{animation:fadeIn 1s ease-in .6s backwards;background:#fff;background:var(--bg-color);border-radius:15px;box-shadow:0 4px 6px #0000001a;padding:2rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.service-card:hover{box-shadow:0 8px 12px #00000026;transform:translateY(-10px)}.service-icon{font-size:3rem}.service-card h2,.service-icon{color:#3b82f6;color:var(--primary-color);margin-bottom:1rem}.service-card p{color:#1f2937;color:var(--text-color);margin-bottom:1.5rem}.service-link{background-color:#3b82f6;background-color:var(--primary-color);border-radius:25px;color:#fff;display:inline-block;padding:.8rem 1.5rem;text-decoration:none;transition:background-color .3s ease}.service-link:hover{background-color:#2563eb;background-color:var(--primary-dark)}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));padding:2rem 0}.project-card{background:#ffffffe6;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:20px;box-shadow:0 10px 30px #0000001a;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.project-card:before{background:linear-gradient(90deg,#3b82f6,#6366f1);background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;top:0;transform:scaleX(0);transform-origin:left;transition:transform .3s ease;width:100%}.project-card:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.project-card:hover:before{transform:scaleX(1)}.project-header{align-items:flex-start;display:flex;margin-bottom:1.5rem}.project-icon{color:#3b82f6;color:var(--primary-color);font-size:2rem;margin-right:1rem}.project-title{flex:1 1}.project-title h3{color:#3b82f6;color:var(--primary-color);font-size:1.5rem;margin-bottom:.5rem}.project-period{color:#9ca3af;color:var(--gray-400);font-size:.9rem}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.tech-tag{background:#f3f4f6;background:var(--gray-100);color:#3b82f6;color:var(--primary-color);font-size:.85rem;padding:.25rem .75rem}.project-description{color:#6b7280;color:var(--gray-500);line-height:1.6;margin-bottom:1.5rem}.project-features{list-style:none;margin:0;padding:0}.project-features li{color:#6b7280;color:var(--gray-500);margin-bottom:.5rem;padding-left:1.5rem;position:relative}.project-features li:before{color:#3b82f6;color:var(--primary-color);content:"•";left:.5rem;position:absolute}.project-image{border-radius:10px;height:200px;margin-bottom:1.5rem;object-fit:cover;width:100%}.game-project{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.game-project .project-icon{color:#6366f1}.ai-project{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.ai-project .project-icon{color:#8b5cf6}.research-project{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.research-project .project-icon{color:#10b981}.note-link{align-items:center;border-radius:4px;color:#1f2937;color:var(--text-color);display:flex;padding:.5rem .75rem;text-decoration:none;transition:background-color .3s}.note-link i{color:#3b82f6;color:var(--primary-color);margin-right:.5rem}.note-link:hover{background-color:#3b82f6;background-color:var(--primary-color);color:#fff}.note-link:hover i{color:#fff}.note-content h1{border-bottom:2px solid #3b82f6;border-bottom:2px solid var(--primary-color);color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.blog-content{padding:2rem}.blog-content h1{color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:1.5rem}.blog-posts{grid-gap:2rem;display:grid;gap:2rem;margin-top:2rem}.blog-post{background:#fff;background:var(--bg-color);border-left:4px solid #3b82f6;border-left:4px solid var(--primary-color);border-radius:15px;box-shadow:0 4px 6px #0000001a;padding:2rem;transition:all .3s ease}.blog-post:hover{box-shadow:0 8px 12px #00000026;transform:translateY(-5px)}.post-header{margin-bottom:1.5rem}.post-title{color:#3b82f6;color:var(--primary-color);font-size:1.8rem;margin-bottom:1rem}.post-meta{color:#6b7280;color:var(--gray-500);display:flex;flex-wrap:wrap;font-size:.9rem;gap:2rem}.post-meta span{align-items:center;display:flex;gap:.5rem}.post-excerpt{color:#1f2937;color:var(--text-color);line-height:1.6;margin-bottom:1.5rem}.read-more{align-items:center;color:#3b82f6;color:var(--primary-color);display:inline-flex;font-weight:500;gap:.5rem;text-decoration:none;transition:all .3s ease}.read-more:hover{color:#2563eb;color:var(--primary-dark);transform:translateX(5px)}.course-content{padding:2rem}.course-content h1{color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:1.5rem}.course-sections{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:2rem 0}.course-section{background:#f9fafb;background:var(--gray-50);border-left:4px solid #3b82f6;border-left:4px solid var(--primary-color);border-radius:15px;padding:2rem}.course-section h2{color:#3b82f6;color:var(--primary-color);margin-bottom:1rem}.course-section ul{list-style:none;padding:0}.course-section li{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);padding:.5rem 0 .5rem 1.5rem;position:relative}.course-section li:before{color:#3b82f6;color:var(--primary-color);content:"•";left:0;position:absolute}.course-materials{background:#f9fafb;background:var(--gray-50);border-radius:15px;margin-top:2rem;padding:2rem}.course-materials h2{color:#3b82f6;color:var(--primary-color);margin-bottom:1rem}.about,.contact,.education,.experience,.skills{margin-bottom:4rem}.about h2,.contact h2,.education h2,.experience h2,.skills h2{color:#3b82f6;color:var(--primary-color);font-size:2rem;margin-bottom:1.5rem;text-align:center}.about-content,.education-content{margin:0 auto;max-width:800px;text-align:center}.hero-section{align-items:center;background:#fff;background:var(--bg-color);border-radius:20px;box-shadow:0 10px 30px #0000001a;display:flex;gap:3rem;margin:2rem 0;padding:2rem}.hero-text{flex:1 1;text-align:left}.hero-text p{color:#1f2937;color:var(--text-color);font-size:1.1rem;line-height:1.8;margin:0}.hero-image{align-items:center;animation:float 6s ease-in-out infinite;display:flex;flex:1 1;justify-content:center;transform:translateY(-20px)}.profile-image{animation:morph 8s ease-in-out infinite;border:4px solid #3b82f6;border:4px solid var(--primary-color);border-radius:30% 70% 70% 30%/30% 30% 70% 70%;box-shadow:0 10px 20px #0000001a,0 6px 6px #0000001a;height:320px;object-fit:cover;width:320px}@keyframes morph{0%,to{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}25%{border-radius:58% 42% 75% 25%/76% 46% 54% 24%}50%{border-radius:50% 50% 33% 67%/55% 27% 73% 45%}75%{border-radius:33% 67% 58% 42%/63% 68% 32% 37%}}.education-item{background:#f9fafb;background:var(--gray-50);border-radius:15px;margin-bottom:1rem;padding:2rem}.education-item h3{color:#3b82f6;color:var(--primary-color);margin-bottom:.5rem}.department,.period{color:#6b7280;color:var(--gray-500);margin-bottom:.5rem}.timeline{margin:0 auto;max-width:1000px;padding:2rem 0;position:relative}.timeline:before{background:linear-gradient(180deg,#3b82f6,#6366f1 50%,#3b82f6);background:linear-gradient(180deg,var(--primary-color) 0,var(--secondary-color) 50%,var(--primary-color) 100%);content:"";height:100%;left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}.experience-item{margin-bottom:4rem;position:relative;width:calc(50% - 30px)}.experience-item:nth-child(odd){left:0;padding-right:3rem}.experience-item:nth-child(2n){left:50%;margin-top:-2rem;padding-left:3rem}.experience-content{background:#ffffffe6;border-radius:20px;box-shadow:0 10px 30px #0000001a;padding:2rem;position:relative;transition:all .3s ease}.experience-content:before{background:#3b82f6;background:var(--primary-color);border-radius:50%;content:"";height:20px;position:absolute;top:50%;width:20px}.experience-item:nth-child(odd) .experience-content:before{right:-40px;transform:translateY(-50%)}.experience-item:nth-child(2n) .experience-content:before{left:-40px;transform:translateY(-50%)}.experience-content:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.company{margin-bottom:1rem}.company,.company-icon{align-items:center;display:flex}.company-icon{background:#3b82f6;background:var(--primary-color);border-radius:12px;height:50px;justify-content:center;margin-right:1rem;width:50px}.company-icon i{color:#fff;font-size:1.5rem}.company-info h3{color:#3b82f6;color:var(--primary-color);font-size:1.5rem;margin-bottom:.25rem}.position{color:#6b7280;color:var(--gray-500);font-size:1.1rem;font-weight:500}.period{background:#f3f4f6;background:var(--gray-100);border-radius:999px;color:#3b82f6;color:var(--primary-color);display:inline-block;font-size:.9rem;margin:1rem 0;padding:.5rem 1rem}.responsibilities{list-style:none;margin:0;padding:0}.responsibilities li{color:#6b7280;color:var(--gray-500);line-height:1.6;margin-bottom:.75rem;padding-left:1.5rem;position:relative}.responsibilities li:before{color:#3b82f6;color:var(--primary-color);content:"•";font-weight:700;left:.5rem;position:absolute}.skills-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.skill-category{background:#ffffffe6;border-radius:20px;box-shadow:0 10px 30px #0000001a;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.skill-category:before{background:linear-gradient(90deg,#3b82f6,#6366f1);background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;top:0;transform:scaleX(0);transform-origin:left;transition:transform .3s ease;width:100%}.skill-category:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.skill-category:hover:before{transform:scaleX(1)}.skill-category h3{align-items:center;color:#3b82f6;color:var(--primary-color);display:flex;font-size:1.5rem;gap:.75rem;margin-bottom:1.5rem}.skill-category h3 i{font-size:1.25rem}.skill-list{list-style:none;margin:0;padding:0}.skill-item{align-items:center;background:#f9fafb;background:var(--gray-50);border-radius:12px;display:flex;margin-bottom:1rem;padding:.75rem;transition:all .3s ease}.skill-item:hover{background:#f3f4f6;background:var(--gray-100);transform:translateX(5px)}.skill-icon{align-items:center;background:#3b82f6;background:var(--primary-color);border-radius:10px;display:flex;height:40px;justify-content:center;margin-right:1rem;width:40px}.skill-icon i{color:#fff;font-size:1.25rem}.skill-info{flex:1 1}.skill-name{color:#1f2937;color:var(--text-color);font-weight:500;margin-bottom:.25rem}.skill-detail{color:#6b7280;color:var(--gray-500);font-size:.9rem}.skill-badge{background:#3b82f6;background:var(--primary-color);border-radius:999px;color:#fff;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.contact-content{align-items:center;margin-top:2rem}.contact-content,.contact-info{display:flex;gap:2rem;justify-content:center}.contact-info{flex-wrap:wrap}.contact-item{background:#ffffffe6;border-radius:20px;box-shadow:0 10px 30px #0000001a;min-width:250px;padding:2rem;text-align:center;transition:all .3s ease}.contact-item:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.contact-item i{color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:1rem}.contact-item a{color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:500;text-decoration:none;transition:all .3s ease}.contact-item a:hover{color:#3b82f6;color:var(--primary-color)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.welcome-section h1{font-size:2rem}.notes-container,.projects-grid,.services-grid{grid-template-columns:1fr}.notes-sidebar{height:auto;max-height:300px}.note-content{height:auto}.timeline:before{left:30px}.experience-item{padding-left:70px!important;padding-right:0!important;width:100%}.experience-item:nth-child(2n),.experience-item:nth-child(odd){left:0;margin-top:0}.experience-content:before{left:-40px!important}.skills-grid{grid-template-columns:1fr}.contact-content{flex-direction:column}.contact-item{width:100%}.course-sections{grid-template-columns:1fr}.hero-section{flex-direction:column;gap:2rem;padding:1.5rem}.hero-text{text-align:center}.hero-text p{font-size:1rem}.profile-image{height:250px;width:250px}.project-meta{flex-direction:column;gap:1rem}.feature-list,.project-gallery{grid-template-columns:1fr}.project-links{flex-direction:column}.project-link{justify-content:center;width:100%}}.projects-content{margin-bottom:3rem;padding:2rem 0;text-align:center}.projects-content h1{color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:1rem}.projects-content p{color:#6b7280;color:var(--gray-500);font-size:1.1rem;margin:0 auto;max-width:600px}.project-details{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;padding:2rem;transition:all .3s ease}.project-details:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.project-header{margin-bottom:2rem}.project-title{color:#3b82f6;color:var(--primary-color);font-size:2rem;margin-bottom:1rem}.project-meta{color:#6b7280;color:var(--gray-500);display:flex;gap:2rem;margin-bottom:1.5rem}.project-meta span{align-items:center;display:flex;gap:.5rem}.project-description{color:var(--gray-600);font-size:1.1rem;line-height:1.8;margin-bottom:2rem}.project-gallery{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.gallery-item{border-radius:10px;box-shadow:0 4px 6px #0000001a;overflow:hidden;transition:all .3s ease}.gallery-item:hover{box-shadow:0 8px 12px #00000026;transform:translateY(-5px)}.gallery-item img{display:block;height:auto;transition:transform .3s ease;width:100%}.gallery-item:hover img{transform:scale(1.05)}.project-features{margin-bottom:2rem}.project-features h3{color:#3b82f6;color:var(--primary-color);font-size:1.5rem;margin-bottom:1.5rem}.feature-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));list-style:none}.feature-item{align-items:flex-start;background:#f9fafb;background:var(--gray-50);border-radius:10px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.feature-item:hover{background:#f3f4f6;background:var(--gray-100);transform:translateX(5px)}.feature-icon{color:#3b82f6;color:var(--primary-color);font-size:1.5rem;margin-top:.25rem}.feature-content h4{color:#1f2937;color:var(--text-color);font-size:1.1rem;margin-bottom:.5rem}.feature-content p{color:#6b7280;color:var(--gray-500);font-size:.9rem;line-height:1.5}.tech-stack{margin-bottom:2rem}.tech-stack h3{color:#3b82f6;color:var(--primary-color);font-size:1.5rem;margin-bottom:1rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.75rem}.tech-tag{background:#3b82f6;background:var(--primary-color);border-radius:999px;color:#fff;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.tech-tag:hover{background:#2563eb;background:var(--primary-dark);transform:translateY(-2px)}.project-links{display:flex;flex-wrap:wrap;gap:1rem}.project-link{align-items:center;border-radius:999px;display:inline-flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.primary-link{background:#3b82f6;background:var(--primary-color);color:#fff}.secondary-link{background:#f3f4f6;background:var(--gray-100);color:#1f2937;color:var(--text-color)}.project-link:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.primary-link:hover{background:#2563eb;background:var(--primary-dark)}.secondary-link:hover{background:#e5e7eb;background:var(--gray-200)}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.navigation-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#3b82f6f2;box-shadow:0 1px 3px #0003;position:fixed;top:0;transition:all .3s ease;width:100%;z-index:1000}.navigation-header.scrolled{background-color:#3b82f6fa;box-shadow:0 4px 6px #0003}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 2rem}.nav-logo{color:#fff;font-size:1.5rem;font-weight:700;position:relative;text-decoration:none;transition:all .3s ease}.nav-logo:after{background-color:#fff;bottom:-4px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-logo:hover:after{width:100%}.nav-links{display:flex;gap:2.5rem;list-style:none;margin:0;padding:0}.nav-link{color:#ffffffe6;gap:.5rem;padding:.5rem 0;position:relative}.nav-link:after{background-color:#fff;bottom:0;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-link.active,.nav-link:hover{color:#fff}.nav-link.active:after,.nav-link:hover:after{width:100%}.nav-link i{font-size:1.1rem}@media (max-width:768px){.nav-links{display:none}.nav-container{padding:1rem}}.slick-slider{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;box-sizing:border-box;touch-action:pan-y;-webkit-user-select:none;user-select:none;-khtml-user-select:none}.slick-list,.slick-slider{display:block;position:relative}.slick-list{margin:0;overflow:hidden;padding:0}.slick-list:focus{outline:none}.slick-list.dragging{cursor:pointer;cursor:hand}.slick-slider .slick-list,.slick-slider .slick-track{transform:translateZ(0)}.slick-track{display:block;left:0;margin-left:auto;margin-right:auto;position:relative;top:0}.slick-track:after,.slick-track:before{content:"";display:table}.slick-track:after{clear:both}.slick-loading .slick-track{visibility:hidden}.slick-slide{display:none;float:left;height:100%;min-height:1px}[dir=rtl] .slick-slide{float:right}.slick-slide img{display:block}.slick-slide.slick-loading img{display:none}.slick-slide.dragging img{pointer-events:none}.slick-initialized .slick-slide{display:block}.slick-loading .slick-slide{visibility:hidden}.slick-vertical .slick-slide{border:1px solid #0000;display:block;height:auto}.slick-arrow.slick-hidden{display:none}.slick-loading .slick-list{background:#fff url(data:image/gif;base64,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) 50% no-repeat}@font-face{font-family:slick;font-style:normal;font-weight:400;src:url(../../static/media/slick.a4e97f5a2a64f0ab1323.eot);src:url(../../static/media/slick.a4e97f5a2a64f0ab1323.eot?#iefix) format("embedded-opentype"),url(../../static/media/slick.295183786cd8a1389865.woff) format("woff"),url(../../static/media/slick.c94f7671dcc99dce43e2.ttf) format("truetype"),url(../../static/media/slick.2630a3e3eab21c607e21.svg#slick) format("svg")}.slick-next,.slick-prev{border:none;cursor:pointer;display:block;font-size:0;height:20px;line-height:0;padding:0;position:absolute;top:50%;transform:translateY(-50%);width:20px}.slick-next,.slick-next:focus,.slick-next:hover,.slick-prev,.slick-prev:focus,.slick-prev:hover{background:#0000;color:#0000;outline:none}.slick-next:focus:before,.slick-next:hover:before,.slick-prev:focus:before,.slick-prev:hover:before{opacity:1}.slick-next.slick-disabled:before,.slick-prev.slick-disabled:before{opacity:.25}.slick-next:before,.slick-prev:before{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:slick;line-height:1;opacity:.75}.slick-prev{left:-25px}[dir=rtl] .slick-prev{left:auto;right:-25px}.slick-prev:before{content:"←"}[dir=rtl] .slick-prev:before{content:"→"}.slick-next{right:-25px}[dir=rtl] .slick-next{left:-25px;right:auto}.slick-next:before{content:"→"}[dir=rtl] .slick-next:before{content:"←"}.slick-dotted.slick-slider{margin-bottom:30px}.slick-dots{bottom:-25px;display:block;list-style:none;margin:0;padding:0;position:absolute;text-align:center;width:100%}.slick-dots li{display:inline-block;margin:0 5px;padding:0;position:relative}.slick-dots li,.slick-dots li button{cursor:pointer;height:20px;width:20px}.slick-dots li button{background:#0000;border:0;color:#0000;display:block;font-size:0;line-height:0;outline:none;padding:5px}.slick-dots li button:focus,.slick-dots li button:hover{outline:none}.slick-dots li button:focus:before,.slick-dots li button:hover:before{opacity:1}.slick-dots li button:before{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#000;content:"•";font-family:slick;font-size:6px;height:20px;left:0;line-height:20px;opacity:.25;position:absolute;text-align:center;top:0;width:20px}.slick-dots li.slick-active button:before{color:#000;opacity:.75}.carousel-container{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);margin:0 auto;padding:2rem 0;width:100%}.carousel-title{color:#3b82f6;font-size:2.5rem;font-weight:700;margin-bottom:2rem;text-align:center}.image-carousel{margin:0 auto;max-width:1200px;padding:0 2rem}.carousel-slide{padding:0 1rem}.carousel-image{border-radius:15px;box-shadow:0 10px 30px #0000001a;height:400px;object-fit:cover;transition:transform .3s ease;width:100%}.carousel-image:hover{transform:scale(1.02)}.slick-next,.slick-prev{background:#3b82f6cc!important;border-radius:50%;height:40px;width:40px;z-index:1}.slick-next:hover,.slick-prev:hover{background:#3b82f6!important}.slick-prev{left:20px}.slick-next{right:20px}.slick-next:before,.slick-prev:before{color:#fff;font-size:20px}.slick-dots{bottom:20px}.slick-dots li button:before{color:#3b82f680;font-size:12px}.slick-dots li.slick-active button:before{color:#3b82f6}@media (max-width:768px){.carousel-title{font-size:2rem;margin-bottom:1.5rem}.image-carousel{padding:0 1rem}.carousel-image{height:300px}.slick-next,.slick-prev{height:35px;width:35px}.slick-prev{left:10px}.slick-next{right:10px}}.page-layout{background-color:#f9fafb;min-height:100vh}.page-main{transition:padding-top .3s ease}.page-content{background:#fff;border-radius:15px;box-shadow:0 4px 6px #0000001a;margin:2rem auto;max-width:1200px;padding:2rem}@media (max-width:768px){.page-content{margin:1rem;padding:1rem}}:root{--primary-color:#3b82f6;--primary-dark:#2563eb;--secondary-color:#6366f1;--text-color:#1f2937;--bg-color:#fff;--accent-color:#f3f4f6}.markdown-content{color:#1f2937;color:var(--text-color);font-family:Noto Sans TC,sans-serif;line-height:1.8}.markdown-content h1{border-bottom:2px solid #3b82f6;border-bottom:2px solid var(--primary-color);color:#3b82f6;color:var(--primary-color);font-size:2.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.markdown-content h2{color:#2563eb;color:var(--primary-dark);font-size:2rem;margin:2rem 0 1rem}.markdown-content h3{color:#6366f1;color:var(--secondary-color);font-size:1.5rem;margin:1.5rem 0 1rem}.markdown-content h4{color:#4f46e5;font-size:1.25rem;margin:1.25rem 0 .75rem}.markdown-content h5{color:#4338ca;font-size:1.125rem;margin:1rem 0 .5rem}.markdown-content h6{color:#3730a3;font-size:1rem;margin:.75rem 0 .5rem}.markdown-content p{line-height:1.8;margin-bottom:1rem}.markdown-content pre{border:1px solid #e5e7eb;border-radius:8px;margin:1rem 0;overflow-x:auto;padding:1rem}.markdown-content code,.markdown-content pre{background:#f3f4f6;background:var(--accent-color);font-family:Fira Code,monospace}.markdown-content code{border-radius:4px;color:#dc2626;font-size:.9em;padding:.2rem .4rem}.markdown-content pre code{background:none;color:inherit;padding:0}.markdown-content blockquote{border-left:4px solid #3b82f6;border-left:4px solid var(--primary-color);color:#4b5563;font-style:italic;margin:1rem 0;padding-left:1rem}.markdown-content ol,.markdown-content ul{margin:1rem 0;padding-left:2rem}.markdown-content li{margin-bottom:.5rem}.markdown-content table{border-collapse:collapse;font-size:.9rem;margin:1rem 0;width:100%}.markdown-content td,.markdown-content th{border:1px solid #e5e7eb;padding:.75rem;text-align:left}.markdown-content th{background-color:#f3f4f6;background-color:var(--accent-color);font-weight:600}.markdown-content img{border-radius:8px;box-shadow:0 2px 4px #0000001a;height:auto;margin:1rem 0;max-width:100%}.markdown-content a{color:#3b82f6;color:var(--primary-color);text-decoration:none;transition:color .3s ease}.markdown-content a:hover{color:#2563eb;color:var(--primary-dark);text-decoration:underline}.markdown-content hr{border:none;border-top:2px solid #e5e7eb;margin:2rem 0}.notes-container{grid-gap:2rem;background:#fff;background:var(--bg-color);border-radius:15px;box-shadow:0 4px 6px #0000001a;display:grid;gap:2rem;grid-template-columns:260px 1fr;margin:2rem auto;max-width:95%;overflow:hidden}.notes-sidebar{background:#f3f4f6;background:var(--accent-color);height:calc(100vh - 200px);overflow-y:auto;padding:1.5rem}.notes-sidebar .list-group-item{background:#0000;border:none;border-radius:4px;margin-bottom:.25rem;padding:.5rem .75rem;transition:background-color .3s}.notes-sidebar .list-group-item:hover{background-color:#3b82f61a!important}.notes-sidebar .list-group-item.bg-primary{background-color:#3b82f6!important;background-color:var(--primary-color)!important;border-radius:4px;color:#fff;margin:2px 0}.note-content{height:calc(100vh - 200px);overflow-y:auto;padding:2rem}@media (max-width:768px){.notes-container{grid-template-columns:1fr;margin:1rem}.notes-sidebar{height:auto;max-height:300px}.note-content{height:auto}.markdown-content h1{font-size:2rem}.markdown-content h2{font-size:1.75rem}.markdown-content h3{font-size:1.5rem}.markdown-content pre{font-size:.85rem}.markdown-content table{font-size:.8rem}}.clickable-card{cursor:pointer;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.clickable-card:after{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease}.clickable-card:hover:after{opacity:1}.clickable-card:active{transform:translateY(-5px) scale(.98)}.enter-course-hint{align-items:center;background:#ffffff26;border:2px solid #fff3;border-radius:12px;color:#ffffffe6;display:flex;font-size:.95rem;font-weight:600;justify-content:center;padding:1rem;transition:all .3s ease}.clickable-card:hover .enter-course-hint{background:#ffffff40;border-color:#fff6;box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.enter-course-hint i{transition:transform .3s ease}.clickable-card:hover .enter-course-hint i{transform:translateX(5px)}.text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.course-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:20px;display:flex;gap:3rem;justify-content:center;margin-top:2rem;padding:2rem}.stat-item{align-items:center;display:flex;flex-direction:column;gap:.5rem}.stat-icon{color:#667eea;font-size:2rem;margin-bottom:.5rem}.stat-number{color:#333;font-size:2rem;font-weight:700}.stat-label{color:#666;font-size:.9rem;letter-spacing:1px;text-transform:uppercase}.course-card{border:none;border-radius:20px;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.course-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.course-card:hover:before{transform:scaleX(1)}.course-card:hover{box-shadow:0 20px 40px #00000026!important;transform:translateY(-10px) scale(1.02)}.primary-gradient{background:linear-gradient(135deg,#667eea,#764ba2)}.success-gradient{background:linear-gradient(135deg,#56ab2f,#a8e6cf)}.warning-gradient{background:linear-gradient(135deg,#f093fb,#f5576c)}.icon-wrapper{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto;position:relative;width:80px}.primary-icon{background:linear-gradient(135deg,#667eea33,#764ba233)}.success-icon{background:linear-gradient(135deg,#56ab2f33,#a8e6cf33)}.warning-icon{background:linear-gradient(135deg,#f093fb33,#f5576c33)}.course-icon{color:#333;transition:all .3s ease}.course-card:hover .course-icon{transform:scale(1.1) rotate(5deg)}.course-details{background:#ffffff1a;border-radius:15px;margin:1rem 0;padding:1.5rem}.detail-row{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:.5rem 0}.detail-row:last-child{border-bottom:none}.detail-label{align-items:center;color:#fffc;display:flex;font-size:.9rem}.detail-value{color:#fff;font-weight:600}.detail-value.price{color:gold;font-size:1.1rem;font-weight:700}.course-features{text-align:left}.course-features h6{color:#fff;margin-bottom:1rem}.features-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.feature-tag{align-items:center;background:#ffffff1a;border-radius:8px;color:#ffffffe6;display:flex;font-size:.8rem;padding:.3rem .5rem;transition:all .3s ease}.feature-tag:hover{background:#fff3;transform:translateX(5px)}.feature-tag i{color:#4ade80;margin-right:.3rem}.course-btn{background:#fff3!important;border:2px solid #ffffff4d!important;color:#fff!important;font-weight:600;overflow:hidden;position:relative;transition:all .3s ease}.course-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.course-btn:hover:before{left:100%}.course-btn:hover{background:#ffffff4d!important;box-shadow:0 10px 20px #0003;transform:translateY(-2px)}.contact-info{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid #667eea1a;border-radius:20px;padding:3rem}.badge-pill{border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:1px;padding:.5rem 1rem;text-transform:uppercase}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.course-card{animation:fadeInUp .6s ease-out}.course-card:first-child{animation-delay:.1s}.course-card:nth-child(2){animation-delay:.2s}.course-card:nth-child(3){animation-delay:.3s}@media (max-width:768px){.course-stats{flex-direction:column;gap:1.5rem;padding:1.5rem}.features-grid{grid-template-columns:1fr}.detail-row{align-items:flex-start;flex-direction:column;gap:.3rem}.contact-info{padding:2rem 1rem}.display-4{font-size:2.5rem}.lead{font-size:1.1rem}}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.course-stats{animation:slideInFromBottom .8s ease-out}.course-card:hover .icon-wrapper{box-shadow:0 10px 20px #0003;transform:scale(1.1)}.course-card ::selection{background:#ffffff4d;color:#fff}.course-btn:focus{box-shadow:0 0 0 .2rem #ffffff40}.password-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#667eea,#764ba2);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.password-modal{animation:modalSlideIn .6s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;text-align:center;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.password-icon{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:50%;box-shadow:0 10px 30px #3498db4d;color:#fff;display:flex;font-size:40px;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.password-title{color:#2c3e50;font-size:28px;font-weight:700;margin-bottom:10px}.password-subtitle{color:#7f8c8d;font-size:16px;margin-bottom:30px}.password-input{border:2px solid #ecf0f1;border-radius:10px;box-sizing:border-box;font-size:16px;margin-bottom:20px;padding:15px 20px;transition:all .3s ease;width:100%}.password-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.password-button{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;margin-bottom:15px;padding:15px 30px;transition:all .3s ease;width:100%}.password-button:hover{box-shadow:0 10px 25px #3498db4d;transform:translateY(-2px)}.password-button:active{transform:translateY(0)}.password-button:disabled{cursor:not-allowed;opacity:.8}.password-error{color:#e74c3c;font-size:14px;margin-top:10px;opacity:0;transition:opacity .3s ease}.password-error.show{opacity:1}.password-hint{color:#95a5a6;font-size:12px;margin-top:15px}.shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.success-animation{animation:successPulse .6s ease-out}@keyframes successPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@media (max-width:768px){.password-modal{margin:20px;padding:30px 20px}.password-title{font-size:24px}.password-subtitle{font-size:14px}.password-icon{font-size:30px;height:60px;width:60px}}.robot-page{background-color:#f5f5f5;color:#333;font-family:Microsoft JhengHei,Arial,sans-serif;line-height:1.6;margin:0;min-height:100vh;padding:70px 0 0}.logout-container{position:fixed;right:20px;top:90px;z-index:1000}.logout-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ff6b6b,#ee5a52);border:2px solid #ff6b6b;border-radius:25px;box-shadow:0 4px 15px #ff6b6b4d;font-weight:600;letter-spacing:.5px;padding:8px 20px;text-transform:uppercase;transition:all .3s ease}.logout-btn:hover{background:linear-gradient(135deg,#ff5252,#d32f2f);border-color:#ff5252;box-shadow:0 6px 20px #ff6b6b66;transform:translateY(-2px)}.logout-btn:active{box-shadow:0 2px 10px #ff6b6b4d;transform:translateY(0)}.logout-icon{animation:pulse 2s infinite;font-size:14px;margin-right:8px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-1{flex:1 1}.sidebar-nav{background:linear-gradient(180deg,#2c3e50,#34495e);box-shadow:2px 0 10px #0000001a;max-width:280px;min-height:100vh;padding:0;position:-webkit-sticky;position:sticky;top:0;width:100%}@media (max-width:768px){.sidebar-nav{max-width:100%;min-height:auto}.flex-col{flex-direction:column}.flex-row{flex-direction:row}}.nav-header{background:#ffffff1a;border-bottom:1px solid #ffffff1a;padding:25px 20px;text-align:center}.nav-header h2{color:#fff;font-size:20px;font-weight:600;margin:0}.nav-header .subtitle{color:#ffffffb3;font-size:12px;margin-top:5px}.nav-menu{padding:20px 0}.nav-item{margin:0;padding:0}.nav-link{align-items:center;border-left:3px solid #0000;color:#fffc;cursor:pointer;display:flex;font-weight:500;padding:15px 25px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#ffffff1a;transform:translateX(5px)}.nav-link.active,.nav-link:hover{border-left-color:#3498db;color:#fff}.nav-link.active{background:#3498db33}.nav-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:18px;margin-right:12px;text-align:center;transition:all .3s ease;width:24px}.nav-link:hover .nav-icon{filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));transform:scale(1.2) rotate(5deg)}.nav-link.active .nav-icon{filter:drop-shadow(0 3px 6px rgba(52,152,219,.3));transform:scale(1.1)}.nav-text{flex:1 1}.nav-status{background:#fff3;border-radius:10px;font-size:10px;padding:2px 6px}.main-content{flex:1 1;padding:20px}.container{background-color:#fff;border-radius:10px;box-shadow:0 0 20px #0000001a;margin:0 auto;max-width:1200px;padding:30px}h1{border-bottom:3px solid #3498db;color:#2c3e50;margin-bottom:30px;padding-bottom:10px;text-align:center}h2{border-left:4px solid #3498db;color:#34495e;margin-top:30px;padding-left:15px}h3{color:#2980b9;margin-top:25px}h4{color:#16a085;margin-top:20px}.video-container{background-color:#f8f9fa;border-radius:8px;margin:30px 0;padding:20px;text-align:center}video{border-radius:8px;box-shadow:0 4px 8px #0000001a;height:auto;max-width:100%}.course-overview{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:15px;margin:40px 0;padding:30px}.overview-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.overview-item{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:25px;text-align:center;transition:all .3s ease}.overview-item:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.overview-item.completed{border-color:#28a745}.overview-item.incomplete{border-color:#ffc107}.overview-icon{animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));font-size:48px;margin-bottom:15px;transition:all .3s ease}.overview-item:hover .overview-icon{filter:drop-shadow(0 6px 12px rgba(0,0,0,.2));transform:scale(1.1) rotate(5deg)}.overview-item.completed .overview-icon{animation:completedPulse 2s ease-in-out infinite}.overview-item.incomplete .overview-icon{animation:incompleteShake 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes completedPulse{0%,to{filter:drop-shadow(0 4px 8px rgba(40,167,69,.3));transform:scale(1)}50%{filter:drop-shadow(0 6px 12px rgba(40,167,69,.5));transform:scale(1.05)}}@keyframes incompleteShake{0%,to{transform:translateX(0)}25%{transform:translateX(-2px)}75%{transform:translateX(2px)}}.overview-item h3{color:#2c3e50;font-size:18px;margin:10px 0 5px}.overview-item p{color:#6c757d;font-size:14px;margin:0 0 15px}.status-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:700;padding:5px 12px;text-transform:uppercase}.overview-item.completed .status-badge{background:#d4edda;color:#155724}.overview-item.incomplete .status-badge{background:#fff3cd;color:#856404}.week-title{color:#2c3e50;font-size:1.5em;font-weight:700;margin-bottom:15px}.image-gallery{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:30px 0}.image-item{align-items:flex-start;display:flex;flex-direction:column;gap:10px;text-align:left}@media (min-width:768px){.image-item{align-items:center;flex-direction:row}.image-caption{margin-top:0}}.image-item img{border-radius:8px;box-shadow:0 2px 4px #0000001a;height:auto;max-width:100%}.image-caption{color:#666;font-style:italic}.content-image{border-radius:8px;box-shadow:0 2px 4px #0000001a;height:auto;margin:15px 0;max-width:100%}.exercise{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:5px;margin:15px 0;padding:15px}.exercise h4{color:#856404;margin-top:0}.note{background-color:#d1ecf1;border:1px solid #bee5eb;border-left:4px solid #17a2b8;border-radius:5px}.note,.warning{margin:10px 0;padding:10px}.warning{background-color:#f8d7da;border:1px solid #f5c6cb;border-left:4px solid #dc3545;border-radius:5px}.code-block{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:5px;font-family:Courier New,monospace;margin:15px 0;padding:15px}ol,ul{padding-left:20px}li{margin:5px 0}.highlight{background-color:#fff3cd;border-radius:3px;padding:2px 4px}@media (max-width:768px){.container{padding:20px}.image-gallery,.overview-grid{grid-template-columns:1fr}.sidebar-nav{order:2}.main-content{order:1}h1{font-size:1.8em}h2{font-size:1.5em}}
/*# sourceMappingURL=main.5383e922.css.map*/