본문 바로가기
EFFECT

검색 이펙트 - 2분 동안 CSS속성 입력하기

by 코빈_ 2022. 10. 23.

검색 이펙트 : 2분 동안 CSS속성 입력하기

이번에는 2분 동안 CSS속성을 입력하는 게임을 만들어봤습니다.

HTML

이번 HTML 구조는 스크립트를 적용해 줄 각 클래스 이름을 정해주고 또 게임 느낌나게 애니메이션을 추가해줬습니다.

HTML CODE
<main id="main">
    <div class="search__wrap">
        <div class="search__audio">
            <span class="play">
                <img src="../assets/img/search/soundOn.svg" alt="">
            </span>
            <span class="stop">
                <img src="../assets/img/search/soundOff.svg" alt="">
            </span>
            <audio id="audio" src="../assets/music/music__audio01.mp3" loop="loop"></audio>
        </div>

        <span>CSS 속성 검색 이벤트</span>
        <h1>2분동안 CSS 속성 검색하기</h1>
        <p class="desc">
            2분 동안 CSS 속성을 많이 검색하면 점수가 올라갑니다.<br>
            기억이 나지 않는다면 힌트보기를 세 번 이용하실 수 있습니다.
        </p>

        <div class="time">
            <span>02 : 00</span>
        </div>

        <div class="search__box">
            <label for="search">검색하기</label>
            <input type="text" id="search" placeholder="CSS 속성을 입력해주세요.">
            <div class="start">버튼을 누르면 게임이 시작됩니다.</div>
        </div>

        <div class="search__info2 center">
            <div>전체 속성 갯수 : <span class="num">0</span></div>
            <div>현재 맞춘 갯수 : <span class="total">0</span></div>
        </div>

        <div class="search__answers">
        </div>

        <div class="search__missAnswers">
        </div>

        <div class="search__list">
        </div>

        <div class="search__result">
            <div class="svg__wrap">
                <svg xmlns="http://www.w3.org/2000/svg" width="448px" height="386px" viewBox="0 0 448 386">
                    <g filter="none" transform="translate(218.184,198.765) translate(-217.528,-187.235)" style="animation: 3.9s linear infinite both bee-a0_ft;">
                        <g id="bee-Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" transform="translate(217.528,187.235) translate(-218.184,-198.765)">
                        <g id="bee-Artboard" transform="translate(218.184,198.765) translate(-1258.18,-1122.76)">
                            <g id="bee-drop" fill="#946BC6" transform="translate(1394.27,1301.5) translate(-27.7667,-6.5)">
                            <rect id="bee-Rectangle" width="25.9539" height="13" rx="6.5" transform="translate(12.977,6.5) translate(-12.977,-6.5)" />
                            <path id="bee-Oval" d="M6.5,0C7.80436,3.3445,3.58985,6.5,0,6.5C-3.58985,6.5,-7.26635,3.5071,-6.5,0C-4.53336,-9,-3.53336,-17.5,0,-17.5C3.46664,-17.5,4.55118,-4.99697,6.5,0Z" transform="translate(49.0334,-83.5)" style="animation: 3.9s linear infinite both bee-Oval_t, 3.9s linear infinite both bee-Oval_d;" />
                            </g>
                            <g id="bee-scene" transform="translate(1258.18,1122.76) translate(-218.184,-198.765)">
                            <g id="bee-flower-2" transform="translate(90.0588,372) translate(0,-206.381)" style="animation: 3.9s linear infinite both bee-flower-2_t;">
                                <path id="bee-Path-9" d="M0.941176,206.381C-1.72549,120.715,1.27451,69.7147,9.94118,53.3814C11.9977,49.5056,14.27,45.7426,16.7582,42.0921L16.7582,42.0921C30.4776,21.9638,51.6942,8.17626,75.6598,3.81498C105.444,-1.60524,131.705,-1.24978,154.441,4.88136C198.941,16.8814,204.941,19.8814,210.441,24.8814C214.108,28.2147,234.275,48.8814,270.941,86.8814" stroke="#7AB6AE" stroke-width="6" transform="translate(135.471,103.191) translate(-135.471,-103.191)" />
                                <g id="bee-Group-3-Copy-3" fill="#7AB6AE" transform="translate(264.26,81.0804) rotate(91) translate(-15.2019,-15.6629)">
                                <rect id="bee-Rectangle-2" width="29.6325" height="13.1271" rx="6.56355" transform="translate(15.2019,6.88946) translate(-14.8162,-6.56355)" />
                                <rect id="bee-Rectangle-Copy-7" width="29.6325" height="12.5416" rx="6.27078" transform="translate(23.7473,16.1837) rotate(-90) translate(-14.8162,-6.27078)" />
                                </g>
                                <g id="bee-Flower-Copy-2" transform="translate(288.54,108.447) rotate(133) translate(-30.4805,-32.3833)">
                                <g id="bee-Group-2" fill="#946BC4" transform="translate(30.2037,10.1784) translate(-22.289,-10.1784)">
                                    <rect id="bee-Rectangle-3" width="11" height="16.6487" rx="5.5" transform="translate(5.5,12.0325) translate(-5.5,-8.32434)" />
                                    <rect id="bee-Rectangle-Copy-5" width="11" height="16.6487" rx="5.5" transform="translate(22.5658,8.32434) translate(-5.5,-8.32434)" />
                                    <rect id="bee-Rectangle-Copy-6" width="11" height="16.6487" rx="5.5" transform="translate(39.078,12.0325) translate(-5.5,-8.32434)" />
                                </g>
                                <path id="bee-Combined-Shape" d="M30.3952,4.26124C39.0927,4.26124,46.9394,7.90412,52.4926,13.7473C50.6453,14.7714,49.3952,16.74,49.3952,19.0006L49.3952,19.0006L49.395,34.1675C47.7715,34.6076,46.0485,34.5367,44.4656,33.9634L44.4656,33.9634L44.4666,23.8117C44.4666,20.498,41.7803,17.8117,38.4666,17.8117C35.1529,17.8117,32.4666,20.498,32.4666,23.8117L32.4666,23.8117L32.4657,33.5686L32.0548,33.797C31.0514,34.3544,29.8179,34.2904,28.8775,33.6322L28.8775,33.6322L28.8427,33.6076L28.8432,23.8117C28.8432,20.498,26.1569,17.8117,22.8432,17.8117C19.5295,17.8117,16.8432,20.498,16.8432,23.8117L16.8432,23.8117L16.8427,33.1626L16.31,33.502C15.1865,34.217,13.7261,34.1057,12.7239,33.2288L12.7239,33.2288L11.9147,32.5206L11.9147,19.0006C11.9147,16.6001,10.505,14.5289,8.46835,13.5696C14.0105,7.83045,21.786,4.26124,30.3952,4.26124Z" fill="#CB90EB" transform="translate(30.4805,19.3569) translate(-30.4805,-19.3569)" />
                                <path id="bee-Combined-Shape-2" d="M55.0037,12.6397C58.2938,12.6397,60.961,15.3069,60.961,18.5971L60.961,33.7508L60.9587,33.9117C60.9602,34.0363,60.961,34.1611,60.961,34.2861C60.961,51.12,47.3144,64.7666,30.4805,64.7666C13.6466,64.7666,0,51.12,0,34.2861L0.00219882,33.9143C0.000736059,33.86,0,33.8055,0,33.7508L0,18.5971C0,15.3069,2.66719,12.6397,5.95733,12.6397C9.24747,12.6397,11.9147,15.3069,11.9147,18.5971L11.9147,32.1618L12.7239,32.87C13.7261,33.7469,15.1865,33.8582,16.31,33.1432L16.8427,32.8038L16.8432,23.4529C16.8432,20.1392,19.5295,17.4529,22.8432,17.4529C26.1569,17.4529,28.8432,20.1392,28.8432,23.4529L28.8427,33.2488L28.8775,33.2734C29.8179,33.9316,31.0514,33.9956,32.0548,33.4382L32.4657,33.2098L32.4666,23.4529C32.4666,20.1392,35.1529,17.4529,38.4666,17.4529C41.7803,17.4529,44.4666,20.1392,44.4666,23.4529L44.4656,33.6046C45.9365,34.1374,47.5285,34.2363,49.0492,33.8944C49.0469,33.8466,49.0463,33.7988,49.0463,33.7508L49.0463,18.5971C49.0463,15.3069,51.7135,12.6397,55.0037,12.6397Z" fill="#946BC6" transform="translate(30.4805,38.7032) translate(-30.4805,-38.7032)" />
                                </g>
                            </g>
                            <g id="bee-flower-3" transform="translate(89.1929,372.5) translate(0,-241)" style="animation: 3.9s linear infinite both bee-flower-3_t;">
                                <g id="bee-Group-3-Copy-5" fill="#7AB6AE" transform="translate(286.509,69.6629) translate(-15.2019,-15.6629)">
                                <rect id="bee-Rectangle-4" width="29.6325" height="13.1271" rx="6.56355" transform="translate(15.2019,6.88946) translate(-14.8162,-6.56355)" />
                                <rect id="bee-Rectangle-Copy-7-2" width="29.6325" height="12.5416" rx="6.27078" transform="translate(23.7473,16.1837) rotate(-90) translate(-14.8162,-6.27078)" />
                                </g>
                                <path id="bee-Path-10" d="M0.8071,241C-0.269033,219.056,-0.269033,203.389,0.8071,194C5.58952,152.274,26.6818,123.699,66.3071,107.5C97.6881,94.6713,146.256,109.316,194.807,104C240.474,99,273.64,85.3333,294.307,63" stroke="#7AB6AE" stroke-width="5" transform="translate(147.154,152) translate(-147.154,-152)" />
                                <g id="bee-Flower-Copy-3" transform="translate(312.878,45.4049) rotate(46) translate(-30.4805,-32.3833)">
                                <g id="bee-Group-2-2" fill="#946BC4" transform="translate(30.2037,10.1784) translate(-22.289,-10.1784)">
                                    <rect id="bee-Rectangle-5" width="11" height="16.6487" rx="5.5" transform="translate(5.5,12.0325) translate(-5.5,-8.32434)" />
                                    <rect id="bee-Rectangle-Copy-5-2" width="11" height="16.6487" rx="5.5" transform="translate(22.5658,8.32434) translate(-5.5,-8.32434)" />
                                    <rect id="bee-Rectangle-Copy-6-2" width="11" height="16.6487" rx="5.5" transform="translate(39.078,12.0325) translate(-5.5,-8.32434)" />
                                </g>
                                <path id="bee-Combined-Shape-3" d="M30.3952,4.26124C39.0927,4.26124,46.9394,7.90412,52.4926,13.7473C50.6453,14.7714,49.3952,16.74,49.3952,19.0006L49.3952,19.0006L49.395,34.1675C47.7715,34.6076,46.0485,34.5367,44.4656,33.9634L44.4656,33.9634L44.4666,23.8117C44.4666,20.498,41.7803,17.8117,38.4666,17.8117C35.1529,17.8117,32.4666,20.498,32.4666,23.8117L32.4666,23.8117L32.4657,33.5686L32.0548,33.797C31.0514,34.3544,29.8179,34.2904,28.8775,33.6322L28.8775,33.6322L28.8427,33.6076L28.8432,23.8117C28.8432,20.498,26.1569,17.8117,22.8432,17.8117C19.5295,17.8117,16.8432,20.498,16.8432,23.8117L16.8432,23.8117L16.8427,33.1626L16.31,33.502C15.1865,34.217,13.7261,34.1057,12.7239,33.2288L12.7239,33.2288L11.9147,32.5206L11.9147,19.0006C11.9147,16.6001,10.505,14.5289,8.46835,13.5696C14.0105,7.83045,21.786,4.26124,30.3952,4.26124Z" fill="#CB90EB" transform="translate(30.4805,19.3569) translate(-30.4805,-19.3569)" />
                                <path id="bee-Combined-Shape-4" d="M55.0037,12.6397C58.2938,12.6397,60.961,15.3069,60.961,18.5971L60.961,33.7508L60.9587,33.9117C60.9602,34.0363,60.961,34.1611,60.961,34.2861C60.961,51.12,47.3144,64.7666,30.4805,64.7666C13.6466,64.7666,0,51.12,0,34.2861L0.00219882,33.9143C0.000736059,33.86,0,33.8055,0,33.7508L0,18.5971C0,15.3069,2.66719,12.6397,5.95733,12.6397C9.24747,12.6397,11.9147,15.3069,11.9147,18.5971L11.9147,32.1618L12.7239,32.87C13.7261,33.7469,15.1865,33.8582,16.31,33.1432L16.8427,32.8038L16.8432,23.4529C16.8432,20.1392,19.5295,17.4529,22.8432,17.4529C26.1569,17.4529,28.8432,20.1392,28.8432,23.4529L28.8427,33.2488L28.8775,33.2734C29.8179,33.9316,31.0514,33.9956,32.0548,33.4382L32.4657,33.2098L32.4666,23.4529C32.4666,20.1392,35.1529,17.4529,38.4666,17.4529C41.7803,17.4529,44.4666,20.1392,44.4666,23.4529L44.4656,33.6046C45.9365,34.1374,47.5285,34.2363,49.0492,33.8944C49.0469,33.8466,49.0463,33.7988,49.0463,33.7508L49.0463,18.5971C49.0463,15.3069,51.7135,12.6397,55.0037,12.6397Z" fill="#946BC6" transform="translate(30.4805,38.7032) translate(-30.4805,-38.7032)" />
                                </g>
                            </g>
                            <g id="bee-leg-l" transform="translate(192,343.25) translate(-9.5,-40.75)">
                                <path id="bee-leg1" d="M9,71.5L14,71.5C16.7614,71.5,19,73.7386,19,76.5C19,79.2614,16.7614,81.5,14,81.5L0,81.5L0,81.5L0,80.5C0,75.5294,4.02944,71.5,9,71.5Z" fill="#283138" transform="translate(9.5,76.5) translate(-9.5,-76.5)" />
                            </g>
                            <g id="bee-leg-m-r" transform="translate(237.5,340.75) translate(-9.5,-43.25)">
                                <path id="bee-leg3" d="M9,76.5L14,76.5C16.7614,76.5,19,78.7386,19,81.5C19,84.2614,16.7614,86.5,14,86.5L0,86.5L0,86.5L0,85.5C0,80.5294,4.02944,76.5,9,76.5Z" fill="#283138" transform="translate(9.5,81.5) scale(-1,1) translate(-9.5,-81.5)" />
                            </g>
                            <g id="bee-leg-r" transform="translate(258.693,329) translate(-9.5,-55)" />
                            <g id="bee-plants" transform="translate(94.5778,321.5) translate(-94.5778,-64.5)">
                                <path id="bee-Rectangle-6" d="M42.5,0C67.9051,0,88.5,20.5949,88.5,46L88.5,96C88.5,100.418,84.9183,104,80.5,104L50.5,104C46.0817,104,42.5,100.418,42.5,96L42.5,0L42.5,0Z" fill="#537B88" transform="translate(65.5,52) translate(-65.5,-52)" />
                                <path id="bee-Path" d="M13,11.5L63.9874,61.1217C67.3073,64.3527,70.0833,68.0989,72.208,72.2155L73.3927,74.5109C75.7858,79.1475,77.5192,84.0959,78.5425,89.2124L80,96.5L80,96.5L85.9454,92.1761C89.2899,89.7437,93.0299,87.9079,97,86.75L97.3619,86.6444C101.108,85.5518,104.968,84.8927,108.864,84.6801L130.5,83.5L130.5,83.5L133.11,88.4305C134.33,90.735,136.329,92.5316,138.75,93.5L138.964,93.5858C141.228,94.4913,143.759,94.4604,146,93.5C148.265,92.5294,150.129,90.8123,151.282,88.6346L154,83.5L154,83.5L188.5,83.5L186.564,93.1802C185.859,96.7031,184.584,100.087,182.789,103.199L181.04,106.232C179.027,109.72,176.458,112.857,173.434,115.518L171.75,117C167.619,120.636,162.854,123.48,157.693,125.392L152,127.5L152,127.5L66.5,129L10.5,73L7.25395,67.3194C4.11471,61.8257,2.07543,55.7733,1.25,49.5L1.03648,47.8772C0.350899,42.6668,0.592462,37.3762,1.75,32.25C2.90438,27.1377,5.09549,22.3167,8.18776,18.0852L13,11.5L13,11.5Z" fill="#7AB6AE" transform="translate(94.5778,70.25) translate(-94.5778,-70.25)" />
                            </g>
                            <g id="bee-flower-1" transform="translate(105,344.5) translate(-62.9058,-344.5)" style="animation: 3.9s linear infinite both bee-flower-1_t;">
                                <g id="bee-Group-3-Copy-2" fill="#7AB6AE" transform="translate(32.4334,179.29) rotate(-136) translate(-15.2019,-15.6629)">
                                <rect id="bee-Rectangle-7" width="29.6325" height="13.1271" rx="6.56355" transform="translate(15.2019,6.88946) translate(-14.8162,-6.56355)" />
                                <rect id="bee-Rectangle-Copy-7-3" width="29.6325" height="12.5416" rx="6.27078" transform="translate(23.7473,16.1837) rotate(-90) translate(-14.8162,-6.27078)" />
                                </g>
                                <g id="bee-Group-9" transform="translate(81.0586,181.765) translate(-81.0586,-181.765)">
                                <g id="bee-Group-3" fill="#7AB6AE" transform="translate(103.222,73.0275) translate(-14.8162,-15.337)">
                                    <rect id="bee-Rectangle-8" width="29.6325" height="13.1271" rx="6.56355" transform="translate(14.8162,6.56355) translate(-14.8162,-6.56355)" />
                                    <rect id="bee-Rectangle-Copy-7-4" width="29.6325" height="12.5416" rx="6.27078" transform="translate(23.3617,15.8578) rotate(-90) translate(-14.8162,-6.27078)" />
                                </g>
                                <g id="bee-flower-1-2" transform="translate(81.0586,181.765) translate(-81.0586,-181.765)">
                                    <g id="bee-leaves" transform="translate(35.6112,110.782) translate(-35.4924,-37.2335)">
                                    <path id="bee-Rectangle-9" d="M35.287,0C54.8931,0,70.787,15.8939,70.787,35.5L70.787,59.5C70.787,66.1274,65.4144,71.5,58.787,71.5L53.037,71.5C43.2339,71.5,35.287,63.5531,35.287,53.75L35.287,0L35.287,0Z" fill="#527B88" transform="translate(53.037,35.75) translate(-53.037,-35.75)" />
                                    <path id="bee-Rectangle-10" d="M18,22.0124C36.8613,22.0124,52.2317,37.1494,52.5203,56.0085L52.9848,86.3585L52.9848,86.3585L48.979,85.8952C31.3224,83.8532,18,68.9013,18,51.127L18,22.0124L18,22.0124Z" fill="#7AB6AE" transform="translate(35.4924,54.1855) rotate(-46) translate(-35.4924,-54.1855)" />
                                    </g>
                                    <g id="bee-Group-8" transform="translate(81.0586,181.765) translate(-81.0586,-181.765)">
                                    <g id="bee-Group-7" stroke="#7AB6AE" stroke-width="6" transform="translate(63.9058,205.5) translate(-49.5,-146.5)">
                                        <path id="bee-Path-7" d="M99,0C86.5722,15.2623,78.2389,26.929,74,35C63.5795,54.8408,58.5351,71.8019,57.5,86.5C55,122,58.406,210.019,56,247C53.594,283.981,43.5,285,41,293" transform="translate(70,146.5) translate(-70,-146.5)" />
                                        <path id="bee-Path-8" d="M0,120L13.25,120C17.3956,120,21.5202,120.589,25.5,121.75C29.4648,122.906,33.1775,124.796,36.4455,127.322L37,127.75C40.6505,130.571,43.9104,133.864,46.6944,137.543L56.5,150.5L56.5,150.5" transform="translate(28.25,135.25) translate(-28.25,-135.25)" />
                                    </g>
                                    <g id="bee-flower1" transform="translate(19.4275,179.229) translate(-19.4275,-22.5293)">
                                        <g id="bee-Group-3-Copy" fill="#7AB6AE" transform="translate(32.4334,22.5899) rotate(-136) translate(-15.2019,-15.6629)">
                                        <rect id="bee-Rectangle-11" width="29.6325" height="13.1271" rx="6.56355" transform="translate(15.2019,6.88946) translate(-14.8162,-6.56355)" />
                                        <rect id="bee-Rectangle-Copy-7-5" width="29.6325" height="12.5416" rx="6.27078" transform="translate(23.7473,16.1837) rotate(-90) translate(-14.8162,-6.27078)" />
                                        </g>
                                        <ellipse id="bee-Oval-2" fill="#BB80DC" rx="14.4572" ry="14.4572" transform="translate(14.4572,22.5)" />
                                    </g>
                                    <g id="bee-Flower" transform="translate(128.476,45.4049) rotate(46) translate(-30.4805,-32.3833)">
                                        <g id="bee-Group-2-3" fill="#946BC4" transform="translate(30.2037,10.1784) translate(-22.289,-10.1784)">
                                        <rect id="bee-Rectangle-12" width="11" height="16.6487" rx="5.5" transform="translate(5.5,12.0325) translate(-5.5,-8.32434)" />
                                        <rect id="bee-Rectangle-Copy-5-3" width="11" height="16.6487" rx="5.5" transform="translate(22.5658,8.32434) translate(-5.5,-8.32434)" />
                                        <rect id="bee-Rectangle-Copy-6-3" width="11" height="16.6487" rx="5.5" transform="translate(39.078,12.0325) translate(-5.5,-8.32434)" />
                                        </g>
                                        <path id="bee-Combined-Shape-5" d="M30.3952,4.26124C39.0927,4.26124,46.9394,7.90412,52.4926,13.7473C50.6453,14.7714,49.3952,16.74,49.3952,19.0006L49.3952,19.0006L49.395,34.1675C47.7715,34.6076,46.0485,34.5367,44.4656,33.9634L44.4656,33.9634L44.4666,23.8117C44.4666,20.498,41.7803,17.8117,38.4666,17.8117C35.1529,17.8117,32.4666,20.498,32.4666,23.8117L32.4666,23.8117L32.4657,33.5686L32.0548,33.797C31.0514,34.3544,29.8179,34.2904,28.8775,33.6322L28.8775,33.6322L28.8427,33.6076L28.8432,23.8117C28.8432,20.498,26.1569,17.8117,22.8432,17.8117C19.5295,17.8117,16.8432,20.498,16.8432,23.8117L16.8432,23.8117L16.8427,33.1626L16.31,33.502C15.1865,34.217,13.7261,34.1057,12.7239,33.2288L12.7239,33.2288L11.9147,32.5206L11.9147,19.0006C11.9147,16.6001,10.505,14.5289,8.46835,13.5696C14.0105,7.83045,21.786,4.26124,30.3952,4.26124Z" fill="#CB90EB" transform="translate(30.4805,19.3569) translate(-30.4805,-19.3569)" />
                                        <path id="bee-Combined-Shape-6" d="M55.0037,12.6397C58.2938,12.6397,60.961,15.3069,60.961,18.5971L60.961,33.7508L60.9587,33.9117C60.9602,34.0363,60.961,34.1611,60.961,34.2861C60.961,51.12,47.3144,64.7666,30.4805,64.7666C13.6466,64.7666,0,51.12,0,34.2861L0.00219882,33.9143C0.000736059,33.86,0,33.8055,0,33.7508L0,18.5971C0,15.3069,2.66719,12.6397,5.95733,12.6397C9.24747,12.6397,11.9147,15.3069,11.9147,18.5971L11.9147,32.1618L12.7239,32.87C13.7261,33.7469,15.1865,33.8582,16.31,33.1432L16.8427,32.8038L16.8432,23.4529C16.8432,20.1392,19.5295,17.4529,22.8432,17.4529C26.1569,17.4529,28.8432,20.1392,28.8432,23.4529L28.8427,33.2488L28.8775,33.2734C29.8179,33.9316,31.0514,33.9956,32.0548,33.4382L32.4657,33.2098L32.4666,23.4529C32.4666,20.1392,35.1529,17.4529,38.4666,17.4529C41.7803,17.4529,44.4666,20.1392,44.4666,23.4529L44.4656,33.6046C45.9365,34.1374,47.5285,34.2363,49.0492,33.8944C49.0469,33.8466,49.0463,33.7988,49.0463,33.7508L49.0463,18.5971C49.0463,15.3069,51.7135,12.6397,55.0037,12.6397Z" fill="#946BC6" transform="translate(30.4805,38.7032) translate(-30.4805,-38.7032)" />
                                    </g>
                                    </g>
                                </g>
                                </g>
                            </g>
                            <g id="bee-bee" transform="translate(224.5,185.29) translate(-105,-114.943)" style="animation: 3.9s linear infinite both bee-bee_t;">
                                <g transform="translate(99.4377,210.746) translate(-32.0265,-22.3044)" style="animation: 3.9s linear infinite both bee-a1_t;">
                                <rect id="bee-Rectangle-13" width="29.5" height="44" rx="14.75" fill="#FFA521" transform="translate(11.2509,22.975) translate(-14.75,-22)" style="animation: 3.9s linear infinite both bee-Rectangle-13_t;" />
                                <rect id="bee-Rectangle-Copy-12" width="29.5" height="44" rx="14.75" fill="#FFA521" transform="translate(45.3387,22.975) translate(-14.75,-22)" style="animation: 3.9s linear infinite both bee-Rectangle-Copy-12_t;" />
                                </g>
                                <g transform="translate(112.695,185.347) translate(-112.695,-199.854)" style="animation: 3.9s linear infinite both bee-a2_t;">
                                <g id="bee-body" transform="translate(105.5,147.52) translate(-77.5,-77.5)">
                                    <ellipse id="bee-Oval-Copy-2" fill="#283138" rx="77.5" ry="77.5" transform="translate(77.5,77.5)" />
                                    <path id="bee-Combined-Shape-7" d="M145.808,114.141C141.546,122.07,135.944,129.172,129.304,135.143L25.696,135.143C19.0564,129.172,13.4541,122.07,9.19189,114.141ZM154.248,66.658C154.744,70.2008,155,73.8205,155,77.5C155,80.9432,154.775,84.3339,154.34,87.6584L0.659782,87.6584C0.224542,84.3339,0,80.9432,0,77.5C0,73.8205,0.256423,70.2008,0.752375,66.658ZM123.524,15.1394C131.261,20.8595,137.897,27.9855,143.053,36.1401L11.9473,36.1401C17.1031,27.9855,23.7386,20.8595,31.4763,15.1394Z" fill="#FFA521" transform="translate(77.5,75.1411) translate(-77.5,-75.1411)" />
                                </g>
                                <g transform="translate(105,99.71) translate(-105,-83.7987)" style="animation: 3.9s linear infinite both bee-a3_t;">
                                    <g id="bee-wings" fill="#B1E2EF" transform="translate(165.5,136.75) translate(-165,-151.855)" style="animation: 3.9s linear infinite both bee-wings_t;">
                                    <rect id="bee-Rectangle-Copy-11" width="158" height="79.5" rx="39.75" transform="translate(168.025,157.166) rotate(60) translate(-158,-39.75)" style="animation: 3.9s linear infinite both bee-Rectangle-Copy-11_t;" />
                                    <rect id="bee-Rectangle-14" width="188.5" height="81" rx="40.5" transform="translate(175.924,154.237) translate(-175.924,-70.8827)" style="animation: 3.9s linear infinite both bee-Rectangle-14_t;" />
                                    </g>
                                    <g id="bee-antennas" stroke="#202528" stroke-linecap="round" stroke-width="5" transform="translate(130,99.2503) translate(-19.4971,-35.5418)" style="animation: 3.9s linear infinite both bee-antennas_t;">
                                    <path id="bee-Path-6" d="M0,36.5L0.139392,33.1081C0.854467,15.708,15.5398,2.18202,32.94,2.8971C33.4607,2.9185,33.9809,2.95281,34.5,3L34.5,3L34.5,3" transform="translate(17.25,19.685) translate(-17.25,-19.685)" />
                                    <path id="bee-Path-6-Copy" d="M32.5,36.5L32.6394,33.1081C33.3545,15.708,48.0398,2.18202,65.44,2.8971C65.9607,2.9185,66.4809,2.95281,67,3L67,3L67,3" transform="translate(49.75,19.685) translate(-49.75,-19.685)" />
                                    </g>
                                    <g id="bee-face" transform="translate(105,129.75) translate(-105,-43.5)">
                                    <path id="bee-Path-3" stroke="#336775" stroke-width="5" opacity="0.968169" d="M209.5,43.5L119,43.5" transform="translate(164.25,43.5) translate(-164.25,-43.5)" />
                                    <g id="bee-Group-5" transform="translate(124.708,46.5) translate(-71,-36.5)">
                                        <rect id="bee-Rectangle-15" fill="#FFA521" width="142" height="73" rx="36" transform="translate(71,36.5) translate(-71,-36.5)" />
                                        <ellipse id="bee-Oval-3" fill="#FFFFFF" rx="29.8575" ry="29.8575" transform="translate(36.1492,36)" />
                                        <ellipse id="bee-Oval-Copy-3" fill="#FFFFFF" rx="29.8575" ry="29.8575" transform="translate(106.649,36)" />
                                        <path id="bee-Combined-Shape-8" d="M37.6205,15.3575C39.5734,15.3575,41.463,15.6287,43.2537,16.1355C41.0876,17.8939,39.7039,20.5773,39.7039,23.5838C39.7039,28.8795,43.9969,33.1725,49.2926,33.1725C52.512,33.1725,55.3608,31.5859,57.0998,29.152C57.8533,31.2948,58.263,33.5995,58.263,36L58.263,37.4713C58.263,48.8718,49.0211,58.1138,37.6205,58.1138L36.1492,58.1138C24.7487,58.1138,15.5067,48.8718,15.5067,37.4713L15.5067,36C15.5067,24.5995,24.7487,15.3575,36.1492,15.3575L37.6205,15.3575Z" fill="#283138" transform="translate(36.8849,36.7356) translate(-36.8849,-36.7356)" style="animation: 3.9s linear infinite both bee-Combined-Shape-8_t;" />
                                        <path id="bee-Combined-Shape-Copy-2" d="M97.0055,15.3575C98.9584,15.3575,100.848,15.6287,102.639,16.1355C100.473,17.8939,99.0889,20.5773,99.0889,23.5838C99.0889,28.8795,103.382,33.1725,108.678,33.1725C111.897,33.1725,114.746,31.5859,116.485,29.152C117.238,31.2948,117.648,33.5995,117.648,36L117.648,37.4713C117.648,48.8718,108.406,58.1138,97.0055,58.1138L95.5342,58.1138C84.1337,58.1138,74.8917,48.8718,74.8917,37.4713L74.8917,36C74.8917,24.5995,84.1337,15.3575,95.5342,15.3575L97.0055,15.3575Z" fill="#283138" transform="translate(96.2699,36.7356) translate(-96.2699,-36.7356)" style="animation: 3.9s linear infinite both bee-Combined-Shape-Copy-2_t;" />
                                    </g>
                                    <path id="bee-Path-11" stroke="#336775" stroke-width="5" d="M129.5,43.5L119.5,43.5" transform="translate(124.5,43.5) translate(-124.5,-43.5)" />
                                    <g id="bee-eye-covers" transform="translate(125.475,15.1468) scale(0.8,0) translate(-65.4172,0)" style="animation: 3.9s linear infinite both bee-eye-covers_t;">
                                        <path fill="#ffa521" stroke="none" d="M30.5342,0C30.5566,2.49713,-30.5104,1.82316,-30.5342,0C-30.709,-13.3918,-16.8636,-24.25,0,-24.25C16.8636,-24.25,30.414,-13.3924,30.5342,0Z" transform="translate(30.535,0) scale(1,1.3) translate(0.000815516,24.25)" />
                                        <path fill="#ffa521" stroke="none" d="M30.5342,0C30.5566,2.49713,-30.5104,1.82316,-30.5342,0C-30.709,-13.3918,-16.8636,-24.25,0,-24.25C16.8636,-24.25,30.414,-13.3924,30.5342,0Z" transform="translate(100.299,0) scale(1,1.3) translate(0.000815516,24.25)" />
                                    </g>
                                    <g id="bee-eye-covers-2" transform="translate(125.475,79) rotate(180) scale(0.7,0) translate(-65.4172,0)" style="animation: 3.9s linear infinite both bee-eye-covers-2_t;">
                                        <path fill="#ffa521" stroke="none" d="M30.5342,0C30.5566,2.49713,-30.5104,1.82316,-30.5342,0C-30.709,-13.3918,-16.8636,-24.25,0,-24.25C16.8636,-24.25,30.414,-13.3924,30.5342,0Z" transform="translate(30.535,0) scale(1,1.3) translate(0.000815516,24.25)" />
                                        <path fill="#ffa521" stroke="none" d="M30.5342,0C30.5566,2.49713,-30.5104,1.82316,-30.5342,0C-30.709,-13.3918,-16.8636,-24.25,0,-24.25C16.8636,-24.25,30.414,-13.3924,30.5342,0Z" transform="translate(100.299,0) scale(1,1.3) translate(0.000815516,24.25)" />
                                    </g>
                                    <ellipse id="bee-Oval-4" stroke="#336775" stroke-width="6" rx="40.5" ry="40.5" transform="translate(79.5,43.5)" />
                                    <ellipse id="bee-Oval-Copy-4" stroke="#336775" stroke-width="6" rx="40.5" ry="40.5" transform="translate(169.5,43.5)" />
                                    <path id="bee-Path-4" d="M121.068,70C122.115,71,123.258,71.5,124.5,71.5C125.742,71.5,127.052,71,128.432,70" stroke="#313942" stroke-width="4" stroke-linecap="round" transform="translate(124.75,70.75) translate(-124.75,-70.75)" />
                                    <path id="bee-Path-5" d="M39,43.5L21.0069,43.5C18.024,43.5,15.0628,44.0072,12.25,45C9.47075,45.9809,7.01648,47.7105,5.15796,49.9979L4.75,50.5C2.61996,53.1216,1.20802,56.2519,0.652707,59.5838L0,63.5L0,63.5" stroke="#336775" stroke-width="5" stroke-linecap="round" transform="translate(19.5,53.5) translate(-19.5,-53.5)" />
                                    </g>
                                </g>
                                </g>
                            </g>
                            <g id="bee-leg-m-l" transform="translate(212.5,329.75) translate(-9.5,-54.25)">
                                <path id="bee-leg2" d="M9,98.5L14,98.5C16.7614,98.5,19,100.739,19,103.5C19,106.261,16.7614,108.5,14,108.5L0,108.5L0,108.5L0,107.5C0,102.529,4.02944,98.5,9,98.5Z" fill="#283138" transform="translate(9.5,103.5) translate(-9.5,-103.5)" />
                            </g>
                            </g>
                        </g>
                        </g>
                        <path d="M-1.66219,-1.66219L-1.66219,32.6228L-1.66219,72.6228" stroke="#283138" fill="none" stroke-width="5" stroke-linecap="round" transform="translate(197.506,293.347)" style="animation: 3.9s linear infinite both bee-a4_d;" />
                        <path d="M0,0L0,-65.1141L0,-99.2912" stroke="#283138" fill="none" stroke-width="5" stroke-linecap="round" transform="translate(215.806,362.47)" style="animation: 3.9s linear infinite both bee-a5_d;" />
                        <path d="M0,0L0.150197,-42.3555L0.25,-70.5" stroke="#283138" fill="none" stroke-width="5" stroke-linecap="round" transform="translate(231.594,362.47)" style="animation: 3.9s linear infinite both bee-a6_d;" />
                        <g transform="translate(258.037,321.72) translate(-9.5,-50.75)">
                        <path d="M0,0L0,-61.2126L0,-104.133" stroke="#283138" fill="none" stroke-width="5" stroke-linecap="round" stroke-linejoin="round" transform="translate(2.17979,95)" style="animation: 3.9s linear infinite both bee-a7_d;" />
                        <g transform="translate(0.5,96.5)" style="animation: 3.9s linear infinite both bee-a8_t;">
                            <path id="bee-leg4" d="M9,100L14,100C16.7614,100,19,102.239,19,105C19,107.761,16.7614,110,14,110L0,110L0,110L0,109C0,104.029,4.02944,100,9,100Z" fill="#283138" transform="translate(0,0) scale(-1,1) translate(-19,-105)" style="animation: 3.9s linear infinite both bee-leg4_t;" />
                        </g>
                        </g>
                    </g>
                </svg>
                <div class="result"></div>
                <button class="restart">다시 도전하기</button>
            </div>
        </div>
    </div>
