/* ===== Hero ===== */

.hero {
  background-color: var(--surface-primary);
  background-image: var(--gradient-atmosphere);
  padding-top: calc(var(--section-py-lg) + 80px); /* account for fixed nav */
  overflow: hidden;
}

.hero__inner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--space-16);
  align-items: center;
}

.hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.hero__title {
  color: var(--text-primary);
  font-size: var(--text-display);
  font-weight: var(--weight-extralight);
  line-height: var(--leading-tight);
  text-wrap: balance;
}

.hero__subtitle {
  font-size: var(--text-h3);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  max-width: 32rem;
}

.hero__actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.hero__media {
  display: flex;
  justify-content: center;
  min-width: 0;
}

.hero__screenshot {
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
  width: 100%;
}

.hero__screenshot-placeholder svg {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 768px) {
  .hero__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .hero__title {
    font-size: var(--text-h1);
  }

  .hero__subtitle {
    margin-inline: auto;
  }

  .hero__actions {
    justify-content: center;
  }

  .hero__screenshot {
    transform: none;
  }
}

/* ===== Features ===== */

.features {
  background-color: var(--surface-secondary);
}

.feature-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  --card-light: transparent;
  --card-base: transparent;
  --card-shadow: transparent;
  border-width: 3px;
  border-color: var(--card-light) var(--card-base) var(--card-shadow) var(--card-light);
  border-radius: 0;
  padding: calc(var(--space-8) - 2px);
}

.feature-card:nth-child(1) { --card-light: rgba(120, 208, 196, 0.5); --card-base: rgba(90, 184, 176, 0.5); --card-shadow: rgba(64, 136, 128, 0.5); }
.feature-card:nth-child(2) { --card-light: rgba(168, 136, 200, 0.5); --card-base: rgba(136, 104, 168, 0.5); --card-shadow: rgba(104, 72, 136, 0.5); }
.feature-card:nth-child(3) { --card-light: rgba(232, 168, 184, 0.5); --card-base: rgba(208, 136, 154, 0.5); --card-shadow: rgba(160, 96, 112, 0.5); }
.feature-card:nth-child(4) { --card-light: rgba(120, 208, 196, 0.5); --card-base: rgba(90, 184, 176, 0.5); --card-shadow: rgba(64, 136, 128, 0.5); }
.feature-card:nth-child(5) { --card-light: rgba(240, 192, 152, 0.5); --card-base: rgba(232, 160, 112, 0.5); --card-shadow: rgba(184, 120, 72, 0.5); }
.feature-card:nth-child(6) { --card-light: rgba(168, 136, 200, 0.5); --card-base: rgba(136, 104, 168, 0.5); --card-shadow: rgba(104, 72, 136, 0.5); }

.feature-card__icon svg {
  width: 48px;
  height: 48px;
}

.feature-card__title {
  font-size: var(--text-h3);
  font-weight: var(--weight-medium);
}

.feature-card__description {
  font-size: var(--text-body);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}

/* ===== Product Showcase ===== */

.showcase {
  background-color: var(--surface-primary);
}

.showcase .section-header__eyebrow {
  font-size: var(--text-mono-data);
}

.showcase__row:nth-child(2) .section-header__eyebrow {
  color: var(--color-violet-base);
}

.showcase__row:nth-child(3) .section-header__eyebrow {
  color: var(--color-peach-base);
}

.showcase__row {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-16);
  align-items: center;
  margin-bottom: var(--space-20);
}

.showcase__row:last-child {
  margin-bottom: 0;
}

.showcase__row--reversed {
  grid-template-columns: 1fr 1.2fr;
}

.showcase__row--reversed .showcase__media {
  order: 2;
}

.showcase__row--reversed .showcase__content {
  order: 1;
}

.showcase__image-placeholder {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.showcase__image-placeholder svg {
  width: 100%;
  height: auto;
}

.showcase__content h3 {
  font-size: var(--text-h2);
  line-height: var(--leading-snug);
}

.showcase__content p {
  font-size: var(--text-h3);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}

@media (max-width: 768px) {
  .showcase__row,
  .showcase__row--reversed {
    grid-template-columns: 1fr;
    gap: var(--space-8);
    margin-bottom: var(--space-12);
  }

  .showcase__row--reversed .showcase__media,
  .showcase__row--reversed .showcase__content {
    order: unset;
  }
}

/* ===== Use Cases ===== */

.use-cases {
  background-color: var(--surface-secondary);
}

.use-cases .section-header__eyebrow {
  color: var(--color-rose-base);
}

.use-case {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.use-case__icon svg {
  width: 48px;
  height: 48px;
}

.use-case__title {
  font-size: var(--text-h3);
  font-weight: var(--weight-medium);
}

.use-case__description {
  font-size: var(--text-body);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}

/* ===== Pricing ===== */

.pricing {
  background-color: var(--surface-secondary);
}

.pricing__card {
  max-width: 28rem;
  margin-inline: auto;
  background-color: var(--surface-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  padding: var(--space-12) var(--space-10);
  text-align: center;
  box-shadow: var(--shadow-xl);
  position: relative;
  overflow: hidden;
}

.pricing__card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent-primary), var(--color-teal-light));
}

