|  | <!doctype html> | 
|  | <html class=reftest-wait> | 
|  | <title>View transitions: offscreen child</title> | 
|  | <link rel="help" href="https://drafts.csswg.org/css-view-transitions-1/"> | 
|  | <link rel="author" href="mailto:vmpstr@chromium.org"> | 
|  | <link rel="match" href="capture-with-offscreen-child-ref.html"> | 
|  | <meta name="fuzzy" content="maxDifference=0-5; totalPixels=0-200"> | 
|  | <script src="/common/reftest-wait.js"></script> | 
|  |  | 
|  | <style> | 
|  | .target { | 
|  | width: 100px; | 
|  | height: 100px; | 
|  | view-transition-name: target; | 
|  | background: blue; | 
|  | } | 
|  | .invisible { | 
|  | position: absolute; | 
|  | top: -100px; | 
|  | width: 50px; | 
|  | height: 50px; | 
|  | background: green; | 
|  | } | 
|  |  | 
|  | ::view-transition-group(root) { | 
|  | visibility: hidden; | 
|  | animation-duration: 500s; | 
|  | } | 
|  |  | 
|  | ::view-transition-group(*), | 
|  | ::view-transition-image-pair(*) { | 
|  | animation-play-state: paused; | 
|  | } | 
|  |  | 
|  | ::view-transition-old(*) { | 
|  | animation: unset; | 
|  | opacity: 1; | 
|  | } | 
|  |  | 
|  | ::view-transition-new(*) { | 
|  | animation: unset; | 
|  | opacity: 0; | 
|  | } | 
|  |  | 
|  | ::view-transition { | 
|  | background: pink; | 
|  | } | 
|  | </style> | 
|  |  | 
|  | <div class=target> | 
|  | <div class=invisible></div> | 
|  | </div> | 
|  |  | 
|  | <script> | 
|  | failIfNot(document.startViewTransition, "Missing document.startViewTransition"); | 
|  |  | 
|  | function runTest() { | 
|  | const transition = document.startViewTransition(); | 
|  | transition.ready.then(takeScreenshot); | 
|  | } | 
|  |  | 
|  | onload = () => requestAnimationFrame(() => requestAnimationFrame(runTest)); | 
|  |  | 
|  | </script> |