/* Secondary pages — visual-first layouts */
.page-main {
  min-height: 60vh;
}

.visual-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-4);
}

.visual-tile {
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: transform 0.25s ease, border-color 0.25s ease;
}

.visual-tile:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--text) 12%, var(--border));
}

.visual-tile__art {
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-sm);
  background: var(--bg-muted);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}

.visual-tile__art svg {
  width: 48px;
  height: 48px;
  opacity: 0.9;
}

.visual-tile h2 {
  margin: 0;
  font-size: 1.125rem;
}

.visual-tile p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--text-muted);
  line-height: 1.5;
}

.stat-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
  margin: var(--space-6) 0;
}

.stat-bubble {
  text-align: center;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
}

.stat-bubble strong {
  display: block;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--accent);
}

.stat-bubble span {
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.timeline {
  display: grid;
  gap: var(--space-4);
  margin: var(--space-6) 0;
  padding-left: var(--space-4);
  border-left: 3px solid color-mix(in srgb, var(--accent) 40%, var(--border));
}

.timeline__item {
  position: relative;
  padding-left: var(--space-4);
}

.timeline__item::before {
  content: "";
  position: absolute;
  left: calc(-1 * var(--space-4) - 7px);
  top: 6px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  outline: 4px solid var(--bg);
}

.split-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  align-items: start;
}

.diagram-card {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  padding: var(--space-5);
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.signin-card {
  max-width: 420px;
  margin: var(--space-6) auto;
}

.signin-main {
  position: relative;
  min-height: min(720px, calc(100vh - var(--header-h) - 80px));
  padding-top: var(--space-7);
  padding-bottom: var(--space-7);
}

.signin-main .nn-stage {
  opacity: 0.32;
  pointer-events: none;
}

.signin-main #neural-canvas {
  min-height: min(65vh, 640px);
  opacity: 0.38;
}

@media (max-width: 900px) {
  .split-panel {
    grid-template-columns: 1fr;
  }
}

/* Accent headline gradient (features, skills, etc.) */
.text-gradient {
  background: var(--ai-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.comparison-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: var(--space-6);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
}

.comparison-table {
  width: 100%;
  min-width: 880px;
  border-collapse: collapse;
  font-size: 0.8125rem;
}

.comparison-table th,
.comparison-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: middle;
}

.comparison-table thead th {
  background: var(--bg-muted);
  font-weight: 700;
  white-space: nowrap;
}

.comparison-table tbody tr:last-child td {
  border-bottom: none;
}

.comparison-table .col-highlight {
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-elevated));
}

.check-cell {
  text-align: center;
}

.check-cell svg {
  width: 18px;
  height: 18px;
  vertical-align: middle;
}

.check-yes {
  color: var(--accent);
}

.check-no {
  color: var(--text-muted);
  opacity: 0.5;
}

.features-cta {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent) 12%, var(--bg-elevated)),
    var(--bg-elevated)
  );
}

.features-cta h2 {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.5rem, 3vw, 2rem);
}

.features-cta p {
  margin: 0 auto var(--space-6);
  max-width: 42rem;
  color: var(--text-muted);
}

/* Skills development — filters & course cards */
.skills-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
  justify-content: center;
}

.skills-stat {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  font-size: 0.875rem;
  color: var(--text-muted);
}

.skills-stat strong {
  color: var(--text);
  font-weight: 700;
}

.skills-filters {
  display: grid;
  grid-template-columns: 1fr repeat(3, minmax(140px, 1fr));
  gap: var(--space-3);
  align-items: stretch;
  margin-top: var(--space-4);
}

@media (max-width: 960px) {
  .skills-filters {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 560px) {
  .skills-filters {
    grid-template-columns: 1fr;
  }
}

.skills-search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
}

.skills-search svg {
  flex-shrink: 0;
  opacity: 0.55;
}

.skills-search input {
  flex: 1;
  border: none;
  background: transparent;
  font: inherit;
  color: var(--text);
  min-width: 0;
}

.skills-search input:focus {
  outline: none;
}

.skills-select {
  appearance: none;
  width: 100%;
  min-height: 44px;
  padding: var(--space-3) calc(var(--space-6) + 12px) var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background-color: var(--bg-elevated);
  color: var(--text);
  font: inherit;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%230d9488' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  background-size: 16px;
}

:root[data-theme="dark"] .skills-select {
  color-scheme: dark;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2314b8a6' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
}

.skills-select:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
}

.skills-select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}

.category-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: var(--space-6) 0 var(--space-4);
}

.category-pill {
  padding: var(--space-2) var(--space-4);
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  color: var(--text);
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    background 0.2s ease,
    color 0.2s ease;
}

