<div id="escaped">
<h1>Escape!</h1>
</div>
<!------- Cheryl Velez - Puzzler -------- >
<!-- Trigger/Open The Modal -->
<!-- <button id="puzzlerBtn">Open Cheryls Puzzle</button> -->
<!-- The Modal -->
<div id="puzzlerModal" class="modal">
<!-- Modal content -->
<div class="modal-content">
<span class="close close-puzzler">×</span>
<!-- puzzler container -->
<div id="puzzler-container">
<div class="content">
<div>
<p id="alert"></p>
</div>
</div>
<p class="quote">"The person who masters himself through self-control and discipline is truly undefeatable." -Buddha</p><br><br>
<p class="quote">Directions: Solve the riddle of the runes: the tiles are all out of order. <br>Can you figure out their correct order?<br>Drag and drop the tiles into the empty boxes in the correct order. <br> Hint: When placing a tile, do not hover over boxes
you've already filled or are going to fill! <br><span class="bighint">Bigger Hint: </span><span class="revealtext">Use the console to watch for changes in the array!</span> </p>
<div id="btn-container"><button>Submit Answer</button>
</div>
<div class="outerflex">
<div class="topContainer">
<div class="outerBorder">
<div class="tile" id="1"><img src="https://assets.codepen.io/108463/tile1.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="2"><img src="https://assets.codepen.io/108463/tile2.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="3"><img src="https://assets.codepen.io/108463/tile3.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="4"><img src="https://assets.codepen.io/108463/tile4.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="5"><img src="https://assets.codepen.io/108463/tile5.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="6"><img src="https://assets.codepen.io/108463/tile6.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="7"><img src="https://assets.codepen.io/108463/tile7.png" alt="" /></div>
</div>
<div class="outerBorder">
<div class="tile" id="8"><img src="https://assets.codepen.io/108463/tile8.png" alt="" /></div>
</div>
</div>
<!-- top container -->
<div class="bottomContainer">
<div class="blank" id="b1"> </div>
<div class="blank" id="b2"> </div>
<div class="blank" id="b3"> </div>
<div class="blank" id="b4"> </div>
<div class="blank" id="b5"> </div>
<div class="blank" id="b6"> </div>
<div class="blank" id="b7"> </div>
<div class="blank" id="b8"> </div>
</div>
<!-- bottom container -->
</div>
<!-- outer container -->
</div>
<!-- end puzzler container -->
</div>
<!-- end modal content -->
</div>
<!-- end modal -->
<!------- End Cheryl Velez - Puzzler ------- >
<!-- Dominic Duffin - Math Puzzle -->
<!-- Trigger/Open The Modal -->
<!-- <button id="mathPuzzleBtn">Open Dominics Puzzle</button> -->
<!-- The Modal -->
<div id="mathPuzzleModal" class="modal">
<!-- Modal content -->
<div class="modal-content">
<span class="close close-mathpuzzle">×</span>
<!-- Math Puzzle Container -->
<!-- PUZZLE GOES INSIDE HERE -->
<div id="math-puzzle-container">
<div id="math-puzzle-main">
<div id="math-puzzle-keypad">
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-one">1</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-two">2</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-three">3</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-four">4</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-five">5</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-six">6</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-seven">7</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-eight">8</button>
<button type="button" class="math-puzzle-numberButton" id="math-puzzle-nine">9</button>
<button type="button" class="math-puzzle-zeroButton" id="math-puzzle-zero">0</button>
<button type="button" class="math-puzzle-signButton" id="math-puzzle-plus">+</button>
<button type="button" class="math-puzzle-signButton" id="math-puzzle-minus">-</button>
</div>
<div id="math-puzzle-sum">
<div class="math-puzzle-position" id="math-puzzle-message">
Make the sum add up!
</div>
<div class="math-puzzle-position" id="math-puzzle-a">Number</div>
<div class="math-puzzle-position" id="math-puzzle-b">Sign</div>
<div class="math-puzzle-position" id="math-puzzle-c">Number</div>
<div class="math-puzzle-position" id="math-puzzle-d">Sign</div>
<div class="math-puzzle-position" id="math-puzzle-e">Number</div>
<div class="math-puzzle-position" id="math-puzzle-f">=</div>
<div class="math-puzzle-position" id="math-puzzle-g">Number</div>
</div>
</div>
</div>
<!-- end math puzzle container -->
</div>
<!-- end modal content -->
</div>
<!-- end modal -->
<!-- End Dominic Duffin - Math Puzzle -->
<!-- Paul - Flexbox Puzzle -->
<!-- Trigger/Open The Modal -->
<!-- <button id="flexboxPuzzleBtn">Open Pauls Puzzles</button> -->
<!-- The Modal -->
<div id="flexboxPuzzleModal" class="modal">
<!-- Modal content -->
<div class="modal-content">
<span class="close close-flexboxpuzzle">×</span>
<!-- Flexbox Puzzle Container -->
<!-- PUZZLE GOES INSIDE HERE -->
<div id="flexbox-puzzle-container">
<div>
<header class="heading">
<p class="heading__rules">
Use the buttons to rearrange the boxes and find the correct alignment!<br> The box color will change and indicate if you're getting hot or cold.
<br><br>
</p>
<p class="heading__subtitle"></p>
<div><span class="notification">Start with turning on "Display Flex"</span></div>
</header>
<div class="flex-menu">
<div>
<label for="flexDisplay">Display</label>
<button class="flex-menu__items" id="flexDisplay">Display Flex </button>
</div>
<div>
<label for="flexDirectn">Flex Direction</label>
<button class="flex-menu__items" id="flexDirectn">Change Flex Direction</button>
</div>
<div>
<label for="flexJustCont">Justify-Content</label>
<button class="flex-menu__items" id="flexJustCont">Justify Content</button>
</div>
<div>
<label for="flexAlignItems">Align-Items</label>
<button class="flex-menu__items" id="flexAlignItems">Align Items</button>
</div>
</div>
<div class="flexPuzzle-container">
<div class="cubes cube-1">
<div class="side top"></div>
<div class="side bottom"></div>
<div class="side front"></div>
<div class="side back"></div>
<div class="side left"></div>
<div class="side right"></div>
</div>
<div class="cubes cube-2">
<div class="side top"></div>
<div class="side bottom"></div>
<div class="side front"></div>
<div class="side back"></div>
<div class="side left"></div>
<div class="side right"></div>
</div>
<div class="cubes cube-3">
<div class="side top"></div>
<div class="side bottom"></div>
<div class="side front"></div>
<div class="side back"></div>
<div class="side left"></div>
<div class="side right"></div>
</div>
<div class="cubes cube-4">
<div class="side top"></div>
<div class="side bottom"></div>
<div class="side front"></div>
<div class="side back"></div>
<div class="side left"></div>
<div class="side right"></div>
</div>
<div class="cubes cube-5">
<div class="side top"></div>
<div class="side bottom"></div>
<div class="side front"></div>
<div class="side back"></div>
<div class="side left"></div>
<div class="side right"></div>
</div>
</div>
</div>
</div>
</div>
<!-- end flexbox puzzle container -->
</div>
<!-- end modal content -->
</div>
<!-- end Modal -->
<!-- End Paul - Flexbox Puzzle -->
<!-- Kristopher Van Sant - Mirror Puzzle -->
<!-- Trigger/Open The Modal -->
<!-- <button id="mirrorPuzzleBtn">Open Kristophers Puzzle</button> -->
<!-- The Modal -->
<div id="mirrorPuzzleModal" class="modal">
<!-- Modal content -->
<div class="modal-content">
<span class="close close-mirrorpuzzle">×</span>
<!-- Mirror Puzzle Container -->
<!-- PUZZLE GOES INSIDE HERE -->
<div id="mirror-puzzle-container">
<p id="mirror-clue">Hmm, I can't seem to read this note.</p>
<div id="note">
<p id="note-text" class="mirror-text">"Scraps of code drifting around the network can congeal into pools of data. within this primordial soup the code breaks, re-assembles, mutates. Evolves"</p>
</div>
<div id="mmirror"></div>
</div>
<!-- end mirror puzzle container -->
</div>
<!-- end modal content -->
</div>
<!-- end modal -->
<!-- End Kristopher Van Sant - Mirror Puzzle -->
<!-- Ryan Saunders - Pipe Puzzle -->
<!-- Trigger/Open The Modal -->
<!-- <button id="pipePuzzleBtn">Open Ryans Puzzle</button> -->
<!-- The Modal -->
<div id="pipePuzzleModal" class="modal">
<!-- Modal content -->
<div class="modal-content">
<span class="close close-pipepuzzle">×</span>
<!-- Pipe Puzzle Container -->
<!-- PUZZLE GOES INSIDE HERE -->
<div id="pipe-puzzle-container">
<div id="pipe-notbusted">
<div class="container" id="container">
</div>
<div class="testArea">
<button class="testButton" id="test" onClick="newPipe()">
Add Pipe
</button>
<button class="testButton" id="test2" onClick="updatePipes()">
Update Rows & Columns
</button>
<button class="testButton" id="test3" onClick="test()">
List Array
</button>
<br /> <br />
<form>
Rows: <input type="number" min="1" max="10" id="rowCount"> Columns: <input type="number" min="1" max="10" id="colCount">
</form>
<br />
<div class="pipe pipe-straight"></div>
<div class="pipe pipe-cross"></div>
<div class="pipe pipe-angle"></div>
<div class="pipe pipe-junction"></div>
</div>
<div class="bottomConsole"></div>
</div>
<div id="pipe-busted">
<h2>Oh my...Looks like these pipes are busted. <br> I guess I better leave this for the plumber.</h2>
<!-- <img src="https://media.giphy.com/media/46LMaiLUFRkoU/giphy.gif" alt=""> -->
</div>
</div>
<!-- end container -->
</div>
<!-- end modal content -->
</div>
<!-- end modal -->
<!-- End Ryan Saunders - Pipe Puzzle -->
<!-- Antoine Guillien - Recursion Puzzle -->
<!-- Trigger/Open The Modal -->
<!-- <button id="recursionPuzzleBtn">Open Antoines Puzzle</button> -->
<!-- The Modal -->
<div id="recursionPuzzleModal" class="modal">
<!-- Modal content -->
<div class="modal-content">
<span class="close close-recursionpuzzle">×</span>
<!-- Recursion Puzzle Container -->
<!-- PUZZLE GOES INSIDE HERE -->
<div id="recursion-puzzle-container">
<div id="app">
<h1>We All Scream For Ice Cream</h1>
<div v-if="won" class="won">
<h1>Yay! You found the Ice Cream at level {{details.level}} after {{details.clicks}} clicks and {{details.opened}} containers opened!</h1>
<h1><i class="fa fa-ice-cream"></i></h1>
</div>
<thing v-else :data="root" :cb="cb"></thing>
</div>
</div>
<!-- end container -->
</div>
<!-- end modal content -->
</div>
<!-- end modal -->
<!-- End Antoine Guillien - Recursion Puzzle -->
<!-- ROOM SCENE -->
<!-- Generator: Adobe Illustrator 23.0.3, SVG Export Plug-In -->
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="300px" height="105px" viewBox="0 0 300 105" style="enable-background:new 0 0 300 105;" xml:space="preserve">
<style type="text/css">
.st0{fill:#e6e6e6;}
.st1{fill:#e6e6e6;stroke:#000000;stroke-width:0.2578;stroke-miterlimit:10;}
.st2{fill:#e6e6e6;fill-opacity:0;}
.st3{opacity:0;}
</style>
<defs>
</defs>
<g id="id="mirrorNoteWrap>
<g id="mirror">
<ellipse id="solidfill" class="st0" cx="285" cy="27.6" rx="11.5" ry="14.7"/>
<g>
<path class="st0" d="M285,7.9c-8.2,0-14.9,8.8-14.9,19.7s6.7,19.7,14.9,19.7s14.9-8.8,14.9-19.7S293.2,7.9,285,7.9z M285,46.3
c-7.7,0-13.9-8.4-13.9-18.7S277.4,9,285,9s13.9,8.4,13.9,18.7S292.7,46.3,285,46.3z"/>
<path class="st0" d="M285,12.3c-6.4,0-11.6,6.9-11.6,15.3S278.6,43,285,43s11.6-6.9,11.6-15.3S291.4,12.3,285,12.3z M285,41.9
c-5.8,0-10.5-6.4-10.5-14.3s4.7-14.3,10.5-14.3s10.5,6.4,10.5,14.3S290.8,41.9,285,41.9z"/>
<rect x="278.4" y="19.3" transform="matrix(0.7032 -0.711 0.711 0.7032 70.135 207.5076)" width="10.4" height="0.9"/>
<rect x="279.1" y="26.5" transform="matrix(0.7032 -0.711 0.711 0.7032 64.812 209.1774)" width="7.7" height="0.9"/>
</g>
<g id="note">
<path d="M292,37.8c0-0.1,0.5-1.6,0.5-3.6V30h-7.3v4.2c0,1.9-0.4,3.4-0.4,3.4l-0.1,0.3h7.3V37.8z M285.2,37.5
c0.1-0.6,0.4-1.8,0.4-3.2v-3.7h6.3v3.7c0,1.5-0.3,2.8-0.4,3.2C291.6,37.5,285.2,37.5,285.2,37.5z"/>
<rect x="287.9" y="29.6" transform="matrix(9.839854e-02 -0.9951 0.9951 9.839854e-02 230.2782 314.6575)" class="st1 st0" width="1.7" height="1.2"/>
<g>
<g>
<path d="M288.8,32.7h-2.4c0,0-0.1,0-0.1-0.1c0,0,0-0.1,0.1-0.1h2.4C288.9,32.6,288.9,32.6,288.8,32.7
C288.9,32.6,288.9,32.7,288.8,32.7z"/>
</g>
</g>
<g>
<g>
<path d="M291.4,33.5c-0.8,0-1.7,0-2.5,0s-1.7,0-2.5,0c0,0-0.1,0-0.1-0.1c0,0,0-0.1,0.1-0.1c0.8,0,1.7,0,2.5,0s1.7,0,2.5,0
C291.4,33.4,291.4,33.5,291.4,33.5L291.4,33.5z"/>
</g>
</g>
<g>
<g>
<path d="M291.2,34.3h-4.9c0,0-0.1,0-0.1-0.1c0,0,0-0.1,0.1-0.1h4.9C291.2,34.2,291.2,34.3,291.2,34.3L291.2,34.3z"/>
</g>
</g>
<g>
<g>
<path d="M286.5,35.1C286.4,35.1,286.4,35.1,286.5,35.1C286.4,35,286.5,35,286.5,35.1c0.8-0.1,1.6-0.1,2.4-0.1s1.6,0,2.4,0
c0,0,0.1,0,0.1,0.1c0,0,0,0.1-0.1,0.1c-0.8,0-1.6,0-2.4,0C288.1,35.1,287.3,35.1,286.5,35.1z"/>
</g>
</g>
</g>
</g>
<rect id="mirrorPuzzleBtn" x="270" y="8" class="st2" width="30" height="39.5"/>
</g>
<g id="door">
<path class="st0" d="M62.7,56.7c1.5,0,2.8-1.3,2.8-2.8s-1.3-2.8-2.8-2.8c-1.5,0-2.8,1.3-2.8,2.8C60,55.5,61.2,56.7,62.7,56.7z
M62.7,52.9c0.6,0,1,0.5,1,1s-0.5,1-1,1c-0.6,0-1-0.5-1-1S62.2,52.9,62.7,52.9z"/>
<path class="st0" d="M95.9,104v-1.7H74.7l0,0h-0.3V0H21.7v102.3h-2.3H0v1.7h19.2h4.1h2.2h1.7h41.6h1.7h2.1 M68.8,102.3H27.2V5.5
h41.6V102.3z M70.5,102.3V3.8l0,0h-45l0,0v98.5h-2.1V1.7h49.2v100.5h-2.1V102.3z"/>
</g>
<!-- padlock section -->
<svg style="display: none;">
<symbol id="locked" viewBox="0 0 24 24">
</symbol>
<symbol id="unlocked" viewBox="0 0 24 24">
</symbol>
</svg>
<svg id="padlock0" x="75" y="25" width="7" height="7" viewBox="0 0 24 24">
<path class="locked" d="M12,17A2,2 0 0,0 14,15C14,13.89 13.1,13 12,13A2,2 0 0,0 10,15A2,2 0 0,0 12,17M18,8A2,2 0 0,1 20,10V20A2,2 0 0,1 18,22H6A2,2 0 0,1 4,20V10C4,8.89 4.9,8 6,8H7V6A5,5 0 0,1 12,1A5,5 0 0,1 17,6V8H18M12,3A3,3 0 0,0 9,6V8H15V6A3,3 0 0,0 12,3Z"/>
<path class="unlocked" d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z"/>
</svg>
<svg id="padlock1" x="75" y="33" width="7" height="7" viewBox="0 0 24 24">
<path class="locked" d="M12,17A2,2 0 0,0 14,15C14,13.89 13.1,13 12,13A2,2 0 0,0 10,15A2,2 0 0,0 12,17M18,8A2,2 0 0,1 20,10V20A2,2 0 0,1 18,22H6A2,2 0 0,1 4,20V10C4,8.89 4.9,8 6,8H7V6A5,5 0 0,1 12,1A5,5 0 0,1 17,6V8H18M12,3A3,3 0 0,0 9,6V8H15V6A3,3 0 0,0 12,3Z"/>
<path class="unlocked" d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z"/>
</svg>
<svg id="padlock2" x="75" y="41" width="7" height="7" viewBox="0 0 24 24">
<path class="locked" d="M12,17A2,2 0 0,0 14,15C14,13.89 13.1,13 12,13A2,2 0 0,0 10,15A2,2 0 0,0 12,17M18,8A2,2 0 0,1 20,10V20A2,2 0 0,1 18,22H6A2,2 0 0,1 4,20V10C4,8.89 4.9,8 6,8H7V6A5,5 0 0,1 12,1A5,5 0 0,1 17,6V8H18M12,3A3,3 0 0,0 9,6V8H15V6A3,3 0 0,0 12,3Z"/>
<path class="unlocked" d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z"/>
</svg>
<svg id="padlock3" x="75" y="49" width="7" height="7" viewBox="0 0 24 24">
<path class="locked" d="M12,17A2,2 0 0,0 14,15C14,13.89 13.1,13 12,13A2,2 0 0,0 10,15A2,2 0 0,0 12,17M18,8A2,2 0 0,1 20,10V20A2,2 0 0,1 18,22H6A2,2 0 0,1 4,20V10C4,8.89 4.9,8 6,8H7V6A5,5 0 0,1 12,1A5,5 0 0,1 17,6V8H18M12,3A3,3 0 0,0 9,6V8H15V6A3,3 0 0,0 12,3Z"/>
<path class="unlocked" d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z"/>
</svg>
<svg id="padlock4" x="75" y="57" width="7" height="7" viewBox="0 0 24 24">
<path class="locked" d="M12,17A2,2 0 0,0 14,15C14,13.89 13.1,13 12,13A2,2 0 0,0 10,15A2,2 0 0,0 12,17M18,8A2,2 0 0,1 20,10V20A2,2 0 0,1 18,22H6A2,2 0 0,1 4,20V10C4,8.89 4.9,8 6,8H7V6A5,5 0 0,1 12,1A5,5 0 0,1 17,6V8H18M12,3A3,3 0 0,0 9,6V8H15V6A3,3 0 0,0 12,3Z"/>
<path class="unlocked" d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z"/>
</svg>
<svg id="padlock5" x="75" y="65" width="7" height="7" viewBox="0 0 24 24">
<path class="locked" d="M12,17A2,2 0 0,0 14,15C14,13.89 13.1,13 12,13A2,2 0 0,0 10,15A2,2 0 0,0 12,17M18,8A2,2 0 0,1 20,10V20A2,2 0 0,1 18,22H6A2,2 0 0,1 4,20V10C4,8.89 4.9,8 6,8H7V6A5,5 0 0,1 12,1A5,5 0 0,1 17,6V8H18M12,3A3,3 0 0,0 9,6V8H15V6A3,3 0 0,0 12,3Z"/>
<path class="unlocked" d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z"/>
</svg>
<!-- end of padlock section -->
<path id="desk" class="st0" d="M130.4,65.4v5.5h2v33.7h5.5V73H207v6.4v1.3v8.4v1.4v14.1h18.3V90.5v-1.4v-8.4v-1.3v-8.5v-1.3v-4.3
L130.4,65.4L130.4,65.4z M136.7,103.4h-3V70.9h3V73V103.4z M138,71.7v-0.8h69.1v0.8H138z M224.1,103.4h-15.7V90.5h15.7V103.4z
M224.1,89.1h-15.7v-8.4h15.7V89.1z M224.1,79.4h-15.7v-8.5h15.7V79.4z M207.9,69.6h-0.8H138h-1.3h-4.3h-0.7v-3h92.4v3H207.9z
M220.3,75.2h-8.1v-0.6c0-0.8,0.7-1.5,1.5-1.5h5c0.8,0,1.5,0.7,1.5,1.5L220.3,75.2L220.3,75.2z M220.3,85.1h-8.1v-0.6
c0-0.8,0.7-1.5,1.5-1.5h5c0.8,0,1.5,0.7,1.5,1.5L220.3,85.1L220.3,85.1z M212.2,101.8v-0.6c0-0.8,0.7-1.5,1.5-1.5h5
c0.8,0,1.5,0.7,1.5,1.5v0.6H212.2z M220.3,95.1h-8.1v-0.6c0-0.8,0.7-1.5,1.5-1.5h5c0.8,0,1.5,0.7,1.5,1.5L220.3,95.1L220.3,95.1z" />
<g id="computer">
<g>
<g id="hard-drive">
<rect x="205.4" y="60.4" class="st0" width="0.9" height="3" />
<rect x="201.7" y="60.4" class="st0" width="0.9" height="3" />
<polygon class="st0" points="196.3,39.1 206.4,39.1 206.4,40.1 207.3,40.1 207.3,38.2 195.4,38.2 195.4,40.1 196.3,40.1 " />
<path class="st0" d="M193.7,36.2v29.5H209V36.2H193.7z M208.1,64.7h-13.5V37.1h13.5V64.7L208.1,64.7z" />
<polygon class="st0" points="206.2,53.7 204.7,53.7 204.7,54.6 207.1,54.6 207.1,52.1 206.2,52.1 " />
<rect x="199.9" y="60.4" class="st0" width="0.9" height="3" />
<rect x="203.6" y="60.4" class="st0" width="0.9" height="3" />
<rect x="204.6" y="40.9" class="st0" width="1.8" height="0.9" />
<rect x="200.1" y="46.2" class="st0" width="6.3" height="0.9" />
<rect x="198" y="60.4" class="st0" width="0.9" height="3" />
<rect x="196.2" y="60.4" class="st0" width="0.9" height="3" />
</g>
<g id="desktop">
<path class="st0" d="M170.2,61.3c-5,0.2-5,1-5,1.4v2.1c0,1.2,4.1,1.4,7.6,1.4s7.6-0.2,7.6-1.4v-2.1c0-0.3,0-1.1-5-1.4v-3h14.3
V34.9h-33.8v23.4h14.3L170.2,61.3L170.2,61.3z M179.4,64.6c-0.5,0.2-2.7,0.6-6.7,0.6c-3.9,0-6.2-0.4-6.7-0.6v-1.2
c1.4,0.5,4.2,0.6,6.7,0.6s5.2-0.1,6.7-0.6V64.6z M156.7,57.4V35.8h31.9v21.6h-14.3v4.8h0.4c2.1,0.1,3.4,0.3,4.1,0.5
c-0.9,0.2-3,0.5-6.2,0.5s-5.2-0.3-6.2-0.5c0.7-0.2,2-0.4,4.1-0.5h0.4v-4.8C171.1,57.4,156.7,57.4,156.7,57.4z" />
<path class="st0" d="M187,37h-28.5v18.4H187V37z M186,54.4h-26.7V37.9H186V54.4z" />
<rect x="158.9" y="37" class="st0" width="28" height="18" />
<g id="screenglitch">
<rect x="175.2" y="43.1" width="3.2" height="1.1" />
<rect x="181.6" y="43.1" width="3.2" height="1.1" />
<rect x="162.5" y="43.1" width="9.5" height="1.1" />
<rect x="168.9" y="40.5" width="6.3" height="1.1" />
<rect x="178.4" y="40.5" width="3.2" height="1.1" />
<rect x="162.5" y="37.9" width="3.2" height="1.1" />
<rect x="168.9" y="37.9" width="3.2" height="1.1" />
<rect x="175.2" y="37.9" width="3.2" height="1.1" />
<rect x="181.6" y="37.9" width="3.2" height="1.1" />
<rect x="159.4" y="45.6" width="3.2" height="1.1" />
<rect x="165.7" y="45.6" width="6.3" height="1.1" />
<rect x="178.4" y="45.6" width="6.3" height="1.1" />
<rect x="170.2" y="50.8" width="3.2" height="1.1" />
<rect x="163.8" y="50.8" width="3.2" height="1.1" />
<rect x="176.5" y="50.8" width="9.5" height="1.1" />
<rect x="173.3" y="48.2" width="6.3" height="1.1" />
<rect x="160.6" y="48.2" width="3.2" height="1.1" />
<rect x="167" y="48.2" width="3.2" height="1.1" />
<rect x="176.5" y="53.4" width="6.3" height="1.1" />
<rect x="163.8" y="53.4" width="6.3" height="1.1" />
</g>
</g>
</g>
</g>
<g id="servers">
<g>
<path class="st0" d="M250.7,72.3c0.2,0,0.4,0.2,0.4,0.4v31.6c0,0.2-0.2,0.4-0.4,0.4h-22.9c-0.2,0-0.4-0.2-0.4-0.4V72.7
c0-0.2,0.2-0.4,0.4-0.4L250.7,72.3 M250.7,71.9h-22.9c-0.4,0-0.7,0.3-0.7,0.7v31.6c0,0.4,0.3,0.7,0.7,0.7h22.9
c0.4,0,0.7-0.3,0.7-0.7V72.7C251.5,72.3,251.1,71.9,250.7,71.9L250.7,71.9z" />
<path class="st0" d="M239.3,87.2c-3.9,0-7.1-3.1-7.1-7s3.2-7,7.1-7c3.9,0,7.1,3.1,7.1,7S243.2,87.2,239.3,87.2z M239.3,73.5
c-3.7,0-6.7,3-6.7,6.6c0,3.7,3,6.6,6.7,6.6s6.7-3,6.7-6.6S243,73.5,239.3,73.5z" />
<g>
<path class="st0" d="M238.9,102.8h-10.2c-0.1,0-0.2-0.1-0.2-0.2V89.9c0-0.1,0.1-0.2,0.2-0.2h10.2c0.1,0,0.2,0.1,0.2,0.2v12.7
C239.1,102.7,239,102.8,238.9,102.8z M228.9,102.4h9.8V90.1h-9.8V102.4z" />
<path class="st0" d="M237.8,91.9h-2.5c-0.1,0-0.2-0.1-0.2-0.2v-0.8c0-0.1,0.1-0.2,0.2-0.2h2.5c0.1,0,0.2,0.1,0.2,0.2v0.8
C238,91.8,237.9,91.9,237.8,91.9z M235.5,91.5h2.1V91h-2.1V91.5z" />
<path class="st0" d="M234.7,91.9h-2.5c-0.1,0-0.2-0.1-0.2-0.2v-0.8c0-0.1,0.1-0.2,0.2-0.2h2.5c0.1,0,0.2,0.1,0.2,0.2v0.8
C234.9,91.8,234.8,91.9,234.7,91.9z M232.4,91.5h2.1V91h-2.1V91.5z" />
<path class="st0" d="M237.8,93.4h-2.5c-0.1,0-0.2-0.1-0.2-0.2v-0.8c0-0.1,0.1-0.2,0.2-0.2h2.5c0.1,0,0.2,0.1,0.2,0.2v0.8
C238,93.3,237.9,93.4,237.8,93.4z M235.5,93h2.1v-0.5h-2.1V93z" />
<path class="st0" d="M234.7,93.4h-2.5c-0.1,0-0.2-0.1-0.2-0.2v-0.8c0-0.1,0.1-0.2,0.2-0.2h2.5c0.1,0,0.2,0.1,0.2,0.2v0.8
C234.9,93.3,234.8,93.4,234.7,93.4z M232.4,93h2.1v-0.5h-2.1V93z" />
<path class="st0" d="M237.8,94.9h-2.5c-0.1,0-0.2-0.1-0.2-0.2v-0.8c0-0.1,0.1-0.2,0.2-0.2h2.5c0.1,0,0.2,0.1,0.2,0.2v0.8
C238,94.8,237.9,94.9,237.8,94.9z M235.5,94.5h2.1V94h-2.1V94.5z" />
<path class="st0" d="M234.7,94.9h-2.5c-0.1,0-0.2-0.1-0.2-0.2v-0.8c0-0.1,0.1-0.2,0.2-0.2h2.5c0.1,0,0.2,0.1,0.2,0.2v0.8
C234.9,94.8,234.8,94.9,234.7,94.9z M232.4,94.5h2.1V94h-2.1V94.5z" />
<path class="st0" d="M230.5,92.1c-0.4,0-0.7-0.3-0.7-0.7s0.3-0.7,0.7-0.7s0.7,0.3,0.7,0.7S230.9,92.1,230.5,92.1z M230.5,91
c-0.2,0-0.4,0.2-0.4,0.4s0.2,0.4,0.4,0.4s0.4-0.2,0.4-0.4S230.7,91,230.5,91z" />
<path class="st0" d="M230.5,94c-0.4,0-0.7-0.3-0.7-0.7s0.3-0.7,0.7-0.7s0.7,0.3,0.7,0.7C231.3,93.6,230.9,94,230.5,94z
M230.5,92.9c-0.2,0-0.4,0.2-0.4,0.4s0.2,0.4,0.4,0.4s0.4-0.2,0.4-0.4S230.7,92.9,230.5,92.9z" />
<path class="st0" d="M237.8,97.5h-8c-0.1,0-0.2-0.1-0.2-0.2v-1.5c0-0.1,0.1-0.2,0.2-0.2h8c0.1,0,0.2,0.1,0.2,0.2v1.5
C238,97.4,237.9,97.5,237.8,97.5z M230,97.1h7.6V96H230V97.1z" />
<path class="st0" d="M237,97h-1.8c-0.1,0-0.1,0-0.2-0.1c0-0.1,0-0.1,0-0.2l0.4-0.5c0,0,0.1-0.1,0.2-0.1h1c0.1,0,0.1,0,0.2,0.1
l0.4,0.5c0,0.1,0,0.1,0,0.2S237.1,97,237,97z M235.6,96.6h1l-0.1-0.2h-0.8L235.6,96.6z" />
<path class="st0" d="M237.8,99.7h-8c-0.1,0-0.2-0.1-0.2-0.2V98c0-0.1,0.1-0.2,0.2-0.2h8c0.1,0,0.2,0.1,0.2,0.2v1.5
C238,99.7,237.9,99.7,237.8,99.7z M230,99.4h7.6v-1.1H230V99.4z" />
<path class="st0" d="M237.8,102h-8c-0.1,0-0.2-0.1-0.2-0.2v-1.5c0-0.1,0.1-0.2,0.2-0.2h8c0.1,0,0.2,0.1,0.2,0.2v1.5
C238,101.9,237.9,102,237.8,102z M230,101.6h7.6v-1.1H230V101.6z" />
<path class="st0" d="M237,99.3h-1.8c-0.1,0-0.1,0-0.2-0.1c0-0.1,0-0.1,0-0.2l0.4-0.5c0,0,0.1-0.1,0.2-0.1h1c0.1,0,0.1,0,0.2,0.1
l0.4,0.5c0,0.1,0,0.1,0,0.2S237.1,99.3,237,99.3z M235.6,98.9h1l-0.1-0.2h-0.8L235.6,98.9z" />
<path class="st0" d="M234.4,99.3h-1.8c-0.1,0-0.1,0-0.2-0.1c0-0.1,0-0.1,0-0.2l0.4-0.5c0,0,0.1-0.1,0.2-0.1h1
c0.1,0,0.1,0,0.2,0.1l0.4,0.5c0,0.1,0,0.1,0,0.2C234.6,99.2,234.5,99.3,234.4,99.3z M233,98.9h1l-0.1-0.2h-0.8L233,98.9z" />
<path class="st0" d="M234.8,97h-1c-0.1,0-0.2-0.1-0.2-0.2v-0.5c0-0.1,0.1-0.2,0.2-0.2h1c0.1,0,0.2,0.1,0.2,0.2v0.5
C235,96.9,234.9,97,234.8,97z M234,96.6h0.6v-0.2H234V96.6z" />
<circle class="st0" cx="230.7" cy="96.5" r="0.2" />
<circle class="st0" cx="231.5" cy="96.5" r="0.2" />
<circle class="st0" cx="232.2" cy="96.5" r="0.2" />
</g>
<path class="st0" d="M239.3,81.6c-0.8,0-1.5-0.7-1.5-1.5s0.7-1.5,1.5-1.5s1.5,0.7,1.5,1.5C240.7,81,240.1,81.6,239.3,81.6z
M239.3,79.1c-0.6,0-1.1,0.5-1.1,1.1s0.5,1.1,1.1,1.1s1.1-0.5,1.1-1.1C240.4,79.6,239.9,79.1,239.3,79.1z" />
<path class="st0" d="M239.8,78.9h-0.4c0-2.2,2-4,4.5-4v0.4C241.6,75.2,239.8,76.9,239.8,78.9z" />
<path class="st0" d="M240.4,79.3H240c0-1.4,2.3-2.5,5.3-2.5v0.4C242.7,77.2,240.4,78.2,240.4,79.3z" />
<path class="st0" d="M244.5,84.4c-0.1-2.2-1.8-4-3.8-4V80c2.2-0.1,4.1,1.9,4.2,4.3L244.5,84.4z" />
<path class="st0" d="M242.6,86c0-1.3-0.3-2.6-0.8-3.5c-0.4-0.9-1-1.3-1.5-1.3l0,0v-0.4l0,0c0.7,0,1.4,0.5,1.9,1.5s0.8,2.3,0.8,3.7
L242.6,86z" />
<path class="st0" d="M236.6,86.6l-0.1-0.3c1-0.3,1.9-1,2.4-1.9s0.6-1.9,0.3-2.8l0.4-0.1c0.3,1,0.2,2.1-0.4,3.1
C238.7,85.5,237.8,86.2,236.6,86.6z" />
<path class="st0" d="M234.6,85.2l-0.1-0.3c2.6-0.8,4.4-2.5,4-3.6l0.4-0.1C239.3,82.5,237.4,84.3,234.6,85.2z" />
<path class="st0" d="M235.6,81.8c-1.2,0-2.4-0.5-3.4-1.5l0.3-0.3c1.6,1.6,4,1.8,5.5,0.4l0.3,0.3C237.5,81.5,236.6,81.8,235.6,81.8
z" />
<path class="st0" d="M237,80.4c-0.4,0-0.8-0.1-1.3-0.3c-1-0.4-2.1-1.2-3.1-2.2l0.3-0.3c0.9,1,2,1.7,2.9,2.1s1.7,0.4,2.1,0l0.3,0.3
C237.9,80.3,237.5,80.4,237,80.4z" />
<path class="st0" d="M238.1,79.7c-1-0.4-1.8-1.3-2.1-2.3c-0.4-1.1-0.3-2.3,0.2-3.3l0.3,0.1c-0.4,1-0.5,2.1-0.1,3.1
c0.3,1,1,1.7,1.9,2.1L238.1,79.7z" />
<path class="st0" d="M238.8,79.2c-0.7-0.3-1-1.1-1.1-2.2c0-1.1,0.3-2.4,0.8-3.7l0.3,0.1c-0.5,1.2-0.8,2.5-0.8,3.5s0.3,1.6,0.8,1.9
V79.2z" />
<g>
<path class="st0" d="M249.6,102.8h-9.8c-0.1,0-0.2-0.1-0.2-0.2V89.5c0-0.1,0-0.1,0.1-0.1c0,0,0.1,0,0.2,0
c0.6,0.1,1.2,0.1,1.9,0.1c2.8-0.1,5.4-2.3,7.7-6.5c0-0.1,0.1-0.1,0.2-0.1c0.1,0,0.1,0.1,0.1,0.2v19.6
C249.8,102.7,249.7,102.8,249.6,102.8z M240.1,102.4h9.4V83.7c-2.3,3.9-4.8,5.9-7.7,6c-0.7,0-1.2,0-1.7-0.1V102.4z" />
<g>
<path class="st0" d="M249.6,83.5V83c-0.1,0.1-0.1,0.2-0.2,0.3L249.6,83.5z" />
<path class="st0" d="M249.5,102.1l0.2,0.2v-0.8l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8
l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2V96l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8
l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2V92l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8
l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2V88l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8
l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2v-0.8l-0.2,0.2l-0.4-0.4l0.4-0.4l0.2,0.2V84l-0.2,0.2l-0.3-0.3c-0.1,0.1-0.1,0.2-0.2,0.3
l0.2,0.2l-0.4,0.4l-0.1-0.1c-0.1,0.1-0.1,0.2-0.2,0.3l0.1,0.1l-0.4,0.4l0,0c-0.9,1.2-1.9,2.3-3,3l-0.3,0.3l-0.1-0.1
c-0.1,0.1-0.2,0.1-0.3,0.2l0.2,0.2l-0.4,0.4l-0.3-0.3c-0.3,0.1-0.7,0.2-1,0.3l0,0l0,0c-0.1,0-0.3,0.1-0.5,0.1l0.2,0.2l-0.4,0.4
l-0.4-0.4l0.2-0.2c-0.3,0-0.6,0-0.9,0l0.2,0.2l-0.4,0.4l-0.4-0.4l0.2-0.2c-0.2,0-0.3,0-0.5-0.1l0,0l0,0h-0.1v0.7L240,90l0.4,0.4
l-0.4,0.4l-0.1-0.1v0.8l0.1-0.1l0.4,0.4l-0.4,0.4l-0.1-0.1v0.8l0.1-0.1l0.4,0.4l-0.4,0.4l-0.1-0.1v0.8L240,94l0.4,0.4l-0.4,0.4
l-0.1-0.1v0.8l0.1-0.1l0.4,0.4l-0.4,0.4l-0.1-0.1v0.8l0.1-0.1l0.4,0.4l-0.4,0.4l-0.1-0.1v0.8l0.1-0.1l0.4,0.4L240,99l-0.1-0.1
v0.8l0.1-0.1l0.4,0.4l-0.4,0.4l-0.1-0.1v0.8l0.1-0.1l0.4,0.4l-0.4,0.4l-0.1-0.1v0.8l0.1-0.1l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1
l0.4-0.4l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1l0.4-0.4l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1l0.4-0.4l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1l0.4-0.4
l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1l0.4-0.4l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1l0.4-0.4l0.4,0.4l-0.1,0.1h0.7l-0.1-0.1L249.5,102.1z
M249.2,100.5l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,100.5z M243.8,96.5l-0.4,0.4l-0.4-0.4l0.4-0.4L243.8,96.5z M243,95.1l0.4-0.4
l0.4,0.4l-0.4,0.4L243,95.1z M243.6,95.8l0.4-0.4l0.4,0.4l-0.4,0.4L243.6,95.8z M245.7,93.8l0.4-0.4l0.4,0.4l-0.4,0.4
L245.7,93.8z M246.5,95.1l-0.4,0.4l-0.4-0.4l0.4-0.4L246.5,95.1z M245.8,94.5l-0.4,0.4l-0.4-0.4l0.4-0.4L245.8,94.5z
M245.2,95.1l-0.4,0.4l-0.4-0.4l0.4-0.4L245.2,95.1z M244.7,96.1l0.4,0.4l-0.4,0.4l-0.4-0.4L244.7,96.1z M245,95.8l0.4-0.4
l0.4,0.4l-0.4,0.4L245,95.8z M246.1,96.1l0.4,0.4l-0.4,0.4l-0.4-0.4L246.1,96.1z M246.4,95.8l0.4-0.4l0.4,0.4l-0.4,0.4
L246.4,95.8z M246.4,94.5l0.4-0.4l0.4,0.4l-0.4,0.4L246.4,94.5z M246.4,93.1l0.4-0.4l0.4,0.4l-0.4,0.4L246.4,93.1z M246.4,91.8
l0.4-0.4l0.4,0.4l-0.4,0.4L246.4,91.8z M246.5,92.4l-0.4,0.4l-0.4-0.4l0.4-0.4L246.5,92.4z M245.8,93.1l-0.4,0.4l-0.4-0.4
l0.4-0.4L245.8,93.1z M245.2,93.8l-0.4,0.4l-0.4-0.4l0.4-0.4L245.2,93.8z M244.5,94.5l-0.4,0.4l-0.4-0.4l0.4-0.4L244.5,94.5z
M243.4,94.2l-0.4-0.4l0.4-0.4l0.4,0.4L243.4,94.2z M243.1,94.5l-0.4,0.4l-0.4-0.4l0.4-0.4L243.1,94.5z M243.1,95.8l-0.4,0.4
l-0.4-0.4l0.4-0.4L243.1,95.8z M243.1,97.1l-0.4,0.4l-0.4-0.4l0.4-0.4L243.1,97.1z M243.4,97.4l0.4,0.4l-0.4,0.4l-0.4-0.4
L243.4,97.4z M243.6,97.1l0.4-0.4l0.4,0.4l-0.4,0.4L243.6,97.1z M244.7,97.4l0.4,0.4l-0.4,0.4l-0.4-0.4L244.7,97.4z M245,97.1
l0.4-0.4l0.4,0.4l-0.4,0.4L245,97.1z M246.1,97.4l0.4,0.4l-0.4,0.4l-0.4-0.4L246.1,97.4z M246.4,97.1l0.4-0.4l0.4,0.4l-0.4,0.4
L246.4,97.1z M247.4,97.4l0.4,0.4l-0.4,0.4l-0.4-0.4L247.4,97.4z M247,96.5l0.4-0.4l0.4,0.4l-0.4,0.4L247,96.5z M247,95.1
l0.4-0.4l0.4,0.4l-0.4,0.4L247,95.1z M247,93.8l0.4-0.4l0.4,0.4l-0.4,0.4L247,93.8z M247,92.4l0.4-0.4l0.4,0.4l-0.4,0.4
L247,92.4z M247,91.1l0.4-0.4l0.4,0.4l-0.4,0.4L247,91.1z M247,89.8l0.4-0.4l0.4,0.4l-0.4,0.4L247,89.8z M247.2,90.4l-0.4,0.4
l-0.4-0.4l0.4-0.4L247.2,90.4z M246.5,91.1l-0.4,0.4l-0.4-0.4l0.4-0.4L246.5,91.1z M245.8,91.8l-0.4,0.4l-0.4-0.4l0.4-0.4
L245.8,91.8z M245.2,92.4l-0.4,0.4l-0.4-0.4l0.4-0.4L245.2,92.4z M244.5,93.1l-0.4,0.4l-0.4-0.4l0.4-0.4L244.5,93.1z
M243.4,92.9l-0.4-0.4l0.4-0.4l0.4,0.4L243.4,92.9z M243.1,93.1l-0.4,0.4l-0.4-0.4l0.4-0.4L243.1,93.1z M242.4,93.8l-0.4,0.4
l-0.4-0.4l0.4-0.4L242.4,93.8z M242.4,95.1l-0.4,0.4l-0.4-0.4l0.4-0.4L242.4,95.1z M242.4,96.5l-0.4,0.4l-0.4-0.4l0.4-0.4
L242.4,96.5z M242.4,97.8l-0.4,0.4l-0.4-0.4l0.4-0.4L242.4,97.8z M242.4,99.1l-0.4,0.4l-0.4-0.4l0.4-0.4L242.4,99.1z
M242.3,98.5l0.4-0.4l0.4,0.4l-0.4,0.4L242.3,98.5z M243.4,98.7l0.4,0.4l-0.4,0.4l-0.4-0.4L243.4,98.7z M243.6,98.5l0.4-0.4
l0.4,0.4l-0.4,0.4L243.6,98.5z M244.7,98.7l0.4,0.4l-0.4,0.4l-0.4-0.4L244.7,98.7z M245,98.5l0.4-0.4l0.4,0.4l-0.4,0.4L245,98.5
z M246.1,98.7l0.4,0.4l-0.4,0.4l-0.4-0.4L246.1,98.7z M246.4,98.5l0.4-0.4l0.4,0.4l-0.4,0.4L246.4,98.5z M247.4,98.7l0.4,0.4
l-0.4,0.4l-0.4-0.4L247.4,98.7z M247.7,98.5l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,98.5z M247.7,97.1l0.4-0.4l0.4,0.4l-0.4,0.4
L247.7,97.1z M247.7,95.8l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,95.8z M247.7,94.5l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,94.5z M247.7,93.1
l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,93.1z M247.7,91.8l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,91.8z M247.7,90.4l0.4-0.4l0.4,0.4l-0.4,0.4
L247.7,90.4z M247.7,89.1l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,89.1z M247.7,87.7l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,87.7z M247.9,88.4
l-0.4,0.4l-0.4-0.4l0.4-0.4L247.9,88.4z M247.2,89.1l-0.4,0.4l-0.4-0.4l0.4-0.4L247.2,89.1z M246.5,89.8l-0.4,0.4l-0.4-0.4
l0.4-0.4L246.5,89.8z M245.8,90.4l-0.4,0.4l-0.4-0.4l0.4-0.4L245.8,90.4z M245.2,91.1l-0.4,0.4l-0.4-0.4l0.4-0.4L245.2,91.1z
M244.5,91.8l-0.4,0.4l-0.4-0.4l0.4-0.4L244.5,91.8z M243.4,91.5l-0.4-0.4l0.4-0.4l0.4,0.4L243.4,91.5z M243.1,91.8l-0.4,0.4
l-0.4-0.4l0.4-0.4L243.1,91.8z M242.4,92.4l-0.4,0.4l-0.4-0.4L242,92L242.4,92.4z M241.3,92.2l-0.4-0.4l0.4-0.4l0.4,0.4
L241.3,92.2z M241.8,93.1l-0.4,0.4l-0.4-0.4l0.4-0.4L241.8,93.1z M241.8,94.5l-0.4,0.4l-0.4-0.4l0.4-0.4L241.8,94.5z
M241.8,95.8l-0.4,0.4l-0.4-0.4l0.4-0.4L241.8,95.8z M241.8,97.1l-0.4,0.4l-0.4-0.4l0.4-0.4L241.8,97.1z M241.8,98.5l-0.4,0.4
l-0.4-0.4l0.4-0.4L241.8,98.5z M241.8,99.8l-0.4,0.4l-0.4-0.4l0.4-0.4L241.8,99.8z M242,100.1l0.4,0.4l-0.4,0.4l-0.4-0.4
L242,100.1z M242.3,99.8l0.4-0.4l0.4,0.4l-0.4,0.4L242.3,99.8z M243.4,100.1l0.4,0.4l-0.4,0.4l-0.4-0.4L243.4,100.1z
M243.6,99.8l0.4-0.4l0.4,0.4l-0.4,0.4L243.6,99.8z M244.7,100.1l0.4,0.4l-0.4,0.4l-0.4-0.4L244.7,100.1z M245,99.8l0.4-0.4
l0.4,0.4l-0.4,0.4L245,99.8z M246.1,100.1l0.4,0.4l-0.4,0.4l-0.4-0.4L246.1,100.1z M246.4,99.8l0.4-0.4l0.4,0.4l-0.4,0.4
L246.4,99.8z M247.4,100.1l0.4,0.4l-0.4,0.4l-0.4-0.4L247.4,100.1z M247.7,99.8l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,99.8z
M249.2,99.1l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,99.1z M249.2,97.8l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,97.8z M249.2,96.5l-0.4,0.4
l-0.4-0.4l0.4-0.4L249.2,96.5z M249.2,95.1l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,95.1z M249.2,93.8l-0.4,0.4l-0.4-0.4l0.4-0.4
L249.2,93.8z M249.2,92.4l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,92.4z M249.2,91.1l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,91.1z
M249.2,89.8l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,89.8z M249.2,88.4l-0.4,0.4l-0.4-0.4l0.4-0.4L249.2,88.4z M249.2,87.1l-0.4,0.4
l-0.4-0.4l0.4-0.4L249.2,87.1z M248.8,85.3l0.4,0.4l-0.4,0.4l-0.4-0.4L248.8,85.3z M248.1,86l0.4,0.4l-0.4,0.4l-0.4-0.4
L248.1,86z M247.4,86.7l0.4,0.4l-0.4,0.4l-0.4-0.4L247.4,86.7z M246.8,87.3l0.4,0.4l-0.4,0.4l-0.4-0.4L246.8,87.3z M246.1,88
l0.4,0.4l-0.4,0.4l-0.4-0.4L246.1,88z M245.4,88.7l0.4,0.4l-0.4,0.4l-0.4-0.4L245.4,88.7z M244.7,89.3l0.4,0.4l-0.4,0.4
l-0.4-0.4L244.7,89.3z M244.5,90.4l-0.4,0.4l-0.4-0.4l0.4-0.4L244.5,90.4z M243.4,89.3l0.4,0.4l-0.4,0.4l-0.4-0.4L243.4,89.3z
M242.7,90l0.4,0.4l-0.4,0.4l-0.4-0.4L242.7,90z M242.4,91.1l-0.4,0.4l-0.4-0.4l0.4-0.4L242.4,91.1z M241.3,90l0.4,0.4l-0.4,0.4
l-0.4-0.4L241.3,90z M240.3,91.1l0.4-0.4l0.4,0.4l-0.4,0.4L240.3,91.1z M240.3,92.4l0.4-0.4l0.4,0.4l-0.4,0.4L240.3,92.4z
M240.3,93.8l0.4-0.4l0.4,0.4l-0.4,0.4L240.3,93.8z M240.3,95.1l0.4-0.4l0.4,0.4l-0.4,0.4L240.3,95.1z M240.3,96.5l0.4-0.4
l0.4,0.4l-0.4,0.4L240.3,96.5z M240.3,97.8l0.4-0.4l0.4,0.4l-0.4,0.4L240.3,97.8z M240.3,99.1l0.4-0.4l0.4,0.4l-0.4,0.4
L240.3,99.1z M240.3,100.5l0.4-0.4l0.4,0.4l-0.4,0.4L240.3,100.5z M240.7,102.2l-0.4-0.4l0.4-0.4l0.4,0.4L240.7,102.2z
M240.9,101.2l0.4-0.4l0.4,0.4l-0.4,0.4L240.9,101.2z M242,102.2l-0.4-0.4l0.4-0.4l0.4,0.4L242,102.2z M242.3,101.2l0.4-0.4
l0.4,0.4l-0.4,0.4L242.3,101.2z M243.4,102.2l-0.4-0.4l0.4-0.4l0.4,0.4L243.4,102.2z M243.6,101.2l0.4-0.4l0.4,0.4l-0.4,0.4
L243.6,101.2z M244.7,102.2l-0.4-0.4l0.4-0.4l0.4,0.4L244.7,102.2z M245,101.2l0.4-0.4l0.4,0.4l-0.4,0.4L245,101.2z
M246.1,102.2l-0.4-0.4l0.4-0.4l0.4,0.4L246.1,102.2z M246.4,101.2l0.4-0.4l0.4,0.4l-0.4,0.4L246.4,101.2z M247.4,102.2
l-0.4-0.4l0.4-0.4l0.4,0.4L247.4,102.2z M247.7,101.2l0.4-0.4l0.4,0.4l-0.4,0.4L247.7,101.2z M248.4,101.8l0.4-0.4l0.4,0.4
l-0.4,0.4L248.4,101.8z" />
</g>
</g>
</g>
<g>
<path class="st0" d="M230.3,52.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C230.5,52.6,230.4,52.7,230.3,52.7z" />
</g>
<g>
<path class="st0" d="M231.5,52.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C231.7,52.6,231.6,52.7,231.5,52.7z" />
</g>
<g>
<path class="st0" d="M232.6,52.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C232.9,52.6,232.8,52.7,232.6,52.7z" />
</g>
<g>
<path class="st0" d="M233.8,52.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C234,52.6,234,52.7,233.8,52.7z" />
</g>
<g>
<path class="st0" d="M235,52.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C235.2,52.6,235.1,52.7,235,52.7z" />
</g>
<g>
<path class="st0" d="M247.2,52.2c-0.7,0-1.4-0.6-1.4-1.4c0-0.7,0.6-1.4,1.4-1.4c0.7,0,1.4,0.6,1.4,1.4
C248.5,51.6,247.9,52.2,247.2,52.2z M247.2,50c-0.5,0-0.9,0.4-0.9,0.9s0.4,0.9,0.9,0.9s0.9-0.4,0.9-0.9
C248.1,50.4,247.7,50,247.2,50z" />
</g>
<path class="st0" d="M239,50.7v0.4h-0.4v-0.4H239 M239,50.2h-0.4c-0.2,0-0.4,0.2-0.4,0.4V51c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C239.4,50.4,239.2,50.2,239,50.2L239,50.2z" />
<path class="st0" d="M241.4,50.7v0.4H241v-0.4H241.4 M241.4,50.2H241c-0.2,0-0.4,0.2-0.4,0.4V51c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C241.8,50.4,241.6,50.2,241.4,50.2L241.4,50.2z" />
<path class="st0" d="M243.8,50.7v0.4h-0.4v-0.4H243.8 M243.8,50.2h-0.4c-0.2,0-0.4,0.2-0.4,0.4V51c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C244.2,50.4,244,50.2,243.8,50.2L243.8,50.2z" />
<g>
<path class="st0" d="M230.3,61.2c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2V61
C230.5,61.1,230.4,61.2,230.3,61.2z" />
</g>
<g>
<path class="st0" d="M231.5,61.2c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2V61
C231.7,61.1,231.6,61.2,231.5,61.2z" />
</g>
<g>
<path class="st0" d="M232.6,61.2c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2V61
C232.9,61.1,232.8,61.2,232.6,61.2z" />
</g>
<g>
<path class="st0" d="M233.8,61.2c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2V61
C234,61.1,234,61.2,233.8,61.2z" />
</g>
<g>
<path class="st0" d="M235,61.2c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2V61
C235.2,61.1,235.1,61.2,235,61.2z" />
</g>
<g>
<path class="st0" d="M247.2,60.8c-0.7,0-1.4-0.6-1.4-1.4c0-0.7,0.6-1.4,1.4-1.4c0.7,0,1.4,0.6,1.4,1.4
C248.5,60.2,247.9,60.8,247.2,60.8z M247.2,58.5c-0.5,0-0.9,0.4-0.9,0.9s0.4,0.9,0.9,0.9s0.9-0.4,0.9-0.9S247.7,58.5,247.2,58.5z" />
</g>
<path class="st0" d="M239,59.2v0.4h-0.4v-0.4H239 M239,58.8h-0.4c-0.2,0-0.4,0.2-0.4,0.4v0.4c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C239.4,58.9,239.2,58.8,239,58.8L239,58.8z" />
<path class="st0" d="M241.4,59.2v0.4H241v-0.4H241.4 M241.4,58.8H241c-0.2,0-0.4,0.2-0.4,0.4v0.4c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C241.8,58.9,241.6,58.8,241.4,58.8L241.4,58.8z" />
<path class="st0" d="M243.8,59.2v0.4h-0.4v-0.4H243.8 M243.8,58.8h-0.4c-0.2,0-0.4,0.2-0.4,0.4v0.4c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C244.2,58.9,244,58.8,243.8,58.8L243.8,58.8z" />
<g>
<path class="st0" d="M230.3,69.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C230.5,69.7,230.4,69.7,230.3,69.7z" />
</g>
<g>
<path class="st0" d="M231.5,69.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C231.7,69.7,231.6,69.7,231.5,69.7z" />
</g>
<g>
<path class="st0" d="M232.6,69.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C232.9,69.7,232.8,69.7,232.6,69.7z" />
</g>
<g>
<path class="st0" d="M233.8,69.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C234,69.7,234,69.7,233.8,69.7z" />
</g>
<g>
<path class="st0" d="M235,69.7c-0.1,0-0.2-0.1-0.2-0.2v-3.1c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2v3.1
C235.2,69.7,235.1,69.7,235,69.7z" />
</g>
<g>
<path class="st0" d="M247.2,69.3c-0.7,0-1.4-0.6-1.4-1.4c0-0.7,0.6-1.4,1.4-1.4c0.7,0,1.4,0.6,1.4,1.4S247.9,69.3,247.2,69.3z
M247.2,67.1c-0.5,0-0.9,0.4-0.9,0.9s0.4,0.9,0.9,0.9s0.9-0.4,0.9-0.9C248.1,67.5,247.7,67.1,247.2,67.1z" />
</g>
<path class="st0" d="M239,67.7v0.4h-0.4v-0.4H239 M239,67.3h-0.4c-0.2,0-0.4,0.2-0.4,0.4v0.4c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C239.4,67.5,239.2,67.3,239,67.3L239,67.3z" />
<path class="st0" d="M241.4,67.7v0.4H241v-0.4H241.4 M241.4,67.3H241c-0.2,0-0.4,0.2-0.4,0.4v0.4c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C241.8,67.5,241.6,67.3,241.4,67.3L241.4,67.3z" />
<path class="st0" d="M243.8,67.7v0.4h-0.4v-0.4H243.8 M243.8,67.3h-0.4c-0.2,0-0.4,0.2-0.4,0.4v0.4c0,0.2,0.2,0.4,0.4,0.4h0.4
c0.2,0,0.4-0.2,0.4-0.4v-0.4C244.2,67.5,244,67.3,243.8,67.3L243.8,67.3z" />
<path class="st0" d="M250.8,54.5c0.1,0,0.2-0.1,0.2-0.2v-6.7c0-0.1-0.1-0.2-0.2-0.2h-22.5c-0.1,0-0.2,0.1-0.2,0.2V51
c-2,0.4-3.6,2.2-3.6,4.4c0,2,1.3,3.7,3.1,4.3c-1.8,0.6-3.1,2.3-3.1,4.3c0,2.2,1.5,4,3.6,4.4v3.1c0,0.1,0.1,0.2,0.2,0.2h22.5
c0.1,0,0.2-0.1,0.2-0.2v-6.7c0-0.1-0.1-0.2-0.2-0.2h-2.9V63h2.9c0.1,0,0.2-0.1,0.2-0.2V56c0-0.1-0.1-0.2-0.2-0.2h-2.9v-1.4h2.9
V54.5z M228.5,47.7h22V54h-22v-2.8v-0.4V47.7z M224.9,55.3c0-1.9,1.4-3.5,3.1-4v2.9c0,0.1,0.1,0.2,0.2,0.2h2.9v1.4h-2.9
c-0.1,0-0.2,0.1-0.2,0.2v3.2C226.3,58.8,224.9,57.2,224.9,55.3z M224.9,63.8c0-1.9,1.4-3.5,3.1-4v2.9c0,0.1,0.1,0.2,0.2,0.2h2.9
v1.4h-2.9c-0.1,0-0.2,0.1-0.2,0.2v3.2C226.3,67.4,224.9,65.7,224.9,63.8z M250.5,71.1h-22v-2.8v-0.4v-3h22V71.1L250.5,71.1z
M247.4,64.4h-15.7V63h15.7V64.4z M250.5,62.6h-22v-2.8v-0.1v-0.4v-0.1v-3h22V62.6L250.5,62.6z M247.4,55.8h-15.7v-1.4h15.7V55.8z" />
</g>
<g id="poster">
<rect x="112" y="26" class="st0" width="0.8" height="0.8" />
<rect x="110.4" y="26" class="st0" width="0.8" height="0.8" />
<rect x="113.7" y="26" class="st0" width="0.8" height="0.8" />
<rect x="107.6" y="19.1" class="st0" width="9.8" height="0.8" />
<rect x="114.5" y="32.1" class="st0" width="0.8" height="0.8" />
<path class="st0" d="M118.4,29.4l-1.5-2.3l0.9-0.9v-4.3c0.7-0.2,1.2-0.8,1.2-1.6v-2.2l-0.8-0.8c-0.1-3.1-2.6-5.5-5.6-5.5
c-3.1,0-5.6,2.4-5.7,5.5l-0.8,0.8v2.2c0,0.8,0.5,1.4,1.2,1.6v4.3l0.9,0.9l-1.5,2.3L101,31l-1.4,2.2V37h0.8v-3.3l5.8-1.5l-0.2-0.8
l-5.1,1.4l0.6-1l5.1-1.5c0.2,0.6,0.8,1.1,1.5,1.1h3.2v2.4h0.8v-3.2H108c-0.4,0-0.7-0.3-0.8-0.7l1.4-2.2l1.2,1.2h5.2l1.2-1.2
l1.4,2.2c0,0.4-0.4,0.7-0.8,0.7h-4V37h0.8v-5.7h3.2c0.7,0,1.3-0.4,1.5-1.1l5.1,1.8l0.6,1l-5-1.7l-0.2,0.8l5.8,1.9v3h0.8v-3.4
l-1.3-2.2L118.4,29.4z M108,22h8.9v1l-1.6,1.6l-0.7-0.6h-4.4l-0.6,0.6L108,23V22z M106.8,20.3v-1.9l0.6-0.6h1.1V17h-0.8
c0.2-2.5,2.3-4.5,4.8-4.5c2.6,0,4.6,2,4.8,4.5h-8.1v0.8h8.4l0.6,0.6v1.9c0,0.4-0.4,0.8-0.8,0.8H117h-9h-0.4
C107.1,21.2,106.8,20.8,106.8,20.3z M114.7,28.1h-4.5l-2.2-2.2v-1.7l1.6,1.6l1-1h3.7l1,1l1.6-1.6v1.7L114.7,28.1z" />
<rect x="105.1" y="35.4" class="st0" width="0.8" height="1.6" />
<rect x="119" y="35.4" class="st0" width="0.8" height="1.6" />
<rect x="111.2" y="36.2" class="st0" width="0.8" height="0.8" />
<rect x="111.2" y="34.6" class="st0" width="0.8" height="0.8" />
<rect x="119.8" y="24" class="st0" width="0.8" height="0.8" />
<rect x="121.4" y="25.6" class="st0" width="0.8" height="0.8" />
<rect x="121.4" y="24" class="st0" width="0.8" height="0.8" />
<rect x="119.8" y="27.2" class="st0" width="0.8" height="0.8" />
<rect x="123" y="27.2" class="st0" width="0.8" height="0.8" />
<rect x="123" y="28.9" class="st0" width="0.8" height="0.8" />
<rect x="124.6" y="27.2" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="28.9" class="st0" width="0.8" height="0.8" />
<rect x="119.8" y="22.4" class="st0" width="0.8" height="0.8" />
<rect x="123" y="25.6" class="st0" width="0.8" height="0.8" />
<rect x="124.6" y="22.4" class="st0" width="0.8" height="0.8" />
<rect x="124.6" y="24" class="st0" width="0.8" height="0.8" />
<rect x="124.6" y="19.1" class="st0" width="0.8" height="0.8" />
<rect x="123" y="20.8" class="st0" width="0.8" height="0.8" />
<rect x="123" y="17.5" class="st0" width="0.8" height="0.8" />
<rect x="121.4" y="19.1" class="st0" width="0.8" height="0.8" />
<rect x="119.8" y="16.9" class="st0" width="0.8" height="0.8" />
<rect x="118.8" y="14.2" class="st0" width="0.8" height="0.8" />
<rect x="118.1" y="11" class="st0" width="0.8" height="0.8" />
<rect x="101.1" y="20.8" class="st0" width="0.8" height="0.8" />
<rect x="102.7" y="20.8" class="st0" width="0.8" height="0.8" />
<rect x="102.7" y="25.6" class="st0" width="0.8" height="0.8" />
<rect x="101.1" y="24" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="25.6" class="st0" width="0.8" height="0.8" />
<rect x="102.7" y="27.2" class="st0" width="0.8" height="0.8" />
<rect x="101.1" y="27.2" class="st0" width="0.8" height="0.8" />
<rect x="104.3" y="24" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="22.4" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="19.1" class="st0" width="0.8" height="0.8" />
<rect x="102.7" y="17.5" class="st0" width="0.8" height="0.8" />
<rect x="104.3" y="15.9" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="11" class="st0" width="0.8" height="0.8" />
<rect x="104.3" y="11" class="st0" width="0.8" height="0.8" />
<rect x="106" y="11" class="st0" width="0.8" height="0.8" />
<rect x="101.1" y="11" class="st0" width="0.8" height="0.8" />
<rect x="101.1" y="19.1" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="15.9" class="st0" width="0.8" height="0.8" />
<rect x="101.1" y="15.9" class="st0" width="0.8" height="0.8" />
<rect x="99.5" y="14.2" class="st0" width="0.8" height="0.8" />
<rect x="104.3" y="12.6" class="st0" width="0.8" height="0.8" />
<rect x="102.7" y="12.6" class="st0" width="0.8" height="0.8" />
<rect x="124.6" y="16.1" class="st0" width="0.8" height="0.8" />
<rect x="119.8" y="12.2" class="st0" width="0.8" height="0.8" />
</g>
<g id="radiator">
<path class="st0" d="M279,77.7v1.1l0,0V77.7L279,77.7z M279,97.6v1.1l0,0V97.6L279,97.6z" />
<path class="st0" d="M269.6,99c0.1,0.1,0.2,0.2,0.3,0.2C269.8,99.2,269.6,99.1,269.6,99z M270,98.1L270,98.1L270,98.1
c0,0.2,0,0.3,0.2,0.4C270,98.4,270,98.3,270,98.1z" />
<path class="st0" d="M278.2,76.6V80l0,0V76.6L278.2,76.6z" />
<path class="st0" d="M297.6,96.8h-0.1c-0.2,0-0.4-0.2-0.4-0.4V80c0-0.2,0.2-0.4,0.4-0.4h0.1c0.7,0,1.3-0.6,1.3-1.3
s-0.6-1.3-1.3-1.3h-0.1c-0.2,0-0.4-0.2-0.4-0.4v-0.1c0-0.5-0.4-1.3-1.3-1.3s-1.3,0.8-1.3,1.3v0.1c0,0.2-0.2,0.4-0.4,0.4h-0.2
c-0.2,0-0.4-0.2-0.4-0.4v-0.1c0-0.5-0.4-1.3-1.3-1.3s-1.3,0.8-1.3,1.3v0.1c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4v-0.1
c0-0.5-0.4-1.3-1.3-1.3s-1.3,0.8-1.3,1.3v0.1c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4v-0.1c0-0.5-0.4-1.3-1.3-1.3
s-1.3,0.8-1.3,1.3v0.1c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4v-0.1c0-0.5-0.4-1.3-1.3-1.3s-1.3,0.8-1.3,1.3v0.1
c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4v-0.2c0-0.5-0.4-1.3-1.3-1.3s-1.3,0.8-1.3,1.3v0.1c0,0.2-0.2,0.4-0.4,0.4h-0.2
c-0.2,0-0.4-0.2-0.4-0.4v-0.1c0-0.5-0.4-1.3-1.3-1.3s-1.3,0.8-1.3,1.3v0.1c0,0.2-0.2,0.4-0.4,0.4h-0.6v-0.2c0-0.4-0.4-0.8-0.8-0.8
h-1c-0.4,0-0.8,0.4-0.8,0.8v2.9c0,0.4,0.4,0.8,0.8,0.8h1c0.4,0,0.8-0.4,0.8-0.8v-0.2h0.6c0.2,0,0.4,0.2,0.4,0.4v16.4
c0,0.2-0.2,0.4-0.4,0.4h-1.9c-0.2,0-0.5,0.1-0.7,0.2c-0.1,0-0.2,0.1-0.2,0.2c-0.1,0.1-0.1,0.1-0.2,0.2c0,0-0.1,0.1-0.1,0.2
s-0.1,0.2-0.1,0.3l0,0c0,0.1,0,0.2,0,0.3c0,0.1,0,0.2,0,0.3c0,0.2,0.2,0.5,0.4,0.6c0.1,0.1,0.2,0.2,0.3,0.2
c0.2,0.1,0.4,0.2,0.6,0.2h1.9c0.2,0,0.4,0.2,0.4,0.4v3.7c0,0.5,0.4,1.3,1.3,1.3s1.3-0.8,1.3-1.3c0-0.1,0-2.3,2.3-2.3h14.5
c2.2,0,2.3,2.1,2.3,2.3c0,0.5,0.4,1.3,1.3,1.3s1.3-0.8,1.3-1.3v-3.7c0-0.2,0.2-0.4,0.4-0.4h0.1c0.7,0,1.3-0.6,1.3-1.3
C298.9,97.4,298.3,96.8,297.6,96.8z M297,77.7c0.1,0,0.3,0.1,0.4,0.1h0.1c0.3,0,0.5,0.2,0.5,0.5s-0.2,0.5-0.5,0.5h-0.1
c-0.2,0-0.3,0-0.4,0.1V77.7z M271,79.7h-1v-2.9h1V79.7z M270.5,98.6c-0.2,0-0.3-0.1-0.4-0.2s-0.2-0.2-0.2-0.4v-0.1
c0-0.1,0.1-0.2,0.1-0.2s0.1-0.1,0.2-0.1s0.1,0,0.2,0c0.3,0,0.5,0.2,0.5,0.5C271,98.4,270.7,98.6,270.5,98.6z M272.8,98.7
c-0.1,0-0.3-0.1-0.4-0.1h-0.7c0.1-0.2,0.1-0.3,0.1-0.5s0-0.4-0.1-0.5h0.7c0.1,0,0.3,0,0.4-0.1V98.7z M272.8,78.9
c-0.1,0-0.3-0.1-0.4-0.1h-0.6v-1h0.6c0.1,0,0.3,0,0.4-0.1V78.9z M275.4,77.7c0.1,0,0.3,0.1,0.4,0.1h0.2c0.1,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.3-0.1-0.4-0.1h-0.2c-0.1,0-0.3,0-0.4,0.1V77.7z M275.4,80c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v16.4
c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4V80z M275.4,97.6c0.1,0,0.3,0.1,0.4,0.1h0.2c0.1,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.3-0.1-0.4-0.1h-0.2c-0.1,0-0.3,0-0.4,0.1V97.6z M273.6,76.5c0-0.1,0-0.5,0.5-0.5s0.5,0.4,0.5,0.5v23.4
c0,0.2,0,0.5-0.5,0.5c-0.4,0-0.5-0.4-0.5-0.5V76.5z M274.6,103.5c0,0.1,0,0.5-0.5,0.5c-0.4,0-0.5-0.4-0.5-0.5v-2.4
c0.2,0.1,0.3,0.1,0.5,0.1c0.9,0,1.3-0.8,1.3-1.3v-0.1c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v0.1c0,0.2,0,0.5,0.2,0.7
C275,101.1,274.6,102.6,274.6,103.5z M278.2,99.9c0,0.1,0,0.5-0.5,0.5c-0.4,0-0.5-0.4-0.5-0.5V76.5c0-0.1,0-0.5,0.5-0.5
s0.5,0.4,0.5,0.5V99.9z M279,77.7L279,77.7c0.1,0,0.3,0.1,0.4,0.1h0.2c0.1,0,0.3,0,0.4-0.1v1.1c-0.1,0-0.3-0.1-0.4-0.1h-0.2
c-0.2,0-0.3,0-0.4,0.1l0,0V77.7z M280,80v16.4c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4V79.9c0-0.2,0.2-0.4,0.4-0.4h0.2
C279.8,79.6,280,79.8,280,80z M279,97.6L279,97.6c0.1,0,0.3,0.1,0.4,0.1h0.2c0.1,0,0.3,0,0.4-0.1v1.1c-0.1,0-0.3-0.1-0.4-0.1h-0.2
c-0.2,0-0.3,0-0.4,0.1l0,0V97.6z M278.9,100.4c0.1-0.2,0.1-0.4,0.1-0.5v-0.2c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v0.1
c0,0.2,0,0.3,0.1,0.5L278.9,100.4L278.9,100.4z M281.8,99.9c0,0.2-0.1,0.5-0.5,0.5s-0.5-0.4-0.5-0.5V76.5c0-0.1,0-0.5,0.5-0.5
c0.4,0,0.5,0.4,0.5,0.5V99.9z M282.6,77.7c0.1,0,0.2,0.1,0.4,0.1h0.2c0.1,0,0.3,0,0.4-0.1v1.1c-0.1,0-0.3-0.1-0.4-0.1H283
c-0.1,0-0.3,0-0.4,0.1V77.7L282.6,77.7z M282.6,80c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v16.4c0,0.2-0.2,0.4-0.4,0.4
H283c-0.2,0-0.4-0.2-0.4-0.4V80L282.6,80z M282.6,97.6c0.1,0,0.2,0.1,0.4,0.1h0.2c0.1,0,0.3,0,0.4-0.1v1.1c-0.1,0-0.3-0.1-0.4-0.1
H283c-0.1,0-0.3,0-0.4,0.1V97.6L282.6,97.6z M282.5,100.4c0.1-0.2,0.1-0.4,0.1-0.5v-0.1c0-0.2,0.2-0.4,0.4-0.4h0.2
c0.2,0,0.4,0.2,0.4,0.4v0.1c0,0.2,0,0.3,0.1,0.5H282.5z M285.4,99.9c0,0.2,0,0.5-0.5,0.5c-0.4,0-0.5-0.4-0.5-0.5V76.5
c0-0.1,0-0.5,0.5-0.5s0.5,0.4,0.5,0.5V99.9z M286.2,77.7c0.1,0,0.3,0.1,0.4,0.1h0.2c0.2,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.2-0.1-0.4-0.1h-0.2c-0.1,0-0.3,0-0.4,0.1V77.7z M286.2,80c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v16.4
c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4V80z M286.2,97.6c0.1,0,0.3,0.1,0.4,0.1h0.2c0.2,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.2-0.1-0.4-0.1h-0.2c-0.1,0-0.3,0-0.4,0.1V97.6z M286.1,100.4c0.1-0.2,0.1-0.4,0.1-0.5v-0.1c0-0.2,0.2-0.4,0.4-0.4h0.2
c0.2,0,0.4,0.2,0.4,0.4v0.1c0,0.2,0,0.3,0.1,0.5H286.1z M289,99.9c0,0.2-0.1,0.5-0.5,0.5s-0.5-0.4-0.5-0.5V76.5
c0-0.1,0-0.5,0.5-0.5c0.4,0,0.5,0.4,0.5,0.5V99.9z M289.8,77.7c0.1,0,0.3,0.1,0.4,0.1h0.2c0.2,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.3-0.1-0.4-0.1h-0.2c-0.2,0-0.3,0-0.4,0.1V77.7z M289.8,80c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v16.4
c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4V80z M289.8,97.6c0.1,0,0.3,0.1,0.4,0.1h0.2c0.2,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.3-0.1-0.4-0.1h-0.2c-0.2,0-0.3,0-0.4,0.1V97.6z M289.7,100.4c0.1-0.2,0.1-0.4,0.1-0.5v-0.1c0-0.2,0.2-0.4,0.4-0.4h0.2
c0.2,0,0.4,0.2,0.4,0.4v0.1c0,0.2,0,0.3,0.1,0.5H289.7z M292.6,99.9c0,0.1,0,0.5-0.5,0.5l0,0c-0.5,0-0.5-0.4-0.5-0.5V76.5
c0-0.2,0-0.5,0.5-0.5c0.4,0,0.5,0.4,0.5,0.5V99.9L292.6,99.9z M293.4,77.7c0.1,0,0.3,0.1,0.4,0.1h0.2c0.2,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.3-0.1-0.4-0.1h-0.2c-0.2,0-0.3,0-0.4,0.1V77.7z M293.4,80c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v16.4
c0,0.2-0.2,0.4-0.4,0.4h-0.2c-0.2,0-0.4-0.2-0.4-0.4V80z M293.4,97.6c0.1,0,0.3,0.1,0.4,0.1h0.2c0.2,0,0.3,0,0.4-0.1v1.1
c-0.1,0-0.3-0.1-0.4-0.1h-0.2c-0.2,0-0.3,0-0.4,0.1V97.6z M296.3,103.5c0,0.2-0.1,0.5-0.5,0.5s-0.5-0.4-0.5-0.5
c0-0.9-0.4-2.4-2-2.9c0.1-0.2,0.2-0.5,0.2-0.7v-0.1c0-0.2,0.2-0.4,0.4-0.4h0.2c0.2,0,0.4,0.2,0.4,0.4v0.1c0,0.5,0.4,1.3,1.3,1.3
c0.2,0,0.4,0,0.5-0.1V103.5z M296.3,99.9c0,0.1,0,0.5-0.5,0.5s-0.5-0.4-0.5-0.5V76.5c0-0.2,0.1-0.5,0.5-0.5s0.5,0.4,0.5,0.5V99.9z
M297.6,98.6h-0.1c-0.2,0-0.3,0-0.4,0.1v-1.1c0.1,0,0.3,0.1,0.4,0.1h0.1c0.3,0,0.5,0.2,0.5,0.5S297.8,98.6,297.6,98.6z" />
<path class="st0" d="M278.2,96.5v3.4l0,0V96.5L278.2,96.5z" />
<path class="st0" d="M273.4,100.8" />
<path class="st0" d="M269.2,97.8c0,0.1,0,0.2,0,0.3s0,0.2,0,0.3c0-0.1,0-0.2,0-0.3S269.2,97.9,269.2,97.8z" />
</g>
<g id="plant">
<polygon class="st0" points="105.9,90.5 92.2,90.5 93.9,103.8 103.8,103.8 " />
<g>
<path class="st0" d="M98.4,90.9c-0.1,0-0.2-0.1-0.2-0.2S97.7,80,96.5,74.5c0-0.1,0.1-0.3,0.2-0.3s0.3,0.1,0.3,0.2
c1.3,5.6,1.8,16.2,1.8,16.3C98.6,90.7,98.5,90.9,98.4,90.9L98.4,90.9z" />
</g>
<g>
<path class="st0" d="M99.7,90.9c-0.1,0-0.2-0.1-0.2-0.2s-0.1-8.2,2.4-14.5c0.1-0.1,0.2-0.2,0.3-0.1c0.1,0.1,0.2,0.2,0.1,0.3
c-2.5,6.1-2.4,14.2-2.4,14.3C99.9,90.8,99.8,90.9,99.7,90.9L99.7,90.9z" />
</g>
<g>
<path class="st0" d="M97.6,90.8c-0.1,0-0.2-0.1-0.2-0.2s-1.1-9.9-5-14.1c-0.1-0.1-0.1-0.3,0-0.3c0.1-0.1,0.3-0.1,0.3,0
c4,4.3,5.1,14,5.1,14.4C97.9,90.7,97.8,90.8,97.6,90.8C97.7,90.8,97.6,90.8,97.6,90.8z" />
</g>
<g>
<path class="st0" d="M99,90.9c-0.1,0-0.2-0.1-0.2-0.2c0-0.4-0.7-10.5,0.6-15.5c0-0.1,0.2-0.2,0.3-0.2c0.1,0,0.2,0.2,0.2,0.3
c-1.3,4.9-0.6,15.2-0.6,15.3C99.3,90.7,99.2,90.9,99,90.9C99.1,90.9,99,90.9,99,90.9z" />
</g>
<g>
<path class="st0" d="M100.3,90.9c-0.1,0-0.2-0.1-0.2-0.2s-0.2-6.4,4.8-10.2c0.1-0.1,0.3-0.1,0.3,0s0.1,0.3,0,0.3
c-4.8,3.6-4.6,9.7-4.6,9.7C100.6,90.7,100.5,90.9,100.3,90.9L100.3,90.9z" />
</g>
<g>
<path class="st0" d="M90.1,78.8c-0.2,0-0.3,0-0.3-0.1l-2.5-0.8c-0.1,0-0.2-0.1-0.2-0.3c0-0.1,0.1-0.2,0.2-0.2
c0.4,0,1.5-0.3,1.8-0.9v-0.1c0,0-0.1,0-0.2,0c-0.6,0-1.7,0.4-2.3,0.9c-0.1,0.1-0.2,0.1-0.3,0c-0.2-0.1-1.8-0.7-2.3-1.5
c0-0.1,0-0.2,0-0.2s0.1-0.1,0.2-0.1c0.8,0,1.7-0.2,1.8-0.5c0,0,0-0.1,0-0.2s-0.1-0.2-0.5-0.2c-0.7,0-1.8,0.6-1.8,0.6
c-0.1,0-0.2,0-0.2,0c-0.1-0.1-2.2-1.3-2.3-2.8v-0.1v-0.1c0,0,0-0.1,0.1-0.1c1.1-0.9,4.1-1,4.2-1s0.2,0.1,0.2,0.2
c0.1,0.4,0.6,1.6,1.2,1.4c0.1,0,0.1-0.1,0.1-0.1c0-0.1-0.4-0.7-0.8-1c-0.1-0.1-0.1-0.2-0.1-0.2c0-0.1,0.1-0.2,0.2-0.2
c0.9-0.1,2.5,0.7,2.6,0.7S89,72,89,72.1c0.1,0.7,0.6,2,0.9,2.1c0,0,0.1,0,0.2-0.2c0.3-0.6-0.2-1.6-0.4-1.9c-0.1-0.1-0.1-0.2,0-0.3
c0.1-0.1,0.2-0.1,0.3,0l2.3,1.4c0.2,0.1,0.9,0.4,0.8,2c0,0.9-0.3,1.3-0.4,1.5s-0.2,0.8-0.9,1.3C90.9,78.7,90.4,78.8,90.1,78.8z
M90,78.3c0,0,0.5,0.2,1.5-0.7c0.6-0.5,0.7-1,0.7-1.1s0-0.1,0.1-0.1l0,0c0,0,0.3-0.3,0.3-1.2c0.1-1.4-0.5-1.6-0.5-1.6s0,0-0.1,0
l-1.6-0.9c0.2,0.5,0.3,1.1,0.1,1.7c-0.3,0.5-0.7,0.6-1,0.3c-0.4-0.4-0.8-1.7-0.9-2.1c-0.3-0.1-1-0.5-1.6-0.6
c0.3,0.3,0.6,0.7,0.5,1.1c0,0.1-0.2,0.3-0.5,0.4c-1,0.2-1.5-1.1-1.7-1.6c-0.6,0-2.8,0.2-3.7,0.8c0.1,1,1.6,2,2,2.2
c0.3-0.2,1.2-0.6,1.9-0.6c0.5,0,0.8,0.2,0.9,0.4c0.2,0.3,0.1,0.5,0,0.6c-0.2,0.4-1.1,0.6-1.7,0.7c0.5,0.4,1.2,0.7,1.6,0.9
c0.7-0.5,1.8-0.9,2.5-0.9c0.3,0,0.5,0.1,0.6,0.3c0.1,0.1,0.1,0.3,0,0.5c-0.2,0.5-0.8,0.9-1.3,1L90,78.3
C89.9,78.3,89.9,78.3,90,78.3L90,78.3z" />
</g>
<g>
<path class="st0" d="M101.6,76.5c-0.1,0-0.1,0-0.2,0c-0.9,0-1.6-0.7-1.8-1c-0.3,0-1-0.1-1.8-0.9c-1.6-1.6-1.2-2.8-1.1-2.9l0.8-2.7
c0-0.1,0.1-0.2,0.2-0.2s0.2,0.1,0.2,0.2c0,0,0.4,1.8,1.4,2.2c0.1,0.1,0.2,0.1,0.3,0.1c0.1-0.4-1.1-2.5-1.6-3.2
c-0.1-0.1-0.1-0.1,0-0.2c0-0.1,0.8-1.8,1.7-2.3c0.1,0,0.2,0,0.2,0c0.1,0,0.1,0.1,0.1,0.2c0.1,0.9,0.4,2,0.7,2h0.1
c0.1-0.1,0.2-0.1,0.2-0.2c0.2-0.6-0.5-1.9-0.8-2.3c-0.1-0.1,0-0.2,0-0.3c0.1-0.1,2-2.6,3.7-2.6h0.1h0.1c0,0,0.1,0,0.1,0.1
c1.2,1.4,1.1,4.6,1.1,4.8c0,0.1-0.1,0.2-0.2,0.2c-0.4,0.1-1.6,0.5-1.9,1.1c-0.1,0.1-0.1,0.3-0.1,0.5c0.1,0.2,0.2,0.2,0.2,0.2
c0.4,0,1.1-0.6,1.5-1c0.1-0.1,0.1-0.1,0.2-0.1s0.2,0.1,0.2,0.2c0.3,1.1-0.2,3.1-0.2,3.2s-0.1,0.2-0.3,0.2c-0.1,0-0.2,0-0.2,0
c-1.1,0-2.4,0.6-2.5,1c0,0.1,0.1,0.1,0.1,0.1c0.2,0.1,0.4,0.2,0.7,0.2c0.8,0,1.6-0.5,1.6-0.5c0.1-0.1,0.2-0.1,0.3,0
c0.1,0.1,0.1,0.2,0.1,0.3l-1,2.8C103.8,75.5,103.4,76.5,101.6,76.5z M99.7,75c0.1,0,0.2,0,0.2,0.1c0,0,0.6,0.9,1.5,0.9
c1.7,0.1,2-0.7,2-0.7l0.8-2.2c-0.3,0.1-0.8,0.3-1.3,0.3c-0.3,0-0.6-0.1-0.9-0.2c-0.4-0.2-0.4-0.6-0.4-0.7c0.2-0.7,1.9-1.4,3-1.3
c0.1-0.4,0.3-1.5,0.3-2.3c-0.4,0.4-1,0.9-1.5,0.9c-0.2,0-0.5-0.1-0.7-0.6c-0.1-0.3-0.1-0.6,0.1-0.8c0.4-0.7,1.6-1.1,2-1.2
c0-0.7-0.1-3.1-1-4.2c-1.2,0.1-2.7,1.8-3.1,2.3c0.3,0.4,1,1.7,0.7,2.5c-0.1,0.2-0.2,0.4-0.4,0.6c-0.1,0.1-0.2,0.1-0.4,0.1
c-0.7,0-1-1.3-1.1-2c-0.4,0.5-0.9,1.3-1.1,1.7c0.4,0.6,1.8,2.8,1.6,3.5c-0.1,0.3-0.4,0.4-0.9,0.1c-0.7-0.3-1.2-1.2-1.4-1.8l-0.6,2
c0,0-0.3,1.1,1,2.4c0.7,0.6,1.2,0.7,1.4,0.7C99.6,75,99.6,75,99.7,75C99.6,75,99.6,75,99.7,75z" />
</g>
<g>
<path class="st0" d="M99.7,75.4C99.6,75.4,99.6,75.4,99.7,75.4c-0.2-0.1-0.3-0.2-0.2-0.3l4.2-12.6c0-0.1,0.2-0.2,0.3-0.2
c0.1,0,0.2,0.2,0.2,0.3L100,75.2C99.9,75.4,99.8,75.4,99.7,75.4z" />
</g>
<g>
<path class="st0" d="M105.4,83.2c-0.3,0-0.7-0.1-1.1-0.3c-0.6-0.3-0.8-0.7-0.9-0.8c-0.1-0.1-0.4-0.4-0.5-1.2
c-0.3-1.3,0.2-1.8,0.4-1.9l1.7-1.8c0.1-0.1,0.2-0.1,0.3,0c0.1,0.1,0.1,0.2,0.1,0.3c-0.1,0.3-0.4,1.3-0.1,1.8c0,0,0,0.1,0.1,0.1
c0.2-0.3,0.4-1.9,0.4-2.5c0-0.1,0-0.1,0.1-0.2s1.3-1.2,2.1-1.4c0.1,0,0.2,0,0.2,0.1c0.1,0.1,0.1,0.2,0,0.3
c-0.4,0.7-0.6,1.5-0.5,1.6c0.5-0.1,0.8-1.3,0.8-2.1c0-0.1,0.1-0.2,0.1-0.2c0.1,0,1.8-0.8,3-0.8c0.3,0,0.5,0,0.6,0.1
c0,0,0.1,0,0.1,0.1l0,0v0.1c0.1,1.2-1.3,3.6-1.4,3.7s-0.2,0.1-0.3,0.1c0,0-0.4-0.1-0.9-0.1c-0.4,0-1,0.1-1.1,0.4
c0,0.1,0,0.1,0,0.1l0,0c0,0,0.1,0.1,0.3,0.1c0.5,0,1.2-0.2,1.2-0.2c0.1,0,0.2,0,0.2,0.1c0.1,0.1,0.1,0.2,0.1,0.3
c-0.3,0.8-1.6,1.9-1.7,1.9c-0.1,0.1-0.2,0.1-0.3,0c-0.2-0.1-0.7-0.2-1.1-0.2c-0.7,0-1,0.2-1,0.2c0.2,0.3,0.6,0.3,0.9,0.3
s0.6-0.1,0.6-0.1c0.1,0,0.2,0,0.3,0.1c0,0.1,0,0.2-0.1,0.3l-2,1.4C106,83,105.8,83.2,105.4,83.2z M103.5,79.3c0,0-0.4,0.3-0.2,1.5
c0.2,0.7,0.4,0.9,0.4,0.9c0.1,0,0.1,0.1,0.1,0.1s0.1,0.4,0.7,0.6c0.3,0.1,0.6,0.2,0.9,0.2s0.4-0.1,0.4-0.1l1.3-1
c-0.5,0-0.9-0.2-1.1-0.5c-0.2-0.2-0.1-0.4,0-0.5c0.2-0.5,1.2-0.5,1.5-0.5c0.5,0,0.9,0.1,1.2,0.2c0.3-0.3,0.8-0.7,1.1-1.1
c-0.2,0-0.5,0.1-0.7,0.1c-0.3,0-0.6-0.1-0.7-0.3c-0.1-0.1-0.1-0.3,0-0.5c0.1-0.3,0.5-0.8,1.5-0.8c0.3,0,0.6,0,0.8,0.1
c0.4-0.7,1.2-2.3,1.3-3.2c-0.1,0-0.2,0-0.3,0c-0.9,0-2.2,0.5-2.7,0.7c0,0.6-0.2,2.2-1.1,2.4h-0.1l0,0c-0.2,0-0.3-0.1-0.4-0.2
c-0.2-0.3,0-1,0.2-1.5c-0.5,0.3-1,0.7-1.2,1c0,0.5-0.1,2.2-0.5,2.7c-0.1,0.2-0.3,0.2-0.4,0.2c-0.2,0-0.3-0.1-0.4-0.3
c-0.3-0.3-0.3-0.8-0.2-1.3L103.5,79.3L103.5,79.3L103.5,79.3z" />
</g>
<g>
<path class="st0" d="M103.6,82.2c-0.1,0-0.1,0-0.2-0.1s-0.1-0.3,0-0.3l8.5-7.5c0.1-0.1,0.3-0.1,0.3,0c0.1,0.1,0.1,0.3,0,0.3
l-8.5,7.5C103.7,82.2,103.6,82.2,103.6,82.2z" />
</g>
<g>
<path class="st0" d="M92.6,76.6L92.6,76.6c-3.2-1.6-11.3-3.8-11.4-3.8S81,72.6,81,72.5c0-0.1,0.2-0.2,0.3-0.2
c0.3,0.1,8.2,2.2,11.4,3.8c0.1,0.1,0.2,0.2,0.1,0.3C92.8,76.5,92.7,76.6,92.6,76.6z" />
</g>
<g>
<path class="st0" d="M104.1,104H93.7c-0.1,0-0.2-0.1-0.2-0.2L92,90.7c0-0.1,0-0.1,0.1-0.2c0-0.1,0.1-0.1,0.2-0.1H106
c0.1,0,0.1,0,0.2,0.1c0,0.1,0.1,0.1,0.1,0.2l-1.8,13.1C104.3,103.9,104.2,104,104.1,104z M93.9,103.5h10l1.7-12.7H92.5L93.9,103.5
z" />
</g>
<g>
<path class="st0" d="M94.6,75.3c-1,0-1.3-0.3-1.4-0.5l-1.8-2c-0.1-0.1-0.1-0.2,0-0.3s0.2-0.1,0.3-0.1c0,0,0.7,0.3,1.3,0.3
c0.3,0,0.5-0.1,0.7-0.2c0.1,0,0.1-0.1,0.1-0.1c-0.1-0.2-1.1-0.6-2.1-0.6c-0.2,0-0.4,0-0.5,0s-0.2,0-0.2-0.1
c-0.1-0.2-1.2-1.5-1.2-2.4c0-0.1,0-0.2,0.1-0.2s0.2,0,0.2,0c0.3,0.2,1.1,0.6,1.6,0.6c0.2,0,0.2-0.1,0.2-0.2c0-0.6-1.5-0.8-2.2-0.8
c-0.1,0-0.2-0.1-0.2-0.2s-0.7-3-0.1-4.3c0,0,0-0.1,0.1-0.1h0.1h0.1c1.4-0.2,3.9,1.5,4,1.6s0.1,0.2,0.1,0.3c-0.2,0.7-0.6,2.1,0,2.4
c0.1,0,0.1,0,0.2,0c0.2-0.3,0.2-1.2,0.1-1.8c0-0.1,0-0.2,0.1-0.2c0.1-0.1,0.2-0.1,0.2,0c0.9,0.3,1.8,1.9,1.9,2c0,0.1,0,0.2,0,0.3
c-0.2,0.6-0.7,2.4-0.5,2.7c0,0,0.1,0,0.2-0.1c0.6-0.4,0.6-1.5,0.6-1.9c0-0.1,0.1-0.2,0.2-0.2s0.2,0,0.3,0.1l0.5,1
c0,0.1,0,0.1,0,0.2c0,0-0.1,0.2-0.2,0.6c0,0.2-0.1,0.4-0.1,0.5s-0.1,0.2-0.1,0.3C97,72,97,72.3,97,72.5c0,0.1,0.1,0.3,0.2,0.5
c0.2,0.3,0.3,0.5,0.3,0.6c0.1,0.1,0.1,0.2,0,0.4c-0.4,0.5-0.7,0.6-0.8,0.7c-0.1,0.1-0.6,0.5-1.4,0.6
C95.1,75.3,94.8,75.3,94.6,75.3z M93.6,74.6c0,0,0.2,0.2,0.9,0.2c0.2,0,0.4,0,0.7-0.1c0.8-0.1,1.1-0.5,1.2-0.5l0.1-0.1l0,0
c0,0,0.2-0.1,0.5-0.4c-0.1-0.1-0.2-0.3-0.3-0.6c-0.1-0.2-0.2-0.5-0.2-0.6c0-0.3,0-0.6,0.1-1c0-0.1,0.1-0.2,0.1-0.4
c0-0.1,0.1-0.3,0.1-0.5c0.1-0.3,0.1-0.5,0.2-0.6h-0.1c-0.1,0.5-0.3,1.1-0.8,1.5c-0.4,0.3-0.7,0.2-0.9-0.1c-0.3-0.6,0.3-2.5,0.5-3
C95.5,68,95,67.3,94.5,67c0,0.5,0,1.3-0.3,1.7c-0.2,0.2-0.4,0.3-0.7,0.2c-1-0.4-0.5-2.2-0.4-2.8c-0.5-0.3-2.3-1.5-3.4-1.4
c-0.4,0.9-0.1,2.8,0.1,3.7c0.6,0,2.5,0.2,2.5,1.3c0,0.4-0.3,0.7-0.7,0.7l0,0c-0.4,0-1-0.2-1.4-0.4c0.2,0.6,0.6,1.2,0.9,1.6
c0.1,0,0.3,0,0.5,0c0.9,0,2.4,0.4,2.6,0.9c0,0.1,0.1,0.4-0.2,0.6c-0.3,0.2-0.6,0.3-1,0.3c-0.2,0-0.4,0-0.6-0.1L93.6,74.6
C93.6,74.5,93.6,74.5,93.6,74.6L93.6,74.6z" />
</g>
<g>
<path class="st0" d="M96.6,74.6c-0.1,0-0.2,0-0.2-0.1c-1.4-2.8-6.8-9.9-6.9-10s-0.1-0.3,0-0.3c0.1-0.1,0.3-0.1,0.3,0
c0.2,0.3,5.5,7.3,6.9,10.1C96.8,74.4,96.7,74.6,96.6,74.6C96.7,74.6,96.6,74.6,96.6,74.6z" />
</g>
<g>
<path class="st0" d="M104.7,76.8c-0.3,0-0.8-0.1-1.5-1.1c-0.1-0.1-0.1-0.2,0-0.3c0,0,0.1-0.2,0.2-0.5l0.3-0.7c0,0,0.3-0.7,0.5-1.2
c-0.1,0-0.1,0.1-0.2,0.1s-0.4,0.1-0.5,0.2c-0.1,0-0.2,0-0.3-0.1c-0.1-0.1-0.1-0.2,0-0.3c0.7-1.3,1.3-1.5,1.4-1.5l2.6-0.7
c0.1,0,0.2,0,0.3,0.1c0.1,0.1,0,0.2-0.1,0.3c-0.3,0.2-1.2,1-1.2,1.6c0,0.1,0,0.1,0,0.1c0.4-0.1,1.5-1.5,1.9-2.1
c0-0.1,0.1-0.1,0.2-0.1s1.8,0.2,2.6,0.5c0.1,0,0.2,0.1,0.2,0.2s-0.1,0.2-0.2,0.2c-0.6,0.2-1.2,0.5-1.3,0.7l0,0c0.1,0,0.1,0,0.2,0
c0.6,0,1.4-0.7,1.7-1c0.1-0.1,0.1-0.1,0.2-0.1c0.3,0.1,2.9,0.8,3.6,1.7v0.1V73v0.1c-0.5,0.9-2.2,1.5-3.2,1.7H112l0,0
c-0.1,0-0.2,0-0.3-0.1c-0.1-0.1-0.1-0.2-0.1-0.3c-0.1,0-0.2,0-0.3,0h-0.2c-0.2,0-0.3,0-0.3-0.1c-0.6-0.4-1-0.5-1.3-0.3
c-0.1,0.1-0.1,0.1-0.1,0.1s0,0,0.1,0s0.2,0.1,0.2,0.2c0,0.2-0.1,0.2-0.5,0.3c-0.2,0.1-0.6,0.2-0.6,0.2s0,0.3,0,0.6c0,0,0,0,0,0.1
s-0.1,0.2-0.2,0.2l0,0c-0.1,0-0.2,0-0.2-0.1c0,0-0.2-0.2-0.3-0.2c-0.1-0.1-0.1-0.1-0.2-0.1s-0.1-0.1-0.2-0.1s-0.1-0.1-0.2-0.2
c-0.3-0.2-0.6-0.4-0.9-0.4c-0.2,0-0.2,0.1-0.2,0.1c0,0.3,0.3,0.6,0.6,0.7c0.1,0,0.1,0.1,0.1,0.2s0,0.1-0.1,0.2
c0,0-0.2,0.2-0.3,0.3c-0.1,0.1-0.3,0.2-0.3,0.2h-0.1H106l-1.2,0.1C104.8,76.8,104.8,76.8,104.7,76.8z M103.8,75.6
c0.6,0.8,1,0.7,1,0.7l1.3-0.1c0,0,0.2-0.1,0.3-0.2l0,0c-0.3-0.3-0.5-0.6-0.5-1s0.3-0.6,0.7-0.6c0.4,0,0.8,0.2,1.2,0.5
c0.1,0.1,0.1,0.1,0.2,0.1s0.1,0.1,0.2,0.1s0.1,0.1,0.2,0.1l0,0c0-0.2,0.1-0.4,0.1-0.5c0.1-0.1,0.3-0.2,0.8-0.3c0,0,0,0,0-0.1
c-0.1-0.2,0-0.5,0.3-0.6c0.4-0.4,1.1-0.3,1.8,0.2c0,0,0,0,0.1,0h0.2c0.4,0,0.6,0.1,0.6,0.1c0.1,0,0.2,0.2,0.1,0.3l0,0
c1.3-0.3,2.3-0.8,2.6-1.3c-0.6-0.6-2.3-1.2-3.1-1.4c-0.3,0.3-1.2,1-2,1c-0.1,0-0.3,0-0.4-0.1c-0.3-0.1-0.3-0.3-0.3-0.4
c0-0.3,0.5-0.6,1-0.9c-0.6-0.1-1.3-0.2-1.6-0.3c-0.4,0.5-1.6,2.2-2.2,2.2c-0.1,0-0.4-0.1-0.5-0.6c0-0.5,0.3-0.9,0.6-1.3l-1.6,0.5
c0,0-0.3,0.1-0.7,0.7c0.1-0.1,0.2-0.1,0.3-0.2c0.1-0.1,0.2-0.1,0.3-0.1c0.1,0,0.2,0,0.2,0.1s0.1,0.2,0,0.2
c-0.1,0.5-0.6,1.7-0.6,1.8l-0.3,0.7C103.9,75.3,103.8,75.5,103.8,75.6z" />
</g>
<g>
<path class="st0" d="M104.1,74.3c-0.1,0-0.2-0.1-0.2-0.2s0.1-0.3,0.2-0.3s5.3-1.1,11.2-0.9c0.1,0,0.2,0.1,0.2,0.2
s-0.1,0.2-0.2,0.2C109.4,73.3,104.2,74.3,104.1,74.3L104.1,74.3z" />
</g>
</g>
<g id="box">
<path class="st0" d="M17.8,88.7H3c-0.3,0-0.5,0.2-0.5,0.5v2.1c0,0.3,0.2,0.5,0.5,0.5h0.7v10.5h13.4V91.9h0.7c0.3,0,0.5-0.2,0.5-0.5
v-2.1C18.3,89,18.1,88.7,17.8,88.7z M4,100.4c0.9,0.1,1.6,0.8,1.7,1.7H4V100.4z M15,102.1c0.1-0.9,0.8-1.6,1.7-1.7v1.7H15z
M16.7,100c-1.1,0.1-2,1-2.1,2.1H6.1c-0.1-1.1-1-2-2.1-2.1v-8.1h12.7V100z M18,91.4c0,0.1-0.1,0.2-0.2,0.2H3
c-0.1,0-0.2-0.1-0.2-0.2v-2.1c0-0.1,0.1-0.2,0.2-0.2h14.8c0.1,0,0.2,0.1,0.2,0.2V91.4z" />
<path class="st0" d="M8.7,95.1H12c0.5,0,0.9-0.4,0.9-0.9s-0.4-0.9-0.9-0.9H8.7c-0.5,0-0.9,0.4-0.9,0.9S8.2,95.1,8.7,95.1z
M8.7,93.7H12c0.3,0,0.5,0.2,0.5,0.5s-0.2,0.5-0.5,0.5H8.7c-0.3,0-0.5-0.2-0.5-0.5S8.4,93.7,8.7,93.7z" />
<path class="st0" d="M17.1,89.5h-4.5v0.4h4.5c0.1,0,0.2,0.1,0.2,0.2v0.7h0.3v-0.7C17.6,89.7,17.4,89.5,17.1,89.5z" />
<rect x="11.5" y="89.5" class="st0" width="0.5" height="0.4" />
</g>
<g id="abacus">
<g transform="translate(50 50) scale(0.69 0.69) rotate(0) translate(-50 -50)">
<path class="st0" d="M173.8,57.7c-0.2,0-0.3,0.2-0.3,0.4v14c0,0.2,0.2,0.3,0.3,0.3H196c0.2,0,0.3-0.2,0.3-0.3v-14
c0-0.2-0.2-0.4-0.3-0.4l0,0L173.8,57.7C173.9,57.7,173.8,57.7,173.8,57.7z M174.2,58.4h21.5v13.3h-21.5V58.4z" />
<path class="st0" d="M173.9,62.6v0.2H196v-0.2H173.9z" />
<path class="st0" d="M176.1,58.1v14h0.2v-14H176.1z" />
<path class="st0" d="M179.6,58.1v14h0.2v-14H179.6z" />
<path class="st0" d="M183.1,58.1v14h0.2v-14H183.1z" />
<path class="st0" d="M186.6,58.1v14h0.2v-14H186.6z" />
<path class="st0" d="M190.1,58.1v14h0.2v-14H190.1z" />
<path class="st0" d="M193.6,58.1v14h0.2v-14H193.6z" />
<path class="st0" d="M175.6,69h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,69,175.6,69z" />
<path class="st0" d="M175.6,70.9h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,70.9,175.6,70.9z
" />
<path class="st0" d="M175.6,70h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,70,175.6,70z" />
<path class="st0" d="M175.6,68.1h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,68.1,175.6,68.1z
" />
<path class="st0" d="M175.6,63.4h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,63.4,175.6,63.4z
" />
<path class="st0" d="M179.1,69h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,69,179.1,69z" />
<path class="st0" d="M179.1,70.9h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,70.9,179.1,70.9z
" />
<path class="st0" d="M179.1,70h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,70,179.1,70z" />
<path class="st0" d="M179.1,65.3h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,65.3,179.1,65.3z
" />
<path class="st0" d="M179.1,64.4h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,64.4,179.1,64.4z
" />
<path class="st0" d="M182.6,69h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,69,182.6,69z" />
<path class="st0" d="M182.6,70.9h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,70.9,182.6,70.9z
" />
<path class="st0" d="M182.6,70h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,70,182.6,70z" />
<path class="st0" d="M182.6,68.1h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,68.1,182.6,68.1z
" />
<path class="st0" d="M182.6,67.2h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,67.2,182.6,67.2z
" />
<path class="st0" d="M182.6,63.4h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,63.4,182.6,63.4z
" />
<path class="st0" d="M186.1,69h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,69,186.1,69z" />
<path class="st0" d="M186.1,70.9h1.2c0.2,0,0.3,0.2,0.3,0.3c0,0.2-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3
S185.9,70.9,186.1,70.9z" />
<path class="st0" d="M186.1,70h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,70,186.1,70z" />
<path class="st0" d="M186.1,68.1h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,68.1,186.1,68.1z
" />
<path class="st0" d="M186.1,67.2h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,67.2,186.1,67.2z
" />
<path class="st0" d="M186.1,63.4h1.2c0.2,0,0.3,0.2,0.3,0.3c0,0.2-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3
C185.8,63.6,185.9,63.4,186.1,63.4z" />
<path class="st0" d="M189.6,69h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,69,189.6,69z" />
<path class="st0" d="M189.6,70.9h1.2c0.2,0,0.3,0.2,0.3,0.3c0,0.2-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3
S189.4,70.9,189.6,70.9z" />
<path class="st0" d="M189.6,70h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,70,189.6,70z" />
<path class="st0" d="M189.6,68.1h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,68.1,189.6,68.1z
" />
<path class="st0" d="M189.6,67.2h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,67.2,189.6,67.2z
" />
<path class="st0" d="M189.6,67.2h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,67.2,189.6,67.2z
" />
<path class="st0" d="M193.1,69h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,69,193.1,69z" />
<path class="st0" d="M193.1,70.9h1.2c0.2,0,0.3,0.2,0.3,0.3c0,0.2-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3
S192.9,70.9,193.1,70.9z" />
<path class="st0" d="M193.1,70h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,70,193.1,70z" />
<path class="st0" d="M193.1,68.1h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,68.1,193.1,68.1z
" />
<path class="st0" d="M193.1,67.2h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,67.2,193.1,67.2z
" />
<path class="st0" d="M193.1,67.2h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,67.2,193.1,67.2z
" />
<path class="st0" d="M175.6,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,61.6,175.6,61.6z
" />
<path class="st0" d="M175.6,58.8h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S175.4,58.8,175.6,58.8z
" />
<path class="st0" d="M179.1,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,61.6,179.1,61.6z
" />
<path class="st0" d="M179.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,60.6,179.1,60.6z
" />
<path class="st0" d="M179.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S178.9,60.6,179.1,60.6z
" />
<path class="st0" d="M182.6,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,61.6,182.6,61.6z
" />
<path class="st0" d="M182.6,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,60.6,182.6,60.6z
" />
<path class="st0" d="M182.6,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S182.4,60.6,182.6,60.6z
" />
<path class="st0" d="M186.1,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,61.6,186.1,61.6z
" />
<path class="st0" d="M186.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,60.6,186.1,60.6z
" />
<path class="st0" d="M186.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S185.9,60.6,186.1,60.6z
" />
<path class="st0" d="M189.6,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,61.6,189.6,61.6z
" />
<path class="st0" d="M189.6,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,60.6,189.6,60.6z
" />
<path class="st0" d="M189.6,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S189.4,60.6,189.6,60.6z
" />
<path class="st0" d="M193.1,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,61.6,193.1,61.6z
" />
<path class="st0" d="M193.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,60.6,193.1,60.6z
" />
<path class="st0" d="M193.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,60.6,193.1,60.6z
" />
<path class="st0" d="M193.1,61.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,61.6,193.1,61.6z
" />
<path class="st0" d="M193.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,60.6,193.1,60.6z
" />
<path class="st0" d="M193.1,60.6h1.2c0.2,0,0.3,0.2,0.3,0.3s-0.2,0.3-0.3,0.3h-1.2c-0.2,0-0.3-0.2-0.3-0.3S192.9,60.6,193.1,60.6z
" />
</g>
</g>
<g id="phone">
<path class="st0" d="M218.1,55.2v-2.7c0-0.1-0.1-0.2-0.2-0.2c-0.1,0-0.2,0.1-0.2,0.2v2.7h-0.4v2l0.7,2.2v4l-0.7,1.3v0.7h1.4V55.2
H218.1z" />
<path class="st0" d="M217.9,59.4l-0.7-2.2v-2h-2.9v2l0.7,2.2v4l-0.7,1.3v0.7h2.9v-0.8l0.7-1.3V59.4z M216.1,55.9
C216.1,55.9,216.2,56,216.1,55.9c0.1,0.1,0,0.2,0,0.2C216.1,56.1,216,56.1,216.1,55.9C216,56,216,55.9,216.1,55.9z M216.1,56.3
C216.1,56.3,216.2,56.3,216.1,56.3c0.1,0.1,0,0.2,0,0.2C216.1,56.5,216,56.4,216.1,56.3C216,56.3,216,56.3,216.1,56.3z M216.1,56.7
C216.1,56.7,216.2,56.7,216.1,56.7c0.1,0.1,0,0.2,0,0.2C216.1,56.8,216,56.8,216.1,56.7C216,56.7,216,56.7,216.1,56.7z M215.7,55.9
C215.8,55.9,215.8,56,215.7,55.9c0.1,0.1,0,0.2,0,0.2S215.7,56.1,215.7,55.9C215.6,56,215.7,55.9,215.7,55.9z M215.7,56.3
C215.8,56.3,215.8,56.3,215.7,56.3c0.1,0.1,0,0.2,0,0.2S215.7,56.4,215.7,56.3C215.6,56.3,215.7,56.3,215.7,56.3z M215.7,56.7
C215.8,56.7,215.8,56.7,215.7,56.7c0.1,0.1,0,0.2,0,0.2S215.7,56.8,215.7,56.7C215.6,56.7,215.7,56.7,215.7,56.7z M215.4,55.9
C215.4,55.9,215.5,56,215.4,55.9c0.1,0.1,0,0.2,0,0.2S215.3,56.1,215.4,55.9C215.3,56,215.3,55.9,215.4,55.9z M215.4,56.3
C215.4,56.3,215.5,56.3,215.4,56.3c0.1,0.1,0,0.2,0,0.2S215.3,56.4,215.4,56.3C215.3,56.3,215.3,56.3,215.4,56.3z M215.4,56.7
C215.4,56.7,215.5,56.7,215.4,56.7c0.1,0.1,0,0.2,0,0.2S215.3,56.8,215.4,56.7C215.3,56.7,215.3,56.7,215.4,56.7z M214.8,57.8h2.2
l0.4,1.1h-2.2L214.8,57.8z M215.5,62.2v-0.4h0.5v0.4H215.5z M216,62.8v0.4h-0.5v-0.4H216z M215.5,61.5v-0.4h0.5v0.4H215.5z
M215.5,60.7v-0.4h0.5v0.4H215.5z M215.5,60v-0.4h0.5V60H215.5z M215.9,65.2h-0.4c-0.1,0-0.2-0.1-0.2-0.2s0.1-0.2,0.2-0.2h0.4
c0.1,0,0.2,0.1,0.2,0.2S216,65.2,215.9,65.2z M216.7,63.1h-0.5v-0.4h0.5V63.1z M216.7,62.2h-0.5v-0.4h0.5V62.2z M216.7,61.5h-0.5
v-0.4h0.5V61.5z M216.7,60.7h-0.5v-0.4h0.5V60.7z M216.7,60h-0.5v-0.4h0.5V60z M217.4,63.1h-0.5v-0.4h0.5V63.1z M217.4,62.2h-0.5
v-0.4h0.5V62.2z M217.4,61.5h-0.5v-0.4h0.5V61.5z M217.4,60.7h-0.5v-0.4h0.5V60.7z M217.4,60h-0.5v-0.4h0.5V60z" />
</g>
<g id="tiles">
<path class="st0" d="M122.3,15c0,0.1,0.1,0.1,0.1,0.1h2.8c0.1,0,0.1-0.1,0.1-0.1v-3.9c0-0.1-0.1-0.1-0.1-0.1h-3.9
c-0.1,0-0.1,0.1-0.1,0.1v2.8c0,0.1,0.1,0.1,0.1,0.1c0.1,0,0.1-0.1,0.1-0.1v-2.6h3.6v3.6L122.3,15C122.4,14.9,122.3,14.9,122.3,15z" />
<path class="st0" d="M123.5,11.7v1.1c0,0.1,0.1,0.1,0.1,0.1h1.1c0.1,0,0.1-0.1,0.1-0.1v-1.1c0-0.1-0.1-0.1-0.1-0.1h-1.1
C123.5,11.6,123.5,11.6,123.5,11.7z M123.7,11.8h0.8v0.8h-0.8V11.8z" />
<path class="st0" d="M123.2,12.8v-1.1c0-0.1-0.1-0.1-0.1-0.1H122c-0.1,0-0.1,0.1-0.1,0.1v1.1c0,0.1,0.1,0.1,0.1,0.1h1.1
C123.1,12.9,123.2,12.9,123.2,12.8z M122.9,12.7h-0.8v-0.8h0.8V12.7z" />
<path class="st0" d="M123.5,13.4v1.1c0,0.1,0.1,0.1,0.1,0.1h1.1c0.1,0,0.1-0.1,0.1-0.1v-1.1c0-0.1-0.1-0.1-0.1-0.1h-1.1
C123.5,13.2,123.5,13.3,123.5,13.4z M123.7,13.5h0.8v0.8h-0.8V13.5z" />
<path class="st0" d="M120.4,14.8v1.1c0,0.1,0.1,0.1,0.1,0.1h1.1c0.1,0,0.1-0.1,0.1-0.1v-1.1c0-0.1-0.1-0.1-0.1-0.1h-1.1
C120.5,14.6,120.4,14.7,120.4,14.8z M120.7,14.9h0.8v0.8h-0.8V14.9z" />
<circle class="st0" cx="121.9" cy="14.5" r="0.1" />
<circle class="st0" cx="121.9" cy="13.9" r="0.1" />
<circle class="st0" cx="121.9" cy="13.4" r="0.1" />
<circle class="st0" cx="122.5" cy="13.4" r="0.1" />
<circle class="st0" cx="123" cy="13.4" r="0.1" />
<circle class="st0" cx="123" cy="13.9" r="0.1" />
<circle class="st0" cx="123" cy="14.5" r="0.1" />
<circle class="st0" cx="122.5" cy="14.5" r="0.1" />
</g>
<rect id="flexboxPuzzleBtn" x="2.5" y="88.5" class="st2" width="16" height="14" />
<rect id="mathPuzzleBtn" x="135" y="55" class="st2" width="16" height="10" />
<rect id="puzzlerBtn" x="120.4" y="11" class="st2" width="5.1" height="5" />
<rect id="recursionPuzzleBtn" x="156" y="34.8" class="st2" width="34" height="23.5" />
<rect id="pipePuzzleBtn" x="269" y="75" class="st2" width="30" height="30" />
<g id="open-door" class="st3">
<path class="st0" d="M49.1,53.9c0,1.5,1.2,2.8,2.8,2.8c1.5,0,2.8-1.2,2.8-2.8c0-1.5-1.2-2.8-2.8-2.8C50.3,51.2,49.1,52.4,49.1,53.9
z M51.2,53.9c0-0.4,0.3-0.6,0.6-0.6c0.4,0,0.6,0.3,0.6,0.6s-0.3,0.6-0.6,0.6C51.5,54.6,51.2,54.3,51.2,53.9z" />
<path class="st0" d="M0,101.9v2.1h27.4l29.8-8.4V12.3L34.2,6h34.3v98h27.4v-2.1H74.5V0H21.4v101.9H0z M27.4,101.5V6.3L55,13.9V94
L27.4,101.5z M23.5,101.9V2.1h48.8v99.7h-1.7v-98H26.5l-1.2-0.3v0.3v98C25.3,101.9,23.5,101.9,23.5,101.9z" />
</g>
<g id="fishbooks">
<path class="st0" d="M249.8,42.7c0.1,0,0.2-0.1,0.2-0.2v-0.7c0-0.1-0.1-0.2-0.2-0.2h-4.9c1.8-0.7,2.9-2.5,2.9-4.4
c0-1.3-0.5-2.6-1.5-3.5c-0.1-0.1-0.1-0.1-0.2-0.2l-0.1-0.1h-5.9c-0.1,0-0.1,0-0.1,0.1c-2,1.7-2.3,4.7-0.5,6.7
c0.5,0.6,1.1,1,1.8,1.3h-2.7c-0.8,0-1.4,0.6-1.4,1.4c0,0.4,0.2,0.8,0.4,1h-0.3c-1,0-1.8,0.8-1.8,1.7s0.8,1.8,1.7,1.8v1.3
c0,0.1,0.1,0.2,0.2,0.2c0.1,0,0.1,0,0.1-0.1l0.5-0.6l0.5,0.6c0.1,0.1,0.2,0.1,0.3,0l0.1-0.1v-1.3h9.2c0.1,0,0.2-0.1,0.2-0.2v-0.7
c0-0.1-0.1-0.2-0.2-0.2h-0.4V45h0.4c0.1,0,0.2-0.1,0.2-0.2v-0.6h1.5c0.1,0,0.2-0.1,0.2-0.2v-0.7c0-0.1-0.1-0.2-0.2-0.2h-0.2v-0.6
h0.2V42.7z M240.2,33.8h5.7l0.1,0.1c0.2,0.2,0.4,0.4,0.6,0.6c-0.2,0-0.5,0.1-0.7,0.2c-0.6,0.2-1.2,0.2-1.8,0
c-0.3-0.1-0.7-0.2-1-0.2c-0.4,0-0.7,0.1-1,0.2c-0.3,0.1-0.6,0.2-0.9,0.2c-0.3,0-0.6-0.1-0.9-0.2c-0.2-0.1-0.5-0.2-0.7-0.2
C239.7,34.3,239.9,34.1,240.2,33.8z M238.7,37.2c0-0.8,0.2-1.6,0.6-2.2c0.3,0,0.6,0.1,0.8,0.2c0.3,0.1,0.7,0.2,1,0.2
c0.4,0,0.7-0.1,1-0.2c0.3-0.1,0.6-0.2,0.9-0.2c0.3,0,0.6,0.1,0.9,0.2c0.3,0.1,0.7,0.2,1,0.2c0.4,0,0.7-0.1,1-0.2
c0.3-0.1,0.5-0.2,0.8-0.2c1.2,2.1,0.5,4.8-1.6,6s-4.8,0.5-6-1.6C238.9,38.7,238.7,37.9,238.7,37.2z M248,47.1h-9v-0.4h9V47.1z
M247.4,46.4h-8.5V46c0-0.1-0.1-0.2-0.2-0.2h-1.3c-0.1,0-0.2,0.1-0.2,0.2v0.4c-0.4,0-0.6-0.3-0.6-0.7s0.3-0.6,0.7-0.6l0,0h10.1
V46.4z M248,44.7h-10.7c-0.6,0-1,0.4-1,1s0.4,1,1,1v0.4c-0.8,0-1.4-0.6-1.4-1.4s0.6-1.4,1.4-1.4H248V44.7z M249.6,44h-11.1
c-0.6,0-1-0.5-1-1c0-0.6,0.5-1,1-1h11.1v0.4h-10.9c-0.4,0-0.6,0.3-0.6,0.6c0,0.4,0.3,0.6,0.6,0.6h10.9V44z M249.3,43.2h-10.5
c-0.2,0-0.3-0.1-0.3-0.3s0.1-0.3,0.3-0.3h10.5V43.2z" />
<path class="st0" d="M245.8,37.5l0.8,0.7c0.1,0.1,0.2,0.1,0.3,0l0.1-0.1v-1.7c0-0.1-0.1-0.2-0.2-0.2c0,0-0.1,0-0.1,0.1l-0.8,0.7
c-0.3-0.4-1.1-1.1-2.1-1.1c-1.2,0-2,1.3-2,1.3c0,0.1,0,0.1,0,0.2c0,0.1,0.8,1.3,2,1.3C244.7,38.6,245.5,37.8,245.8,37.5z
M246.5,36.8v0.8l-0.4-0.4L246.5,36.8z M242.1,37.2c0.2-0.3,0.8-1,1.6-1s1.6,0.7,1.8,1c-0.3,0.3-1,1-1.8,1
C242.9,38.2,242.3,37.5,242.1,37.2L242.1,37.2z" />
<circle class="st0" cx="242.8" cy="37" r="0.2" />
<path class="st0" d="M242.1,35.4c0-0.5-0.4-1-1-1c-0.5,0-1,0.4-1,1c0,0.5,0.4,1,1,1C241.6,36.4,242.1,35.9,242.1,35.4z M241.1,36
c-0.3,0-0.6-0.3-0.6-0.6s0.3-0.6,0.6-0.6s0.6,0.3,0.6,0.6S241.4,36,241.1,36z" />
<path class="st0" d="M240.2,36.6c-0.3,0-0.6,0.3-0.6,0.6s0.3,0.6,0.6,0.6s0.6-0.3,0.6-0.6C240.9,36.9,240.6,36.6,240.2,36.6
L240.2,36.6z M240.2,37.4c-0.1,0-0.2-0.1-0.2-0.2s0.1-0.2,0.2-0.2c0.1,0,0.2,0.1,0.2,0.2l0,0C240.5,37.3,240.4,37.4,240.2,37.4z" />
</g>
</svg>
/***** Global Styles ******/
/*****
Objects in the Room
#door
#screenglitch
#computer
#desk
#servers
#poster
#radiator
#mirror
#plant
#noteWrap
#box
#abacus
#phone
#tiles
#open-door
******/
/* Start global colors */
:root {
--white: #e6e6e6; /* white alt */
--darkest-blue-color: #071e26; /* black alt */
--greyish-blue-color: #06394c;
--bright-blue-color: #0c4383; /*Recursion*/
--turquoise-blue-color: #22a0b6; /* Tiles */
--palest-blue-color: #6a96b9; /* Mirror */
--dark-magenta-color: #7b1346; /* Pipe */
--magenta-color: #cb0c59; /* Math */
--pink-color: #eb649f; /* Box */
}
/* End global color variables */
* {
box-sizing: border-box;
}
html {
height: 100%;
}
body {
display: grid;
align-items: center;
justify-items: center;
background-color: #051217;
background-image: radial-gradient(circle, #071e26, #051217);
font-family: "Cutive Mono", monospace;
}
svg {
width: 100%;
height: 100vh;
margin: 0 auto;
}
/* Room scene */
.st0 {
fill: var(--white);
transition: 0.4s ease-in-out;
}
#solidfill {
fill: var(--white);
}
#poster {
transition: 0.4s ease-in-out;
opacity: 1;
}
#flexboxPuzzleBtn:hover,
#mathPuzzleBtn:hover,
#puzzlerBtn:hover,
#recursionPuzzleBtn:hover,
#pipePuzzleBtn:hover,
#mirrorPuzzleBtn:hover,
#noteBtn:hover {
cursor: pointer;
}
/* End room scene */
/* The Modal (background) */
.modal {
display: none; /* Hidden by default */
position: fixed; /* Stay in place */
z-index: 1; /* Sit on top */
left: 0;
top: 0;
width: 100%; /* Full width */
height: 100%; /* Full height */
overflow: auto; /* Enable scroll if needed */
background-color: rgb(0, 0, 0); /* Fallback color */
background-color: rgba(0, 0, 0, 0.4); /* Black w/ opacity */
}
// Less opaque versions of their color
#mirrorPuzzleModal .modal-content {
background-color: #6a96b9d9;
box-shadow: 0px 0px 30px 10px #6a96b9d9;
}
#recursionPuzzleModal .modal-content {
background-color: #0c4383f2;
box-shadow: 0px 0px 30px 10px #0c4383f2;
}
#puzzlerModal .modal-content {
background-color: #22a0b6f2;
box-shadow: 0px 0px 30px 10px #22a0b6f2;
width: 90%;
}
#flexboxPuzzleModal .modal-content {
background-color: #eb649fe6;
box-shadow: 0px 0px 30px 10px #eb649fe6;
}
#mathPuzzleModal .modal-content {
background-color: #cb0c59e6;
box-shadow: 0px 0px 30px 10px #cb0c59e6;
}
#pipePuzzleModal .modal-content {
background-color: #7b1346d9;
box-shadow: 0px 0px 30px 10px #7b1346d9;
}
/* Modal Content */
.modal-content {
background-color: #fefefe;
margin: auto;
padding: 20px;
width: 80%;
}
/* The Close Button */
.close {
color: var(--white);
float: right;
font-size: 28px;
font-weight: bold;
z-index: 100;
position: relative;
}
.close:hover,
.close:focus {
color: var(--darkest-blue-color);
text-decoration: none;
cursor: pointer;
}
/****** End Global Styles ******/
/* Cheryl Velez - Puzzler */
#puzzler-container {
margin: 0;
display: flex;
flex-direction: column;
}
#puzzler-container button {
font-size: 19px;
padding: 10px;
color: var(--white);
background: #253543;
margin-bottom: 8px;
border: 5px solid #22a0b6f2;
outline: 2px dashed var(--greyish-blue-color);
transition: 0.3s ease-in-out;
}
#alert {
position: relative;
color: var(--dark-magenta-color);
font-size: 32px;
text-align: center;
}
.quote {
position: relative;
color: var(--white);
font-size: 25px;
margin-top: 10px;
text-align: center;
cursor: auto;
width: 72%;
margin: 0 auto;
text-align: center;
}
.quote:last-of-type {
text-align: justify;
font-size: 18px;
margin-bottom: 35px;
}
#puzzler-container button:hover {
transform: scale(1.3);
}
.content {
display: flex;
flex-direction: column;
justify-content: space-evenly;
flex: 0 0 30%;
}
#btn-container {
text-align: center;
}
.topContainer {
margin-top: 20px;
justify-content: space-evenly;
display: flex;
}
.bottomContainer {
margin-top: 20px;
justify-content: space-evenly;
display: flex;
}
.outerflex {
display: flex;
flex-direction: column;
justify-content: space-around;
flex: 1;
height: 66vh;
}
#puzzler-container button {
cursor: pointer;
}
.outerBorder {
border: 2px dashed var(--greyish-blue-color);
padding: 5px;
height: fit-content;
width: fit-content;
margin: 10px;
}
.tile {
width: 100px;
height: 100px;
z-index: 1000;
box-sizing: border-box;
cursor: move;
border: 5px solid var(--darkest-blue-color);
}
.tile img {
filter: invert(100%);
}
.blank {
min-width: 116px;
min-height: 116px;
z-index: 100;
box-sizing: border-box;
border: 2px dashed var(--greyish-blue-color);
top: 200px;
padding: 5px;
margin: 10px;
}
.ui-state-highlight {
border-color: var(--dark-magenta-color);
}
@media all and (max-width: 1200px) {
.outerflex {
flex-direction: row;
justify-content: space-around;
height: auto;
}
.topContainer,
.bottomContainer {
flex-direction: column;
}
}
.revealtext {
background-color: var(--white);
transition: 0.3s ease;
}
.revealtext:hover {
cursor: pointer;
}
/* End Cheryl Velez - Puzzler */
/* Dominic Duffin - Math Puzzle */
:root {
--text-color: #111111;
}
#math-puzzle-container div {
color: var(--white);
}
#math-puzzle-container button {
line-height: 100px;
width: 100px;
border-radius: 40%;
border: 4px solid var(--white);
font-size: 2em;
font-weight: bold;
color: var(--white);
margin: 2px 0 0 2px;
}
#math-puzzle-main {
display: grid;
grid-template-rows: 1fr;
grid-template-columns: 50% 50%;
}
#math-puzzle-keypad {
grid-column: 1;
width: 50%;
margin-left: 10%;
}
#math-puzzle-sum {
grid-column: 2;
margin-right: 10%;
}
.math-puzzle-numberButton {
background-color: transparent;
}
.math-puzzle-zeroButton {
background-color: transparent;
}
.math-puzzle-signButton {
background-color: transparent;
}
.math-puzzle-position {
text-align: center;
line-height: 65px;
font-size: 2em;
padding: 10px;
font-weight: bold;
border-bottom: 1px solid var(--white);
}
#math-puzzle-message {
line-height: normal;
font-size: 1.5em;
}
/* End Dominic Duffin - Math Puzzle */
/* Paul - Flexbox Puzzle */
#flexbox-puzzle-container {
height: 700px;
margin: 0 auto;
display: flex;
flex-direction: column;
position: relative;
}
.heading {
margin: 8px;
color: var(--white);
}
.heading__rules {
padding: 0;
margin: 0 auto;
text-align: center;
}
.heading__subtitle {
display: block;
margin: 10px auto;
width: 80%;
height: 50px;
text-align: center;
}
.notification {
display: block;
width: 100%;
height: 35px;
font-size: 25px;
margin-bottom: 30px;
text-align: center;
color: var(--white);
transition: all 0.5s ease-in;
}
.flex-menu {
width: 100%;
height: 25%;
padding: 0.5rem;
text-align: center;
display: flex;
flex-direction: row;
justify-content: space-evenly;
align-items: center;
color: var(--white);
}
.flex-menu div {
display: flex;
flex-direction: column;
}
.flex-menu label {
display: inline-block;
padding-bottom: 0.5rem;
}
.flex-menu button {
margin: 10px;
margin-bottom: 50px;
border: 0;
padding: 10px 0;
width: 140px;
font-size: 0.75rem;
white-space: nowrap;
text-decoration: none;
outline: none;
box-shadow: 5px 6px 4px 2px rgba(12, 67, 131, 0.45);
}
.flex-menu__items {
background-color: var(--bright-blue-color);
padding: 4px;
text-decoration: none;
color: #fff;
cursor: pointer;
}
.flexPuzzle-container {
// display: block;
position: absolute;
height: 25%;
max-width: 100%;
left: 10%;
perspective: 1000px;
top: 300px;
}
.cube-1,
.cube-2,
.cube-3,
.cube-4,
.cube-5 {
//position: relative;
width: 75px;
height: 75px;
padding: 25px;
transform-style: preserve-3d;
transform: translateZ(-360px) rotateX(65deg) rotateZ(75deg);
transition: all 2s ease-in-out;
.side {
position: absolute;
width: 75px;
height: 75px;
}
.front {
background-color: var(--bright-blue-color);
transform: rotateY(0deg) translateZ(35px);
transition: all 0.5s ease-in-out;
}
.back {
background-color: var(--bright-blue-color);
transform: rotateX(180deg) translateZ(35px);
transition: all 0.5s ease-in-out;
}
.right {
background-color: var(--bright-blue-color);
transform: rotateY(90deg) translateZ(35px);
transition: all 0.5s ease-in-out;
}
.left {
transform: rotateY(-90deg) translateZ(35px);
transition: all 0.5s ease-in-out;
}
.top {
// background-color: var(--bright-blue-color);
transform: rotateX(90deg) translateZ(35px);
transition: all 0.5s ease-in-out;
}
.bottom {
background-color: var(--bright-blue-color);
transform: rotateX(-90deg) translateZ(35px);
transition: all 0.5s ease-in-out;
}
}
// Media queries smaller screen
@media only screen and (max-width: 1500px) {
#flexboxPuzzleModal .modal-content {
width: 90%;
}
.flexPuzzle-container {
left: 0;
}
}
/* End Paul - Flexbox Puzzle */
/* Kristopher Van Sant - Mirror Puzzle */
#mirror-puzzle-container {
text-align: center;
}
#mirror-clue,
#mirror-puzzle-container > p:first-of-type {
color: var(--white);
font-size: 1.7em;
margin-bottom: 50px;
}
#mirror-puzzle-container #note {
color: var(--darkest-blue-color);
width: 285px;
padding: 2%;
box-sizing: border-box;
display: inline-block;
vertical-align: middle;
background: var(--white);
background-size: contain;
text-align: left;
font-size: 19px;
}
#mirror-puzzle-container #note:hover {
cursor: grab;
}
#mirror-puzzle-container #note:active {
cursor: grabbing;
}
#mirror-puzzle-container #mmirror {
width: 500px;
height: 500px;
padding: 5%;
display: inline-block;
vertical-align: middle;
background: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/108463/mirror.svg)
center center no-repeat;
background-size: contain;
}
#note-text {
margin: 0;
padding: 9%;
border: 2px dashed var(--darkest-blue-color);
}
#mirror-puzzle-container .mirror-text {
-moz-transform: scaleX(-1);
-o-transform: scaleX(-1);
-webkit-transform: scaleX(-1);
transform: scaleX(-1);
}
/* End Kristopher Van Sant - Mirror Puzzle */
/* Ryan Saunders - Pipe Puzzle */
#pipe-puzzle-container {
font-size: 100%;
height: 600px;
padding: 0;
margin: 0;
color: var(--white);
position: relative;
}
#pipePuzzleModal .modal-content {
height: 660px;
}
#pipe-puzzle-container span {
-webkit-transition-duration: 0.5s;
-moz-transition-duration: 0.5s;
-o-transition-duration: 0.5s;
transition-duration: 0.5s;
-webkit-transition-property: -webkit-transform;
-moz-transition-property: -moz-transform;
-o-transition-property: -o-transform;
transition-property: transform;
}
.container {
text-align: center;
margin-top: 50px;
font-size: 0;
width: 50%;
float: right;
}
.box {
width: 95px;
height: 95px;
position: relative;
display: inline-block;
font-size: 16px;
}
.box.fake {
border: none;
height: 25px;
}
#pipe-puzzle-container .left {
float: left;
position: absolute;
left: 0px;
top: 0px;
z-index: 9999;
width: 50%;
height: 100%;
font-size: xx-large;
line-height: 95px;
}
#pipe-puzzle-container .right {
float: left;
position: absolute;
right: 0px;
top: 0px;
z-index: 9999;
width: 50%;
height: 100%;
font-size: xx-large;
line-height: 95px;
}
.testArea {
position: absolute;
top: 20px;
left: 0px;
padding: 30px 15px;
background-color: #6a96b9d9;
text-align: center;
}
.testButton {
border: none;
padding: 10px;
background-color: var(--white);
}
.pipe {
width: 95px;
height: 95px;
filter: grayscale(1);
background: url("");
float: left;
//border: 1px solid #dddddd;
}
.pipe.pipe-straight {
background-position: -383px -192px;
background-size: 2400px;
}
.testArea .pipe.pipe-straight {
transition: all linear 2s;
opacity: 1;
filter: alpha(opacity=100);
}
.testArea .pipe.pipe-straight:hover {
box-shadow: inset 100px 0 0 0 blue;
opacity: 0.5;
filter: alpha(opacity=50);
}
.pipe.pipe-cross {
background-position: -95px -95px;
background-size: 2400px;
}
.testArea .pipe.pipe-cross {
transition: all linear 1s;
opacity: 1;
filter: alpha(opacity=100);
}
.testArea .pipe.pipe-cross:hover {
opacity: 0;
filter: alpha(opacity=0);
}
.pipe.pipe-angle {
background-position: -193px -192px;
background-size: 2400px;
}
.pipe.pipe-junction {
background-position: -193px -384px;
background-size: 2400px;
}
.pipe.pipe-empty {
background-position: 100px 0;
background-size: 2400px;
}
input[type="number"] {
width: 45px;
background-color: var(--white);
}
.startPipe {
position: absolute;
height: 20px;
width: 75%;
background: var(--palest-blue-color);
font-size: 16px;
bottom: 2px;
left: 12px;
}
.endPipe {
position: absolute;
height: 75%;
width: 20px;
background: var(--palest-blue-color);
font-size: 16px;
bottom: 10px;
left: 2px;
writing-mode: vertical-rl;
}
.bottomConsole {
position: absolute;
bottom: 0px;
left: 0px;
height: 50%;
width: 410px;
padding: 10px;
background-color: #6a96b9d9;
color: var(--white);
overflow-x: auto;
scrollbar-width: thin;
}
.bottomConsole hr {
color: var(--white);
}
#pipe-busted {
text-align: center;
display: none;
}
#pipe-busted h2 {
font-weight: ligher;
}
/* End Ryan Saunders - Pipe Puzzle */
/* Antoine Guillien - Recursion Puzzle */
#recursion-puzzle-container #app {
padding: 0.5rem;
font-size: 2rem;
}
#recursion-puzzle-container .fa-ice-cream {
font-size: 2rem;
color: var(--pink-color);
}
#recursion-puzzle-container h1 {
font-weight: normal;
font-size: 1.7rem;
text-align: center;
margin: 1rem 0 3.5rem 0;
color: var(--white);
}
#recursion-puzzle-container .thing {
> .flex {
font-size: 23px;
font-weight: 700;
color: var(--white);
border-bottom: 1px solid var(--pink-color);
padding-bottom: 5px;
display: flex;
div {
padding: 0.5rem;
}
div:nth-child(2) {
color: var(--white);
cursor: pointer;
transition: 0.3s ease-in-out;
}
div:nth-child(2):hover {
transform: scale(1.5);
}
}
> .children {
.thing {
padding: 0.5rem 0 0 2rem;
}
}
}
#recursion-puzzle-container .won {
padding: 1rem;
}
#recursion-puzzle-container h1 .fa-ice-cream {
color: var(--pink-color);
font-size: 7rem;
}
/* End Antoine Guillien - Recursion Puzzle */
.locked {
fill: var(--white);
}
/* padlock unlocked colors */
#padlock0 .unlocked {
fill: var(--turquoise-blue-color);
}
#padlock1 .unlocked {
fill: var(--magenta-color);
}
#padlock2 .unlocked {
fill: var(--pink-color);
}
#padlock4 .unlocked {
fill: var(--palest-blue-color);
}
#padlock3 .unlocked {
fill: var(--dark-magenta-color);
}
#padlock5 .unlocked {
fill: var(--bright-blue-color);
}
.unlocked {
opacity: 0;
}
#escaped {
visibility: hidden;
display: grid;
position: absolute;
z-index: 100;
width: 100%; /* Full width */
height: 100%; /* Full height */
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
color: var(--white);
text-align: center;
margin: 0;
font-family: "Bangers", cursive;
background-color: rgb(0, 0, 0); /* Fallback color */
background-color: rgba(0, 0, 0, 0.4);
overflow: hidden;
}
#escaped h1 {
font-size: 300px;
justify-self: center;
align-self: center;
}
// make font responsive
View Compiled
// Global
// These variables set to true when player solves puzzle:
// Please comment here with ✅ as triggers are added to puzzles:
var puzzlerSolved = false; // ✅
var mathPuzzleSolved = false; // ✅
var flexboxPuzzleSolved = false; // ✅
var mirrorPuzzleSolved = false; // ✅
var pipePuzzleSolved = false; // ✅
var recursionPuzzleSolved = false; // ✅
// Theme color variables - please use in all color functions.
var white = "#e6e6e6";
var darkestBlueColor = "#071e26";
var greyishBlueColor = "#06394c";
var brightBlueColor = "#0c4383";
var turquoiseBlueColor = "#22a0b6";
var palestBlueColor = "#6a96b9";
var darkMagentaColor = "#7b1346";
var magentaColor = "#cb0c59";
var pinkColor = "#eb649f";
// End Global
// Room scene
// Changes fill color of elements <selectors> to <color>
function toColor(selectors, color) {
var item = document.querySelectorAll(selectors);
item.forEach(function(i) {
i.style.fill = color;
});
}
// Changes opacity of element <selector> to <opacity>
function toOpacity(selector, opacity) {
var item = document.querySelector(selector);
item.style.opacity = opacity;
}
function abacusToColor() {
toColor("#abacus .st0", magentaColor);
}
function abacusToWhite() {
toColor("#abacus .st0", white);
}
function boxToColor() {
toColor("#box .st0", pinkColor);
}
function boxToWhite() {
toColor("#box .st0", white);
}
function mirrorToColor() {
toColor("#mirror .st0", palestBlueColor);
}
function mirrorToWhite() {
toColor("#mirror .st0", white);
}
function mirrorToColor() {
toColor("#mirror .st0", palestBlueColor);
}
function mirrorToWhite() {
toColor("#mirror .st0", white);
}
function radiatorToColor() {
toColor("#radiator .st0", darkMagentaColor);
}
function radiatorToWhite() {
toColor("#radiator .st0", white);
}
function computerToColor() {
toColor("#computer #desktop .st0", brightBlueColor);
}
function computerToWhite() {
toColor("#computer .st0", white);
}
function posterToTransparent() {
toOpacity("#poster", "0.2");
}
function posterToOpaque() {
toOpacity("#poster", "1");
}
function tilesToColor() {
toColor("#tiles .st0", turquoiseBlueColor);
}
function tilesToWhite() {
toColor("#tiles .st0", white);
}
document
.getElementById("mathPuzzleBtn")
.addEventListener("mouseover", abacusToColor);
document
.getElementById("mathPuzzleBtn")
.addEventListener("mouseout", abacusToWhite);
document
.getElementById("flexboxPuzzleBtn")
.addEventListener("mouseover", boxToColor);
document
.getElementById("flexboxPuzzleBtn")
.addEventListener("mouseout", boxToWhite);
document
.getElementById("mirrorPuzzleBtn")
.addEventListener("mouseover", mirrorToColor);
document
.getElementById("mirrorPuzzleBtn")
.addEventListener("mouseout", mirrorToWhite);
document
.getElementById("pipePuzzleBtn")
.addEventListener("mouseover", radiatorToColor);
document
.getElementById("pipePuzzleBtn")
.addEventListener("mouseout", radiatorToWhite);
document
.getElementById("recursionPuzzleBtn")
.addEventListener("mouseover", computerToColor);
document
.getElementById("recursionPuzzleBtn")
.addEventListener("mouseout", computerToWhite);
document
.getElementById("puzzlerBtn")
.addEventListener("mouseover", posterToTransparent);
document
.getElementById("puzzlerBtn")
.addEventListener("mouseout", posterToOpaque);
document
.getElementById("puzzlerBtn")
.addEventListener("mouseover", tilesToColor);
document
.getElementById("puzzlerBtn")
.addEventListener("mouseout", tilesToWhite);
// End room scene
// Cheryl Velez - Puzzler
// MODAL
// Get the modal
var puzzlerModal = document.getElementById("puzzlerModal");
// Get the button that opens the modal
var puzzlerBtn = document.getElementById("puzzlerBtn");
// Get the <span> element that closes the modal
var closePuzzler = document.getElementsByClassName("close-puzzler")[0];
// When the user clicks the button, open the modal
puzzlerBtn.onclick = function() {
puzzlerModal.style.display = "grid";
};
// When the user clicks on <span> (x), close the modal and check whether all puzzles solved
closePuzzler.onclick = function() {
puzzlerModal.style.display = "none";
verify();
};
// When the user clicks anywhere outside of the modal, close it
window.onclick = function(event) {
if (event.target == puzzlerModal) {
puzzlerModal.style.display = "none";
}
};
// END MODAL
// Start JS for Puzzler Puzzler
!(function(a) {
function f(a, b) {
if (!(a.originalEvent.touches.length > 1)) {
a.preventDefault();
var c = a.originalEvent.changedTouches[0],
d = document.createEvent("MouseEvents");
d.initMouseEvent(
b,
!0,
!0,
window,
1,
c.screenX,
c.screenY,
c.clientX,
c.clientY,
!1,
!1,
!1,
!1,
0,
null
),
a.target.dispatchEvent(d);
}
}
if (((a.support.touch = "ontouchend" in document), a.support.touch)) {
var e,
b = a.ui.mouse.prototype,
c = b._mouseInit,
d = b._mouseDestroy;
(b._touchStart = function(a) {
var b = this;
!e &&
b._mouseCapture(a.originalEvent.changedTouches[0]) &&
((e = !0),
(b._touchMoved = !1),
f(a, "mouseover"),
f(a, "mousemove"),
f(a, "mousedown"));
}),
(b._touchMove = function(a) {
e && ((this._touchMoved = !0), f(a, "mousemove"));
}),
(b._touchEnd = function(a) {
e &&
(f(a, "mouseup"),
f(a, "mouseout"),
this._touchMoved || f(a, "click"),
(e = !1));
}),
(b._mouseInit = function() {
var b = this;
b.element.bind({
touchstart: a.proxy(b, "_touchStart"),
touchmove: a.proxy(b, "_touchMove"),
touchend: a.proxy(b, "_touchEnd")
}),
c.call(b);
}),
(b._mouseDestroy = function() {
var b = this;
b.element.unbind({
touchstart: a.proxy(b, "_touchStart"),
touchmove: a.proxy(b, "_touchMove"),
touchend: a.proxy(b, "_touchEnd")
}),
d.call(b);
});
}
})(jQuery);
/* *** end jQuery UI Touch Punch *** */
var tileArr = [];
var ansID = ["6", "8", "1", "2", "7", "4", "3", "5"];
var droppedID = [0, 0, 0, 0, 0, 0, 0, 0];
var dragThis = 0;
var dropThis = 0;
$(document).ready(function() {
$(".tile").each(function() {
$(this).draggable({
drag: function(event, ui) {
dragThis = $(this).attr("id");
console.log(droppedID);
}
});
});
$(".blank").each(function() {
$(this).droppable({
drop: function(event, ui) {
$(this).addClass("ui-state-highlight");
dropThis =
$(this)
.attr("id")
.substring(2, 1) - 1;
droppedID[dropThis] = dragThis;
},
out: function(event, ui) {
$(this).removeClass("ui-state-highlight");
droppedID[dropThis] = 0;
}
});
});
$("button").click(function() {
var c = 0;
$(".blank").each(function(obj, value) {
if ($(this).hasClass("ui-state-highlight")) {
//do nothing
} else {
c++;
}
});
if (c > 0) {
$("#alert").html("Please place all tiles!");
} else {
var w = 0;
$.each(ansID, function(obj, value) {
if (value == droppedID[obj]) {
w++;
}
if (w == 8) {
puzzlerSolved = true;
$("#alert").html("You solved it!");
//unlock 1st padlock once puzzle is solved
// checkPadlocks('padlock0',puzzlerSolved);
// document.querySelector('.unlocked').setAttribute('fill', "#22a0b6");
document.querySelector("#padlock0 .locked").style.opacity = "0";
document.querySelector("#padlock0 .unlocked").style.opacity = "1";
//$("#alert").html(`You win! ${puzzlerSolved}`);
//console.log(puzzlerSolved); //done- trigger worked
} else {
$("#alert").html("Sorry please try again!");
puzzlerSolved = false;
}
//unlock 1st padlock once puzzle is solved
// puzzlerSolved= true;
// checkPadlocks('padlock0',puzzlerSolved);
});
}
});
});
// End JS for Puzzler Puzzle
document.querySelector(".revealtext").onclick = function() {
document.querySelector(".revealtext").style.backgroundColor = "transparent";
};
// End Cheryl Velez - Puzzler
// Dominic Duffin - Math Puzzle
// Get the modal
var mathPuzzleModal = document.getElementById("mathPuzzleModal");
// Get the button that opens the modal
var mathPuzzleBtn = document.getElementById("mathPuzzleBtn");
// Get the <span> element that closes the modal
var closeMathPuzzle = document.getElementsByClassName("close-mathpuzzle")[0];
// When the user clicks the button, open the modal
mathPuzzleBtn.onclick = function() {
mathPuzzleModal.style.display = "grid";
};
// When the user clicks on <span> (x), close the modal and check whether all puzzles solved
closeMathPuzzle.onclick = function() {
mathPuzzleModal.style.display = "none";
verify();
};
// When the user clicks anywhere outside of the modal, close it
window.onclick = function(event) {
if (event.target == mathPuzzleModal) {
mathPuzzleModal.style.display = "none";
}
};
// Begin Math Puzzle JavaScript (not modal)
// TODO Replace window.alerts with something else!
var positionA; //A-G store value assigned to positions in sum
var positionB;
var positionC;
var positionD;
var positionE; //F doesn't exist because = is hard wired for F.
var positionG;
var choice; //Stores value of button last pressed by user
var bPlus = true; //Switch to false if user selects minus for B
var dPlus = true; //Switch to false if user selects minus for D
var sumTotal; //Stores correct sum for comparison with final position
//Messages:
function invalidMessage() {
document.getElementById("math-puzzle-message").innerHTML =
"Sorry, your choice is invalid!";
}
function fullMessage() {
document.getElementById("math-puzzle-message").innerHTML =
"Sorry, there are no more positions to fill!";
}
function solvedMessage() {
document.getElementById("math-puzzle-message").innerHTML =
"Yay, you've solved this one!";
}
function wrongMessage() {
document.getElementById("math-puzzle-message").innerHTML =
"Oh no, you got it wrong, better try again!";
}
function resetMathPuzzle() {
positionA = void 0;
positionB = void 0;
positionC = void 0;
positionD = void 0;
positionE = void 0;
positionG = void 0;
document.getElementById("math-puzzle-a").innerHTML = "Number";
document.getElementById("math-puzzle-b").innerHTML = "Sign";
document.getElementById("math-puzzle-c").innerHTML = "Number";
document.getElementById("math-puzzle-d").innerHTML = "Sign";
document.getElementById("math-puzzle-e").innerHTML = "Number";
document.getElementById("math-puzzle-g").innerHTML = "Number";
}
function checkNumber(x) {
//Returns true if x is a number 0 ≥ x ≤ 9
for (var i = 0; i < 10; i++) {
if (x == i) {
var y = true;
i = 10; //To stop loop
} else {
var y = false;
}
}
return y;
}
function checkSign(x) {
//Returns true if x is '+' or '-'
if (x == "+" || x == "-") {
var y = true;
} else {
var y = false;
}
return y;
}
//The assignPosition functions assign the user's choice to the position's var, after checking for validity.
function assignPositionA() {
isChoiceValid = checkNumber(choice);
if (isChoiceValid == true) {
positionA = choice;
document.getElementById("math-puzzle-a").innerHTML = choice;
} else {
invalidMessage();
}
}
function assignPositionB() {
isChoiceValid = checkSign(choice);
if (isChoiceValid == true) {
positionB = choice;
document.getElementById("math-puzzle-b").innerHTML = choice;
if (choice == "-") {
bPlus = false;
//console.log(bPlus);
}
} else {
invalidMessage();
}
}
function assignPositionC() {
isChoiceValid = checkNumber(choice);
if (isChoiceValid == true) {
positionC = choice;
document.getElementById("math-puzzle-c").innerHTML = choice;
} else {
invalidMessage();
}
}
function assignPositionD() {
isChoiceValid = checkSign(choice);
if (isChoiceValid == true) {
positionD = choice;
document.getElementById("math-puzzle-d").innerHTML = choice;
if (choice == "-") {
dPlus = false;
//console.log(dPlus);
}
} else {
invalidMessage();
}
}
function assignPositionE() {
isChoiceValid = checkNumber(choice);
if (isChoiceValid == true) {
positionE = choice;
document.getElementById("math-puzzle-e").innerHTML = choice;
} else {
invalidMessage();
}
}
function assignPositionG() {
//Also calls calculate function
isChoiceValid = checkNumber(choice);
if (isChoiceValid == true) {
positionG = choice;
document.getElementById("math-puzzle-g").innerHTML = choice;
calculateSumTotal();
} else {
invalidMessage();
}
}
function findEmptyPosition() {
//Finds the first unfilled position
if (positionA == undefined) {
assignPositionA();
} else if (positionB == undefined) {
assignPositionB();
} else if (positionC == undefined) {
assignPositionC();
} else if (positionD == undefined) {
assignPositionD();
} else if (positionE == undefined) {
assignPositionE();
} else if (positionG == undefined) {
assignPositionG();
} else {
fullMessage();
}
}
//The clicked functions record button presses by user
function oneClicked() {
choice = 1;
findEmptyPosition();
}
function twoClicked() {
choice = 2;
findEmptyPosition();
}
function threeClicked() {
choice = 3;
findEmptyPosition();
}
function fourClicked() {
choice = 4;
findEmptyPosition();
}
function fiveClicked() {
choice = 5;
findEmptyPosition();
}
function sixClicked() {
choice = 6;
findEmptyPosition();
}
function sevenClicked() {
choice = 7;
findEmptyPosition();
}
function eightClicked() {
choice = 8;
findEmptyPosition();
}
function nineClicked() {
choice = 9;
findEmptyPosition();
}
function zeroClicked() {
choice = 0;
findEmptyPosition();
}
function plusClicked() {
choice = "+";
findEmptyPosition();
}
function minusClicked() {
choice = "-";
findEmptyPosition();
}
function calculateSumTotal() {
//Calculates correct total
if (bPlus == true && dPlus == true) {
sumTotal = positionA + positionC + positionE;
} else if (bPlus == true && dPlus == false) {
sumTotal = positionA + positionC - positionE;
} else if (bPlus == false && dPlus == true) {
sumTotal = positionA - positionC + positionE;
} else if (bPlus == false && dPlus == false) {
sumTotal = positionA - positionC - positionE;
}
endGame();
}
function endGame() {
//Checks whether user is correct
if (sumTotal == positionG) {
solvedMessage();
mathPuzzleSolved = true; // Global var
//unlock 2nd lock
// checkPadlocks('padlock1',mathPuzzleSolved);
// document.querySelector('.unlocked').setAttribute('fill', "#cb0c59");
document.querySelector("#padlock1 .locked").style.opacity = "0";
document.querySelector("#padlock1 .unlocked").style.opacity = "1";
} else {
wrongMessage();
resetMathPuzzle();
}
}
//Tests for checkNumber
//var output = checkNumber(0);
//console.log(output); //true
//output = checkNumber(-1);
//console.log(output); //false
//output = checkNumber(9);
//console.log(output); //true
//output = checkNumber(10);
//console.log(output); //false
//output = checkNumber('+');
//console.log(output); //false
//Tests for checkSign:
//var output = checkSign('+');
//console.log(output); //true
//output = checkSign('-');
//console.log(output); //true
//output = checkSign(8);
//console.log(output); //false
//Tests for assignPosition functions:
//choice = 5;
//assignPositionA();
//assignPositionB(); //invalid
//assignPositionC();
//assignPositionD(); //invalid
//assignPositionE();
//assignPositionG();
//choice = '+';
//assignPositionA(); //invalid
//assignPositionB();
//assignPositionC(); //invalid
//assignPositionD();
//assignPositionE(); //invalid
//assignPositionG(); //invalid
//Tests for calculateSumTotal:
//bPlus = true;
//dPlus = true;
//positionA = 1;
//positionC = 2;
//positionE = 4;
//calculateSumTotal();
//console.log(sumTotal) //7
//bPlus = true;
//dPlus = false;
//positionA = 4;
//positionC = 2;
//positionE = 6;
//calculateSumTotal();
//console.log(sumTotal) //0
//bPlus = false;
//dPlus = true;
//positionA = 1;
//positionC = 2;
//positionE = 4;
//calculateSumTotal();
//console.log(sumTotal) //3
//bPlus = false;
//dPlus = false;
//positionA = 1;
//positionC = 1;
//positionE = 1;
//calculateSumTotal();
//console.log(sumTotal) //-1
//Tests for endGame:
//sumTotal = 9;
//positionG = 9;
//endGame(); //You win!
//sumTotal = 0;
//positionG = 9;
//endGame(); //Oh no, you're wrong!
document
.getElementById("math-puzzle-one")
.addEventListener("click", oneClicked, false);
document
.getElementById("math-puzzle-two")
.addEventListener("click", twoClicked, false);
document
.getElementById("math-puzzle-three")
.addEventListener("click", threeClicked, false);
document
.getElementById("math-puzzle-four")
.addEventListener("click", fourClicked, false);
document
.getElementById("math-puzzle-five")
.addEventListener("click", fiveClicked, false);
document
.getElementById("math-puzzle-six")
.addEventListener("click", sixClicked, false);
document
.getElementById("math-puzzle-seven")
.addEventListener("click", sevenClicked, false);
document
.getElementById("math-puzzle-eight")
.addEventListener("click", eightClicked, false);
document
.getElementById("math-puzzle-nine")
.addEventListener("click", nineClicked, false);
document
.getElementById("math-puzzle-zero")
.addEventListener("click", zeroClicked, false);
document
.getElementById("math-puzzle-plus")
.addEventListener("click", plusClicked, false);
document
.getElementById("math-puzzle-minus")
.addEventListener("click", minusClicked, false);
// End Math Puzzle JavaScript
// End Dominic Duffin - Math Puzzle
// `Paul` - Flexbox Puzzle
// Get the modal
var flexboxPuzzleModal = document.getElementById("flexboxPuzzleModal");
// Get the button that opens the modal
var flexboxPuzzleBtn = document.getElementById("flexboxPuzzleBtn");
// Get the <span> element that closes the modal
var closeFlexboxPuzzle = document.getElementsByClassName(
"close-flexboxpuzzle"
)[0];
// When the user clicks the button, open the modal
flexboxPuzzleBtn.onclick = function() {
flexboxPuzzleModal.style.display = "grid";
};
// When the user clicks on <span> (x), close the modal adn check whether all puzzles solved
closeFlexboxPuzzle.onclick = function() {
flexboxPuzzleModal.style.display = "none";
verify();
};
// When the user clicks anywhere outside of the modal, close it
window.onclick = function(event) {
if (event.target == flexboxPuzzleModal) {
flexboxPuzzleModal.style.display = "none";
}
};
//define all variables used
let i = 0;
let subTitle = document.getElementsByClassName("heading__subtitle");
let displayFlex = document.getElementById("flexDisplay");
let directionOfFlex = document.getElementById("flexDirectn");
let justContent = document.getElementById("flexJustCont");
let flexAlign = document.getElementById("flexAlignItems");
let notification = document.querySelector(".notification");
let cubes = document.getElementsByClassName("cubes");
const containerClass = document.getElementsByClassName("flexPuzzle-container");
const flexDirections = ["row", "row-reverse", "column", "column-reverse"];
const flexJustifyContent = [
"flex-start",
"flex-end",
"center",
"space-between",
"space-around",
"space-evenly"
];
const flexAlignArray = [
"stretch",
"center",
"flex-start",
"flex-end",
"baseline"
];
//buttons event listener
displayFlex.addEventListener("click", function() {
if (containerClass[0].style.display == "block") {
containerClass[0].style.display = "flex";
displayFlex.innerHTML = "flex";
//add space on cubes when flex is on
for (i = 0; i < 5; i++) {
cubes[i].style.padding = "125px";
}
} else {
containerClass[0].style.display = "block";
displayFlex.innerHTML = "Display Flex";
//bring back original padding size on each cube
for (i = 0; i < 5; i++) {
cubes[i].style.padding = "15px";
}
}
checkPuzzle();
});
let itemLength = flexDirections.length;
directionOfFlex.addEventListener("click", function() {
// console.log(this.textContent);
subTitle[0].innerHTML =
"The flex-direction CSS property specifies how flex items are placed in the flex container defining the main axis and the direction (normal or reversed).";
if (i <= itemLength) {
this.textContent = flexDirections[i];
containerClass[0].style.flexDirection = flexDirections[i];
i++;
if (
document.querySelector(".flexPuzzle-container").style.flexDirection ===
"column-reverse"
) {
document.querySelector(".flexPuzzle-container").style.top = "1100px";
document.querySelector("#flexboxPuzzleModal .modal-content").style.height =
"1300px";
}
if (
document.querySelector(".flexPuzzle-container").style.flexDirection ===
"column"
) {
document.querySelector("#flexboxPuzzleModal .modal-content").style.height =
"1300px";
}
}
if (i > itemLength) {
document.querySelector("#flexboxPuzzleModal .modal-content").style.height =
"745px";
document.querySelector(".flexPuzzle-container").style.top = "300px";
this.textContent = "Change Flex Direction";
containerClass[0].style.flexDirection = "row";
i = 0;
}
checkPuzzle();
});
let itemJustifyContLength = flexJustifyContent.length;
justContent.addEventListener("click", function() {
// console.log(subTitle[0].innerHTML);
subTitle[0].innerHTML =
"justify-content property defines how the browser distributes space between and around content items along the main-axis of their container.";
if (i <= itemJustifyContLength) {
this.textContent = flexJustifyContent[i];
containerClass[0].style.justifyContent = flexJustifyContent[i];
i++;
}
if (i > itemJustifyContLength) {
this.textContent = "Change Flex Direction";
containerClass[0].style.justifyContent = "flex-start";
i = 0;
}
checkPuzzle();
});
let itemAlignmentArrayLen = flexAlignArray.length;
let midItem = document.getElementsByClassName("cubes");
flexAlign.addEventListener("click", function() {
// console.log(midItem[2].innerHTML);
subTitle[0].innerHTML =
"This controls the alignment of items on the Cross Axis.";
if (i <= itemAlignmentArrayLen) {
this.textContent = flexAlignArray[i];
containerClass[0].style.alignItems = flexAlignArray[i];
i++;
}
if (i > itemAlignmentArrayLen) {
this.textContent = "Change Flex Direction";
containerClass[0].style.alignItems = "flex-start";
midItem[2].classList.remove("itemHeight");
i = 0;
}
checkPuzzle();
});
function checkPuzzle() {
if (displayFlex.innerHTML === "flex") {
document.querySelectorAll(".front")[0].style.backgroundColor = "#7b1346";
// document.querySelectorAll('.side')[0]].style.backgroundColor = '#7b1346';
document.querySelectorAll(".left")[0].style.backgroundColor = "#7b1346";
document.querySelectorAll(".right")[0].style.backgroundColor = "#7b1346";
document.querySelectorAll(".bottom")[0].style.backgroundColor = "#7b1346";
document.querySelectorAll(".top")[0].style.backgroundColor = "#7b1346";
document.querySelectorAll(".back")[0].style.backgroundColor = "#7b1346";
notification.innerHTML = "Keep going! Try changing flex direction now.";
notification.style.color = "#0c4383";
checkDirection();
} else {
document.querySelectorAll(".front")[0].style.backgroundColor = "#0c4383";
// document.querySelectorAll('.side')[0].style.backgroundColor = '#0c4383';
document.querySelectorAll(".left")[0].style.backgroundColor = "#0c4383";
document.querySelectorAll(".right")[0].style.backgroundColor = "#0c4383";
document.querySelectorAll(".bottom")[0].style.backgroundColor = "#0c4383";
document.querySelectorAll(".top")[0].style.backgroundColor = "#0c4383";
document.querySelectorAll(".back")[0].style.backgroundColor = "#0c4383";
notification.innerHTML = 'Start with turning on "Display Flex"';
notification.style.color = "#E6E6E6";
}
checkAllButtons();
}
function checkDirection() {
if (displayFlex.innerHTML == "flex" && directionOfFlex.innerHTML == "row") {
document.querySelectorAll(".front")[4].style.backgroundColor = "#7b1346";
// document.querySelectorAll('.side')[4].style.backgroundColor = '#7b1346';
document.querySelectorAll(".left")[4].style.backgroundColor = "#7b1346";
document.querySelectorAll(".right")[4].style.backgroundColor = "#7b1346";
document.querySelectorAll(".bottom")[4].style.backgroundColor = "#7b1346";
document.querySelectorAll(".top")[4].style.backgroundColor = "#7b1346";
document.querySelectorAll(".back")[4].style.backgroundColor = "#7b1346";
notification.innerHTML = "Ok now, keep going...";
notification.style.color = "#0c4383";
checkJustifyContent();
} else {
document.querySelectorAll(".front")[4].style.backgroundColor = "#0c4383";
// document.querySelectorAll('.side')[4].style.backgroundColor = '#0c4383';
document.querySelectorAll(".left")[4].style.backgroundColor = "#0c4383";
document.querySelectorAll(".right")[4].style.backgroundColor = "#0c4383";
document.querySelectorAll(".bottom")[4].style.backgroundColor = "#0c4383";
document.querySelectorAll(".top")[4].style.backgroundColor = "#0c4383";
document.querySelectorAll(".back")[4].style.backgroundColor = "#0c4383";
}
}
function checkJustifyContent() {
if (
displayFlex.innerHTML == "flex" &&
directionOfFlex.innerHTML == "row" &&
justContent.innerHTML == "center"
) {
document.querySelectorAll(".front")[1].style.backgroundColor = "#7b1346";
// document.querySelectorAll('.side')[1].style.backgroundColor = '#7b1346';
document.querySelectorAll(".left")[1].style.backgroundColor = "#7b1346";
document.querySelectorAll(".right")[1].style.backgroundColor = "#7b1346";
document.querySelectorAll(".bottom")[1].style.backgroundColor = "#7b1346";
document.querySelectorAll(".top")[1].style.backgroundColor = "#7b1346";
document.querySelectorAll(".back")[1].style.backgroundColor = "#7b1346";
document.querySelectorAll(".front")[3].style.backgroundColor = "#7b1346";
// document.querySelectorAll('.side')[3].style.backgroundColor = '#7b1346';
document.querySelectorAll(".left")[3].style.backgroundColor = "#7b1346";
document.querySelectorAll(".right")[3].style.backgroundColor = "#7b1346";
document.querySelectorAll(".bottom")[3].style.backgroundColor = "#7b1346";
document.querySelectorAll(".top")[3].style.backgroundColor = "#7b1346";
document.querySelectorAll(".back")[3].style.backgroundColor = "#7b1346";
notification.innerHTML = "Hmm, you're getting hotter.";
notification.style.color = "#0d4383";
checkAllButtons();
} else {
document.querySelectorAll(".front")[1].style.backgroundColor = "#0c4383";
// document.querySelectorAll('.side')[1].style.backgroundColor = '#0c4383';
document.querySelectorAll(".left")[1].style.backgroundColor = "#0c4383";
document.querySelectorAll(".right")[1].style.backgroundColor = "#0c4383";
document.querySelectorAll(".bottom")[1].style.backgroundColor = "#0c4383";
document.querySelectorAll(".top")[1].style.backgroundColor = "#0c4383";
document.querySelectorAll(".back")[1].style.backgroundColor = "#0c4383";
document.querySelectorAll(".front")[3].style.backgroundColor = "#0c4383";
// document.querySelectorAll('.side')[3].style.backgroundColor = '#0c4383';
document.querySelectorAll(".left")[3].style.backgroundColor = "#0c4383";
document.querySelectorAll(".right")[3].style.backgroundColor = "#0c4383";
document.querySelectorAll(".bottom")[3].style.backgroundColor = "#0c4383";
document.querySelectorAll(".top")[3].style.backgroundColor = "#0c4383";
document.querySelectorAll(".back")[3].style.backgroundColor = "#0c4383";
notification.innerHTML = "Ok now, keep going...";
}
}
function checkAllButtons() {
if (
displayFlex.innerHTML == "flex" &&
directionOfFlex.innerHTML == "row" &&
justContent.innerHTML == "center" &&
flexAlign.innerHTML == "center"
) {
document.querySelectorAll(".front")[2].style.backgroundColor = "#7b1346";
// document.querySelectorAll('.side')[2].style.backgroundColor = '#7b1346';
document.querySelectorAll(".left")[2].style.backgroundColor = "#7b1346";
document.querySelectorAll(".right")[2].style.backgroundColor = "#7b1346";
document.querySelectorAll(".bottom")[2].style.backgroundColor = "#7b1346";
document.querySelectorAll(".top")[2].style.backgroundColor = "#7b1346";
document.querySelectorAll(".back")[2].style.backgroundColor = "#7b1346";
notification.innerHTML = "Well done! You've solved it!";
notification.style.color = "#0d4383";
flexboxPuzzleSolved = true;
//unlock 2nd padlock once puzzle is solved
// checkPadlocks('padlock2',flexboxPuzzleSolved);
// document.querySelector('.unlocked').setAttribute('fill', "#eb649f");
flexboxPuzzleSolved = true;
document.querySelector("#padlock2 .locked").style.opacity = "0";
document.querySelector("#padlock2 .unlocked").style.opacity = "1";
} else {
document.querySelectorAll(".front")[2].style.backgroundColor = "#0c4383";
// document.querySelectorAll('.side')[2].style.backgroundColor = '#0c4383';
document.querySelectorAll(".left")[2].style.backgroundColor = "#0c4383";
document.querySelectorAll(".right")[2].style.backgroundColor = "#0c4383";
document.querySelectorAll(".bottom")[2].style.backgroundColor = "#0c4383";
document.querySelectorAll(".top")[2].style.backgroundColor = "#0c4383";
document.querySelectorAll(".back")[2].style.backgroundColor = "#0c4383";
notification.innerHTML = "Ok now, keep going...";
flexboxPuzzleSolved = false;
document.querySelector("#padlock2 .locked").style.opacity = "1";
document.querySelector("#padlock2 .unlocked").style.opacity = "0";
}
console.log(flexboxPuzzleSolved);
}
// End Paul - Flexbox Puzzle
// Kristopher Van Sant - Mirror Puzzle
// Get the modal
var mirrorPuzzleModal = document.getElementById("mirrorPuzzleModal");
// Get the button that opens the modal
var mirrorPuzzleBtn = document.getElementById("mirrorPuzzleBtn");
// Get the <span> element that closes the modal
var closeMirrorPuzzle = document.getElementsByClassName(
"close-mirrorpuzzle"
)[0];
// When the user clicks the button, open the modal
mirrorPuzzleBtn.onclick = function() {
mirrorPuzzleModal.style.display = "grid";
};
// When the user clicks on <span> (x), close the modal and check whether all puzzles solved
closeMirrorPuzzle.onclick = function() {
mirrorPuzzleModal.style.display = "none";
verify();
};
// When the user clicks anywhere outside of the modal, close it
window.onclick = function(event) {
if (event.target == mirrorPuzzleModal) {
mirrorPuzzleModal.style.display = "none";
}
};
// // Drag and drop note
// Draggable.create("#noteWrap", {
// bounds:"svg"
// });
// Begin JS for Mirror Puzzle (not modal)
$(function() {
$("#note").draggable();
});
$(function() {
$("#note").draggable();
$("#mmirror").droppable({
drop: function(event, ui) {
$("#note-text").removeClass("mirror-text");
$("#mirror-clue").replaceWith("<p>Ah, there we go. Interesting.</p>");
mirrorPuzzleSolved = true;
//unlock 4th padlock once puzzle is solved
// checkPadlocks('padlock4',mirrorPuzzleSolved);
// document.querySelector('use#ulock4 >
document.querySelector("#padlock4 .locked").style.opacity = "0";
document.querySelector("#padlock4 .unlocked").style.opacity = "1";
}
});
});
// End JS for Mirror Puzzle
// End Kristopher Van Sant - Mirror Puzzle
// Ryan Saunders - Pipe Puzzle
// Pipe Break Timer
var myVar;
function myFunction() {
myVar = setTimeout(function() {
document.querySelector(
"#pipePuzzleModal .modal-content "
).style.backgroundImage =
"url('https://media.giphy.com/media/46LMaiLUFRkoU/giphy.gif')";
document.querySelector(
"#pipePuzzleModal .modal-content "
).style.backgroundSize =
"cover";
document.querySelector("#pipePuzzleModal .modal-content ").style.boxShadow =
"0px 0px 30px 10px #727ab9";
document.querySelector("#pipe-notbusted").style.display = "none";
document.querySelector("#pipe-notbusted").style.display = "none";
document.querySelector("#pipe-busted").style.display = "block";
pipePuzzleSolved = true;
document.querySelector("#padlock3 .locked").style.opacity = "0";
document.querySelector("#padlock3 .unlocked").style.opacity = "1";
}, 75000);
}
function myStopFunction() {
clearTimeout(myVar);
}
// Get the modal
var pipePuzzleModal = document.getElementById("pipePuzzleModal");
// Get the button that opens the modal
var pipePuzzleBtn = document.getElementById("pipePuzzleBtn");
// Get the <span> element that closes the modal
var closePipePuzzle = document.getElementsByClassName("close-pipepuzzle")[0];
// When the user clicks the button, open the modal
pipePuzzleBtn.onclick = function() {
pipePuzzleModal.style.display = "grid";
myFunction();
};
// When the user clicks on <span> (x), close the modal and check whether all puzzles solved
closePipePuzzle.onclick = function() {
pipePuzzleModal.style.display = "none";
verify();
myStopFunction();
};
// When the user clicks anywhere outside of the modal, close it
// window.onclick = function(event) {
// if (event.target == pipePuzzleModal) {
// pipePuzzleModal.style.display = "none";
// myStopFunction2();
// }
// }
// Begin JS for Pipe Puzzle (not Modal)
// Store our Pipes directions within an array
// NOTE: We need to look into extending this on a per row basis
let pipeDef = [];
// Set rows to have letter assigned
var rowAlpha = "A".charCodeAt(0);
var curRow = String.fromCharCode(rowAlpha++);
// Array of classes for our different types of pipe
var pipeType = ["straight", "cross", "angle", "junction", "empty"];
var pipeTypeX = [
["Up", "Down"],
["Up", "Right", "Down", "Left"],
["Right", "Down"],
["Up", "Right", "Down"],
["None"]
];
// Text for pipe current direction
var dirText = ["Up", "Right", "Down", "Left"];
// Set initial line count & pipe count
var lineCount = 0; // current line
var pipeCount = 0; // current pipe number
// Set the initial number of total blocks and columns
var columns = 5; // Total of 4 coluns - 4 * 4 = 16 total blocks
var totalBlocks = 25;
$(document).ready(function() {
// Add the first row with the start point
addStart();
// Call our newPipe function for the total number of blocks
for (var i = 0; i < totalBlocks; i++) newPipe();
// Add the final end block to the screen
addEnd();
// When a pipe is clicked on the left half, turn counter clockwise & save the direction
$(document).on("click touchstart", ".left", function() {
pipeID = $(this)
.next()
.next()
.attr("id")
.substring(5);
pipeDef[pipeID].direction -= 90;
$(this)
.next()
.next()
.css("transform", "rotate(" + pipeDef[pipeID].direction + "deg)");
});
// When a pipe is clicked on the right half, turn clockwise & save the direction
$(document).on("click touchstart", ".right", function() {
pipeID = $(this)
.next()
.attr("id")
.substring(5);
pipeDef[pipeID].direction += 90;
$(this)
.next()
.css("transform", "rotate(" + pipeDef[pipeID].direction + "deg)");
});
});
// Function to add a new pipe to the screen
function newPipe() {
// When the current lineCount reaches the column maximum, force a clear to start a new line
if (lineCount == columns) {
$(".container").append($("<div>", { style: "clear: both" }));
lineCount = 0;
curRow = String.fromCharCode(rowAlpha++);
}
// Add our new 'box' div within the content div
$(".container").append($("<div>", { class: "box" }));
// Add the left overlaid div as a child of 'box'
$(".box")
.last()
.append($("<div>", { class: "left", text: curRow }));
// Add the right overlaid div as a child of 'box'
$(".box")
.last()
.append($("<div>", { class: "right", text: lineCount + 1 }));
// Before any specific pipe code is spat out, call function which will return the details of the pipe as an object. Pass argument of "A1" etc.
// curRow = A | lineCount = 0 + 1 (starts on line 0)
var curPipe = valPipe(curRow + (lineCount + 1));
// Increase the pipeDef array to have the same number of elements as there are pipes.
if (pipeDef.length <= pipeCount) {
pipeDef.push(curPipe);
}
//alert(pipeDef[pipeCount].direction);
//alert(curPipe.id + " " + curPipe.direction + " " + curPipe.type);
// Here we need to put our algorithm to make this work.
// Also need random rotation for each pipe so that they don't always start in the same direction!
// I need to calculate the route for a win from A1 to D4.
// So, A1, A2, B2, B3, C3, D3, D4
// 1 2 3 4
// A [[X][X][ ][ ]]
// B [[ ][X][X][ ]]
// C [[ ][ ][X][ ]]
// D [[ ][ ][X][X]]
// A1 is Bend, Junction or cross
// A2 is Bend, Junction or Cross
// B2 is Bend, Junction or Cross
// B3 is Bend, Junction or Cross
// C3 is Straight, Junction or Cross
// D3 is Bend, Junction or Cross
// D4 is Straight, Junction or Cross
// Then we need to work out orientation of pipes
// If pipeType = 2 for first pipe, we need to make A2 have a pipe
// if A2 = pipeType 2 then B2 must have pipe!
// if B2 = pipeType 2 then B1 or B3 must have pipe!
// add our actual pipe span (Random)
$(".box")
.last()
.append(
$("<span>", {
class: "pipeblock pipe pipe-" + pipeType[curPipe.type],
id: "pipe-" + pipeCount,
style: "transform: rotate(" + curPipe.direction + "deg);"
})
);
// Increment the pipeCount & lineCount counters
pipeCount += 1;
lineCount += 1;
// Output number of rows and columns to test area
document.getElementById("rowCount").value = Math.ceil(pipeCount / columns);
document.getElementById("colCount").value = columns;
}
// Add a new "Start" block/label to the first line.
function addStart() {
// Add our new 'box' div within the content div
$(".container").append($("<div>", { class: "box fake" }));
// Add the end pipe as a child of 'box'
$(".box")
.last()
.append($("<span>", { class: "startPipe", text: "Start" }));
for (var i = 0; i < columns - 1; i++) {
$(".container").append($("<div>", { class: "box fake" }));
}
$(".container").append($("<div>", { style: "clear: both" }));
}
// Add a new "End" block/label to the last pipe added.
function addEnd() {
// Add our new 'box' div within the content div
$(".container").append(
$("<div>", {
class: "box",
style: "width:25px; border: none; position: absolute;"
})
);
// Add the end pipe as a child of 'box'
$(".box")
.last()
.append($("<span>", { class: "endPipe", text: "End" }));
}
// Function to add a new pipe to the screen
function updatePipes() {
clearAll();
columns = document.getElementById("colCount").value;
totalBlocks = document.getElementById("rowCount").value * columns;
//alert("Columns: " + columns + " | Total Blocks: " + totalBlocks + " | Rows: " + (totalBlocks / columns));
addStart();
for (var i = 0; i < totalBlocks; i++) newPipe();
addEnd();
}
function clearAll() {
//$(".container").innerHTML = '';
// Store our Pipes directions within an array
pipeDef = [];
// Set initial line count & pipe count
lineCount = 0;
pipeCount = 0;
document.getElementById("container").innerHTML = "";
// reset row letters
rowAlpha = "A".charCodeAt(0);
curRow = String.fromCharCode(rowAlpha++);
}
function valPipe(cell) {
var x;
var topLeft =
pipeCount - columns - 1 >= 0 &&
(pipeCount - columns - 1) % columns != columns - 1
? pipeCount - columns - 1
: "None";
var top = pipeCount - columns >= 0 ? pipeCount - columns : "None";
var topRight =
pipeCount - columns + 1 >= 0 && (pipeCount - columns + 1) % columns != 0
? pipeCount - columns + 1
: "None";
var left =
pipeCount - 1 >= 0 && (pipeCount - 1) % columns != columns - 1
? pipeCount - 1
: "None";
// If A1 (So if Above = Empty and Left = Empty and lineCount not final pipe) then must contain pipe (not empty)
// If Above = empty & left = straight then pick anything.
// If above = empty & left = bent then pick any other than empty
// Set x to a random value between 0-4 (0-3 for first element and last element)
// First element can be 0-3 but last needs to check various bits!
if (cell == "A1") {
x = Math.floor(Math.random() * 4);
} else {
x =
pipeCount == 0
? Math.floor(Math.random() * 4)
: pipeCount == totalBlocks - 1
? Math.floor(Math.random() * 4)
: Math.floor(Math.random() * 5);
}
$(".bottomConsole").append("<strong>" + cell + ": </strong>");
$(".bottomConsole").append(
"Top Left: " +
(topLeft != "None"
? pipeType[pipeDef[topLeft].type]
: "<strong>None</strong>") +
" | Top: " +
(top != "None" ? pipeType[pipeDef[top].type] : "<strong>None</strong>") +
" | Top Right: " +
(topRight != "None"
? pipeType[pipeDef[topRight].type]
: "<strong>None</strong>") +
" | Left: " +
(left != "None"
? pipeType[pipeDef[left].type]
: "<strong>None</strong>") +
"<br />"
);
$(".bottomConsole").append(
"Top Left Pipe can Join on: " +
(topLeft != "None"
? pipeTypeX[pipeDef[topLeft].type]
.toString()
.split(",")
.join(", ")
: "None") +
"<br />"
);
$(".bottomConsole").append(
"Top Pipe can Join on: " +
(top != "None"
? pipeTypeX[pipeDef[top].type]
.toString()
.split(",")
.join(", ")
: "None") +
"<br />"
);
$(".bottomConsole").append(
"Top Right Pipe can Join on: " +
(topRight != "None"
? pipeTypeX[pipeDef[topRight].type]
.toString()
.split(",")
.join(", ")
: "None") +
"<br />"
);
$(".bottomConsole").append(
"Left Pipe can Join on: " +
(left != "None"
? pipeTypeX[pipeDef[left].type]
.toString()
.split(",")
.join(", ")
: "None") +
"<br />"
);
//if (left != "None") {
// $('.bottomConsole').append(pipeTypeX[pipeDef[left].type].includes('Right'));
//}
// A1 - Still tempted to just check for cell == 'A1' here...
if (left == "None" && top == "None") {
// Setting direction to -90 as the images I'm using are not the same as the actual algorithm being used.
var y = -90;
var dirCount = 0;
var dirCheck = "";
var z = [];
// This for loop swaps our directions to see which orientations are valid (Does the pipe connect?)
for (var r = 0; r < 4; r++) {
dirCheck = "Run " + (r + 1) + ": ";
for (var i = 0; i < pipeTypeX[x].length; i++) {
dirCheck +=
(dirText.indexOf(pipeTypeX[x][i]) + r > dirText.length - 1
? (dirText.indexOf(pipeTypeX[x][i]) + r) % (dirText.length - 1) > 0
? dirText[
(dirText.indexOf(pipeTypeX[x][i]) + r) %
(dirText.length - 1) -
1
]
: dirText[
(dirText.indexOf(pipeTypeX[x][i]) + r) %
(dirText.length - 1) +
2
]
: dirText[dirText.indexOf(pipeTypeX[x][i]) + r]) +
"[" +
(dirText.indexOf(pipeTypeX[x][i]) + r > dirText.length - 1
? (dirText.indexOf(pipeTypeX[x][i]) + r) % (dirText.length - 1) > 0 // if out of bounds, this corrects index
? (dirText.indexOf(pipeTypeX[x][i]) + r) % (dirText.length - 1) -
1
: (dirText.indexOf(pipeTypeX[x][i]) + r) % (dirText.length - 1) +
2
: dirText.indexOf(pipeTypeX[x][i]) + r) + // if within bounds, this simply grabs new index
"] ";
// puts all current directions into string, if our count >= 2 then it's a valid pipe that
// we can use to connect to others. If so, we +1 to our master check. At the end if our total > 0
// the pipe is valid? I need to save f though on a "good" pipe.
//alert("Run " + (f+1) + ": " + dirText.indexOf(pipeTypeX[x][i]) + " - " + pipeTypeX[x][i] + " Becomes: " + (((dirText.indexOf(pipeTypeX[x][i])+f) > (dirText.length -1)) ? (dirText.indexOf(pipeTypeX[x][i])+f)%(dirText.length -1)-1 : (dirText.indexOf(pipeTypeX[x][i])+f)) + " - " + (((dirText.indexOf(pipeTypeX[x][i])+f) > (dirText.length -1)) ? dirText[(dirText.indexOf(pipeTypeX[x][i])+f)%(dirText.length -1)-1] : dirText[(dirText.indexOf(pipeTypeX[x][i])+f)]));
//alert(dirText.indexOf(pipeTypeX[x][i])+f%(dirText.length -1) + " - " + (dirText.length -1));
}
// These need to be dynamic based upon what's around it.
dirCount += dirCheck.includes("Up") ? 1 : -1;
dirCount += dirCheck.includes("Right") ? 1 : 0;
dirCount += dirCheck.includes("Down") ? 1 : 0;
dirCount += dirCheck.includes("Left") ? 0 : 0;
//bleh += (pipeTypeX[x].includes('Up')) ? 1 : -1;
//bleh += (pipeTypeX[x].includes('Right')) ? 1 : 0;
//bleh += (pipeTypeX[x].includes('Down')) ? 1 : 0;
//bleh += (pipeTypeX[x].includes('Left')) ? -1 : 0;
// Add successful direction to Connection State
if (dirCount >= 2) {
z.push(r);
}
dirCount = 0;
}
} else {
// Direction of pipe (When finished will be based on surrounding)
var y = 90 * Math.floor(Math.random() * 4);
// Shoving directions in here for now. Changing to orientation (0-3) later - can have more than 1 value
var z = pipeTypeX[x];
}
$(".bottomConsole").append("<hr />");
return {
id: cell, // A1 (A1-E5)
type: x, // 1 (Used in pipeType Array (0,1,2,3,4))
direction: y, // 90 (Degrees (0,90,180,270))
state: z // 1,2 (Orientations that are valid (0-3))
};
}
function test() {
$(".bottomConsole").empty();
var dirNum;
for (var i = 0; i < pipeDef.length; i++) {
dirNum = pipeDef[i].direction / 360;
dirNum = (dirNum - Math.floor(dirNum)) * 4;
$(".bottomConsole").append(
"Pipe ID: pipe-" +
i +
" | Pipe Position: " +
pipeDef[i].id +
" | Pipe Direction: " +
pipeDef[i].direction +
" ( " +
dirText[dirNum] +
") | Pipe Type: " +
pipeType[pipeDef[i].type] +
" | Connection State: " +
pipeDef[i].state +
"<br />"
);
}
}
// NOTES:
// Make button with slider to select difficulty ?
// Easy - Normal - Hard - Extreme - Expert
// 2x2 - 3x3 - 4x4 - 5x5 - 6x6
// Multi dimensional key-pair/array? each side has an index?
// create algorithm to generate correct "path" to win
// and based on difficulty, spit out "grid" in random
// order (avoiding solved path).
// top left & bottom right always ends. Direction is
// random based on possible solved path outcomes
// End JS for Pipe Puzzle
// End Ryan Saunders - Pipe Puzzle
// Antoine Guillien - Recursion Puzzle
// Get the modal
var recursionPuzzleModal = document.getElementById("recursionPuzzleModal");
// Get the button that opens the modal
var recursionPuzzleBtn = document.getElementById("recursionPuzzleBtn");
// Get the <span> element that closes the modal
var closeRecursionPuzzle = document.getElementsByClassName(
"close-recursionpuzzle"
)[0];
// When the user clicks the button, open the modal
recursionPuzzleBtn.onclick = function() {
recursionPuzzleModal.style.display = "grid";
};
// When the user clicks on <span> (x), close the modal and check whether all puzzles solved
closeRecursionPuzzle.onclick = function() {
recursionPuzzleModal.style.display = "none";
verify();
};
// When the user clicks anywhere outside of the modal, close it
window.onclick = function(event) {
if (event.target == recursionPuzzleModal) {
recursionPuzzleModal.style.display = "none";
verify();
}
if (event.target == puzzlerModal) {
puzzlerModal.style.display = "none";
verify();
}
if (event.target == mathPuzzleModal) {
mathPuzzleModal.style.display = "none";
verify();
}
if (event.target == flexboxPuzzleModal) {
flexboxPuzzleModal.style.display = "none";
verify();
}
if (event.target == mirrorPuzzleModal) {
mirrorPuzzleModal.style.display = "none";
verify();
}
if (event.target == pipePuzzleModal) {
pipePuzzleModal.style.display = "none";
verify();
myStopFunction();
}
};
// Start JS for Recursion Puzzle
const TYPE = {
ROOM: 0,
CORRIDOR: 1,
DOOR_IN: 2,
DOOR_OUT: 3,
OBJECT: 4,
CONTAINER: 5,
CAT: 6,
THOUGHTS: 7,
EXIT: 8
};
const config = {
[TYPE.ROOM]: {
seeds: () => {
const adjectives = ["Tiny", "Big", "Dirty"];
const colors = ["Fluorescent", "Dark", "Luminous", "Resplendant"];
return `${_.sample(adjectives)} ${_.sample(colors)} Room`;
},
relations: [
{ type: TYPE.DOOR_OUT, min: 1, max: 3 },
{ type: TYPE.CONTAINER, min: 1, max: 5 },
{ type: TYPE.CAT, min: 1, max: 1, p: 0.2 }
]
},
[TYPE.CONTAINER]: {
seeds: ["Freezer", "Fridge", "Icebox"],
relations: [
{ type: TYPE.OBJECT, min: 1, max: 2 },
{
type: TYPE.EXIT,
min: 1,
max: 1,
p: data => {
const nb = countParents(data);
if (nb > 2) {
return 0.05 * (nb / 2);
} else {
return 0;
}
}
}
]
},
[TYPE.OBJECT]: {
seeds: [
"Beans",
"Carrots",
"French fries",
"Cucumber",
"Peas",
"Strawberries",
"Blueberries",
"Shrimp",
"Pizza",
"Broccoli",
"Spinach",
"Soup"
],
relations: []
},
[TYPE.CORRIDOR]: {
seeds: ["Corridor", "Aisle", "Passage", "Couloir", "Lobby"],
relations: [{ type: TYPE.DOOR_IN, min: 1, max: 3 }]
},
[TYPE.DOOR_IN]: {
seeds: ["A Door"],
relations: [{ type: TYPE.ROOM, min: 1, max: 1 }]
},
[TYPE.DOOR_OUT]: {
seeds: ["A Door"],
relations: [{ type: TYPE.CORRIDOR, min: 1, max: 1 }]
},
[TYPE.EXIT]: {
seeds: ["wiiiii"],
relations: []
},
[TYPE.CAT]: {
seeds: () => {
const adjectives = ["Majestic", "Big", "Lazy"];
const coats = ["", "Bi-Coloured", "Tabby", "Tortoiseshell", "Calico"];
const colors = [
"Dark",
"White",
"Brown",
"Ginger",
"Grey",
"Cinnamon",
""
];
return `${_.sample(adjectives)} ${_.sample(coats)} ${_.sample(
colors
)} Cat`;
},
relations: [{ type: TYPE.THOUGHTS, min: 1, max: 2 }]
},
[TYPE.THOUGHTS]: {
seeds: [
"Sharp Look",
"Paws",
"Tail",
"Weird Look",
"Thoughts Of Destruction",
"Starvation"
],
relations: []
}
};
let tid = 0;
const generateThing = (type, parent) => {
let name = Array.isArray(config[type].seeds)
? _.sample(config[type].seeds)
: config[type].seeds();
return {
type: type,
name,
id: tid++,
links: [],
parent
};
};
const countParents = data => {
let sum = 0;
let p = data;
while (p.parent) {
p = p.parent;
sum++;
}
return sum;
};
const generateFromParent = parent => {
let links = [];
config[parent.type].relations.forEach(r => {
let p = r.p ? (r.p instanceof Function ? r.p(parent) : r.p) : 1;
if (r.type == TYPE.EXIT) {
console.log(p);
}
if (p === 1 || Math.random() < p) {
links = links.concat(
Array.from({ length: _.random(r.min, r.max) }, () =>
generateThing(r.type, parent)
)
);
}
});
return links;
};
Vue.component("thing", {
props: ["data", "create", "cb"],
data: () => ({
show: false
}),
methods: {
createLinks: function() {
let self = this;
this.data.links = generateFromParent(this.data);
this.cb(this.data);
},
handle: function() {
if (!this.data.links.length) {
this.createLinks();
}
this.show = !this.show;
}
},
template: `
<div class="thing">
<div class="flex">
<div>
<span v-if="data.type == TYPE.EXIT"><i class="fa fa-ice-cream"></i></span>
<span v-else>{{data.name}}</span>
</div>
<div @click="handle" v-if="[TYPE.OBJECT, TYPE.EXIT, TYPE.THOUGHTS].indexOf(data.type) === -1">
<i v-if="show" class="fas fa-arrow-left"></i>
<i v-else class="fas fa-arrow-right"></i>
</div>
</div>
<div class="children" v-if="show">
<div v-for="c in data.links">
<thing :data="c" :key="c.id" :cb="cb"></thing>
</div>
</div>
</div>
`
});
const app = new Vue({
el: "#app",
data: {
root: null,
won: false,
details: {
clicks: 0,
level: 0,
opened: 0
}
},
beforeMount: function() {
this.root = generateFromParent({ type: TYPE.DOOR_IN, links: [] }).pop();
},
methods: {
cb: function(data) {
if (data.type === TYPE.CONTAINER) {
this.details.opened++;
}
if (data.links.some(l => l.type === TYPE.EXIT)) {
this.details.level = countParents(data);
this.won = true;
recursionPuzzleSolved = true;
//unlock 6th padlock once puzzle is solved
// checkPadlocks('padlock5',recursionPuzzleSolved);
// document.querySelector(' .unlocked').setAttribute('fill', "#7b1346");
document.querySelector("#padlock5 .locked").style.opacity = "0";
document.querySelector("#padlock5 .unlocked").style.opacity = "1";
}
this.details.clicks++;
}
}
});
// End Antoine Guillien - Recursion Puzzle
// Padlock Functionality and Verification
// let padlocks = document.querySelectorAll('[id^=padlock]'),
// pathsToAnimate = document.querySelectorAll('[id^=ulock]');
// function checkPadlocks(whichLock,bol=false) {
// //iterate through each path id of svg padlock
// for(let i=0; i < 6; i++) {
// //console.log(i + ' ' + padlocks[i].getAttribute('id'));
// //console.log(whichLock === padlocks[i].getAttribute('id'));
// if(whichLock === padlocks[i].getAttribute('id') && bol) {
// // pathsToAnimate[i].setAttribute('href','#unlocked');
// // console.log(pathsToAnimate[i]);
// // document.querySelector(`${whichLock}.locked`).style.opacity="0";
// // document.querySelector(`${whichLock}.unlocked`).style.opacity="1";
// var paths = document.getElementsByTagName("path");
// whichLock.paths[0].style.opacity = "0";
// whichLock.paths[1].style.opacity = "1";
// }
// }
// }
// Start JS for verification
var haveEscaped;
function escapeNow() {
haveEscaped = setTimeout(function() {
// replace door with opened version
document.getElementById("door").style.opacity = "0";
document.getElementById("open-door").style.opacity = "1";
// window.alert("You may now escape!");
document.getElementById("escaped").style.visibility = "visible";
}, 750);
}
// Checks whether player has solved all puzzles, if yes, escape!
function verify() {
// testing
// var puzzlerSolved = true; // ✅
// var mathPuzzleSolved = true; // ✅
// var flexboxPuzzleSolved = true; // ✅
// var mirrorPuzzleSolved = true; // ✅
// var pipePuzzleSolved = true; // ✅
// var recursionPuzzleSolved = true; // ✅
if (
puzzlerSolved == true &&
mathPuzzleSolved == true &&
flexboxPuzzleSolved == true &&
mirrorPuzzleSolved == true &&
pipePuzzleSolved == true &&
recursionPuzzleSolved == true
) {
//ESCAPE
escapeNow();
}
}
verify();
// End JS for verification