</main>

CSS

서치는 다 똑같은 형태의 css입니다.
사이트를 코딩하는 데에 필요한 css의 구조를 잡아줍니다.
앞선 검색 이펙트들과 거의 동일한 형태입니다.
CSS var() 함수를 사용하여 색 지정 및 변경을 하기 편하도록 해줬습니다.
var() : 함수로 정의해둔 속성을 불러와 사용가능하다. : 사용 방법. var(--htmlColor)

CSS CODE
:root {
    --htmlColor : #223547;
    --cssColor : #0e3d2e;
    --javascriptColor : #130744;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: "SCoreDream";
    color: #223547;
}

*,
*:before,
*:after {
    box-sizing: border-box;
}

a {
    color: #000;
    text-decoration: none;
}
li {
    list-style: none;
}

/* header */
#header {
    display: flex;
}
#header h1 {
    margin: 10px;
}
#header nav {
    margin: 10px;
}
#header nav li {
    display: inline;
    position: relative;
}
#header nav li a {
    width: 30px;
    height: 30px;
    border: 1px solid var(--htmlColor);
    border-radius: 50%;
    display: inline-block;
    text-align: center;
    line-height: 30px;
    font-family: "SCoreDream";
}
#header nav ul li.active a {
    background-color: var(--htmlColor);
    color: #fff;
}
#header nav li .sub {
    position: absolute;
    left: 0;
    top: 35px;
    width: 400px;
}
#header nav li .sub li a {
    width: auto;
    background-color: transparent;
    color: var(--htmColor);
    border: 0;
    text-align: left;
    line-height: 1.2;
}
#header nav li .sub li.active a {
    text-decoration: underline;
}

