/* Fonts */
:root {
--default-font: "Roboto", "Noto Sans", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial,  "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
--heading-font: "Raleway",  sans-serif;
--nav-font: "Poppins",  sans-serif;
--main-font:"Noto Sans";
}

/* Global Colors - The following color variables are used throughout the website. Updating them here will change the color scheme of the entire website */
:root { 
--background-color: #ffffff; /* Background color for the entire website, including individual sections */
--default-color: #666666; /* Default color used for the majority of the text content across the entire website */
--heading-color: #333333; /* Color for headings, subheadings and title throughout the website */
--accent-color: #ff0082; /* Accent color that represents your brand on the website. It's used for buttons, links, and other elements that need to stand out */
--surface-color: #ffffff; /* The surface color is used as a background of boxed elements within sections, such as cards, icon boxes, or other elements that require a visual separation from the global background. */
--contrast-color: #ffffff; /* Contrast color for text, ensuring readability against backgrounds of accent, heading, or default colors. */
}

/* Nav Menu Colors - The following color variables are used specifically for the navigation menu. They are separate from the global colors to allow for more customization options */
:root {
--nav-color: #ffffff;  /* The default color of the main navmenu links */
--nav-hover-color: #58f999; /* Applied to main navmenu links when they are hovered over or active */
--nav-mobile-background-color: #ffffff; /* Used as the background color for mobile navigation menu */
--nav-dropdown-background-color: #ffffff; /* Used as the background color for dropdown items that appear when hovering over primary navigation items */
--nav-dropdown-color: #666666; /* Used for navigation links of the dropdown items in the navigation menu. */
--nav-dropdown-hover-color: #18d26e; /* Similar to --nav-hover-color, this color is applied to dropdown navigation links when they are hovered over. */
}

