/* ==========================================================================
   Connection Page
   ========================================================================== */

.connection__preview {
  margin-top: var(--space-sm);
  transition: var(--transition-base);

  & header {
    margin-bottom: var(--space-sm);
  }

  & .label {
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--color-ink);
  }

  & .card {
    background: var(--color-canvas);
    border: var(--border-thick);
    box-shadow: var(--shadow-medium);
    padding: var(--space-md);
  }

  & .text {
    font-size: var(--font-size-base);
    line-height: 1.5;
    margin-bottom: 0;
    color: var(--color-ink);
  }

  & footer {
    font-size: var(--font-size-sm);
    color: #666;
    font-style: italic;
  }
}

/* ==========================================================================
   Pages - Legal, Contact & Instructions
   ========================================================================== */

/* ==========================================================================
   Legal Pages (Terms & Privacy)
   ========================================================================== */

.legal-page {
  max-width: 800px;
  margin: var(--space-lg) auto;
  padding: var(--space-2xl) var(--space-xl);
  background-color: white;
  border: var(--border-thick);
  box-shadow: var(--shadow-large);
}

.legal-page > h1 {
  font-size: var(--font-size-2xl);
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
  color: var(--color-ink);
}

.legal-page__effective {
  font-size: var(--font-size-sm);
  color: #666;
  margin-bottom: var(--space-xl);
  font-style: italic;
}

.legal-page__section {
  margin-bottom: var(--space-xl);
}

.legal-page__section h2 {
  font-size: var(--font-size-lg);
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: var(--space-md);
  color: var(--color-ink);
  border-bottom: var(--border);
  padding-bottom: var(--space-sm);
}

.legal-page__section h3 {
  font-size: var(--font-size-md);
  font-weight: 700;
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
  color: var(--color-ink);
}

.legal-page__section p {
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.legal-page__section ul,
.legal-page__section ol {
  margin-left: var(--space-lg);
  margin-bottom: var(--space-md);
}

.legal-page__section li {
  margin-bottom: var(--space-sm);
  line-height: 1.6;
}

.legal-page__footer {
  margin-top: var(--space-2xl);
  padding-top: var(--space-xl);
  border-top: var(--border-thick);
}

/* ==========================================================================
   Contact Page
   ========================================================================== */

.contact-page {
  max-width: 800px;
  margin: var(--space-lg) auto;
  padding: var(--space-2xl) var(--space-xl);
  background-color: white;
  border: var(--border-thick);
  box-shadow: var(--shadow-large);
}

.contact-page__header {
  text-align: center;
  margin-bottom: var(--space-xl);
}

.contact-page__header h1 {
  font-size: var(--font-size-2xl);
  font-weight: 900;
  text-transform: uppercase;
  color: var(--color-ink);
}

.contact-page__photo {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-2xl);
}

.photo-placeholder {
  width: 200px;
  height: 200px;
  border: var(--border-thick);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-gray-100);
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
}

.contact-page__section {
  margin-bottom: var(--space-xl);
}

.contact-page__section h2 {
  font-size: var(--font-size-lg);
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: var(--space-md);
  color: var(--color-ink);
  border-bottom: var(--border);
  padding-bottom: var(--space-sm);
}

.contact-page__section p {
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.contact-page__section--highlight {
  background-color: var(--color-gray-100);
  padding: var(--space-lg);
  border: var(--border-thick);
}

.contact-page__email {
  display: inline-block;
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-ink);
  text-decoration: none;
  margin-top: var(--space-sm);
}

.contact-page__email:hover {
  text-decoration: underline;
}

.contact-page__footer {
  margin-top: var(--space-2xl);
  padding-top: var(--space-xl);
  border-top: var(--border-thick);
}

/* ==========================================================================
   Instructions
   ========================================================================== */
.instructions {
  max-width: 800px;
  margin: var(--space-lg) auto;
  padding: var(--space-2xl) var(--space-xl);
  background-color: white;
  border: var(--border-thick);
  box-shadow: var(--shadow-large);

  & ol {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
  }
}

