/* ── skills.css ── */
#skills {
  background: var(--white);
  border-top: 1px solid var(--ink-12);
}

.skills-layout {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.2rem;
}

.skill-group {
  background: var(--cream);
  border: 1px solid var(--ink-12);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}
.skill-group:hover {
  box-shadow: 0 6px 24px rgba(12, 24, 36, 0.07);
  transform: translateY(-2px);
  border-color: var(--blue-light);
}

.skill-group-icon {
  width: 42px; height: 42px;
  background: var(--blue-pale);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.1rem;
  font-size: 18px;
}

.skill-group h4 {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 1.1rem;
}

.skill-items { display: flex; flex-direction: column; gap: 0.6rem; }

.skill-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.86rem;
  color: var(--ink-70);
}

.skill-bar {
  width: 72px; height: 3px;
  background: var(--ink-12);
  border-radius: 2px;
  overflow: hidden;
  flex-shrink: 0;
}
.skill-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--blue-accent), var(--blue-mid));
  border-radius: 2px;
  width: 0%;
  transition: width 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.skill-bar-fill.animated { width: var(--fill-width, 80%); }

.skill-lang-section {
  grid-column: 1 / -1;
  background: var(--cream);
  border: 1px solid var(--ink-12);
  border-radius: var(--radius-lg);
  padding: 2rem;
  display: flex;
  align-items: center;
  gap: 3rem;
}
.skill-lang-section h4 {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  white-space: nowrap;
}

.lang-chips { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.lang-chip {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  color: var(--ink-70);
  background: var(--white);
  border: 1px solid var(--ink-12);
  padding: 0.4rem 1rem;
  border-radius: 30px;
}
.lang-chip strong { font-weight: 500; color: var(--ink); }
.lang-chip em {
  font-style: normal;
  font-size: 0.75rem;
  color: var(--blue-accent);
  margin-left: 0.3rem;
}

@media (max-width: 1024px) { .skills-layout { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) {
  .skills-layout { grid-template-columns: 1fr; }
  .skill-lang-section { flex-direction: column; align-items: flex-start; gap: 1rem; }
}