:root{font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh}#root{width:100%;min-height:100vh}.profile-sidebar{position:sticky;top:2rem;text-align:center;padding:2.5rem 1.5rem;background-color:var(--ts-base-00);border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a;border:1px solid var(--ts-gray-200)}.theme-toggle-btn{position:absolute;top:1rem;right:1rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background-color:var(--ts-gray-100);color:var(--ts-gray-600);border:none;cursor:pointer;transition:all .2s ease}.theme-toggle-btn:hover{background-color:var(--ts-indigo-600);color:var(--ts-base-00);transform:translateY(-2px)}@media(prefers-color-scheme:dark){.profile-sidebar{box-shadow:0 1px 3px #0000004d,0 1px 2px -1px #0000004d}}.profile-image-wrapper{margin-bottom:1.25rem}.profile-image{width:140px;height:140px;border-radius:50%;object-fit:cover;border:4px solid var(--ts-base-00);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;margin:0 auto;display:block}@media(prefers-color-scheme:dark){.profile-image{box-shadow:0 4px 6px -1px #0006,0 2px 4px -2px #0006}}.profile-name{font-size:1.5rem;font-weight:800;margin-bottom:.5rem;letter-spacing:-.025em}.profile-title{color:var(--ts-gray-600);font-size:.9rem;margin-bottom:1.5rem;font-weight:500}.social-links{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}.profile-actions{margin-top:1.25rem}.profile-actions .cv-button{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;background-color:var(--ts-gray-100)!important;color:var(--ts-gray-700)!important;border:1px solid var(--ts-gray-200)!important;transition:all .2s ease}.profile-actions .cv-button:hover{background-color:var(--ts-gray-200)!important;color:var(--ts-gray-800)!important;transform:translateY(-1px)}.social-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background-color:var(--ts-gray-100);color:var(--ts-gray-600);transition:all .2s ease;text-decoration:none}.social-icon:hover{background-color:var(--ts-indigo-600);color:var(--ts-base-00);transform:translateY(-2px)}@media(max-width:900px){.profile-sidebar{position:static;margin-bottom:2rem}}.ts-timeline{margin-top:.5rem}.ts-timeline .item{margin-bottom:0}.ts-timeline .item .aside{min-width:100px;text-align:right;padding-right:1rem}.ts-timeline .item .content{line-height:1.6}.ts-timeline .item .content>div{margin-bottom:.25rem}.ts-timeline .item .content>div:last-child{margin-bottom:0}.ts-timeline .item .content .ts-text.is-bold{font-weight:700;color:var(--ts-gray-900)}.ts-timeline .item .content .ts-content.is-rounded.is-secondary{margin-top:.75rem}@media(max-width:768px){.ts-timeline .item .aside{min-width:80px;padding-right:.75rem}}.ts-timeline .item .content .vulnerability-link{color:inherit;text-decoration:none;transition:color .2s ease;display:block;line-height:1.6}.ts-timeline .item .content .vulnerability-link:hover{color:var(--ts-indigo-600)}.ts-timeline .item .aside:empty{min-width:100px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}@media(min-width:768px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}@media(min-width:1200px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}.project-card{padding:0;height:100%;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--ts-gray-200);border-radius:.75rem;background-color:var(--ts-base-00);transition:transform .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;cursor:pointer}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}@media(prefers-color-scheme:dark){.project-card:hover{box-shadow:0 10px 15px -3px #00000080,0 4px 6px -4px #00000080}}.project-image-wrapper{width:100%;aspect-ratio:16/9;overflow:hidden;border-bottom:1px solid var(--ts-gray-200);background-color:var(--ts-gray-100)}.project-image{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card:hover .project-image{transform:scale(1.05)}.project-content{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column}.project-title{font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.project-desc{color:var(--ts-gray-600);font-size:.9rem;margin-bottom:1.25rem;flex-grow:1;line-height:1.6}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.tech-tag{background-color:var(--ts-gray-100);border:1px solid var(--ts-gray-200);color:var(--ts-gray-600);padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-weight:500}.ts-modal.is-visible{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;background-color:transparent}.ts-modal__overlay{position:absolute;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1001}.ts-modal__container{position:relative;z-index:1002;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;background-color:var(--ts-gray-50);border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a;border:1px solid var(--ts-gray-200);padding:0;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(prefers-color-scheme:dark){.ts-modal__container{box-shadow:0 1px 3px #0000004d,0 1px 2px -1px #0000004d}}.ts-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--ts-gray-200)}.ts-modal__title{font-size:1.5rem;font-weight:700;color:var(--ts-gray-900)}.ts-modal__content{padding:1.5rem}.project-modal-image{width:100%;margin-bottom:2rem;border-radius:.75rem;overflow:hidden;background-color:var(--ts-gray-100);aspect-ratio:16/9;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.project-modal-image img{width:100%;height:100%;object-fit:cover;display:block}.project-modal-info{padding:0}.project-modal-summary,.project-modal-details{margin-bottom:2rem}.project-modal-summary-title,.project-modal-details-title,.project-modal-tags-title{font-size:1.1rem;font-weight:700;margin-bottom:1rem;color:var(--ts-gray-900);display:flex;align-items:center;gap:.5rem}.project-modal-summary-title:before,.project-modal-details-title:before,.project-modal-tags-title:before{content:"";width:4px;height:1.1rem;background-color:var(--ts-indigo-600);border-radius:2px}.project-modal-description{color:var(--ts-gray-600);font-size:1.05rem;line-height:1.8;margin-bottom:0;padding-left:calc(4px + .5rem)}.project-modal-detailed-description{color:var(--ts-gray-600);font-size:1rem;line-height:1.8;margin-bottom:0;padding-left:calc(4px + .5rem)}.project-modal-tags{margin-bottom:1.5rem}.project-modal-tags-list{display:flex;flex-wrap:wrap;gap:.5rem;padding-left:calc(4px + .5rem)}.project-modal-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--ts-gray-200);justify-content:flex-end}.project-modal-actions .ts-button{display:inline-flex;align-items:center;gap:.5rem}.project-modal-actions .ts-button .ts-icon{margin:0;flex-shrink:0;color:inherit!important}.project-modal-actions .ts-button .ts-icon:before,.project-modal-actions .ts-button .ts-icon:after{color:inherit!important}@media(max-width:768px){.vulnerability-item{flex-direction:column;gap:.5rem}.vulnerability-year{min-width:auto}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.project-modal-image{margin-bottom:1rem}.project-modal-info{padding:0}}.professional-footer{text-align:center;color:var(--ts-gray-400);margin-top:3rem;padding-top:2rem;border-top:1px solid var(--ts-gray-200);font-size:.85rem}.footer-content{padding:1rem 0}.app-container{max-width:1100px;margin:0 auto;padding:4rem 2rem}.professional-layout{display:grid;grid-template-columns:280px 1fr;gap:3rem;align-items:start}.main-content{display:flex;flex-direction:column;gap:2.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .6s ease-out forwards}.professional-card{background-color:var(--ts-base-00);border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a;border:1px solid var(--ts-gray-200);padding:2rem;transition:transform .2s ease,box-shadow .2s ease}@media(prefers-color-scheme:dark){.professional-card{box-shadow:0 1px 3px #0000004d,0 1px 2px -1px #0000004d}}.professional-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}@media(prefers-color-scheme:dark){.professional-card:hover{box-shadow:0 4px 6px -1px #0006,0 2px 4px -2px #0006}}.section-header{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--ts-gray-200);letter-spacing:-.01em;color:var(--ts-gray-900)}@media(max-width:900px){.professional-layout{grid-template-columns:1fr;gap:2rem}.app-container{padding:2rem 1rem}}.cv-container{max-width:1000px;margin:0 auto;padding:2rem;background-color:#fff;color:#1f2937}.cv-header{margin-bottom:3rem;padding:2.5rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.cv-header-content{display:flex;align-items:center;gap:2.5rem}.cv-profile-image-wrapper{flex-shrink:0;width:140px;height:140px;border-radius:50%;overflow:hidden;border:4px solid #ffffff;box-shadow:0 4px 6px -1px #0000001a;background-color:#f3f4f6}.cv-profile-image{width:100%;height:100%;object-fit:cover}.cv-header-text{flex:1;display:flex;flex-direction:column;gap:.75rem}.cv-header-text h1{font-size:2.5rem;font-weight:700;margin:0;color:#111827;letter-spacing:-.02em}.cv-subtitle{font-size:1.125rem;color:#6b7280;margin:0;font-weight:500}.cv-social-links{display:flex;justify-content:flex-start;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.cv-social-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background-color:#f3f4f6;color:#4b5563;transition:all .2s ease;text-decoration:none}.cv-social-icon:hover{background-color:#4f46e5;color:#fff;transform:translateY(-2px)}.cv-content{display:flex;flex-direction:column;gap:2rem}.cv-container .professional-card{background-color:#fff!important;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a}.cv-container .professional-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.cv-container .section-header{border-bottom-color:#e5e7eb;color:#111827}@media(max-width:768px){.cv-container{padding:1rem}.cv-header{padding:1.5rem;margin-bottom:2rem}.cv-header-content{flex-direction:column;text-align:center;gap:1.5rem}.cv-profile-image-wrapper{width:120px;height:120px}.cv-header-text h1{font-size:2rem}.cv-subtitle{font-size:1.1rem}.cv-social-links{justify-content:center;gap:.75rem}}@media(max-width:480px){.cv-header{padding:1.25rem}.cv-profile-image-wrapper{width:100px;height:100px}.cv-header-text h1{font-size:1.75rem}.cv-subtitle{font-size:1rem}.cv-social-links{justify-content:center;gap:.5rem}}.cv-attachment-link{display:inline-flex;align-items:center;gap:.4rem;margin-left:.5rem;color:#4f46e5;text-decoration:none;font-size:.85rem;transition:color .2s ease,transform .2s ease}.cv-attachment-link:hover{color:#4338ca;transform:translateY(-1px)}.cv-attachment-link .ts-icon{font-size:.9rem;color:#4f46e5;transition:color .2s ease}.cv-attachment-link:hover .ts-icon{color:#4338ca}.ts-timeline .item .content .cv-attachment-link{margin-top:.25rem;display:inline-flex}.work-detail-item{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #e5e7eb}.work-detail-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.work-detail-title{font-size:1rem;font-weight:700;color:#111827;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.work-detail-summary{font-size:.9rem;color:#4b5563;margin-bottom:.75rem;font-weight:500}.work-detail-item .ts-list{margin-top:.5rem}.work-detail-item .ts-list .item{line-height:1.7;color:#374151;font-size:.9rem}.certificate-modal-container{max-width:95%;width:1000px;max-height:90vh;display:flex;flex-direction:column}.certificate-modal-content{padding:0;display:flex;flex-direction:column;max-height:85vh;overflow:hidden}.certificate-iframe-wrapper{width:100%;max-height:70vh;overflow:auto;display:flex;justify-content:center;align-items:flex-start;background-color:#f9fafb;border-radius:.5rem;padding:1rem;position:relative}.certificate-iframe{width:100%;min-height:500px;height:70vh;max-height:70vh;border:none;background-color:#f9fafb;border-radius:.5rem;display:block}.certificate-image-wrapper{width:100%;max-height:70vh;overflow:auto;display:flex;justify-content:center;align-items:flex-start;background-color:#f9fafb;border-radius:.5rem;padding:1rem}.certificate-image{max-width:100%;max-height:70vh;width:auto;height:auto;object-fit:contain;border-radius:.25rem;box-shadow:0 4px 6px -1px #0000001a}.certificate-modal-actions{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;justify-content:flex-end}.certificate-modal-actions .ts-button{display:inline-flex;align-items:center;gap:.5rem}.certificate-modal-actions .ts-button .ts-icon{margin:0;flex-shrink:0;color:inherit!important}.certificate-modal-actions .ts-button .ts-icon:before,.certificate-modal-actions .ts-button .ts-icon:after{color:inherit!important}@media(max-width:768px){.certificate-modal-container{max-width:98%;width:98%}.certificate-iframe-wrapper{max-height:60vh;padding:.5rem}.certificate-iframe{height:60vh;max-height:60vh}.certificate-image-wrapper{max-height:60vh;padding:.5rem}}.language-switcher{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .2s ease}.language-switcher:hover{background-color:#f3f4f6;border-color:#d1d5db}.lang-option{color:#9ca3af;transition:color .2s ease}.lang-option.active{color:#374151;font-weight:600}.lang-divider{color:#d1d5db;margin:0 .125rem}.cv-header{position:relative}@media(max-width:768px){.language-switcher{top:.75rem;right:.75rem;padding:.375rem .5rem;font-size:.8rem}}@media(max-width:480px){.language-switcher{top:.5rem;right:.5rem;padding:.25rem .4rem;font-size:.75rem}}
