
/********************************************
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: 1600px; 
margin: 0 auto; 
text-align: center; 
padding-top: 0px; 
 } 

.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: #111; 
/* text-shadow: 0 8px 24px rgb(5 227 72 / 41%);  */
/* font-size: 68px; */

 } 

.main-visual-title-ai {
    display: inline-block;
    margin-right: 8px;
    font-weight: 900;
    line-height: 1;
    /* letter-spacing: -0.06em; */
    vertical-align: baseline;
    color: transparent !important;
    background: linear-gradient(90deg, #8dff98 0%, #05e348 22%, #7fffd4 48%, #05e348 72%, #0a9f38 100%);
    background-size: 220% 100%;
    background-position: 0% 50%;
    -webkit-background-clip: text;
    background-clip: text;
    /* text-shadow: 0 0 7px rgba(5, 227, 72, 0.28), 0 7px 8px rgba(5, 227, 72, 0.18); */
    filter: saturate(1.15);
    transform: translateY(1px) scale(1.02);
    font-size: 96px;
    animation: wave-gradient 3.8s ease-in-out infinite;
}

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

.aihome-quick-process {
position: relative;
margin: 24px auto 0;
max-width: 1280px;
padding: 22px 18px 18px;
border-radius: 18px;
border: 1px solid rgba(254, 107, 33, 0.25);
background:
linear-gradient(135deg, rgba(254, 107, 33, 0.08) 0%, rgba(5, 227, 72, 0.06) 100%),
#ffffff;
box-shadow: 0 18px 38px rgba(17, 24, 39, 0.09);
overflow: hidden;
}
.aihome-quick-process .process-tit{
  text-align: center;
  padding-bottom: 36px;
}
/* .aihome-quick-process::before {
content: "";
position: absolute;
left: 16px;
right: 16px;
top: 56%;
height: 1px;
background: linear-gradient(90deg, rgba(254, 107, 33, 0.15) 0%, rgba(17, 24, 39, 0.16) 100%);
pointer-events: none;
} */

.aihome-quick-process-list {
display: flex;
justify-content: space-between;
gap: 14px;
margin: 0;
padding: 0;
list-style: none;
}

.aihome-quick-process-item {
width: 100%;
position: relative;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
text-align: center;
padding: 26px 12px 12px;
border-radius: 14px;
background: #fff;
border: 1px solid rgba(17, 24, 39, 0.09);
box-shadow: 0 10px 24px rgba(17, 24, 39, 0.07);
transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
z-index: 1;
}

@media (hover: hover) {
.aihome-quick-process-item:hover {
transform: translateY(-3px);
box-shadow: 0 16px 28px rgba(17, 24, 39, 0.11);
border-color: rgba(254, 107, 33, 0.38);
}
}

@media screen and (max-width:980px){
/*   .sample{flex-wrap: wrap; justify-content: flex-start;}
  .sample .aihome-quick-process-item{width:calc(100% / 3 - 8px ) } */
  .aihome-quick-process-list{flex-wrap: wrap; justify-content: flex-start;}
  .aihome-quick-process-item {width:calc(100% / 2 - 8px )}
  .aihome-quick-process .process-tit{font-size: 22px;}
}

/* .aihome-quick-process-item:not(:last-child)::after {
content: "";
position: absolute;
right: -11px;
top: 50%;
width: 8px;
height: 8px;
border-top: 2px solid #fb923c;
border-right: 2px solid #fb923c;
transform: translateY(-50%) rotate(45deg);
z-index: 2;
background: #fff;
box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.95);
} */

.aihome-quick-process-num {
position: absolute;
left: 50%;
top: -14px;
transform: translateX(-50%);
display: inline-flex;
align-items: center;
justify-content: center;
width: 34px;
height: 34px;
border-radius: 999px;
background: linear-gradient(135deg, #ff8a4c 0%, #fe6b21 100%);
color: #fff;
font-size: 12px;
font-weight: 900;
line-height: 1;
box-shadow: 0 10px 18px rgba(254, 107, 33, 0.35);
border: 2px solid #fff;
}

.aihome-quick-process-step {
display: block;
font-size: 16px;
font-weight: 800;
line-height: 1.3;
color: #111827;
word-break: keep-all;
}

.aihome-quick-process-sub {
width: 100%;
min-height: 16px;
margin: 6px 0 0;
font-size: 12px;
font-weight: 500;
line-height: 1.35;
color: #6b7280;
}

.main-visual-marquee {
margin-top: 50px;
overflow: hidden;
}

.main-visual-marquee-window {
position: relative;
overflow: hidden;
mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
-webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}

.main-visual-marquee-track {
display: flex;
align-items: center;
gap: 18px;
width: max-content;
animation: main-visual-marquee-scroll 28s linear infinite;
will-change: transform;
}

.main-visual-marquee:hover .main-visual-marquee-track {
animation-play-state: paused;
}

.main-visual-marquee-item {
flex: 0 0 auto;
    width: 280px;
    height: 165px;
/* border-radius: 24px; */
overflow: hidden;
background: #fff;
box-shadow: 0 18px 38px rgba(17, 24, 39, 0.10);
border: 1px solid rgba(17, 17, 17, 0.06);
}

.main-visual-marquee-item img {
display: block;
width: 100%;
height: 100%;
object-fit: cover;
}

@keyframes main-visual-marquee-scroll {
0% {
transform: translateX(0);
}

100% {
transform: translateX(calc(-50% - 9px));
}
}

.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; 
 } 

 .main-visual-title .br-block{display: none;}

@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; 
font-size: 56px;
 } 

