@charset "UTF-8";


/* Page Portfolio */
.tab-portfolio-wrap {
	display: flex;
	justify-content: center;
	gap: 5rem;
	margin-top: 3rem;
}
.tab-portfolio {
	display: flex;
	justify-content: center;
	gap: 10px;
	align-items: center;
	overflow: hidden;
	position: relative;
	width: 70px;
	height: 70px;
	border: 2px solid var(--color-white);
	border-radius: 35px;
	border-radius: 40px;
	background: var(--color-black-gray);
	text-indent: -100%;
	cursor: pointer;
}
.tab-portfolio::before {
	content: "";
  position: absolute;
  left: -1px;
  right: -1px;
  top: -1px;
  bottom: -1px;
	border-radius: 40px;
}
.tab-portfolio span {
	display: none;
	position: relative;
	font-size: clamp(1.8rem, 1.25vw, 3.6rem);
	color: var(--color-white);
	font-weight: 700;
	letter-spacing: -0.08px;
}
.tab-portfolio img {
	position: relative;
	width: 24px;
}

.tab-portfolio.active {
	width: 210px;
	border: none;
	background: linear-gradient(55deg, var(--color-pink), var(--color-blue));
	text-indent: 0;
}
.tab-portfolio.active span {
	display: block;
}



.banner-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.banner-layout {
	overflow: hidden;
	position: relative;
	width: 48.5%;
	height: 55rem;
	margin-top: 8rem;
	border-radius: 5px;
	background-color: #878787;
}
.banner-layout.hidden {
	display: none;
}
.banner-layout .banner-bg {
	position: relative;
	width: auto;
	height: 100%;
}
.banner-layout .banner-bg img {
	width: 100.3%;
	height: 100%;
	object-fit: cover;
}
.banner-layout .banner-info {
	position: absolute;
	left: 5%;
	top: 6%;
	width: 90%;
	z-index: 1;
}
.banner-layout .banner-logo {
	display: block;
	width: 100%;
	min-width: 144px;
	margin-bottom: 12px;
	font-size: clamp(1.6rem, 1vw, 4.8rem);
	color: var(--color-white);
	line-height: 110%;
	font-weight: 700;
	text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.05);
	object-fit: cover;
}
.banner-layout .banner-logo p {
	display: block;
	width: 300%;
	max-width: 32rem;
}
.banner-layout .banner-logo strong {
	display: block;
	width: 300%;
	font-size: 4.8rem;
	line-height: 110%;
	font-weight: 700;
}
.banner-layout .banner-logo img {
	width: 100%;
}
.banner-layout .banner-title {
	display: block;
	font-size: clamp(1.8rem, 1.32vw, 5rem);
	color: var(--color-white);
	line-height: 110%;
	font-weight: 700;
	text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.2);
}
.banner-layout .banner-desc {
	display: block;
	margin-top: 12px;
	font-size: clamp(1.6rem, 1.2vw, 4.8rem);
	color: var(--color-white);
	font-weight: 400;
	text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.2);
}
.banner-layout .banner-date {
	display: block;
	margin-top: 8px;
	font-size: clamp(1.6rem, 1.2vw, 4.8rem);
	color: var(--color-white);
	font-weight: 400;
	text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.2);
}

/* TODO banner style */
.banner-layout.fc-black * {
	color: var(--color-black);
	text-shadow: 1px 1px 0px rgba(255, 255, 255, 0.2);
}
.banner-wrap.cont-all > li:nth-child(2),
.banner-wrap.cont-all > li:nth-child(6) {
	height: 60rem;
}

.banner-wrap.cont-all > li:nth-child(1),
.banner-wrap.cont-all > li:nth-child(8) {
	width: 100%;
}
.banner-wrap.cont-all > li:nth-child(1).banner-layout .banner-info,
.banner-wrap.cont-all > li:nth-child(8).banner-layout .banner-info {
	left: 2.4%;
}
.banner-wrap.cont-all > li:nth-child(1).banner-layout .banner-logo,
.banner-wrap.cont-all > li:nth-child(8).banner-layout .banner-logo {
	width: 40%;
}
.banner-wrap.cont-all > li:nth-child(1),
.banner-wrap.cont-all > li:nth-child(3),
.banner-wrap.cont-all > li:nth-child(4),
.banner-wrap.cont-all > li:nth-child(7),
.banner-wrap.cont-all > li:nth-child(8),
.banner-wrap.cont-all > li:nth-child(9),
.banner-wrap.cont-all > li:nth-child(12) {
	height: 75rem;
}

