/* Auto-generated — do not edit by hand; edit build-css.py + styles.css */

/* AIV Tech Pipeline — scoped for WordPress shortcode */
.aivtp-wrap {
  --aivtp-bg: #0a0a0a !important;
  --aivtp-accent: #00ff9c !important;
  --aivtp-gray-400: #9ca3af !important;
  --aivtp-gray-500: #6b7280 !important;
  --aivtp-white: #ffffff !important;
  --aivtp-black-40: rgba(0, 0, 0, 0.4) !important;
  --aivtp-accent-02: rgba(0, 255, 156, 0.02) !important;
  --aivtp-accent-05: rgba(0, 255, 156, 0.05) !important;
  --aivtp-accent-10: rgba(0, 255, 156, 0.1) !important;
  --aivtp-accent-20: rgba(0, 255, 156, 0.2) !important;
  --aivtp-accent-30: rgba(0, 255, 156, 0.3) !important;
  --aivtp-accent-40: rgba(0, 255, 156, 0.4) !important;
  --aivtp-accent-60: rgba(0, 255, 156, 0.6) !important;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
  -webkit-font-smoothing: antialiased !important;
  background-color: transparent !important;
  color: var(--aivtp-white) !important;
  /* overflow-x:hidden 단독 사용 시 overflow-y가 auto로 계산되어 래퍼에 세로 스크롤이 생길 수 있음 */
  overflow: visible !important;
  font-size: 16px !important;
}

.aivtp-wrap,
.aivtp-wrap * {
  box-sizing: border-box !important;
}

.aivtp-wrap .aivtp-block {
  display: block !important;
}

.aivtp-wrap .aivtp-font-normal {
  font-weight: 400 !important;
}

.aivtp-wrap .aivtp-mt-2 {
  margin-top: 0.5rem !important;
}

.aivtp-wrap .aivtp-mt-3 {
  margin-top: 0.75rem !important;
}

.aivtp-wrap h2 {
  color: var(--aivtp-white) !important;
}

.aivtp-wrap .aivtp-feature-card h3 {
  color: var(--aivtp-white) !important;
}

/* Layout */.aivtp-wrap .aivtp-max-w-6xl {
  max-width: 72rem !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100% !important;
  min-width: 0 !important;
}

.aivtp-wrap .aivtp-px-6 {
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}

.aivtp-wrap .aivtp-py-32 {
  padding-top: 8rem !important;
  padding-bottom: 8rem !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-py-32 {
  padding-top: 3.5rem !important;
  padding-bottom: 3.5rem !important;
}

}

.aivtp-wrap .aivtp-text-center {
  text-align: center !important;
}

.aivtp-wrap .aivtp-mb-16 {
  margin-bottom: 4rem !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-mb-16 {
  margin-bottom: 2.5rem !important;
}

}

.aivtp-wrap .aivtp-mb-6 {
  margin-bottom: 1.5rem !important;
}

.aivtp-wrap .aivtp-mb-4 {
  margin-bottom: 1rem !important;
}

.aivtp-wrap .aivtp-mb-3 {
  margin-bottom: 0.75rem !important;
}

.aivtp-wrap .aivtp-mb-1 {
  margin-bottom: 0.25rem !important;
}

.aivtp-wrap .aivtp-mb-12 {
  margin-bottom: 3rem !important;
}

/* Typography */.aivtp-wrap .aivtp-text-5xl {
  font-size: clamp(1.75rem, 6vw + 0.5rem, 3rem) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.025em !important;
}

.aivtp-wrap .aivtp-text-xl {
  font-size: 1.25rem !important;
  line-height: 1.75rem !important;
}

.aivtp-wrap .aivtp-text-lg {
  font-size: 1.125rem !important;
  line-height: 1.75rem !important;
}

.aivtp-wrap .aivtp-text-base {
  font-size: 1rem !important;
  line-height: 1.5rem !important;
}

.aivtp-wrap .aivtp-text-sm {
  font-size: 0.875rem !important;
  line-height: 1.25rem !important;
}

.aivtp-wrap .aivtp-text-xs {
  font-size: 0.75rem !important;
  line-height: 1rem !important;
}

.aivtp-wrap .aivtp-text-2xl {
  font-size: 1.5rem !important;
  line-height: 2rem !important;
}

.aivtp-wrap .aivtp-text-gray-400 {
  color: var(--aivtp-gray-400) !important;
}

.aivtp-wrap .aivtp-text-gray-500 {
  color: var(--aivtp-gray-500) !important;
}