.main-visual-title-ai {
margin-right: 6px;
transform: translateY(1px) scale(1.01);
}

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

.aihome-quick-process {
margin-top: 14px;
padding: 18px 12px 12px;
}

.aihome-quick-process-list {
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 8px;
}

.aihome-quick-process-item {
padding: 24px 8px 10px;
}

.aihome-quick-process-item:not(:last-child)::after {
display: none;
}

.aihome-quick-process::before {
display: none;
}

.aihome-quick-process-num {
top: -12px;
width: 30px;
height: 30px;
font-size: 11px;
}

.aihome-quick-process-step {
font-size: 12px;
}

.main-visual-marquee { 
margin-top: 24px; 
 } 

.main-visual-marquee-track { 
gap: 14px; 
 } 

.main-visual-marquee-item { 
width: 190px; 
height: 120px; 
/* border-radius: 20px;  */
 } 

.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:600px){
   .main-visual-title .br-block{display: block;}
}

@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; 
 } 

.aihome-quick-process-list {
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 10px;
}

.aihome-quick-process-step {
font-size: 13px;
}

.main-visual-marquee-item { 
width: 156px; 
height: 102px; 
border-radius: 18px; 
 } 
 } 
@media screen and (max-width:480px){
  .main-visual-title span{font-size:36px}
}
/********************************************
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: 140px; 
 } 

 @media screen and (max-width: 900px) {
  .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-brand-img {
    aspect-ratio: 248/55;
    width: 200px;
  }

 .landing-header-brand-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
 }

.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: 18px; 
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-rolling {
  position: relative;
  z-index: 1;
  --rolling-step: 86px;
  --rolling-bubble-height: 74px;
  width: min(100%, 820px);
  margin: 0 auto 24px;
}

.main-visual-rolling-window {
  position: relative;
  height: var(--rolling-step);
  overflow: hidden;
}

.main-visual-rolling-track {
  display: flex;
  flex-direction: column;
  gap: calc(var(--rolling-step) - var(--rolling-bubble-height));
  animation: main-visual-rolling 9s cubic-bezier(0.76, 0, 0.24, 1) infinite;
}

.main-visual-rolling-bubble {
  position: relative;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: var(--rolling-bubble-height);
  margin: 0 auto;
  padding: 0 26px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgb(5 227 72 / 41%);
/*   box-shadow: 0 18px 34px rgba(0, 0, 0, 0.08); */
}

.main-visual-rolling-bubble::after {
  content: "";
  position: absolute;
  left: 42px;
  bottom: -8px;
  width: 16px;
  height: 16px;
  background: rgba(255, 255, 255, 0.92);
  border-right: 1px solid rgb(5 227 72 / 41%);
  border-bottom: 1px solid rgb(5 227 72 / 41%);
  transform: rotate(45deg);
}

.main-visual-rolling-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #05e348 0%, #6dfc66 100%);
  color: #111111;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.main-visual-rolling-text {
  margin: 0;
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.04em;
  color: #111111;
  white-space: nowrap;
}

@keyframes main-visual-rolling {
  0%, 24% {
    transform: translateY(0);
  }

  33%, 57% {
    transform: translateY(calc(-1 * var(--rolling-step)));
  }

  66%, 90% {
    transform: translateY(calc(-2 * var(--rolling-step)));
  }

  100% {
    transform: translateY(calc(-3 * var(--rolling-step)));
  }
}

.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; 
 } 
  .landing-header-brand-img {
    width: 140px;
  }
 } 

@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; 
 } 
 } 

@media screen and (max-width: 980px) {
.main-visual-rolling {
  --rolling-step: 78px;
  --rolling-bubble-height: 66px;
  width: 100%;
  margin-bottom: 18px;
}

.main-visual-rolling-bubble {
  padding: 0 20px;
}

.main-visual-rolling-bubble::after {
  left: 34px;
}

.main-visual-rolling-tag {
  min-width: 38px;
  height: 38px;
  font-size: 11px;
}

.main-visual-rolling-text {
  font-size: clamp(14px, 3.6vw, 18px);
}

}

