/* SMS / OTP sign-in pages — chat-app inspired layout (issue: crew phone OTP). */
/* Scoped tokens: do not use outside .auth-page--sms-chat */
@layer components {
  .auth-page--sms-chat {
    --sms-wa-green: #25d366;
    --sms-wa-green-hover: #20bd5a;
    --sms-wa-green-focus-ring: color-mix(in srgb, #25d366 55%, transparent);
    --sms-wa-teal: #075e54;
    --sms-wa-teal-mid: #128c7e;
    --sms-chat-wallpaper: #e5ddd5;
    --sms-chat-wallpaper-dark: #0b141a;
    --sms-card-border: color-mix(in srgb, #25d366 28%, var(--color-border));

    background-color: var(--sms-chat-wallpaper);
    background-image: radial-gradient(
      circle at 1px 1px,
      color-mix(in srgb, var(--color-text) 7%, transparent) 1px,
      transparent 0
    );
    background-size: 14px 14px;
  }

  @media (prefers-color-scheme: dark) {
    .auth-page--sms-chat {
      background-color: var(--sms-chat-wallpaper-dark);
      background-image: radial-gradient(
        circle at 1px 1px,
        color-mix(in srgb, var(--color-nav-text) 12%, transparent) 1px,
        transparent 0
      );
    }
  }

  .card--auth.card--sms-chat {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--sms-card-border);
    border-radius: var(--radius-lg);
    box-shadow:
      0 8px 32px color-mix(in srgb, var(--color-text) 10%, transparent),
      0 0 0 1px color-mix(in srgb, #25d366 8%, transparent);
  }

  .sms-chat-auth__header-stripe {
    display: block;
    height: 5px;
    margin: calc(-1 * var(--space-8)) calc(-1 * var(--space-8)) var(--space-5);
    width: calc(100% + 2 * var(--space-8));
    background: linear-gradient(
      90deg,
      var(--sms-wa-teal) 0%,
      var(--sms-wa-teal-mid) 45%,
      var(--sms-wa-teal) 100%
    );
  }

  .sms-chat-auth__bubble-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    margin: 0 auto var(--space-4);
    border-radius: 50%;
    background: color-mix(in srgb, var(--sms-wa-green) 16%, var(--color-surface));
    color: var(--sms-wa-teal-mid);
  }

  .sms-chat-auth__bubble-icon svg {
    width: 1.5rem;
    height: 1.5rem;
  }

  .auth-page--sms-chat .auth-card__title {
    text-align: center;
  }

  .auth-page--sms-chat .auth-card__subtitle {
    margin: 0 0 var(--space-6);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
    text-align: center;
  }

  .auth-page--sms-chat .auth-card__back:hover {
    color: var(--sms-wa-teal-mid);
  }

  .auth-page--sms-chat .btn--primary {
    background: var(--sms-wa-green);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 2px 8px color-mix(in srgb, #25d366 35%, transparent);
  }

  .auth-page--sms-chat .btn--primary:hover {
    background: var(--sms-wa-green-hover);
    border-color: transparent;
    color: #fff;
  }

  .auth-page--sms-chat .btn--primary:focus-visible {
    outline: 2px solid var(--sms-wa-green-focus-ring);
    outline-offset: 2px;
  }

  .auth-page--sms-chat .form-group input:focus,
  .auth-page--sms-chat .form-group select:focus {
    border-color: var(--sms-wa-green);
    box-shadow: var(--shadow-focus-input);
  }

  .auth-page--sms-chat .auth-card__footer a {
    color: var(--sms-wa-teal-mid);
    font-weight: 500;
  }

  .auth-page--sms-chat .auth-card__footer a:hover {
    color: var(--sms-wa-teal);
  }

  /* Public email sign-in page → /crew/sign-in (same palette as SMS OTP screens) */
  .sessions-new__sms {
    margin: var(--space-5) 0 var(--space-4);
  }

  .sessions-new__sms-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    background: #25d366;
    color: #fff !important;
    border-color: transparent;
    font-weight: 600;
    text-decoration: none;
    box-shadow: 0 2px 10px color-mix(in srgb, #25d366 30%, transparent);
  }

  .sessions-new__sms-cta:hover {
    background: #20bd5a;
    color: #fff !important;
    border-color: transparent;
  }

  .sessions-new__sms-cta:focus-visible {
    outline: 2px solid color-mix(in srgb, #25d366 55%, transparent);
    outline-offset: 2px;
  }

  .sessions-new__sms-cta-icon {
    display: flex;
    flex-shrink: 0;
  }
}