.aivtp-wrap .aivtp-text-white {
  color: var(--aivtp-white) !important;
}

.aivtp-wrap .aivtp-text-accent {
  color: var(--aivtp-accent) !important;
}

.aivtp-wrap .aivtp-uppercase {
  text-transform: uppercase !important;
}

.aivtp-wrap .aivtp-tracking-wide {
  letter-spacing: 0.025em !important;
}

.aivtp-wrap .aivtp-max-w-2xl {
  max-width: 42rem !important;
}

.aivtp-wrap .aivtp-mx-auto {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Section backgrounds */.aivtp-wrap .aivtp-bg-gradient-rfm {
  background: linear-gradient(to bottom, transparent, rgba(0, 255, 156, 0.02), transparent) !important;
}

/* Pipeline box */.aivtp-wrap .aivtp-pipeline-box {
  border: 1px solid rgba(0, 255, 156, 0.2) !important;
  border-radius: 0.5rem !important;
  padding: 3rem !important;
  background: rgba(0, 255, 156, 0.02) !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  transition:
    border-color 0.4s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.45s ease !important;
}

.aivtp-wrap .aivtp-pipeline-box:hover {
  border-color: rgba(0, 255, 156, 0.38) !important;
  box-shadow: 0 0 0 1px rgba(0, 255, 156, 0.12), 0 12px 40px rgba(0, 255, 156, 0.06) !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-pipeline-box {
  padding: 1rem 0.75rem !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-bottom: 1.25rem !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
}

}

/* Grid: stack on mobile, 2 cols from md */.aivtp-wrap .aivtp-grid-md-2 {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 2.5rem !important;
  min-width: 0 !important;
}

@media (min-width: 768px) {
.aivtp-wrap .aivtp-grid-md-2 {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 4rem !important;
  align-items: center !important;
}

}

.aivtp-wrap .aivtp-grid {
  display: grid !important;
}

.aivtp-wrap .aivtp-gap-16 {
  gap: 4rem !important;
}

.aivtp-wrap .aivtp-items-center {
  align-items: center !important;
}

/* Inline label row */.aivtp-wrap .aivtp-inline-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  margin-bottom: 1.5rem !important;
  color: var(--aivtp-accent) !important;
}

