/* ===== intro.css | assets/diagnostic/css/intro.css ===== */

/* ===== Base / Layout / Components ===== */
.page-diagnosis_intro {
  --color-deep: var(--color-navy-950);
  --color-brand: var(--color-blue-600);
  --color-accent: var(--color-copper-500);
  --color-accent-soft: var(--color-copper-100);
  --color-bg: var(--color-cloud);
  --color-surface: var(--color-paper);
  --color-surface-tint: #eef5ff;
  --color-border: var(--color-line);
  --color-muted-soft: var(--color-muted);
  --color-warning: var(--color-gold-300);
  --color-warning-soft: var(--color-gold-100);
  --color-purple: #ece7ff;
  --color-pink-soft: #fde8ee;
  --border: var(--color-line);
  --border-span: #8db8e8;
  --fs-16: var(--font-size-body);
  --fs-18: 18px;
  --fs-24: 24px;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-bold: 700;
  --radius-8: 8px;
  --radius-12: 12px;
  --radius-16: 16px;
  --radius-20: 20px;
  --space-4: 4px;
  --space-8: 8px;
  --space-12: 12px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-32: 32px;
  --space-40: 40px;
  --space-56: 56px;
  --size-32: 32px;
  --size-36: 36px;
  --size-44: 44px;
  --size-54: 54px;
}

#hero {
  min-height: 100vh;
  background: var(--color-deep);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: 120px 5% 80px;
}

.hero-grid {
  width: 100%;
  max-width: var(--layout-container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: var(--space-4xl);
  align-items: center;
  position: relative;
  z-index: 1;
}

.hero-eyebrow {
  font-weight: var(--fw-medium);
  color: var(--color-accent);
}

.hero-title {
  font-size: clamp(40px, 5vw, 64px);
  color: var(--color-surface);
  margin-bottom: var(--space-12);
}

.hero-title span {
  font-weight: var(--fw-medium);
}

.hero-title .accent {
  color: var(--color-accent);
}

.hero-sub {
  font-size: var(--fs-18);

  color: rgba(255, 255, 255, 0.6);
  margin-bottom: var(--space-40);
  max-width: 480px;
}

.ax-intro-hero-actions {
  display: flex;
  gap: var(--space-12);
  flex-wrap: wrap;
}

.ax-intro-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  background: var(--color-accent-soft);
  color: var(--color-deep);
  padding: var(--space-12) var(--space-24);
  border-radius: var(--radius-8);
  font-weight: var(--fw-medium);
  text-decoration: none;
  transition:
    transform 0.15s,
    opacity 0.15s;
}

.ax-intro-btn-primary:hover {
  transform: translateY(-1px);
  opacity: 0.9;
}

.ax-intro-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  border: 1px solid rgba(255, 255, 255, 0.25);
  color: rgba(255, 255, 255, 0.8);
  padding: var(--space-12) var(--space-24);
  border-radius: var(--radius-8);
  font-weight: var(--fw-regular);
  text-decoration: none;
  transition:
    border-color 0.15s,
    color 0.15s;
}

.ax-intro-btn-ghost:hover {
  border-color: rgba(255, 255, 255, 0.55);
  color: var(--color-surface);
}

.hero-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-16);
  padding: var(--space-32);
  backdrop-filter: blur(8px);
}

.stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-24);
  margin-bottom: var(--space-24);
}

.stat-val {
  font-size: 36px;
  font-weight: var(--fw-medium);
  color: var(--color-surface);
  margin-bottom: var(--space-4);
}

.stat-val .unit {
  font-size: var(--fs-18);
  color: var(--color-accent);
}

.stat-lbl {
  color: rgba(255, 255, 255, 0.45);
}

.hero-card-title {
  color: var(--color-accent);
  margin-bottom: var(--space-8);
}

.ax-intro-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

.ax-intro-tag {
  padding: var(--space-4) var(--space-12);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-20);
  color: rgba(255, 255, 255, 0.6);
}

.ax-intro-kicker {
  color: var(--color-accent);
}
.ax-intro-title span {
  font-weight: var(--fw-medium);
}
.legend-dot--sky {
  background: var(--color-brand);
}

.legend-dot--mint {
  background: var(--color-accent-soft);
}

.legend-dot--gold {
  background: var(--color-warning);
}

.axintro-gap-row--last {
  margin-bottom: var(--space-0);
}

.bar-fill--ax5-emp {
  width: 70%;
  background: var(--color-brand);
}

.bar-fill--ax5-mgr {
  width: 40%;
  background: var(--color-accent-soft);
}

.bar-fill--ax2-emp {
  width: 55%;
  background: var(--color-brand);
}

.bar-fill--ax2-hr {
  width: 35%;
  background: var(--color-muted-soft);
}

