/*
 * CODESONS Listings — add-listing form and my-listings view.
 * Design system: codesons-wp-core skill
 */

/* ── Add listing wrap ─────────────────────────────────────────────────────── */

.codesons-listing-wrap {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 48px 16px;
  font-family: 'Source Sans 3', 'Segoe UI', sans-serif;
}

.codesons-listing-card {
  background: #ffffff;
  border: 1px solid var(--codesons-gray-200);
  border-radius: 12px;
  box-shadow: var(--codesons-shadow-sm);
  width: 100%;
  max-width: 640px;
  padding: 48px 40px 40px;
}

.codesons-listing-title {
  font-family: 'Plus Jakarta Sans', 'Segoe UI', sans-serif;
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--codesons-gray-800);
  margin: 0 0 28px;
  line-height: 1.2;
}

/* ── Textarea ─────────────────────────────────────────────────────────────── */

.codesons-form-textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.6;
}

/* ── Radio group ──────────────────────────────────────────────────────────── */

.codesons-radio-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.codesons-radio-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--codesons-gray-200);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.codesons-radio-label:hover {
  border-color: var(--codesons-primary-500);
  background: var(--codesons-primary-50);
}

.codesons-radio-label:has(.codesons-radio:checked) {
  border-color: var(--codesons-primary-500);
  background: var(--codesons-primary-50);
}

.codesons-radio {
  width: 18px;
  height: 18px;
  min-width: 18px;
  margin-top: 1px;
  cursor: pointer;
  accent-color: var(--codesons-primary-600);
}

.codesons-radio-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.4;
}

.codesons-radio-text strong {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--codesons-gray-800);
}

.codesons-radio-text small {
  font-size: 0.8125rem;
  color: var(--codesons-gray-500);
}

/* ── Success block (large variant) ───────────────────────────────────────────*/

.codesons-form-success--large {
  text-align: center;
  padding: 40px 24px;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  font-size: 1.0625rem;
}

.codesons-form-success--large p {
  margin: 0;
}

.codesons-btn--inline {
  width: auto;
  padding: 10px 24px;
  margin-top: 8px;
}

/* ── Generic notices ──────────────────────────────────────────────────────── */

.codesons-notice {
  font-size: 1rem;
  color: var(--codesons-gray-600);
  line-height: 1.6;
  text-align: center;
}

.codesons-notice--error {
  color: var(--codesons-error);
}

/* ── Buttons: small + danger ──────────────────────────────────────────────── */

.codesons-btn--sm {
  padding: 8px 16px;
  font-size: 0.875rem;
  width: auto;
}

.codesons-btn--danger {
  background: var(--codesons-error, #DC2626);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 8px;
  font-family: 'Plus Jakarta Sans', 'Segoe UI', sans-serif;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s ease;
}

.codesons-btn--danger:hover:not(:disabled) {
  background: #B91C1C;
}

/* ── My Listings wrap ─────────────────────────────────────────────────────── */

.codesons-my-listings-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 40px 24px;
  font-family: 'Source Sans 3', 'Segoe UI', sans-serif;
}

.codesons-my-listings-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 28px;
}

.codesons-my-listings-title {
  font-family: 'Plus Jakarta Sans', 'Segoe UI', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--codesons-gray-800);
  margin: 0;
}

.codesons-my-listings-empty {
  padding: 48px 24px;
  text-align: center;
  color: var(--codesons-gray-500);
  background: var(--codesons-gray-50);
  border-radius: 12px;
  border: 1px solid var(--codesons-gray-200);
}

/* ── Listing row ──────────────────────────────────────────────────────────── */

.codesons-my-listings-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.codesons-my-listing-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  background: #ffffff;
  border: 1px solid var(--codesons-gray-200);
  border-radius: 10px;
  box-shadow: var(--codesons-shadow-sm);
  transition: box-shadow 0.15s ease;
}

.codesons-my-listing-row:hover {
  box-shadow: var(--codesons-shadow-md);
}

.codesons-my-listing-row__info {
  flex: 1;
  min-width: 0;
}

.codesons-my-listing-row__title {
  font-family: 'Plus Jakarta Sans', 'Segoe UI', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--codesons-gray-800);
  margin: 0 0 6px;
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.codesons-my-listing-row__title a {
  color: inherit;
  text-decoration: none;
}

.codesons-my-listing-row__title a:hover {
  color: var(--codesons-primary-600);
}

.codesons-my-listing-row__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.codesons-my-listing-row__date {
  font-size: 0.8125rem;
  color: var(--codesons-gray-400);
}

.codesons-my-listing-row__actions {
  flex-shrink: 0;
}

.codesons-delete-form {
  margin: 0;
}

/* ── Status badges ────────────────────────────────────────────────────────── */

.codesons-status {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.4;
}

.codesons-status--active {
  background: #F0FDF4;
  color: #15803D;
}

.codesons-status--pending {
  background: #FFFBEB;
  color: #B45309;
}

.codesons-status--rejected {
  background: var(--codesons-error-bg);
  color: var(--codesons-error);
}

.codesons-status--expired {
  background: var(--codesons-gray-100);
  color: var(--codesons-gray-500);
}

.codesons-status--draft {
  background: var(--codesons-gray-100);
  color: var(--codesons-gray-500);
}

/* ── Responsive ───────────────────────────────────────────────────────────── */

@media ( max-width: 640px ) {	
  .codesons-listing-wrap {
    padding: 24px 12px;
  }

  .codesons-listing-card {
    padding: 28px 20px 24px;
    border-radius: 0;
    border-left: none;
    border-right: none;
    box-shadow: none;
    max-width: 100%;
  }

  .codesons-my-listings-wrap {
    padding: 24px 16px;
  }

  .codesons-my-listing-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .codesons-my-listing-row__info {
    width: 100%;
  }

  .codesons-my-listing-row__actions {
    width: 100%;
  }

  .codesons-delete-form,
  .codesons-delete-form button {
    width: 100%;
  }
}
