.contact {
    width: 100%;
    height: 100%;
    z-index: 3;
    }
    .contact .form_contact {
    width: 80%;
  max-width: 1150px;
    height: 100%;
    margin: 0 auto;
    position: relative;
    z-index: 3;
    margin-top: 60px;
    margin-bottom: 24px;
    padding-bottom: 50px;
    }
    .contact .form_contact form {
    background-color: #ffffff;
    -webkit-box-shadow: 0 10px 30px 0 rgb(191 191 191 / 30%);
    box-shadow: 0 10px 30px 0 rgb(191 191 191 / 30%);
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
    -ms-border-radius: 40px;
    -o-border-radius: 40px;
    margin-bottom: 24px;
    position: relative;
    }
    .contact .form_contact .contact_form_in {
    max-width: 720px;
  margin: 0 auto;
  padding: 50px 0;
    
    }
    .contact .form_contact .contact_form_in .input-group {
    position: relative;
    margin-bottom: 30px;
    }
    .contact .form_contact .contact_form_in .input-group label {
      color: #666;
      display: inline-block;
    margin-bottom: 5px;
    font-size: 19px;
    }
    .contact .form_contact .contact_form_in .input-group .u-full-width {
    position: relative;
    display: block;
    width: 100%;
    line-height: 1.5;
    font-size: 1rem;
    color: #000;
    font-weight: normal;
    height: auto;
    padding: 11px 20px 11px 20px;
    border-radius: 25px;
    -webkit-border-radius: 25px;
    -moz-border-radius: 25px;
    -ms-border-radius: 25px;
    -o-border-radius: 25px;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #d9d9d9;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
    overflow: visible;
    }
    
    .contact .form_contact .contact_form_in .input-group select {
    background-image: url(https://cdn.cybassets.com/s/files/5330/theme/72268/assets/1638507214_cce41a0a_45e574jh5f15w8u4jha.png?1638507214);
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background-color: #fff;
    background-repeat: no-repeat, repeat;
    background-position: right 1.5em top 50%, 0 0;
    background-size: 1em auto, 100%;
    }
    .contact .form_contact .contact_form_in .input-group .u-full-width:focus {
    border-color: #e5669f;
    outline: 0;
    box-shadow: none;
    }
    .contact .form_contact .contact_form_in .input-group #brand_textarea {
      resize: none;
    height: 135px;
    }
    .contact .form_contact .contact_form_in .title {
    text-align: center;
    }
    .contact .form_contact .contact_form_in h3 {
    color: #000;
    display: inline-block;
    margin-bottom: 35px;
    font-size: 30px;
    margin-top: 0;
    font-weight: 500;
    }
    .contact .form_contact .privacypolicy_checkbox {
    position: relative;
    display: block;
    padding-left: 28px;
    user-select: none;
    margin: 30px 0px;
    }
    .contact .form_contact #chbox {
      display: none;
    }
    .contact .form_contact .check-mark {
    width: 21px;
    height: 21px;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #d9d9d9;
    position: absolute;
    left: 0;
    display: inline-block;
    top: 0;
    border-radius: 50%;
    }
    .checkbox:checked + .check-mark {
    background-color: #fff;
    transition: .1s;
    }
    .checkbox:checked + .check-mark:after {
    content: "";
    position: absolute;
    width: 10px;
    transition: .1s;
    height: 5px;
    background: #fff;
    top: 45%;
    left: 50%;
    border-left: 2px solid #000;
    border-bottom: 2px solid #000;
    transform: translate(-50%, -50%) rotate(-45deg);
    }
    .contact .form_contact .privacypolicy_checkbox p {
    color: #666;
    margin: 0;
    font-size: 14px;
    line-height: 22px;
    }
    .black {
    color:#000;
    }
    .btn_bottom {
    text-align: center;
    }
    .contact .form_contact .button-primary {
    cursor: pointer;
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    background-color: #000000;
    border: 1px solid #000000;
    font-size: 18px;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    -ms-border-radius: 30px;
    -o-border-radius: 30px;
    color: #ffffff;
    font-weight: 500;
    line-height: 1.7;
    padding: 14px 25px;
    min-width: 265px;
    }
    .contact .form_contact .button-primary:hover {
    background-color: #1a00ff;
    border: 1px solid #1a00ff;
    color: #fff;
    -webkit-box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    }
    
    @media (min-width:991px) {
    .contact .form_contact .button-primary {
    transition: all .3s ease-in-out;
    }
    .banner_font_part .banner_font_box .banner_btn .banner_btn_con, .header-menu a .contact, .contact_m {
    transition: all .3s ease-in-out;
    }
    .content .banner_part .banner_bg_box {
    overflow: hidden;
    }
    }

    
    ::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #d9d9d9;
  opacity: 1; /* Firefox */
}
    
*,
*::before,
*::after {
  box-sizing: border-box;
  }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-size: 20px;
  font-weight: 400;
  line-height: 1.5;
  color: #000;
  text-align: left;
  background-color: #fff; }