/* main */
#main {
    margin: 50px 10px;
}
.search__wrap {
    max-width: 1400px;
    margin: 0 auto;
    border: 3px solid var(--htmlColor);
    border-radius: 20px;
    background-color: #f1f3f6;
    padding: 30px;
    text-align: center;
}
.search__wrap > span {
    font-size: 20px;
    margin-bottom: 10px;
    display: inline-block;
}
.search__wrap > h1 {
    font-family: 'Tmon';
    color: var(--htmlColor);
    font-size: 6vw;
    margin-bottom: 10px;
}
.search__audio {
    margin-bottom: 10px;
    cursor: pointer;
}
.search__audio .play {
    display: none;
}
.search__wrap > span {
    font-size: 16px;
    margin-bottom: 10px;
}
.search__wrap .time {
    width: 140px;
    height: 140px;
    line-height: 140px;
    text-align: center;
    border-radius: 50%;
    margin: 0 auto;
    background: var(--htmlColor);
    margin-top: 20px;
}
.search__wrap .time span {
    color: #fff;
    font-size: 34px;
    font-weight: 400;
}
.search__box {
    margin-bottom: 20px;
    position: relative;
}
.search__box input {
    border: 2px solid var(--htmlColor);
    padding: 15px 40px;
    width: 30%;
    border-radius: 50px;
    font-size: 20px;
    margin-top: 20px;
}
.search__box .start {
    position: absolute;
    left: 50%; bottom: 0;
    transform: translateX(-50%);
    background: #223547;
    width: 30%;
    border-radius: 50px;
    font-size: 20px;
    border: 2px solid var(--htmlColor);
    padding: 15px 40px;
    color: #fff;
    cursor: pointer;
}
.search__box label {
    position:absolute;
    clip:rect(0 0 0 0);
    width:1px;
    height:1px;
    margin:-1px;
    overflow:hidden
}
.search__list {
    margin-top: 50px;
}
.search__list li {
    text-align: left;
    line-height: 1.7;
}
.search__list li.hide {
    display: none;
}