.aivtp-wrap .aivtp-inline-label .aivtp-label-text {
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.aivtp-wrap .aivtp-section-kicker {
  font-size: 0.875rem !important;
  color: var(--aivtp-accent) !important;
  margin-bottom: 0.5rem !important;
  letter-spacing: 0 !important;
}

.aivtp-wrap .aivtp-text-2xl-heading {
  font-size: 1.5rem !important;
  line-height: 2rem !important;
  font-weight: 500 !important;
  color: var(--aivtp-white) !important;
}

.aivtp-wrap .aivtp-tc-intro {
  margin-bottom: 1.25rem !important;
}

.aivtp-wrap .aivtp-tc-intro .aivtp-section-kicker {
  margin-bottom: 0.35rem !important;
}

.aivtp-wrap .aivtp-chart-caption {
  margin-top: 0.75rem !important;
  text-align: center !important;
  font-size: 0.9375rem !important;
  color: var(--aivtp-accent) !important;
  font-variant-numeric: tabular-nums !important;
}

.aivtp-wrap .aivtp-chart-caption span {
  display: inline-block !important;
  min-width: 0.25em !important;
  transition: color 0.2s ease !important;
}

.aivtp-wrap .aivtp-subsection-heading {
  text-align: center !important;
  font-size: 1.25rem !important;
  font-weight: 500 !important;
  margin-bottom: 1.25rem !important;
  color: var(--aivtp-white) !important;
}

.aivtp-wrap .aivtp-icon-20 {
  width: 1.25rem !important;
  height: 1.25rem !important;
  flex-shrink: 0 !important;
}

.aivtp-wrap .aivtp-icon-24 {
  width: 1.5rem !important;
  height: 1.5rem !important;
  flex-shrink: 0 !important;
}

.aivtp-wrap .aivtp-icon-stroke {
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

/* Bullet lists */.aivtp-wrap .aivtp-space-y-4 > * + * {
  margin-top: 1rem !important;
}

.aivtp-wrap .aivtp-bullet-row {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.75rem !important;
  transition: transform 0.3s ease !important;
}

/* h4 기본 마진이 있으면 점은 위·텍스트는 아래로 밀려 보이므로 정리 */.aivtp-wrap .aivtp-bullet-row h4 {
  margin: 0 0 0.25rem !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
}

.aivtp-wrap .aivtp-bullet-row .aivtp-text-sm {
  margin: 0 !important;
  line-height: 1.5 !important;
}

/* 첫 줄의 세로 중앙에 점 정렬: (줄높이 − 점지름) / 2 */.aivtp-wrap .aivtp-bullet-dot {
  width: 0.375rem !important;
  height: 0.375rem !important;
  background: var(--aivtp-accent) !important;
  border-radius: 9999px !important;
  flex-shrink: 0 !important;
  margin-top: calc((1.5em - 0.375rem) / 2) !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}

/* Bordered panels */.aivtp-wrap .aivtp-border-panel {
  border: 1px solid rgba(0, 255, 156, 0.2) !important;
  border-radius: 0.5rem !important;
  padding: 2rem !important;
  background: var(--aivtp-black-40) !important;
  min-width: 0 !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-border-panel {
  padding: 1.25rem !important;
}

}

.aivtp-wrap .aivtp-border-panel-sm {
  border: 1px solid rgba(0, 255, 156, 0.2) !important;
  border-radius: 0.5rem !important;
  padding: 1.5rem !important;
  background: var(--aivtp-black-40) !important;
  min-width: 0 !important;
}

.aivtp-wrap .aivtp-border-panel-highlight {
  border: 1px solid rgba(0, 255, 156, 0.6) !important;
  border-radius: 0.5rem !important;
  padding: 1.5rem !important;
  background: var(--aivtp-accent-05) !important;
  min-width: 0 !important;
}

/* TC-Pruner grid */.aivtp-wrap .aivtp-tc-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1.5rem !important;
  min-width: 0 !important;
}

.aivtp-wrap .aivtp-tc-chart-span {
  grid-column: span 2 / span 2 !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-tc-grid {
  grid-template-columns: 1fr !important;
}

.aivtp-wrap .aivtp-tc-chart-span {
  grid-column: auto !important;
}

}

.aivtp-wrap .aivtp-label-muted {
  font-size: 0.875rem !important;
  color: rgba(0, 255, 156, 0.6) !important;
  margin-bottom: 1rem !important;
}

.aivtp-wrap .aivtp-label-accent {
  font-size: 0.875rem !important;
  color: var(--aivtp-accent) !important;
  margin-bottom: 1rem !important;
}

.aivtp-wrap .aivtp-stat-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  gap: 0.75rem !important;
  font-size: 0.875rem !important;
}

.aivtp-wrap .aivtp-stat-row span:last-child {
  text-align: right !important;
  flex-shrink: 0 !important;
}

.aivtp-wrap .aivtp-stat-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.75rem !important;
  margin-bottom: 1.5rem !important;
}

.aivtp-wrap .aivtp-text-accent-soft {
  color: var(--aivtp-accent) !important;
}

/* Order: mobile text first, desktop charts left */.aivtp-wrap .aivtp-tc-order-text {
  order: 1 !important;
  min-width: 0 !important;
}

.aivtp-wrap .aivtp-tc-order-charts {
  order: 2 !important;
  min-width: 0 !important;
}

@media (min-width: 768px) {
.aivtp-wrap .aivtp-tc-order-text {
  order: 2 !important;
}

.aivtp-wrap .aivtp-tc-order-charts {
  order: 1 !important;
}

}

/* Cloud/Edge outer */.aivtp-wrap .aivtp-cloud-edge-wrap {
  border: 1px solid rgba(0, 255, 156, 0.2) !important;
  border-radius: 0.5rem !important;
  padding: 3rem !important;
  background: var(--aivtp-black-40) !important;
  margin-bottom: 3rem !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  transition: border-color 0.35s ease, box-shadow 0.4s ease !important;
}

.aivtp-wrap .aivtp-cloud-edge-wrap:hover {
  border-color: rgba(0, 255, 156, 0.35) !important;
  box-shadow: 0 0 0 1px rgba(0, 255, 156, 0.08), 0 12px 40px rgba(0, 255, 156, 0.07) !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-cloud-edge-wrap {
  padding: 1rem 0.75rem !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  overflow-x: visible !important;
}

}

/* 데스크톱: 가로 SVG만 표시 */.aivtp-wrap .aivtp-pipeline-stack-mobile, .aivtp-wrap .aivtp-cloud-edge-stack-mobile {
  display: none !important;
}

