/* proyectos.css */
.proyectos-hero { position: relative; padding: 58px 0 36px; overflow: hidden; }
.proyectos-hero::before {
  content: ''; position: absolute; inset: 18px -20px auto auto;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle, rgba(77,255,196,0.12), transparent 62%);
  pointer-events: none;
}
.proyectos-hero h1 { font-family: var(--font-hand); font-weight: 700; font-size: clamp(32px,5vw,52px); line-height: 1.1; margin-bottom: 8px; }
.proyectos-hero h1 .accent { color: var(--mint); }
.proyectos-hero p { font-size: 15px; color: var(--textm); max-width: 560px; line-height: 1.6; }
.orbital-mark { position: absolute; top: 44px; right: 34px; width: 104px; height: 104px; opacity: 0.75; pointer-events: none; }
.orbital-core { position: absolute; inset: 42px; border-radius: 50%; background: #4DFFC4; box-shadow: 0 0 24px rgba(77,255,196,0.5); }
.orbital-ring { position: absolute; inset: 16px; border: 1px solid rgba(77,255,196,0.24); border-radius: 50%; }
.orbital-ring-one { transform: rotate(22deg) scaleX(1.35); }
.orbital-ring-two { transform: rotate(-34deg) scaleX(1.45); border-style: dashed; }
.project-filter-panel {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  margin: 10px 0 28px; padding: 16px 18px;
  border: 1px solid rgba(77,255,196,0.12); border-radius: 18px;
  background: linear-gradient(90deg, rgba(77,255,196,0.07), transparent 34%), rgba(7,16,30,0.74);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02), 0 14px 40px rgba(0,0,0,0.18);
}
.project-filter-grid { display: flex; gap: 8px; flex-wrap: wrap; }
.project-filter-panel .filter-btn {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500; letter-spacing: 0.4px;
  color: #8aa4be; padding: 6px 13px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.035);
  cursor: pointer; transition: transform 0.2s, color 0.2s, border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.project-filter-panel .filter-btn:hover, .project-filter-panel .filter-btn.active {
  color: #4DFFC4; border-color: rgba(77,255,196,0.36); background: rgba(77,255,196,0.08);
  box-shadow: 0 0 18px rgba(77,255,196,0.08); transform: translateY(-1px);
}
.proyectos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px,1fr)); gap: 20px; margin-bottom: 56px; }
.proj-full-card {
  position: relative;
  background: linear-gradient(145deg, rgba(77,255,196,0.055), transparent 38%), linear-gradient(180deg, rgba(11,24,40,0.96), rgba(7,16,30,0.98));
  border: 1px solid rgba(77,255,196,0.13); border-radius: 22px; overflow: hidden;
  text-decoration: none; color: inherit; display: flex; flex-direction: column; min-height: 360px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.26); transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.proj-full-card:hover { transform: translateY(-6px); border-color: rgba(77,255,196,0.42); box-shadow: 0 26px 70px rgba(0,0,0,0.36), 0 0 28px rgba(77,255,196,0.08); }
.proj-full-card.hidden { display: none; }
.proj-card-orbit { position: absolute; right: -42px; top: -42px; width: 132px; height: 132px; border: 1px dashed rgba(77,255,196,0.16); border-radius: 50%; pointer-events: none; }
.proj-cover { height: 142px; position: relative; overflow: hidden; background: #03060d; }
.proj-cover img { width:100%; height:100%; object-fit:cover; filter: saturate(0.9) contrast(1.05); transition: transform 0.35s, filter 0.35s; }
.proj-full-card:hover .proj-cover img { transform: scale(1.045); filter: saturate(1.08) contrast(1.12); }
.proj-cover-overlay { position:absolute; inset:0; background: linear-gradient(0deg, rgba(7,16,30,1), transparent 62%), linear-gradient(90deg, rgba(77,255,196,0.16), transparent 46%); }
.proj-scanline { position: absolute; inset: 0; background: repeating-linear-gradient(180deg, transparent 0 8px, rgba(77,255,196,0.035) 9px 10px); opacity: 0.55; }
.proj-full-body { padding: 18px 20px; flex: 1; display: flex; flex-direction: column; gap: 10px; }
.proj-coordinates { font-family: var(--font-mono); font-size: 9px; letter-spacing: 1.5px; color: rgba(77,255,196,0.58); text-transform: uppercase; }
.proj-full-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.proj-full-name { font-family: var(--font-sign); font-size: 24px; line-height: 1.05; font-weight: 700; color: var(--text); }
.proj-badges { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; flex-shrink: 0; }
.proj-lang-badge, .proj-status-wip, .proj-status-arc { font-family: var(--font-mono); font-size: 9px; padding: 3px 8px; border-radius: 999px; }
.lang-python     { background: rgba(77,255,196,0.08); color: var(--mint); border: 1px solid rgba(77,255,196,0.24); }
.lang-go         { background: rgba(34,211,238,0.08); color: #22d3ee; border: 1px solid rgba(34,211,238,0.24); }
.lang-rust       { background: rgba(251,146,60,0.08); color: #fb923c; border: 1px solid rgba(251,146,60,0.24); }
.lang-c, .lang-c\+\+ { background: rgba(167,139,250,0.08); color: #a78bfa; border: 1px solid rgba(167,139,250,0.24); }
.lang-javascript { background: rgba(245,158,11,0.08); color: #fbbf24; border: 1px solid rgba(245,158,11,0.24); }
.lang-bash       { background: rgba(245,158,11,0.08); color: #fbbf24; border: 1px solid rgba(245,158,11,0.24); }
.proj-status-wip { background: rgba(245,158,11,0.1); color: #fbbf24; border: 1px solid rgba(245,158,11,0.24); }
.proj-status-arc { background: rgba(255,255,255,0.04); color: #4a6a85; border: 1px solid rgba(255,255,255,0.08); }
.proj-full-desc { font-size: 13px; color: var(--textm); line-height: 1.58; flex: 1; }
.proj-full-tags { display: flex; gap: 5px; flex-wrap: wrap; }
.proj-full-footer { padding: 13px 20px; border-top: 1px solid rgba(77,255,196,0.08); display: flex; align-items: center; justify-content: space-between; background: rgba(3,6,13,0.22); }
.proj-stars { font-family: var(--font-mono); font-size: 11px; color: #fbbf24; }
.proj-gh-link { font-family: var(--font-mono); font-size: 11px; color: var(--mint); opacity: 0.72; transition: opacity 0.2s, transform 0.2s; }
.proj-full-card:hover .proj-gh-link { opacity: 1; transform: translateX(2px); }
.proj-single-hero { padding: 40px 0 24px; }
.proj-single-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.proj-single-title  { font-family: var(--font-hand); font-weight: 700; font-size: clamp(28px,4vw,44px); margin-bottom: 10px; }
.proj-single-desc   { font-size: 16px; color: var(--textm); line-height: 1.65; max-width: 520px; margin-bottom: 16px; }
.proj-single-meta   { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.proj-single-actions { flex-shrink: 0; padding-top: 40px; }
.proj-single-content { margin-top: 40px; }
@media (max-width: 700px) {
  .orbital-mark { display: none; }
  .project-filter-panel { align-items: flex-start; flex-direction: column; }
  .proyectos-grid { grid-template-columns: 1fr; }
}