.cursor {
    left: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    z-index: 2;
    transition: all .1s ease-in-out;
}

.cursor__item {
    width: 30px;
    height: 30px;
    background-color: #1a00ff;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: all 0.3s ease-in-out;
}

.cursor__item span {
    display: block;
    opacity: 0;
    transition: opacity 0.2s ease-in-out;
    text-align: center;
    line-height: 20px;
    font-size: 14px;
}

.cursor.hover .cursor__item {
    width: 60px;
    height: 60px;
    background-color: #fff;
}

.cursor.hover .cursor__item span {
    opacity: 1;
}



.banner_part_mark {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 650px;
    height: 650px;
    border-radius: 100%;
    opacity: 0.5;
    filter: blur(250px);
    transition: all 450ms ease-out;
    position: fixed;
    pointer-events: none;
    left: 0;
    top: 0;
    transform: translate(calc(-50% + 15px), -50%);
    z-index: 1;
}

@-webkit-keyframes topAni {
    0% {
        top: 150px;
        opacity: 0;
    }

    35% {
        opacity: 1;
    }

    75% {
        top: -150px;
        opacity: 0;
    }

    100% {
        top: -150px;
        opacity: 0;
    }
}

@keyframes topAni {
    0% {
        top: 150px;
        opacity: 0;
    }

    35% {
        opacity: 1;
    }

    75% {
        top: -150px;
        opacity: 0;
    }

    100% {
        top: -150px;
        opacity: 0;
    }
}

@-webkit-keyframes leftAni {
    0% {
        left: -150px;
    }

    75% {
        left: 150px;
    }

    100% {
        left: 150px;
    }
}

@keyframes leftAni {
    0% {
        left: -150px;
    }

    75% {
        left: 150px;
    }

    100% {
        left: 150px;
    }
}


.content .banner_part {
    width: 100%;
    height: calc(100vh - 100px);
    position: relative;
    z-index: 1;
}

.content .banner_part .banner_bg_box {
    position: absolute;
    top: 0px;
    width: 100%;
    height: 2000px;
}

.content .banner_part .banner_bg_box .banner_bg {
    position: absolute;
    top: 0px;
    left: 40%;
    width: 100%;
}

.content .banner_part .banner_bg_box .banner_bg .banner_bg_con {
    position: absolute;
    top: 0px;
    left: 0px;
    filter: blur(30px);
}

.content .banner_part .banner_bg_box .banner_bg .bg_1 {
    width: 50%;
    margin-top: -50px;
    margin-left: -50px;
}

.content .banner_part .banner_bg_box .banner_bg .bg_2 {
    width: 60%;
    margin-top: 0px;
    margin-left: -100px;
}

.content .banner_part .banner_bg_box .banner_bg .bg_t {
    width: 90%;
    margin-top: -380px;
    margin-left: -360px;
    opacity: 1;
    animation: 5s cubic-bezier(0.27, 0.61, 0.17, 0.73) 0s infinite normal none running topAni, 5s linear 0s infinite normal none running leftAni;
}

.content .banner_part .banner_bg_box .banner_bg .bg_t_2 {
    width: 90%;
    margin-top: -380px;
    margin-left: -360px;
    opacity: 0;
    animation: 5s cubic-bezier(0.27, 0.61, 0.17, 0.73) 2.5s infinite normal none running topAni, 5s linear 2.5s infinite normal none running leftAni;
}

.content .banner_part .banner_bg_box .banner_bg .bg_b {
    width: 90%;
    opacity: 1;
    margin-top: -100px;
    margin-left: -270px;
    animation: 6s cubic-bezier(0.27, 0.61, 0.17, 0.73) 1s infinite normal none running topAni, 6s linear 1s infinite normal none running leftAni;
}

.content .banner_part .banner_bg_box .banner_bg .bg_b_2 {
    width: 90%;
    opacity: 0;
    margin-top: -100px;
    margin-left: -270px;
    animation: 6s cubic-bezier(0.27, 0.61, 0.17, 0.73) 4s infinite normal none running topAni, 6s linear 4s infinite normal none running leftAni;
}

.content .banner_part .part_con {
    position: relative;
    z-index: 10;
    height: 105vh;
}

.banner_font_part {
  width: 80%;
    max-width: 1150px;
    margin: 0 auto;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}
