.siteA{ display: block; padding: 14px 15px; line-height: 1; text-decoration: none; border: 1px solid #e4eaec; position: relative; border-radius: 5px; color: #76838f; } .siteAyi{ position: absolute; top: 50%; left: 10px; transform: translateY(-50%); display: flex; flex-flow: column; } .siteAyi p{ line-height: 0.3; width: 0.5; } .siteA a{ text-indent: 30px; display: block; color: #76838f; } .siteA:hover a{ color: #62a8ea; } .siteA:hover .siteAyi{ color: #62a8ea; } .mapul{ position: relative; padding: 10px 10px 20px 40px; margin: 0; list-style-type: none; } .mapul::before{ position: absolute; top: 0; left: 20px; width: 1px; height: 100%; content: " "; background: #e4eaec; } .mapli{ position: relative; display: block; min-width: 220px; padding: 10px; margin-bottom: 5px; line-height: 1; text-decoration: none; border: 1px solid #e4eaec; } .mapli a{ color: #76838f; } .mapli:hover a{ color: #62a8ea; } .mapli::before{ left: -20px; width: 20px; height: 1px; margin-top: -1px; position: absolute; top: 50%; content: " "; background: #e4eaec; } .mapli::after{ left: -23px; width: 5px; height: 5px; margin-top: -3px; -webkit-border-radius: 50%; -moz-border-radius: 50%; -o-border-radius: 50%; -ms-border-radius: 50%; border-radius: 50%; position: absolute; top: 50%; content: " "; background: #e4eaec; }