@media (max-width: 767px) {
.aivtp-wrap .aivtp-pipeline-box .aivtp-diagram-svg-desktop, .aivtp-wrap .aivtp-cloud-edge-wrap .aivtp-diagram-svg-desktop {
  display: none !important;
}

.aivtp-wrap .aivtp-pipeline-stack-mobile {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
}

.aivtp-wrap .aivtp-cloud-edge-stack-mobile {
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
}

}

/* 모바일: 파이프라인 세로 스텝 */.aivtp-wrap .aivtp-pipeline-step-card {
  position: relative !important;
  border: 1px solid rgba(0, 255, 156, 0.35) !important;
  border-radius: 0.5rem !important;
  padding: 1rem 1rem 1.1rem !important;
  text-align: center !important;
  background: rgba(0, 255, 156, 0.04) !important;
}

.aivtp-wrap .aivtp-pipeline-step-card--rfm {
  padding-top: 2.6rem !important;
}

.aivtp-wrap .aivtp-pipeline-step-line {
  display: block !important;
  color: var(--aivtp-accent) !important;
  font-size: 0.9375rem !important;
  font-weight: 500 !important;
  line-height: 1.45 !important;
}

.aivtp-wrap .aivtp-pipeline-step-line--sub {
  font-size: 0.8125rem !important;
  font-weight: 400 !important;
  opacity: 0.92 !important;
  margin-top: 0.15rem !important;
}

.aivtp-wrap .aivtp-pipeline-rfm-ring {
  position: absolute !important;
  top: 0.65rem !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 2.75rem !important;
  height: 2.75rem !important;
  border: 1.5px solid rgba(0, 255, 156, 0.35) !important;
  border-radius: 50% !important;
  pointer-events: none !important;
}

.aivtp-wrap .aivtp-pipeline-step-connector {
  flex-shrink: 0 !important;
  width: 2px !important;
  height: 1.1rem !important;
  margin: 0.2rem auto !important;
  background: linear-gradient(
    to bottom,
    rgba(0, 255, 156, 0.25),
    rgba(0, 255, 156, 0.55)
  ) !important;
  border-radius: 1px !important;
  position: relative !important;
}

.aivtp-wrap .aivtp-pipeline-step-connector::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  bottom: -5px !important;
  transform: translateX(-50%) !important;
  border-left: 5px solid transparent !important;
  border-right: 5px solid transparent !important;
  border-top: 6px solid rgba(0, 255, 156, 0.45) !important;
}

/* 모바일: 클라우드 vs 엣지 카드 */.aivtp-wrap .aivtp-cec-card {
  border-radius: 0.5rem !important;
  padding: 1.2rem 1rem 1.25rem !important;
  text-align: center !important;
}

.aivtp-wrap .aivtp-cec-card--cloud {
  border: 1px solid rgba(0, 255, 156, 0.28) !important;
  background: rgba(0, 0, 0, 0.25) !important;
}

.aivtp-wrap .aivtp-cec-card--edge {
  border: 1px solid rgba(0, 255, 156, 0.55) !important;
  background: rgba(0, 255, 156, 0.06) !important;
  box-shadow: 0 0 24px rgba(0, 255, 156, 0.1) !important;
}

.aivtp-wrap .aivtp-cec-title {
  margin: 0 0 0.65rem !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  color: var(--aivtp-accent) !important;
}

.aivtp-wrap .aivtp-cec-cloud-doodle {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 0.15rem !important;
  margin-bottom: 0.85rem !important;
  min-height: 2rem !important;
  opacity: 0.55 !important;
}

.aivtp-wrap .aivtp-cec-cloud-blob {
  display: block !important;
  width: 2.4rem !important;
  height: 1.45rem !important;
  border: 1.5px solid var(--aivtp-accent) !important;
  border-radius: 999px !important;
}

.aivtp-wrap .aivtp-cec-cloud-blob--sm {
  width: 1.5rem !important;
  height: 1.1rem !important;
  margin-left: -0.8rem !important;
}

.aivtp-wrap .aivtp-cec-cloud-blob--sm2 {
  width: 1.5rem !important;
  height: 1.1rem !important;
  margin-left: -0.8rem !important;
}

.aivtp-wrap .aivtp-cec-edge-doodle {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 0.4rem !important;
  margin-bottom: 0.85rem !important;
  flex-wrap: wrap !important;
}

.aivtp-wrap .aivtp-cec-edge-screen {
  display: inline-block !important;
  width: 3.25rem !important;
  height: 2rem !important;
  border: 1.5px solid var(--aivtp-accent) !important;
  border-radius: 3px !important;
  opacity: 0.75 !important;
}