@media screen and (max-width: 480px) {
.main-visual-rolling {
  --rolling-step: 72px;
  --rolling-bubble-height: 60px;
  margin-bottom: 16px;
}

.main-visual-rolling-bubble {
  gap: 10px;
  padding: 0 16px;
}

.main-visual-rolling-bubble::after {
  left: 28px;
  width: 14px;
  height: 14px;
}

.main-visual-rolling-tag {
  min-width: 34px;
  height: 34px;
  padding: 0 10px;
  font-size: 10px;
}

.main-visual-rolling-text {
  font-size: 13px;
}

}

@media (prefers-reduced-motion: reduce) {
.main-visual-rolling-track,
.main-visual-marquee-track,
.main-visual-title-ai,
.hero-scroll-indicator-icon::before {
  animation: none;
}
}




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

.aistep-title-wrap {
 max-width: 1480px;
 margin: 0 auto;
 padding: 90px 24px 0;
 box-sizing: border-box;
}

.aistep-title-wrap .space-visual-head {
 margin-bottom: -170px;
}

@media screen and (max-width:1280px){
.aistep-title-wrap .space-visual-head {
 margin-bottom: -100px;
}
}
@media screen and (max-width:1024px){
.aistep-title-wrap .space-visual-head {
 margin-bottom: 0;
}
}
@media screen and (max-width:600px){
.aistep-title-wrap .space-visual-head {
 margin-bottom: 20px;
}
}
.aistep-scroll-wrap { position: relative; height: 400vh; } 

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

.aistep-sticky { position: sticky; top: 0; min-height: 100vh; display: flex; align-items: flex-start; justify-content: center; padding: 8px 24px 28px; 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: 48px; 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-title-wrap { padding: 72px 20px 10px; }

.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); } 
.page-wrap{min-height: auto;}
 } 

@media (max-width: 767px) { 
.aistep-title-wrap { padding: 56px 16px 8px; }

.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: 20px;
    line-height: 1.7;
    letter-spacing: -0.02em;
    color: #ff0000;
    font-weight: 600; } 