.banner_font_part .banner_font_box .drop_title {
    position: relative;
    cursor: pointer;
    transition: all .3s ease-out 0s;
    display: inline-block;
    line-height: 30px;
    vertical-align: top;
    z-index: 2;
    border: 1px solid #ababab;
    border-radius: 30px;
    padding: 0 15px 0 15px;
    margin-bottom: 15px;
}
.banner_font_part .banner_font_box .drop_title:hover {
    border: 1px solid #000;
}
.banner_font_part .banner_font_box .drop_title .text {
    color: #000;
    font-size: 17px;
    line-height: 30px;
    transition: all .3s ease-out 0s;
}
.banner_font_part .banner_font_box .title .banner_title {
  font-size: 64px;
    color: #000;
    line-height: 1.3;
    font-weight: 600;
    margin: 0;
}
.banner_font_part .banner_font_box .banner_font_list {
  margin-top: 13px;
  margin-block-start: 0;
    margin-block-end: 0;
    padding-inline-start: 0;
}
.banner_font_part .banner_font_box .banner_font_list .banner_font_item {
  margin-top: 22px;
}
.banner_font_part .banner_font_box .banner_font_list .banner_font_item .banner_font_item_ft {
  font-size: 20px;
    line-height: 1;
    color: #555;
}
dd, ol, ul {
    list-style: none outside;
}
.banner_font_part .banner_font_box .banner_btn {
    max-width: 220px;
    border-radius: 55px;
    margin-top: 40px;
    color: #fff;
    cursor: pointer;
}
.banner_font_part .banner_font_box .banner_btn .banner_btn_con {
    width: 100%;
    border-radius: 55px;
    line-height: 1.7;
    padding: 14px 25px;
    background-color: #f74a87;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    z-index: 3;
}
.banner_font_part .banner_font_box .banner_btn .banner_btn_con .banner_btn_font {
    font-size: 18px;
    font-weight: 500;
}
.banner_font_part .banner_font_box .banner_btn .banner_btn_con:hover {
    background-color: #1a00ff;
    color: #fff;
    -webkit-box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    }
    .banner_font_part .banner_img {
    height: auto;
    width: 47%;
    position: relative;
    }
    .banner_font_part .banner_img .banner_img_con {
        padding-top: 20px;
        animation: float2 2.5s 0.1s infinite;
    }


.header {
	position: fixed;
	width: 100%;
	top: 0;
	z-index: 999;
	height: 120px;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
	background-color: transparent;
	display: flex;
	pointer-events: none;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
}

.header.header_scroll {
	height: 130px;
}

.header_con {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-radius: 90px;
	padding: 0;
	width: 80%;
	max-width: 1150px;
	margin: 0 auto;
	height: 70px;
	position: relative;
	z-index: 999;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	pointer-events: auto;
}

.header.header_scroll .header_con {
	padding: 0 13px 0 60px;
	border-radius: 90px;
	background-color: hsla(0,0%,100%,.5);
	animation: blur-in 2000ms 0s forwards;
	-webkit-box-shadow: 0 10px 50px rgb(47 40 39 / 20%);
	box-shadow: 0 10px 50px rgb(47 40 39 / 20%);
}

@keyframes blur-in {
	from {
		-webkit-backdrop-filter: saturate(0%) blur(0);
		backdrop-filter: saturate(0%) blur(0);
		content: 'viewport-units-buggyfill; backdrop-filter: saturate(0%) blur(0)';
	}

	to {
		-webkit-backdrop-filter: saturate(180%) blur(5.128vw);
		backdrop-filter: saturate(180%) blur(5.128vw);
		content: 'viewport-units-buggyfill; backdrop-filter: saturate(180%) blur(5.128vw)';
	}
}

.header.header_scroll .header-logo {
	height: 40px;
}

.header-menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
}

.header-menu a {
	text-decoration: none;
    line-height: 48px;
    font-size: 16px;
    position: relative;
    cursor: pointer;
    color: #666;
    margin-right: 20px;
    transition: color 0.3s;
}

.header-menu .nav_line {
    position: absolute;
    left: 0;
    bottom: 2px;
    width: 20px;
    height: 3px;
    opacity: 0;
    border-radius: 3px;
    background-color: #f74a87;
    -webkit-transition: width .3s ease,opacity .3s ease;
    transition: width .3s ease,opacity .3s ease;
}

.header-menu a.select .nav_line {
	width: 100%;
    opacity: 1;
}

.header-menu a.select .nav_title {
    color: #f74a87;
}

.transparent {
	background-color: transparent !important;
}

.hamburger {
	display: none;
	flex-direction: column;
	cursor: pointer;
}


.header-logo {
	height: 50px;
	transition: transform 0.3s;
}