.aivtp-wrap .aivtp-cec-edge-dot {
  width: 5px !important;
  height: 5px !important;
  background: var(--aivtp-accent) !important;
  border-radius: 50% !important;
  opacity: 0.75 !important;
}

.aivtp-wrap .aivtp-cec-list {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  font-size: 0.8125rem !important;
  line-height: 1.7 !important;
  color: rgba(0, 255, 156, 0.62) !important;
}

.aivtp-wrap .aivtp-cec-list--edge {
  color: var(--aivtp-accent) !important;
  opacity: 0.92 !important;
}

.aivtp-wrap .aivtp-cec-vs-pill {
  text-align: center !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.35em !important;
  color: rgba(0, 255, 156, 0.5) !important;
  padding: 0.15rem 0 0.05rem !important;
}

/* Three cards: column + gap on mobile */.aivtp-wrap .aivtp-grid-md-3 {
  display: flex !important;
  flex-direction: column !important;
  gap: 2rem !important;
}

@media (min-width: 768px) {
.aivtp-wrap .aivtp-grid-md-3 {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 2rem !important;
}

}

.aivtp-wrap .aivtp-feature-card {
  text-align: center !important;
  padding: 2rem !important;
  border: 1px solid rgba(0, 255, 156, 0.2) !important;
  border-radius: 0.5rem !important;
  background: var(--aivtp-accent-02) !important;
  transition:
    border-color 0.35s ease,
    box-shadow 0.4s ease,
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

.aivtp-wrap .aivtp-feature-card:hover {
  border-color: rgba(0, 255, 156, 0.5) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35), 0 0 28px rgba(0, 255, 156, 0.12) !important;
}

.aivtp-wrap .aivtp-feature-card:hover .aivtp-feature-icon-wrap {
  transform: scale(1.06) !important;
  background: rgba(0, 255, 156, 0.16) !important;
}

.aivtp-wrap .aivtp-feature-icon-wrap {
  width: 3rem !important;
  height: 3rem !important;
  background: var(--aivtp-accent-10) !important;
  border-radius: 0.5rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1rem !important;
  color: var(--aivtp-accent) !important;
  transition: transform 0.35s ease, background 0.35s ease !important;
}

/* Technology flow */.aivtp-wrap .aivtp-flow-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 1.5rem !important;
}

@media (min-width: 768px) {
.aivtp-wrap .aivtp-flow-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

}

.aivtp-wrap .aivtp-flow-step {
  position: relative !important;
}

.aivtp-wrap .aivtp-flow-connector {
  display: none !important;
}