.bar-fill--ax6-emp {
  width: 75%;
  background: var(--color-brand);
}

.bar-fill--ax6-mgr {
  width: 72%;
  background: var(--color-accent-soft);
}

.axintro-gap-signal--blue {
  background: var(--color-surface-tint);
  color: var(--color-brand);
}

.axintro-gap-signal--violet {
  background: var(--color-purple);
  color: var(--color-muted-soft);
}

.axintro-gap-signal--mint {
  background: var(--color-accent-soft);
  color: var(--color-accent);
}

.container--foreground {
  position: relative;
  z-index: 1;
}

.section-body {
  font-size: var(--fs-16);
  color: var(--color-muted-soft);
  max-width: 600px;
  margin-bottom: var(--space-56);
}

#problem,
#axes,
#respondents,
#packages,
#process,
#effects,
#cta {
  padding: 100px 0;
}

#problem {
  background: var(--color-bg);
}

.problem-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-24);
}

.problem-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-12);
  padding: var(--space-32);
  position: relative;
  overflow: hidden;
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}

.problem-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(13, 27, 62, 0.1);
}

.problem-num {
  font-size: 48px;
  font-weight: var(--fw-bold);
  color: var(--border);
  margin-bottom: var(--space-20);
}
.problem-body {
  color: var(--color-muted-soft);
  margin-bottom: var(--space-20);
}

.problem-result {
  font-weight: var(--fw-medium);
  color: var(--color-brand);
  background: var(--color-surface-tint);
  padding: var(--space-8) var(--space-12);
  border-radius: var(--radius-8);
  display: inline-block;
}

.problem-bar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
}

.problem-card:nth-child(1) .problem-bar {
  background: var(--color-brand);
}

.problem-card:nth-child(2) .problem-bar {
  background: var(--color-brand);
}

.problem-card:nth-child(3) .problem-bar {
  background: var(--color-brand);
}

#axes {
  background: var(--color-deep);
}

#axes .section-title,
#axes .ax-intro-kicker,
#packages .section-title,
#packages .card-title {
  color: var(--color-surface);
}
#axes .section-body {
  color: rgba(255, 255, 255, 0.5);
}

.ax-intro-axes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-16);
}

.ax-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: var(--radius-12);
  padding: var(--space-24);
  transition:
    background 0.2s,
    border-color 0.2s;
  cursor: default;
}

.ax-card:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.18);
}

.ax-code {
  font-weight: var(--fw-medium);
  margin-bottom: var(--space-8);
}

.ax-name {
  font-weight: var(--fw-medium);
  color: var(--color-surface);
  margin-bottom: var(--space-8);
}

.ax-kw {
  color: rgba(255, 255, 255, 0.35);
}

.ax-card.g1 .ax-code {
  color: var(--color-brand);
}

.ax-card.g1 {
  border-left: 3px solid rgba(46, 134, 222, 0.5);
}

.ax-card.g2 .ax-code {
  color: var(--color-accent);
}

.ax-card.g2 {
  border-left: 3px solid rgba(0, 180, 166, 0.5);
}

.ax-card.g3 .ax-code {
  color: var(--color-warning);
}

.ax-card.g3 {
  border-left: 3px solid rgba(245, 166, 35, 0.5);
}

.axes-legend {
  display: flex;
  gap: var(--space-32);
  padding-top: var(--space-24);
}

.legend-item {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  color: rgba(255, 255, 255, 0.45);
}

.legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

#respondents {
  background: var(--color-surface);
}

.resp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-32);
  margin-bottom: var(--space-3xl);
}

.resp-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-12);
  padding: var(--space-32);
  position: relative;
}

.resp-avatar {
  width: 52px;
  height: var(--size-54);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-20);
}

.resp-card.emp .resp-avatar {
  background: var(--color-surface-tint);
  color: var(--color-brand);
}

.resp-card.mgr .resp-avatar {
  background: var(--color-accent-soft);
  color: var(--color-accent);
}

.resp-card.hr .resp-avatar {
  background: var(--color-warning-soft);
  color: var(--color-warning);
}
.resp-body {
  color: var(--color-muted-soft);
  margin-bottom: var(--space-20);
}

.resp-note {
  padding: var(--space-8) var(--space-12);
  border-radius: var(--radius-8);
  font-weight: var(--fw-medium);
}

.resp-card.emp .resp-note {
  background: var(--color-surface-tint);
  color: var(--color-brand);
}

.resp-card.mgr .resp-note {
  background: var(--color-accent-soft);
  color: var(--color-accent);
}

.resp-card.hr .resp-note {
  background: var(--color-warning-soft);
  color: var(--color-danger);
}