.header-logo img {
	width: 100%;
	height: 100%;
}
.header-menu a .contact {
    visibility: hidden;
    opacity: 0;
    text-align: center;
    width: 150px;
    border-radius: 55px;
    font-size: 15px;
    color: #fff;
    padding: 0;
    background-color: #f74a87;
    cursor: pointer;
    font-weight: 600;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.header-menu a .contact:hover {
background-color: #1a00ff;
    color: #fff;
    -webkit-box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
}
.header-menu a .contact.contact_scroll {
opacity: 1;
    visibility: visible;
}
.contact_m {
visibility: hidden;
    opacity: 0;
    text-align: center;
    width: 150px;
    padding: 10px 10px;
    border-radius: 55px;
    font-size: 15px;
    color: #fff;
    background-color: #f74a87;
    cursor: pointer;
    font-weight: 600;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.header.header_scroll .contact_m {
opacity: 1;
    visibility: visible;
}
.contact_m:hover {
background-color: #1a00ff;
    color: #fff;
    -webkit-box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
}
.header-menu a.select .contact_scroll {
    background-color: #1a00ff;
    color: #fff;
    -webkit-box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
    box-shadow: 0 10px 40px rgb(0 53 255 / 27%);
}





@media (max-width:991px) {
.banner_part_mark {
            display: none;
        }
	.header-menu {
		display: none;
	}
	.header.header_scroll .hamburger {
		display: block;
	}
	.header_con {
    max-width: 100%;
    border-radius: 0 !important;
    justify-content: center;
	}
	.header.header_scroll .header_con {
    padding: 0 30px 0 30px;
    width: 100%;
    justify-content: space-between;
	}
	.header {
	height: auto;
	}
	.header.header_scroll {
    height: auto;
}
.content .banner_part {
    height: auto;
}
.content .banner_part .banner_bg_box {
    height: auto;
}
.content {
overflow: hidden;
}
.content .banner_part {
width: 100%;
    height: auto;
    position: relative;
    z-index: 1;
}
.content .banner_part .banner_bg_box {
    position: absolute;
    top: 0px;
    width: 100%;
    height: auto;
}
.content .banner_part .part_con {
    width: 86%;
    position: relative;
    z-index: 10;
    height: auto;
    display: block;
    margin: auto;
    padding-top: 22.513vw;
}
.content .banner_part .banner_bg_box .banner_bg .bg_1 {
width: 100%;
    margin-top: 51.282vw;
    margin-left: -12.821vw;
}
.content .banner_part .banner_bg_box .banner_bg .bg_2 {
width: 120%;
    margin-top: 25.641vw;
    margin-left: -25.641vw;
}
.content .banner_part .banner_bg_box .banner_bg .bg_t {
width: 160%;
    margin-top: 10.256vw;
    margin-left: -41.026vw;
    opacity: 1;
    -webkit-animation: topAni 5s cubic-bezier(.27,.61,.17,.73) infinite,leftAni 5s linear infinite;
    animation: topAni 5s cubic-bezier(.27,.61,.17,.73) infinite,leftAni 5s linear infinite;
}
.content .banner_part .banner_bg_box .banner_bg .bg_t_2 {
width: 160%;
    margin-top: 10.256vw;
    margin-left: -41.026vw;
    opacity: 0;
    -webkit-animation: topAni 5s cubic-bezier(.27,.61,.17,.73) 2.5s infinite,leftAni 5s linear 2.5s infinite;
    animation: topAni 5s cubic-bezier(.27,.61,.17,.73) 2.5s infinite,leftAni 5s linear 2.5s infinite;
}
.content .banner_part .banner_bg_box .banner_bg .bg_b {
width: 200%;
    opacity: 1;
    margin-top: 25.641vw;
    margin-left: -41.026vw;
    -webkit-animation: topAni 6s cubic-bezier(.27,.61,.17,.73) 1s infinite,leftAni 6s linear 1s infinite;
    animation: topAni 6s cubic-bezier(.27,.61,.17,.73) 1s infinite,leftAni 6s linear 1s infinite;
}
.content .banner_part .banner_bg_box .banner_bg .bg_b_2 {
width: 200%;
    opacity: 0;
    margin-top: 25.641vw;
    margin-left: -41.026vw;
    -webkit-animation: topAni 6s cubic-bezier(.27,.61,.17,.73) 4s infinite,leftAni 6s linear 4s infinite;
    animation: topAni 6s cubic-bezier(.27,.61,.17,.73) 4s infinite,leftAni 6s linear 4s infinite;
}
.banner_font_box {
margin-left: 2.564vw;
margin-bottom: 7.5vw;
}
.banner_font_part .banner_img {
width: 100%;
    height: auto;
    position: relative;
}
.banner_font_part .banner_img .banner_img_con {
padding-right: 0;
}
.banner_img_con #parallaxImage {
width: 100% !important;
    transform: translate(0) !important;
}
.header.header_scroll .header-logo {
    height: auto;
    }
    .header-logo {
    width: 20vw;
    height: auto;
    display: flex;
    align-content: center;
    justify-content: flex-start;
    }
}

    @media (max-width:767px) {
    .loading-screen .loading-text .loading-svg {
      max-width: 285px !important;
    }
    .header-logo {
    width: 29vw;
    }
    .contact .form_contact {
    max-width: 100%;
    padding: 0px 30px 0px 30px;
        padding-bottom: 20px;
    }
    .contact .form_contact .contact_form_in {
    max-width: 100%;
    padding: 50px 30px;
    }
    .banner_font_part .banner_font_box .title .banner_title {
    font-size: 9.231vw;
    }
    .banner_font_part .banner_font_box .banner_font_list .banner_font_item .banner_font_item_ft {
    font-size: 3.5vw;
    }
    .banner_font_part .banner_font_box .banner_btn {
    max-width: 44vw;
    margin-top: 7vw;
    }
    .banner_font_part .banner_font_box .banner_btn .banner_btn_con .banner_btn_font {
    font-size: 17px;
    }
    .banner_font_part .banner_font_box .banner_btn .banner_btn_con {
    line-height: 5vw;
    padding: 14px 16px;
    }
    .banner_font_part .banner_font_box .drop_title .text {
    font-size: 15px;
    line-height: 25px;
    }
    .banner_font_part .banner_font_box .drop_title {
    line-height: 25px;
    }
    .banner_font_part .banner_font_box .banner_font_list .banner_font_item {
    margin-top: 4vw;
    }
    .banner_font_part .banner_img .banner_img_con {
    text-align: center;
    }
    .banner_img_con #parallaxImage {
    width: 90% !important;
    padding-bottom: 5vw;
    }
    
    .content .banner_part .banner_bg_box .banner_bg {
    left: 42%;
    width: 110%;
    }
    }
    
    @media (max-width:440px) {
    .contact .form_contact .button-primary {
     min-width: 100%;
    }
    }
    
    .float { -webkit-animation-duration:2.5s; animation-duration:2.5s;-webkit-animation-name:righttoleft;animation-name:righttoleft; -webkit-animation-iteration-count:infinite; animation-iteration-count:infinite; animation-timing-function: ease-in;}
 @-webkit-keyframes float2 {
    0%   { transform: translate(0,0px);opacity:1;} 
    50% { transform: translate(0px,9px);opacity: 1;}
    100% { transform: translate(0px,0px);opacity: 1;}
 }
 @keyframes float2 { 
  0%   { transform: translate(0,0px);opacity:1;} 
  50% { transform: translate(0px,9px);opacity: 1;}
  100% { transform: translate(0px,0px);opacity: 1;}
 }
 
    /* ===== Design Studio Sections ===== */