@media (min-width: 768px) {
.aivtp-wrap .aivtp-flow-connector {
  display: block !important;
  position: absolute !important;
  top: 2rem !important;
  left: 100% !important;
  width: 1.5rem !important;
  height: 1px !important;
  background: rgba(0, 255, 156, 0.3) !important;
  transform: translateX(-12px) !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.aivtp-wrap .aivtp-flow-step:last-child .aivtp-flow-connector {
  display: none !important;
}

}

.aivtp-wrap .aivtp-flow-card {
  border: 1px solid rgba(0, 255, 156, 0.3) !important;
  border-radius: 0.25rem !important;
  padding: 1rem !important;
  height: 100% !important;
  transition:
    border-color 0.35s ease,
    box-shadow 0.4s ease,
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

.aivtp-wrap .aivtp-flow-card:hover {
  border-color: rgba(0, 255, 156, 0.6) !important;
  box-shadow: 0 0 20px rgba(0, 255, 156, 0.1) !important;
  transform: translateY(-2px) !important;
}

.aivtp-wrap .aivtp-flow-num {
  color: var(--aivtp-accent) !important;
  font-size: 1.5rem !important;
  line-height: 2rem !important;
  margin-bottom: 0.5rem !important;
  opacity: 0.6 !important;
}

.aivtp-wrap .aivtp-flow-desc {
  color: rgba(0, 255, 156, 0.5) !important;
  font-size: 0.875rem !important;
}

.aivtp-wrap .aivtp-flow-title {
  color: var(--aivtp-white) !important;
  margin-bottom: 0.5rem !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
}

/* SVG diagrams */.aivtp-wrap .aivtp-diagram-svg {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
  transform-origin: center center !important;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

.aivtp-wrap .aivtp-diagram-svg text {
  font-family: inherit !important;
}

.aivtp-wrap .aivtp-svg-text-sm {
  font-size: 14px !important;
}

.aivtp-wrap .aivtp-svg-text-xs {
  font-size: 12px !important;
}

.aivtp-wrap .aivtp-svg-text-base {
  font-size: 16px !important;
  font-weight: 500 !important;
}

.aivtp-wrap .aivtp-svg-text-lg {
  font-size: 18px !important;
}

/* —— 등장 애니메이션 (스크롤·새로고침) —— */.aivtp-wrap .aivtp-section-block.aivtp-reveal {
  opacity: 0 !important;
  transform: translate3d(0, 18px, 0) !important;
  transition:
    opacity 1.35s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    transform 1.35s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  will-change: opacity, transform !important;
}

.aivtp-wrap .aivtp-section-block.aivtp-reveal.aivtp-is-visible {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
  will-change: auto !important;
}

@media (prefers-reduced-motion: reduce) {
.aivtp-wrap .aivtp-section-block.aivtp-reveal {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
  will-change: auto !important;
}

}

/* —— 호버: 패널·다이어그램 —— */.aivtp-wrap .aivtp-border-panel, .aivtp-wrap .aivtp-border-panel-sm, .aivtp-wrap .aivtp-border-panel-highlight {
  transition:
    border-color 0.35s ease,
    box-shadow 0.4s ease,
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

.aivtp-wrap .aivtp-border-panel:hover, .aivtp-wrap .aivtp-border-panel-sm:hover, .aivtp-wrap .aivtp-border-panel-highlight:hover {
  border-color: rgba(0, 255, 156, 0.45) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35), 0 0 24px rgba(0, 255, 156, 0.1) !important;
}

.aivtp-wrap .aivtp-border-panel:hover .aivtp-diagram-svg, .aivtp-wrap .aivtp-border-panel-sm:hover .aivtp-diagram-svg, .aivtp-wrap .aivtp-border-panel-highlight:hover .aivtp-diagram-svg {
  transform: scale(1.01) !important;
}

.aivtp-wrap .aivtp-cloud-edge-wrap:hover .aivtp-diagram-svg {
  transform: scale(1.008) !important;
}

.aivtp-wrap .aivtp-bullet-row:hover {
  transform: translateX(4px) !important;
}

.aivtp-wrap .aivtp-bullet-row:hover .aivtp-bullet-dot {
  transform: scale(1.35) !important;
  box-shadow: 0 0 10px rgba(0, 255, 156, 0.55) !important;
}

.aivtp-wrap .aivtp-tc-intro .aivtp-text-2xl-heading {
  transition: color 0.3s ease !important;
}

.aivtp-wrap .aivtp-section-kicker {
  transition: opacity 0.3s ease !important;
}

.aivtp-wrap .aivtp-section-block.aivtp-is-visible .aivtp-section-kicker {
  animation: kickerFade 1.05s ease forwards !important;
}

@keyframes kickerFade {
  from {
    opacity: 0.5 !important;
  }
  to {
    opacity: 1 !important;
  }
}

@media (prefers-reduced-motion: reduce) {
.aivtp-wrap .aivtp-section-block.aivtp-is-visible .aivtp-section-kicker {
  animation: none !important;
}

.aivtp-wrap .aivtp-pipeline-box:hover, .aivtp-wrap .aivtp-border-panel:hover, .aivtp-wrap .aivtp-border-panel-sm:hover, .aivtp-wrap .aivtp-border-panel-highlight:hover, .aivtp-wrap .aivtp-cloud-edge-wrap:hover, .aivtp-wrap .aivtp-feature-card:hover, .aivtp-wrap .aivtp-flow-card:hover, .aivtp-wrap .aivtp-bullet-row:hover {
  transform: none !important;
}

.aivtp-wrap .aivtp-border-panel:hover .aivtp-diagram-svg, .aivtp-wrap .aivtp-border-panel-sm:hover .aivtp-diagram-svg, .aivtp-wrap .aivtp-border-panel-highlight:hover .aivtp-diagram-svg, .aivtp-wrap .aivtp-cloud-edge-wrap:hover .aivtp-diagram-svg {
  transform: none !important;
}

.aivtp-wrap .aivtp-feature-card:hover .aivtp-feature-icon-wrap {
  transform: none !important;
}

.aivtp-wrap .aivtp-bullet-row:hover .aivtp-bullet-dot {
  transform: none !important;
  box-shadow: none !important;
}

}

