
/********************************************
ver2 Style
ver2 Style
ver2 Style
ver2 Style
ver2 Style
*********************************************/

.fw300 { font-weight: 300 !important; } 
.aihome-landing { } 


/********************************************
메인 비주얼
*********************************************/
.main-visual { 
position: relative; 
overflow: hidden; 
background: #f5f6f4; 
/* min-height: 100vh; */
height: 100vh; 
padding: 120px 20px 100px; 
 } 

.main-visual::before { 
content: ""; 
position: absolute; 
left: -120px; 
top: -120px; 
width: 420px; 
height: 420px; 
background: radial-gradient(circle, rgba(5, 227, 72, 0.10) 0%, rgba(5, 227, 72, 0) 70%); 
pointer-events: none; 
 } 

.main-visual::after { 
content: ""; 
position: absolute; 
right: -180px; 
bottom: -180px; 
width: 520px; 
height: 520px; 
background: radial-gradient(circle, rgba(5, 227, 72, 0.08) 0%, rgba(5, 227, 72, 0) 72%); 
pointer-events: none; 
 } 

.main-visual-inner { 
position: relative; 
top: 38%;
transform: translateY(-50%);
max-width: 1440px;  
margin: 0 auto; 
 } 

.main-visual-content { 
position: relative; 
z-index: 3; 
max-width: 760px; 
margin: 0 auto; 
text-align: center; 
padding-top: 80px; 
 } 

.main-visual-subtitle { 
margin: 0 0 22px; 
font-size: 28px; 
font-weight: 700; 
color: #111; 
line-height: 1.4; 
letter-spacing: -0.03em; 


 } 

.main-visual-title { 
margin: 0; 
font-size:68px; 
line-height: 1.12; 
font-weight: 700; 
color: #111; 
letter-spacing: -0.05em; 

 } 

.main-visual-title span { 
display: inline-block; 
margin-top: 12px; 
color: #05e348; 
text-shadow: 0 8px 24px rgba(5, 227, 72, 0.18); 
/* font-size: 68px; */

 } 

.main-visual-desc { 
margin: 28px 0 0; 
font-size: 22px; 
line-height: 1.7; 
color: #555; 
letter-spacing: -0.03em; 
 } 

.main-visual-btn-wrap { 
display: flex; 
justify-content: center; 
align-items: center; 
gap: 16px; 
margin-top: 46px; 
 } 


.main-visual-btn { 
display: inline-flex; 
align-items: center; 
justify-content: center; 
min-width: 230px; 
height: 64px; 
padding: 0 30px; 
border-radius: 999px; 
font-size: 18px; 
font-weight: 700; 
text-decoration: none; 
letter-spacing: -0.02em; 
transition: all 0.25s ease; 
box-sizing: border-box; 
 } 

.main-visual-btn-primary { 
background: #05e348; 
border: 1px solid #05e348; 
color: #111; 
/* box-shadow: 0 16px 34px rgba(5, 227, 72, 0.22); */ 
 } 

.main-visual-btn-primary:hover { 
transform: translateY(-3px); 
/* box-shadow: 0 22px 38px rgba(5, 227, 72, 0.28); */
 } 

.main-visual-btn-outline { 
background: #fff; 
border: 1px solid rgba(5, 227, 72, 0.45); 
color: #111; 
/* box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); */
 } 

.main-visual-btn-outline:hover { 
transform: translateY(-3px); 
border-color: #05e348; 
/* box-shadow: 0 16px 32px rgba(5, 227, 72, 0.12); */
 } 

.main-visual-floating { 
position: absolute; 
z-index: 2; 
 } 

.main-visual-floating-left { 
left: 80px; 
top: 60px; 
 } 

.main-visual-floating-right { 
right: 60px; 
bottom: 20px; 
 } 

.main-visual-photo-card { 
width: 300px; 
border-radius: 28px; 
overflow: hidden; 
background: #fff; 
box-shadow: 0 24px 60px rgba(0, 0, 0, 0.10); 
 } 

.main-visual-photo-card img { 
display: block; 
width: 100%; 
height: auto; 
 } 

.main-visual-ui-toolbar { 
display: flex; 
align-items: center; 
gap: 12px; 
width: fit-content; 
margin: 0 0 18px auto; 
padding: 14px 18px; 
border-radius: 18px; 
background: rgba(255, 255, 255, 0.96); 
box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08); 
 } 

.main-visual-ui-toolbar button { 
width: 18px; 
height: 18px; 
border: 0; 
border-radius: 50%; 
background: #e4e4e4; 
cursor: pointer; 
 } 

.main-visual-ui-toolbar button.is-active { 
background: #05e348; 
box-shadow: 0 0 0 6px rgba(5, 227, 72, 0.16); 
 } 

.main-visual-product-card { 
width: 310px; 
padding: 14px; 
border-radius: 24px; 
background: rgba(255, 255, 255, 0.98); 
box-shadow: 0 24px 60px rgba(0, 0, 0, 0.10); 
 } 

.main-visual-product-thumb { 
border-radius: 18px; 
overflow: hidden; 
 } 

.main-visual-product-thumb img { 
display: block; 
width: 100%; 
height: auto; 
 } 

.main-visual-product-info { 
padding: 16px 6px 6px; 
 } 

.main-visual-product-info strong { 
display: block; 
font-size: 18px; 
font-weight: 800; 
color: #111; 
letter-spacing: -0.03em; 
 } 

.main-visual-product-info p { 
margin: 10px 0 0; 
font-size: 15px; 
line-height: 1.65; 
color: #666; 
letter-spacing: -0.02em; 
 } 

@media screen and (max-width: 1280px) { 
.main-visual-floating-left { 
left: 20px; 
top: 40px; 
 } 

.main-visual-floating-right { 
right: 20px; 
bottom: 10px; 
 } 

.main-visual-photo-card { 
width: 240px; 
 } 

.main-visual-product-card { 
width: 260px; 
 } 

.main-visual-title { 
font-size: 64px; 
 } 
 } 

@media screen and (max-width: 900px) { 
.main-visual { 
min-height: auto; 
padding: 90px 20px 70px; 
 } 

.main-visual-inner { 

 } 

.main-visual-floating { 
position: static; 
 } 

.main-visual-floating-left,
.main-visual-floating-right { 
display: none; 
 } 

.main-visual-content { 
max-width: 100%; 
padding-top: 0; 
 } 

.main-visual-subtitle { 
font-size: 20px; 
margin-bottom: 16px; 
 } 

.main-visual-title { 
font-size: 42px; 
line-height: 1.2; 
 } 

.main-visual-title span { 
margin-top: 8px; 
 } 

.main-visual-desc { 
margin-top: 18px; 
font-size: 17px; 
line-height: 1.6; 
 } 

.main-visual-btn-wrap { 
flex-direction: column; 
gap: 12px; 
margin-top: 34px; 
 } 

.main-visual-btn { 
width: 100%; 
min-width: 0; 
height: 58px; 
font-size: 16px; 
 } 
 } 

@media screen and (max-width: 480px) { 
.main-visual { 
padding: 80px 16px 60px; 
 } 

.main-visual-title { 
font-size: 34px; 
 } 

.main-visual-subtitle { 
font-size: 17px; 
 } 

.main-visual-desc { 
font-size: 15px; 
 } 
 } 

/********************************************
landing header
*********************************************/
html { 
scroll-behavior: smooth; 
 } 

body.page-aihome2 { 
background: #fff; 
 } 

body.page-aihome2.is-landing-menu-open { 
overflow: hidden; 
 } 

.landing-section-anchor { 
scroll-margin-top: 120px; 
 } 

.aihome-landing { 
position: relative; 
background: #fff; 
 } 