.ds-section {
  position: relative;
  padding: 110px 0;
  overflow: hidden;
  z-index: 3;
}

.ds-section-soft {
  background:
    radial-gradient(circle at top left, rgba(247, 74, 135, 0.08), transparent 30%),
    radial-gradient(circle at bottom right, rgba(26, 0, 255, 0.05), transparent 35%),
    #fafafa;
}

.ds-container {
  width: 80%;
  max-width: 1150px;
  margin: 0 auto;
}

.ds-section-head {
  max-width: 760px;
  margin-bottom: 48px;
}

.ds-kicker {
  display: inline-block;
  margin: 0 0 16px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: #111;
  border: 1px solid #dcdcdc;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(8px);
}

.ds-section-head h2 {
  margin: 0 0 18px;
  font-size: 48px;
  line-height: 1.2;
  font-weight: 600;
  color: #000;
  word-break: keep-all;
}

.ds-desc {
  margin: 0;
  font-size: 18px;
  line-height: 1.9;
  color: #666;
  word-break: keep-all;
}

/* ===== Advantage ===== */
.advantage-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.adv-card {
  padding: 34px 30px;
  border-radius: 28px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 20px 50px rgba(0,0,0,0.06);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.adv-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 26px 60px rgba(0,0,0,0.1);
  border-color: rgba(247, 74, 135, 0.25);
}

.adv-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: #f74a87;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
}

.adv-card h3 {
  margin: 0 0 12px;
  font-size: 26px;
  line-height: 1.35;
  color: #000;
}

.adv-card p {
  margin: 0;
  font-size: 17px;
  line-height: 1.8;
  color: #666;
}

/* ===== Services ===== */
.service-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.service-card {
  position: relative;
  padding: 34px 30px 30px;
  border-radius: 30px;
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 20px 50px rgba(0,0,0,0.05);
  transition: transform .3s ease, box-shadow .3s ease;
}

.service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 70px rgba(0,0,0,0.09);
}

.service-tag {
  display: inline-block;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(247, 74, 135, 0.1);
  color: #f74a87;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .8px;
  margin-bottom: 18px;
}

.service-card h3 {
  margin: 0 0 14px;
  font-size: 30px;
  line-height: 1.25;
  color: #000;
}

.service-card p {
  margin: 0 0 20px;
  font-size: 17px;
  line-height: 1.8;
  color: #666;
}

.service-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.service-card ul li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 12px;
  font-size: 16px;
  color: #333;
  line-height: 1.7;
  word-break: keep-all;
}

.service-card ul li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #f74a87;
  position: absolute;
  left: 0;
  top: 10px;
}

/* ===== Portfolio ===== */
.portfolio-wrap {
  position: relative;
}

.portfolio-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 30px;
  max-width: 100%;
}

.portfolio-nav {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
}

.portfolio-btn {
  width: 54px;
  height: 54px;
  border: 0;
  border-radius: 999px;
  background: #fff;
  color: #111;
  font-size: 22px;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(0,0,0,0.08);
  transition: all .25s ease;
}

.portfolio-btn:hover {
  background: #1a00ff;
  color: #fff;
  box-shadow: 0 16px 34px rgba(26,0,255,0.26);
}

.portfolio-slider {
  overflow: hidden;
  margin-top: 10px;
}

.portfolio-track {
  display: flex;
  transition: transform .45s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}

.case-slide {
  min-width: 100%;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 34px;
  align-items: center;
}