.banner-layout.hana-linebank {
	background: linear-gradient(20deg, #3B11E4 10%, #13D456 80%);
}
.banner-layout.hana-linebank .conts01 {
	position: absolute;
	left: 0%;
	bottom: 0%;
	width: 100%;
}
.banner-layout.hana-linebank .conts02 {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 24%;
	animation: moveLinebank 4s cubic-bezier(0.325, 0.905, 0.460, -0.075) infinite;
}
@keyframes moveLinebank {
  0% {
    transform: translate(-303%, -12%);
  }
  80% {
    transform: translate(185%, -182%);
  }
	100% {
    transform: translate(185%, -182%);
  }
}
.banner-layout.hana-nextg {
	background: linear-gradient(0deg, #fff 10%, #B6D1DC 30%);
}
.banner-layout.hana-nextg .conts01 {
	position: absolute;
	left: 12%;
	bottom: 5%;
	width: 35%;
	animation: moveNextG01 4s ease-in-out infinite alternate;
	z-index: 1;
}
.banner-layout.hana-nextg .conts02 {
	position: absolute;
	right: 10%;
	bottom: 10%;
	width: 60%;
	animation: moveNextG02 4s ease infinite alternate;
	
}
@keyframes moveNextG01 {
  0% {
    transform: translateX(-15%);
		opacity: 0.8;
  }
	100% {
    transform: translateX(0%);
		opacity: 1;
  }
}
@keyframes moveNextG02 {
  0% {
    transform: translateX(2%);
		opacity: 0.3;
  }
	100% {
    transform: translateX(0%);
		opacity: 1;
  }
}





.banner-layout.my-aac {
	position: relative;
	background-color: #fff;
}
.banner-layout.my-aac::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 26%;
	background-color: #E5EEF3;
}
.banner-layout.my-aac .conts01 {
	position: absolute;
	left: -10%;
	bottom: -16%;
	width: 60%;
	animation: moveAAC01 4s cubic-bezier(0.325, 0.905, 0.460, -0.075) infinite alternate;
	z-index: 2;
}
.banner-layout.my-aac .conts02 {
	position: absolute;
	right: -6.5%;
	bottom: 2%;
	width: 65%;
	z-index: 1;
}
.banner-layout.my-aac .conts03 {
	position: absolute;
	right: -3%;
	top: 12%;
	width: 45%;
	animation: moveAAC02 4s cubic-bezier(0.325, 0.905, 0.460, -0.075) infinite alternate;
	z-index: 1;
}
@keyframes moveAAC01 {
	0% {
    transform: scale(1) translateY(-2%);
  }
	100% {
    transform: scale(1.1) translateY(-0%);
  }
}
@keyframes moveAAC02 {
	0% {
    transform: scale(1) rotate(3deg);
		opacity: 0.7;
  }
	100% {
    transform: scale(1.2) rotate(0deg);
		opacity: 1;
  }
}

.banner-layout.hanyoung {
	background-color: #2A2984;
}
.banner-layout.hanyoung .conts01 {
	position: absolute;
	left: 40%;
	bottom: -10%;
	width: 70%;
	animation: rotateStar 180s ease infinite forwards;
}
.banner-layout.hanyoung .conts02 {
	position: absolute;
	left: 10%;
	bottom: 22%;
	width: 20%;
	animation: scaleBox 3s ease infinite alternate;
}
.banner-layout.hanyoung .conts03 {
	position: absolute;
	left: 22%;
	bottom: -6%;
	width: 20%;
	animation: fadeInBox 3s ease infinite;
}
.banner-layout.hanyoung .conts04 {
	position: absolute;
	left: 42.5%;
	bottom: 21%;
	width: 20%;
	animation: rotateStar 8s cubic-bezier(0.325, 0.905, 0.460, -0.075) infinite;
}
.banner-layout.hanyoung .conts05 {
	position: absolute;
	left: 65%;
	bottom: 80%;
	width: 6%;
	animation: scaleStar 8s ease infinite alternate;
}
.banner-layout.hanyoung .conts06 {
	position: absolute;
	left: 72%;
	bottom: 54%;
	width: 11%;
	
}
.banner-layout.hanyoung .conts07 {
	position: absolute;
	left: 62.5%;
	bottom: 21%;
	width: 20%;
	
}
.banner-layout.hanyoung .conts08 {
	position: absolute;
	left: 62.5%;
	bottom: -5.6%;
	width: 20%;
	animation: rotateScale 6s ease infinite;
}
.banner-layout.hanyoung .conts09 {
	position: absolute;
	left: 83%;
	bottom: -5.6%;
	width: 20%;
}
@keyframes rotateStar {
	0% {
    rotate: 0deg;
  }
	100% {
    rotate: 360deg;
  }
}
@keyframes scaleStar {
	0% {
    scale: 0.4;
  }
	100% {
    scale: 1;
  }
}
@keyframes scaleBox {
	0% {
		width: 0;
  }
	100% {
		width: 20%;
  }
}
@keyframes fadeInBox {
	0% {
		transform: translateX(-25%);
    opacity: 0;
  }
	20% {
		transform: translateX(0%);
    scale: 1;
  }
	100% {
		transform: translateX(0%);
    scale: 1;
  }
}
@keyframes rotateScale {
	0% {
		width: 0;
		transform: scale(0.2) rotate(-90deg) translate(-20%, -30%);
  }
	10% {
		width: 20%;
		transform: translateX(0%);
		transform: scale(1) rotate(0deg) translate(0%, 0%);
  }
	100% {
		transform: scale(1) rotate(0deg) translate(0%, 0%);
    scale: 1;
  }
}





/* //TODO banner style */

.more-banner-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 20rem;
	padding-bottom: 13rem;
	text-align: center;
}
.btn-more-view {
	display: flex;
	justify-content: center;
	gap: 40px;
	align-items: center;
	/* background-color: aqua; */
	padding: 0 1.3rem;
	font-size: clamp(2rem, 3.14vw, 12rem);
	color: var(--color-white);
	line-height: 16rem;
	font-weight: 500;
	cursor: pointer;

}
.btn-more-view p {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: linear-gradient(75deg, var(--color-pink), var(--color-blue));

}
.btn-more-view img {
	width: 26px;
}