.landing-header { 
position: fixed; 
top: 16px; 
left: 0; 
width: 100%; 
z-index: 1000; 
pointer-events: none; 
 } 

.landing-header-inner { 
pointer-events: auto; 
display: flex; 
align-items: center; 
justify-content: space-between; 
gap: 18px; 
max-width: 1600px; 
min-height: 70px; 
margin: 0 auto; 
padding: 14px 14px 14px 50px; 
border: 1px solid rgba(17, 24, 39, 0.08); 
border-radius: 999px; 
background: rgba(255, 255, 255, 0.9); 
box-shadow: 0 14px 40px rgba(15, 23, 42, 0.08); 
backdrop-filter: blur(18px); 
 } 

.landing-header-brand { 
display: inline-flex; 
align-items: center; 
gap: 10px; 
color: #111; 
text-decoration: none; 
white-space: nowrap; 
 } 

.landing-header-brand-mark { 
display: inline-flex; 
align-items: center; 
justify-content: center; 
min-width: 64px; 
height: 40px; 
padding: 0 14px; 
border-radius: 999px; 
background: #111; 
color: #fff; 
font-size: 13px; 
font-weight: 800; 
letter-spacing: 0.08em; 
 } 

.landing-header-brand-text { 
font-size: 24px; 
font-weight: 700; 
letter-spacing: -0.02em; 
 } 

.landing-header-nav { 
display: flex; 
align-items: center; 
gap: 8px; 
 } 

.landing-header-link { 
display: inline-flex; 
align-items: center; 
justify-content: center; 
height: 44px; 
padding: 0 18px; 
border-radius: 999px; 
color: #475467; 
font-size: 15px; 
font-weight: 700; 
text-decoration: none; 
letter-spacing: -0.02em; 
transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease; 
 } 

/* .landing-header-link:hover, */
.landing-header-link.is-active { 
background: rgb(156 156 156 / 12%); 
color: #111; 
transform: translateY(-1px); 
 } 

.landing-header-actions { 
display: flex; 
align-items: center; 
gap: 12px; 
 } 

.landing-header-cta,
.landing-mobile-cta { 
display: inline-flex; 
align-items: center; 
justify-content: center; 
min-width: 136px; 
height: 48px; 
padding: 0 20px; 
border-radius: 999px; 
background: #05e348; 
color: #000; 
font-size: 15px; 
font-weight: 700; 
text-decoration: none; 
letter-spacing: -0.02em; 
transition: transform 0.25s ease, box-shadow 0.25s ease; 
/* box-shadow: 0 14px 30px rgba(17, 17, 17, 0.16); */
 } 

.landing-header-cta:hover,
.landing-mobile-cta:hover { 
transform: translateY(-2px); 
 } 

.landing-header-toggle { 
display: none; 
position: relative; 
width: 48px; 
height: 48px; 
padding: 0; 
border: 0; 
border-radius: 50%; 
background: #111; 
cursor: pointer; 
 } 

.landing-header-toggle-line { 
position: absolute; 
left: 50%; 
width: 18px; 
height: 2px; 
border-radius: 999px; 
background: #fff; 
transform: translateX(-50%); 
transition: transform 0.25s ease, opacity 0.25s ease, top 0.25s ease; 
 } 

.landing-header-toggle-line:nth-child(1) { 
top: 17px; 
 } 

.landing-header-toggle-line:nth-child(2) { 
top: 23px; 
 } 

.landing-header-toggle-line:nth-child(3) { 
top: 29px; 
 } 

.landing-header.is-menu-open .landing-header-toggle-line:nth-child(1) { 
top: 23px; 
transform: translateX(-50%) rotate(45deg); 
 } 

.landing-header.is-menu-open .landing-header-toggle-line:nth-child(2) { 
opacity: 0; 
 } 

.landing-header.is-menu-open .landing-header-toggle-line:nth-child(3) { 
top: 23px; 
transform: translateX(-50%) rotate(-45deg); 
 } 

.landing-mobile-dim { 
position: fixed; 
inset: 0; 
background: rgba(15, 23, 42, 0.45); 
opacity: 0; 
visibility: hidden; 
pointer-events: auto; 
transition: opacity 0.25s ease, visibility 0.25s ease; 
 } 

.landing-mobile-menu { 
position: fixed; 
top: 16px; 
right: 16px; 
width: min(360px, calc(100% - 32px)); 
padding: 20px; 
border-radius: 28px; 
background: rgba(255, 255, 255, 0.98); 
box-shadow: 0 24px 60px rgba(15, 23, 42, 0.18); 
opacity: 0; 
visibility: hidden; 
transform: translateY(-12px); 
pointer-events: auto; 
transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease; 
 } 

.landing-mobile-head { 
display: flex; 
align-items: center; 
justify-content: space-between; 
gap: 12px; 
margin-bottom: 18px; 
 } 

.landing-mobile-title { 
font-size: 18px; 
font-weight: 800; 
color: #111; 
letter-spacing: -0.03em; 
 } 

.landing-mobile-close { 
display: inline-flex; 
align-items: center; 
justify-content: center; 
height: 38px; 
padding: 0 14px; 
border: 1px solid rgba(17, 24, 39, 0.1); 
border-radius: 999px; 
background: #fff; 
color: #111; 
font-size: 13px; 
font-weight: 700; 
cursor: pointer; 
 } 

.landing-mobile-nav { 
display: flex; 
flex-direction: column; 
gap: 8px; 
 } 

.landing-mobile-link { 
display: flex; 
align-items: center; 
justify-content: space-between; 
min-height: 54px; 
padding: 0 18px; 
border-radius: 18px; 
background: #f8fafc; 
color: #344054; 
font-size: 16px; 
font-weight: 700; 
text-decoration: none; 
letter-spacing: -0.03em; 
transition: background 0.25s ease, color 0.25s ease; 
 } 

.landing-mobile-link.is-active { 
background: rgba(5, 227, 72, 0.12); 
color: #111; 
 } 

.landing-mobile-cta { 
width: 100%; 
margin-top: 18px; 
 } 

.landing-header.is-scrolled .landing-header-inner { 
box-shadow: 0 18px 44px rgba(15, 23, 42, 0.12); 
 } 

.landing-header.is-menu-open .landing-mobile-dim,
.landing-header.is-menu-open .landing-mobile-menu { 
opacity: 1; 
visibility: visible; 
 } 

.landing-header.is-menu-open .landing-mobile-menu { 
transform: translateY(0); 
 } 

.main-visual { 
padding-top: 180px; 
 } 

.main-visual-inner { 
/* min-height: 820px;  */
 } 

.hero-scroll-indicator { 
position: absolute; 
left: 50%; 
bottom: 34px; 
z-index: 4; 
display: inline-flex; 
align-items: center; 
gap: 12px; 
color: #111; 
text-decoration: none; 
font-size: 13px; 
font-weight: 800; 
letter-spacing: 0.12em; 
transform: translateX(-50%); 
 } 

.hero-scroll-indicator-icon { 
position: relative; 
width: 22px; 
height: 34px; 
border: 2px solid rgba(17, 17, 17, 0.8); 
border-radius: 999px; 
 } 

.hero-scroll-indicator-icon::before { 
content: ""; 
position: absolute; 
top: 7px; 
left: 50%; 
width: 4px; 
height: 7px; 
border-radius: 999px; 
background: rgba(17, 17, 17, 0.75); 
transform: translateX(-50%); 
animation: landing-scroll-pulse 1.8s infinite; 
 } 

@keyframes landing-scroll-pulse { 
0% { 
opacity: 0; 
transform: translateX(-50%) translateY(0); 
 } 

25%,
75% { 
opacity: 1; 
 } 

100% { 
opacity: 0; 
transform: translateX(-50%) translateY(10px); 
 } 
 } 