.case-media {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  background: #f5f5f5;
  box-shadow: 0 25px 60px rgba(0,0,0,0.09);
}

.case-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.case-info {
  padding: 10px 0;
}

.case-category {
  display: inline-block;
  margin-bottom: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(26,0,255,0.08);
  color: #1a00ff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .7px;
}

.case-info h3 {
  margin: 0 0 10px;
  font-size: 38px;
  line-height: 1.25;
  color: #000;
}

.case-client {
  margin: 0 0 16px;
  font-size: 16px;
  color: #f74a87;
  font-weight: 600;
}

.case-description {
  margin: 0 0 22px;
  font-size: 17px;
  line-height: 1.9;
  color: #666;
}

.case-points {
  list-style: none;
  padding: 0;
  margin: 0 0 0px;
}
.case-actions {
    margin-top: 30px;
}
.case-points li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 12px;
  font-size: 16px;
  color: #333;
  line-height: 1.7;
  word-break: normal;
}
.case-points li:last-child {
  margin-bottom: 0px;
}

.case-points li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #f74a87;
  position: absolute;
  left: 0;
  top: 10px;
}

.case-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  padding: 14px 24px;
  border-radius: 999px;
  background: #000;
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  font-weight: 600;
  transition: all .25s ease;
}

.case-actions a:hover {
  background: #1a00ff;
  box-shadow: 0 14px 34px rgba(26,0,255,0.25);
}

.portfolio-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 28px;
}

.portfolio-dots button {
  width: 10px;
  height: 10px;
  border: 0;
  padding: 0;
  border-radius: 50%;
  background: rgba(0,0,0,0.16);
  cursor: pointer;
  transition: all .25s ease;
}

.portfolio-dots button.active {
  width: 34px;
  border-radius: 999px;
  background: #f74a87;
}

.portfolio-note {
  margin-top: 24px;
  text-align: center;
}

.portfolio-note p {
  margin: 0;
  font-size: 14px;
  color: #888;
}

/* ===== Responsive ===== */
@media (max-width: 991px) {
  .ds-section {
    padding: 88px 0;
  }

  .ds-container {
    width: 86%;
  }

  .ds-section-head h2 {
    font-size: 38px;
  }

  .advantage-grid,
  .service-grid {
    grid-template-columns: 1fr;
  }

  .case-slide {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .portfolio-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .case-info h3 {
    font-size: 32px;
  }
}

@media (max-width: 767px) {
  .ds-section-head {
    margin-bottom: 34px;
  }

  .ds-section-head h2 {
    font-size: 32px;
  }

  .ds-desc,
  .adv-card p,
  .service-card p,
  .case-description {
    font-size: 16px;
    line-height: 1.8;
  }

  .adv-card,
  .service-card {
    padding: 28px 22px;
    border-radius: 24px;
  }

  .case-media {
    border-radius: 24px;
  }

  .case-info h3 {
    font-size: 28px;
  }

  .portfolio-btn {
    width: 48px;
    height: 48px;
  }
}
    
    /* ===== Shared Section ===== */
.ds-section {
  position: relative;
  padding: 110px 0;
}

.ds-container {
  width: 80%;
  max-width: 1150px;
  margin: 0 auto;
}

.ds-section-head {
  max-width: 760px;
  margin-bottom: 48px;
}

.ds-kicker {
  display: inline-block;
  margin: 0 0 16px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: #111;
  border: 1px solid #dcdcdc;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
}

.ds-section-head h2 {
  margin: 0 0 18px;
  font-size: 48px;
  line-height: 1.2;
  font-weight: 600;
  color: #000;
  word-break: keep-all;
}

.ds-desc {
  margin: 0;
  font-size: 18px;
  line-height: 1.9;
  color: #666;
  word-break: keep-all;
}

/* ===== Portfolio ===== */
.portfolio-list {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.portfolio-case {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 34px;
  align-items: center;
  padding: 28px;
  border-radius: 34px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 25px 60px rgba(0,0,0,0.06);
}

/* slider */
.portfolio-case-slider {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  background: #f5f5f7;
  box-shadow: 0 16px 40px rgba(0,0,0,0.08);
  border: 1px solid rgba(0, 0, 0, 0.06);
}

.portfolio-case-track {
  display: flex;
  transition: transform .45s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}

.case-image-slide {
  min-width: 100%;
  aspect-ratio: 16 / 12;
  overflow: hidden;
}

.case-image-slide img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.case-slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  color: #111;
  font-size: 20px;
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 10px 25px rgba(0,0,0,0.14);
  transition: all .25s ease;
}

.case-slider-btn:hover {
  background: #1a00ff;
  color: #fff;
}

.case-slider-btn.prev {
  left: 16px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.14);
}

.case-slider-btn.next {
  right: 16px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.14);
}

.case-slider-dots {
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 2;
}

.case-slider-dots button {
  width: 10px;
  height: 10px;
  border: 0;
  padding: 0;
  border-radius: 50%;
  background: rgb(0 0 0 / 16%);
  cursor: pointer;
  transition: all .25s ease;
}