.axintro-gap-section {
  background: var(--color-bg);
  border-radius: var(--radius-16);
  padding: var(--space-40);
}

.axintro-gap-title {
  font-weight: var(--fw-medium);
  margin-bottom: var(--space-24);
}

.axintro-gap-row {
  display: flex;
  align-items: center;
  gap: var(--space-16);
  margin-bottom: var(--space-16);
}

.axintro-gap-label {
  font-weight: var(--fw-medium);
  width: 48px;
  flex-shrink: 0;
}

.axintro-gap-bars {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.bar-line {
  display: flex;
  align-items: center;
  gap: var(--space-8);
}

.bar-role {
  color: var(--color-muted-soft);
  width: 40px;
  flex-shrink: 0;
}

.bar-track {
  flex: 1;
  height: var(--space-8);
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  border-radius: 4px;
}

.bar-val {
  color: var(--color-muted-soft);
  width: 28px;
}

.axintro-gap-signal {
  font-weight: var(--fw-medium);
  padding: var(--space-4) var(--space-12);
  border-radius: var(--radius-20);
  white-space: nowrap;
  flex-shrink: 0;
}

#packages {
  background: var(--color-deep);
}
#packages .ax-intro-kicker {
  color: var(--color-accent);
}

#packages .section-body {
  color: rgba(255, 255, 255, 0.5);
}

.axintro-pkg-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-20);
}

.axintro-pkg-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: var(--radius-12);
  padding: var(--space-24);
  display: flex;
  flex-direction: column;
  transition: transform 0.2s;
}

.axintro-pkg-card:hover {
  transform: translateY(-4px);
}

.axintro-pkg-code-badge {
  font-weight: var(--fw-medium);
  padding: var(--space-4) var(--space-8);
  border-radius: 4px;
  display: inline-block;
  margin-bottom: var(--space-16);
  width: fit-content;
}

.axintro-pkg-card.p1 .axintro-pkg-code-badge {
  background: rgba(46, 134, 222, 0.2);
  color: var(--color-muted-soft);
}

.axintro-pkg-card.p2 .axintro-pkg-code-badge {
  background: rgba(0, 180, 166, 0.2);
  color: var(--color-accent);
}

.axintro-pkg-card.p3 .axintro-pkg-code-badge {
  background: rgba(26, 95, 171, 0.3);
  color: var(--border-span);
}

.axintro-pkg-card.p4 .axintro-pkg-code-badge {
  background: rgba(245, 166, 35, 0.2);
  color: var(--color-warning);
}

.axintro-pkg-card.p1 {
  border-top: 3px solid var(--color-brand);
}

.axintro-pkg-card.p2 {
  border-top: 3px solid var(--color-accent);
}

.axintro-pkg-card.p3 {
  border-top: 3px solid var(--color-muted-soft);
}

.axintro-pkg-card.p4 {
  border-top: 3px solid var(--color-warning);
}
.axintro-pkg-eng {
  color: rgba(255, 255, 255, 0.3);
  margin-bottom: var(--space-20);
}

.axintro-pkg-meta {
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: var(--space-16);
}

.axintro-pkg-meta span {
  display: block;
}

.axintro-pkg-desc {
  color: rgba(255, 255, 255, 0.45);
  flex: 1;
  margin-bottom: var(--space-20);
}

.axintro-pkg-cond {
  padding: var(--space-8) var(--space-12);
  border-radius: var(--radius-20);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.4);
  text-align: center;
}

.axintro-pkg-card.p1 .axintro-pkg-cond {
  border-color: rgba(46, 134, 222, 0.3);
  color: var(--color-muted-soft);
}

.axintro-pkg-card.p2 .axintro-pkg-cond {
  border-color: rgba(0, 180, 166, 0.3);
  color: var(--color-accent);
}

.axintro-pkg-card.p3 .axintro-pkg-cond {
  border-color: rgba(91, 155, 216, 0.3);
  color: var(--border-span);
}

.axintro-pkg-card.p4 .axintro-pkg-cond {
  border-color: rgba(245, 166, 35, 0.3);
  color: var(--color-warning);
}

#process {
  background: var(--color-bg);
}

.process-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-0);
  position: relative;
}

.process-steps::before {
  content: "";
  position: absolute;
  top: 28px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: linear-gradient(90deg, var(--color-brand), var(--color-accent));
  z-index: 0;
}

.process-step {
  text-align: center;
  padding: 0 var(--space-16);
  position: relative;
  z-index: 1;
}

.step-circle {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-surface);
  border: 2px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-20);

  font-weight: var(--fw-medium);
  color: var(--color-brand);
  transition:
    border-color 0.2s,
    background 0.2s;
}

.process-step:last-child .step-circle {
  background: var(--color-accent-soft);
  border-color: var(--color-accent);
  color: var(--color-deep);
}

