/*
 * github-analyzer.css
 * Styles for the GitHub Repository Analyzer section
 */

/* ── Section ───────────────────────────────────────────────────────────── */
.github-stats-section {
  padding: 0;
  background-color: var(--color-bg-primary);
  position: relative;
  overflow: hidden;
}

.github-stats-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 85% 15%, rgba(var(--color-accent-2-rgb), 0.05) 0%, transparent 50%),
    radial-gradient(circle at 15% 85%, rgba(var(--color-accent-3-rgb), 0.04) 0%, transparent 50%);
  pointer-events: none;
}

.analyzer-intro {
  margin-bottom: 0.8rem;
}

.analyzer-intro p {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  border-left: 2px solid var(--color-accent-2);
  padding-left: var(--space-xs);
  max-width: 72rem;
}

/* ── Loading / Error states ────────────────────────────────────────────── */
.analyzer-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-md) 0;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.analyzer-dots {
  display: inline-block;
  animation: analyzer-dot-blink 1.2s steps(4, end) infinite;
}

@keyframes analyzer-dot-blink {
  0%, 100% { opacity: 0.2; }
  50%       { opacity: 1; }
}

.analyzer-error {
  text-align: center;
  padding: var(--space-md) 0;
  color: var(--color-error);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}

.analyzer-error p {
  font-size: var(--text-sm);
  max-width: 50rem;
}

/* ── Metric cards ──────────────────────────────────────────────────────── */
.analyzer-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 1rem;
  flex-shrink: 0;
}

@media (max-width: 900px) {
  .analyzer-cards { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .analyzer-cards { grid-template-columns: 1fr 1fr; }
}

.analyzer-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 0.8rem;
  padding: 1rem 1.4rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.4rem;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.analyzer-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--gradient-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}

.analyzer-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.analyzer-card:hover::after {
  transform: scaleX(1);
}

.card-icon {
  font-size: var(--text-md);
  color: var(--color-accent-2);
  opacity: 0.8;
}

#card-repos  .card-icon { color: var(--color-accent-3); }
#card-loc    .card-icon { color: var(--color-accent-2); }
#card-stars  .card-icon { color: var(--color-accent-4); }
#card-quality .card-icon { color: var(--color-accent-1); }

.card-value {
  font-family: var(--font-secondary);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  line-height: 1;
}

.card-label {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}

/* ── Lower grid ────────────────────────────────────────────────────────── */
.analyzer-results {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.analyzer-lower {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1.6rem;
  align-items: start;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

@media (max-width: 1024px) {
  .analyzer-lower { grid-template-columns: 1fr 1fr; }
  .analyzer-top-repos { grid-column: 1 / -1; }
}

@media (max-width: 640px) {
  .analyzer-lower { grid-template-columns: 1fr; }
}

.analyzer-sub-title {
  font-family: var(--font-secondary);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  margin-bottom: 0.8rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.analyzer-sub-title i {
  color: var(--color-accent-2);
  font-size: var(--text-base);
}

/* ── Language bars ─────────────────────────────────────────────────────── */
.lang-bars {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.lang-row {
  animation: fadeInUp 0.4s ease both;
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.lang-meta {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.2rem;
}

.lang-dot {
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  flex-shrink: 0;
}

.lang-name {
  font-family: 'Fira Code', monospace;
  font-size: var(--text-xs);
  color: var(--color-text-primary);
  flex: 1;
}

.lang-pct {
  font-family: 'Fira Code', monospace;
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

.lang-track {
  height: 0.4rem;
  background: var(--color-bg-tertiary);
  border-radius: 0.2rem;
  overflow: hidden;
}

.lang-fill {
  height: 100%;
  width: 0;
  border-radius: 0.2rem;
  animation: lang-grow 1s cubic-bezier(0.4, 0, 0.2, 1) both;
  animation-delay: inherit;
}

@keyframes lang-grow {
  from { width: 0; }
  to   { width: var(--fill-pct); }
}

/* ── Complexity rings ──────────────────────────────────────────────────── */
.complexity-rings {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.complexity-ring {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.ring-svg {
  width: 4.8rem;
  height: 4.8rem;
  flex-shrink: 0;
  transform: rotate(-90deg);
}

.ring-track {
  fill: none;
  stroke: var(--color-bg-tertiary);
  stroke-width: 4;
}

.ring-fill {
  fill: none;
  stroke-width: 4;
  stroke-linecap: round;
  transition: stroke-dasharray 1s cubic-bezier(0.4, 0, 0.2, 1);
}

.ring-label {
  display: flex;
  flex-direction: column;
}

.ring-count {
  font-family: var(--font-secondary);
  font-size: var(--text-md);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  line-height: 1;
}

.ring-name {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  margin-top: 0.3rem;
}

/* ── Top repos list ────────────────────────────────────────────────────── */
.top-repo-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.top-repo-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-left: 2px solid var(--color-accent-2);
  border-radius: 0 0.6rem 0.6rem 0;
  padding: 0.6rem 1rem;
  text-decoration: none;
  color: inherit;
  transition: all 0.25s ease;
  animation: fadeInUp 0.4s ease both;
}

.top-repo-item:hover {
  border-left-color: var(--color-accent-1);
  background: var(--color-bg-tertiary);
  transform: translateX(4px);
}

.repo-item-left {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  min-width: 0;
}

.repo-item-name {
  font-family: 'Fira Code', monospace;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 22rem;
}

.repo-item-meta {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

.repo-lang-dot {
  display: inline-block;
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 50%;
}

.repo-item-complexity {
  font-size: 1.1rem;
  padding: 0.2rem 0.6rem;
  border-radius: 0.3rem;
  font-weight: var(--weight-medium);
}

.complexity-beginner     { background: rgba(0, 229, 179, 0.1);  color: var(--color-accent-3); }
.complexity-intermediate { background: rgba(255, 204, 0, 0.1);  color: var(--color-accent-4); }
.complexity-advanced     { background: rgba(255, 61, 0, 0.1);   color: var(--color-accent-1); }

/* ── Score ring (per repo) ─────────────────────────────────────────────── */
.repo-item-right {
  flex-shrink: 0;
  margin-left: var(--space-sm);
  position: relative;
}

.repo-score-ring {
  position: relative;
  width: 4rem;
  height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.score-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.score-track {
  fill: none;
  stroke: var(--color-bg-tertiary);
  stroke-width: 3;
}

.score-fill {
  fill: none;
  stroke-width: 3;
  stroke-linecap: round;
}

.score-num {
  font-family: var(--font-secondary);
  font-size: 1.1rem;
  font-weight: var(--weight-bold);
  position: relative;
  z-index: 1;
}

/* ── Footer badge ──────────────────────────────────────────────────────── */
.analyzer-footer {
  margin-top: 0.8rem;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.analyzer-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  background: var(--color-bg-tertiary);
  border: 1px solid var(--color-border);
  padding: 0.5rem 1.2rem;
  border-radius: 2rem;
}

.analyzer-badge i {
  color: #3572A5;
}

.analyzer-cached {
  font-size: var(--text-xs);
  color: var(--color-accent-3);
  font-family: 'Fira Code', monospace;
}