/* Color Presets - These classes override global colors when applied to any section or element, providing reuse of the sam color scheme. */
.light-background { --background-color: #f7f7f7; --surface-color: #ffffff; }
.dark-background { --background-color: #232323; --default-color: #ffffff; --heading-color: #ffffff; --surface-color: #252525; --contrast-color: #ffffff; } 
.back-background { --background-color: #020202; --default-color: #ffffff; --heading-color: #ffffff; --surface-color: #252525; --contrast-color: #ffffff; } 
/* Smooth scroll */
:root {scroll-behavior: smooth; }

/*--------------------------------------------------------------
# General Styling & Shared Classes
--------------------------------------------------------------*/
body {color: var(--default-color); background-color: var(--background-color); font-family: var(--default-font); }
a { color: var(--accent-color); text-decoration: none; transition: 0.3s; }
a:hover { color: color-mix(in srgb, var(--accent-color), transparent 25%); text-decoration: none; }

h1,
h2,
h3,
h4,
h5,
h6 { color: var(--heading-color); font-family: var(--heading-font); }

/* PHP Email Form Messages
------------------------------*/
.php-email-form .error-message { display: none; background: #df1529; color: #ffffff; text-align: left; padding: 15px; margin-bottom: 24px; font-weight: 600; }
.php-email-form .sent-message { display: none; color: #ffffff; background: #059652; text-align: center; padding: 15px; margin-bottom: 24px; font-weight: 600; }
.php-email-form .loading { display: none; background: var(--surface-color); text-align: center; padding: 15px; margin-bottom: 24px; }
.php-email-form .loading:before { content: ""; display: inline-block; border-radius: 50%; width: 24px; height: 24px; margin: 0 10px -6px 0; border: 3px solid var(--accent-color); border-top-color: var(--surface-color); animation: php-email-form-loading 1s linear infinite; }

@keyframes php-email-form-loading {
	0% {	transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

/*-# Global Header*/
.header { --background-color: rgba(0, 0, 0, 0); --default-color: #ffffff; --heading-color: #ffffff; color: var(--default-color); background-color: var(--background-color); padding: 15px 0; transition: all 0.5s; z-index: 997; }
.header .logo { line-height: 1; }
.header .logo img { max-height: 4rem; margin-right: 8px; }
.header .logo h1 { font-size: 30px; margin: 0; font-weight: 700; color: var(--heading-color); /*border-left: 4px solid var(--accent-color); padding-left: 8px;*/ }
.scrolled .header { box-shadow: 0px 0 18px rgba(0, 0, 0, 0.1); }

.language { position: relative; display: inline-block; width: 140px; }
.dropdown { position: relative; display: inline-block; }

/* 버튼
.dropdown-btn { display: flex; align-items: center; gap: 8px; padding: 8px 14px; /*background: #fff; border: 1px solid #ddd; border-radius: 8px;*/ cursor: pointer; font-size: 14px; font-weight: 600; transition: background .15s, box-shadow .15s;}
.dropdown-btn:hover {/*background: #f9f9f9; box-shadow: 0 2px 6px rgba(0,0,0,0.08);*/ color:yellow }
.dropdown-btn .icon {}
/* 메뉴 
.dropdown-menu { position: absolute; top: 110%; right: 0; width: 180px; background: #fff; border: 1px solid #e6e6e6; border-radius: 12px; box-shadow: 0 4px 14px rgba(0,0,0,0.12); padding: 6px 0; display: none; z-index: 100; }
.dropdown-menu.open { display: block; }
.dropdown-item { padding: 10px 16px; font-size: 14px; color: #333; cursor: pointer; display: flex; align-items: center; gap: 8px; transition: background .15s; }
.dropdown-item:hover { background: #f5f8fa; }
.dropdown-divider { height: 1px; margin: 6px 0; background: #eaeaea;}

/* Global Header on Scroll*/
.scrolled .header { --background-color: rgba(255, 0, 130, 0.85); }

@media (max-width: 768px) {
	.header {padding:10px 0; }
	.header .logo img { max-height: 2.5rem; margin-right: 8px; }
}

/* Navmenu - Desktop */
@media (min-width: 1200px) {
	.navmenu { padding: 0; }
	.navmenu ul { margin: 0; padding: 0; display: flex; list-style: none; align-items: center; }
	.navmenu li { position: relative; }
	.navmenu a,
	.navmenu a:focus { color: var(--nav-color); padding: 18px 15px; font-size: 15px; font-family: var(--nav-font); font-weight: 600; text-transform: uppercase; display: flex; align-items: center; justify-content: space-between; white-space: nowrap; transition: 0.3s; }
	.navmenu a i,
	.navmenu a:focus i { font-size: 12px; line-height: 0; margin-left: 5px; transition: 0.3s; }
	.navmenu li:last-child a { padding-right: 0; }
	.navmenu li:hover>a,
	.navmenu .active,
	.navmenu .active:focus { color: var(--nav-hover-color); }
	.navmenu .dropdown ul { margin: 0; padding: 10px 0; background: var(--nav-dropdown-background-color); display: block; position: absolute; visibility: hidden; left: 14px; top: 130%; opacity: 0; transition: 0.3s; border-radius: 4px; z-index: 99; box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1); }
	.navmenu .dropdown ul li { min-width: 200px; }
	.navmenu .dropdown ul a { padding: 10px 20px; font-size: 15px; text-transform: none; color: var(--nav-dropdown-color); }
	.navmenu .dropdown ul a i { font-size: 12px; }
	.navmenu .dropdown ul a:hover,
	.navmenu .dropdown ul .active:hover,
	.navmenu .dropdown ul li:hover>a { color: var(--nav-dropdown-hover-color); }
	.navmenu .dropdown:hover>ul { opacity: 1; top: 100%; visibility: visible; }
	.navmenu .dropdown .dropdown ul { top: 0; left: -90%; visibility: hidden; }
	.navmenu .dropdown .dropdown:hover>ul { opacity: 1; top: 0; left: -100%; visibility: visible; }
}

/* Navmenu - Mobile */
@media (max-width: 1199px) {
	.dropdown-btn {display:none;}
	.mobile-nav-toggle { color: var(--nav-color); font-size: 28px; line-height: 0; margin-right: 10px; cursor: pointer; transition: color 0.3s; }
	.navmenu { padding: 0; z-index: 9997; }
	.navmenu ul { display: none; list-style: none; position: absolute; inset: 60px 20px 20px 20px; padding: 10px 0; margin: 0; border-radius: 6px; background-color: var(--nav-mobile-background-color); overflow-y: auto; transition: 0.3s; z-index: 9998; box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1); }
	.navmenu a,
	.navmenu a:focus { color: var(--nav-dropdown-color); padding: 10px 20px; font-family: var(--nav-font); font-size: 17px; font-weight: 500; display: flex; align-items: center; justify-content: space-between; white-space: nowrap; transition: 0.3s; }
	.navmenu a i,
	.navmenu a:focus i { font-size: 12px; line-height: 0; margin-left: 5px; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: 0.3s; background-color: color-mix(in srgb, var(--accent-color), transparent 90%); }
	.navmenu a i:hover,
	.navmenu a:focus i:hover { background-color: var(--accent-color); color: var(--contrast-color); }
	.navmenu a:hover,
	.navmenu .active,
	.navmenu .active:focus { color: var(--nav-dropdown-hover-color); }
	.navmenu .active i,
	.navmenu .active:focus i { background-color: var(--accent-color); color: var(--contrast-color); transform: rotate(180deg); }
	.navmenu .dropdown ul { position: static; display: none; z-index: 99; padding: 10px 0; margin: 10px 20px; background-color: var(--nav-dropdown-background-color); border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%); box-shadow: none; transition: all 0.5s ease-in-out; }
	.navmenu .dropdown ul ul { background-color: rgba(33, 37, 41, 0.1); }
	.navmenu .dropdown>.dropdown-active { display: block; background-color: rgba(33, 37, 41, 0.03); }
	.mobile-nav-active { overflow: hidden; }
	.mobile-nav-active .mobile-nav-toggle { color: #fff; position: absolute; font-size: 32px; top: 15px; right: 15px; margin-right: 0; z-index: 9999; }
	.mobile-nav-active .navmenu { position: fixed; overflow: hidden; inset: 0; background: rgba(33, 37, 41, 0.8); transition: 0.3s; }
	.mobile-nav-active .navmenu>ul { display: block; }
}

/*# Global Footer-*/
.footer { color: var(--default-color); background-color: var(--background-color); font-size: 14px; position: relative; }
.footer .footer-top { padding-top: 50px; border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%); }
.footer .footer-about .logo { line-height: 1; margin-bottom: 25px; }
.footer .footer-about .logo img { max-height: 40px; margin-right: 6px; }
.footer .footer-about .logo span { font-size: 26px; font-weight: 700; letter-spacing: 1px; font-family: var(--heading-font); color: var(--heading-color); }
.footer .footer-about p { font-size: 14px; font-family: var(--heading-font); }
.footer .social-links a { display: flex; align-items: center;justify-content: center;  width: 40px; height: 40px; border-radius: 50%; border: 1px solid color-mix(in srgb, var(--default-color), transparent 50%); font-size: 16px; color: color-mix(in srgb, var(--default-color), transparent 30%); margin-right: 10px; transition: 0.3s; }
.footer .social-links a:hover { color: var(--accent-color); border-color: var(--accent-color); }
.footer h4 { font-size: 16px; font-weight: bold; position: relative; padding-bottom: 12px; }
.footer .footer-links { margin-bottom: 30px; }
.footer .footer-links ul { list-style: none; padding: 0; margin: 0; }
.footer .footer-links ul i { padding-right: 2px; font-size: 12px; line-height: 0; }
.footer .footer-links ul li { padding: 10px 0; display: flex; align-items: center; }
.footer .footer-links ul li:first-child { padding-top: 0; }
.footer .footer-links ul a { color: color-mix(in srgb, var(--default-color), transparent 30%); display: inline-block; line-height: 1; }
.footer .footer-links ul a:hover { color: var(--accent-color); }
.footer .footer-contact p { margin-bottom: 5px; }
.footer .footer-newsletter .newsletter-form { margin-top: 30px; margin-bottom: 15px; padding: 6px 8px; position: relative; border-radius: 4px; border: 1px solid color-mix(in srgb, var(--default-color), transparent 80%); display: flex; background-color: var(--background-color); transition: 0.3s; }
.footer .footer-newsletter .newsletter-form:focus-within { border-color: var(--accent-color); }
.footer .footer-newsletter .newsletter-form input[type=email] { border: 0; padding: 4px; width: 100%; background-color: var(--background-color); color: var(--default-color); }
.footer .footer-newsletter .newsletter-form input[type=email]:focus-visible { outline: none; } 
.footer .footer-newsletter .newsletter-form input[type=submit] { border: 0; font-size: 16px; padding: 0 20px;  margin: -7px -8px -7px 0; background: var(--accent-color); color: var(--contrast-color); transition: 0.3s; border-radius: 0 4px 4px 0; }
.footer .footer-newsletter .newsletter-form input[type=submit]:hover { background: color-mix(in srgb, var(--accent-color), transparent 20%); }
.footer .copyright { padding: 25px 0; border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%); }
.footer .copyright p { margin-bottom: 0; }
.footer .credits { margin: 0 0 10px 0; }
.footer .credits p {padding:0 1rem; }
.footer .credits a { color: color-mix(in srgb, var(--default-color), transparent 30%); display: inline-block; line-height: 1; margin: 0 10px; }
.footer .credits a:hover { color: var(--accent-color); }

/*---# Preloader-------*/
#preloader { position: fixed; inset: 0; z-index: 999999; overflow: hidden; background: var(--background-color); transition: all 0.6s ease-out; }
#preloader:before { content: ""; position: fixed; top: calc(50% - 30px); left: calc(50% - 30px); border: 6px solid #ffffff; border-color: var(--accent-color) transparent var(--accent-color) transparent; border-radius: 50%; width: 60px; height: 60px; animation: animate-preloader 1.5s linear infinite; }

@keyframes animate-preloader {
	0% {transform: rotate(0deg);}
	100% {transform: rotate(360deg);}
}

/*-# Scroll Top Button---*/
.scroll-top { position: fixed; visibility: hidden; opacity: 0; right: 15px; bottom: 15px; z-index: 99999; background-color: var(--accent-color); width: 40px;height: 40px;border-radius: 4px;transition: all 0.4s; } 
.scroll-top i { font-size: 24px; color: var(--contrast-color); line-height: 0; }
.scroll-top:hover { background-color: color-mix(in srgb, var(--accent-color), transparent 20%); color: var(--contrast-color); }
.scroll-top.active { visibility: visible; opacity: 1; }

/*-# Disable aos animation delay on mobile devices-----*/
@media screen and (max-width: 768px) {
	[data-aos-delay] { transition-delay: 0 !important; }
}

/*-# Global Page Titles & Breadcrumbs-------*/
.page-title { color: var(--default-color); background-color: var(--background-color); background-size: cover; background-position: center; background-repeat: no-repeat; padding: 160px 0 80px 0; text-align: center; position: relative; }
.page-title:before { content: ""; background-color: color-mix(in srgb, var(--background-color), transparent 50%); position: absolute; inset: 0; }
.page-title h1 { font-size: 42px; font-weight: 700; margin-bottom: 10px; }
.page-title .breadcrumbs ol { display: flex; flex-wrap: wrap; list-style: none; justify-content: center; padding: 0; margin: 0; font-size: 16px; font-weight: 400; }
.page-title .breadcrumbs ol li+li { padding-left: 10px; }
.page-title .breadcrumbs ol li+li::before { content: "/"; display: inline-block; padding-right: 10px; color: color-mix(in srgb, var(--default-color), transparent 50%); }

/*-# Global Sections--*/
section,
.section {  color: var(--default-color); background-color: var(--background-color); padding: 60px 0; scroll-margin-top: 85px; overflow: clip; }
@media (max-width: 1199px) {
	section,
	.section { scroll-margin-top: 66px; }
}

/*--# Global Section Titles--*/
.section-title { text-align: center; padding-bottom: 60px; position: relative; }
.section-title h2 { font-size: 32px; font-weight: 800; margin-bottom: 20px; padding-bottom: 20px; position: relative; }
.section-title h2:before { content: ""; position: absolute; display: block; width: 160px; height: 1px; background: color-mix(in srgb, var(--default-color), transparent 60%); left: 0; right: 0; bottom: 1px; margin: auto; }
.section-title h2::after { content: ""; position: absolute; display: block; width: 60px; height: 3px; background: var(--accent-color); left: 0; right: 0; bottom: 0; margin: auto; }
.section-title h2 small {display:block; font-weight:normal; font-size:16px; color:#888; }
.section-title p { margin-bottom: 0; font-family:var(--main-font); }

/*-# Hero Section--*/
.hero { padding: 0; }
.hero .carousel { width: 100%; min-height: 100vh; padding: 0; margin: 0; background-color: var(--background-color); position: relative; }
.hero img { position: absolute; inset: 0; display: block; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.hero .carousel-item { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; overflow: hidden; }
.carousel-item video { position: absolute; top: 50%; left: 50%; min-width: 100%; min-height: 100%; transform: translate(-50%, -50%); object-fit: cover; /* 비율 유지하며 채움 */ z-index: -1; /* 텍스트/버튼 위에 깔림 */ }
.hero .carousel-item:before { content: ""; background: color-mix(in srgb, var(--background-color), transparent 30%); position: absolute; inset: 0; z-index: 2; }
.hero .carousel-item::before { content: ""; background-color: color-mix(in srgb, var(--background-color), transparent 30%); position: absolute; inset: 0; }
.hero .carousel-container { position: absolute; inset: 90px 64px 64px 64px; display: flex; justify-content: center; align-items: center; flex-direction: column; z-index: 3; }
.hero h2 { margin-bottom: 30px; font-size: 48px; font-weight: 700; font-family:var(--main-font) animation: fadeInDown 1s both; text-align:center;  }
.hero p {text-align:center; }

@media (max-width: 768px) {
	.hero .carousel-container { inset: 90px 20px 64px 20px; }
	.hero h2 { font-size: 24px; }
	.section-title h2 { font-size: 28px; font-weight: 800; margin-bottom: 20px; padding-bottom: 20px; position: relative; }
	.section-title h2 small {display:block; font-weight:normal; font-size:14px; color:#888; }
	.section-title p { margin-bottom: 0; font-family:var(--main-font); font-size:15px; letter-spacing:-.5px;}
}

.hero p { animation: fadeInDown 1s both 0.2s; font-family:var(--main-font) }

@media (min-width: 1024px) {
	.hero h2,
	.hero p { max-width: 60%; }
}

.hero .btn-get-started { color: var(--contrast-color); background: var(--accent-color); font-family: var(--heading-font); font-weight: 500; font-size: 15px; font-family:var(--main-font) ; letter-spacing: 1px; display: inline-block; padding: 10px 32px; border-radius: 50px; transition: 0.5s; margin: 10px; animation: fadeInUp 1s both 0.4s; }
.hero .btn-get-started:hover { background: color-mix(in srgb, var(--accent-color), transparent 20%); }
.hero .carousel-control-prev,
.hero .carousel-control-next { width: 10%; transition: 0.3s; opacity: 0.5; }
.hero .carousel-control-prev:focus,
.hero .carousel-control-next:focus { opacity: 0.5; }
.hero .carousel-control-prev:hover,
.hero .carousel-control-next:hover { opacity: 0.9; }

@media (min-width: 1024px) {
	.hero .carousel-control-prev,
	.hero .carousel-control-next { width: 5%; }
}

.hero .carousel-control-next-icon,
.hero .carousel-control-prev-icon { background: none; font-size: 32px; line-height: 1; }
.hero .carousel-indicators { list-style: none; }
.hero .carousel-indicators li { cursor: pointer; }

@keyframes fadeInUp {
	from { opacity: 0; transform: translate3d(0, 100%, 0); }
	to { opacity: 1; transform: translate3d(0, 0, 0); }
}

@keyframes fadeInDown {
	from { opacity: 0; transform: translate3d(0, -100%, 0); }
	to { opacity: 1; transform: translate3d(0, 0, 0); }
}

/*-# Featured Services Section---*/
.featured-services {  padding: 40px 0 10px 0; }
.featured-services .service-item { position: relative; height: 100%; margin-bottom: 30px; }
.featured-services .service-item .icon { margin-right: 20px; }
.featured-services .service-item .icon i { color: var(--accent-color); font-size: 40px; line-height: 0; transition: 0.3s; }
.featured-services .service-item:hover .icon i { color: var(--accent-color); }
.featured-services .service-item .title { color: var(--heading-color); font-weight: 700; margin-bottom: 10px; font-size: 20px; transition: 0.3s; }
.featured-services .service-item .description { font-size: 15px; color: color-mix(in srgb, var(--default-color), transparent 30%); margin-bottom: 10px; padding:0 2rem; }
.featured-services .service-item .readmore { display: flex; align-items: center; color: color-mix(in srgb, var(--default-color), transparent 50%); transition: 0.3s; font-weight: 700; font-size: 14px; }
.featured-services .service-item .readmore i { margin-left: 8px; }
.featured-services .service-item:hover .title,
.featured-services .service-item:hover .readmore,
.featured-services .service-item:hover .icon i { color: var(--accent-color); }

/*-# About Section--*/
.about .content .who-we-are { text-transform: uppercase; margin-bottom: 15px; color: color-mix(in srgb, var(--default-color), transparent 40%); }
.about .content h3 { font-size: 2rem; font-weight: 700; }
.about .content ul { list-style: none; padding: 0; }
.about .content ul li { padding-bottom: 10px; }
.about .content ul i { font-size: 1.25rem; margin-right: 4px; color: var(--accent-color); }
.about .content p:last-child { margin-bottom: 0; }
.about .content .read-more { background: var(--accent-color); color: var(--contrast-color); font-family: var(--heading-font); font-weight: 500; font-size: 16px; letter-spacing: 1px; padding: 12px 24px; border-radius: 5px; transition: 0.3s; display: inline-flex; 
align-items: center; justify-content: center; }
.about .content .read-more i { font-size: 18px; margin-left: 5px; line-height: 0; transition: 0.3s; }
.about .content .read-more:hover { background: color-mix(in srgb, var(--accent-color), transparent 20%); padding-right: 19px; }
.about .content .read-more:hover i { margin-left: 10px; }
.about .about-images img { border-radius: 10px; }
.about .vision p.description {margin:0 1rem; }

/*-# Stats Section--*/
.stats .stats-item { padding: 30px; width: 100%; }
.stats .stats-item span { font-size: 48px; display: block; color: var(--accent-color); font-weight: 700; }
.stats .stats-item p {  color: color-mix(in srgb, var(--default-color), transparent 40%); padding: 0; margin: 0; font-family: var(--heading-font); font-size: 15px; font-weight: 600; }

/*--# Services Section-----*/
.call-to-action .service-item { background-color: var(--surface-color); padding: 30px; border: 1px solid color-mix(in srgb, var(--default-color), transparent 85%); transition: 0.3s; }
.call-to-action .service-item .icon { font-size: 36px; line-height: 0; margin-right: 30px; margin-top:20px; color: var(--accent-color); } 
.call-to-action .service-item .title { font-weight: 700; margin-bottom: 15px; font-size: 20px; }
.call-to-action .service-item .title a { color: var(--heading-color); } 
.call-to-action .service-item .description { line-height: 24px; font-size: 14px; margin: 0; font-family:var(--main-font) }
.call-to-action .service-item:hover { border-color: var(--accent-color); }
.call-to-action .service-item:hover .title a { color: var(--accent-color); }

/*-# Call To Action Section-----*/
.call-to-action { padding: 80px 0; position: relative; clip-path: inset(0); }
.call-to-action img { position: fixed; top: 0; left: 0; display: block; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.call-to-action:before { content: ""; background: color-mix(in srgb, var(--background-color), transparent 50%); position: absolute; inset: 0; z-index: 2; }
.call-to-action .container { position: relative; z-index: 3; }
.call-to-action h3 { font-size: 28px; font-weight: 700; color: var(--default-color); }
.call-to-action p { color: var(--default-color); }
.call-to-action .cta-btn { font-family: var(--heading-font); font-weight: 500; font-size: 16px; letter-spacing: 1px; display: inline-block; padding: 12px 40px; border-radius: 5px; transition: 0.5s; margin: 10px; border: 2px solid var(--contrast-color); color: var(--contrast-color); }
.call-to-action .cta-btn:hover { background: var(--accent-color); border: 2px solid var(--accent-color); }

/*-# Portfolio Section-*/
.portfolio .portfolio-filters { padding: 0; margin: 0 auto 20px auto; list-style: none; text-align: center; font-family:var(--main-font)}
.portfolio .portfolio-filters li { cursor: pointer; display: inline-block; padding: 0; font-size: 16px; font-weight: 600; margin: 0 10px; line-height: 1; text-transform: uppercase; margin-bottom: 5px; transition: all 0.3s ease-in-out; }
.portfolio .portfolio-filters li:hover,
.portfolio .portfolio-filters li.filter-active { color: var(--accent-color); }
.portfolio .portfolio-filters li:first-child { margin-left: 0; }
.portfolio .portfolio-filters li:last-child { margin-right: 0; }


@media (max-width: 575px) {
	.portfolio .portfolio-filters li { font-size: 14px; margin: 0 5px; }
}

.portfolio .portfolio-item { position: relative; }
.portfolio .portfolio-item .portfolio-info { background-color: color-mix(in srgb, var(--surface-color), transparent 10%); opacity: 0; position: absolute; left: 30px; right: 30px; bottom: 0; z-index: 3; transition: all ease-in-out 0.3s; padding: 15px; }
.portfolio .portfolio-item .portfolio-info h4 { font-size: 18px; font-weight: 600; padding-right: 50px; }
.portfolio .portfolio-item .portfolio-info p { color: color-mix(in srgb, var(--default-color), transparent 30%); font-size: 14px; margin-bottom: 0; padding-right: 50px; }
.portfolio .portfolio-item .portfolio-info .preview-link,
.portfolio .portfolio-item .portfolio-info .details-link { position: absolute; right: 50px; font-size: 24px; top: calc(50% - 14px); color: color-mix(in srgb, var(--default-color), transparent 30%); transition: 0.3s; line-height: 0; }
.portfolio .portfolio-item .portfolio-info .preview-link:hover,
.portfolio .portfolio-item .portfolio-info .details-link:hover { color: var(--accent-color); }
.portfolio .portfolio-item .portfolio-info .details-link { right: 14px; font-size: 28px; }
.portfolio .portfolio-item:hover .portfolio-info { opacity: 1; bottom: 20px; }

/*-# Testimonials Section-----*/
.testimonials .section-header { margin-bottom: 40px; }
.testimonials .testimonials-carousel,
.testimonials .testimonials-slider { overflow: hidden; }
.testimonials .testimonial-item { text-align: center; }
.testimonials .testimonial-item .testimonial-img { width: 200px; border-radius: 50%; border: 4px solid var(--background-color); margin: 0 auto; background:#eee; }
.testimonials .testimonial-item h3 { font-size: 20px; font-weight: bold; margin: 10px 0 5px 0; }
.testimonials .testimonial-item h4 { font-size: 14px; color: color-mix(in srgb, var(--default-color), transparent 40%); margin: 0 0 15px 0; }
.testimonials .testimonial-item .stars { margin-bottom: 15px; }
.testimonials .testimonial-item .stars i { color: #ffc107; margin: 0 1px; }
.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right { color: color-mix(in srgb, var(--accent-color), transparent 50%); font-size: 26px; line-height: 0; }
.testimonials .testimonial-item .quote-icon-left { display: inline-block; left: -5px; position: relative; }
.testimonials .testimonial-item .quote-icon-right { display: inline-block; right: -5px; position: relative; top: 10px; transform: scale(-1, -1); }
.testimonials .testimonial-item p { font-style: italic; margin: 0 auto 15px auto; }
.testimonials .swiper-wrapper { height: auto; }
.testimonials .swiper-pagination { margin-top: 20px; position: relative; }
.testimonials .swiper-pagination .swiper-pagination-bullet { width: 12px; height: 12px; opacity: 1; background-color: color-mix(in srgb, var(--default-color), transparent 85%); }
.testimonials .swiper-pagination .swiper-pagination-bullet-active { background-color: var(--accent-color); }
.testimonials .read-more { max-width:20rem; background: var(--heading-color); color: var(--contrast-color); font-family: var(--main-font); font-weight: 500; font-size: 16px; letter-spacing: -.5px; padding: 12px 24px; border-radius: 5px; transition: 0.3s; display: inline-flex; align-items: center; justify-content: center; margin:0 auto; }
.testimonials .read-more i { font-size: 18px; margin-left: 5px; line-height: 0; transition: 0.3s; }
.testimonials .read-more:hover { background: color-mix(in srgb, var(--heading-color), transparent 20%); padding-right: 19px; }
.testimonials .read-more:hover i { margin-left: 10px; }

#loadmap {font-family:var(--main-font) !important; }
#loadmap h2 small {color:#ddd; }
.loadmap h4 { color: var(--nav-hover-color) !important; }
.loadmap p {color:#ddd !important; }
.loadmap .list-disc { margin-left:-0.8rem; }

@media (min-width: 992px) {
	.testimonials .testimonial-item p { width: 80%; }
}

/*-# Team Section--*/
.team { --default-color: #ffffff; }
.team .member { text-align: center; position: relative; height: 100%; }
.team .member .member-info { opacity: 0; display: flex; justify-content: center; align-items: center; position: absolute; inset: 0; transition: 0.2s; }
.team .member .member-info-content { margin-top: -50px; transition: margin 0.2s; }
.team .member:hover .member-info { background: rgba(0, 0, 0, 0.6); opacity: 1; transition: 0.4s; } 
.team .member:hover .member-info-content { margin-top: 0; transition: margin 0.4s; }
.team .member h4 { color: var(--contrast-color); font-weight: 700; margin-bottom: 2px; font-size: 18px; }
.team .member span { font-style: italic; display: block; font-size: 13px; }
.team .member .social { margin-top: 15px; }
.team .member .social a { transition: 0.3s; color: var(--default-color); }
.team .member .social a:hover { color: var(--accent-color); } 
.team .member .social i { font-size: 18px; margin: 0 2px; } 

/*--# Pricing Section-*/
.pricing { padding: 60px 0 120px 0; }
.pricing .section-title { margin-bottom: 40px; }
.pricing .pricing-item { background-color: var(--surface-color); box-shadow: 0 3px 20px -2px rgba(0, 0, 0, 0.1); padding: 60px 40px; height: 100%; position: relative; border-radius: 15px; }
.pricing h3 { font-weight: 600; margin-bottom: 15px; font-size: 20px; text-align: center; }
.pricing .icon { margin: 30px auto 20px auto; width: 70px; height: 70px; background: var(--accent-color); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: 0.3s; transform-style: preserve-3d; }
.pricing .icon i { color: var(--background-color); font-size: 28px; transition: ease-in-out 0.3s; line-height: 0; }
.pricing .icon::before { position: absolute; content: ""; height: 86px; width: 86px; border-radius: 50%; background: color-mix(in srgb, var(--accent-color), transparent 80%); transition: all 0.3s ease-out 0s; transform: translateZ(-1px); }
.pricing .icon::after { position: absolute; content: ""; height: 102px; width: 102px; border-radius: 50%; background: color-mix(in srgb, var(--accent-color), transparent 90%); transition: all 0.3s ease-out 0s; transform: translateZ(-2px); }
.pricing h4 { font-size: 48px; color: var(--accent-color); font-weight: 700;  font-family: var(--heading-font); margin-bottom: 25px; text-align: center; }
.pricing h4 sup { font-size: 28px; }
.pricing h4 span { color: color-mix(in srgb, var(--default-color), transparent 50%); font-size: 18px; font-weight: 400; }
.pricing ul { padding: 20px 0; list-style: none; color: color-mix(in srgb, var(--default-color), transparent 20%); text-align: left; line-height: 20px; }
.pricing ul li { padding: 10px 0; display: flex; align-items: center; }
.pricing ul i { color: #059652; font-size: 24px; padding-right: 3px; }
.pricing ul .na { color: color-mix(in srgb, var(--default-color), transparent 70%); }
.pricing ul .na i { color: color-mix(in srgb, var(--default-color), transparent 70%); }
.pricing ul .na span { text-decoration: line-through; }
.pricing .buy-btn { color: color-mix(in srgb, var(--default-color), transparent 20%); display: inline-block; padding: 8px 40px 10px 40px; border-radius: 50px; border: 1px solid color-mix(in srgb, var(--default-color), transparent 80%); transition: none;
font-size: 16px; font-weight: 600; font-family: var(--heading-font); transition: 0.3s; }
.pricing .buy-btn:hover { background-color: var(--accent-color); color: var(--contrast-color); } 
.pricing .featured { z-index: 10; border: 3px solid var(--accent-color); }

@media (min-width: 992px) {
	.pricing .featured { transform: scale(1.15); }
}

/*-# Faq Section--*/
.faq .faq-container .faq-item { background-color: var(--surface-color); position: relative; padding: 20px; margin-bottom: 15px; border: 1px solid color-mix(in srgb, var(--default-color), transparent 85%); border-radius: 5px; overflow: hidden; }
.faq .faq-container .faq-item:last-child { margin-bottom: 0; } 
.faq .faq-container .faq-item h3 { font-weight: 600; font-size: 16px; line-height: 24px; margin: 0 30px 0 0; transition: 0.3s; cursor: pointer; display: flex; align-items: center; }
.faq .faq-container .faq-item h3 .num { color: var(--accent-color); padding-right: 5px; } 
.faq .faq-container .faq-item h3:hover { color: var(--accent-color); }
.faq .faq-container .faq-item .faq-content { display: grid; grid-template-rows: 0fr; transition: 0.3s ease-in-out; visibility: hidden; opacity: 0; }
.faq .faq-container .faq-item .faq-content p { margin-bottom: 0; font-size:.925rem; font-family:var(--main-font); overflow: hidden; }
.faq .faq-container .faq-item .faq-toggle { position: absolute; top: 20px; right: 20px; font-size: 16px; line-height: 0; transition: 0.3s;  cursor: pointer; }
.faq .faq-container .faq-item .faq-toggle:hover { color: var(--accent-color); }
.faq .faq-container .faq-active h3 { color: var(--accent-color); }
.faq .faq-container .faq-active .faq-content { grid-template-rows: 1fr; visibility: visible; opacity: 1; padding-top: 10px; } 
.faq .faq-container .faq-active .faq-toggle { transform: rotate(90deg); color: var(--accent-color); }

/*--# Contact Section-------*/
.contact .info-item i { font-size: 20px; color: var(--accent-color); font-size: 36px; display: flex; justify-content: center; align-items: center; border-radius: 4px; transition: all 0.3s ease-in-out; }
.contact .info-item h3 { font-size: 24px; font-weight: 700; margin: 20px 0; }
.contact .info-item p { padding: 0; margin-bottom: 0; font-size: 14px; }

@media (min-width: 992px) {
 .contact .info-item.info-item-borders { border-left: 1px solid color-mix(in srgb, var(--default-color), transparent 85%); border-right: 1px solid color-mix(in srgb, var(--default-color), transparent 85%); }
}

.contact .php-email-form { box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1); padding: 30px; margin-top: 30px; }

@media (max-width: 575px) {
	.contact .php-email-form { padding: 20px; }
}

.contact .php-email-form input[type=text],
.contact .php-email-form input[type=email],
.contact .php-email-form textarea { font-size: 14px; padding: 10px 15px; box-shadow: none; border-radius: 0; color: var(--default-color); background-color: color-mix(in srgb, var(--background-color), transparent 50%); border-color: color-mix(in srgb, var(--default-color), transparent 80%); }
.contact .php-email-form input[type=text]:focus,
.contact .php-email-form input[type=email]:focus,
.contact .php-email-form textarea:focus { border-color: var(--accent-color); }
.contact .php-email-form input[type=text]::placeholder,
.contact .php-email-form input[type=email]::placeholder,
.contact .php-email-form textarea::placeholder { color: color-mix(in srgb, var(--default-color), transparent 70%); }
.contact .php-email-form button[type=submit] { color: var(--contrast-color); background: var(--accent-color); border: 0; padding: 10px 30px; transition: 0.4s; border-radius: 50px; }
.contact .php-email-form button[type=submit]:hover { background: color-mix(in srgb, var(--accent-color), transparent 20%); }

/*-# Blog Posts Section-----*/
.blog-posts article { background-color: var(--surface-color); box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); padding: 30px; height: 100%; } 
.blog-posts .post-img { max-height: 240px; margin: -30px -30px 0 -30px; overflow: hidden; }
.blog-posts .title { font-size: 20px; font-weight: 700; padding: 0; margin: 20px 0 0 0; }
.blog-posts .title a { color: var(--heading-color); transition: 0.3s; }
.blog-posts .title a:hover { color: var(--accent-color); }
.blog-posts .meta-top { margin-top: 20px; color: color-mix(in srgb, var(--default-color), transparent 40%); }
.blog-posts .meta-top ul { display: flex; flex-wrap: wrap; list-style: none; align-items: center; padding: 0; margin: 0; }
.blog-posts .meta-top ul li+li { padding-left: 20px; }
.blog-posts .meta-top i { font-size: 16px; margin-right: 8px; line-height: 0; color: color-mix(in srgb, var(--default-color), transparent 20%); }
.blog-posts .meta-top a { color: color-mix(in srgb, var(--default-color), transparent 40%); font-size: 14px; display: inline-block; line-height: 1; }
.blog-posts .content { margin-top: 20px; }
.blog-posts .read-more a { display: inline-block; background: var(--accent-color); color: var(--contrast-color); padding: 8px 30px; transition: 0.3s; font-size: 14px; border-radius: 4px; }
.blog-posts .read-more a:hover { background: color-mix(in srgb, var(--accent-color), transparent 20%); }

/*-# Blog Pagination Section---*/
.blog-pagination { padding-top: 0; color: color-mix(in srgb, var(--default-color), transparent 40%); }
.blog-pagination ul { display: flex; padding: 0; margin: 0; list-style: none; }
.blog-pagination li { margin: 0 5px; transition: 0.3s; }
.blog-pagination li a { color: var(--accent-color); display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--accent-color); }
.blog-pagination li a.active,
.blog-pagination li a:hover { background: var(--accent-color); color: var(--contrast-color); }
.blog-pagination li a.active a,
.blog-pagination li a:hover a { color: var(--contrast-color); }

/*-# Blog Details Section */
.blog-details { padding-bottom: 30px; }
.blog-details .article { background-color: var(--surface-color); padding: 30px; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); } 
.blog-details .post-img { margin: -30px -30px 20px -30px; overflow: hidden; }
.blog-details .title { color: var(--heading-color); font-size: 28px; font-weight: 700; padding: 0; margin: 30px 0; }
.blog-details .content { margin-top: 20px; }
.blog-details .content h3 { font-size: 22px; margin-top: 30px; font-weight: bold; }
.blog-details .content blockquote { overflow: hidden; background-color: color-mix(in srgb, var(--default-color), transparent 95%); padding: 60px; position: relative; text-align: center; margin: 20px 0; }
.blog-details .content blockquote p { color: var(--default-color); line-height: 1.6; margin-bottom: 0; font-style: italic; font-weight: 500; font-size: 22px; }
.blog-details .content blockquote:after { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background-color: var(--accent-color); margin-top: 20px; margin-bottom: 20px; }
.blog-details .meta-top { margin-top: 20px; color: color-mix(in srgb, var(--default-color), transparent 40%); }
.blog-details .meta-top ul { display: flex; flex-wrap: wrap; list-style: none; align-items: center; padding: 0; margin: 0; }
.blog-details .meta-top ul li+li { padding-left: 20px; }
.blog-details .meta-top i { font-size: 16px; margin-right: 8px; line-height: 0; color: color-mix(in srgb, var(--default-color), transparent 40%); }
.blog-details .meta-top a { color: color-mix(in srgb, var(--default-color), transparent 40%); font-size: 14px; display: inline-block; line-height: 1; }
.blog-details .meta-bottom { padding-top: 10px; border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%); }
.blog-details .meta-bottom i { color: color-mix(in srgb, var(--default-color), transparent 40%); display: inline; } 
.blog-details .meta-bottom a { color: color-mix(in srgb, var(--default-color), transparent 40%); transition: 0.3s; }
.blog-details .meta-bottom a:hover { color: var(--accent-color); }
.blog-details .meta-bottom .cats { list-style: none; display: inline; padding: 0 20px 0 0; font-size: 14px; }
.blog-details .meta-bottom .cats li { display: inline-block; }
.blog-details .meta-bottom .tags { list-style: none; display: inline; padding: 0; font-size: 14px; }
.blog-details .meta-bottom .tags li { display: inline-block; } 
.blog-details .meta-bottom .tags li+li::before { padding-right: 6px; color: var(--default-color); content: ","; }
.blog-details .meta-bottom .share { font-size: 16px; } 
.blog-details .meta-bottom .share i { padding-left: 5px; }

/*-# Blog Comments Section------*/
.blog-comments { padding: 10px 0; } 
.blog-comments .comments-count { font-weight: bold; }
.blog-comments .comment { margin-top: 30px; position: relative; }
.blog-comments .comment .comment-img { margin-right: 14px; }
.blog-comments .comment .comment-img img { width: 60px; }
.blog-comments .comment h5 { font-size: 16px; margin-bottom: 2px; }
.blog-comments .comment h5 a { font-weight: bold; color: var(--default-color); transition: 0.3s; }
.blog-comments .comment h5 a:hover { color: var(--accent-color); }
.blog-comments .comment h5 .reply { padding-left: 10px; color: color-mix(in srgb, var(--default-color), transparent 20%); }
.blog-comments .comment h5 .reply i { font-size: 20px; }
.blog-comments .comment time { display: block; font-size: 14px; color: color-mix(in srgb, var(--default-color), transparent 40%); margin-bottom: 5px; }
.blog-comments .comment.comment-reply { padding-left: 40px; }

/*-# Comment Form Section---*/
.comment-form { padding-top: 10px; }
.comment-form form { background-color: var(--surface-color); margin-top: 30px; padding: 30px; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); }
.comment-form form h4 {  font-weight: bold; font-size: 22px; }
.comment-form form p { font-size: 14px; }
.comment-form form input { background-color: var(--surface-color); color: var(--default-color); border: 1px solid color-mix(in srgb, var(--default-color), transparent 70%); font-size: 14px; border-radius: 4px; padding: 10px 10px; }
.comment-form form input:focus { color: var(--default-color); background-color: var(--surface-color); box-shadow: none; border-color: var(--accent-color); }
.comment-form form input::placeholder { color: color-mix(in srgb, var(--default-color), transparent 50%); }
.comment-form form textarea { background-color: var(--surface-color); color: var(--default-color); border: 1px solid color-mix(in srgb, var(--default-color), transparent 70%); border-radius: 4px; padding: 10px 10px; font-size: 14px; height: 120px; }
.comment-form form textarea:focus { color: var(--default-color); box-shadow: none; border-color: var(--accent-color); background-color: var(--surface-color); }
.comment-form form textarea::placeholder { color: color-mix(in srgb, var(--default-color), transparent 50%); }
.comment-form form .form-group { margin-bottom: 25px; }
.comment-form form .btn-primary { border-radius: 4px; padding: 10px 20px; border: 0; background-color: var(--accent-color); color: var(--contrast-color); }
.comment-form form .btn-primary:hover { color: var(--contrast-color); background-color: color-mix(in srgb, var(--accent-color), transparent 20%); }

/*-# Portfolio Details Section-----*/
.portfolio-details .portfolio-details-slider img { width: 100%; }
.portfolio-details .portfolio-details-slider .swiper-pagination { margin-top: 20px; position: relative; }
.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet { width: 12px; height: 12px; background-color: color-mix(in srgb, var(--default-color), transparent 85%); opacity: 1; }
.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet-active { background-color: var(--accent-color); } 
.portfolio-details .portfolio-info { background-color: var(--surface-color); padding: 30px; box-shadow: 0px 0 30px rgba(0, 0, 0, 0.1); } 
.portfolio-details .portfolio-info h3 { font-size: 22px; font-weight: 700; margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid color-mix(in srgb, var(--default-color), transparent 85%); }
.portfolio-details .portfolio-info ul { list-style: none; padding: 0; font-size: 15px; }
.portfolio-details .portfolio-info ul li+li { margin-top: 10px; }
.portfolio-details .portfolio-description { padding-top: 30px; }
.portfolio-details .portfolio-description h2 { font-size: 26px; font-weight: 700; margin-bottom: 20px; }
.portfolio-details .portfolio-description p { padding: 0; color: color-mix(in srgb, var(--default-color), transparent 30%); }

/*-# Service Details Section--*/
.service-details .services-list { background-color: var(--surface-color); padding: 10px 30px; border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%); margin-bottom: 20px; }
.service-details .services-list a { display: block; line-height: 1; padding: 8px 0 8px 15px; border-left: 3px solid color-mix(in srgb, var(--default-color), transparent 70%);margin: 20px 0;color: color-mix(in srgb, var(--default-color), transparent 20%); transition: 0.3s; }
.service-details .services-list a.active { color: var(--heading-color); font-weight: 700; border-color: var(--accent-color); } 
.service-details .services-list a:hover { border-color: var(--accent-color); }
.service-details .services-img { margin-bottom: 20px; }
.service-details h3 { font-size: 26px; font-weight: 700; }
.service-details h4 { font-size: 20px; font-weight: 700; }
.service-details p { font-size: 15px; }
.service-details ul { list-style: none; padding: 0; font-size: 15px; }
.service-details ul li { padding: 5px 0; display: flex; align-items: center; }
.service-details ul i { font-size: 20px; margin-right: 8px; color: var(--accent-color); }

.services h4 {text-align:center;}

/*-# Starter Section Section*/
.starter-section { /* Add your styles here */ }

/*# Widgets------*/
.widgets-container { background-color: var(--surface-color); padding: 30px; margin: 60px 0 30px 0; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); }
.widget-title { color: var(--heading-color); font-size: 20px; font-weight: 700;padding: 0; margin: 0 0 20px 0; }
.widget-item { margin-bottom: 40px; }
.widget-item:last-child { margin-bottom: 0; }
.search-widget form { background: var(--background-color); border: 1px solid color-mix(in srgb, var(--default-color), transparent 75%); padding: 3px 10px; position: relative; border-radius: 50px; transition: 0.3s; }
.search-widget form input[type=text] { border: 0; padding: 4px 10px; border-radius: 4px; width: calc(100% - 40px); background-color: var(--background-color); color: var(--default-color); }
.search-widget form input[type=text]:focus { outline: none; }
.search-widget form button { background: none; color: var(--default-color); position: absolute; top: 0; right: 0; bottom: 0; border: 0; font-size: 16px; padding: 0 16px; transition: 0.3s; line-height: 0; }
.search-widget form button i { line-height: 0; }
.search-widget form button:hover { color: var(--accent-color); }
.search-widget form:is(:focus-within) { border-color: var(--accent-color); }
.categories-widget ul { list-style: none; padding: 0; margin: 0; }
.categories-widget ul li { padding-bottom: 10px; }
.categories-widget ul li:last-child { padding-bottom: 0; }
.categories-widget ul a { color: color-mix(in srgb, var(--default-color), transparent 20%); transition: 0.3s; }
.categories-widget ul a:hover { color: var(--accent-color); }
.categories-widget ul a span { padding-left: 5px; color: color-mix(in srgb, var(--default-color), transparent 50%); font-size: 14px; }
.recent-posts-widget .post-item { display: flex; margin-bottom: 15px; }
.recent-posts-widget .post-item:last-child { margin-bottom: 0; }
.recent-posts-widget .post-item img { width: 80px; margin-right: 15px; }
.recent-posts-widget .post-item h4 { font-size: 15px; font-weight: bold; margin-bottom: 5px; }
.recent-posts-widget .post-item h4 a { color: var(--default-color); transition: 0.3s; }
.recent-posts-widget .post-item h4 a:hover { color: var(--accent-color); }
.recent-posts-widget .post-item time { display: block; font-style: italic; font-size: 14px; color: color-mix(in srgb, var(--default-color), transparent 50%); }
.tags-widget ul { list-style: none; padding: 0; margin: 0; } 
.tags-widget ul li { display: inline-block; }
.tags-widget ul a { background-color: color-mix(in srgb, var(--default-color), transparent 94%); color: color-mix(in srgb, var(--default-color), transparent 30%); border-radius: 50px; font-size: 14px; padding: 5px 15px; margin: 0 6px 8px 0; display: inline-block; transition: 0.3s; }
.tags-widget ul a:hover { background: var(--accent-color); color: var(--contrast-color); }
.tags-widget ul a span { padding-left: 5px; color: color-mix(in srgb, var(--default-color), transparent 60%); font-size: 14px; }


/*추가*/
.vision { font-family:var(--main-font); text-align:center; }
.vision i {display:block; font-size:3rem; color:var(--accent-color); padding-bottom:1rem; }

.text-5xl { font-size: 3rem; line-height: 1;}
.text-4xl { font-size: 2.25rem; line-height: 2.5rem; color:var(--accent-color); }
.flex-col { flex-direction: column; }
.flex { display: flex; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.shadow-lg { --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); }
.md:gap-4 { gap: 1rem; }
.rounded-full { border-radius: 9999px; width: 8rem; height:8rem; }
.arr { margin-left:5rem; margin-top:3rem; text-align: center; }

.lg:flex-row { flex-direction: row; }
.gap-12 { gap: 3rem; }
.lg:w-1/2 { width: 50%; }
.chart-container { position: relative; width: 100%; max-width: 450px; margin-left: auto; margin-right: auto; height: auto; max-height: 450px; }
canvas { display: block; box-sizing: border-box; height: 300px; width: 450px;}

.text-2xl { font-size: 1.5rem; line-height: 2rem; }
.mb-4 { margin-bottom: 1rem; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }

.round-full { display:block; border-radius: 9999px; width: 1rem; height:1rem; background:#e94560; margin-left:-2rem; margin-right:1rem; }
.bg1 {background:#ff9a8b; }
.bg2 {background:#f7d794; }
.bg3 {background:#77aaff; }
.bg4 {background:#a2d5f2; }
.bg5 {background:#cccccc; }

ul.text-lg li {font-family:var(--main-font); }

@media (max-width: 768px) {
	.rounded-full {width: 6rem; height:6rem; }
	.col-sm-6 {width:50%; position:relative; }
	.arr.trans { position:absolute; transform:rotate(135deg); top:7rem; left:-10%; }
	.arr { position:absolute; left:92%; margin-left:0rem; margin-top:2.5rem; text-align: center; }
	.services .row .col-sm-6 {padding-left:1rem; }
	
	.lg:w-1/2 { width: 100%; }
	.tokenomics .flex { display: block; }
	.chart-container { position: relative; width: 100%; max-width: 100%; margin-left: auto; margin-right: auto; height: auto; max-height: 450px; }
	canvas { display: block; box-sizing: border-box; height: 250px; width: 250px; }
	.round-full { display: inline-block; margin-left:0rem; margin-right:1rem; padding-top:1rem; }
	
	.tokenomics .flex-col h3 {margin-left:1.5rem; margin-top:1.5rem; }

	.team {margin-top:-2rem;}
	.team .col-md-6 {width:50%; position:relative; }
	.pd-minus {margin-top:-3rem;}
	
	.testimonials .testimonial-item .testimonial-img { width: 100px; }
	.br {margin-top:1rem; }
	
	.contact .col-sm-4 { width:33.3333%; }
	.contact .col-sm-4 h3 { font-size:18px !important; }
	.contact .col-sm-4 p { word-break:break-all; text-align:center; }
	
	.footer .col-md-6 { width:60%; }
	.footer .col-md-6 + .col-md-6 {width:40%;}
}