.search__list li.show {
    display: block;
}
.search__list span {
    display: inline-block;
    padding: 10px 20px;
    border: 1px solid var(--htmlColor);
    border-radius: 50px;
    margin: 5px;
    transition: all 0.3s;
    cursor: pointer;
}
.search__list span:hover {
    background-color: var(--htmlColor);
    color: #fff;
}
.search__list em {
    float: right;
    font-style: normal;
}
.search__list .line {
    margin: 50px 0;
}
.search__list .line li {
    background: #fff;
    padding: 10px 20px;
    margin-bottom: 5px;
    border-radius: 15px;
}
.search__list .line li:hover {
    background: #f9f9f9;
    cursor: pointer;
}
.search__info {
    text-align: center;
    margin-bottom: 30px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--htmlColor);
}
.search__info2 {
    text-align: center;
    margin-top: 40px;
    margin-bottom: 30px;
    padding-bottom: 10px;
    text-align: right;
    border-bottom: 2px solid var(--htmlColor);
}
.search__info2.center {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding-bottom: 30px;
}
.search__info .type {
    text-align: center;
    margin-bottom: 10px;
}
.search__info .keyword {
    text-align: center;
    margin-bottom: 10px;
}
.search__info .keyword span {
    border: 2px solid var(--htmlColor);
    border-radius: 50px;
    padding: 10px;
    display: inline-block;
}
.search__info .keyword span:hover {
    background-color: var(--htmlColor);
    color: #fff;
    cursor: pointer;
}
.search__desc {
    border-bottom: 1px solid var(--htmlColor);
    border-bottom-style: dashed;
    padding: 10px 40px;
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='11' cy='11' r='8' stroke='%23223547' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M16.5 16.958L21.5 21.958' stroke='%23223547' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: 5px 10px;
    width: 70%;
    margin: 0 auto;
    text-align: left;
    font-weight: 500;
}
.search__desc2 {
    border-bottom: 1px solid var(--htmlColor);
    border-bottom-style: dashed;
    padding: 10px 40px;
    width: 70%;
    margin: 0 auto;
    text-align: left;
    font-weight: 500;
}
.search__click {
    margin-top: 10px;
    margin-bottom: 30px;
}
.search__click li {
    display: inline;
}
.search__click li a {
    display: inline-block;
    border: 1px solid var(--htmlColor);
    border-radius: 50px;
    padding: 10px 20px;
    margin: 5px 0;
}
.search__click li a:hover {
    background-color: var(--htmlColor);
    color: #fff;
}

@media (max-width: 600px) {
    .search__wrap {
        padding: 20px;
    }
    .search__wrap > h1 {
        font-size: 40px;
    }
    .search__box input {
        font-size: 16px;
        padding: 12px 30px;
    }
}

/* footer */
#footer {
    text-align: center;
}
#footer a {
    color: #000;
    font-family: "SCoreDream";
    padding-bottom: 50px;
}
footer a:hover {
    text-decoration: underline;
}

.search__answers {
    border-bottom: 2px dashed var(--htmlColor);
    padding-bottom: 40px;
}
.search__answers span {
    display: inline-block;
    background: var(--htmlColor);
    padding: 10px 20px;
    color: #fff;
    border-radius: 30px;
    margin: 3px;
}
.search__missAnswers {
    border-bottom: 2px dashed var(--htmlColor);
    padding: 40px 0;
}
.search__missAnswers span {
    display: inline-block;
    border: 1px solid var(--htmlColor);
    color: var(--htmlColor);
    padding: 10px 20px;
    border-radius: 30px;
    margin: 3px;
}
.search__result {
    transform: scale3d(0, 0, 0);
    position: fixed;
    right: 3vw;
    top: 3vw;
    width: 30vw;
    height: 30vw;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: #fff;
    border: 3px solid #946BC6;
}
.search__result.show {
    display: flex;
    animation: rubberBand 1s 0.6s ease forwards;
}
.search__result .result {
    margin-top: 10px;
    font-style: 1vw;
    line-height: 1.4;
}
.search__result .restart {
    background: #946BC6;
    color: #fff;
    border: 0;
    font-size: 16px;
    padding: 6px 20px;
    margin-top: 10px;
    border-radius: 30px;
    cursor: pointer;
}

@keyframes rubberBand {
    from {
        transform: scale3d(0, 0, 0);
    }
    20% {
        transform: scale3d(1, 1, 1);
    }
    30% {
        transform: scale3d(1.25, 0.75, 1);
    }
    40% {
        transform: scale3d(0.75, 1.25, 1);
    }
    50% {
        transform: scale3d(1.15, 0.85, 1);
    }
    65% {
        transform: scale3d(0.95, 1.05, 1);
    }
    75% {
        transform: scale3d(1.05, 0.95, 1);
    }
    to {
        transform: scale3d(1, 1, 1);
    }
  }

script

이번 스크립트는 각 클래스에 적용해 줄 스크립트를 짜줍니다.