.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; 
	 } 
	 } 
	
	/********************************************
	관리자 포트폴리오 연동
	*********************************************/
	.portfolio-sr-only { position: absolute; width: 1px; height: 1px; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; } 
	body.portfolio-modal-open,
	body.portfolio-sample-modal-open,
	body.is-portfolio-category-more-open { overflow: hidden; } 
	.aihome-hero-portfolio-panel .portfolio-main-area { position: relative; width: 100%; margin-top: 0; } 
	.aihome-hero-portfolio-panel .portfolio-search-panel { position: relative; z-index: 30; width: 100%; max-width: none; margin: 0 auto; padding: 0 clamp(16px, 1.6vw, 28px); } 
	.aihome-hero-portfolio-panel .portfolio-search-title,
	.aihome-hero-portfolio-panel .portfolio-search-note { display: none; } 
	.aihome-hero-portfolio-panel .portfolio-search-form { display: flex; align-items: center; width: min(960px, 100%); margin: 0 auto; gap: 12px; padding: 10px 12px; border: 0; border-radius: 27px; background: rgba(238,238,238,.96); box-shadow: inset 0 0 0 1px rgba(0,0,0,.05), 0 10px 22px rgba(0,0,0,.14); transition: opacity .2s ease; } 
	.aihome-hero-portfolio-panel .portfolio-search-form.is-loading { opacity: .66; } 
	.aihome-hero-portfolio-panel .portfolio-input-wrap { display: flex; flex: 1 1 auto; width: auto; min-width: 0; gap: 12px; } 
	.aihome-hero-portfolio-panel .portfolio-keyword-input,
	.aihome-hero-portfolio-panel .portfolio-search-button { min-height: 48px; border: 0; border-radius: 16px; font-size: 14px; letter-spacing: 0; } 
	.aihome-hero-portfolio-panel .portfolio-keyword-input { flex: 1; width: 100%; padding: 0 20px; background: #fff; color: #3a3a3a; font-weight: 800; outline: 0; } 
	.aihome-hero-portfolio-panel .portfolio-keyword-input::placeholder { color: #444; opacity: .88; } 
	.aihome-hero-portfolio-panel .portfolio-search-button { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 88px; min-width: 88px; padding: 0 16px; background: #ff5638; color: #fff; font-weight: 900; cursor: pointer; box-shadow: none; } 
	.aihome-hero-portfolio-panel .portfolio-category-nav-wrap { position: relative; z-index: 40; width: 100vw; margin: 10px 0 0 calc(50% - 50vw); padding: 0 24px; } 
	.aihome-hero-portfolio-panel .portfolio-category-nav { display: grid; grid-template-columns: repeat(9, minmax(0, 1fr)); justify-content: center; gap: 8px; width: 100%; max-width: 1440px; margin: 0 auto; } 
	.aihome-hero-portfolio-panel .portfolio-category-root-wrap { position: relative; min-width: 0; } 
	.aihome-hero-portfolio-panel .portfolio-category-root { display: inline-flex; align-items: center; justify-content: center; width: 100%; min-width: 0; gap: 8px; padding: 5px 18px; border: 1px solid #fff; border-radius: 999px; background: #fff; color: #252833; font-size: 14px; font-weight: 900; line-height: 1; white-space: nowrap; cursor: pointer; box-shadow: 0 8px 18px rgba(0,0,0,.08); transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease; } 
	.aihome-hero-portfolio-panel .portfolio-category-root > span:first-child { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } 
	.aihome-hero-portfolio-panel .portfolio-category-root:hover,
	.aihome-hero-portfolio-panel .portfolio-category-root.is-active { border-color: transparent; background: #ffe326; color: #000; box-shadow: 0 10px 22px rgba(0,0,0,.12); transform: none; } 
	.aihome-hero-portfolio-panel .portfolio-category-featured,
	.aihome-hero-portfolio-panel .portfolio-category-featured:hover,
	.aihome-hero-portfolio-panel .portfolio-category-featured.is-active { min-width: 105px; border-color: transparent; background: #087bff; color: #fff; box-shadow: 0 10px 22px rgba(0,92,220,.22); } 
	.aihome-hero-portfolio-panel .portfolio-category-root-icon { flex: 0 0 auto; width: 7px; height: 7px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg) translateY(-2px); } 
	.aihome-hero-portfolio-panel .portfolio-category-more-trigger { display: inline-flex; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-plus { flex: 0 0 auto; font-size: 16px; font-weight: 900; line-height: 1; } 
	.aihome-hero-portfolio-panel .portfolio-category-nav.has-desktop-category-overflow > :nth-child(n+18):not(.portfolio-category-more-trigger):not(.portfolio-category-more-modal) { display: none; } 
	.aihome-hero-portfolio-panel .portfolio-category-panel { position: absolute; top: calc(100% + 10px); left: 50%; z-index: 60; width: max-content; min-width: 240px; max-width: 520px; padding: 12px; border-radius: 16px; background: #fff; box-shadow: 0 24px 44px rgba(0,0,0,.22); opacity: 0; visibility: hidden; transform: translate(-50%, -6px); transition: opacity .18s ease, transform .18s ease, visibility .18s ease; } 
	.aihome-hero-portfolio-panel .portfolio-category-root-wrap.is-open .portfolio-category-panel { opacity: 1; visibility: visible; transform: translate(-50%, 0); } 
	.aihome-hero-portfolio-panel .portfolio-category-subgroup { min-width: 220px; } 
	.aihome-hero-portfolio-panel .portfolio-category-subgroup-parent { margin-bottom: 6px; padding-bottom: 6px; border-bottom: 1px solid #eef1f5; } 
	.aihome-hero-portfolio-panel .portfolio-category-subgroup + .portfolio-category-subgroup { margin-top: 6px; padding-top: 6px; border-top: 1px solid #eef1f5; } 
	.aihome-hero-portfolio-panel .portfolio-category-sub { display: flex; align-items: center; width: 100%; min-height: 38px; border: 0; border-radius: 10px; background: transparent; color: #252833; font-size: 14px; font-weight: 800; text-align: left; cursor: pointer; } 
	.aihome-hero-portfolio-panel .portfolio-category-sub span { display: block; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } 
	.aihome-hero-portfolio-panel .portfolio-category-sub:hover,
	.aihome-hero-portfolio-panel .portfolio-category-sub.is-active { background: rgba(254,33,164,.1); color: #d40d85; } 
	.aihome-hero-portfolio-panel .portfolio-category-parent-option { background: #f8fafc; color: #111827; } 
	.aihome-hero-portfolio-panel .portfolio-category-depth-2 { padding: 0 12px; } 
	.aihome-hero-portfolio-panel .portfolio-category-third-list { margin: 2px 0 4px; } 
	.aihome-hero-portfolio-panel .portfolio-category-depth-3 { min-height: 34px; padding: 0 12px 0 28px; color: #4b5563; font-size: 13px; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-modal { position: fixed; inset: 0; z-index: 2147483200; display: none; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-modal.is-open { display: block; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-backdrop { position: absolute; inset: 0; background: rgba(10,12,18,.56); } 
	.aihome-hero-portfolio-panel .portfolio-category-more-dialog { position: absolute; top: 50%; left: 50%; width: min(720px, calc(100vw - 32px)); max-height: min(760px, calc(100vh - 44px)); padding: 18px; border-radius: 18px; background: #f4f5f2; box-shadow: 0 26px 70px rgba(0,0,0,.28); transform: translate(-50%, -50%); overflow: hidden; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-head strong { color: #111827; font-size: 18px; font-weight: 900; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-close { display: inline-flex; align-items: center; justify-content: center; min-width: 54px; min-height: 34px; border: 0; border-radius: 999px; background: #111827; color: #fff; font-size: 13px; font-weight: 900; cursor: pointer; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; max-height: calc(min(760px, calc(100vh - 44px)) - 84px); overflow-y: auto; padding-right: 2px; } 
	.aihome-hero-portfolio-panel .portfolio-category-more-list .portfolio-category-root { min-height: 34px; padding: 0 14px; } 
	.aihome-hero-portfolio-panel .portfolio-gallery-section { position: relative; padding: 32px 0 0; background: transparent; } 
	.aihome-hero-portfolio-panel .portfolio-gallery-inner { width: 100%; max-width: 1680px; margin: 0 auto; padding: 0 clamp(16px, 1.6vw, 28px); } 
	.aihome-hero-portfolio-panel .portfolio-gallery-head { display: none; } 
	.aihome-hero-portfolio-panel .portfolio-grid { display: grid; grid-template-columns: repeat(10, minmax(0, 1fr)); gap: 12px; transition: opacity .2s ease; } 
	.aihome-hero-portfolio-panel .portfolio-grid.is-loading { opacity: .48; } 
	.aihome-hero-portfolio-panel .portfolio-card { position: relative; display: block; width: 100%; aspect-ratio: 1 / 1; min-height: 110px; overflow: hidden; border: 0; padding: 0; border-radius: 18px; background: #d3d5dc; box-shadow: 0 14px 26px rgba(0,0,0,.14); text-align: left; cursor: pointer; transform: translateY(0); transition: transform .2s ease, box-shadow .2s ease; } 
	.aihome-hero-portfolio-panel .portfolio-card::before { content: none; display: none; } 
	.aihome-hero-portfolio-panel .portfolio-card:hover { transform: translateY(-4px); box-shadow: 0 22px 34px rgba(0,0,0,.2); } 
	.aihome-hero-portfolio-panel .portfolio-card-media { width: 100%; height: 100%; background: linear-gradient(180deg,#eceef3,#cfd4db); } 
	.aihome-hero-portfolio-panel .portfolio-card-media img { display: block; width: 100%; height: 100%; object-fit: cover; } 
	.aihome-hero-portfolio-panel .portfolio-card-placeholder { display: flex; width: 100%; height: 100%; align-items: center; justify-content: center; padding: 14px; color: rgba(17,20,28,.55); font-size: 14px; font-weight: 800; text-align: center; line-height: 1.5; } 
	.aihome-hero-portfolio-panel .portfolio-card-badge { position: absolute; top: 10px; left: 10px; z-index: 2; display: inline-flex; align-items: center; justify-content: center; padding: 6px 9px; border-radius: 999px; background: #111; color: #fff; font-size: 10px; font-weight: 800; letter-spacing: .04em; } 
	.aihome-hero-portfolio-panel .portfolio-empty-state { grid-column: 1 / -1; padding: 54px 20px; border-radius: 28px; background: rgba(16,18,24,.74); border: 1px solid rgba(255,255,255,.08); text-align: center; } 
	.aihome-hero-portfolio-panel .portfolio-empty-state p { margin: 0 0 10px; color: #fff; font-size: 20px; font-weight: 800; } 
	.aihome-hero-portfolio-panel .portfolio-empty-state span { color: rgba(255,255,255,.72); font-size: 14px; line-height: 1.6; } 
	.portfolio-card-detail { display: none; } 
	.portfolio-detail-modal,
	.portfolio-sample-modal { position: fixed; inset: 0; z-index: 2147483300; display: none; align-items: center; justify-content: center; padding: 24px; } 
	.portfolio-detail-modal.is-open,
	.portfolio-sample-modal.is-open { display: flex; } 
	.portfolio-detail-backdrop,
	.portfolio-sample-backdrop { position: absolute; inset: 0; background: rgba(6,8,12,.76); } 
	.portfolio-detail-dialog { position: relative; z-index: 1; width: min(1280px, calc(100vw - 48px)); height: min(900px, calc(100vh - 48px)); overflow: auto; border-radius: 8px; background: #fff; color: #111827; box-shadow: 0 30px 80px rgba(0,0,0,.34); outline: 0; } 
	.portfolio-detail-close { position: sticky; top: 10px; z-index: 5; float: right; min-width: 72px; min-height: 42px; margin: 16px 16px 0 0; border: 0; border-radius: 999px; background: #111827; color: #fff; font-size: 13px; font-weight: 800; cursor: pointer; } 
	.portfolio-detail-body { clear: both; padding: 30px 34px 40px; } 
	.portfolio-detail-head { padding-right: 92px; } 
	.portfolio-detail-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; } 
	.portfolio-detail-meta span { display: inline-flex; align-items: center; min-height: 30px; padding: 0 11px; border-radius: 999px; background: #eef2f7; color: #334155; font-size: 12px; font-weight: 800; } 
	.portfolio-detail-meta .portfolio-detail-best { background: linear-gradient(135deg, rgb(0,57,255), rgb(0,201,230)); color: #fff; } 
	.portfolio-detail-head h3 { margin: 0; color: #0f172a; font-size: clamp(26px, 4vw, 44px); line-height: 1.12; letter-spacing: 0; word-break: keep-all; } 
	.portfolio-detail-head p { margin: 12px 0 0; color: #475569; font-size: 16px; line-height: 1.7; } 
	.portfolio-detail-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid #e5e7eb; } 
	.portfolio-detail-section h4 { margin: 0 0 14px; color: #111827; font-size: 16px; font-weight: 900; } 
	.portfolio-detail-layouts { display: flex; flex-wrap: wrap; gap: 8px; margin: 0; padding: 0; list-style: none; } 
	.portfolio-detail-layouts li { display: inline-flex; align-items: center; min-height: 34px; padding: 0 12px; border-radius: 999px; background: #f1f5f9; color: #1f2937; font-size: 13px; font-weight: 800; } 
	.portfolio-detail-text { color: #374151; font-size: 15px; line-height: 1.8; word-break: keep-all; } 
	.portfolio-detail-media-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(260px, 360px); gap: 22px; align-items: start; } 
	.portfolio-detail-frame { display: flex; align-items: center; justify-content: center; overflow: hidden; border: 1px solid #e5e7eb; border-radius: 8px; background: #f8fafc; } 
	.portfolio-detail-frame-pc { display: block; width: 100%; height: auto; max-height: 520px; overflow-x: hidden; overflow-y: auto; scrollbar-gutter: stable; } 
	.portfolio-detail-frame-pc img,
	.portfolio-detail-frame-mobile img { display: block; width: 100%; height: auto; background: #fff; } 
	.portfolio-detail-frame-mobile { min-height: 520px; background: #eef2f7; } 
	.portfolio-detail-frame-mobile img { max-height: 680px; object-fit: contain; } 
	.portfolio-detail-pc p,
	.portfolio-detail-mobile p { margin: 0 0 10px; color: #111827; font-size: 14px; font-weight: 900; } 
	.portfolio-detail-thumbs { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; margin-top: 10px; } 
	.portfolio-detail-thumb { position: relative; overflow: hidden; aspect-ratio: 16 / 10; border: 2px solid transparent; border-radius: 8px; padding: 0; background: #e5e7eb; cursor: pointer; } 
	.portfolio-detail-thumb.is-active { border-color: rgb(0,115,255); } 
	.portfolio-detail-thumb img { display: block; width: 100%; height: 100%; object-fit: cover; } 
	.portfolio-detail-placeholder { display: flex; align-items: center; justify-content: center; width: 100%; min-height: 180px; color: #64748b; font-size: 14px; font-weight: 900; } 
	.portfolio-detail-source-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; } 
	.portfolio-detail-source-head h4 { margin: 0; } 
	.portfolio-detail-source-actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; } 
	.portfolio-detail-source-device-toggle { display: inline-flex; align-items: center; gap: 4px; padding: 4px; border: 1px solid #dbe3ef; border-radius: 10px; background: #f8fafc; } 
	.portfolio-detail-device-btn { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 34px; border: 0; border-radius: 8px; background: transparent; color: #64748b; cursor: pointer; transition: background .2s ease, color .2s ease, box-shadow .2s ease; } 
	.portfolio-detail-device-btn.is-active { background: #111827; color: #fff; box-shadow: 0 8px 18px rgba(15,23,42,.18); } 
	.portfolio-detail-device-icon { position: relative; display: block; box-sizing: border-box; color: inherit; } 
	.portfolio-detail-device-icon-pc { width: 21px; height: 15px; border: 2px solid currentColor; border-radius: 3px; } 
	.portfolio-detail-device-icon-pc::before { content: ""; position: absolute; left: 50%; bottom: -6px; width: 2px; height: 5px; background: currentColor; transform: translateX(-50%); } 
	.portfolio-detail-device-icon-pc::after { content: ""; position: absolute; left: 50%; bottom: -8px; width: 14px; height: 2px; border-radius: 999px; background: currentColor; transform: translateX(-50%); } 
	.portfolio-detail-device-icon-mobile { width: 13px; height: 22px; border: 2px solid currentColor; border-radius: 4px; } 
	.portfolio-detail-device-icon-mobile::after { content: ""; position: absolute; left: 50%; bottom: 2px; width: 3px; height: 3px; border-radius: 50%; background: currentColor; transform: translateX(-50%); } 
	.portfolio-detail-source-open { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 13px; border-radius: 8px; background: #111827; color: #fff; font-size: 13px; font-weight: 900; text-decoration: none; } 
	.portfolio-detail-source-stage { width: 100%; overflow: auto; padding: 16px; border: 1px solid #dbe3ef; border-radius: 8px; background: #e9edf3; } 
	.portfolio-detail-source-frame-wrap { width: 100%; height: min(720px, calc(100vh - 250px)); min-height: 520px; margin: 0 auto; overflow: hidden; border: 1px solid #dbe3ef; border-radius: 8px; background: #fff; box-shadow: 0 14px 32px rgba(15,23,42,.12); transition: width .22s ease, max-width .22s ease, border-radius .22s ease; } 
	.portfolio-detail-source-stage[data-source-device="mobile"] .portfolio-detail-source-frame-wrap { width: min(390px, 100%); min-height: 640px; border-radius: 22px; } 
	.portfolio-detail-source-frame { display: block; width: 100%; height: 100%; border: 0; background: #fff; } 
	.portfolio-detail-sample-cta { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 24px; border: 1px solid #dbe3ef; border-radius: 8px; background: #f8fafc; } 
	.portfolio-detail-sample-copy h4 { margin: 0 0 8px; color: #0f172a; font-size: 18px; font-weight: 900; } 
	.portfolio-detail-sample-copy p { margin: 0; color: #475569; font-size: 14px; line-height: 1.6; word-break: keep-all; } 
	.portfolio-sample-open { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; min-width: 140px; min-height: 48px; padding: 0 20px; border: 0; border-radius: 8px; background: #111827; color: #fff; font-size: 14px; font-weight: 900; cursor: pointer; } 
	.portfolio-sample-dialog { position: relative; z-index: 1; width: min(760px, calc(100vw - 48px)); max-height: calc(100vh - 48px); overflow: auto; border-radius: 8px; background: #fff; color: #111827; box-shadow: 0 24px 70px rgba(0,0,0,.32); outline: 0; padding: 30px 20px; } 
	.portfolio-sample-close { position: sticky; top: 12px; z-index: 3; float: right; min-width: 64px; min-height: 38px; margin: 14px 14px 0 0; border: 0; border-radius: 999px; background: #111827; color: #fff; font-size: 12px; font-weight: 900; cursor: pointer; } 
	.portfolio-sample-head { clear: both; padding: 0; } 
	.portfolio-sample-head span { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; background: #e0f2fe; color: #075985; font-size: 12px; font-weight: 900; } 
	.portfolio-sample-head h3 { margin: 12px 0 8px; color: #0f172a; font-size: 28px; line-height: 1.2; font-weight: 900; letter-spacing: 0; } 
	.portfolio-sample-head p { margin: 0; color: #475569; font-size: 14px; line-height: 1.6; word-break: keep-all; } 
	.portfolio-sample-form { padding: 0 30px 30px; } 
	.portfolio-sample-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; } 
	.portfolio-sample-field { display: grid; gap: 7px; min-width: 0; } 
	.portfolio-sample-field-full { grid-column: 1 / -1; } 
	.portfolio-sample-field span { color: #111827; font-size: 13px; font-weight: 900; } 
	.portfolio-sample-field input,
	.portfolio-sample-field select,
	.portfolio-sample-field textarea { width: 100%; min-height: 44px; border: 1px solid #cbd5e1; border-radius: 8px; padding: 0 12px; background: #fff; color: #111827; font-size: 14px; letter-spacing: 0; outline: 0; } 
	.portfolio-sample-field textarea { min-height: 104px; padding-top: 12px; resize: vertical; line-height: 1.6; } 
	.portfolio-sample-field input[type="color"] { padding: 4px; cursor: pointer; } 
	.portfolio-sample-logo-field input[type="file"] { padding: 10px 12px; } 
	.portfolio-sample-logo-field em { color: #64748b; font-size: 12px; font-style: normal; line-height: 1.5; } 
	.portfolio-sample-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 18px; } 
	.portfolio-sample-cancel,
	.portfolio-sample-submit { display: inline-flex; align-items: center; justify-content: center; min-width: 120px; min-height: 46px; border: 0; border-radius: 8px; padding: 0 18px; font-size: 14px; font-weight: 900; cursor: pointer; } 
	.portfolio-sample-cancel { background: #e5e7eb; color: #111827; } 
	.portfolio-sample-submit { background: rgb(0,115,255); color: #fff; } 
	.portfolio-sample-submit:disabled { opacity: .58; cursor: wait; } 
	.portfolio-sample-status { min-height: 22px; margin-top: 14px; color: #475569; font-size: 13px; font-weight: 800; line-height: 1.6; } 
	.portfolio-sample-status.is-ok { color: #047857; } 
	.portfolio-sample-status.is-error { color: #b91c1c; } 
	.portfolio-sample-status.is-loading { color: #1d4ed8; } 
	.portfolio-sample-status a { color: inherit; text-decoration: underline; text-underline-offset: 3px; } 
	@media screen and (max-width:1280px) { 
	 .aihome-hero-portfolio-panel .portfolio-grid { grid-template-columns: repeat(8, minmax(0, 1fr)); } 
	 } 
	@media screen and (max-width:1024px) { 
	 .aihome-hero-portfolio-panel .portfolio-search-panel { padding: 0 20px; } 
	 .aihome-hero-portfolio-panel .portfolio-search-form { width: min(760px, 100%); border-radius: 26px; } 
	 .aihome-hero-portfolio-panel .portfolio-category-nav { grid-template-columns: repeat(4, minmax(0, 1fr)); max-width: 720px; } 
	 .aihome-hero-portfolio-panel .portfolio-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); } 
	 } 
	@media screen and (max-width:768px) { 
	 .portfolio-detail-media-grid { grid-template-columns: 1fr; } 
	 .portfolio-detail-head { padding-right: 0; } 
	 .portfolio-detail-body { padding: 22px 16px 28px; } 
	 .portfolio-detail-source-head { align-items: flex-start; flex-direction: column; } 
	 .portfolio-detail-source-actions { width: 100%; justify-content: space-between; } 
	 .portfolio-detail-source-stage { padding: 10px; } 
	 .portfolio-detail-source-frame-wrap { height: calc(100vh - 210px); min-height: 360px; } 
	 .portfolio-detail-source-stage[data-source-device="mobile"] .portfolio-detail-source-frame-wrap { min-height: 540px; } 
	 .portfolio-detail-sample-cta { align-items: stretch; flex-direction: column; padding: 18px; } 
	 .portfolio-sample-open { width: 100%; } 
	 .portfolio-sample-grid { grid-template-columns: 1fr; } 
	 .portfolio-sample-form { padding: 0 18px 22px; } 
	 .portfolio-sample-head h3 { font-size: 24px; } 
	 .portfolio-sample-actions { flex-direction: column-reverse; } 
	 .portfolio-sample-cancel,
	 .portfolio-sample-submit { width: 100%; } 
	 } 
	@media screen and (max-width:640px) { 
	 .aihome-hero-portfolio-panel .portfolio-search-panel { padding: 0 14px; } 
	 .aihome-hero-portfolio-panel .portfolio-search-form { flex-direction: column; gap: 8px; padding: 8px; border-radius: 22px; } 
	 .aihome-hero-portfolio-panel .portfolio-input-wrap { width: 100%; gap: 6px; } 
	 .aihome-hero-portfolio-panel .portfolio-search-button { width: 100%; min-height: 50px; } 
	 .aihome-hero-portfolio-panel .portfolio-keyword-input { min-height: 50px; font-size: 15px; } 
	 .aihome-hero-portfolio-panel .portfolio-category-nav { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; max-width: none; } 
	 .aihome-hero-portfolio-panel .portfolio-category-root { padding: 5px 10px; font-size: 11px; } 
	 .aihome-hero-portfolio-panel .portfolio-category-panel { left: 0; max-width: calc(100vw - 32px); max-height: 280px; overflow-y: auto; transform: translateY(-6px); } 
	 .aihome-hero-portfolio-panel .portfolio-category-root-wrap.is-open .portfolio-category-panel { transform: translateY(0); } 
	 .aihome-hero-portfolio-panel .portfolio-category-more-trigger { display: none; } 
	 .aihome-hero-portfolio-panel .portfolio-category-nav.has-mobile-category-overflow > :nth-child(n+6):not(.portfolio-category-more-trigger):not(.portfolio-category-more-modal) { display: none; } 
	 .aihome-hero-portfolio-panel .portfolio-category-nav.has-mobile-category-overflow > .portfolio-category-more-trigger { display: inline-flex; } 
	 .aihome-hero-portfolio-panel .portfolio-category-more-dialog { top: auto; bottom: 0; left: 0; width: 100%; max-height: min(82vh, 680px); padding: 16px 14px 18px; border-radius: 20px 20px 0 0; transform: none; } 
	 .aihome-hero-portfolio-panel .portfolio-category-more-list { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; max-height: calc(min(82vh, 680px) - 78px); } 
	 .aihome-hero-portfolio-panel .portfolio-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 6px; } 
	 .aihome-hero-portfolio-panel .portfolio-card { border-radius: 10px; min-height: auto; } 
	 .aihome-hero-portfolio-panel .portfolio-card-badge { top: 6px; left: 6px; padding: 4px 6px; font-size: 8px; } 
	 .portfolio-detail-modal,
	 .portfolio-sample-modal { padding: 70px 20px; } 
	 .portfolio-detail-dialog,
	 .portfolio-sample-dialog { width: calc(100vw - 40px); height: 100%; max-height: none; } 
	 } 
	@media screen and (max-width:420px) { 
	 .aihome-hero-portfolio-panel .portfolio-grid { gap: 2px; } 
	 .portfolio-detail-source-actions { align-items: stretch; flex-direction: column; } 
	 .portfolio-detail-source-device-toggle { justify-content: center; } 
	 .portfolio-detail-source-open { width: 100%; } 
	 } 
	
	
	
	
