:root{--ink:#151610;--paper:#f4f1e8;--cream:#e8e3d7;--acid:#d7ff43;--orange:#ff6b3d;--muted:#77786f;--line:rgba(21,22,16,.14);--sans:'Noto Sans TC','Microsoft JhengHei',system-ui,sans-serif;--display:'Arial Narrow','Roboto Condensed',Impact,sans-serif}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:#cfcec8;color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}.app-shell{width:min(100%,1180px);min-height:100vh;margin:auto;background:var(--paper);box-shadow:0 0 80px rgba(0,0,0,.12);overflow:hidden}.topbar{height:76px;padding:0 42px;display:flex;align-items:center;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;background:rgba(244,241,232,.92);backdrop-filter:blur(16px)}.brand{color:var(--ink);text-decoration:none;font:800 24px var(--display);letter-spacing:.1em}.brand span{display:inline-grid;place-items:center;background:var(--ink);color:var(--acid);width:29px;height:29px;margin-right:3px;transform:skew(-7deg)}.status-pill{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.06em}.status-pill i{width:7px;height:7px;border-radius:50%;background:#65b44a;box-shadow:0 0 0 4px rgba(101,180,74,.12)}.icon-btn,.round-btn{border:0;background:transparent;padding:0;cursor:pointer}.icon-btn{margin-left:18px;width:34px;height:34px}.icon-btn svg,.round-btn svg{width:22px;fill:none;stroke:currentColor;stroke-width:1.8}.hero{background:var(--ink);color:white;padding:78px 7.5% 84px;position:relative;overflow:hidden}.hero:after{content:'FORM';position:absolute;right:-42px;bottom:-75px;font:800 260px var(--display);letter-spacing:-.06em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.08);transform:skew(-7deg);pointer-events:none}.hero-kicker{font:700 12px var(--display);letter-spacing:.2em;color:#c6c7bd;display:flex;align-items:center;gap:14px}.hero-kicker:after{content:'';width:70px;height:1px;background:#696a62}.hero-kicker span{color:var(--acid)}.hero h1{font:800 clamp(66px,10vw,116px)/.84 var(--display);letter-spacing:-.035em;text-transform:uppercase;margin:34px 0 28px;position:relative;z-index:1}.hero h1 em{font-style:italic;color:var(--acid)}.hero>p{max-width:410px;color:#aaa;line-height:1.8;font-size:14px;margin:0 0 34px}.search-wrap{width:min(460px,100%);height:58px;background:#272820;border:1px solid #3c3d34;display:flex;align-items:center;padding:0 18px;position:relative;z-index:2}.search-wrap svg{width:21px;fill:none;stroke:#d4d5cc;stroke-width:1.6}.search-wrap input{flex:1;background:transparent;border:0;outline:0;color:white;font:500 14px var(--sans);padding:0 16px}.search-wrap input::placeholder{color:#77786f}.search-wrap kbd{font:18px var(--sans);color:#77786f}.category-section,.library-section{padding:72px 7.5%}.section-heading{display:flex;justify-content:space-between;align-items:end;margin-bottom:32px}.section-heading span,.offline-note span,.block-title span{font:700 11px var(--display);letter-spacing:.18em;color:var(--orange)}.section-heading h2{font:800 38px var(--display);margin:6px 0 0;letter-spacing:-.015em;text-transform:uppercase}.section-heading small{color:var(--muted);font-size:11px}.category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:11px}.category-card{min-width:0;height:235px;border:1px solid var(--line);background:#ece8df;position:relative;overflow:hidden;text-align:left;padding:20px;cursor:pointer;transition:transform .25s,background .25s,color .25s}.category-card:hover,.category-card.active{transform:translateY(-5px);background:var(--ink);color:white}.category-card.active{box-shadow:inset 0 -4px var(--accent)}.category-card .count{font:700 11px var(--display);color:var(--muted);letter-spacing:.12em}.category-card h3{font:800 28px var(--display);margin:4px 0 0}.category-card p{font-size:10px;color:var(--muted);margin:3px 0}.body-map{position:absolute;right:-14px;bottom:-16px;width:140px;height:176px;opacity:.96}.body-map svg{width:100%;height:100%}.body-map .base{fill:#cac6bb;transition:fill .25s}.body-map .target{fill:var(--accent);filter:drop-shadow(0 0 8px color-mix(in srgb,var(--accent),transparent 55%))}.category-card:hover .base,.category-card.active .base{fill:#3a3b34}.category-arrow{position:absolute;left:20px;bottom:20px;width:32px;height:32px;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;font-size:17px}.library-section{padding-top:28px}.library-heading{margin-bottom:20px}.text-btn{border:0;border-bottom:1px solid var(--ink);background:transparent;font:600 11px var(--sans);padding:5px 0;cursor:pointer}.submuscle-tabs{display:flex;gap:7px;overflow:auto;padding:2px 0 19px;scrollbar-width:none}.submuscle-tabs:empty{display:none}.submuscle-tabs button{white-space:nowrap;border:1px solid var(--line);background:transparent;padding:9px 14px;border-radius:100px;font:600 11px var(--sans);cursor:pointer;color:var(--muted)}.submuscle-tabs button.active{background:var(--ink);color:white;border-color:var(--ink)}.exercise-list{border-top:1px solid var(--ink)}.exercise-card{display:grid;grid-template-columns:52px 1fr auto 44px;align-items:center;gap:15px;padding:22px 4px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .2s,padding .2s}.exercise-card:hover{background:#ebe7dd;padding-left:14px;padding-right:14px}.exercise-index{font:700 14px var(--display);color:#a3a39c}.exercise-info small{font-size:10px;color:var(--orange);font-weight:700;letter-spacing:.06em}.exercise-info h3{font-size:17px;margin:4px 0 0}.exercise-tags{display:flex;gap:6px}.exercise-tags span{font-size:10px;border:1px solid var(--line);padding:6px 9px;color:var(--muted)}.exercise-open{width:36px;height:36px;border:1px solid var(--ink);border-radius:50%;display:grid;place-items:center;font-size:18px;transition:.2s}.exercise-card:hover .exercise-open{background:var(--acid);color:var(--ink);transform:rotate(-30deg)}.empty-result{text-align:center;padding:80px 0}.empty-result span{font:700 11px var(--display);letter-spacing:.2em;color:var(--orange)}.empty-result h3{font:800 30px var(--display);margin:10px 0}.empty-result p{font-size:13px;color:var(--muted)}.empty-result button{border:0;background:var(--ink);color:white;padding:12px 20px}.offline-note{margin:30px 7.5% 110px;background:var(--acid);padding:36px;display:flex;align-items:center;gap:24px}.offline-note .offline-icon{width:58px;height:58px;border:1px solid rgba(0,0,0,.3);border-radius:50%;display:grid;place-items:center;flex:0 0 auto}.offline-icon svg{width:26px;fill:none;stroke:currentColor;stroke-width:1.5}.offline-note span{color:#566615}.offline-note h2{font:800 30px var(--display);margin:4px 0}.offline-note p{font-size:12px;margin:0;color:#56604b}.bottom-nav{display:none}dialog{padding:0;border:0;width:min(100%,750px);max-width:750px;height:100dvh;max-height:100dvh;margin:0 0 0 auto;background:var(--paper);color:var(--ink);box-shadow:-30px 0 80px rgba(0,0,0,.22)}dialog::backdrop{background:rgba(0,0,0,.64);backdrop-filter:blur(3px)}dialog[open]{animation:sheetIn .32s ease both}@keyframes sheetIn{from{transform:translateX(50px);opacity:.5}}.detail-sheet{min-height:100%;background:var(--paper)}.detail-topbar{height:68px;padding:0 22px;background:var(--ink);color:white;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:5}.detail-topbar>span{font-size:10px;letter-spacing:.12em;color:#b6b7ad}.round-btn{color:white;width:38px;height:38px;border:1px solid #484940;border-radius:50%;display:grid;place-items:center}.save-button.saved{background:var(--acid);color:var(--ink);border-color:var(--acid)}.save-button svg{fill:transparent}.save-button.saved svg{fill:currentColor}.motion-stage{height:390px;background:#20211b;color:white;position:relative;overflow:hidden}.motion-stage:before{content:'';position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:30px 30px}.stage-label{position:absolute;left:23px;top:23px;z-index:2}.stage-label span{display:block;font:700 9px var(--display);letter-spacing:.18em;color:var(--acid)}.stage-label b{font-size:11px;font-weight:500;color:#aaa}.motion-figure{height:100%;display:grid;place-items:center;position:relative}.motion-figure svg{width:90%;height:85%;position:relative;z-index:2}.motion-figure svg path,.motion-figure svg circle{fill:none;stroke:#e9e9e0;stroke-width:9;stroke-linecap:round;stroke-linejoin:round}.motion-figure .head{fill:#e9e9e0;stroke-width:3}.motion-figure .bench path{stroke:#77796f;stroke-width:4}.motion-figure .weight{stroke:var(--acid);stroke-width:5}.motion-figure .joint{fill:var(--orange);stroke:none}.motion-ring{position:absolute;width:260px;height:260px;border:1px solid #3d3e36;border-radius:50%;animation:ringPulse 3s ease-in-out infinite}.motion-ring:after{content:'';position:absolute;inset:24px;border:1px dashed #383930;border-radius:50%}.muscle-glow{position:absolute;width:60px;height:60px;border-radius:50%;background:var(--orange);filter:blur(35px);opacity:.36;top:120px;left:46%}.person .arm,.person .leg,.person .torso,.person .head,.person .weight{transform-box:fill-box;transform-origin:center;animation-duration:2.8s;animation-timing-function:ease-in-out;animation-iteration-count:infinite}.motion-figure.paused *{animation-play-state:paused!important}.motion-figure[data-motion="press"] .arm-a,.motion-figure[data-motion="raise"] .arm-a{animation-name:armPress}.motion-figure[data-motion="press"] .weight,.motion-figure[data-motion="raise"] .weight{animation:weightPress 2.8s ease-in-out infinite}.motion-figure[data-motion="pull"] .arm-a,.motion-figure[data-motion="row"] .arm-a{animation-name:armPull}.motion-figure[data-motion="hinge"] .torso,.motion-figure[data-motion="extension"] .torso{animation-name:torsoHinge}.motion-figure[data-motion="squat"] .leg-a,.motion-figure[data-motion="lunge"] .leg-a{animation-name:legBend}.motion-figure[data-motion="abduct"] .leg-b{animation-name:legOpen}.motion-figure[data-motion="calf"] .leg-a,.motion-figure[data-motion="calf"] .leg-b{animation-name:calfRise}.motion-figure[data-motion="rotate"] .arm-b{animation-name:armRotate}@keyframes armPress{0%,100%{transform:rotate(0) translate(0)}50%{transform:rotate(-22deg) translateY(-20px)}}@keyframes weightPress{0%,100%{transform:translate(0)}50%{transform:translate(12px,-44px)}}@keyframes armPull{0%,100%{transform:rotate(-16deg) translateX(-20px)}50%{transform:rotate(18deg) translateX(12px)}}@keyframes torsoHinge{0%,100%{transform:rotate(0)}50%{transform:rotate(30deg) translate(15px,8px)}}@keyframes legBend{0%,100%{transform:rotate(0)}50%{transform:rotate(25deg) translateY(8px)}}@keyframes legOpen{0%,100%{transform:rotate(0)}50%{transform:rotate(-35deg) translateX(10px)}}@keyframes calfRise{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes armRotate{0%,100%{transform:rotate(-18deg)}50%{transform:rotate(32deg)}}@keyframes ringPulse{50%{transform:scale(1.05);opacity:.55}}.play-button{position:absolute;right:23px;bottom:23px;z-index:3;width:48px;height:48px;border-radius:50%;border:0;background:var(--acid);display:grid;place-items:center;cursor:pointer}.pause-icon{width:11px;height:15px;border-left:4px solid var(--ink);border-right:4px solid var(--ink)}.play-button.is-paused .pause-icon{width:0;height:0;border:0;border-left:11px solid var(--ink);border-top:7px solid transparent;border-bottom:7px solid transparent;margin-left:3px}.timeline{position:absolute;left:23px;right:87px;bottom:45px;height:2px;background:#4b4c44}.timeline i{display:block;height:100%;background:var(--acid);animation:progress 2.8s linear infinite}.motion-figure.paused~.timeline i{animation-play-state:paused}@keyframes progress{from{width:0}to{width:100%}}.detail-content{padding:42px 7% 70px;position:relative}.detail-number{position:absolute;right:7%;top:38px;font:800 48px var(--display);color:#d9d5ca}.detail-content>h2{font:800 42px/1 var(--display);margin:0 80px 12px 0}.detail-intro{font-size:13px;line-height:1.8;color:var(--muted);max-width:510px}.meta-row{display:flex;gap:8px;margin:25px 0}.meta-row span{border:1px solid var(--line);font-size:10px;padding:8px 10px}.form-cue{border-left:4px solid var(--orange);background:#e9e4da;padding:18px 20px;margin:28px 0;display:flex;flex-direction:column;gap:5px}.form-cue span{font:700 9px var(--display);letter-spacing:.15em;color:var(--orange)}.form-cue strong{font-size:16px}.instruction-block{margin-top:36px}.block-title{display:flex;align-items:baseline;gap:14px;margin-bottom:16px}.block-title h3{font:800 25px var(--display);margin:0}.instruction-block ol{list-style:none;padding:0;margin:0;counter-reset:steps}.instruction-block ol li{counter-increment:steps;display:grid;grid-template-columns:34px 1fr;gap:12px;padding:15px 0;border-top:1px solid var(--line);font-size:13px;line-height:1.7}.instruction-block ol li:before{content:'0' counter(steps);font:700 12px var(--display);color:var(--orange);padding-top:3px}.mistakes ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}.mistakes li{background:#e9e4da;padding:16px;font-size:12px;line-height:1.6}.mistakes li:before{content:'×';color:var(--orange);font:bold 18px var(--display);margin-right:8px}.safety-note{margin-top:35px;border:1px solid var(--line);padding:18px;display:flex;gap:18px;font-size:11px;line-height:1.6}.safety-note b{white-space:nowrap}.safety-note span{color:var(--muted)}.toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%,20px);background:var(--ink);color:white;padding:12px 18px;font-size:12px;opacity:0;pointer-events:none;transition:.25s;z-index:100}.toast.show{opacity:1;transform:translate(-50%,0)}
@media(max-width:800px){body{background:var(--paper)}.app-shell{width:100%;box-shadow:none}.topbar{height:64px;padding:0 20px}.category-grid{grid-template-columns:repeat(5,164px);overflow-x:auto;margin:0 -8.2vw;padding:4px 8.2vw 12px;scroll-snap-type:x mandatory;scrollbar-width:none}.category-card{height:210px;scroll-snap-align:start}.hero{padding:60px 8% 65px}.hero:after{font-size:170px;bottom:-45px}.hero h1{font-size:clamp(62px,20vw,86px)}.category-section,.library-section{padding:58px 8%}.library-section{padding-top:20px}.offline-note{margin:20px 8% 120px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:72px;padding:7px max(18px,env(safe-area-inset-right)) max(7px,env(safe-area-inset-bottom));background:rgba(244,241,232,.95);border-top:1px solid var(--line);z-index:30;backdrop-filter:blur(14px);justify-content:space-around}.bottom-nav a,.bottom-nav button{border:0;background:transparent;text-decoration:none;color:#86877e;font:600 10px var(--sans);display:flex;flex-direction:column;align-items:center;gap:3px;padding:0 12px}.bottom-nav svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.7}.bottom-nav .active{color:var(--ink)}.bottom-nav b{display:inline-grid;place-items:center;background:var(--orange);color:white;border-radius:50%;font-size:8px;min-width:14px;height:14px}dialog{width:100%;max-width:none;height:100dvh}.motion-stage{height:360px}.detail-content{padding:38px 7% 100px}}
@media(max-width:520px){.hero-kicker{font-size:10px}.hero h1{font-size:72px}.hero>p{font-size:13px}.section-heading h2{font-size:33px}.section-heading small{display:none}.category-section{padding-top:52px}.exercise-card{grid-template-columns:36px 1fr 34px;gap:10px;padding:19px 2px}.exercise-tags{display:none}.exercise-info h3{font-size:15px}.exercise-open{width:32px;height:32px}.offline-note{padding:26px 22px;align-items:flex-start}.offline-note .offline-icon{width:44px;height:44px}.offline-note h2{font-size:25px}.detail-content>h2{font-size:36px}.mistakes ul{grid-template-columns:1fr}.motion-stage{height:340px}.motion-figure svg{width:105%}.safety-note{flex-direction:column;gap:6px}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}.person *,.motion-ring,.timeline i{animation:none!important}}
button,a,input{-webkit-tap-highlight-color:transparent}button:focus-visible,a:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--orange);outline-offset:3px}