.case-slider-dots button.active {
  width: 30px;
  border-radius: 999px;
  background: #f74a87;
}

/* case text */
.portfolio-case-info {
  padding: 6px 0;
}

.case-category {
  display: inline-block;
  margin-bottom: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(247,74,135,0.1);
  color: #f74a87;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .7px;
}

.portfolio-case-info h3 {
  margin: 0 0 10px;
  font-size: 34px;
  line-height: 1.25;
  color: #000;
}

.case-client {
  margin: 0 0 16px;
  font-size: 16px;
  color: #f74a87;
  font-weight: 600;
}

.case-description {
  margin: 0 0 22px;
  font-size: 17px;
  line-height: 1.9;
  color: #666;
}

.case-points {
  list-style: none;
  padding: 0;
  margin: 0 0 0;
}

.case-points li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 12px;
  font-size: 16px;
  color: #333;
  line-height: 1.7;
}

.case-points li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #f74a87;
  position: absolute;
  left: 0;
  top: 10px;
}

.case-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  padding: 14px 24px;
  border-radius: 999px;
  background: #000;
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  font-weight: 600;
  transition: all .25s ease;
}

.case-actions a:hover {
  background: #1a00ff;
  box-shadow: 0 14px 34px rgba(26,0,255,0.25);
}

/* responsive */
@media (max-width: 991px) {
  .ds-section {
    padding: 88px 0;
  }

  .ds-container {
    width: 86%;
  }

  .ds-section-head h2 {
    font-size: 38px;
  }

  .portfolio-case {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 22px;
  }

  .portfolio-case-info h3 {
    font-size: 32px;
  }
}

@media (max-width: 767px) {
  .ds-section-head {
    margin-bottom: 34px;
  }

  .ds-section-head h2 {
    font-size: 32px;
  }

  .ds-desc,
  .case-description {
    font-size: 16px;
    line-height: 1.8;
  }

  .portfolio-case {
    border-radius: 24px;
    padding: 18px;
  }

  .portfolio-case-slider {
    border-radius: 22px;
  }

  .portfolio-case-info h3 {
    font-size: 28px;
  }

  .case-slider-btn {
    width: 40px;
    height: 40px;
    font-size: 18px;
  }
}

.old-style-footer {
  margin-top: 120px;
  padding: 90px 20px 70px;
  text-align: center;
      background-color: black;
      position: fixed;
    bottom: 0;
    width: 100%;
    z-index: 0;
}

.old-footer-inner {
  position: relative;
  z-index: 1;
  max-width: 820px;
  margin: 0 auto;
}

.old-footer-logo img {
  width: 50%;
    max-width: 100%;
    height: auto;
}

.old-footer-title {
      color: white;
    font-size: 30px;
    font-weight: 600;
    font-family: sans-serif;
}

.old-footer-copy {
  margin: 28px 0 0;
  font-size: 13px;
  line-height: 2;
  color: rgba(255,255,255,0.58);
}

.old-footer-copy a {
  color: rgba(255,255,255,0.85);
  text-decoration: none;
}
@media (max-width: 767px) {
  .old-footer-logo img {
  width: 80%;
}
.ds-section-head {
    max-width: 100%;
}
.ds-section-head h2, .ds-desc {
    word-break: normal;
}
}
@media (max-width: 991px) {
  .content {
    overflow-x: hidden;
    overflow-y: visible;
  }

  #banner_top {
    overflow: visible;
    position: relative;
  }

  .content .banner_part .banner_bg_box {
    overflow-x: hidden;
    overflow-y: visible;
    height: 2000px;
  }
}
.design-contact-panel {
  margin-top: 48px;
  padding: 0 0px 80px;
      position: relative;
    z-index: 3;
}

.design-contact-panel__inner {
max-width: 1150px;
width: 80%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 28px;
  align-items: stretch;
}

.design-contact-panel__content,
.design-contact-panel__side {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  background: rgba(255,255,255,0.86);
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 24px 60px rgba(28, 22, 20, 0.08);
  backdrop-filter: blur(10px);
}

.design-contact-panel__content {
  padding: 40px 38px;
  background:
    radial-gradient(circle at top left, rgba(247,74,135,0.10), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.88));
}

.design-contact-panel__side {
  padding: 34px 28px;
  background:
    radial-gradient(circle at bottom right, rgba(26,0,255,0.06), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.90));
}

.design-contact-panel__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 1.2px;
  font-weight: 700;
  color: #cf8f8b;
  background: rgba(207,143,139,0.12);
  margin-bottom: 18px;
}

.design-contact-panel__title {
  margin: 0 0 14px;
  font-size: 34px;
  line-height: 1.2;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.02em;
}

.design-contact-panel__desc {
  margin: 0 0 26px;
  font-size: 16px;
  line-height: 1.9;
  color: #666;
}

.design-contact-panel__mailbox {
  padding: 22px 24px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5);
  margin-bottom: 24px;
}

