#wrap {z-index: 5;}

/* section */
section { padding: 5vw 0 ; }
section >* { z-index: 3; }
section .title_box {padding-bottom: 3vw;font-size: 40px;line-height: 1.5;font-weight: 500;}
section .emtit {font-size: 40px;font-style: unset;font-family: "Anybody", sans-serif;font-weight: 700;color: #d2d7de;display: block;text-transform: uppercase;line-height: 1.5;}
section .clip { margin: auto; width: 100%; }
section .clip img { height: 100%; }
section .clip iframe { width: 100%; height: 100%; top: 0; left: 0; }
section .clip video { width: auto; height: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); }

/* contact_area */
#contact_area{margin-top: -114px;padding: 0;}
#contact_area .workframe{width: calc(70% - 60px);display: grid;grid-template-columns: repeat(5, 1fr);}
#contact_area .box{background: var(--complement);padding: 30px 30px;display: grid;grid-template-columns: 40px 1fr;gap: 20px;align-items: center;}
#contact_area .box:nth-child(2){background: var(--triadic1);}
#contact_area .box:nth-child(3){background: var(--primary);}
#contact_area .box:hover{transform: translateY(-15px);}
#contact_area .box *{color:white;fill:white;font-weight: 500;}
#contact_area .box a{width:100%;height: 100%;z-index: 2;top: 0;}
#contact_area .box svg{width: 40px;height: 40px;}

/* product_sub_list */
#product_sub_list >div { margin: auto; width: 100%; }
#product_sub_list li {width: 210px;display: block;}
#product_sub_list li .clip { height: 210px; -webkit-clip-path: url(#clip_sub_product); clip-path: url(#clip_sub_product); }
#product_sub_list li h3 { font-weight: 300; }

/* product_list */
#product_list { width: 600px; }
#product_list li .clip { height: 690px; -webkit-clip-path: url(#clip_product); clip-path: url(#clip_product); }
#product_list li .info_box { width: 367px; height: 228px; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 367 228'%3E%3Cpath d='M367.78 126C374 16.84 244.78 11.74 169 1.62c-30.92-4.22-65.18-.49-89.25 18.28-10.07 8.27-21.49 9.51-30.69 14.7-10.8 7-24 26.55-31.88 38.77-20.79 30.78-25.12 73.93 3.58 101.93 42.82 40.82 125.08 59.41 182.75 51.15 18.44-2.61 31-8 48.42-10.85 17.13-1.86 30.89-3.56 48.43-10.85 33.48-12.81 54.43-40.22 67.42-78.75z' fill='%23f4ece5'/%3E%3C/svg%3E") no-repeat center / 100%; bottom: 0; left: 0; }
#product_list li .info_box >div { margin: auto; width: 80%; }
#product_list li .info_box h3 { height: auto; font-size: 20px; }
#product_list li .info_box p { margin-right: 10px; font-weight: 300; }
#product_list li .info_box p:first-letter { margin-right: 2px; font-size: 12px; }

/* about_area */
#about_area {padding-top:8vw}
#about_area .workframe{display:grid;grid-template-columns: 55% 35%;align-items: center;justify-content: space-between;}
#about_area .title_box { padding-bottom: 0; }
#about_area .pageh1{font-size: 40px;line-height: 1.5;font-weight: 500;}
#about_area article p{margin-bottom: 70px;line-height: 2.2;text-align: justify;margin-top: 40px;}
#about_area #about_img{box-shadow: 30px 30px var(--secondary);order: -1;}
#about_area #about_img img{aspect-ratio: 1/1;object-position: 15% 50%;}

/* custom_area */
#custom_area  {background-image: url(/images/44/road-foggy-weather.jpg);background-repeat: no-repeat;background-position: 50% 50%;background-size: cover;position: relative;}
#custom_area:after{content:'';position: absolute;width: 100%;height: 100%;background: linear-gradient(180deg, rgb(239 239 243 / 75%), rgb(239 239 243 / 10%));z-index: 1;top: 0;}
#custom_area *{text-align:center;}
#custom_area p{font-size: 18px;letter-spacing: 1px;line-height: 2.2;padding: 0 5%;}
#custom_area .workframe {position:relative;width: min(90%, 1200px);}
#custom_area ul {display:grid;grid-template-columns: repeat(5, 1fr);margin: 50px 0 70px;gap: 30px;}
#custom_area ul li{display:flex;flex-direction: column;align-items: center;background:white;padding: 40px 30px;border-radius: 5px;border: 1px solid #d2d2d2;}
#custom_area ul li .clip{width: 75%;margin-bottom: 20px;}
#custom_area ul li span{width: 66%;position: absolute;top: 0;height: 4px;background: var(--complement);}
#custom_area ul li .h3 {margin: 15px 0 0;font-size: 17px;color: var(--info);}