.category-pill:hover {
  border-color: var(--accent);
  color: var(--text);
}

.category-pill.is-active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, var(--bg-elevated));
  color: var(--text);
}

:root[data-theme="dark"] .category-pill:not(.is-active) {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 18%, var(--border));
}

:root[data-theme="dark"] .category-pill:not(.is-active):hover {
  color: var(--text);
  border-color: var(--accent);
}

.skills-results {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin-bottom: var(--space-4);
}

.courses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}

.course-card {
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease;
  cursor: default;
  text-align: left;
  overflow: hidden;
}

.course-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}

.course-card__media {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--bg-muted);
}

.course-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.course-card__body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}

.course-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: 0.75rem;
  color: var(--text-muted);
}

.course-card__badge {
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--bg-muted);
  font-weight: 600;
}

.course-card h3 {
  margin: 0;
  font-size: 1.0625rem;
  line-height: 1.35;
}

.course-card p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--text-muted);
  line-height: 1.5;
  flex: 1;
}

.skills-cta-banner {
  position: relative;
  padding: var(--space-8) var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--bg-muted);
  text-align: center;
  overflow: hidden;
}

.skills-cta-banner h2 {
  margin: 0 0 var(--space-3);
}

.skills-cta-banner p {
  margin: 0 auto var(--space-6);
  max-width: 42rem;
  color: var(--text-muted);
}

.course-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--z-chat);
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(4px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  overflow-y: auto;
}

.course-modal-backdrop.is-open {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.modal-container.course-modal {
  width: 100%;
  max-width: min(56rem, 100%);
  max-height: min(92vh, 900px);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  position: relative;
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18);
}

.course-modal__hero {
  flex-shrink: 0;
  aspect-ratio: 21 / 9;
  max-height: 220px;
  background: var(--bg-muted);
}

.course-modal__hero:empty {
  display: none;
}

.course-modal__hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.modal-header {
  position: relative;
  padding: var(--space-5) var(--space-6);
  padding-top: var(--space-7);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.modal-close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  z-index: 3;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    color 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease;
}

.modal-close:hover {
  color: var(--text);
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-elevated));
}

.modal-category-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}

.modal-category-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #fff;
  background: var(--accent);
}

.modal-category-tag svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.modal-title {
  margin: 0 0 0.75rem;
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.25;
  letter-spacing: -0.02em;
  padding-right: 2.5rem;
}

.modal-refs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.modal-ref {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.modal-ref svg {
  width: 14px;
  height: 14px;
  opacity: 0.85;
}

.modal-status-banner {
  margin-top: 1rem;
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-muted));
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
  font-size: 0.8125rem;
  color: var(--text);
  line-height: 1.45;
}

.modal-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  margin-top: 0.35rem;
}

.modal-body {
  flex: 0 0 auto;
  overflow: visible;
  padding: var(--space-5) var(--space-6);
}

.modal-key-info {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.modal-info-card {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-muted);
}

.modal-info-card-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  margin-bottom: var(--space-2);
}

.modal-info-card-icon svg {
  width: 18px;
  height: 18px;
}

.modal-info-card-label {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.modal-info-card-value {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text);
}

.modal-nav-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
  border-bottom: 1px solid var(--border);
  padding-bottom: var(--space-2);
}

.modal-nav-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-muted);
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
  transition:
    color 0.2s ease,
    background 0.2s ease,
    border-color 0.2s ease;
}

.modal-nav-tab svg {
  width: 16px;
  height: 16px;
}

.modal-nav-tab:hover {
  color: var(--text);
  background: var(--bg-muted);
}

.modal-nav-tab.active {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--bg-elevated));
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}

.modal-tab-content {
  display: none;
}

.modal-tab-content.active {
  display: block;
}

.modal-section {
  margin-bottom: var(--space-5);
}

.modal-section:last-child {
  margin-bottom: 0;
}

.modal-section-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 var(--space-3);
}

.modal-section-title svg {
  width: 20px;
  height: 20px;
  color: var(--accent);
}

.modal-section p {
  margin: 0 0 0.75rem;
  font-size: 0.9375rem;
  color: var(--text-muted);
  line-height: 1.65;
}

.modal-footer {
  flex-shrink: 0;
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg-muted) 40%, var(--bg-elevated));
}

.modal-footer-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-bottom: var(--space-4);
}

.modal-footer-info svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--accent);
}

.modal-footer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

.modal-footer-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.modal-footer-actions .btn svg {
  width: 18px;
  height: 18px;
}

