[data-theme=dark]{--bg:#080808;--bg2:#0f0f0f;--surface:#161616;--lift:#1e1e1e;--border:rgba(255, 255, 255, 0.08);--border2:rgba(255, 255, 255, 0.14);--fg:#f0f0f0;--fg2:#a0a0a0;--fg3:#f0f0f0;--cyan:#00e5ff;--cyan-dim:rgba(27, 31, 31, 0.12);--nav-bg:rgba(8, 8, 8, 0.95);--card-bg:#111111;--tog-bg:#1e1e1e;--noise:0.025}[data-theme=light]{--bg:#f8f8f8;--bg2:#f0f0f0;--surface:#e8e8e8;--lift:#e0e0e0;--border:rgba(0, 0, 0, 0.08);--border2:rgba(0, 0, 0, 0.15);--fg:#0a0a0a;--fg2:#505050;--fg3:#000000;--cyan:#0077aa;--cyan-dim:rgba(0, 119, 170, 0.08);--nav-bg:rgba(248, 248, 248, 0.96);--card-bg:#efefef;--tog-bg:#e0e0e0;--noise:0.012}*,::after,::before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-snap-type:y mandatory;overflow-y:scroll;height:100%}body{font-family:Outfit,'Noto Sans TC',sans-serif;background:var(--bg);color:var(--fg);overflow-x:hidden;cursor:none;transition:background .4s,color .4s;height:100%}@media (hover:none){body{cursor:auto}}body::before{content:'';position:fixed;inset:0;z-index:999;pointer-events:none;opacity:var(--noise);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;transition:opacity .4s}#cur-dot{position:fixed;z-index:9999;pointer-events:none;width:6px;height:6px;background:var(--cyan);border-radius:50%;transform:translate(-50%,-50%);transition:width .15s,height .15s}#cur-ring{position:fixed;z-index:9998;pointer-events:none;width:32px;height:32px;border:1px solid rgba(0,229,255,.4);border-radius:50%;transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s}[data-theme=light] #cur-ring{border-color:rgba(0,119,170,.35)}body.h #cur-dot{width:10px;height:10px}body.h #cur-ring{width:46px;height:46px;border-color:var(--cyan)}nav{position:fixed;top:0;left:0;right:0;z-index:500;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;background:var(--nav-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(16px);transition:background .4s,border-color .4s}.nav-logo{font-family:Unbounded,sans-serif;font-weight:800;font-size:1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg);text-decoration:none;display:flex;align-items:center;gap:.6rem;transition:color .3s}.nav-logo-accent{color:var(--cyan)}.nav-right{display:flex;align-items:center;gap:.75rem}.btn-cta{font-family:Unbounded,sans-serif;font-weight:700;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:var(--cyan);border:none;padding:.55rem 1.2rem;cursor:pointer;text-decoration:none;transition:opacity .2s,transform .15s;display:inline-flex;align-items:center}.btn-cta:hover{opacity:.85;transform:translateY(-1px)}.tog{background:var(--tog-bg);color:var(--fg);border:1px solid var(--border);padding:.35rem .65rem;font-family:Outfit,sans-serif;font-size:.65rem;letter-spacing:.1em;cursor:pointer;transition:border-color .2s,color .2s,background .4s}.tog:hover{border-color:var(--cyan);color:var(--cyan)}#langBtn .l-zh{display:inline}#langBtn .l-en{display:none}[data-lang=en] #langBtn .l-zh{display:none}[data-lang=en] #langBtn .l-en{display:inline}#themeBtn .t-dark{display:inline}#themeBtn .t-light{display:none}[data-theme=light] #themeBtn .t-dark{display:none}[data-theme=light] #themeBtn .t-light{display:inline}.nav-hamburger{display:flex;flex-direction:column;gap:5px;background:0 0;border:none;cursor:pointer;padding:.3rem}.nav-hamburger span{display:block;width:22px;height:1.5px;background:var(--fg);transition:transform .3s,opacity .3s}.nav-hamburger.open span:first-child{transform:translateY(6.5px) rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0}.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.nav-drawer{display:none;position:fixed;inset:0;z-index:490;background:var(--bg);flex-direction:column;padding:90px 2.5rem 3rem;gap:0;transition:background .4s}.nav-drawer.open{display:flex}.nav-drawer a{font-family:Unbounded,sans-serif;font-weight:700;font-size:2.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--fg);text-decoration:none;border-bottom:1px solid var(--border);padding:1.2rem 0;transition:color .2s}.nav-drawer a:hover{color:var(--cyan)}.drawer-bottom{margin-top:auto;display:flex;gap:1rem;align-items:center}.snap-section{scroll-snap-align:start;scroll-snap-stop:always;height:100vh;position:relative;display:flex;flex-direction:column}.snap-section.free{height:auto;min-height:100vh;scroll-snap-align:start;padding-bottom:2rem}#work.snap-section.free{min-height:auto;padding-bottom:0}.hero{height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 2.5rem;position:relative;overflow:hidden}.hero-grid{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(0,229,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,255,.04) 1px,transparent 1px);background-size:80px 80px}[data-theme=light] .hero-grid{background-image:linear-gradient(rgba(0,119,170,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,119,170,.05) 1px,transparent 1px)}.hero-lava{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;will-change:transform}.hero-lava-1{position:absolute;width:620px;height:620px;background:var(--cyan);top:-120px;left:-120px;border-radius:60% 40% 55% 45%/50% 60% 40% 50%;filter:blur(90px);opacity:.14;animation:lava1 18s ease-in-out infinite alternate,breathe1 5s ease-in-out infinite alternate;will-change:transform}.hero-lava-2{position:absolute;width:520px;height:520px;background:#ff8c42;bottom:-100px;right:-100px;border-radius:50% 50% 60% 40%/60% 40% 50% 50%;filter:blur(100px);opacity:.1;animation:lava2 22s ease-in-out infinite alternate,breathe2 6s ease-in-out infinite alternate;will-change:transform}.hero-lava-3{position:absolute;width:400px;height:400px;background:#c84bff;top:30%;left:40%;border-radius:45% 55% 50% 50%/55% 45% 60% 40%;filter:blur(110px);opacity:.08;animation:lava3 25s ease-in-out infinite alternate,breathe3 7s ease-in-out infinite alternate;will-change:transform}[data-theme=dark] .hero-lava-1{opacity:.22}[data-theme=dark] .hero-lava-2{opacity:.16}[data-theme=dark] .hero-lava-3{opacity:.13}@keyframes lava1{0%{transform:translate(0,0) scale(1) rotate(0)}33%{transform:translate(25vw,15vh) scale(1.2) rotate(60deg)}66%{transform:translate(15vw,30vh) scale(.8) rotate(140deg)}100%{transform:translate(45vw,10vh) scale(1.1) rotate(220deg)}}@keyframes lava2{0%{transform:translate(0,0) scale(1) rotate(0)}33%{transform:translate(-30vw,-20vh) scale(1.3) rotate(-85deg)}66%{transform:translate(-10vw,-45vh) scale(.7) rotate(-165deg)}100%{transform:translate(-35vw,-15vh) scale(1.1) rotate(-245deg)}}@keyframes lava3{0%{transform:translate(0,0) scale(1) rotate(0)}33%{transform:translate(-25vw,25vh) scale(1.2) rotate(60deg)}66%{transform:translate(30vw,-20vh) scale(.8) rotate(120deg)}100%{transform:translate(-15vw,30vh) scale(1.1) rotate(220deg)}}@keyframes breathe1{from{opacity:.1}to{opacity:.22}}@keyframes breathe2{from{opacity:.07}to{opacity:.18}}@keyframes breathe3{from{opacity:.05}to{opacity:.14}}.hero-swap-wrap{display:flex;align-items:baseline;gap:.6rem;margin-bottom:2rem;font-family:Outfit,sans-serif;font-size:.95rem;letter-spacing:.08em;color:var(--fg2);height:1.4em;overflow:hidden}.hero-swap-label{flex-shrink:0}#hero-lang-text{color:var(--cyan);font-weight:600;transition:opacity .3s ease,color .4s ease;display:inline-block;will-change:opacity}.hero-content{position:relative;z-index:2;max-width:900px;width:100%;text-align:center}.hero-eyebrow{font-family:Unbounded,sans-serif;font-size:.97rem;letter-spacing:.35em;text-transform:uppercase;color:var(--cyan);margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--cyan)}.hero-headline{font-family:Unbounded,'Noto Sans TC',sans-serif;font-weight:800;font-size:clamp(3rem, 7vw, 4.5rem);line-height:1.25;letter-spacing:-.02em;color:var(--fg);margin-bottom:2rem;transition:color .4s}[data-lang=en] .hero-headline{font-size:clamp(3.2rem, 7vw, 5rem);line-height:1.1}.hero-headline .line{display:block;overflow:hidden}.hero-sub{font-size:clamp(.95rem, 1.6vw, 1.1rem);color:var(--fg2);line-height:1.8;max-width:480px;margin-bottom:3rem;font-weight:300;transition:color .4s}[data-lang=en] .hero-sub{font-size:clamp(1rem, 1.65vw, 1.15rem)}.hero-actions{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.btn-primary{font-family:Unbounded,'Noto Sans TC',sans-serif;font-weight:700;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:var(--fg);padding:.9rem 2rem;min-width:200px;justify-content:center;text-decoration:none;display:inline-flex;align-items:center;gap:.75rem;transition:background .2s,color .2s,transform .15s;border:1px solid var(--fg)}.btn-primary:hover{background:var(--cyan);border-color:var(--cyan);transform:translateY(-2px)}.btn-secondary{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg2);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:.5rem;transition:color .2s}.btn-secondary:hover{color:var(--cyan)}.btn-secondary::after{content:'↓'}.hero-bottom{position:absolute;bottom:0;left:0;right:0;z-index:2;display:flex;justify-content:space-between;align-items:center;padding:1.2rem 2.5rem;border-top:1px solid var(--border);transition:border-color .4s}.hero-stat{text-align:center}.hero-stat-num{font-family:Unbounded,sans-serif;font-weight:800;font-size:1.6rem;color:var(--fg);line-height:1;transition:color .4s}.hero-stat-num span{color:var(--cyan)}.hero-stat-label{font-size:1rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3);margin-top:.2rem;transition:color .4s}.hero-avail{display:flex;align-items:center;gap:.5rem;font-size:.95rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg2)}.pulse{width:7px;height:7px;background:#00e676;border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(0,230,118,.4)}50%{box-shadow:0 0 0 5px rgba(0,230,118,0)}}.work-section{padding:64px 2.5rem 4rem;display:flex;flex-direction:column;max-width:1920px;margin:0 auto;width:100%}.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:.5rem;padding-bottom:.2rem;border-bottom:1px solid var(--border);flex-shrink:0;transition:border-color .4s}.section-label{font-family:Unbounded,sans-serif;font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem}.section-label::before{content:'';width:18px;height:1px;background:var(--cyan);display:block}.section-title{font-family:Unbounded,sans-serif;font-weight:800;font-size:clamp(1.8rem, 3.5vw, 2.8rem);color:var(--fg);letter-spacing:-.02em;line-height:1;transition:color .4s}.work-grid{display:flex;flex-direction:column;gap:16px;max-width:90%;margin:0}.work-card{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border);cursor:pointer;transition:background .2s;text-decoration:none;color:inherit}.work-card:hover{background:var(--surface)}.work-card-thumb{aspect-ratio:2/1;background-size:cover;background-position:center;background-color:var(--surface);position:relative;overflow:hidden;width:100%}.work-card-vis{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Noto Sans TC',sans-serif;font-weight:300;font-size:5rem;color:var(--fg);opacity:.06;transition:opacity .4s,transform .4s}.work-card:hover .work-card-vis{opacity:.12;transform:scale(1.04)}.work-card-body{display:flex;flex-direction:column;vertical-align:middle;justify-content:center;padding:2.5rem 3rem;gap:.5rem}.work-card-type{font-size:1rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan)}.work-card-name{font-family:Unbounded,sans-serif;font-weight:700;font-size:clamp(1rem, 2vw, 1.6rem);color:var(--fg);line-height:1.15;transition:color .2s}.work-card:hover .work-card-name{color:var(--cyan)}.work-card-sub{font-size:.85rem;color:var(--fg2);margin-top:.1rem}.work-card-arrow{font-size:4.1rem;color:var(--cyan);margin-top:.8rem;display:inline-block;transition:transform .2s}.work-card:hover .work-card-arrow{transform:translateX(5px)}@media (max-width:768px){.work-card{grid-template-columns:1fr}.work-card-thumb{aspect-ratio:16/9;max-height:220px}.work-card-body{padding:1rem 1.2rem 1.2rem;justify-content:flex-start;gap:.3rem}.work-card-arrow{font-size:2rem;margin-top:.4rem}}.about-section{padding:64px 2.5rem 2rem;display:grid;grid-template-columns:1fr 1fr;overflow:visible;gap:0;max-width:1920px;margin:0 auto;width:100%}.about-left{display:flex;flex-direction:column;justify-content:flex-start;vertical-align:top;padding:3rem 4rem 3rem 0;border-right:1px solid var(--border);transition:border-color .4s}.about-quote{font-family:Unbounded,sans-serif;font-weight:700;font-size:clamp(1.6rem, 2.8vw, 2.4rem);line-height:1.2;color:var(--fg);margin-bottom:2rem;letter-spacing:-.01em;transition:color .4s}.about-quote strong{color:var(--cyan);font-weight:800}.about-p{font-size:.85rem;line-height:1.9;color:var(--fg2);margin-bottom:1.2rem;font-weight:300;transition:color .4s}.about-p:last-of-type{margin-bottom:2rem}.about-closing{font-family:Unbounded,sans-serif;font-weight:700;font-size:1rem;color:var(--fg);letter-spacing:.02em;border-left:3px solid var(--cyan);padding-left:1rem;transition:color .4s}.about-right{display:flex;flex-direction:column;justify-content:flex-start;padding:3rem 0 3rem 4rem;overflow-y:auto}.svc-header{font-family:Unbounded,sans-serif;font-weight:800;font-size:clamp(1.8rem, 3.5vw, 2.8rem);color:var(--fg);letter-spacing:-.02em;line-height:1;margin-bottom:1.5rem;transition:color .4s}.svc-list{display:flex;flex-direction:column}.svc{display:grid;grid-template-columns:28px 1fr;align-items:start;gap:.5rem 1rem;padding:1rem 0;border-bottom:1px solid var(--border);transition:border-color .4s}.svc:hover .svc-name{color:var(--cyan)}.svc-n{font-family:Unbounded,sans-serif;font-size:.6rem;color:var(--cyan);font-weight:700;padding-top:.3rem}.svc-body{display:flex;flex-direction:column;gap:.25rem}.svc-name{font-family:Unbounded,sans-serif;font-weight:600;font-size:1.1rem;color:var(--fg);transition:color .2s}.svc-desc{font-size:.95rem;color:var(--fg2);line-height:1.5;transition:color .4s}.cli-block{margin-top:0}.cli-grid{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.8rem;justify-content:center}.cli-tag{font-family:Outfit,sans-serif;font-size:.75rem;letter-spacing:.12em;color:var(--fg2);border:1px solid var(--border2);padding:.4rem .9rem;transition:border-color .2s,color .2s}.cli-tag:hover{border-color:var(--cyan);color:var(--cyan)}.contact-section{padding:64px 2.5rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1920px;margin:0 auto;width:100%}.contact-left{display:flex;flex-direction:column;justify-content:center;padding:3rem 4rem 3rem 0;border-right:1px solid var(--border);transition:border-color .4s}.contact-headline{font-family:Unbounded,sans-serif;font-weight:800;font-size:clamp(2.2rem, 5vw, 4.5rem);line-height:1;color:var(--fg);letter-spacing:-.03em;margin-bottom:1.5rem;transition:color .4s}.contact-headline span{color:var(--cyan);display:block}.contact-sub{font-size:.85rem;line-height:1.9;color:var(--fg2);max-width:380px;margin-bottom:2.5rem;font-weight:300;transition:color .4s}.contact-email-block{display:flex;flex-direction:column;justify-content:center;height:100%}.contact-email-link{font-family:Unbounded,sans-serif;font-weight:700;font-size:clamp(1rem, 2.2vw, 1.6rem);color:var(--fg);text-decoration:none;letter-spacing:-.01em;border-bottom:2px solid var(--cyan);padding-bottom:.4rem;display:inline-block;margin-bottom:2rem;transition:color .2s}.contact-email-link:hover{color:var(--cyan)}.contact-mailto{display:inline-flex;align-items:center;gap:.6rem;font-family:Unbounded,sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.08em;color:var(--fg2);text-decoration:none;transition:color .2s}.contact-mailto::before{content:'→';color:var(--cyan)}.contact-mailto:hover{color:var(--cyan)}.contact-info{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}.ci-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:.4rem}.ci-val{font-size:.92rem;color:var(--fg2);line-height:1.7;transition:color .4s}.contact-right{display:flex;flex-direction:column;justify-content:center;padding:3rem 0 3rem 4rem}.clients-inner{padding:2rem 2.5rem;border-top:1px solid var(--border);max-width:1920px;margin:0 auto;width:100%;text-align:center;transition:border-color .4s}.cli-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:3rem;margin-top:2.5rem}.cli-logo-img{max-width:150px;max-height:60px;object-fit:contain;opacity:.5;transition:opacity .4s,filter .4s,transform .3s;cursor:pointer}.cli-logo-img:hover{opacity:1;transform:translateY(-2px)}[data-theme=dark] .cli-logo-img{filter:invert(1) brightness(1.5)}[data-theme=dark] .cli-logo-img:hover{filter:invert(1) brightness(2)}@media (max-width:540px){.cli-grid{gap:2rem}.cli-logo-img{max-width:120px;max-height:48px}}.faq-list{display:flex;flex-direction:column;margin-top:1.5rem}.faq-item{padding:1rem 0;border-bottom:1px solid var(--border);transition:border-color .4s}.faq-item:last-child{border-bottom:none}.faq-summary{cursor:pointer;font-family:Unbounded,sans-serif;font-weight:700;font-size:1rem;color:var(--fg);list-style:none;transition:color .2s}.faq-summary:hover{color:var(--cyan)}.faq-summary::-webkit-details-marker{display:none}.faq-answer{margin-top:.8rem;margin-bottom:0}.faq-section{max-width:1920px;margin:0 auto;width:100%;padding:1.5rem 2.5rem 3rem;border-top:1px solid var(--border);transition:border-color .4s}.faq-inner{max-width:780px;margin:0 auto}.contact-right{display:flex;align-items:center;justify-content:flex-start;padding:3rem 0 3rem 4rem}.contact-email-display{font-family:Unbounded,sans-serif;font-weight:900;font-size:clamp(1.2rem, 2.4vw, 2.4rem);line-height:1.2;letter-spacing:-.03em;color:var(--fg);text-decoration:none;white-space:nowrap;display:block;border-bottom:2px solid var(--cyan);padding-bottom:.5rem;transition:color .3s}.contact-email-display:hover{color:var(--cyan)}.footer-lava{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}.footer-lava-1{position:absolute;width:600px;height:600px;background:var(--cyan);left:-100px;top:0;border-radius:60% 40% 55% 45%/50% 60% 40% 50%;filter:blur(90px);opacity:.06;animation:lava1 18s ease-in-out infinite alternate,breathe1 5s ease-in-out infinite alternate}.footer-lava-2{position:absolute;width:320px;height:320px;background:#ff8c42;right:-80px;bottom:-150px;border-radius:50% 50% 60% 40%/60% 40% 50% 50%;filter:blur(80px);opacity:.05;animation:lava2 22s ease-in-out infinite alternate,breathe2 6s ease-in-out infinite alternate}[data-theme=dark] .footer-lava-1{opacity:.12}[data-theme=dark] .footer-lava-2{opacity:.09}.site-footer{grid-column:1/-1;padding:2rem 0 0;margin-top:2rem;border-top:1px solid var(--border);transition:border-color .4s}.footer-bar{display:flex;justify-content:space-between;align-items:center}.footer-logo{font-family:Unbounded,sans-serif;font-weight:900;font-size:1.3rem;letter-spacing:.08em;text-transform:uppercase;color:var(--fg);transition:color .4s;line-height:1.2;margin-bottom:1rem;display:block}.footer-logo span{color:var(--cyan)}.footer-tagline{font-size:.92rem;color:var(--fg2);line-height:1.8;font-weight:300;margin-bottom:1.5rem;transition:color .4s}.footer-copy{font-size:.8rem;color:var(--fg3);letter-spacing:.06em;margin-top:1rem;transition:color .4s;display:block}.footer-col-label{font-family:Unbounded,sans-serif;font-weight:700;font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:1.2rem;display:block}.footer-links{display:flex;flex-direction:column;gap:1rem}.footer-links a{font-size:.82rem;letter-spacing:.04em;color:var(--fg2);text-decoration:none;transition:color .2s;font-weight:400}.footer-links a:hover{color:var(--cyan)}.footer-contact-val{font-size:.82rem;color:var(--fg2);line-height:1.9;font-weight:300;transition:color .4s}.footer-contact-val a{color:var(--cyan);text-decoration:none}@media (max-width:768px){.site-footer{grid-template-columns:1fr 1fr;gap:2rem;padding:2.5rem 0 1.5rem}}@media (max-width:480px){.site-footer{grid-template-columns:1fr}}.reveal{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}.reveal.will-animate{opacity:0;transform:translateY(20px)}.reveal.will-animate.in{opacity:1;transform:translateY(0)}@media (max-width:768px){nav{padding:0 1.4rem}.tog{display:inline-flex!important}.nav-hamburger{display:flex!important}.hero{padding:0 1.4rem}.hero-headline{font-size:clamp(2rem, 8vw, 3rem)}.hero-bottom{padding:1rem 1.4rem;flex-wrap:wrap;gap:.8rem}.work-section{padding:64px 1.4rem 2rem}.about-section{grid-template-columns:1fr;height:auto;min-height:100vh;padding:64px 1.4rem 2rem}.about-left{padding:2rem 0;border-right:none;border-bottom:1px solid var(--border)}.about-right{padding:2rem 0}.contact-section{grid-template-columns:1fr;padding:64px 1.4rem 2rem}.contact-left{padding:2rem 0;border-right:none;border-bottom:1px solid var(--border);text-align:center}.contact-right{padding:1.5rem 0 2rem;justify-content:center}.contact-email-display{font-size:clamp(1rem, 5vw, 1.6rem);text-align:center;white-space:normal;word-break:break-word}.contact-headline{font-size:2.4rem}html{scroll-snap-type:none}.snap-section{height:auto;min-height:100vh}.work-grid{max-width:100%;margin:0}}@media (max-width:480px){.hero-headline{font-size:clamp(1.8rem, 10vw, 2.5rem)}.about-quote{font-size:1.4rem}.contact-headline{font-size:2rem}.contact-info{grid-template-columns:1fr;gap:1.2rem}.hero-bottom{justify-content:center}}.pj-overlay{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .35s ease}.pj-overlay.open{opacity:1;pointer-events:all}.pj-modal{position:fixed;top:50%;left:50%;z-index:801;transform:translate(-50%,-48%) scale(.97);opacity:0;pointer-events:none;transition:opacity .35s ease,transform .35s ease;width:min(780px,92vw);max-height:88vh;overflow-y:auto;background:var(--bg);border:1px solid var(--border2);scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.pj-modal::-webkit-scrollbar{width:4px}.pj-modal::-webkit-scrollbar-track{background:0 0}.pj-modal::-webkit-scrollbar-thumb{background:var(--border2)}.pj-modal.open{opacity:1;pointer-events:all;transform:translate(-50%,-50%) scale(1)}.pj-close{position:sticky;top:0;left:100%;z-index:10;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface);border:1px solid var(--border);color:var(--fg2);font-size:1rem;cursor:pointer;transition:background .2s,color .2s,border-color .2s;margin-left:auto;float:right;margin-bottom:-40px}.pj-close:hover{background:var(--cyan);color:var(--bg);border-color:var(--cyan)}.pj-hero{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:var(--surface)}.pj-hero-placeholder{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-family:'Noto Sans TC',sans-serif;font-size:5rem;color:var(--fg);opacity:.06;background:var(--surface)}.pj-body{padding:2rem 2.5rem 2.5rem}.pj-type{font-family:Unbounded,sans-serif;font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:.6rem}.pj-title{font-family:Unbounded,sans-serif;font-weight:800;font-size:clamp(1.4rem, 3vw, 2rem);color:var(--fg);letter-spacing:-.02em;line-height:1.1;margin-bottom:.4rem}.pj-meta{font-size:.72rem;letter-spacing:.12em;color:var(--fg3);text-transform:uppercase;margin-bottom:1.8rem;padding-bottom:1.8rem;border-bottom:1px solid var(--border)}.pj-scope-label{font-family:Unbounded,sans-serif;font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:.7rem;display:flex;align-items:center;gap:.6rem}.pj-scope-label::before{content:'';width:14px;height:1px;background:var(--cyan);display:block}.pj-scope-text{font-size:.85rem;line-height:1.9;color:var(--fg2);font-weight:300;margin-bottom:2rem;max-width:580px}.pj-services{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}.pj-svc-tag{font-family:Outfit,sans-serif;font-size:.68rem;letter-spacing:.12em;color:var(--fg2);border:1px solid var(--border2);padding:.3rem .8rem}.pj-imgs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--border)}.pj-img{aspect-ratio:4/3;object-fit:cover;display:block;width:100%;background:var(--surface)}.pj-img-placeholder{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--surface);font-family:Unbounded,sans-serif;font-size:.6rem;letter-spacing:.2em;color:var(--fg3);text-transform:uppercase}@media (max-width:540px){.pj-body{padding:1.5rem 1.2rem 2rem}.pj-imgs{grid-template-columns:1fr}}