/* news_area */
#news_area{padding-top:3vw}
#news_area .workframe{width: min(90%, 1200px);display: grid;grid-template-columns: 40% 60%;align-items: center;}
#news_area li {padding: 45px 35px;border-bottom: 1px solid var(--primary);}
#news_area li:hover{background: #e4ecf0;border-color: transparent;border-radius: 20px;}
#news_area li .info_box {display: grid;grid-template-columns: 80px 1fr;gap: 40px;align-items: center;}
#news_area li .time {display: flex;font-weight: 400;font-size: 15px;flex-direction: column;align-items: center;font-family: "Anybody", sans-serif;}
#news_area li .time b{font-family: "Anybody", sans-serif;font-size: 35px;}
#news_area li .more_btn { margin-left: 10px; padding: 2px 15px; max-width: calc(100% - 105px); height: 22px; font-weight: 100; font-size: 13px; z-index: 6; }
#news_area li .h3 {margin-top: 10px;height: auto;line-height: 150%;font-size: 20px;-webkit-line-clamp: 1;}

/* book_area */
#book_area li h3 { margin-top: 10px; height: 30px; font-size: 18px; }

/* photo_area */
#photo_area{ background: linear-gradient(90deg, var(--primary), var(--secondary));}
#photo_area .emtit{color: var(--info);}
#photo_area .item {margin:0 15px;position: relative;}
#photo_area .item a{width:100%;height: 100%;z-index: 2;}
#photo_area .item img {aspect-ratio:4/3;object-fit: cover;}
#photo_area .infoo{padding: 15px 5%;bottom:0;background: rgb(51 51 51 / 75%);width: 90%;display: flex;align-items: center;justify-content: space-between;}
#photo_area .infoo .h3{color:white;font-size: 17px;height: auto;}
#photo_area .infoo svg{fill:white}
#photo_area .item:hover .infoo svg{transform:translateX(5px);}

@media screen and (max-width: 1680px) {
    #contact_area .workframe{grid-template-columns: repeat(4, 1fr);}
}
@media screen and (max-width: 1460px) {
	#about_area .about_sub_1 , #about_area .about_sub_2 , #about_area .about_sub_3 { width: 20vw; }
	#product_list { width: 500px; margin-left: 30px; }
	#product_list li .clip { height: 590px; }
	#about_area .about_sub_2 { top: -20vw; right: 6vw; }
}
@media screen and (max-width: 1280px) {
    #about_area .pageh1, section .title_box{font-size: 30px;}
    #contact_area .workframe{width: calc(90% - 60px);}
}
@media screen and (max-width: 1024px) {
    #contact_area .workframe{grid-template-columns: repeat(3, 1fr);}
    #contact_area{margin-top: -64px;}
	#product_list { margin: auto; }
	#news_area li h3 { height: 30px; -webkit-line-clamp: 1; }
}
@media screen and (max-width: 980px) {
    #news_area .workframe{grid-template-columns:1fr;gap: 20px;}
    #custom_area ul{grid-template-columns: repeat(3, 1fr);}
    #about_area .workframe{grid-template-columns:1fr;gap: 80px;}
    #contact_area{margin:0}
    #contact_area .workframe{width: 100%;}
    section .emtit{font-size: 50px;}
    section { padding: 10vw 0; }
	#product_list { width: 500px; }
	#product_list li .clip { height: 590px; }
	#about_area #about_info { margin-bottom: 8vw; }
	#about_area .about_sub_2 { top: auto; bottom: 35vw; width: 35vw; }
	#about_area .about_sub_3 { width: 29vw; left: 10vw; }
}
@media screen and (max-width: 760px) {
	section .clip img{height: auto;}
    #news_area li{padding: 35px 15px;}
    section, #news_area, #about_area {padding: 60px 0;}
    section .title_box{margin-bottom:5vw}
    #custom_area ul{gap: 15px;display: flex;flex-wrap: wrap;justify-content: center;}
    #custom_area ul li{width: calc(50% - 70px);}
    #custom_area p{font-size:16px;padding: 0;}
    section .emtit{font-size: 40px;}
    #contact_area .workframe{grid-template-columns: 1fr;}
	#product_sub_list>div { margin: 10px auto 50px; }
	#product_sub_list li { width: 150px; }
	#product_sub_list li .clip { height: 150px; }
	#product_list { width: 70vw; }
	#product_list li .clip { height: 80vw; }
	#product_list li .info_box { width: 45vw; height: 30vw; }
}
@media screen and (max-width: 550px) {
	#product_sub_list li { margin: 10px; width: 35vw; }
	#product_sub_list li .clip { height: 35vw; }
	#product_list { width: 90vw; }
	#product_list li .clip { height: 100vw; }
	#product_list li .info_box { width: 55vw; height: 40vw; }
	#about_area #about_img { width: 80vw; }
	#about_area .about_sub_2 { bottom: 60vw; }
	#news_area li .row { margin: auto; width: 280px; }
}
@media screen and (max-width: 480px) {
	#book_area li.row { margin: auto; width: 250px; }
}