.course-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.course-card__actions .btn {
  flex: 1;
  min-width: 0;
  justify-content: center;
}

@media (max-width: 540px) {
  .modal-footer-actions {
    flex-direction: column;
  }

  .modal-footer-actions .btn {
    width: 100%;
  }
}

.skills-no-results {
  text-align: center;
  padding: var(--space-8);
  color: var(--text-muted);
}

/* Features page — explorer header, filters, interactive steps */
.page-features .features-explorer {
  text-align: center;
  max-width: 46rem;
  margin: 0 auto var(--space-8);
}

.page-features .features-explorer__eyebrow {
  margin-bottom: var(--space-2);
}

.page-features .features-explorer__title {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.35rem, 2.8vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.page-features .features-explorer__lead {
  margin: 0 auto var(--space-6);
  font-size: 1rem;
  color: var(--text-muted);
  line-height: 1.6;
}

.page-features .feature-filter-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  align-items: center;
}

.page-features .features-filter-meta {
  margin: var(--space-4) 0 0;
  font-size: 0.875rem;
  color: var(--text-muted);
  min-height: 1.35em;
}

/* Feature illustrations — vector scenes + motion (features grid only) */
.page-features #feature-grid .feature-card__visual {
  margin: calc(-1 * var(--space-5)) calc(-1 * var(--space-5)) var(--space-4);
  width: calc(100% + 2 * var(--space-5));
  aspect-ratio: 2 / 1;
  min-height: 108px;
  max-height: 168px;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  overflow: hidden;
  background: linear-gradient(
    165deg,
    color-mix(in srgb, var(--accent) 10%, var(--bg-muted)),
    var(--bg-muted)
  );
  border-bottom: 1px solid var(--border);
  color: var(--accent);
}

.page-features #feature-grid .feature-card__visual .feature-art {
  display: block;
  width: 100%;
  height: 100%;
}

.page-features #feature-grid .feature-card__title-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.page-features #feature-grid .feature-card__title-row h3 {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-size: 1.125rem;
}

