.home-page {
  background: var(--color-bg);
  color: var(--color-text);

  .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 var(--space-xl);
  }

  /* HERO */
  .hero {
    position: relative;
    padding: 140px 0;

    .hero-bg {
      position: absolute;
      inset: 0;
      background:
        radial-gradient(
          circle at 20% 30%,
          var(--color-primary-soft),
          transparent 45%
        ),
        radial-gradient(
          circle at 80% 20%,
          var(--color-primary-soft),
          transparent 50%
        );
      opacity: 0.7;
    }

    .hero-inner {
      position: relative;
      display: grid;
      grid-template-columns: 1.2fr 0.8fr;
      align-items: center;
      gap: 80px;

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

      .hero-content {
        display: flex;
        flex-direction: column;
        align-items: flex-start;

        @media (max-width: 900px) {
          align-items: center;
        }
      }

      .badge {
        display: inline-block;
        background: var(--color-primary-soft);
        color: var(--color-primary);
        padding: 4px 10px;
        border-radius: var(--radius-2xl);
        font-size: var(--font-xs);
        margin-bottom: var(--space-lg);
      }
    }

    h1 {
      font-size: 52px;
      line-height: 1.05;
      letter-spacing: -0.03em;
      margin-bottom: var(--space-lg);
    }

    .sub {
      font-size: var(--font-lg);
      color: var(--color-text-light);
      max-width: 520px;
      margin-bottom: var(--space-xl);
      line-height: 1.6;
    }

    .cta {
      display: flex;
      align-items: center;
      gap: var(--space-lg);
      margin-bottom: var(--space-xl);

      @media (max-width: 900px) {
        justify-content: center;
        flex-direction: column;
      }

      .cta-note {
        font-size: var(--font-sm);
        color: var(--color-text-light);
      }
    }

    .mini-proof {
      display: flex;
      flex-direction: column;
      gap: 6px;
      font-size: var(--font-sm);
      color: var(--color-text-light);

      @media (max-width: 900px) {
        align-items: center;
      }
    }

    /* RIGHT SIDE */
    .hero-visual {
      position: relative;
      display: flex;
      justify-content: center;
    }

    .dashboard-card.large {
      width: 320px;
      padding: var(--space-xl);
      border-radius: 16px;

      background: var(--color-surface); /* replace gradient */
      border: 1px solid var(--color-border);

      box-shadow:
        0 10px 30px rgba(0, 0, 0, 0.08),
        var(--shadow-md);
    }

    .card-header {
      font-weight: var(--font-semibold);
      margin-bottom: var(--space-lg);
    }

    .appointment {
      display: flex;
      justify-content: space-between;
      align-items: center;

      padding: var(--space-sm) var(--space-md);
      margin-bottom: var(--space-sm);
      border-radius: var(--radius-md);

      font-size: var(--font-sm);
      font-weight: 500;

      background-color: transparent;

      /* subtle structure without heavy UI */
      border-bottom: 1px solid var(--color-border);

      &:last-child {
        border-bottom: none;
      }

      span:first-child {
        color: var(--color-text);
      }

      span:last-child {
        font-size: var(--font-xs);
        padding: var(--space-xs) var(--space-sm);
        border-radius: var(--radius-2xl);
        font-weight: var(--font-medium);
      }

      &.ok {
        span:last-child {
          background-color: var(--color-positive-soft);
          color: var(--color-positive);
        }
      }

      &.missed {
        span:last-child {
          background-color: var(--color-negative-soft);
          color: var(--color-danger);
        }
      }

      &.pending {
        span:last-child {
          background-color: var(--color-warning-soft);
          color: var(--color-warning);
        }
      }

      &:hover {
        background-color: var(--hover-bg);
      }
    }

    .hero-floating {
      position: absolute;
      bottom: -20px;
      right: 10px;
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      padding: 10px 14px;
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-md);
      font-size: var(--font-sm);
      color: var(--color-text-light);

      @media (max-width: 480px) {
        display: none;
      }
    }
  }

  /* STRIP */
  .strip {
    background-color: var(--color-surface);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);

    .strip-inner {
      display: flex;
      justify-content: space-between;
      align-items: center;

      padding: var(--space-lg) 0;
      font-size: var(--font-sm);

      div {
        position: relative;
        padding-left: var(--space-lg);
        color: var(--color-text-light);

        &::before {
          content: "";
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%);
          width: 6px;
          height: 6px;
          border-radius: 50%;
          background-color: var(--color-primary);
          opacity: 0.6;
        }
      }

      @media (max-width: 768px) {
        flex-direction: column;
        gap: var(--space-md);
        text-align: center;

        div {
          padding-left: 0;

          &::before {
            display: none;
          }
        }
      }
    }
  }

  /* FEATURES */
  .features {
    padding: 80px 0;

    h2 {
      text-align: center;
      margin-bottom: 40px;
    }

    .feature-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;

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

    .feature-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-lg);
      padding: var(--space-xl);
      transition: 0.25s ease;
      overflow: hidden;

      &:hover {
        transform: translateY(-6px);
        border-color: var(--color-primary);
      }

      .icon {
        background: var(--color-primary-soft);
        width: 40px;
        height: 40px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: var(--space-md);
      }

      h3 {
        font-size: var(--font-lg);
        margin-bottom: var(--space-sm);
      }

      p {
        font-size: var(--font-sm);
        line-height: 1.5;
      }
    }
  }

  /* STEPS */
  .steps-section {
    .steps-flow {
      display: flex;
      flex-direction: column;
      gap: var(--space-xl);
      margin-top: var(--space-xl);

      .step-item {
        display: flex;
        gap: var(--space-xl);
      }

      /* LEFT SIDE (timeline) */
      .step-line {
        display: flex;
        flex-direction: column;
        align-items: center;
        min-width: 40px;
      }

      .step-dot {
        width: 34px;
        height: 34px;
        border-radius: 50%;
        background: var(--color-primary);
        color: var(--color-light);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: var(--font-sm);
        font-weight: var(--font-semibold);
        box-shadow: var(--shadow-sm);
      }

      .step-bar {
        width: 2px;
        flex: 1;
        background: var(--color-border);
        margin-top: var(--space-sm);
      }

      /* RIGHT SIDE */
      .step-content {
        padding-bottom: var(--space-xl);

        h3 {
          font-size: var(--font-lg);
          margin-bottom: var(--space-sm);
        }

        p {
          color: var(--color-text-light);
          font-size: var(--font-sm);
          max-width: 500px;
        }
      }

      /* last item cleanup */
      .step-item:last-child .step-bar {
        display: none;
      }
    }
  }

  .trust {
    padding: 80px 0;
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);

    @media (max-width: 480px) {
      padding: 60px 0;
    }

    .container {
      max-width: 900px;
      text-align: center;
    }

    h2 {
      font-size: var(--font-xxl);
      font-weight: var(--font-bold);
      margin-bottom: var(--space-lg);
      color: var(--color-text);

      @media (max-width: 480px) {
        font-size: var(--font-xl);
      }
    }

    .sub {
      font-size: var(--font-base);
      color: var(--color-text-light);
      margin-bottom: var(--space-xxl);
      line-height: 1.6;
    }

    .mini-proof {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: 14px 28px;
      margin-top: var(--space-xl);
      color: var(--color-text);
      font-size: var(--font-sm);

      div {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 6px 12px;
        background: var(--color-primary-soft);
        border-radius: var(--radius-lg);
        color: var(--color-text);
        font-weight: var(--font-medium);
      }
    }
  }

  /* CTA */
  .cta-section {
    padding: 80px 0;

    .cta-box {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-2xl);
      padding: 48px 32px;
      box-shadow: var(--shadow-sm);
      text-align: center;

      @media (max-width: 480px) {
        padding: 32px 20px;
      }

      h2 {
        /* font-size: 40px;
        line-height: 1.1;
        margin-bottom: var(--space-lg); */
        font-size: var(--font-xxl);
        font-weight: var(--font-bold);
        margin-bottom: 12px;
      }

      p {
        /* max-width: 650px;
        margin: 0 auto var(--space-xl);
        color: var(--color-text-light);
        font-size: var(--font-lg); */
        font-size: var(--font-base);
        color: var(--color-text-light);
        margin-bottom: 24px;
        line-height: 1.6;
      }
    }

    .cta-actions {
      /* margin-top: var(--space-lg);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: var(--space-md); */
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
    }

    .cta-actions .btn--primary {
      transform: scale(1.05);
    }

    .cta-note {
      font-size: var(--font-sm);
      color: var(--color-text-light);
    }
  }
}