@media screen and (max-width: 1180px) { 
.landing-header-inner { 
padding-left: 16px; 
padding-right: 16px; 
 } 

.landing-header-link { 
padding: 0 14px; 
font-size: 14px; 
 } 

.landing-header-cta { 
min-width: 120px; 
 } 
 } 

@media screen and (max-width: 980px) { 
.landing-header { 
top: 10px; 
padding: 0 16px; 
 } 

.landing-header-inner { 
min-height: 68px; 
padding: 10px 14px; 
border-radius: 24px; 
 } 

.landing-header-nav,
.landing-header-cta { 
display: none; 
 } 

.landing-header-toggle { 
display: inline-flex; 
 } 

.main-visual { 
padding-top: 132px; 
 } 

.hero-scroll-indicator { 
bottom: 20px; 
 } 
 } 

@media screen and (max-width: 900px) { 
.main-visual { 
padding-top: 132px; 
 } 

.hero-scroll-indicator { 
gap: 10px; 
font-size: 11px; 
 } 

.hero-scroll-indicator-icon { 
width: 20px; 
height: 30px; 
 } 
 } 

@media screen and (max-width: 480px) { 
.landing-header { 
padding: 0 12px; 
 } 

.landing-header-inner { 
min-height: 62px; 
padding: 10px 12px; 
 } 

.landing-header-brand-mark { 
min-width: 56px; 
height: 34px; 
font-size: 11px; 
 } 

.landing-header-brand-text { 
font-size: 15px; 
 } 

.landing-mobile-menu { 
top: 10px; 
right: 12px; 
width: calc(100% - 24px); 
padding: 18px; 
border-radius: 22px; 
 } 

.main-visual { 
padding-top: 118px; 
 } 

.hero-scroll-indicator { 
bottom: 16px; 
 } 
 } 