/* Wallet — card drift + signal arcs */
.page-features .feature-card.reveal-feature.is-visible .feature-art--wallet .feature-art__anim--slide {
  animation: fa-wallet-slide 3s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center center;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--wallet .feature-art__wave {
  stroke-dasharray: 40 60;
  animation: fa-wave-dash 3.5s linear infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--wallet .feature-art__wave--2 {
  animation-duration: 4.2s;
  animation-direction: reverse;
}

@keyframes fa-wallet-slide {
  0%,
  100% {
    transform: translate(0, 0);
  }

  50% {
    transform: translate(5px, -3px);
  }
}

@keyframes fa-wave-dash {
  to {
    stroke-dashoffset: -100;
  }
}

/* Loyalty — bow pulse + sparkles */
.page-features .feature-card.reveal-feature.is-visible .feature-art--gift .feature-art__bow {
  animation: fa-bow-pulse 2.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.page-features .feature-art--gift .feature-art__spark {
  transform-box: fill-box;
  transform-origin: center;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--gift .feature-art__spark {
  animation: fa-sparkle 2s ease-in-out infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--gift .feature-art__spark--d {
  animation-delay: 0.4s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--gift .feature-art__spark--d2 {
  animation-delay: 0.8s;
}

@keyframes fa-bow-pulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.38;
  }

  50% {
    transform: scale(1.06);
    opacity: 0.52;
  }
}

@keyframes fa-sparkle {
  0%,
  100% {
    opacity: 0.35;
    transform: scale(1);
  }

  50% {
    opacity: 0.85;
    transform: scale(1.15);
  }
}

/* CRM — nodes breathe */
.page-features .feature-art--crm .feature-art__node {
  transform-box: fill-box;
  transform-origin: center;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__node {
  animation: fa-node 2.5s ease-in-out infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__node--2 {
  animation-delay: 0.35s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__node--3 {
  animation-delay: 0.7s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__node--4 {
  animation-delay: 1.05s;
}

.page-features .feature-art--crm .feature-art__link {
  stroke-dasharray: 8 12;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__link {
  animation: fa-link-dash 4s linear infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__link--2 {
  animation-delay: 0.5s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--crm .feature-art__link--3 {
  animation-delay: 1s;
}

@keyframes fa-node {
  0%,
  100% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.08);
    opacity: 0.85;
  }
}

@keyframes fa-link-dash {
  to {
    stroke-dashoffset: -80;
  }
}

/* Automation — steps highlight chain */
.page-features .feature-card.reveal-feature.is-visible .feature-art--flow .feature-art__step {
  animation: fa-step-glow 2.8s ease-in-out infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--flow .feature-art__step--2 {
  animation-delay: 0.35s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--flow .feature-art__step--3 {
  animation-delay: 0.7s;
}

.page-features .feature-art--flow .feature-art__dot {
  transform-box: fill-box;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--flow .feature-art__dot {
  animation: fa-dot-bounce 1.4s ease-in-out infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--flow .feature-art__flow-arrow {
  stroke-dasharray: 14 10;
  animation: fa-arrow-dash 1.8s linear infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--flow .feature-art__flow-arrow--2 {
  animation-delay: 0.35s;
}

@keyframes fa-step-glow {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.55;
  }
}

@keyframes fa-dot-bounce {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-4px);
  }
}

@keyframes fa-arrow-dash {
  to {
    stroke-dashoffset: -48;
  }
}

/* Referral — exchange arrows pulse */
.page-features .feature-card.reveal-feature.is-visible .feature-art--refer .feature-art__arc {
  stroke-dasharray: 100 200;
  animation: fa-arc-flow 3.5s linear infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--refer .feature-art__arc-rev {
  stroke-dashoffset: 0;
  animation: fa-arc-flow-rev 4s linear infinite;
}

@keyframes fa-arc-flow {
  to {
    stroke-dashoffset: -300;
  }
}

@keyframes fa-arc-flow-rev {
  to {
    stroke-dashoffset: 40;
  }
}

/* Analytics — bars grow */
.page-features .feature-art--chart .feature-art__bar {
  transform-box: fill-box;
  transform-origin: center bottom;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__bar {
  transform: scaleY(0.35);
  animation: fa-bar-rise 2.4s ease-in-out infinite alternate;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__bar--2 {
  animation-delay: 0.15s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__bar--3 {
  animation-delay: 0.3s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__bar--4 {
  animation-delay: 0.45s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__trend {
  stroke-dasharray: 42 120;
  animation: fa-trend-dash 3.2s ease-in-out infinite;
}

@keyframes fa-bar-rise {
  to {
    transform: scaleY(1);
  }
}

@keyframes fa-trend-dash {
  0%,
  100% {
    stroke-dashoffset: 0;
    opacity: 0.45;
  }

  50% {
    stroke-dashoffset: -24;
    opacity: 0.75;
  }
}

/* Multi-location — pins float */
.page-features .feature-art--map .feature-art__pin {
  transform-box: fill-box;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--map .feature-art__pin {
  animation: fa-pin-float 2.6s ease-in-out infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--map .feature-art__pin--2 {
  animation-delay: 0.35s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--map .feature-art__pin--3 {
  animation-delay: 0.7s;
}

@keyframes fa-pin-float {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-5px);
  }
}

/* White-label app — grid tiles shimmer */
.page-features .feature-card.reveal-feature.is-visible .feature-art--app .feature-art__app-grid rect:nth-child(1) {
  animation: fa-tile 2.2s ease-in-out infinite;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--app .feature-art__app-grid rect:nth-child(2) {
  animation: fa-tile 2.2s ease-in-out infinite 0.2s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--app .feature-art__app-grid rect:nth-child(3) {
  animation: fa-tile 2.2s ease-in-out infinite 0.4s;
}

.page-features .feature-card.reveal-feature.is-visible .feature-art--app .feature-art__app-grid rect:nth-child(4) {
  animation: fa-tile 2.2s ease-in-out infinite 0.6s;
}

@keyframes fa-tile {
  0%,
  100% {
    opacity: 0.35;
  }

  50% {
    opacity: 0.85;
  }
}

/* Bento grid — asymmetric layout (features page only) */
.page-features #feature-grid.feature-grid--bento {
  display: grid;
  gap: var(--space-4);
  align-items: stretch;
}

@media (min-width: 961px) {
  .page-features #feature-grid.feature-grid--bento {
    grid-template-columns: repeat(12, 1fr);
    grid-auto-flow: dense;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(1) {
    grid-column: 1 / span 7;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(2) {
    grid-column: 8 / span 5;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(3) {
    grid-column: 1 / span 5;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(4) {
    grid-column: 6 / span 7;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(5) {
    grid-column: 1 / span 6;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(6) {
    grid-column: 7 / span 6;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(7) {
    grid-column: 1 / span 5;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card:nth-child(8) {
    grid-column: 6 / span 7;
  }

  /* Filtered view: drop rigid spans so remaining cards pack cleanly */
  .page-features #feature-grid.feature-grid--bento.feature-grid--filtered {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-features #feature-grid.feature-grid--bento.feature-grid--filtered .feature-card {
    grid-column: auto;
  }
}

@media (max-width: 960px) {
  .page-features #feature-grid.feature-grid--bento {
    grid-template-columns: 1fr;
  }

  .page-features #feature-grid.feature-grid--bento .feature-card {
    grid-column: 1 / -1;
  }
}

/* Stagger index for entrance + illustration motion */
.page-features #feature-grid .feature-card:nth-child(1) {
  --feature-stagger: 0;
}

.page-features #feature-grid .feature-card:nth-child(2) {
  --feature-stagger: 1;
}

.page-features #feature-grid .feature-card:nth-child(3) {
  --feature-stagger: 2;
}

.page-features #feature-grid .feature-card:nth-child(4) {
  --feature-stagger: 3;
}

.page-features #feature-grid .feature-card:nth-child(5) {
  --feature-stagger: 4;
}

.page-features #feature-grid .feature-card:nth-child(6) {
  --feature-stagger: 5;
}

.page-features #feature-grid .feature-card:nth-child(7) {
  --feature-stagger: 6;
}

.page-features #feature-grid .feature-card:nth-child(8) {
  --feature-stagger: 7;
}

.page-features #feature-grid .feature-card.reveal-feature {
  opacity: 0;
  transform: translate3d(0, 40px, 0) scale(0.985);
  transition:
    opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1) calc(var(--feature-stagger, 0) * 70ms),
    transform 0.75s cubic-bezier(0.22, 1, 0.36, 1) calc(var(--feature-stagger, 0) * 70ms),
    border-color 0.25s ease,
    box-shadow 0.28s ease;
}

.page-features #feature-grid .feature-card.reveal-feature:not(.is-visible):nth-child(odd) {
  transform: translate3d(0, 40px, 0) rotate(-1deg) scale(0.985);
}

.page-features #feature-grid .feature-card.reveal-feature:not(.is-visible):nth-child(even) {
  transform: translate3d(0, 40px, 0) rotate(1deg) scale(0.985);
}

.page-features #feature-grid .feature-card.reveal-feature.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
}

.page-features #feature-grid .feature-card.reveal-feature.is-visible:hover {
  transform: translate3d(0, -6px, 0) rotate(0deg) scale(1);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
  box-shadow: 0 14px 40px color-mix(in srgb, var(--accent) 14%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .page-features #feature-grid .feature-card.reveal-feature,
  .page-features #feature-grid .feature-card.reveal-feature:not(.is-visible):nth-child(odd),
  .page-features #feature-grid .feature-card.reveal-feature:not(.is-visible):nth-child(even) {
    opacity: 1;
    transform: none;
    transition: border-color 0.2s ease;
  }

  .page-features #feature-grid .feature-card.reveal-feature.is-visible .feature-art *,
  .page-features #feature-grid .feature-card.reveal-feature.is-visible .feature-art .feature-art__anim {
    animation: none !important;
  }

  .page-features #feature-grid .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__bar {
    transform: scaleY(1);
  }

  .page-features #feature-grid .feature-card.reveal-feature.is-visible .feature-art--chart .feature-art__trend {
    stroke-dasharray: none;
    stroke-dashoffset: 0;
    opacity: 0.55;
  }

  .page-features #feature-grid .feature-card.reveal-feature.is-visible:hover {
    transform: none;
  }
}

.page-features .steps-interactive {
  margin-top: var(--space-6);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: linear-gradient(
    165deg,
    color-mix(in srgb, var(--accent) 8%, var(--bg-elevated)),
    var(--bg-elevated)
  );
}

.page-features .steps-interactive__tabs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

@media (max-width: 768px) {
  .page-features .steps-interactive__tabs {
    grid-template-columns: repeat(2, 1fr);
  }
}

.page-features .steps-interactive__tab {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.page-features .steps-interactive__tab:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
}

.page-features .steps-interactive__tab:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}

.page-features .steps-interactive__tab.is-active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, var(--bg-elevated));
  box-shadow: 0 8px 28px color-mix(in srgb, var(--accent) 14%, transparent);
}

.page-features .steps-interactive__tab-num {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--accent);
}

.page-features .steps-interactive__tab-label {
  font-size: 0.9375rem;
  font-weight: 700;
}

.page-features .steps-interactive__panels {
  min-height: 11rem;
}

.page-features .step-card--interactive {
  margin: 0;
  min-height: 100%;
}

.page-features .steps-interactive__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}

.page-features .steps-interactive__counter {
  margin: 0;
  flex: 1;
  text-align: center;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-muted);
}

.page-features .steps-interactive__arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.page-features .steps-interactive__arrow:disabled {
  opacity: 0.45;
  pointer-events: none;
}