/* Clear offline start/end coaching frames */
.motion-stage{height:auto;min-height:470px;padding:76px 24px 24px;background:#191a15}.motion-stage:before{opacity:.45}.motion-frames{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) 52px minmax(0,1fr);align-items:center;gap:10px}.motion-frame{margin:0;aspect-ratio:3/2;background:#2a2b24;border:1px solid #46473e;position:relative;overflow:hidden}.motion-frame img{width:100%;height:100%;display:block;object-fit:cover}.frame-badge{position:absolute;z-index:2;left:10px;top:10px;background:rgba(21,22,16,.9);color:white;padding:7px 9px;display:flex;align-items:center;gap:7px;backdrop-filter:blur(6px)}.frame-badge b{font:800 18px var(--display);color:var(--acid)}.frame-badge span{font-size:10px;font-weight:700;letter-spacing:.05em}.motion-arrow{text-align:center;color:var(--acid);display:grid;place-items:center}.motion-arrow span{font:800 32px var(--display);line-height:1}.motion-arrow small{font-size:9px;color:#a8a99f;letter-spacing:.12em;margin-top:3px}.visual-cue{position:relative;z-index:2;margin-top:18px;border-left:3px solid var(--acid);padding:10px 14px;background:#24251f;display:flex;gap:13px;align-items:baseline}.visual-cue span{font:700 9px var(--display);letter-spacing:.14em;color:var(--acid);white-space:nowrap}.visual-cue strong{font-size:13px;line-height:1.55;color:#f0f0e8}.detail-content:after{content:'真人示範圖：free-exercise-db · Public Domain';display:block;margin-top:24px;font-size:9px;color:#999a91;letter-spacing:.04em}
@media(max-width:520px){.motion-stage{min-height:0;padding:68px 14px 18px}.motion-frames{grid-template-columns:1fr;gap:8px}.motion-frame{aspect-ratio:3/2}.motion-arrow{height:28px;display:flex;justify-content:center;gap:7px}.motion-arrow span{transform:rotate(90deg);font-size:26px}.motion-arrow small{margin:0}.frame-badge{left:8px;top:8px}.visual-cue{margin-top:12px;align-items:flex-start}}
