/* Nevanu — Team Profile Page */

.tp { max-width: 800px; margin: 0 auto; padding: 40px 20px 80px; font-family: var(--font-body, 'Outfit', sans-serif); color: var(--color-dark-gray, #3a3634); }
.tp-loader { text-align: center; padding: 80px 20px; color: var(--color-medium-gray, #c4c0bc); }
.tp-loader .spinner { width: 32px; height: 32px; border: 3px solid var(--color-light-gray, #f0eeec); border-top-color: var(--color-primary, #f27182); border-radius: 50%; animation: tp-spin 0.8s linear infinite; margin: 0 auto 16px; }
@keyframes tp-spin { to { transform: rotate(360deg); } }

/* Hero */
.tp-hero { text-align: center; margin-bottom: 48px; }
.tp-hero__photo { width: 160px; height: 160px; border-radius: 50%; object-fit: cover; border: 4px solid var(--color-primary, #f27182); margin-bottom: 20px; }
.tp-hero__name { font-family: var(--font-display, 'Eros', serif); font-size: 2.5rem; font-weight: 400; margin: 0 0 4px; }
.tp-hero__role { font-size: 0.9375rem; color: var(--color-medium-gray, #c4c0bc); font-weight: 300; }
.tp-hero__exp { display: inline-block; margin-top: 12px; padding: 4px 16px; border-radius: 100px; font-size: 0.75rem; font-weight: 500; background: rgba(242,113,130,0.1); color: var(--color-primary, #f27182); }

/* Radar Chart */
.tp-radar { margin: 0 auto 48px; text-align: center; }
.tp-radar svg { max-width: 340px; width: 100%; }

/* Section titles */
.tp-section-title { font-family: var(--font-display, 'Eros', serif); font-size: 1.5rem; font-weight: 400; margin: 0 0 24px; }
.tp-section-subtitle { font-size: 0.8125rem; color: var(--color-medium-gray, #c4c0bc); margin: -16px 0 24px; }

/* Match Statements (Bars) */
.tp-statements { margin-bottom: 48px; }
.tp-bar { margin-bottom: 16px; }
.tp-bar__header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.tp-bar__text { font-size: 0.875rem; font-weight: 400; }
.tp-bar__pct { font-size: 0.875rem; font-weight: 600; color: var(--color-primary, #f27182); }
.tp-bar__track { height: 8px; background: var(--color-light-gray, #f0eeec); border-radius: 4px; overflow: hidden; }
.tp-bar__fill { height: 100%; background: linear-gradient(90deg, var(--color-primary, #f27182), var(--color-primary-light, #f7949f)); border-radius: 4px; transition: width 1s ease-out; }

/* Tags (Personality, Values) */
.tp-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 48px; }
.tp-tag { display: inline-block; padding: 6px 18px; border-radius: 100px; font-size: 0.8125rem; font-weight: 500; background: var(--color-off-white, #faf8f6); border: 1px solid var(--color-light-gray, #f0eeec); color: var(--color-dark-gray, #3a3634); }
.tp-tag--accent { background: rgba(242,113,130,0.08); border-color: rgba(242,113,130,0.2); color: var(--color-primary, #f27182); }

/* Tinder-Style Matching */
.tp-matching { background: var(--color-off-white, #faf8f6); border-radius: 20px; padding: 32px; margin-bottom: 48px; }
.tp-matching__title { font-family: var(--font-display, 'Eros', serif); font-size: 1.5rem; margin: 0 0 8px; text-align: center; }
.tp-matching__desc { font-size: 0.8125rem; color: var(--color-medium-gray, #c4c0bc); margin: 0 0 24px; text-align: center; }

.tq-progress { text-align: center; font-size: 0.75rem; color: var(--color-medium-gray, #c4c0bc); margin-bottom: 16px; letter-spacing: 0.04em; }
.tq-card-area { display: flex; justify-content: center; margin-bottom: 24px; min-height: 200px; align-items: center; }
.tq-card { background: #fff; border-radius: 20px; padding: 40px 32px; max-width: 340px; width: 100%; text-align: center; box-shadow: 0 4px 24px rgba(0,0,0,0.06); cursor: grab; user-select: none; touch-action: pan-y; }
.tq-card:active { cursor: grabbing; }
.tq-quote { font-size: 2rem; color: var(--color-primary, #f27182); opacity: 0.3; line-height: 1; margin-bottom: 8px; }
.tq-text { font-family: var(--font-display, 'Eros', serif); font-size: 1.125rem; font-weight: 400; line-height: 1.5; color: var(--color-dark-gray, #3a3634); }

.tq-buttons { display: flex; justify-content: center; gap: 32px; }
.tq-btn { width: 56px; height: 56px; border-radius: 50%; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
.tq-btn:active { transform: scale(0.9); }
.tq-btn--no { background: #fff; border: 2px solid #e53e3e; color: #e53e3e; }
.tq-btn--no:hover { background: #e53e3e; color: #fff; }
.tq-btn--yes { background: var(--color-primary, #f27182); color: #fff; border: 2px solid var(--color-primary, #f27182); }
.tq-btn--yes:hover { background: var(--color-primary-dark, #d94f60); border-color: var(--color-primary-dark, #d94f60); }

.tq-result { text-align: center; padding: 24px 0; }
.tq-result__emoji { font-size: 3rem; margin-bottom: 8px; }
.tq-result__pct { font-size: 3.5rem; font-weight: 700; line-height: 1; }
.tq-result__label { font-size: 0.875rem; color: var(--color-medium-gray, #c4c0bc); margin-top: 4px; }
.tq-result__msg { font-size: 0.9375rem; color: var(--color-dark-gray, #3a3634); margin-top: 12px; line-height: 1.5; }
.tq-retry { background: none; border: none; color: var(--color-medium-gray, #c4c0bc); font-size: 0.8125rem; cursor: pointer; margin-top: 16px; text-decoration: underline; font-family: var(--font-body, 'Outfit', sans-serif); }

/* CTA */
.tp-cta { text-align: center; padding: 48px 0; }
.tp-cta__btn { display: inline-block; padding: 16px 48px; border-radius: 100px; background: var(--color-primary, #f27182); color: #fff; font-family: var(--font-body, 'Outfit', sans-serif); font-size: 1rem; font-weight: 600; text-decoration: none; transition: all 0.3s; }
.tp-cta__btn:hover { background: var(--color-primary-dark, #d94f60); transform: translateY(-2px); }

/* Sources */
.tp-sources { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-bottom: 32px; }
.tp-source { font-size: 0.6875rem; padding: 3px 10px; border-radius: 100px; background: var(--color-light-gray, #f0eeec); color: var(--color-medium-gray, #c4c0bc); }

/* Responsive */
@media (max-width: 480px) {
  .tp { padding: 24px 16px 60px; }
  .tp-hero__name { font-size: 2rem; }
  .tp-hero__photo { width: 120px; height: 120px; }
  .tp-matching { padding: 24px 20px; }
}