cssProperty CODE
const cssProperty = [
    { num: 1, name: "accent-color", desc: "특정 요소에 색상을 지정할 때 사용됩니다." },
    { num: 2, name: "align-content", desc: "콘텐츠 아이템의 상하관계 정렬 상태를 설정합니다." },
    { num: 3, name: "align-items", desc: "콘텐츠 아이템의 내부 상하관계 정렬 상태를 설정합니다." },
    { num: 4, name: "align-self", desc: "개별적인 콘텐츠 아이템의 정렬 상태를 설정합니다." },
    { num: 5, name: "all", desc: "요소의 속성을 초기화 또는 상속을 설정합니다." },
    { num: 6, name: "animation", desc: "애니메이션과 관련된 속성을 일괄적으로 설정합니다." },
    { num: 7, name: "animation-delay", desc: "애니메이션 지연 시간을 설정합니다." },
    { num: 8, name: "animation-direction", desc: "애니메이션 움직임 방향을 설정합니다." },
    { num: 9, name: "animation-duration", desc: "애니메이션 움직임 시간을 설정합니다." },
    { num: 10, name: "animation-fill-mode", desc: "애니메이션이 끝난 후의 상태를 설정합니다." },
    { num: 11, name: "animation-iteration-count", desc: "애니메이션의 반복 횟수를 설정합니다." },
    { num: 12, name: "animation-name", desc: "애니메이션 keyframe 이름을 설정합니다." },
    { num: 13, name: "animation-play-state", desc: "애니메이션 진행상태를 설정 합니다." },
    { num: 14, name: "animation-timeline", desc: "x" },
    { num: 15, name: "animation-timing-function", desc: "애니메이션 움직임의 속도를 설정 합니다." },
    { num: 16, name: "appearance", desc: "운영체제 및 브라우저에 기본적으로 설정되어 있는 테마를 기반으로 요소를 표현합니다." },
    { num: 17, name: "aspect-ratio", desc: "요소의 크기를 비율대로 조정할 수 있게 합니다." },
    { num: 18, name: "backdrop-filter", desc: "요소 뒤 영역에 흐림이나 색상 시프트 등 그래픽 효과를 적용할 수 있는 속성입니다." },
    { num: 19, name: "backface-visibility", desc: "입체적인 모습의 뒷면의 가시성을 결정하는 속성이다." },
    { num: 20, name: "background", desc: "백그라운드 속성을 일괄적으로 설정 합니다." },
    { num: 21, name: "background-attachment", desc: "배경 이미지의 고정 여부를 설정 합니다." },
    { num: 22, name: "background-blend-mode", desc: "배경을 혼합했을 때 그래픽 효과를 설정 합니다." },
    { num: 23, name: "background-clip", desc: "백그라운드 이미지의 위치 기준점을 설정 합니다." },
    { num: 24, name: "background-color", desc: "백그라운드 색을 설정 합니다." },
    { num: 25, name: "background-image", desc: "백그라운드 이미지 속성을 설정 합니다." },
    { num: 26, name: "background-origin", desc: "백그라운드 이미지의 위치 기준점을 설정하기 위한 속성입니다." },
    { num: 27, name: "background-position", desc: "백그라운드 이미지의 위치 영역을 설정 합니다." },
    { num: 28, name: "background-position-x", desc: "백그라운드 이미지의 x축 위치 영역을 설정 합니다." },
    { num: 29, name: "background-position-y", desc: "백그라운드 이미지의 y축 위치 영역을 설정 합니다." },
    { num: 30, name: "background-repeat", desc: "백그라운드 이미지 반복 여부를 설정 합니다." },
    { num: 31, name: "background-size", desc: "백그라운드 이미지 사이즈를 설정 합니다." },
    { num: 32, name: "block-size", desc: "기록 모드에 따라서, 요소의 블록의 수평과 수직 크기를 정의합니다." },
    { num: 33, name: "border", desc: "테두리 속성을 일괄적으로 설정 합니다." },
    { num: 34, name: "border-block", desc: "X" },
    { num: 35, name: "border-block-color", desc: "x" },
    { num: 36, name: "border-block-end", desc: "x" },
    { num: 37, name: "border-block-end-color", desc: "x" },
    { num: 38, name: "border-block-end-style", desc: "x" },
    { num: 39, name: "border-block-end-width", desc: "x" },
    { num: 40, name: "border-block-start", desc: "x" },
    { num: 41, name: "border-block-start-color", desc: "x" },
    { num: 42, name: "border-block-start-style", desc: "x" },
    { num: 43, name: "border-block-start-width", desc: "x" },
    { num: 44, name: "border-block-style", desc: "x" },
    { num: 45, name: "border-block-width", desc: "x" },
    { num: 46, name: "border-bottom", desc: "아래쪽 속성을 일괄적으로 설정 합니다." },
    { num: 47, name: "border-bottom-color", desc: "테두리 아래쪽 색 속성을 설정합니다." },
    { num: 48, name: "border-bottom-left-radius", desc: "아래 왼쪽 모서리 굴곡을 설정합니다." },
    { num: 49, name: "border-bottom-right-radius", desc: "아래 오른쪽 모서리 굴곡을 설정합니다." },
    { num: 50, name: "border-bottom-style", desc: "아래쪽 테두리의 스타일 속성을 설정합니다." },
    { num: 51, name: "border-bottom-width", desc: "아래쪽 테두리의 두께 속성을 설정합니다." },
    { num: 52, name: "border-collapse", desc: "테이블의 테두리를 겹칠지, 떨어트릴지를 설정합니다." },
    { num: 53, name: "border-color", desc: "모든 면의 테두리 색상을 설정 합니다." },
    { num: 54, name: "border-end-end-radius", desc: "요소의 테두리 반경을 설정 합니다." },
    { num: 55, name: "border-end-start-radius", desc: "요소의 테두리 반경을 설정 합니다." },
    { num: 56, name: "border-image", desc: "요소의 주위에 이미지를 설정 합니다." },
    { num: 57, name: "border-image-outset", desc: "테두리 상자와 테두리 이미지의 거리를 설정 합니다." },
    { num: 58, name: "border-image-repeat", desc: "모서리 영역을 테두리 이미지 크기에 맞춰 설정 합니다." },
    { num: 59, name: "border-image-slice", desc: "설정한 이미지를 여러개의 영역으로 나눕니다." },
    { num: 60, name: "border-image-source", desc: "테두리 이미지로 사용할 원본 이미지를 설정 합니다." },
    { num: 61, name: "border-image-width", desc: "테두리 이미지의 너비를 설정 합니다." },
    { num: 62, name: "border-inline", desc: "스타일 시트의 한 위치에 개별 논리적 인라인 테두리 속성 값을 설정 합니다." },
    { num: 63, name: "border-inline-color", desc: "모든 인라인 테두리 색상을 설정 합니다." },
    { num: 64, name: "border-inline-end", desc: "인라인 엔드 border 속성 값을 설정합니다." },
    { num: 65, name: "border-inline-end-color", desc: "개별 논리적 인라인 끝 테두리 색상을 설정 합니다." },
    { num: 66, name: "border-inline-end-style", desc: "인라인 끝 테두리 스타일을 설정 합니다." },
    { num: 67, name: "border-inline-end-width", desc: "논리적 인라인 끝 테두리 너비를 설정 합니다." },
    { num: 68, name: "border-inline-start", desc: "개별 논리적 인라인 시작 테두리 속성 값을 설정 합니다." },
    { num: 69, name: "border-inline-start-color", desc: "논리적 인라인 시작 테두리 색상을 설정 합니다." },
    { num: 70, name: "border-inline-start-style", desc: "논리적 인라인 시작 테두리 스타일을 설정 합니다." },
    { num: 71, name: "border-inline-start-width", desc: "논리적 인라인 시작 테두리 너비를 설정 합니다." },
    { num: 72, name: "border-inline-style", desc: "논리적 인라인 테두리 스타일을 설정 합니다." },
    { num: 73, name: "border-inline-width", desc: "논리적 인라인 테두리 너비를 설정 합니다." },
    { num: 74, name: "border-left", desc: "테두리 왼쪽 너비, 스타일, 색상을 설정 합니다." },
    { num: 75, name: "border-left-color", desc: "요소의 왼쪽 테두리의 색상을 설정합니다." },
    { num: 76, name: "border-left-style", desc: "요소의 왼쪽 테두리의 스타일 속성을 설정합니다." },
    { num: 77, name: "border-left-width", desc: "요소의 왼쪽 테두리의 두께를 설정합니다." },
    { num: 78, name: "border-radius", desc: "요소의 테두리 굴곡을 설정합니다." },
    { num: 79, name: "border-right", desc: "요소의 오른쪽 테두리 속성을 일괄적으로 설정합니다." },
    { num: 80, name: "border-right-color", desc: "요소의 오른쪽 테두리의 색상을 설정합니다." },
    { num: 81, name: "border-right-style", desc: "요소의 오른쪽 테두리의 스타일 속성을 설정합니다." },
    { num: 82, name: "border-right-width", desc: "요소의 오른쪽 테두리의 두께를 설정합니다." },
    { num: 83, name: "border-spacing", desc: "테이블의 테두리 사이의 간격을 설정합니다." },
    { num: 84, name: "border-start-end-radius", desc: "논리적 테두리 반경을 설정 합니다." },
    { num: 85, name: "border-start-start-radius", desc: "논리적 테두리 반경을 설정 합니다." },
    { num: 86, name: "border-style", desc: "요소의 테두리 스타일 속성을 설정합니다." },
    { num: 87, name: "border-top", desc: "요소의 위쪽 테두리 속성을 일괄적으로 설정합니다." },
    { num: 88, name: "border-top-color", desc: "요소의 위쪽 테두리의 색상을 설정합니다." },
    { num: 89, name: "border-top-left-radius", desc: "요소의 위쪽 왼쪽 모서리의 굴곡을 설정합니다" },
    { num: 90, name: "border-top-right-radius", desc: "요소의 위쪽 오른쪽 모서리의 굴곡을 설정합니다." },
    { num: 91, name: "border-top-style", desc: "요소의 위쪽 테두리의 스타일 속성을 설정합니다." },
    { num: 92, name: "border-top-width", desc: "요소의 위쪽 테두리의 두께를 설정합니다." },
    { num: 93, name: "border-width", desc: "요소의 테두리의 두께를 설정합니다." },
    { num: 94, name: "bottom", desc: "요소의 아래쪽에서의 위치를 설정합니다." },
    { num: 95, name: "box-decoration-break", desc: "분할될 때 요소의 조각을 렌더링 하는 방법을 설정 합니다." },
    { num: 96, name: "box-shadow", desc: "박스 그림자 효과를 설정 합니다." },
    { num: 97, name: "box-sizing", desc: "브라우저가 요소의 크기를 어떻게 계산할지를 설정합니다." },
    { num: 98, name: "break-after", desc: "박스 나누기가 작동하는 방식을 설정 합니다. 상자가 없으면 속성이 무시됩니다." },
    { num: 99, name: "break-before", desc: "박스 나누기가 작동하는 방식을 설정 합니다. 상자가 없으면 속성이 무시됩니다." },
    { num: 100, name: "break-inside", desc: "박스 나누기가 작동하는 방식을 설정 합니다. 상자가 없으면 속성이 무시됩니다." },
    { num: 101, name: "caption-side", desc: "테이블 내용을 지정된 쪽에 배치 합니다." },
    { num: 102, name: "caret-color", desc: "삽입 캐럿의 색상을 설정 합니다. 이것은 텍스트 입력 커서라고도 합니다." },
    { num: 103, name: "clear", desc: "float 버그를 제거해줍니다." },
    { num: 104, name: "clip", desc: "요소의 특정 부분만 나오도록 할 수 있습니다." },
    { num: 105, name: "clip-path", desc: "이미지나 요소를 말 그대로 클립(잘라내기)할 수 있는 속성" },
    { num: 106, name: "color", desc: "텍스트의 색상을 설정합니다." },
    { num: 107, name: "color-scheme", desc: "렌더링할 수 있는 색 구성표를 나타냅니다." },
    { num: 108, name: "column-count", desc: "요소의 내용을 지정된 수의 열로 나눕니다." },
    { num: 109, name: "column-fill", desc: "열로 나눌 때 요소의 균형을 이루는 방법을 제어 합니다." },
    { num: 110, name: "column-gap", desc: "열 사이의 간격 크기를 설정 합니다." },
    { num: 111, name: "column-rule", desc: "다중 열 레이아웃에서 열 사이에 그려지는 선의 너비, 스타일 및 색상을 설정 합니다." },
    { num: 112, name: "column-rule-color", desc: "다중 열 레이아웃에서 열 사이에 그려지는 선의 색상을 설정 합니다." },
    { num: 113, name: "column-rule-style", desc: "다중 열 레이아웃에서 열 사이에 그려지는 선의 스타일을 설정 합니다." },
    { num: 114, name: "column-rule-width", desc: "다중 열 레이아웃에서 열 사이에 그려지는 선의 너비를 설정 합니다." },
    { num: 115, name: "column-span", desc: "다단 구성 시 여러 단을 차지하는 요소를 지정하기 위한 속성" },
    { num: 116, name: "column-width", desc: "다중 열 레이아웃에서 이상적인 열 너비를 설정 합니다." },
    { num: 117, name: "columns", desc: "내용을 그릴 때 사용할 열 수와 해당 열의 너비를 설정 합니다." },
    { num: 118, name: "contain", desc: "각 위젯의 내부가 위젯의 경계 상자 외부에서 부작용이 발생하지 않도록 방지하는 데 사용할 수 있으므로 모두 독립적 인 위젯이 많이 포함 된 페이지에서 유용합니다." },
    { num: 119, name: "content", desc: "한 값으로 요약됩니다. contnet 속성으로 추가한 기능은 익명 콘텐츠입니다." },
    { num: 120, name: "content-visibility", desc: "요소가 콘텐츠를 전혀 렌더링하는지 여부를 제어하고 강력한 포함 세트를 강제하여 사용자 에이전트가 필요할 때까지 많은 레이아웃 및 렌더링 작업을 잠재적으로 생략할 수 있습니다." },
    { num: 121, name: "counter-increment", desc: "카운터 값을 주어진 값 만큼 늘리거나 줄 입니다." },
    { num: 122, name: "counter-reset", desc: "카운터를 주어진 값으로 재설정 합니다." },
    { num: 123, name: "counter-set", desc: "카운터를 주어진 값으로 설정 합니다." },
    { num: 124, name: "cursor", desc: "요소 위에 마우스 커서가 올라갔을 때 보여줄 모양을 지정합니다." },
    { num: 125, name: "direction", desc: "텍스트,테이블 열 및 가로 오버프롤의 방향을 설정 합니다." },
    { num: 126, name: "display", desc: "요소를 어떻게 보여줄지를 결정합니다." },
    { num: 127, name: "empty-cells", desc: "보이는 내용이 없는 셀 주위에 테두리와 배경을 표시할지 여부를 설정 합니다." },
    { num: 128, name: "filter", desc: "흐림 효과나 변형 효과를 나타냅니다." },
    { num: 129, name: "flex", desc: "플렉스 아이템이 자신의 컨테이너가 차지하는 공간에 맞추기 위해 크기를 키우거나 줄이는 방법을 설정하는 속성 입니다." },
    { num: 130, name: "flex-basis", desc: "플렉스 초기 기본 크기를 설정 합니다." },
    { num: 131, name: "flex-direction", desc: "아이템이 플렉스 컨테이너 안에 위치되는 방법을 설정 합니다." },
    { num: 132, name: "flex-flow", desc: "플렉스 방향, 포장의 속성을 설정 합니다." },
    { num: 133, name: "flex-grow", desc: "플렉스 아이템 요소가 컨테이너 내부의 정도를 제한합니다." },
    { num: 134, name: "flex-shrink", desc: "플렉스 아이템 요소의 flex-shrink을 설정 합니다." },
    { num: 135, name: "flex-wrap", desc: "플렉스 아이템을 wrap으로 감쌉니다." },
    { num: 136, name: "float", desc: "레이아웃 흐름에서 벗어나 요소의 모서리가 페이지 왼쪽이나 오른쪽에 이동한다." },
    { num: 137, name: "font", desc: "텍스트에 대해 설정 합니다." },
    { num: 138, name: "font-family", desc: "선택한 항목에 우선 순위가 더 높은 글꼴 패밀리 이름을 추가 합니다." },
    { num: 139, name: "font-feature-settings", desc: "다양한 모바일타입 피처를 설정 합니다." },
    { num: 140, name: "font-kerning", desc: "글꼴에 커닝 정보의 사용을 설정 합니다." },
    { num: 141, name: "font-language-override", desc: "서체에서 언어별 글리프의 사용을 제어 합니다." },
    { num: 142, name: "font-optical-sizing", desc: "텍스트 렌더링이 다양한 크기로 보기에 최적화되어 있는지 여부를 설정 합니다." },
    { num: 143, name: "font-size", desc: "폰트 크기를 설정 합니다." },
    { num: 144, name: "font-size-adjust", desc: "현재 글꼴 크기를 기준으로 소문자 크기를 설정 합니다." },
    { num: 145, name: "font-strh", desc: "글꼴에서 일반, 축소 또는 확장된 면을 선택합니다." },
    { num: 146, name: "font-style", desc: "글꼴의 스타일을 설정 합니다." },
    { num: 147, name: "font-synthesis", desc: "브라우저가 굵은 글꼴과 이탤릭 글꼴을 합성하는 것을 허용할지 설정합니다." },
    { num: 148, name: "font-variant", desc: "글꼴에 대한 모든 글꼴 변형을 설정 합니다." },
    { num: 149, name: "font-variant-alternates", desc: "대체 글리프의 사용을 제어합니다." },
    { num: 150, name: "font-variant-caps", desc: "문자에 대한 대체 글리프의 사용을 제어합니다." },
    { num: 151, name: "font-variant-east-asian", desc: "일본어 및 중국어와 같은 동아시아 스크립트에 대한 대체 글리프 사용을 제어합니다." },
    { num: 152, name: "font-variant-ligatures", desc: "텍스트 콘텐츠에 사용되는 합자 및 컨텍스트 형식을 제어합니다." },
    { num: 153, name: "font-variant-numeric", desc: "숫자, 분수 및 서수 마커에 대한 대체 글리프의 사용을 제어합니다." },
    { num: 154, name: "font-variant-position", desc: "위 첨자 또는 아래 첨자로 배치되는 더 작은 대체 글리프의 사용을 제어합니다." },
    { num: 155, name: "font-variation-settings", desc: "변경하려는 특성의 4글자 축 이름을 해당 값과 함께 지정하여 가변 글꼴 특성에 대한 저수준 제어를 제공합니다." },
    { num: 156, name: "font-weight", desc: "글꼴 두께를 설정 합니다." },
    { num: 157, name: "forced-color-adjust", desc: "작성자가 강제 색상 모드에서 특정 요소를 선택할 수 있습니다." },
    { num: 158, name: "gap (grid-gap)", desc: "정과 열 사이의 거리를 설정 합니다." },
    { num: 159, name: "grid", desc: "표 형태의 레이아웃을 만들 수 있는 속성입니다." },
    { num: 160, name: "grid-area", desc: "영역(Area) 이름을 설정합니다." },
    { num: 161, name: "grid-auto-columns", desc: "암시적으로 생성된 그리드 열 트랙 또는 트랙 패턴의 크기를 지정합니다." },
    { num: 162, name: "grid-auto-flow", desc: "자동 배치 알고리즘이 작동하는 방식을 제어하여 자동 배치 항목이 그리드로 흐르는 방식을 정확히 지정 합니다." },
    { num: 163, name: "grid-auto-rows", desc: "암시적으로 생성된 그리드 행 트랙 또는 트랙 패턴의 크기를 지정 합니다." },
    { num: 164, name: "grid-column", desc: "그리드 항목의 크기와 위치를 지정하고 그리드 영역의 인라인 시작 및 인라인 끝 가장자리를 지정합니다." },
    { num: 165, name: "grid-column-end", desc: "그리드 열 내에서 그리드 항목의 끝 위치를 지정하여 그리드 영역의 블록 끝 가장자리를 지정 합니다." },
    { num: 166, name: "grid-column-start", desc: "특정 item을 표시하기 시작할 열을 지정합니다." },
    { num: 167, name: "grid-row", desc: "그리드 열 내에서 그리드 항목의 시작 위치를 지정합니다." },
    { num: 168, name: "grid-row-end", desc: "그리드 행 네에서 그리드 항목의 끝 위치를 지정함으로써 그리드 영역의 인라인 끝 가장자리를 지정합니다." },
    { num: 169, name: "grid-row-start", desc: "그리드 행 내에서 그리드 항목의 시작 위치를 지정함으로써 그리드 영역의 인라인 시작 가장자리를 지정합니다." },
    { num: 170, name: "grid-template", desc: "그리드 열, 행 및 영역을 정의 합니다." },
    { num: 171, name: "grid-template-areas", desc: "명명된 격자 영역을 지정하고 격자에 셀을 설정하고 이름을 할당합니다." },
    { num: 172, name: "grid-template-columns", desc: "그리드 열의 너비를 설정 합니다." },
    { num: 173, name: "grid-template-rows", desc: "그리드 행의 높이를 설정 합니다." },
    { num: 174, name: "hanging-punctuation", desc: "문장 부호가 텍스트 줄의 시작 또는 끝에 매달려야 하는지 여부를 지정합니다." },
    { num: 175, name: "height", desc: "요소의 높이를 설정 합니다." },
    { num: 176, name: "hyphenate-character", desc: "하이픈 나누기 전에 줄 끝에서 사용되는 문자를 설정 합니다." },
    { num: 177, name: "hyphens", desc: "여러 줄에 걸치는 텍스트에서 단어에 붙임표를 추가하는 방식을 설정 합니다." },
    { num: 178, name: "image-orientation", desc: "이미지 방향에 대한 레이아웃 독립적 수정을 지정합니다." },
    { num: 179, name: "image-rendering", desc: "렌더링에 대한 이미지를 제공합니다." },
    { num: 180, name: "image-resolution", desc: "요소에서 사용되는 모든 래스터 이미지의 고유 해상도를 지정합니다." },
    { num: 181, name: "ime-mode", desc: "IME(Input Method Editor)의 상태를 반환하거나 설정합니다." },
    { num: 182, name: "initial-letter", desc: "떨어뜨림, 올리기 및 움푹 들어간 이니셜 문자에 대한 스타일을 설정 합니다." },
    { num: 183, name: "initial-letter-align", desc: "단락 내에서 첫 글자의 정렬을 지정합니다." },
    { num: 184, name: "inline-size", desc: "쓰기 모드에 따라 요소 블록의 가로 또는 세로 크기를 정의합니다." },
    { num: 185, name: "inset", desc: "상하좌우값을 지정해 줄수 있는 css 속성." },
    { num: 186, name: "inset-block", desc: "쓰기 모드, 방향 및 텍스트 방향에 따라 물리적 오프셋에 매핑되는 요소의 논리적 블록 시작 및 끝 오프셋을 정의합니다." },
    { num: 187, name: "inset-block-end", desc: "요소의 쓰기모드, 방향 및 텍스트 방향에 따라 물리적 인세트에 매핑되는 요소의 논리적 블록 끝 오프셋을 정의합니다." },
    { num: 188, name: "inset-block-start", desc: "요소의 쓰기모드, 방향 및 텍스트 방향에 따라 물리적 인세트에 매핑되는 요소의 논리적 블록 시작 오프셋을 정의합니다." },
    { num: 189, name: "inset-inline", desc: "인라인 방향으로 요소의 논리적 시작 및 끝 오프셋을 정의합니다." },
    { num: 190, name: "inset-inline-end", desc: "요소의 쓰기모드,방향 및 텍스트 방향에 따라 물리적 오프셋에 매핑되는 요소의 논리적 인라인 끝 삽입을 정의합니다." },
    { num: 191, name: "inset-inline-start", desc: "요소의 쓰기모드, 방향 및 텍스트 방향에 따라 물리적 오프셋에 매핑되는 요소의 논리적 인라인 시작 삽입을 정의합니다." },
    { num: 192, name: "isolation", desc: "요소가 새로운 쌓임 맥락을 생성해야 하는지 지정합니다." },
    { num: 193, name: "justify-content", desc: "플렉스 컨테이너의 기본 축과 그리드 컨테이너의 인라인 축을 기준으로 아이템들을 정렬 합니다." },
    { num: 194, name: "justify-items", desc: "상자의 모든 항목에 대한 기본값을 정의합니다." },
    { num: 195, name: "justify-self", desc: "적절한 축을 따라 정렬 컨테이너 내부에서 상자가 정렬되는 방식을 설정 합니다." },
    { num: 196, name: "left", desc: "배치된 요소의 수평 위치 지정에 참여합니다." },
    { num: 197, name: "letter-spacing", desc: "글자 사이의 간격을 조절합니다." },
    { num: 198, name: "line-break", desc: "한중일 3개국어의 텍스트 줄을 어디서 바꿀지 지정합니다." },
    { num: 199, name: "line-height", desc: "라인 상자의 높이를 설정합니다. heigh와 값이 같을 경우 가운데정렬" },
    { num: 200, name: "line-height-step", desc: "라인 상자 높이의 단계 단위를 설정 합니다." },
    { num: 201, name: "list-style", desc: "모든 목록 스타일 속성을 설정 합니다." },
    { num: 202, name: "list-style-image", desc: "목록 항목 마커로 사용할 이미지를 설정 합니다." },
    { num: 203, name: "list-style-position", desc: "목록 항목에 대한 상대 위치를 설정 합니다." },
    { num: 204, name: "list-style-type", desc: "목록 항목 요소의 마커를 설정 합니다." },
    { num: 205, name: "margin", desc: "요소 사이의 간격을 설정 합니다." },
    { num: 206, name: "margin-block", desc: "쓰기모드,방향 및 텍스트 방향에 따라 물리적 여백에 매핑되는 요소의 논리적 블록 시작 및 끝 여백을 정의합니다." },
    { num: 207, name: "margin-block-end", desc: "쓰기모드,방향 및 텍스트 방향에 따라 물리적 여백에 매핑되는 요소의 논리적 블록 끝 여백을 정의합니다." },
    { num: 208, name: "margin-block-start", desc: "쓰기모드,방향 및 텍스트 방향에 따라 물리적 여백에 매핑되는 요소의 논리적 블록 시작 여백을 정의합니다." },
    { num: 209, name: "margin-bottom", desc: "아래 여백 영역을 설정 합니다." },
    { num: 210, name: "margin-inline", desc: "쓰기모드,방향 및 텍스트 방향에 따라 물리적 여백에 매핑되는 요소의 논리적 인라인 시작 및 끝 여백을 모두 정의합니다." },
    { num: 211, name: "margin-inline-end", desc: "쓰기모드,방향 및 텍스트 방향에 따라 물리적 여백에 매핑되는 요소의 논리적 인라인 끝 여백을 정의합니다." },
    { num: 212, name: "margin-inline-start", desc: "쓰기모드,방향 및 텍스트 방향에 따라 물리적 여백에 매핑되는 요소의 논리적 인라인 시작 여백을 정의합니다." },
    { num: 213, name: "margin-left", desc: "요소의 왼쪽에 여백 영역을 설정 합니다." },
    { num: 214, name: "margin-right", desc: "요소의 오른쪽 여백 영역을 설정 합니다." },
    { num: 215, name: "margin-top", desc: "요소의 상단 여백 영역을 설정 합니다." },
    { num: 216, name: "margin-trim", desc: "컨테이너가 컨테이너의 가장자리에 인접한 자식의 여백을 트리밍할 수 있습니다." },
    { num: 217, name: "mask", desc: "아이템이 부분적으로만 보여지게 하거나 혹은 완전히 가려서 보여지지 않게 할 수 있는 기능을 가지고 있습니다." },
    { num: 218, name: "mask-border", desc: "요소 테두리의 가장자리를 따라 마스크를 만들 수 있습니다." },
    { num: 219, name: "mask-border-mode", desc: "마스크 테두리에 사용되는 혼합 모드를 지정합니다." },
    { num: 220, name: "mask-border-outset", desc: "요소의 마스크 테두리가 테두리 상자에서 설정되는 거리를 지정합니다." },
    { num: 221, name: "mask-border-repeat", desc: "소스 이미지의 가장자리 영역이 요소의 마스크 테두리 크기에 맞게 조정되는 방식을 설정합니다." },
    { num: 222, name: "mask-border-slice", desc: "이미지 세트를 영역으로 나눕니다." },
    { num: 223, name: "mask-border-source", desc: "요소의 마스크 테두리를 만드는데 사용되는 소스 이미지를 설정 합니다." },
    { num: 224, name: "mask-border-width", desc: "요소의 마스크 테두리 너비를 설정 합니다." },
    { num: 225, name: "mask-clip", desc: "마스크의 영향을 받는 영역을 결정합니다." },
    { num: 226, name: "mask-composite", desc: "현재 마스크 레이어 아래에 마스크 레이어가 있는 합성 작업을 나타냅니다." },
    { num: 227, name: "mask-image", desc: "요소의 마스크 레이어로 사용되는 이미지를 설정 합니다." },
    { num: 228, name: "mask-mode", desc: "정의된 마스크 참조가 광도 또는 알파 마스크로 처리되는지 여부를 설정 합니다." },
    { num: 229, name: "mask-origin", desc: "마스크의 원점을 설정 합니다." },
    { num: 230, name: "mask-position", desc: "정의된 각 마스크 이미지에 대해 설정된 마스크 위치 레이어를 기준으로 초기 위치를 설정합니다." },
    { num: 231, name: "mask-repeat", desc: "마스크 이미지가 반복되는 방식을 설정 합니다." },
    { num: 232, name: "mask-size", desc: "마스크 이미지의 크기를 설정 합니다." },
    { num: 233, name: "mask-type", desc: "SVG 요소가 휘도 또는 알파 마스크로 사용되는지 여부를 설정 합니다." },
    { num: 234, name: "max-block-size", desc: "지정된 대로 쓰기 방향과 반대 방향으로 요소의 최대 크기를 지정합니다." },
    { num: 235, name: "max-height", desc: "요소의 최대 높이를 설정 합니다." },
    { num: 236, name: "max-inline-size", desc: "쓰기 모드에 따라 요소 블록의 가로 또는 세로 최대 크기를 정의합니다." },
    { num: 237, name: "max-width", desc: "요소의 최대 너비를 설정 합니다." },
    { num: 238, name: "min-block-size", desc: "쓰기 모드에 따라 요소 블록의 최소 가로 또는 세로 크기를 정의합니다." },
    { num: 239, name: "min-height", desc: "요소의 최소 높이를 합니다." },
    { num: 240, name: "min-inline-size", desc: "쓰기 모드에 따라 요소 블록의 가로 또는 세로 최소 크기를 정의합니다." },
    { num: 241, name: "min-width", desc: "요소의 최소 너비를 설정 합니다." },
    { num: 242, name: "mix-blend-mode", desc: "배경을 혼합 합니다." },
    { num: 243, name: "object-fit", desc: "img 나 video 요소와 같은 대체 요소의 콘텐츠 크기를 어떤 방식으로 조절해 요소에 맞출 것인지 지정합니다." },
    { num: 244, name: "object-position", desc: "오브젝트 위치를 설정 합니다." },
    { num: 245, name: "offset", desc: "정의된 경로에 따라 요소에 애니메이션을 적용하는데 필요한 모든 속성을 설정 합니다." },
    { num: 246, name: "offset-anchor", desc: "실제로 경로를 따라 움직이는 요소를 따라 이동하는 요소의 상자 내부 지점을 지정합니다." },
    { num: 247, name: "offset-distance", desc: "요소가 배치될 위치를 지정합니다." },
    { num: 248, name: "offset-path", desc: "요소가 따라갈 모션 경로를 지정하고 상위 컨테이너 또는 SVG 좌표 시스템 내에서의 요소의 위치를 정의합니다." },
    { num: 249, name: "offset-postion", desc: "요소가 따라 배치될 때 요소의 위치를 정의합니다." },
    { num: 250, name: "offset-rotate", desc: "요소가 따라 배치될 때 요소의 방향을 정의합니다." },
    { num: 251, name: "opacity", desc: "요소의 투명도를 설정 합니다." },
    { num: 252, name: "order", desc: "플렉스 또는 그리드 컨테이너 안에서 현재 요소의 배치 순서를 지정합니다." },
    { num: 253, name: "orphans", desc: "페이지, 영역 또는 열의 맨 아래에 표시되어야 하는 블록 컨테이너 최소 줄 수를 설정 합니다." },
    { num: 254, name: "outline", desc: "요소의 윤곽선을 설정 합니다." },
    { num: 255, name: "outline-color", desc: "요소의 윤곽선 색상을 설정 합니다." },
    { num: 256, name: "outline-offset", desc: "윤곽선과 요소의 가장자리 또는 테두리 사이의 간격을 설정 합니다." },
    { num: 257, name: "outline-style", desc: "윤곽선의 스타일을 설정 합니다." },
    { num: 258, name: "outline-width", desc: "윤곽선의 두께를 설정 합니다." },
    { num: 259, name: "overflow", desc: "내용이 박스보다 큰 경우 넘친 부분에 대해 설정 합니다." },
    { num: 260, name: "overflow-anchor", desc: "콘텐츠 이동을 최소화하기 위해 스크롤 위치를 조정하는 브라우저의 스크롤 고정 동작을 옵트아웃하는 방법을 제공합니다." },
    { num: 261, name: "overflow-block", desc: "콘텐츠가 상자의 블록 시작 및 블록 끝 가장자리를 오버플로할 때 표시되는 내용을 설정합니다." },
    { num: 262, name: "overflow-clip-margin", desc: "클리핑되기 전에 요소가 경계를 벗어나 얼마나 멀리 칠할 수 있는지를 결정합니다." },
    { num: 263, name: "overflow-inline", desc: "콘텐츠가 상자의 인라인 시작 및 끝 가장자리를 오버플로할 때 표시되는 내용을 설정합니다." },
    { num: 264, name: "overflow-wrap", desc: "줄바꿈 위해 단어 쪼개기" },
    { num: 265, name: "overflow-x", desc: "콘텐츠가 블록 수준 요소의 왼쪽 및 오른쪽 가장자리를 오버플로할 때 표시되는 내용을 설정합니다." },
    { num: 266, name: "overflow-y", desc: "콘텐츠가 블록 수준 요소의 위쪽 및 아래쪽 가장자리를 오버플로할 때 표시되는 내용을 설정합니다." },
    { num: 267, name: "overscroll-behavior", desc: "스크롤 영역의 경계에 도달할 때 브라우저가 수행하는 작업을 설정합니다." },
    { num: 268, name: "overscroll-behavior-block", desc: "스크롤 영역의 블록 방향 경계에 도달할 때 브라우저의 동작을 설정합니다." },
    { num: 269, name: "overscroll-behavior-inline", desc: "스크롤 영역의 인라인 방향 경계에 도달할 때 브라우저의 동작을 설정합니다." },
    { num: 270, name: "overscroll-behavior-x", desc: "스크롤 영역의 수평 경계에 도달할 때 브라우저의 동작을 설정합니다." },
    { num: 271, name: "overscroll-behavior-y", desc: "스크롤 영역의 수직 경계에 도달할 때 브라우저의 동작을 설정합니다." },
    { num: 272, name: "padding", desc: "속성의 네 방향 여백을 설정 합니다." },
    { num: 273, name: "padding-block-end", desc: "요소의 쓰기모드, 방향 및 텍스트 방향에 따라 물리적 패딩에 매핑되는 요소의 논리적 블록 끝 패딩을 정의합니다." },
    { num: 274, name: "padding-block-start", desc: "요소의 쓰기모드, 방향 및 텍스트 방향에 따라 물리적 패딩에 매핑되는 요소의 논리적 블록 시작 패딩을 정의합니다." },
    { num: 275, name: "padding-bottom", desc: "요소 내부의 아래쪽 여백을 설정 합니다." },
    { num: 276, name: "padding-inline-end", desc: "요소의 쓰기모드,방향 및 텍스트 방향에 따라 물리적 패딩에 매핑되는 요소의 논리적 인라인 끝 패딩을 정의합니다." },
    { num: 277, name: "padding-inline-start", desc: "요소의 쓰기모드,방향 및 텍스트 방향에 따라 물리적 패딩에 매핑되는 요소의 논리적 인라인 시작 패딩을 정의합니다." },
    { num: 278, name: "padding-left", desc: "요소의 왼쪽 여백을 설정 합니다." },
    { num: 279, name: "padding-right", desc: "요소의 오른쪽 여백을 설정 합니다." },
    { num: 280, name: "padding-top", desc: "요소의 상단 여백을 설정 합니다." },
    { num: 281, name: "page-break-after", desc: "페이지 인쇄시 분리에 관한 설정을 정의합니다." },
    { num: 282, name: "page-break-before", desc: "프린터로 출력할 때 다음 페이지로 페이지를 넘기는 것을 지정하는 Property입니다." },
    { num: 283, name: "page-break-inside", desc: "인쇄시 페이지 분리에 관한 설정을 정의합니다." },
    { num: 284, name: "perspective", desc: "3D 위치 요소에 약간의 원근감을 주기 위해 z=0 평면과 사용자 사이의 거리를 결정합니다." },
    { num: 285, name: "perspective-origin", desc: "뷰어가 보고 있는 위치를 결정합니다." },
    { num: 286, name: "place-content", desc: "그리드나 플렉스 레이아웃에서 블록 및 인라인 방향을 따라 콘텐츠를 한 번에 정렬할 수 있습니다." },
    { num: 287, name: "place-items", desc: "그리드나 플렉스 레이아웃에서 블록 및 인라인 방향을 따라 항목을 한 번에 정렬할 수 있습니다." },
    { num: 288, name: "place-self", desc: "그리드나 플렉스 레이아웃에서 블록 및 인라인 방향으로 개별 항목을 한 번에 정리할 수 있습니다." },
    { num: 289, name: "pointer-event", desc: "HTML 요소들의 마우스/터치 이벤트들(CSS hover/active, JS click/tap, 커서 드래그등)의 응답을 조정할 수 있는 속성이다." },
    { num: 290, name: "position", desc: "속성이 배치될 최종 위치를 결정합니다." },
    { num: 291, name: "print-color-adjust", desc: "출력 장치에서 요소의 모양을 최적화하기 위해 사용자 에이전트가 수행할 수 있는 작업을 설정합니다." },
    { num: 292, name: "quotes", desc: "속성 또는 값을 사용하여 추가된 따옴표를 브라우저에서 렌더링하는 방법을 설정 합니다." },
    { num: 293, name: "resize", desc: "요소의 크기를 조정할 수 있는지 여부와 가능한 경우 방향을 설정 합니다." },
    { num: 294, name: "right", desc: "배치된 요소의 수평 위치 지정에 참여합니다." },
    { num: 295, name: "rotate", desc: "속성과 별도로 회전 변환을 지정할 수 있습니다." },
    { num: 296, name: "row-gap (grid-row-gap)", desc: "요소 행 사이의 간격을 설정 합니다." },
    { num: 297, name: "ruby-align", desc: "베이스에 대한 다양한 루비 요소의 분포를 정의합니다." },
    { num: 298, name: "ruby-position", desc: "기본 요소를 기준으로 루비 요소의 위치를 정의합니다." },
    { num: 299, name: "scale", desc: "속성과 별개로 스케일 변환을 개별적으로 지정할 수 있습니다." },
    { num: 300, name: "scroll-behavior", desc: "스크롤이 탐색 또는 CSSOM 스크롤 API에 의해 트리거될 때 스크롤 상자의 동작을 설정합니다." },
    { num: 301, name: "scroll-margin", desc: "요소의 모든 스크롤 여백을 한 번에 설정하여 속성이 요소의 여백에 대해 수행하는 것과 유사한 값을 할당합니다." },
    { num: 302, name: "scroll-margin-block", desc: "블록 차원에서 요소의 스크롤 여백을 설정 합니다." },
    { num: 303, name: "scroll-margin-block-end", desc: "상자를 스냅포트에 맞추는 데 사용되는 블록 치수 끝에서 스크롤 스냅 영역의 여백을 정의합니다." },
    { num: 304, name: "scroll-margin-block-start", desc: "상자를 스냅포트에 맞추는 데 사용되는 블록 차원의 시작 부분에서 스크롤 스냅 영역의 여백을 정의합니다." },
    { num: 305, name: "scroll-margin-bottom", desc: "상자를 snapport에 맞추는 데 사용되는 스크롤 스냅 영역의 아래쪽 여백을 정의합니다." },
    { num: 306, name: "scroll-margin-inline", desc: "인라인 차원에서 요소의 스크롤 여백을 설정합니다." },
    { num: 307, name: "scroll-margin-inline-end", desc: "상자를 snapport에 맞추는 데 사용되는 인라인 차원의 끝에서 스크롤 스냅 영역의 여백을 정의합니다." },
    { num: 308, name: "scroll-margin-inline-start", desc: "상자를 snapport에 맞추는 데 사용되는 인라인 차원의 시작부분에서 스크롤 스냅 영역의 여백을 정의합니다." },
    { num: 309, name: "scroll-margin-left", desc: "상자를 snapport에 맞추는 데 사용되는 스크롤 스냅 영역의 왼쪽 여백을 정의합니다." },
    { num: 310, name: "scroll-margin-right", desc: "상자를 snapport에 맞추는 데 사용되는 스크롤 스냅 영역의 오른쪽 여백을 정의합니다." },
    { num: 311, name: "scroll-margin-top", desc: "상자를 snapport에 맞추는 데 사용되는 스크롤 스냅 영역의 위쪽 여백을 정의합니다." },
    { num: 312, name: "scroll-padding", desc: "요소의 모든 면에 스크롤 패딩을 한 번에 설정 합니다." },
    { num: 313, name: "scroll-padding-block", desc: "블록 차원에서 요소의 스크롤 패딩을 설정 합니다." },
    { num: 314, name: "scroll-padding-block-end", desc: "스크롤포트의 최적보기 영역의 블록 차원에서 끝 가장자리에 대한 오프셋을 정의합니다." },
    { num: 315, name: "scroll-padding-block-start", desc: "스크롤 포트의 최적보기 영역의 블록 차원에서 시작 가장자리에 대한 오프셋을 정의합니다." },
    { num: 316, name: "scroll-padding-bottom", desc: "스크롤포트의 최적 보기영역 하단에 대한 오프셋을 정의합니다." },
    { num: 317, name: "scroll-padding-inline", desc: "인라인 차원에서 요소의 스크롤 패딩을 설정 합니다." },
    { num: 318, name: "scroll-padding-inline-end", desc: "스크롤 포트의 최적보기 영역의 인라인 차원에서 끝 가장자리에 대한 오프셋을 정의합니다." },
    { num: 319, name: "scroll-padding-inline-start", desc: "스크롤 포트의 최적보기 영역의 인라인 차원에서 시작 가장자리에 대한 오프셋을 정의합니다." },
    { num: 320, name: "scroll-padding-left", desc: "스크롤 포트의 최적 보기영역 왼쪽에 대한 오프셋을 정의합니다." },
    { num: 321, name: "scroll-padding-right", desc: "스크롤 포트의 최적 보기영역 오른쪽에 대한 오프셋을 정의합니다." },
    { num: 322, name: "scroll-padding-top", desc: "스크롤 포트의 최적 보기영역 상단에 대한 오프셋을 정의합니다." },
    { num: 323, name: "scroll-snap-align", desc: "상자의 스냅 위치를 해당 스냅 컨테이너의 스냅포트 내에서 해당 스냅영역의 정렬로 지정합니다." },
    { num: 324, name: "scroll-snap-coordinate", desc: "x" },
    { num: 325, name: "scroll-snap-destination", desc: "x" },
    { num: 326, name: "scroll-snap-points-x", desc: "x" },
    { num: 327, name: "scroll-snap-points-y", desc: "x" },
    { num: 328, name: "scroll-snap-stop", desc: "스크롤 컨테이너가 가능한 스냅 위치를 통과할 수 있는지 여부를 정의합니다." },
    { num: 329, name: "scroll-snap-type", desc: "스냅 포인트가 있는 경우 스크롤 컨테이너에 스냅 포인트가 얼마나 엄격하게 적용되는지 설정합니다." },
    { num: 330, name: "scrollbar-color", desc: "스크롤바 트랙과 썸의 색상을 설정 합니다." },
    { num: 331, name: "scrollbar-width", desc: "작성자가 표시될 때 요소의 스크롤 막대의 최대 두께를 설정합니다." },
    { num: 332, name: "shape-image-threshold", desc: "이미지를 값으로 사용하여 모양을 추출하는 데 사용되는 알파 채널 임계값을 설정합니다." },
    { num: 333, name: "shape-margin", desc: "CSS 모양의 여백을 설정 합니다." },
    { num: 334, name: "shape-outside", desc: "인접한 인라인 콘텐츠가 둘러싸야 하는 사각형이 아닐 수 있는 모양을 정의합니다." },
    { num: 335, name: "tab-size", desc: "탭 문자(+ 0009 U)의 폭을 지정하는 데 사용합니다." },
    { num: 336, name: "table-layout", desc: "셀,행 및 열 배치하는데 사용되는 알고리즘을 설정 합니다." },
    { num: 337, name: "text-align ", desc: "블럭 안 요소의 정렬을 설정 합니다." },
    { num: 338, name: "text-align-last", desc: "강제 줄 바꿈 직전의 블록이나 줄의 마지막 줄을 정렬하는 방법을 설정합니다." },
    { num: 339, name: "text-combine-upright ", desc: "문자 조합을 단일 문자 공간으로 설정합니다." },
    { num: 340, name: "text-decoration", desc: "텍스트에 꾸밈 요소를 설정 합니다." },
    { num: 341, name: "text-decoration-color", desc: "텍스트에 추가되는 장식의 색상을 설정 합니다." },
    { num: 342, name: "text-decoration-line", desc: "밑줄이나 윗줄과 같이 요소의 텍스트에 사용되는 장식의 종류를 설정 합니다." },
    { num: 343, name: "text-decoration-skip", desc: "요소에 영향을 미치는 텍스트 장식이 건너뛰어야 하는 요소 콘텐츠의 부분을 설정합니다." },
    { num: 344, name: "text-decoration-skip-ink", desc: "윗줄과 밑줄이 글리프 어센더 및 디센더를 전달할 때 그려지는 방법을 지정합니다." },
    { num: 345, name: "text-decoration-style", desc: "지정된 선의 스타일을 설정 합니다." },
    { num: 346, name: "text-emphasis", desc: "텍스트에 강조 표시를 적용합니다." },
    { num: 347, name: "text-emphasis-color", desc: "강조 표시의 색상을 설정 합니다." },
    { num: 348, name: "text-emphasis-position", desc: "루비 텍스트와 마찬가지로 강조 표시를 위한 공간이 충분하지 않으면 줄 높이가 높아집니다." },
    { num: 349, name: "text-emphasis-style", desc: "강조 표시의 모양을 설정합니다." },
    { num: 350, name: "text-indent", desc: "블록의 텍스트 줄 앞에 배치되는 빈 공간의 길이를 설정 합니다." },
    { num: 351, name: "text-justify", desc: "텍스트에 적용해야 하는 맞춤 유형을 설정 합니다." },
    { num: 352, name: "text-orientation", desc: "줄에서 텍스트 문자의 방향을 설정 합니다." },
    { num: 353, name: "text-overflow", desc: "숨겨진 오버플로 콘텐츠가 사용자에게 신호되는 방식을 설정합니다." },
    { num: 354, name: "text-rendering", desc: "텍스트를 렌더링할 때 최적화할 대상에 대한 정보를 렌더링 엔진에게 제공합니다." },
    { num: 355, name: "text-shadow", desc: "그림자를 추가합니다." },
    { num: 356, name: "text-size-adjust", desc: "일부 스마트폰 및 태블릿에서 사용되는 텍스트 인플레이션 알고리즘을 제어합니다." },
    { num: 357, name: "text-transform", desc: "요소의 텍스트를 대문자로 표시하는 방법을 지정합니다." },
    { num: 358, name: "text-underline-position", desc: "속성 값을 사용하여 설정되는 밑줄의 위치를 지정합니다." },
    { num: 359, name: "top", desc: "태그 위치를 상단 기준으로 어느 높이에 위치시킬건지 설정합니다." },
    { num: 360, name: "touch-action", desc: "터치스크린 사용자가 요소의 영역을 조작하는 방법을 설정합니다." },
    { num: 361, name: "transform", desc: "요소에 회전, 크기조절, 기울이기, 이동 효과를 부여할 수 있습니다." },
    { num: 362, name: "transform-box", desc: "속성이 관련된 레이아웃 상자를 정의합니다." },
    { num: 363, name: "transform-origin", desc: "요소 변형의 원점을 설정합니다." },
    { num: 364, name: "transform-style", desc: "요소의 자식이 3D 공간에 배치되는지 또는 요소 평면에서 병합 되는지 여부를 설정합니다." },
    { num: 365, name: "transition", desc: "애니메이션 효과의 속도를 조절하는 방법을 제공합니다." },
    { num: 366, name: "transition-delay", desc: "전환(transition) 효과가 나타나기 전까지의 지연 시간을 설정합니다." },
    { num: 367, name: "transition-duration", desc: "전환(transition) 효과가 지속될 시간을 설정함." },
    { num: 368, name: "transition-property", desc: "전환 효과를 적용할 CSS 속성을 설정 합니다." },
    { num: 369, name: "transition-timing-function", desc: "전환 효과의 영향을 받는 CSS 속성에 대해 중간 값이 계산되는 방식을 설정합니다." },
    { num: 370, name: "translate", desc: "속성과 별개로 개별적으로 변환을 지정할 수 있습니다." },
    { num: 371, name: "unicode-bidi", desc: "속성과 함께 문서의 양방향 텍스트가 처리되는 방식을 결정합니다." },
    { num: 372, name: "user-select", desc: "text 텍스트를 선택할 수 있습니다. element 텍스트를 선택할 수 있지만 요소 범위로 제한됩니다." },
    { num: 373, name: "vertical-align", desc: "inline 또는 table-cell box에서의 수직 정렬을 지정합니다." },
    { num: 374, name: "visibility", desc: "태그의 가시성을 결정합니다." },
    { num: 375, name: "white-space", desc: "요소의 공백을 어떻게 처리할 지를 정의합니다." },
    { num: 376, name: "widows", desc: "페이지, 영역 또는 열의 상단에 표시되어야 하는 블록 컨테이너의 최소 줄 수를 설정합니다." },
    { num: 377, name: "width", desc: "요소의 너비를 설정 합니다." },
    { num: 378, name: "will-change", desc: "요소에 예상되는 변화의 종류에 관한 힌트를 브라우저에게 제공하게 합니다." },
    { num: 379, name: "word-break", desc: "텍스트들을 줄을 바꾸면서 표시해야 할때 텍스트를 어떤식으로 줄바꿈 해줄지 정하는 속성." },
    { num: 380, name: "word-spacing", desc: "신약과 사이에, 태그와 사이의 거리를 설정합니다." },
    { num: 381, name: "writing-mode", desc: "텍스트 줄을 가로 또는 세로로 배치할지 여부와 블록이 진행되는 방향을 설정합니다." },
    { num: 382, name: "z-index", desc: "요소들의 수직 위치를 설정합니다." }
];
SCRIPT CODE
const searchTime = document.querySelector(".time span");
    const searchList = document.querySelector(".search__list");
    const searchNum = document.querySelector(".search__info2 .num")
    const searchTotal = document.querySelector(".search__info2 .total")
    const searchAnswers = document.querySelector(".search__answers");
    const searchMissAnswers = document.querySelector(".search__missAnswers");
    const searchStart = document.querySelector(".search__box .start");
    const searchInput = document.querySelector("#search");
    const searchAudio = document.querySelector("#audio");
    const searchPlay = document.querySelector(".search__audio .play");
    const searchStop = document.querySelector(".search__audio .stop");
    const searchResult = document.querySelector(".search__result .result");
    const searchResultWrap = document.querySelector(".search__result");
    const searchRestart = document.querySelector(".search__result .restart");

    searchNum.innerText = cssProperty.length   // 전체 갯수 구하기
    
    let timeReamining = 120,    // 남은 시간
        timeInterval = "",      // 시간 간격
        score = 0,              // 점수
        answers = {};           // 새로운 정답

    function updateList() {
        cssProperty.forEach(data => {
            searchList.innerHTML += `${data.name}`;
        });
    }
    updateList();

    // 게임 시작하기
    function startQuiz() {
        
        // 시작 버튼 없애기 & 속성 리스트 없애기
        searchStart.style.display = "none";
        searchList.style.display = "none";

        // 다시 시작할 때 기존 데이터 초기화
        searchAnswers.innerHTML = "";
        searchMissAnswers.innerHTML = "";

        // 시간 설정
        timeInterval = setInterval(reduceTime, 1000);

        // 뮤직 추가하기
        searchAudio.play();

        // 점수 계산
        searchNum.textContent = cssProperty.length;

        // 정답 체크
        checkAnswers();
    }

    // 음악 설정
    function musicStop() {
        searchStop.addEventListener("click", () => {
            searchAudio.pause();
        });
    };
    musicStop();

    function musicPlay() {
        searchPlay.addEventListener("click", () => {
            searchAudio.play();
        });
    };
    musicPlay();

    // 인풋 체크하기
    function checkInput() {
        let input = event.currentTarget.value.trim().toLowerCase();

        if(answers.hasOwnProperty(input) && !answers[input]) {
            answers[input] = true;

            // 정답 표시
            searchAnswers.style.display = "block";
            searchAnswers.innerHTML += `${input}`;

            // 점수 반영
            score++;
            searchTotal.innerHTML = `${score}`

            // 정답 초기화
            searchInput.value = "";
        }
    }

    // 정답 체크하기
    function checkAnswers() {
        cssProperty.forEach(item => {
            let answer = item.name.trim().toLocaleLowerCase();
            answers[answer] = false;
        });
        // console.log(answers);
    }

    function missAnswers() {
        searchMissAnswers.style.display = "block";

        cssProperty.forEach(item => {
            let answer = item.name.trim().toLocaleLowerCase();
            if(!answer[answer]) {
                searchMissAnswers.innerHTML += `${answer}`;
            }
        });
    }

    // 시간 설정하기
    function reduceTime() {
        timeReamining--;

        if(timeReamining == 0 ) endQuiz();

        searchTime.innerText = displayTime();
    }

    // 시간 표시하기
    function displayTime() {
        if(timeReamining <= 0) {
            return "0:00";
        } else {
            let minutes = Math.floor(timeReamining / 60);
            let seconds = timeReamining % 60;

            // 초 단위가 한 자리 일 때 0을 추가
            if(seconds < 10 ) seconds = "0" + seconds;
            return minutes + ":" + seconds;
         }
    }

    // 게임 끝났을 때
    function endQuiz() {
        // alert("게임 끝");

        // 시작 버튼 만들기
        searchStart.style.display = "block";
        searchStart.style.pointerEvents = "none";

        // 오답 보여주기
        missAnswers();

        // 음악 끄기
        searchAudio.pause();

        // 시간 정지
        clearInterval(timeInterval);

        // 메세지 출력
        searchResultWrap.classList.add("show");
        let point = Math.round(score/cssProperty.length * 100);
        searchResult.innerHTML = `게임 끝
총 갯수 ${cssProperty.length} 중 당신이 맞힌 갯수는 ${score}개,
맞춘 비율은 ${point}%입니다.`; } // 다시 시작하기 function restart() { searchResultWrap.classList.remove("show"); timeReamining = 120; score = 0; searchTotal.innerText = "0"; searchPlay.classList.add("playing"); searchAudio.play() startQuiz(); } // 버튼 이벤트 searchStart.addEventListener("click", startQuiz); searchInput.addEventListener("input", checkInput); searchRestart.addEventListener("click", restart);


RESULT

댓글


INFORMATION

javascript

css

html