/* Feedback View Specific Styles */
/* Styles specific to the feedback page. Uses design tokens from base.css / app.css. */

/* ===== HERO ===== */
.feedback-hero {
  text-align: center;
  padding-top: 6rem;
  padding-bottom: 6rem;
}
@media (min-width: 640px) {
  .feedback-hero {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
}

.feedback-hero__title {
  font-size: var(--font-size-4xl);
  font-weight: 700;
  margin-bottom: var(--space-4);
  color: var(--fg);
  line-height: 1.2;
}
@media (min-width: 640px) {
  .feedback-hero__title {
    font-size: var(--font-size-5xl);
  }
}
@media (min-width: 1024px) {
  .feedback-hero__title {
    font-size: var(--font-size-6xl);
  }
}

.feedback-hero__subtitle {
  font-size: var(--font-size-lg);
  color: var(--muted);
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 640px) {
  .feedback-hero__subtitle {
    font-size: var(--font-size-xl);
  }
}

/* ===== LAYOUT ===== */
.feedback-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 1024px) {
  .feedback-layout {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-12);
  }
}

.feedback-layout__list {
  min-width: 0;
}
@media (min-width: 1024px) {
  .feedback-layout__list {
    grid-column: span 2;
  }
}

.feedback-layout__form {
  min-width: 0;
}
@media (min-width: 1024px) {
  .feedback-layout__form {
    grid-column: span 1;
  }
}

.feedback-section {
  padding-bottom: 6rem;
}

/* ===== LIST ===== */
.feedback-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

/* ===== CARD ===== */
.feedback-card {
  background: var(--glass);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line2);
  border-radius: 24px;
  padding: var(--space-6);
  transition: transform 0.3s ease;
}
.feedback-card:hover {
  transform: translateY(-4px);
}

.feedback-card--empty {
  text-align: center;
  padding: var(--space-8);
}

.feedback-card--empty .feedback-card__emoji {
  font-size: 2.25rem;
  margin-bottom: var(--space-4);
}

.feedback-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-4);
}

.feedback-card__author-wrap {
  flex: 1 1 0%;
  min-width: 0;
}

.feedback-card__author {
  font-weight: 600;
  color: var(--fg);
  margin-bottom: var(--space-1);
}

.feedback-card__company {
  font-size: var(--font-size-sm);
  color: var(--muted);
}

.feedback-card__rating {
  display: flex;
  gap: var(--space-1);
  font-size: var(--font-size-sm);
  color: #facc15;
}

.feedback-card__body {
  color: var(--fg);
  line-height: 1.625;
  margin-bottom: var(--space-4);
}

.feedback-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-xs);
  color: var(--muted);
}

.feedback-card__tag {
  background: rgba(37, 99, 235, 0.1);
  color: var(--cta);
  padding: var(--space-1) var(--space-2);
  border-radius: 8px;
}

/* Dark: --cta blue on navy glass fails AA; use lighter link blue on tag */
html[data-theme="dark"] .feedback-card__tag {
  color: #93c5fd;
}

/* ===== PAGINATION ===== */
.feedback-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-12);
}

.feedback-pagination__link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--line2);
  background: var(--glass);
  color: var(--fg);
  border-radius: 8px;
  text-decoration: none;
  transition: background 0.3s, color 0.3s, border-color 0.3s;
}

.feedback-pagination__icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}
.feedback-pagination__link:hover {
  background: var(--cta);
  color: var(--blue-900);
  border-color: var(--cta);
}

.feedback-pagination__link--current {
  background: var(--cta);
  color: var(--blue-900);
  border-color: var(--cta);
}

.feedback-meta {
  text-align: center;
  margin-top: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--muted);
}

/* ===== FORM PANEL ===== */
.feedback-form-panel {
  background: var(--glass);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line2);
  border-radius: 24px;
  padding: var(--space-8);
  box-shadow: 0 20px 60px rgba(0, 230, 255, 0.14);
}
@media (min-width: 1024px) {
  .feedback-form-panel {
    position: sticky;
    top: 6rem;
  }
}

.feedback-form-panel__heading {
  font-size: var(--font-size-xl);
  font-weight: 600;
  margin-bottom: var(--space-6);
  color: var(--fg);
}

/* ===== SUCCESS MESSAGE ===== */
.feedback-success {
  background: rgba(0, 255, 136, 0.1);
  border: 1px solid var(--color-success);
  border-radius: 12px;
  padding: var(--space-4);
  text-align: center;
  margin-bottom: var(--space-6);
}

.feedback-success__emoji {
  font-size: var(--font-size-2xl);
  margin-bottom: var(--space-2);
}

.feedback-success__title {
  font-weight: 600;
  margin-bottom: var(--space-1);
  color: var(--color-success);
}

.feedback-success__text {
  font-size: var(--font-size-sm);
  color: var(--muted);
}

/* ===== FORM ===== */
.feedback-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.feedback-form__group {
  display: block;
}

.feedback-form__label {
  display: block;
  margin-bottom: var(--space-2);
  font-weight: 500;
  color: var(--fg);
}

.feedback-form__input,
.feedback-form__select,
.feedback-form__textarea {
  width: 100%;
  background: var(--glass);
  border: 1px solid var(--line2);
  border-radius: 12px;
  padding: var(--space-3) var(--space-4);
  color: var(--fg);
  font-family: var(--font-family-sans);
  font-size: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.feedback-form__input:focus,
.feedback-form__select:focus,
.feedback-form__textarea:focus {
  outline: none;
  border-color: var(--cta);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
}

.feedback-form__textarea {
  resize: vertical;
  min-height: 8rem;
}

.feedback-form__input::placeholder,
.feedback-form__textarea::placeholder {
  color: var(--muted);
}

/* Star rating row */
.feedback-form__stars {
  display: flex;
  gap: var(--space-1);
  margin-bottom: var(--space-2);
}

.feedback-form__star {
  font-size: var(--font-size-2xl);
  cursor: pointer;
  transition: color 0.2s;
  color: var(--line2);
}
.feedback-form__star:hover,
.feedback-form__star.feedback-form__star--active {
  color: #facc15;
}

.feedback-form__rating-hint {
  font-size: var(--font-size-sm);
  color: var(--muted);
  margin-top: var(--space-1);
}

/* ===== GDPR BOX ===== */
.feedback-gdpr {
  background: rgba(255, 170, 0, 0.1);
  border: 1px solid var(--color-warning);
  border-radius: 12px;
  padding: var(--space-4);
}

.feedback-gdpr__title {
  font-weight: 600;
  margin-bottom: var(--space-2);
  color: var(--color-warning);
}

.feedback-gdpr__text {
  font-size: var(--font-size-sm);
  color: var(--muted);
  margin-bottom: var(--space-3);
}

.feedback-gdpr__row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.feedback-gdpr__row + .feedback-gdpr__row {
  margin-top: var(--space-3);
}

.feedback-gdpr__checkbox {
  margin-top: 0.25rem;
  flex-shrink: 0;
  accent-color: var(--cta);
}

.feedback-gdpr__label {
  font-size: var(--font-size-sm);
  color: var(--fg);
  cursor: pointer;
}

html[data-theme="light"] .feedback-gdpr {
  background: rgba(251, 191, 36, 0.12);
  border-color: #d97706;
}

html[data-theme="light"] .feedback-gdpr__title {
  color: #92400e;
}

/* CMS / hero: Tailwind green chips (class may use / so avoid broken attribute selectors) */
html[data-theme="light"] .feedback-hero__content [class*="text-green"] {
  color: #065f46 !important;
}
