/* Copyright 2025-2026 Renofy Ltd. All rights reserved. */
/* Milestone Card Component - Mobile-first responsive design */

/* Base styles (Mobile) */
.milestone-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1rem;
  align-self: start;
  display: flex;
  flex-direction: column;
  position: relative;
  box-shadow: var(--shadow);
}

/* Header is a vertical stack of rows. Each row is a flex pair (label on
   the left, status pill on the right) so the work-status badge lines up
   with the title and the payment-status badge lines up with the £cost.
   No more absolute positioning — the rows simply flow. */
.milestone-card__header {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 0.75rem;
}

.milestone-card__header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-width: 0;
}

.milestone-card__header-row--cost {
  align-items: baseline;
}

.milestone-card__title {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-semibold);
  flex: 1;
  min-width: 0;
}

.milestone-card__cost {
  font-weight: var(--font-weight-semibold);
  color: var(--color-pink);
  font-size: var(--font-size-lg);
}

.milestone-card__description {
  color: var(--color-text-secondary);
  font-size: var(--font-size-lg);
}

.milestone-card__content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.milestone-card__content > *:not(:last-child) {
  margin-bottom: auto;
}

/* Timeline section */
.milestone-card__timeline {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--color-border);
}

.milestone-card__timeline-item {
  display: flex;
  align-items: center;
  margin-bottom: 0.5rem;
  font-size: var(--font-size-sm);
}

.milestone-card__timeline-item:last-child {
  margin-bottom: 0;
}

.milestone-card__timeline-icon {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  margin-right: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  flex-shrink: 0;
}

.milestone-card__timeline-icon--complete {
  background-color: color-mix(in srgb, var(--color-mint) 20%, var(--color-white));
  color: var(--color-mint);
}

.milestone-card__timeline-icon--pending {
  background: var(--color-bg-surface);
  color: var(--color-text-secondary);
}

.milestone-card__timeline-text {
  color: var(--color-text-secondary);
  flex: 1;
}

/* Review history section */
.milestone-card__review-history {
  background: var(--color-bg-surface);
  border-radius: var(--radius-base);
  padding: 0.75rem;
  margin-top: 0.75rem;
  border-left: 0.25rem solid var(--color-warning);
}

.milestone-card__review-title {
  color: var(--color-text-primary);
  margin-bottom: 0.75rem;
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
}

.milestone-card__review-item {
  margin-bottom: 0.75rem;
  padding: 0.75rem;
  background: var(--color-white);
  border-radius: var(--radius-base);
  border: 1px solid var(--color-border);
}

.milestone-card__review-item:last-child {
  margin-bottom: 0;
}

.milestone-card__review-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.4rem;
}

.milestone-card__review-date {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.milestone-card__review-content {
  color: var(--color-text-secondary);
  margin: 0;
}

.milestone-card__review-action {
  font-size: var(--font-size-sm);
}

/* Actions section */
.milestone-card__actions {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.milestone-card__form {
  display: inline;
}

.milestone-card__actions .button--outline-danger {
  color: var(--color-danger);
  border-color: var(--color-danger);
}

.milestone-card__actions .button--outline-danger:hover {
  color: var(--color-white);
}

/* Submission comment */
.milestone-card__submission-comment {
  margin-top: 1rem;
  padding: 0.75rem;
  background-color: var(--color-background);
  border-radius: var(--radius-base);
  font-size: var(--font-size-sm);
}

.milestone-card__submission-comment strong {
  color: var(--color-text-primary);
}

.milestone-card__submission-comment p {
  margin: 0.5rem 0 0 0;
  color: var(--color-text-secondary);
}

/* Pending delete notice */
.milestone-card__pending-notice {
  display: block;
  margin-top: 0.5rem;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-danger);
}

/* History link */
.milestone-card__history-link {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}

.milestone-card__link {
  display: inline-block;
  color: var(--color-pink);
  text-decoration: none;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: color var(--transition-smooth);
}

.milestone-card__link:hover {
  color: var(--color-pink-dark, #d63384);
  text-decoration: underline;
}

/* Desktop enhancement (min-width: larger screens) */
@media (min-width: 821px) {
  .milestone-card {
    padding: 1.25rem;
  }

  .milestone-card__header {
    padding-bottom: 1rem;
    margin-bottom: 1rem;
  }

  .milestone-card__cost {
    font-size: var(--font-size-base);
  }

  .milestone-card__description {
    font-size: var(--font-size-base);
  }

  .milestone-card__timeline {
    margin-top: 1rem;
    padding-top: 1rem;
  }

  .milestone-card__review-history {
    margin-top: 1rem;
  }

  .milestone-card__review-header {
    margin-bottom: 0.5rem;
  }

  .milestone-card__review-date {
    font-size: var(--font-size-xs);
  }

  .milestone-card__review-action {
    font-size: var(--font-size-base);
  }

  .milestone-card__actions {
    margin-top: 1rem;
    padding-top: 1rem;
  }
}