.step-title {
  font-weight: var(--fw-medium);
  margin-bottom: var(--space-8);
}

.step-body {
  color: var(--color-muted-soft);
}

.process-outputs {
  margin-top: var(--space-56);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-16);
}

.output-item {
  background: var(--color-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-12);
  padding: var(--space-16);
  text-align: center;
}

.output-item .o-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-brand);
  margin: 0 auto var(--space-8);
}

.output-item .o-text {
  color: var(--color-muted-soft);
}

#effects {
  background: var(--color-surface);
}

.effects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-24);
}

.effect-card {
  padding: var(--space-32);
  border: 1px solid var(--border);
  border-radius: var(--radius-12);
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}

.effect-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(13, 27, 62, 0.07);
}

.effect-num {
  width: 36px;
  height: var(--size-36);
  border-radius: var(--radius-8);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-16);
}

.effect-card:nth-child(1) .effect-num,
.effect-card:nth-child(3) .effect-num {
  background: var(--color-surface-tint);
  color: var(--color-brand);
}

.effect-card:nth-child(2) .effect-num {
  background: var(--color-accent-soft);
  color: var(--color-accent);
}

.effect-card:nth-child(4) .effect-num {
  background: var(--color-warning-soft);
  color: var(--color-warning);
}

.effect-card:nth-child(5) .effect-num {
  background: var(--color-purple);
  color: var(--color-muted-soft);
}

.effect-card:nth-child(6) .effect-num {
  background: var(--color-pink-soft);
  color: var(--color-muted-soft);
}
.effect-body {
  color: var(--color-muted-soft);
}

#cta {
  background: var(--color-deep);
  text-align: center;
  position: relative;
  overflow: hidden;
}

#cta::before {
  content: "";
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(0, 180, 166, 0.1) 0%,
    transparent 70%
  );
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.cta-kicker {
  color: var(--color-accent);
}

.cta-title {
  font-size: clamp(32px, 4vw, 52px);

  color: var(--color-surface);

  margin-bottom: var(--space-20);
}

.cta-title span {
  font-weight: var(--fw-medium);
}

.cta-body {
  font-size: var(--fs-16);
  color: rgba(255, 255, 255, 0.5);
  max-width: 520px;
  margin: 0 auto var(--space-40);
}

.cta-steps {
  display: grid;
  gap: var(--space-0);
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-12);
  overflow: hidden;
  margin-bottom: var(--space-40);
}

.cta-step {
  padding: var(--space-16) var(--space-24);
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  text-align: left;
}

.cta-step:last-child {
  border-right: none;
}

.cs-num {
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}

.cs-text {
  color: rgba(255, 255, 255, 0.7);
}

.cta-actions {
  display: flex;
  justify-content: center;
  gap: var(--space-12);
  flex-wrap: wrap;
}

.cta-note {
  margin-top: var(--space-24);
  color: rgba(255, 255, 255, 0.3);
}
.page-diagnosis_intro .footer-brand span {
  color: var(--color-accent);
}
.fade-up {
  animation: fadeUp 0.65s ease both;
}

.delay-1 {
  font-size: var(--size-44);
  color: var(--color-surface);
  animation-delay: 0.1s;
  line-height: 1.2;
}
.section-title {
  font-size: var(--size-32);
  line-height: 1.3;
}
.delay-2 {
  animation-delay: 0.2s;
}

.delay-3 {
  animation-delay: 0.3s;
}

.delay-4 {
  animation-delay: 0.4s;
}

/* ===== Animations ===== */

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===== Responsive / Media Queries =====
   ORDER: keep max-width blocks from large to small.
   RULE: add breakpoint overrides here, not in component sections above.
===== */

@media (max-width: 860px) {
  .hero-grid {
    grid-template-columns: 1fr;
    gap: var(--space-40);
  }

  .problem-grid,
  .ax-intro-axes-grid,
  .resp-grid,
  .axintro-pkg-grid,
  .process-steps,
  .effects-grid {
    grid-template-columns: 1fr;
  }

  .process-steps::before {
    display: none;
  }

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

  .process-outputs {
    grid-template-columns: 1fr 1fr;
    display: none;
  }
}

@media (max-width: 560px) {
  #hero {
    padding: 96px 5% 64px;
  }
  .axes-legend {
    flex-direction: column;
    gap: var(--space-12);
  }
  .axintro-gap-row {
    align-items: flex-start;
    flex-direction: column;
  }
  .axintro-gap-label {
    width: auto;
  }
  .axintro-gap-bars {
    width: 100%;
  }
  .process-step {
    max-width: 350px;
    padding-bottom: 26px;
    margin: auto;
  }
}