.pricing__features {
  text-align: left;
  margin-bottom: var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.pricing__feature {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-body);
  color: var(--text-secondary);
  line-height: var(--leading-snug);
}

.pricing__check-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-full);
  background-color: var(--color-teal-bg);
  color: var(--color-teal-base);
  flex-shrink: 0;
}

.pricing__check {
  width: 14px;
  height: 14px;
}

.pricing__card .btn--lg {
  width: 100%;
  justify-content: center;
}

/* ===== Pricing (page) ===== */

.pricing-page {
  padding-top: calc(var(--section-py-lg) + 80px); /* account for fixed nav */
  padding-bottom: var(--section-py-lg);
  background-color: var(--surface-secondary);
  min-height: 100vh;
}

.pricing__price-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-1);
}

.pricing__was {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.pricing__now {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}

.pricing__badge {
  display: inline-block;
  background-color: var(--color-teal-bg);
  color: var(--color-teal-base);
  font-size: var(--text-caption);
  font-weight: var(--weight-bold);
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.pricing__amount-regular {
  font-size: var(--text-body);
  font-weight: var(--weight-medium);
  color: var(--text-muted);
  text-decoration: line-through;
  line-height: 1;
}

.pricing__amount {
  font-size: var(--text-display);
  font-weight: var(--weight-light);
  color: var(--accent-primary);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}

.pricing__period {
  font-size: var(--text-h3);
  color: var(--text-muted);
}

.pricing__savings {
  font-size: var(--text-caption);
  font-weight: var(--weight-bold);
  color: var(--accent-primary);
  letter-spacing: var(--tracking-wide);
}

.pricing__per-account {
  font-size: var(--text-small);
  color: var(--text-muted);
  text-align: center;
  margin-top: var(--space-3);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--border-default);
}

.pricing__per-account strong {
  color: var(--accent-primary);
  font-weight: var(--weight-semibold);
}

/* ===== Request Access ===== */

.request-access {
  background-color: var(--surface-primary);
  background-image: var(--gradient-atmosphere);
}

.request-access .section-header__eyebrow {
  color: var(--color-violet-base);
}

.request-access .section-header__title {
  color: var(--text-primary);
}

.request-access .section-header__subtitle {
  color: var(--text-secondary);
}

.request-access__form[hidden],
.request-access__success[hidden] {
  display: none;
}

.request-access__form {
  max-width: 28rem;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-label {
  font-size: var(--text-small);
  font-weight: var(--weight-medium);
  color: var(--text-primary);
}

.form-label__optional {
  font-weight: var(--weight-regular);
  color: var(--text-muted);
}

.form-input {
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--text-body);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background-color: var(--surface-elevated);
  color: var(--text-primary);
  transition: border-color var(--transition-fast);
}

.form-input::placeholder {
  color: var(--text-muted);
}

.form-input:focus {
  outline: none;
  border-color: var(--accent-primary);
  box-shadow: var(--shadow-glow-teal);
}

.request-access .btn {
  width: 100%;
  justify-content: center;
}

.request-access__note {
  text-align: center;
  font-size: var(--text-small);
  color: var(--text-muted);
}

.request-access .btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.request-access__error {
  font-size: var(--text-small);
  line-height: var(--leading-normal);
  color: var(--color-rose-base);
  background-color: var(--color-rose-bg);
  border: 1px solid rgba(208, 136, 154, 0.3);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}

.request-access__error a {
  color: var(--color-rose-light);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.request-access__error a:hover {
  color: var(--text-primary);
}

.request-access__success {
  max-width: 28rem;
  margin-inline: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.request-access__success-icon {
  width: 48px;
  height: 48px;
}

.request-access__success-title {
  color: var(--text-primary);
  font-size: var(--text-h2);
}

.request-access__success-text {
  color: var(--text-secondary);
  font-size: var(--text-body);
  line-height: var(--leading-normal);
}

/* ===== CTA Banner ===== */

.cta-banner {
  background-color: var(--surface-primary);
  background-image: var(--gradient-atmosphere);
}

.cta-banner__title {
  color: var(--text-primary);
  margin-bottom: var(--space-4);
  text-wrap: balance;
}

.cta-banner__subtitle {
  color: var(--text-secondary);
  font-size: var(--text-h3);
  max-width: 36rem;
  margin-inline: auto;
  margin-bottom: var(--space-8);
}

/* ===== Footer ===== */

.footer {
  background-color: var(--surface-sidebar);
  padding-block: var(--space-16);
  color: var(--text-muted);
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}

.footer__logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-h3);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

.footer__description {
  font-size: var(--text-small);
  color: var(--text-muted);
  line-height: var(--leading-normal);
  max-width: 20rem;
}

.footer__heading {
  font-size: var(--text-small);
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-4);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer__links a {
  font-size: var(--text-small);
  color: var(--text-muted);
  transition: color var(--transition-fast);
}

.footer__links a:hover {
  color: var(--text-primary);
}

.footer__bottom {
  padding-top: var(--space-8);
  border-top: 1px solid var(--border-subtle);
  font-size: var(--text-small);
}

.footer__disclaimer {
  margin-top: var(--space-2);
  font-size: var(--text-caption);
  color: var(--text-muted);
}

@media (max-width: 768px) {
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }

  .footer__brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 480px) {
  .footer__grid {
    grid-template-columns: 1fr;
  }
}