/********************************************
AI 홈페이지 제작 단계 
*********************************************/
.page-wrap { width: 100%; min-height: 100vh; background: linear-gradient(180deg, #ffffff 0%, #f5f5f5 100%); } 

.aistep-scroll-wrap { position: relative; height: 440vh; } 

.aistep-swiper-section { display: none; } 

.aistep-sticky { position: sticky; top: 0; min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 28px 24px; overflow: hidden; } 

.aistep-card { position: relative; width: min(100%, 1480px); min-height: 92vh; padding: 0 16px; display: flex; align-items: center; justify-content: space-between; gap: 40px; overflow: hidden; } 

.aistep-card::before { content: ''; position: absolute; inset: 0; pointer-events: none; } 

.aistep-left { position: relative; z-index: 2; width: 44%; min-width: 320px; } 

.aistep-head { position: relative; z-index: 3; width: 100%; max-width: 1200px; margin: 0 auto 40px; padding: 100px 24px 0; text-align: center; } 

.aistep-label { display: inline-block; margin-bottom: 18px; font-size: 20px; font-weight: 700; color: #111111; letter-spacing: -0.01em; } 

.aistep-copy { margin: 0; font-size: 60px; line-height: 1.4; letter-spacing: -0.06em; font-weight: 800; color: #111111; word-break: keep-all; } 

.aistep-left { position: relative; z-index: 2; width: 44%; min-width: 320px; } 
/* .accent-wave { display: inline-block; background: linear-gradient(
90deg,
#30d1bc 0%,
#00e35e 22%,
#4f8de6 48%,
#7e6ff6 72%,
#30d1bc 100%
); background-size: 220% 100%; background-position: 0% 50%; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; color: transparent; animation: wave-gradient 6s ease-in-out infinite; } 
*/
.aistep-list { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 24px; } 

.aistep-item { position: relative; display: flex; flex-direction: column; align-items: flex-start; gap: 12px; font-size: clamp(20px, 2.8vw, 44px); line-height: 1.14; letter-spacing: -0.06em; font-weight: 700; color: rgba(60, 52, 56, 0.15); transition: color 0.5s ease, opacity 0.5s ease, transform 0.5s ease; word-break: keep-all; } 

.aistep-item-text-wrap { position: relative; } 
.aistep-step { display: inline-flex; align-items: center; justify-content: center; min-width: 96px; height: 34px; padding: 0 14px; margin-bottom: 8px; border-radius: 999px; background: rgba(0, 0, 0, .08); /* background: linear-gradient(90deg, #21db4b 0%, #10c93f 100%); */ color: #ffffff; font-size: 13px; line-height: 1; letter-spacing: 0; font-weight: 800; transition: background 0.4s ease, color 0.4s ease, box-shadow 0.4s ease; } 

.aistep-item-text { display: block; } 

.aistep-item.is-active { color: #111111; transform: translateX(0); } 

.aistep-item.is-dim { color: rgba(60, 52, 56, 0.15); } 

.aistep-item.is-active .aistep-step { background: linear-gradient(90deg, #21db4b 0%, #10c93f 100%); color: #ffffff; box-shadow: 0 8px 20px rgba(33, 219, 75, 0.25); } 

.aistep-right { position: relative; z-index: 2; width: 56%; min-height: 520px; display: flex; align-items: center; justify-content: center;  cursor: none;  overflow: hidden;} 

.aistep-right {
  position: relative;
  z-index: 2;
  width: 56%;
  min-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: none;
  overflow: hidden;
}

/* 스크롤 가이드 */
.scroll-guide {
  position: absolute;
  left: 0;
  top: 0;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  pointer-events: none;
  z-index: 30;
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: opacity 0.2s ease;
}

.aistep-right.is-cursor-active .scroll-guide {
  opacity: 1;
}

.scroll-guide-mouse {
  position: relative;
  display: block;
  width: 30px;
  height: 42px;
  border: 2px solid #4b4b4b;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.7);
  box-sizing: border-box;
}

.scroll-guide-wheel {
  position: absolute;
  left: 50%;
  top: 8px;
  width: 5px;
  height: 9px;
  margin-left: -2.5px;
  border-radius: 999px;
  background: #4b4b4b;
  animation: scrollWheelMove 1.4s ease-in-out infinite;
}

.scroll-guide-text {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: #222;
  line-height: 1;
  white-space: nowrap;
}

@keyframes scrollWheelMove {
  0% {
    opacity: 0;
    transform: translateY(0);
  }
  20% {
    opacity: 1;
    transform: translateY(0);
  }
  70% {
    opacity: 1;
    transform: translateY(10px);
  }
  100% {
    opacity: 0;
    transform: translateY(12px);
  }
}

.aistep-visual-stage { 
   position: relative;
  width: 100%;
  min-height: 520px;
  height: 100%;
  border-radius: 28px;
  overflow-y: auto;
  overflow-x: hidden;
  background: #ececec;

  /* 스크롤바 숨기기 */
  -ms-overflow-style: none;
  scrollbar-width: none; } 

.aistep-visual { position: absolute; inset: 0; opacity: 0; transform: scale(1.06); transition: opacity 0.6s ease, transform 0.6s ease; pointer-events: none; } 

.aistep-visual.is-active { opacity: 1; transform: scale(1); } 

.aistep-visual img,
.aistep-visual video { display: block; width: 100%; height: 100%; object-fit: cover; } 

/* .aistep-floating-star { position: absolute; width: 20px; height: 20px; background: radial-gradient(circle, #7fe6ff 0%, #4dcbff 55%, rgba(77, 203, 255, 0) 70%); clip-path: polygon(50% 0%, 61% 35%, 100% 50%, 61% 65%, 50% 100%, 39% 65%, 0% 50%, 39% 35%); opacity: 0.9; animation: star-float 2.8s ease-in-out infinite; z-index: 2; } 

.aistep-floating-star.star-a { left: 30%; top: 24%; } 

.aistep-floating-star.star-b { right: 24%; top: 30%; animation-delay: 0.3s; } 

.aistep-floating-star.star-c { left: 36%; bottom: 26%; animation-delay: 0.6s; } 
*/
.aistep-progress-bar { position: absolute; left: 56px; right: 56px; bottom: 34px; height: 6px; border-radius: 999px; background: rgba(17, 17, 17, 0.06); overflow: hidden; z-index: 3; } 

.aistep-progress-fill { width: 0%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, #1bdc4a 0%, #7e6ff6 100%); transition: width 0.2s linear; } 

.aistep-head-mobile { margin-bottom: 28px; padding-top: 80px; } 

.aistep-mobile-swiper { width: 100%; padding: 0 24px 90px; overflow: hidden; } 

.aistep-mobile-card { min-height: 100%; border-radius: 28px; overflow: hidden; background: #ffffff; box-shadow: 0 24px 54px rgba(17, 24, 39, 0.10); } 

.aistep-mobile-visual { position: relative; min-height: 420px; background: #ececec; } 

.aistep-mobile-visual img { display: block; width: 100%; height: 100%; object-fit: cover; } 

.aistep-mobile-body { padding: 24px 24px 28px; } 

.aistep-mobile-title { margin: 14px 0 0; font-size: clamp(24px, 4.2vw, 36px); line-height: 1.3; letter-spacing: -0.05em; font-weight: 800; color: #111111; word-break: keep-all; } 

.aistep-mobile-controls { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 24px; } 

.aistep-mobile-pagination { position: static; display: flex; align-items: center; gap: 8px; } 

.aistep-mobile-pagination .swiper-pagination-bullet { width: 10px; height: 10px; margin: 0 !important; background: rgba(17, 17, 17, 0.18); opacity: 1; } 

.aistep-mobile-pagination .swiper-pagination-bullet-active { width: 28px; border-radius: 999px; background: linear-gradient(90deg, #1bdc4a 0%, #7e6ff6 100%); } 

.aistep-mobile-navigation { display: flex; align-items: center; gap: 10px; } 

.aistep-mobile-nav-btn { width: 48px; height: 48px; border: 1px solid rgba(17, 24, 39, 0.10); border-radius: 999px; background: #ffffff; color: #111111; font-size: 18px; cursor: pointer; box-shadow: 0 10px 24px rgba(17, 24, 39, 0.06); transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease; } 

.aistep-mobile-nav-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(17, 24, 39, 0.10); } 

.aistep-mobile-nav-btn.swiper-button-disabled { opacity: 0.35; cursor: default; pointer-events: none; } 

@keyframes star-float { 
0% { transform: translateY(0px) scale(1); } 
50% { transform: translateY(-8px) scale(1.08); } 
100% { transform: translateY(0px) scale(1); } 
 } 

@keyframes wave-gradient { 
0% { background-position: 0% 50%; } 
50% { background-position: 100% 50%; } 
100% { background-position: 0% 50%; } 
 } 

@media (max-width: 1280px) { 
.aistep-card { min-height: 74vh; padding: 54px 44px; } 

.aistep-left { width: 46%; } 

.aistep-right { width: 54%; } 

.aistep-copy { font-size: 48px; } 
 } 

@media (max-width: 980px) { 
.aistep-scroll-wrap { display: none; } 

.aistep-swiper-section { display: block; } 

.aistep-head-mobile { padding-left: 20px; padding-right: 20px; } 

.aistep-copy { font-size: 34px; } 

.aistep-mobile-swiper { padding: 0 20px 84px; } 

.aistep-mobile-visual { min-height: 420px; } 

.aistep-mobile-title { font-size: clamp(22px, 4.8vw, 34px); } 
 } 

@media (max-width: 767px) { 
.aistep-head-mobile { padding: 56px 16px 0; margin-bottom: 20px; } 

.aistep-label { margin-bottom: 14px; font-size: 13px; } 

.aistep-copy { font-size: 28px; } 

.aistep-mobile-swiper { padding: 0 16px 74px; } 

.aistep-mobile-card { border-radius: 22px; } 

.aistep-mobile-visual { min-height: 320px; } 

.aistep-mobile-body { padding: 20px 20px 24px; } 

.aistep-mobile-title { margin-top: 12px; font-size: clamp(20px, 7vw, 30px); line-height: 1.28; } 

.aistep-mobile-controls { margin-top: 20px; } 

.aistep-mobile-nav-btn { width: 42px; height: 42px; font-size: 16px; } 
 } 

@media (max-width: 480px) { 
.aistep-head-mobile { padding: 48px 16px 0; } 

.aistep-copy { font-size: 24px; } 

.aistep-mobile-visual { min-height: 250px; } 

.aistep-mobile-body { padding: 18px 18px 22px; } 

.aistep-mobile-title { font-size: 18px; } 

.aistep-step { min-width: 76px; height: 28px; padding: 0 10px; font-size: 10px; } 
 } 

@media (max-width: 320px) { 
.aistep-head-mobile { padding: 40px 12px 0; } 

.aistep-copy { font-size: 22px; } 

.aistep-mobile-swiper { padding-left: 12px; padding-right: 12px; } 

.aistep-mobile-title { font-size: 17px; } 
 } 

@media (max-width: 980px) { 
.aistep-scroll-wrap { height: auto; } 

.aistep-sticky { position: relative; top: auto; min-height: auto; padding: 0 20px 100px; } 

.aistep-card { min-height: auto; padding: 34px 24px 84px; flex-direction: column; align-items: flex-start; gap: 26px; } 

.aistep-left,
.aistep-right { width: 100%; min-width: 0; } 

.aistep-copy { font-size: 34px; } 

.aistep-list { gap: 18px; } 

.aistep-item { font-size: clamp(22px, 4.8vw, 40px); } 

.aistep-right { min-height: 420px; } 

.aistep-visual-stage { min-height: 420px; } 

.aistep-progress-bar { left: 24px; right: 24px; } 
 } 

@media (max-width: 767px) { 
.aistep-sticky { padding: 0 16px 84px; } 

.aistep-card { padding: 26px 18px 74px; } 

.aistep-head { padding: 56px 16px 0; margin-bottom: 20px; } 

.aistep-label { margin-bottom: 14px; font-size: 13px; } 

.aistep-copy { font-size: 28px; } 
.aistep-item { gap: 10px; font-size: clamp(20px, 7vw, 34px); line-height: 1.18; } 

.aistep-step { min-width: 82px; height: 30px; padding: 0 12px; font-size: 11px; background: linear-gradient(90deg, #21db4b 0%, #10c93f 100%); } 

.aistep-right { min-height: 290px; } 

.aistep-visual-stage { min-height: 290px; border-radius: 20px; } 

.aistep-floating-star { width: 16px; height: 16px; } 

.aistep-progress-bar { bottom: 20px; height: 5px; } 
 } 

@media (max-width: 480px) { 
.aistep-card { padding: 22px 16px 70px; } 

.aistep-head { padding: 48px 16px 0; } 

.aistep-copy { font-size: 24px; } 

.aistep-item { font-size: 18px; } 

.aistep-step { min-width: 76px; height: 28px; padding: 0 10px; font-size: 10px; } 

.aistep-right,
.aistep-visual-stage { min-height: 250px; } 
 } 

@media (max-width: 320px) { 
.aistep-sticky { padding-left: 12px; padding-right: 12px; } 

.aistep-card { padding: 20px 12px 64px; } 

.aistep-left { min-width: 0; } 

.aistep-head { padding: 40px 12px 0; } 

.aistep-copy { font-size: 22px; } 
.aistep-item { font-size: 17px; } 

.aistep-step { min-width: 72px; font-size: 10px; } 
 } 


/********************************************
장점
*********************************************/
.space-visual-section { 
 padding: 90px 0 110px; 
 background: #f3f3f3; 
 } 

.space-visual-inner { 
 max-width: 1280px; 
 margin: 0 auto; 
 padding: 0 24px; 
 box-sizing: border-box; 
 } 

.space-visual-head { 
 margin-bottom: 38px; 
 } 

.space-visual-eyebrow { 
 margin: 0 0 10px; 
 font-size: 34px; 
 line-height: 1.1; 
 font-weight: 500; 
 color: #05e348; 
 letter-spacing: -0.04em; 
 } 

.space-visual-title { 
 margin: 0; 
 font-size: 46px; 
 line-height: 1.3; 
 font-weight: 700; 
 color: #222; 
 letter-spacing: -0.05em; 
 } 

.space-visual-grid { 
 display: grid; 
 grid-template-columns: 1fr 1fr; 
 gap: 18px; 
 } 

.space-card { 
 position: relative; 
 overflow: hidden; 
 border-radius: 22px; 
 background: #ececef; 
 min-height: 250px; 
 padding: 34px 32px; 
 box-sizing: border-box; 
 display: flex; 
 justify-content: space-between; 
 } 

.space-card-lg { 
 grid-row: span 2; 
 min-height: 520px; 
 } 

.space-card-md { 
 min-height: 166px; 
 } 

.space-card-text { 
 position: relative; 
 z-index: 2; 
 max-width: 52%; 
 } 

.space-card-lg .space-card-text { 
 max-width: 55%; 
 } 

.space-card h3 { 
 margin: 0; 
 font-size: 24px; 
 line-height: 1.45; 
 font-weight: 700; 
 color: #222; 
 letter-spacing: -0.05em; 
 } 

.space-card p { 
 margin: 18px 0 0; 
 font-size: 17px; 
 line-height: 1.65; 
 color: #5e6572; 
 letter-spacing: -0.04em; 
 } 

.space-card-link { 
 position: relative; 
 display: inline-block; 
 margin-top: 20px; 
 padding-right: 18px; 
 font-size: 17px; 
 line-height: 1.4; 
 font-weight: 500; 
 color: #707786; 
 text-decoration: none; 
 letter-spacing: -0.03em; 
 } 

.space-card-link::after { 
 content: ""; 
 position: absolute; 
 right: 0; 
 top: 50%; 
 width: 7px; 
 height: 7px; 
 border-top: 1.5px solid #8a919d; 
 border-right: 1.5px solid #8a919d; 
 transform: translateY(-50%) rotate(45deg); 
 } 

.space-card-art { 
 position: absolute; 
 right: 0; 
 bottom: 0; 
 pointer-events: none; 
 z-index: 1; 
 } 

.space-card-art img { 
 display: block; 
 width: 100%; 
 height: auto; 
 } 

/* 카드별 이미지 위치/크기 */
.space-card-art-phone { 
 right: 34px; 
 bottom: 0; 
/* width: 174px; */
 } 

.space-card-art-chart { 
 right: 28px; 
 bottom: 0; 
 width: 190px; 
 } 

.space-card-art-security { 
 right: 34px; 
 bottom: 26px; 
 width: 192px; 
 } 

.space-card-art-integration { 
 right: 28px; 
 bottom: 0; 
 width: 190px; 
 } 

.space-card-art-service { 
 right: 34px; 
 bottom: 0; 
 width: 200px; 
 } 

/* tablet */
@media screen and (max-width: 1024px) { 
 .space-visual-section { 
 padding: 72px 0 88px; 
 } 

 .space-visual-eyebrow { 
 font-size: 28px; 
 } 

 .space-visual-title { 
 font-size: 46px; 
 } 

 .space-card { 
 padding: 28px 24px; 
 } 

 .space-card h3 { 
 font-size: 21px; 
 } 

 .space-card p,
 .space-card-link { 
 font-size: 15px; 
 } 

 .space-card-text { 
 max-width: 58%; 
 } 

 .space-card-lg { 
 min-height: 470px; 
 } 

 .space-card-art-phone { 
 width: 150px; 
 right: 24px; 
 } 

 .space-card-art-chart { 
 width: 158px; 
 right: 18px; 
 } 

 .space-card-art-security { 
 width: 168px; 
 right: 22px; 
 bottom: 20px; 
 } 

 .space-card-art-integration { 
 width: 170px; 
 right: 18px; 
 } 

 .space-card-art-service { 
 width: 120px; 
 right: 24px; 
 } 
 } 

/* mobile */
@media screen and (max-width: 768px) { 
 .space-visual-inner { 
 padding: 0 16px; 
 } 

 .space-visual-head { 
 margin-bottom: 26px; 
 } 

 .space-visual-eyebrow { 
 font-size: 22px; 
 margin-bottom: 8px; 
 } 

 .space-visual-title { 
 font-size: 34px; 
 line-height: 1.22; 
 } 

 .space-visual-grid { 
 grid-template-columns: 1fr; 
 gap: 14px; 
 } 

 .space-card,
 .space-card-lg,
 .space-card-md { 
 min-height: auto; 
 padding: 26px 22px 210px; 
 display: block; 
 } 

 .space-card-text,
 .space-card-lg .space-card-text { 
 max-width: 100%; 
 } 

 .space-card h3 { 
 font-size: 24px; 
 } 

 .space-card p { 
 font-size: 15px; 
 margin-top: 14px; 
 } 

 .space-card-link { 
 font-size: 15px; 
 margin-top: 16px; 
 } 

 .space-card-art-phone { 
 width: 150px; 
 right: 12px; 
 bottom: 0; 
 } 

 .space-card-art-chart { 
 width: 160px; 
 right: 10px; 
 bottom: 0; 
 } 

 .space-card-art-security { 
 width: 168px; 
 right: 12px; 
 bottom: 20px; 
 } 

 .space-card-art-integration { 
 width: 162px; 
 right: 8px; 
 bottom: 0; 
 } 

 .space-card-art-service { 
 width: 118px; 
 right: 18px; 
 bottom: 0; 
 } 
 } 

@media screen and (max-width: 480px) { 
 .space-visual-section { 
 padding: 58px 0 72px; 
 } 

 .space-visual-eyebrow { 
 font-size: 19px; 
 } 

 .space-visual-title { 
 font-size: 28px; 
 } 

 .space-card,
 .space-card-lg,
 .space-card-md { 
 padding: 22px 18px 188px; 
 border-radius: 18px; 
 } 

 .space-card h3 { 
 font-size: 21px; 
 } 

 .space-card p,
 .space-card-link { 
 font-size: 14px; 
 } 

 .space-card-art-phone { 
 width: 128px; 
 right: 6px; 
 } 

 .space-card-art-chart { 
 width: 138px; 
 right: 4px; 
 } 

 .space-card-art-security { 
 width: 146px; 
 right: 6px; 
 bottom: 16px; 
 } 

 .space-card-art-integration { 
 width: 142px; 
 right: 2px; 
 } 

 .space-card-art-service { 
 width: 102px; 
 right: 10px; 
 } 
 } 

/********************************************
포트폴리오
*********************************************/
.portfolio-section { position: relative; padding: 140px 0; background:
radial-gradient(circle at 8% 18%, rgba(126, 211, 255, 0.16), transparent 24%),
radial-gradient(circle at 88% 12%, rgba(179, 160, 255, 0.14), transparent 22%),
linear-gradient(180deg, #f8fbff 0%, #f3f7fb 50%, #f9fbfd 100%); overflow: hidden; } 

.portfolio-inner { width: 100%; max-width: 1280px; margin: 0 auto; padding:0 16px; } 

.portfolio-head { max-width: 900px; margin: 0 auto; text-align: center; } 

.portfolio-label { margin: 0 0 10px; 
 font-size: 34px; 
 line-height: 1.1; 
 font-weight: 500; 
 color: #05e348; 
 letter-spacing: -0.04em; } 

.portfolio-title { margin: 22px 0 0; font-size: clamp(28px, 4.2vw, 46px); line-height: 1.3; letter-spacing: -0.06em; font-weight: 700; color: #111827; word-break: keep-all; } 

.portfolio-desc { margin: 20px auto 0; max-width: 760px; font-size: clamp(16px, 1.15vw, 19px); line-height: 1.8; letter-spacing: -0.03em; color: #667085; word-break: keep-all; } 

.portfolio-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-top: 52px; margin-bottom: 40px; flex-wrap: wrap; background-color: #fff; padding: 20px 22px; border-radius: 100px; } 

.portfolio-tab-list { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 0; padding: 0; list-style: none; } 

.portfolio-tab-item { margin: 0; padding: 0; } 

.portfolio-tab-link { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 18px; border: 1px solid rgba(17, 24, 39, 0.08); border-radius: 999px; background: rgba(255, 255, 255, 0.85); color: #475467; font-size: 15px; font-weight: 700; letter-spacing: -0.02em; text-decoration: none; box-shadow: 0 8px 24px rgba(17, 24, 39, 0.04); transition: all 0.25s ease; } 

.portfolio-tab-link:hover { transform: translateY(-2px); color: #2855e0; border-color: rgba(40, 85, 224, 0.18); } 

.portfolio-tab-link.is-active { width: 100%; color: #ffffff; border-color: transparent; background: linear-gradient(90deg, #05e348 0%, #5c7cff 100%); box-shadow: 0 12px 28px rgba(92, 124, 255, 0.18); } 

.portfolio-more-link { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 18px; border-radius: 999px; background: #ffffff; border: 1px solid rgba(17, 24, 39, 0.08); color: #111827; font-size: 15px; font-weight: 700; text-decoration: none; box-shadow: 0 8px 24px rgba(17, 24, 39, 0.04); transition: all 0.25s ease; } 

.portfolio-more-link:hover { transform: translateY(-2px); color: #2855e0; border-color: rgba(40, 85, 224, 0.18); } 

.portfolio-masonry { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; align-items: start; margin: 0; padding: 0; list-style: none; } 

.portfolio-item { margin: 0; padding: 0; } 

.portfolio-item.is-hidden { display: none; } 

.portfolio-card { position: relative; border-radius: 10px; overflow: hidden; background: rgba(255, 255, 255, 0.82); border: 1px solid rgba(255, 255, 255, 0.92); box-shadow:
0 18px 44px rgba(17, 24, 39, 0.06),
inset 0 1px 0 rgba(255, 255, 255, 0.7); backdrop-filter: blur(14px); transition: transform 0.35s ease, box-shadow 0.35s ease; } 

.portfolio-card:hover { transform: translateY(-8px); box-shadow:
0 26px 56px rgba(17, 24, 39, 0.10),
inset 0 1px 0 rgba(255, 255, 255, 0.85); } 

.portfolio-card::before { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 1; } 

.portfolio-item-1 .portfolio-card::before { background: linear-gradient(180deg, rgba(255, 204, 223, 0.24) 0%, rgba(255,255,255,0) 55%); } 

.portfolio-item-2 .portfolio-card::before { background: linear-gradient(180deg, rgba(191, 228, 255, 0.24) 0%, rgba(255,255,255,0) 55%); } 

.portfolio-item-3 .portfolio-card::before { background: linear-gradient(180deg, rgba(230, 203, 255, 0.24) 0%, rgba(255,255,255,0) 55%); } 

.portfolio-item-4 .portfolio-card::before { background: linear-gradient(180deg, rgba(201, 255, 236, 0.22) 0%, rgba(255,255,255,0) 55%); } 

.portfolio-item-5 .portfolio-card::before { background: linear-gradient(180deg, rgba(255, 229, 191, 0.24) 0%, rgba(255,255,255,0) 55%); } 

.portfolio-item-6 .portfolio-card::before { background: linear-gradient(180deg, rgba(213, 224, 255, 0.24) 0%, rgba(255,255,255,0) 55%); } 

.portfolio-card-link { position: relative; z-index: 2; display: block; color: inherit; text-decoration: none; } 

.portfolio-card-thumb { position: relative; /* padding: 12px 20px 10px; */ min-height: 220px; display: flex; align-items: center; justify-content: center; } 

.portfolio-card-thumb img { display: block; width: 100%; /* max-width: 210px; */
height: auto; object-fit: contain; transition: transform 0.4s ease; } 

.portfolio-card:hover .portfolio-card-thumb img { transform: translateY(-4px) scale(1.03); } 

.portfolio-card-body { padding: 8px 26px 28px; } 

.portfolio-card-title { margin: 0; font-size: clamp(18px, 1.7vw, 22px); line-height: 1.24; letter-spacing: -0.05em; font-weight: 800; color: #1f2937; word-break: keep-all; } 

.portfolio-card-text { margin: 18px 0 0; font-size: 15px; line-height: 1.75; letter-spacing: -0.02em; color: #667085; word-break: keep-all; } 

.portfolio-video-badge { position: absolute; top: 18px; right: 18px; display: inline-flex; align-items: center; justify-content: center; height: 32px; padding: 0 12px; border-radius: 999px; background: rgba(17, 24, 39, 0.72); color: #ffffff; font-size: 11px; font-weight: 800; letter-spacing: 0.08em; } 

.portfolio-item-1,
.portfolio-item-3,
.portfolio-item-5 { margin-top: 0; } 

.portfolio-item-2 { margin-top: 38px; } 

.portfolio-item-4 { margin-top: -22px; } 

.portfolio-item-5 { margin-top: -8px; } 

.portfolio-item-6 { margin-top: 30px; } 

.portfolio-load-more { display: flex; justify-content: center; margin-top: 44px; } 

.portfolio-load-more[hidden] { display: none; } 

.portfolio-load-more-btn { display: inline-flex; align-items: center; justify-content: center; min-width: 180px; min-height: 56px; padding: 0 28px; border: 0; border-radius: 999px; background: linear-gradient(90deg, #05e348 0%, #5c7cff 100%); color: #ffffff; font-size: 16px; font-weight: 800; letter-spacing: -0.02em; box-shadow: 0 16px 32px rgba(92, 124, 255, 0.22); cursor: pointer; transition: transform 0.25s ease, box-shadow 0.25s ease; } 

.portfolio-load-more-btn:hover { transform: translateY(-2px); box-shadow: 0 20px 40px rgba(92, 124, 255, 0.28); } 

.portfolio-load-more-btn[hidden] { display: none; } 

@media screen and (max-width:1500px) { 
.portfolio-toolbar { border-radius: 12px; } 
 } 

@media (max-width: 1280px) { 
.portfolio-section { padding: 120px 20px; } 

.portfolio-card-thumb { min-height: 200px; } 

.portfolio-item-2 { margin-top: 24px; } 

.portfolio-item-4 { margin-top: 0; } 

.portfolio-item-6 { margin-top: 20px; } 
 } 

@media (max-width: 991px) { 
.portfolio-title { font-size: clamp(30px, 5.8vw, 46px); } 

.portfolio-desc { font-size: 15px; } 

.portfolio-toolbar { margin-top: 40px; margin-bottom: 30px; flex-direction: column; align-items: flex-start; padding: 18px; border-radius: 28px; } 

.portfolio-tab-list { width: 100%; flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; scrollbar-width: thin; padding-bottom: 6px; } 

.portfolio-tab-list::-webkit-scrollbar { height: 6px; } 

.portfolio-tab-list::-webkit-scrollbar-thumb { background: rgba(92, 124, 255, 0.28); border-radius: 999px; } 

.portfolio-tab-item { flex: 0 0 auto; } 

.portfolio-tab-link { white-space: nowrap; } 

.portfolio-more-link { align-self: flex-start; } 

.portfolio-masonry { grid-template-columns: repeat(2, minmax(0, 1fr)); } 

.portfolio-item-2,
.portfolio-item-4,
.portfolio-item-5,
.portfolio-item-6 { margin-top: 0; } 

.portfolio-item:nth-child(even) { margin-top: 28px; } 
 } 

@media (max-width: 767px) { 
.portfolio-section { padding: 90px 16px; } 

.portfolio-masonry { 
gap: 18px; } 

.portfolio-item,
.portfolio-item:nth-child(even) { margin-top: 0; } 

.portfolio-tab-list { gap: 10px; padding-bottom: 4px; } 

.portfolio-tab-link,
.portfolio-more-link { min-height: 42px; height: 42px; padding: 0 16px; font-size: 14px; } 

.portfolio-card { border-radius: 20px; } 

/* .portfolio-card-thumb { min-height: 180px; padding: 24px 24px 8px; } 
*/


.portfolio-card-body { padding: 8px 20px 22px; } 

.portfolio-card-title { font-size: 24px; } 

.portfolio-card-text { font-size: 14px; line-height: 1.7; } 

.portfolio-load-more { margin-top: 36px; } 

.portfolio-load-more-btn { min-width: 160px; min-height: 50px; padding: 0 24px; font-size: 15px; } 
 } 

@media (max-width: 480px) { 
.portfolio-title br,
.portfolio-desc br { display: none; } 

.portfolio-title { font-size: 28px; } 

.portfolio-card-thumb { min-height: 170px; } 

 } 

@media (max-width: 320px) { 
.portfolio-section { padding-left: 12px; padding-right: 12px; } 

.portfolio-title { font-size: 24px; } 

.portfolio-card-body { padding: 8px 16px 18px; } 

.portfolio-card-title { font-size: 21px; } 
 } 



/********************************************
이용약관
*********************************************/
.policy-banner-section {padding: 100px 16px 200px 16px; background: #f8fafc; } 

.policy-banner-inner { width: 100%; max-width: 1280px; margin: 0 auto; } 

.policy-banner-head { margin-bottom: 36px; text-align: center; } 

.policy-banner-title { margin: 0; font-size: clamp(28px, 3vw, 44px); line-height: 1.2; letter-spacing: -0.04em; font-weight: 700; color: #111827; } 

.policy-banner-desc { margin: 14px 0 0; font-size: 16px; line-height: 1.7; letter-spacing: -0.02em; color: #6b7280; } 

.policy-banner-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; } 

.policy-banner-item { display: flex; flex-direction: column; align-items: flex-start; min-height: 100%; padding: 28px 28px 26px; border: 1px solid #e5e7eb; background: #ffffff; box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04); } 

.policy-banner-item-top { width: 100%; margin-bottom: 12px; } 

.policy-banner-item-title { margin: 0; font-size: 20px; line-height: 1.3; letter-spacing: -0.03em; font-weight: 700; color: #111827; } 

.policy-banner-item-text { margin: 0; font-size: 15px; line-height: 1.8; letter-spacing: -0.02em; color: #4b5563; word-break: keep-all; } 

.policy-banner-more { display: inline-flex; align-items: center; justify-content: center; min-width: 120px; height: 42px; margin-top: 22px; padding: 0 18px; border: 1px solid #dbe3f0; border-radius: 999px; background: #ffffff; color: #111827; font-size: 14px; font-weight: 700; text-decoration: none; transition: all 0.25s ease; } 

.policy-banner-more:hover { transform: translateY(-2px); border-color: #c7d2fe; background: #f8fbff; color: #4f46e5; box-shadow: 0 10px 24px rgba(79, 70, 229, 0.08); } 

@media (max-width: 767px) { 
.policy-banner-section { padding: 80px 16px; } 

.policy-banner-list { grid-template-columns: 1fr; } 

.policy-banner-item { padding: 22px 20px; border-radius: 18px; } 

.policy-banner-item-title { font-size: 18px; } 

.policy-banner-item-text { font-size: 14px; line-height: 1.7; } 

.policy-banner-more { min-width: 112px; height: 40px; margin-top: 18px; font-size: 13px; } 
 } 

@media (max-width: 320px) { 
.policy-banner-section { padding-left: 12px; padding-right: 12px; } 

.policy-banner-item { padding: 18px 16px; } 
 } 

/********************************************
버튼 배너 영역 
*********************************************/
.banner-cta-section { 
 position: relative; 
 overflow: hidden; 
 padding: 120px 20px; 
 background: #edf7ef; 
 } 

.banner-cta-bg { 
 position: absolute; 
 inset: 0; 
 z-index: 1; 
 background-repeat: no-repeat; 
 background-position: center center; 
 background-size: cover; 
 background: linear-gradient(135deg, #f3fff6 0%, #dfffe8 35%, #bff7cf 70%, #8eecad 100%); 
 /* 배경 이미지는 여기 넣으면 됨 */
 /* background-image: url('../images/main/banner_bg.jpg'); */
 } 

.banner-cta-section::after { 
 content: ""; 
 position: absolute; 
 inset: 0; 
 z-index: 2; 
 background: rgba(255, 255, 255, 0.08); 
 pointer-events: none; 
 } 

.banner-cta-inner { 
 position: relative; 
 z-index: 3; 
 max-width: 1440px; 
 margin: 0 auto; 
 } 

.banner-cta-content { 
 max-width: 980px; 
 margin: 0 auto; 
 text-align: center; 
 } 

.banner-cta-subtitle { 
 margin: 0 0 18px; 
 font-size: 24px; 
 line-height: 1.4; 
 font-weight: 600; 
 color: #05e348; 
 letter-spacing: -0.03em; 
 } 

.banner-cta-title { 
 margin: 0; 
 font-size: 46px; 
 line-height: 1.3; 
 font-weight: 700; 
 color: #222; 
 letter-spacing: -0.05em; 
 word-break: keep-all; 
 } 

.banner-cta-btn-wrap { 
 display: flex; 
 justify-content: center; 
 align-items: flex-end; 
 gap: 18px; 
 margin-top: 44px; 
 flex-wrap: wrap; 
 } 

.banner-cta-btn { 
 display: inline-flex; 
 align-items: center; 
 justify-content: center; 
 min-width: 260px; 
 height: 68px; 
 padding: 0 34px; 
 border-radius: 999px; 
 font-size: 20px; 
 font-weight: 700; 
 text-decoration: none; 
 letter-spacing: -0.03em; 
 box-sizing: border-box; 
 transition: all 0.3s ease; 
 } 

/* 기본: 채워진 버튼 */
.banner-cta-btn-primary { 
 background: #05e348; 
 border: 2px solid #05e348; 
 color: #111; 
 } 
.banner-cta-btn-primary i { padding-right: 5px; } 
/* hover: 라인 버튼으로 */
.banner-cta-btn-primary:hover { 
 background: transparent; 
 color: #05e348; 
 } 

/* 기본: 라인 버튼 */
.banner-cta-btn-outline { 
 background: #fff; 
 border: 2px solid #05e348; 
 color: #111; 
 } 
.banner-cta-btn-outline i { padding-right: 5px; } 
/* hover: 채워진 버튼으로 */
.banner-cta-btn-outline:hover { 
 background: transparent; 
 color: #111; 
 border: 2px solid #05e348; 
 } 


.banner-cta-btn-bubble-wrap { 
 position: relative; 
 display: inline-flex; 
 flex-direction: column; 
 align-items: center; 
 padding-top: 34px; 
 } 

.banner-cta-btn-bubble { 
 position: absolute; 
 top: 0; 
 left: 50%; 
 transform: translateX(-50%); 
 display: inline-flex; 
 align-items: center; 
 gap: 8px; 
 height: 42px; 
 padding: 0 16px; 
 border-radius: 14px; 
background-color: #ffffffe5;
 box-shadow: 0 10px 24px rgba(0, 0, 0, 0.10); 
 font-size: 15px; 
 font-weight: 700; 
 color: #666; 
 letter-spacing: -0.03em; 
 white-space: nowrap; 
 z-index: 5; 
   animation: bubbleFloat 2s ease-in-out infinite;
  will-change: transform;
 } 
@keyframes bubbleFloat {
  0% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(5px);
  }
  100% {
    transform: translateX(-50%) translateY(0);
  }
}
.banner-cta-btn-bubble::after { 
 content: ""; 
 position: absolute; 
 left: 50%; 
 bottom: -6px; 
 width: 12px; 
 height: 12px; 
 background: rgba(255, 255, 255, 0.96); 
 transform: translateX(-50%) rotate(45deg); 
 border-radius: 2px; 
 } 

.banner-cta-btn-bubble strong { 
 color: #5c7cff; 
 font-weight: 800; 
 } 

.banner-cta-btn-bubble-icon { 
 position: relative; 
 width: 18px; 
 height: 18px; 
 border-radius: 8px; 
 background: linear-gradient(135deg, #cdb7ff 0%, #9f7cff 100%); 
 box-shadow: 0 4px 10px rgba(159, 124, 255, 0.22); 
 flex: 0 0 auto; 
 } 

.banner-cta-btn-bubble-icon::before,
.banner-cta-btn-bubble-icon::after { 
 content: ""; 
 position: absolute; 
 background: #fff; 
 border-radius: 50%; 
 } 

.banner-cta-btn-bubble-icon::before { 
 width: 6px; 
 height: 6px; 
 top: 3px; 
 left: 2px; 
 box-shadow: 8px 0 0 #fff; 
 } 

.banner-cta-btn-bubble-icon::after { 
 width: 14px; 
 height: 7px; 
 left: 2px; 
 bottom: 2px; 
 border-radius: 8px 8px 6px 6px; 
 } 

@media screen and (max-width: 1024px) { 
 .banner-cta-section { 
 padding: 100px 20px; 
 } 

 .banner-cta-subtitle { 
 font-size: 20px; 
 margin-bottom: 14px; 
 } 

 .banner-cta-title { 
 font-size: 38px; 
 } 

 .banner-cta-btn { 
 min-width: 230px; 
 height: 62px; 
 font-size: 18px; 
 } 
 } 

@media screen and (max-width: 768px) { 
 .banner-cta-section { 
 padding: 80px 16px; 
 } 

 .banner-cta-title { 
 font-size: 36px; 
 line-height: 1.3; 
 } 

 .banner-cta-subtitle { 
 font-size: 18px; 
 } 

 .banner-cta-btn-wrap { 
 flex-direction: column; 
 gap: 14px; 
 margin-top: 34px; 
 } 

 .banner-cta-btn { 
 width: 100%; 
 min-width: 0; 
 height: 58px; 
 font-size: 17px; 
 } 
 .banner-cta-btn-bubble-wrap { 
 width: 100%; 
 padding-top: 30px; 
 } 

.banner-cta-btn-bubble-wrap .banner-cta-btn { 
 width: 100%; 
 } 

.banner-cta-btn-bubble { 
 font-size: 13px; 
 height: 38px; 
 padding: 0 14px; 
 } 
 } 

@media screen and (max-width: 480px) { 
 .banner-cta-title { 
 font-size: 30px; 
 } 

 .banner-cta-subtitle { 
 font-size: 16px; 
 } 

 .banner-cta-btn { 
 height: 54px; 
 font-size: 16px; 
 } 
 } 

/********************************************
Footer
*********************************************/
.site-footer { 
 background: #f3f4f6; 
 border-top: 1px solid #e4e6ea; 
 padding: 60px 20px 50px; 
 } 

.site-footer-inner { 
 max-width: 1440px; 
 margin: 0 auto; 
 } 

.site-footer-top { 
 display: flex; 
 justify-content: space-between; 
 align-items: flex-start; 
 gap: 32px; 
 padding-bottom: 30px; 
 margin-bottom: 30px; 
 border-bottom: 1px solid #dcdfe4; 
 } 

.site-footer-logo { 
 margin: 0; 
 font-size: 0; 
 line-height: 1; 
 } 

.site-footer-logo a { 
 display: inline-block; 
 font-size: 28px; 
 font-weight: 800; 
 color: #111; 
 text-decoration: none; 
 letter-spacing: -0.03em; 
 } 

.site-footer-nav { 
 display: flex; 
 flex-wrap: wrap; 
 gap: 14px 32px; 
 } 

.site-footer-nav a { 
 font-size: 17px; 
 font-weight: 600; 
 color: #222; 
 text-decoration: none; 
 letter-spacing: -0.02em; 
 } 

.site-footer-nav a:hover { 
 color: #05e348; 
 } 

.site-footer-bottom { 
 display: block; 
 } 

.site-footer-info { 
 display: flex; 
 flex-direction: column; 
 gap: 14px; 
 } 

.site-footer-line { 
 margin: 0; 
 font-size: 15px; 
 line-height: 1.3; 
 color: #555; 
 letter-spacing: -0.02em; 
 word-break: keep-all; 
 } 

.site-footer-line strong { 
 display: inline-block; 
 margin-right: 6px; 
 font-weight: 700; 
 color: #111; 
 } 

.site-footer-line span { 
 display: inline; 
 margin-right: 18px; 
 } 

.site-footer-line a { 
 color: #555; 
 text-decoration: none; 
 } 

.site-footer-line a:hover { 
 color: #111; 
 } 

.site-footer-copy { 
 margin: 10px 0 0; 
 font-size: 16px; 
 line-height: 1.7; 
 color: #666; 
 letter-spacing: -0.02em; 
 } 

/* tablet */
@media screen and (max-width: 1024px) { 
 .site-footer { 
 padding: 50px 20px 42px; 
 } 

 .site-footer-top { 
 flex-direction: column; 
 align-items: flex-start; 
 gap: 20px; 
 padding-bottom: 24px; 
 margin-bottom: 24px; 
 } 

 .site-footer-logo a { 
 font-size: 24px; 
 } 

 .site-footer-nav { 
 gap: 12px 22px; 
 } 

 .site-footer-nav a { 
 font-size: 16px; 
 } 

 .site-footer-line { 
 font-size: 16px; 
 line-height: 1.75; 
 } 

 .site-footer-line span { 
 margin-right: 14px; 
 } 

 .site-footer-copy { 
 font-size: 15px; 
 } 
 } 

/* mobile */
@media screen and (max-width: 768px) { 
 .site-footer { 
 padding: 42px 16px 36px; 
 } 

 .site-footer-top { 
 gap: 16px; 
 padding-bottom: 20px; 
 margin-bottom: 20px; 
 } 

 .site-footer-logo a { 
 font-size: 22px; 
 } 

 .site-footer-nav { 
 flex-direction: column; 
 gap: 10px; 
 } 

 .site-footer-nav a { 
 font-size: 15px; 
 } 

 .site-footer-info { 
 gap: 12px; 
 } 

 .site-footer-line { 
 font-size: 14px; 
 line-height: 1.7; 
 } 

 .site-footer-line strong,
 .site-footer-line span { 
 display: inline; 
 margin-right: 0; 
 } 

 .site-footer-line strong::after { 
 content: " "; 
 } 

 .site-footer-line span::after { 
 content: " "; 
 } 

 .site-footer-copy { 
 margin-top: 6px; 
 font-size: 14px; 
 } 
 } 




