/* CSS Document 
Theme Name: HYUNDAI MOTOR SECURITIES Pension Theme
Theme URI: 
Description: 현대차증권 내일의연금 Theme
Author: ibiz communication
*/

/*--------------------------------------------------------------------------------*/
/*--------------------------------- FONT STYLES ----------------------------------*/
/*--------------------------------------------------------------------------------*/

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css");

@font-face {
    font-family: 'Jalnan';
    src: url('https://cdn.jsdelivr.net/gh/wizfile/font/Jalnan.eot');
    src:url('https://cdn.jsdelivr.net/gh/wizfile/font/Jalnan.woff') format('woff');
    font-style: normal;
}


/*--------------------------------------------------------------------------------*/
/*------------------------------------ Basic -------------------------------------*/
/*--------------------------------------------------------------------------------*/

html { -webkit-font-smoothing: antialiased; font-size:14px; height: 100%; }
body { background-color: #FFF; letter-spacing: -0.5px; height: 100%; }
body,td,form,input, select, textarea {
	font-size:14px;
	font-family: 'Pretendard Variable', 'Pretendard', 'NotoKrR', 'Open Sans', sans-serif;
	color:#111;
	line-height:1.5rem;
	margin:0 0 0 0;	
}
a:link   	{ color:#111; text-decoration:none;}
a:visited	{ color:#111; text-decoration:none;}
a:hover   	{ color:#111; text-decoration:none;}
a:active 	{ color:#111; text-decoration:none;}
img { max-width: 100%; }

.container {
	width: 100%;
	padding-right: var(--bs-gutter-x, 1.5rem);
	padding-left: var(--bs-gutter-x, 1.5em); 
	max-width: inherit;
}

.font-hero { font-family: 'Jalnan'; }

.text-theme, .color-theme { color: #6D5BE1 !important; }
.color-red { color: #C2031B !important; }
.color-gray, .text-gray { color: #CCCCCC !important; }
.color-yellow { color: #FFE812 !important; }
.bg-theme { background-color: #6D5BE1 !important; }
.bg-lightgray { background-color: #F1F2F4 !important; }
.bg-gray { background-color: #D9D9D9 !important; }
.bg-white { background-color: #FFF !important; }
.bg-red { background-color: #C2031B !important; }
.rounded-4 { border-radius: 0.5rem !important; }
.rounded-12 { border-radius: 12px !important; }
.rounded-24 { border-radius: 24px !important; }
.fs-7 { font-size: 0.857rem !important; }


/*--------------------------------------------------------------------------------*/
/*------------------------------------ Header ------------------------------------*/
/*--------------------------------------------------------------------------------*/

.site-header { position: fixed; top: 0; z-index: 999; width: 100%; margin: 0 auto; }
.site-header::before { position: absolute; top: 50px; left: 0; content: ""; width: 30px; height: 30px; background: url(../images/menuwrapper-after.svg) no-repeat left bottom; transform: rotate(180deg); }
.site-header::after { position: absolute; top: 50px; right: 0; content: ""; width: 30px; height: 30px; background: url(../images/menuwrapper-before.svg) no-repeat left bottom; transform: rotate(180deg); }
.site-header.cambio-header .header-bg { box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.12); }
.header-bg { display: flex; justify-content: space-between; padding: 0 0.5rem 0 1.5rem; background-color: #6D5BE1; }
.top-navi { display: flex; align-items: center; height: 50px; }
.btn-back { padding: 0; }
.site-brand { position: relative; }
.navi-right { display: flex; align-items: center; min-width: 38px; }
.navi-right .btn-search { filter: brightness(0) invert(1); }
.site-body { min-height: 100%; padding: 50px 0; }

.section-hero { background-position: 90% 15%; background-repeat: no-repeat; background-size: 100px 100px; background-color: #6D5BE1; padding-bottom: 36px; }
.section-hero p { font-weight: 600; color: #FFF; }
.hero-title { position: relative; padding-top: 22px; font-family: 'Jalnan'; font-size: 2.571rem; font-weight: bold; color: #FFF; }
.hero-subtitle { font-size: 1.714rem; font-weight: 300; margin-bottom: 0; color: #FFF; }

.section-pagetitle { position: relative; display: flex; justify-content: space-between; background-color: #F1F2F4; padding-top: 0.75rem; }
.section-pagetitle label { font-size: 1rem; font-weight: 500; margin-bottom: 0.5rem; }
.section-pagetitle p { font-size: 0.857rem; color: #999; }
.single-title { font-size: 1.714rem; font-weight: 600; }
.section-coverimg { padding-top: 1rem; background: linear-gradient(to bottom, #F1F2F4 90px, #FFF 90px); }


/*--------------------------------------------------------------------------------*/
/*------------------------------------ Footer ------------------------------------*/
/*--------------------------------------------------------------------------------*/

.site-bottom { position: fixed; width: 100%; height: 50px; padding-top: 3px; bottom: 0; background-color: #6D5BE1; z-index: 9; }
.site-bottom .col { text-align: center; }
.site-bottom .btn { position: relative; color: #FFF; text-align: center; font-size: 0.786rem; line-height: 20px; padding: 0; filter: brightness(0) invert(1); opacity: 0.5; }
.site-bottom .btn-ai { filter: none; opacity: 1; width: 42px; height: 42px; line-height: 14px; border-radius: 50%; border:3px solid transparent; background-image: linear-gradient(#3C2DA4, #3C2DA4), linear-gradient(45deg, #5C43FC 0%,  #9E2DA4 100%); background-origin: border-box; background-clip: content-box, border-box; }
.site-bottom .btn-ai .menuicon, .site-bottom .btn-ai span { opacity: 0.5; }
.site-bottom .btn:hover, .site-bottom .btn.active { filter: none; font-weight: bold; opacity: 1; }
.site-bottom .btn-ai:hover .menuicon, .site-bottom .btn-ai.active .menuicon, .site-bottom .btn-ai.active span { opacity: 1; }
.site-bottom .btn-ai.active { margin-top: -24px; border: none; width: 50px; height: 50px; background: #271892; box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25); }
.site-bottom .btn-ai.mic { background-color: #DC3545; text-indent: -9999px; background-image: url(../images/icon-mic.svg); background-position: center center; background-repeat: no-repeat; }
.site-bottom .btn-ai.mic span { display: none; }
.site-bottom::before { position: absolute; top: -30px; left: 0; content: ""; width: 30px; height: 30px; background: url(../images/menuwrapper-before.svg) no-repeat left bottom; }
.site-bottom::after { position: absolute; top: -30px; right: 0; content: ""; width: 30px; height: 30px; background: url(../images/menuwrapper-after.svg) no-repeat left bottom; }

/*--------------------------------------------------------------------------------*/
/*-------------------------------------- main ------------------------------------*/
/*--------------------------------------------------------------------------------*/

.nav-filtericon .nav-link { color: #fff; background-color: #3C2DA4; padding: 0.25rem 0.75rem; }
.nav-filtericon .nav-setting { padding: 0.25rem; }
.nav-filtericon li:not(:last-child) { margin-right: 0.25rem; }
.schedule-slider-wrapper { display: flex; width: 100%; align-items: center; }
.schedule-select { width: 70px; margin-left: 20px; border-right: 1px solid #ddd; }
.schedule-select select { border: 0; padding: 0; }
.schedule-slider { width: calc(100% - 70px); margin: 0 0.75rem; }
.schedule-slider .btn-date { width: 40px; height: 60px; font-size: 0.929rem; font-weight: 700; }
.schedule-slider .btn-date label { display: block; font-size: 0.786rem; }
.schedule-slider .btn-date.active { border-radius: 2rem; background-color: #6D5BE1; color: #FFF !important; }
.btn-date.sat { color: #0d6efd; }
.btn-date.sun { color: #dc3545; }

/*--------------------------------------------------------------------------------*/
/*------------------------------------ content -----------------------------------*/
/*--------------------------------------------------------------------------------*/

.section-area { position: relative; background-color: #FFF; padding: 1.5rem 0; }
.section-padding-sm { padding: 0.5rem 0; }
.section-padding-lg { padding: 2.5rem 0; }
.boxshadow { box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.12); }
.section-area.section-toprounded { padding-top: 0rem; }
.section-toprounded::before { position: absolute; top: -2rem; content: ""; background-color: #FFF; width: 100%; height: 2rem; border-radius: 2rem 2rem 0 0; z-index: 2; }
.section-area.section-bottomrounded { border-radius: 0 0 2rem 2rem; }
.section-area.section-bottomrounded.boxshadow::after { display: none; }
.section-area.boxshadow { margin-bottom: 1px; }
.section-area.boxshadow::after { position: absolute; bottom: -1px; content: ""; background-color: #F1F2F4; width: 100%; height: 1px; box-shadow: inset 0px 2px 2px 0px rgba(0, 0, 0, 0.12); z-index: 2; }
.section-category { position: relative; padding: 1rem 0; }
.section-category::before { position: absolute; top: 0; left: 0; content: ""; width: 30px; height: 30px; background: url(../images/menuwrapper-after.svg) no-repeat left bottom; transform: rotate(180deg); }
.section-category::after { position: absolute; top: 0; right: 0; content: ""; width: 30px; height: 30px; background: url(../images/menuwrapper-before.svg) no-repeat left bottom; transform: rotate(180deg); }
.section-gototop { display: flex; padding: 1rem 0; }

.section-title-wrapper { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.75rem; }
.section-title { font-size: 1.286rem; font-weight: 700; margin-bottom: 0; }
.category-title { font-size: 1.429rem; font-weight: 700; margin-bottom: 0; line-height: 50px; color: #FFF; }
.inline-icon { margin-right: 0.5rem; }

.list-group > .list-group-item { background-color: transparent; }
.list-group > .list-group-item.roundwrapper { padding: 0.857rem; background-color: #FFF; border: 1px solid rgba(0, 0, 0, 0.125); border-radius: 12px; margin-bottom: 0.714rem; }
.list-group-arrow > .list-group-item { border-width: 0 0 1px; padding: 0.857rem 0; }
.list-group-arrow > .list-group-item h5 { position: relative; padding-right: 3rem; height: 2.83rem; font-size: 1.143rem; margin-bottom: 0; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.list-group-arrow > .list-group-item h5::after { position: absolute; top: 0; right: 0; content: ""; width: 15px; height: 20px; background: url(../images/listicon-arrow.svg); }
.list-group-arrow > .list-group-item p { margin-bottom: 0; color: #999; font-size: 0.857rem; }
.list-group-clear > .list-group-item { border-width: 0; padding: 0.125rem 0; }
.text-truncate { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.text-truncate2 { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.text-truncate3 { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }

.thumb { background-size: cover; background-position: center; padding: 0; border-radius: 0.5rem; }
.list-group-thumb > .list-group-item { border-width: 0 0 0; padding: 0.714rem 0;}
.list-group-thumb > .list-group-item .thumb { width: 100px; float: left; margin-right: 1rem; }
.list-group-thumb > .list-group-item.roundwrapper .thumb { width: 80px; }
.list-group-thumb > .list-group-item h5 { font-size: 1rem; padding-top: 1rem; margin-bottom: 0; line-height: 1.4; }
.list-group-thumb > .list-group-item.roundwrapper h5 { padding-top: 0.714rem; }
.list-group-thumb > .list-group-item p { margin-bottom: 0; color: #999; font-size: 0.857rem; }
.roundwrapper { padding: 0.857rem; background-color: #FFF; border: 1px solid rgba(0, 0, 0, 0.125); border-radius: 12px; }

.list-group-flush > .list-group-item { border-width: 0 0 1px; padding: 1rem 0 0.857rem; }
.list-group-flush > .list-group-item h5 { font-size: 1.143rem; margin-bottom: 0.25rem; line-height: 1.4; }
.list-group-flush > .list-group-item h6 { font-size: 1rem; margin-bottom: 0; line-height: 1.4; }
.list-group-flush > .list-group-item p { margin-bottom: 0; color: #999; font-size: 0.857rem; }
.list-group-flush li:nth-child(1) .badge-category { background-color: #03B9D2; }
.list-group-flush li:nth-child(2) .badge-category { background-color: #03D297; }
.badge-category { display: flex; align-items: center; justify-content: center; width: 55px; height: 55px; font-size: 1rem; font-weight: 500; float: left; margin-right: 1rem; padding: 0.35em; white-space: break-spaces; }
.badge-category h6 { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; line-height: 1 !important; }
.list-group-label { font-size: 0.857rem; background-color: #D9D9D9; border-radius: 5px; padding-left: 0.65em; padding-right: 0.65em; margin-bottom: 0.5rem; }

.list-group-disc > .list-group-item { border-width: 0 0 0; padding: 0 0 0.125rem 1.25rem; }
.list-group-disc > .list-group-item::before { position: absolute; top: 0; left: 6px; content: "·"; width: 15px; height: 20px; }

.card-imglist { border-radius: 1rem; overflow: hidden; margin-bottom: 1rem; }
.card-imglist .card-body { background-size: cover; background-position: center; padding: 0; }
.card-imglist .card-footer { background-color: #FFF; border-top: 0; padding: 0.75rem 1rem 1rem; }
.card-imglist .card-footer h5 { font-size: 1rem; margin-bottom: 0; line-height: 1.4; min-height: 40px; }
.card-imglist .card-footer p { color: #999; font-size: 0.857rem; margin-bottom: 0; }
.card-marketlist { border-radius: 1rem; overflow: hidden; margin-bottom: 1rem; border: 0; box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); margin-top: 1.5rem; }
.card-marketlist.even { margin-top: 0rem; }
.card-marketlist .card-footer { background-color: transparent; color: #FFF; border-top: 0; padding: 0.75rem 1rem 1rem; }
.card-marketlist h6 { margin-bottom: 0.25rem; }
.card-marketlist h2 { font-size: 1.714rem; font-weight: 300; }
.badge-marketnews { background-color: #FFF; border: 1px solid #D9D9D9; font-size: 0.786rem; font-weight: 500; color: #666; border-radius: 5px; margin-bottom: 0.125rem; }

.details-faq > summary { position: relative; list-style: none; font-size: 1.143rem; padding: 0.857rem 2rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.details-faq > summary > label { position: absolute; left: 0; }
.details-faq > summary::after { position: absolute; top: 0.857rem; right: 0; content: ""; width: 20px; height: 20px; background: url(../images/listicon-plus.svg); }
details[open].details-faq > summary::after { background: url(../images/listicon-minus.svg); }
.readmore-expand { background: url(../images/icon-readmore.svg) no-repeat right center; }
.details-faq > div { padding: 0 2.143rem; margin-bottom: 1rem; max-height: 420px; overflow-y: scroll; }
.details-faq { border-bottom: 1px solid rgba(0, 0, 0, 0.125); }

.details-alarm > summary { position: relative; list-style: none; font-size: 1.143rem; padding: 0.857rem 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.details-alarm > summary::after { position: absolute; top: 14px; right: 0; content: ""; width: 18px; height: 18px; background: url(../images/listicon-arrow-down.svg) no-repeat center center; transform: rotate(0); transition: .25s transform;  }
.details-alarm > summary p { margin-bottom: 0; font-size: 0.875rem; }
details[open].details-alarm > summary::after { transform: rotate(180deg); }
.details-alarm > div { padding: 1rem; max-height: 420px; overflow-y: scroll; background-color: #fafafa; }
.details-alarm { border-bottom: 1px solid rgba(0, 0, 0, 0.125); }

.details-entry { background-color: #FFF; padding: 0.857rem 0; border: 1px solid #FFF; border-radius: 0.5rem; box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); margin-bottom: 0.5rem; }
.details-entry > summary { position: relative; list-style: none; margin: 0 0.857rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.details-entry > summary dl { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0; }
.details-entry > summary dl dt { color: #6D5BE1;}
.details-entry > summary dl dd { margin-bottom: 0; padding-right: 1.5rem; }
.details-entry > summary::after { position: absolute; bottom: 2px; right: 0; content: ""; width: 18px; height: 18px; background: url(../images/listicon-arrow-down.svg) no-repeat center center; transform: rotate(0); transition: .25s transform; }
details[open].details-entry { border: 1px solid #6D5BE1; }
details[open].details-entry > summary::after { transform: rotate(180deg); }
.details-hr { margin: 0.5rem 0.875rem; background-color: #D9D9D9; opacity: 1; }
.details-content { padding-left: 0.875rem; }
.details-content.scroll ul { padding-left: 0; }

.scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; }
.scroll .nav, .scroll ul { position: relative; min-width: max-content; padding-left: var(--bs-gutter-x, 1.5em); }
.scroll { -ms-overflow-style: none;  /* IE and Edge */ scrollbar-width: none;  /* Firefox */ }
.scroll::-webkit-scrollbar{ display: none;	width: 0;  /* Remove scrollbar space */	height: 0; background: transparent;  /* Optional: just make scrollbar invisible */ -webkit-appearance: none; }

.nav-custom-wrapper { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.nav-custom .nav-link { background-color: #FFF; color: #333; border: 1px solid #E7E8EC; border-radius: 5rem; min-width: 48px; text-align: center; margin-right: 0.5rem; margin-bottom: 0.5rem; cursor: pointer; }
.nav-custom .nav-link.active, .nav-custom .show>.nav-link { color: #fff; background-color: #6D5BE1; }
.nav-custom .nav-link.dropdown { background: url(../images/navicon-arrowdown.svg) no-repeat right 0.5rem center; padding-right: 2rem; }
.nav-custom .nav-link.dropdown.active, .nav-custom .show>.nav-link.dropdown { background:#6D5BE1 url(../images/navicon-arrowdown-white.svg) no-repeat right 0.5rem center; }
.nav-customtabs { border-bottom: 1px solid #6D5BE1; }
.nav-customtabs .nav-link { margin-bottom: -1px; background: none; color: #333; padding: 0.5rem 0.75rem; }
.nav-customtabs .nav-link.active, .nav-customtabs .show>.nav-link { font-weight: 700; color: #6D5BE1; background: none; border: none; border-bottom: 3px solid #6D5BE1; }

.media-wrapper { margin: auto; }
.media-iframe { position: relative; padding-bottom: 56.25%; padding-top: 0; height: 0; overflow: hidden; }
.media-iframe iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.details-entry .details-label { display: flex; align-items: center; margin-bottom: 0.25rem; }
.details-entry .badge { margin-right: 0.25rem; }
.details-entry h6 { margin-bottom: 0.25rem; }
.badge-distance { color: #333; border: 1px solid #D9D9D9; }
.badge-special { background-color: #DC3545; }
.badge-realtime { background-color: #6D5BE1; }
.badge-manager { background-color: #ffc107; color: #000; }
.badge-agency { width: 18px; height: 18px; border-radius: 0.25rem; border: 1px solid #D9D9D9; padding: 0; overflow: hidden; }
.badge-agency-lg { width: 40px; height: 40px; border-radius: 0.5rem; padding: 0; overflow: hidden; }
.card-golfcourse { background-color: #FFF; border-color: #D9D9D9; width: 80px; font-size: 0.875rem; margin-right: 0.5rem; }
.bg-morning { background-color: #FFF; }
.bg-afternoon { background-color: #EFEFEF; }
.bg-night { background-color: #323232; color: #FFF; }
.bg-night .list-group > .list-group-item { color: #FFF; }
.card-golfcourse .card-header { padding: 0.25rem 0.25rem 0; background-color: transparent; border-color: transparent; display: flex; align-items: center; font-weight: 700; }
.card-golfcourse .card-header img { height: 10px; width: auto; }
.card-golfcourse .card-body { padding: 0.25rem 0.25rem; background-color: transparent; overflow: hidden; }
.card-golfcourse .card-footer { padding: 0 0.25rem 0.25rem; background-color: transparent; border-color: transparent; display: flex; align-items: center;}
.card-golfcourse .text-theme { color: #9585FF !important; }
.price-group .price { color: #6D5BE1; font-weight: 600; margin-bottom: 0 !important; }
.card-myreserve { border-radius: 0.75rem; margin-bottom: 1rem; }
.card-myreserve .card-header, .card-myreserve .card-footer { display: flex; justify-content: space-between; background-color: transparent; border: 0; }

/* swiper */
.event-list { position: relative; }
.event-list span.bullet { position: absolute; bottom: 12px; right: 12px; z-index: 1; }
.event-list .bullet { display: inline-block; height: 20px; padding: 0 6px; border: 1px solid rgba(250, 250, 250, 1); border-radius: 4px; background: #FFF; line-height: 18px; color: #3c3c3c; font-size: .786rem; font-weight: 500; box-sizing: border-box; }
.event-list .bullet.red { color: #ee3739; }
.event-list .bullet.gray { background-color: rgba(220, 220, 220, 1); color: #424242; }
.event-swiper .swiper-pagination { position: relative; margin: 0.75rem 0 0; }
.event-swiper .swiper-pagination .swiper-pagination-bullet { width: 5px; height: 5px; }
.event-swiper .swiper-pagination .swiper-pagination-bullet-active { background-color: #000; }
.map-screen { width: 100vw; height: calc(100vh - 500px); }
.map-list { position: fixed; width: 100%; bottom: 50px; background-color: #6D5BE1; border-radius: 2rem 2rem 0 0; z-index: 2; }
.map-swiper {}
.map-swiper-title { text-align: center; color: #FFF; height: 28px; margin: 0; line-height: 28px; }
.map-list .swiper-button-next, .map-list .swiper-button-prev { width: 24px; height: 24px; position: absolute; top: 24px; }
.map-list .swiper-button-prev:after, .map-list .swiper-button-next:after { font-size: 16px; color: #FFF; }

/* aitalk */
.bg-aitalk { background: linear-gradient(to bottom, #6D5BE1 50px, #3C2DA4); }
.section-loading { display: flex; justify-content: center; align-items: center; height: calc(100vh - 130px); padding: 0; background-color: transparent; }
.section-aitalk { padding: 0; background-color: transparent; }
.loader { position: relative; margin: 100px auto; width: 200px; height: 200px; border-radius: 50%; background: linear-gradient(#14ffe9, #ffeb3b, #ff00e0); animation: animate 0.5s linear infinite; }
.loader span { position: absolute; width: 100%; height: 100%; border-radius: 50%; background: linear-gradient(#14ffe9, #ffeb3b, #ff00e0); }
.loader span:nth-child(1) { filter: blur(5px); }
.loader span:nth-child(2) { filter: blur(10px); animation: bounce 1s infinite linear; }
.loader span:nth-child(3) { filter: blur(25px); }
.loader span:nth-child(4) { filter: blur(50px); animation: bounce 2s infinite linear; }
.loader::after { position: absolute; top: 10px; left: 10px; right: 10px; bottom: 10px; content: ""; background: linear-gradient(to bottom, #6D5BE1, #5942bf); border-radius: 50%; animation: bounce 1s infinite linear; }
.loader-desc { text-align: center; color: #FFF; font-weight: 300; opacity: 0.5; }
.msg-wrapper { position: relative; width: 100%; height: calc(100vh - 130px); color: #FFF; }
.msg-history { width: 100%; height: calc(100vh - 180px); overflow: scroll; padding: 1rem 0; -ms-overflow-style: none;  /* IE and Edge */	scrollbar-width: none;  /* Firefox */ }
.msg-history::-webkit-scrollbar { display: none; }
.msg-search { position: absolute; bottom: 0; width: 100%; height: 50px; }
.incoming-msg { display: flex; justify-content: end; margin-bottom: 1rem; }
.outgoing-msg { display: flex; justify-content: start; margin-bottom: 1rem; }
.received-msg { display: inline-block; background-color: rgba(255, 255, 255, 0.1); padding: 0.5rem 1rem; border-radius: 1.5rem; max-width: calc(100% - 50px); }
.received-msg p { margin-bottom: 0; }
.sent-msg { display: flex; }
.sent-msg-avatar { display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; background-color: #FFF; border-radius: 50%; margin-right: 0.75rem; }
.sent-msg-box { padding-top: 0.5rem; width: calc(100% - 38px); }
.msg-link { display: inline-block; background-color: #271892; padding: 0.5rem 1rem; border-radius: 1.5rem; text-decoration: none; color: #FFF; margin-bottom: 0.25rem; }
.input-group-search { background-color: #FFF; border-radius: 6rem; }
.input-group-search .form-control { background-color: transparent; border: 0; padding-left: 1.5rem; }
.input-group-search .input-group-text { background-color: transparent; border: 0; }

/* intro */
.section-intro { display: flex; align-items: center; justify-content: center; width: 100vw; height: 100vh; background-color: #3C2DA4; }
.section-intro::before { position: absolute; top: 0; right: 0; content: ""; width: 160px; height: 160px; background: url(../images/intro-bg-top.svg) no-repeat top right; opacity: 0.75; }
.section-intro::after { position: absolute; bottom: 0; left: 0; content: ""; width: 200px; height: 200px; background: url(../images/intro-bg-bottom.svg) no-repeat bottom left; opacity: 0.75; }

/* member */
.card-login { border-radius: 2rem; box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25); z-index: 1; max-width: 380px; margin: auto; }
.card-login .card-header, .card-login .card-footer { background-color: transparent; border: 0; }
.intro-logo { margin: 1rem auto; text-align: center; }
.card-login .form-control { border-radius: 12px; }

/* myT */
.avatar { position: relative; display: block; width: 50px; height: 50px; border-radius: 50%; background-position: center center; background-repeat: no-repeat; background-size: cover; }
.avatar-lg { width: 150px; height: 150px; }
.details-status { position: relative; background-color: rgba(255, 255, 255, 0.1); padding: 1rem; border-radius: 1rem; box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); margin-bottom: 1rem; }
.details-status > summary { position: relative; list-style: none; margin: 0.25rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.details-status > summary::after { position: absolute; top: -6px; right: 0; content: ""; width: 40px; height: 30px; background: url(../images/detailicon-arrow-down.svg) no-repeat center center; transform: rotate(0); transition: .25s transform; }
details[open].details-status > summary::after { width: 40px; height: 30px; transform: rotate(180deg); }
.table-status-wrapper { background-color: #FFF; border-radius: 0.5rem; padding: 0.5rem; max-height: 186px; overflow: scroll; }
.table-status td { color: #7B6BE4; }
.list-group-mymenu .list-group-item { border: 0; padding-left: 0; }
.list-group-mymenu .list-group-item a { color: #FFF; }


/*--------------------------------------------------------------------------------*/
/*--------------------------------- Form & Button --------------------------------*/
/*--------------------------------------------------------------------------------*/

input:focus, button:focus, select:focus, textarea:focus { box-shadow: none !important; }
.btn-more { padding-right: 1.143rem; background: url(../images/btn-more.svg) no-repeat center right; }
.btn-share { padding: 0 0 0 1rem; }
.btn-top { float: right; width: 34px; height: 34px; padding: 4px 0 0; border: none; border-radius: 50%; background: rgba(255, 255, 255, 1) url(../images/btn-top.png) no-repeat center top 7px / 11px auto; line-height: 1.5; font-size: .643rem; box-shadow: 0 1px 4px #0000001a; box-sizing: border-box; }
.btn-theme { padding: 0.375rem 1rem; color: #fff; background-color: #6D5BE1; border-color: #6D5BE1; border-radius: 50rem; }
.btn-theme:hover { color: #fff; background-color: #614DDD; border-color: #614DDD; }
.btn-outline-theme { padding: 0.375rem 1rem; color: #6D5BE1; background-color: #FFF; border-color: #6D5BE1; border-radius: 50rem; }
.btn-outline-theme:hover { color: #fff; background-color: #614DDD; border-color: #614DDD; }
.btn-outline-danger { background-color: #fff; }
.btn-youtube { min-width: 62px; }
.btn-reload { font-size: 0.857rem; }
.search-form { display: flex; justify-content: space-between; }
.search-form .form-floating { width: calc(100% - 60px); }
.modal-title { color: #3C2DA4; font-weight: 700; }
.modal-buttonn-area { display: flex; width: 100%; margin: 0; border-radius: 0 0 0.3rem 0.3rem; overflow: hidden; margin-top: 1rem; }
.modal-buttonn-area .btn { border-radius: 0; padding: 0.75rem 1rem; }
.modal-content { border-radius: 0.5rem; }
.form-check-input:checked { background-color: #6D5BE1; border-color: #6D5BE1; }
.form-check-lg.form-switch .form-check-input { width: 3.8em; height: 2em; }

/*--------------------------------------------------------------------------------*/
/*--------------------------------- animation set --------------------------------*/
/*--------------------------------------------------------------------------------*/

.fadein { animation: fadein 1s linear; }
.zoomin { animation: zoomin 1s linear; }
.bounce { animation: bounce 1s infinite linear; }
.slipup { animation: slipup .1s linear; }
.slipdown { animation: slipdown .1s linear; }
.slideup { animation: slideup .3s linear; }
.slidedown { animation: slidedown .3s linear; }
.rotate { animation: rotate 1s infinite linear; }
@keyframes bounce {
	0% { transform: translateY(0px); }
	50% { transform: translateY(-1px); }
	70% { transform: translateY(-4px); }
	100% { transform: translateY(0); }	
}
@keyframes fadein {
	0% { opacity: 0; }
	100% { opacity: 1; }	
}
@keyframes zoomin {
	0% { transform: scale(0.75, 0.75); }
	100% { transform: scale(1, 1); }
}
@keyframes slipup {
	0% { transform: translateY(30px); }
	100% { transform: translateY(0); }	
}	
@keyframes slipdown {
	0% { transform: translateY(-30px); }
	100% { transform: translateY(0); }	
}
@keyframes slideup {
	0% { transform: translateY(480px); }
	100% { transform: translateY(0); }	
}
@keyframes slidedown {
	0% { opacity: 0; transform: translateY(-480px); }
	100% { opacity: 1; transform: translateY(0); }	
}
@keyframes rotate {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }	
}