/* ==========================================================================
    Stanard page
    ========================================================================== */
.page {
  max-width: var(--content-width);
  margin: var(--space-md) auto;
  padding: var(--space-2xl) var(--space-lg);
}

/* ==========================================================================
    Subscription Page
    ========================================================================== */

.subscription-status {
  text-align: center;
  & .subscription-status__badge {
    display: inline-block;
    padding: var(--space-xs) var(--space-md);
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-ink);
    margin-bottom: var(--space-md);
    position: relative;
    isolation: isolate;
  }

  & .subscription-status__badge::before {
    content: '';
    position: absolute;
    top: 0.1em;
    left: -0.3em;
    width: calc(100% + 0.6em);
    height: 1.1em;
    background: var(--color-ink);
    z-index: -1;
    transform: skewX(-30deg) rotate(-5deg);
  }

  &.subscription-status--pro .subscription-status__badge::before,
  &.subscription-status--comped .subscription-status__badge::before
  {
    background: var(--color-primary);
  }

  &.subscription-status--basic .subscription-status__badge::before {
    background: var(--color-accent);
  }

  & .subscription-status__price {
    font-size: var(--font-size-2xl);
    font-weight: 900;
    margin-bottom: var(--space-md);
  }

  & .subscription-status__details {
    margin-bottom: var(--space-lg);

    & p {
      margin-bottom: var(--space-sm);
      line-height: 1.5;
    }
  }

  & .subscription-status__renewal {
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
    font-style: italic;
  }

  & .subscription-status__features {
    text-align: left;
    margin: var(--space-lg) 0;
    padding: var(--space-lg);
    background: var(--color-gray-100);
    border: var(--border);

    & h3 {
      font-size: var(--font-size-md);
      font-weight: 700;
      margin-bottom: var(--space-md);
      text-transform: uppercase;
    }

    & ul {
      list-style: none;
      padding: 0;
    }

    & li {
      padding: var(--space-xs) 0;
      padding-left: var(--space-md);
      position: relative;

      &::before {
        content: '✓';
        position: absolute;
        left: 0;
        color: var(--color-success);
        font-weight: 700;
      }
    }
  }
}

.subscription-intro {
  text-align: center;
  margin-bottom: var(--space-xl);
  padding: var(--space-xl);
  background: var(--color-gray-100);
  border: var(--border-thick);

  & .subscription-intro__remaining {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);

    &.subscription-intro__remaining--exhausted .subscription-intro__count {
      color: var(--color-danger);
    }
  }

  & .subscription-intro__count {
    font-size: var(--font-size-3xl);
    font-weight: 900;
    line-height: 1;
  }

  & .subscription-intro__label {
    font-size: var(--font-size-sm);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-gray-600);
  }

  & .subscription-intro__notice {
    margin-top: var(--space-md);
    font-size: var(--font-size-md);
    color: var(--color-ink);
  }
}

.subscription-faq {
  margin-top: var(--space-2xl);
  padding: var(--space-xl);
  background: var(--color-info-light, #e3f2fd);
  border: var(--border-thick);
  box-shadow: var(--shadow-medium);

  & h3 {
    font-size: var(--font-size-lg);
    font-weight: 700;
    margin-bottom: var(--space-md);
    text-transform: uppercase;
  }

  & p {
    line-height: 1.7;
  }
}

/* ==========================================================================
   Empty State
   ========================================================================== */

.empty-state {
  text-align: center;
  padding: var(--space-2xl);
  background: var(--color-warning-light, #fff9e6);
  border: var(--border-thick);
  box-shadow: var(--shadow-large);

  & h2 {
    font-size: var(--font-size-2xl);
    font-weight: 900;
    text-transform: uppercase;
    color: var(--color-ink);
    margin-bottom: var(--space-md);
    letter-spacing: 0.02em;
  }

  & p {
    font-size: var(--font-size-md);
    color: var(--color-gray-700);
    line-height: 1.6;
    margin-bottom: var(--space-sm);
  }

  & p:last-child {
    margin-bottom: 0;
    font-style: italic;
  }
}