.design-contact-panel__mail-label {
  font-size: 13px;
  color: #999;
  margin-bottom: 8px;
  letter-spacing: 0.4px;
}

.design-contact-panel__mail {
  font-size: 26px;
  line-height: 1.3;
  font-weight: 600;
  color: #171717;
  text-decoration: none;
  word-break: break-word;
}

.design-contact-panel__mail:hover {
  color: #1a00ff;
}

.design-contact-panel__note {
  padding-top: 6px;
}

.design-contact-panel__note-title {
  font-size: 15px;
  font-weight: 600;
  color: #171717;
  margin-bottom: 12px;
}

.design-contact-panel__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.design-contact-panel__list li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 10px;
  font-size: 15px;
  line-height: 1.8;
  color: #666;
}

.design-contact-panel__list li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #f74a87;
  position: absolute;
  left: 0;
  top: 10px;
}

.design-contact-panel__side-title {
  font-size: 22px;
  line-height: 1.35;
  font-weight: 700;
  color: #171717;
  margin-bottom: 22px;
}

.design-contact-panel__social-grid {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.design-contact-card {
  display: grid;
  grid-template-columns: 82px 1fr;
  gap: 16px;
  align-items: center;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.06);
  text-decoration: none;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.design-contact-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 34px rgba(0,0,0,0.08);
  border-color: rgba(207,143,139,0.22);
}

.design-contact-card__img-wrap {
  width: 82px;
  height: 82px;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.design-contact-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.design-contact-card__text {
  min-width: 0;
}

.design-contact-card__name {
  font-size: 18px;
  font-weight: 700;
  color: #171717;
  margin-bottom: 4px;
}

.design-contact-card__sub {
  font-size: 14px;
  line-height: 1.7;
  color: #777;
}

@media (max-width: 991px) {
  .design-contact-panel {
    padding: 0 20px 64px;
  }

  .design-contact-panel__inner {
    grid-template-columns: 1fr;
  }

  .design-contact-panel__title {
    font-size: 30px;
  }
}

@media (max-width: 767px) {
  .design-contact-panel {
    padding: 0 30px 54px;
    margin-top: 36px;
  }

  .design-contact-panel__content,
  .design-contact-panel__side {
    border-radius: 22px;
  }

  .design-contact-panel__content {
    padding: 28px 22px;
  }

  .design-contact-panel__side {
    padding: 24px 18px;
  }

  .design-contact-panel__title {
    font-size: 26px;
  }

  .design-contact-panel__desc {
    font-size: 15px;
    line-height: 1.8;
  }

  .design-contact-panel__mail {
    font-size: 21px;
  }

  .design-contact-card {
    grid-template-columns: 68px 1fr;
    gap: 14px;
    padding: 14px;
    border-radius: 16px;
  }

  .design-contact-card__img-wrap {
    width: 68px;
    height: 68px;
    border-radius: 14px;
  }

  .design-contact-card__name {
    font-size: 16px;
  }

  .design-contact-card__sub {
    font-size: 13px;
    line-height: 1.6;
  }
}
@media (max-width: 767px) {

  .ds-container,
  .contact .form_contact,
  .design-contact-panel__inner {
    width: 86%;
    max-width: 100%;
  }

  .contact .form_contact {
    padding: 0;
  }

  .design-contact-panel {
    padding: 0;
  }

}

/* ===== Case Image Lightbox ===== */
.case-popup-trigger {
  cursor: zoom-in;
}

.case-image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s ease, visibility .25s ease;
}

.case-image-lightbox.is-open {
  opacity: 1;
  visibility: visible;
}

.case-image-lightbox__backdrop {
  position: absolute;
  inset: 0;

  background: rgba(0, 0, 0, 0.0); /* 初始透明 */
  backdrop-filter: blur(0px);

  transition: 
    backdrop-filter .6s ease,
    background .6s ease;
}

/* 開啟時 */
.case-image-lightbox.is-open .case-image-lightbox__backdrop {
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}
.case-image-lightbox__dialog {
  position: relative;
  z-index: 2;
  max-width: min(1200px, 92vw);
  max-height: 88vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.case-image-lightbox__img {
  display: block;
  max-width: 100%;
  max-height: 88vh;
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.28);
  background: #fff;
}

.case-image-lightbox__close {
  position: absolute;
  top: -18px;
  right: -18px;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: #fff;
  color: #111;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
  transition: transform .2s ease, background .2s ease, color .2s ease;
}

.case-image-lightbox__close:hover {
  transform: scale(1.06);
  background: #111;
  color: #fff;
}

body.lightbox-open {
  overflow: hidden;
}

@media (max-width: 767px) {
  .case-image-lightbox {
    padding: 18px;
  }

  .case-image-lightbox__dialog {
    max-width: 100%;
    max-height: 82vh;
  }

  .case-image-lightbox__img {
    max-height: 82vh;
    border-radius: 14px;
  }

  .case-image-lightbox__close {
    top: -12px;
    right: -6px;
    width: 40px;
    height: 40px;
    font-size: 24px;
  }
}