/* =========================================================
   PROJECTS VIEW — Coro Layout 2026
   ========================================================= */
.projects-body { overflow: auto; height: 100%; background: var(--bg-900); }

/* Header */
.projects-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(15,17,23,0.9); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.projects-header-inner {
  max-width: 1200px; margin: 0 auto; padding: 16px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.projects-logo { display: flex; align-items: center; gap: 14px; color: var(--accent); }
.projects-logo > div > h1 { font-size: 22px; color: var(--text-100); line-height: 1.1; }
.projects-logo > div > span { font-size: 12px; color: var(--text-400); font-weight: 400; }

/* Main */
.projects-main { max-width: 1200px; margin: 0 auto; padding: 40px 24px 80px; }

.projects-section-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 28px; gap: 16px; flex-wrap: wrap;
}
.projects-section-header h2 { font-size: 24px; color: var(--text-100); }

.projects-search-wrap {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-700); border: 1px solid var(--border-light);
  border-radius: var(--radius-sm); padding: 8px 12px; min-width: 220px;
  color: var(--text-400);
}
.projects-search-wrap input {
  background: none; border: none; outline: none; font-size: 13px;
  color: var(--text-100); flex: 1; font-family: var(--font);
}
.projects-search-wrap input::placeholder { color: var(--text-600); }

/* Grid */
.projects-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px;
}

/* Card */
.project-card {
  background: var(--bg-700); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition), transform 200ms ease;
  animation: fadeInUp 250ms ease both;
  display: flex; flex-direction: column;
}
.project-card:hover { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 8px 32px rgba(59,130,246,0.15); transform: translateY(-2px); }

.project-card-header {
  background: linear-gradient(135deg, var(--bg-600), var(--bg-500));
  padding: 24px; display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  border-bottom: 1px solid var(--border);
}
.project-card-icon {
  width: 46px; height: 46px; border-radius: var(--radius); background: var(--accent-glow);
  border: 1px solid var(--border-light); display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
}
.project-card-actions { display: flex; gap: 6px; opacity: 0; transition: opacity var(--transition); }
.project-card:hover .project-card-actions { opacity: 1; }
.card-action-btn {
  background: var(--bg-600); border: 1px solid var(--border-light);
  border-radius: var(--radius-sm); padding: 6px; cursor: pointer;
  color: var(--text-400); transition: color var(--transition), background var(--transition);
}
.card-action-btn:hover { color: var(--text-100); background: var(--bg-500); }
.card-action-btn.danger:hover { color: var(--danger); background: var(--danger-glow); border-color: var(--danger); }

.project-card-body { padding: 18px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.project-card-name { font-size: 16px; font-weight: 700; color: var(--text-100); line-height: 1.3; }
.project-card-desc { font-size: 13px; color: var(--text-400); line-height: 1.5; flex: 1; }

.project-card-footer {
  padding: 12px 18px; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.project-card-meta { display: flex; gap: 16px; }
.project-meta-item {
  display: flex; align-items: center; gap: 5px;
  font-size: 11px; color: var(--text-600); font-weight: 500;
}
.project-meta-item svg { opacity: 0.7; }
.project-card-date { font-size: 11px; color: var(--text-600); }

.open-btn {
  padding: 6px 14px; border-radius: var(--radius-sm); font-size: 12px; font-weight: 600;
  background: var(--accent); color: white; border: none; cursor: pointer;
  transition: background var(--transition); white-space: nowrap;
}
.open-btn:hover { background: var(--accent-hover); }

.empty-icon { color: var(--text-600); }

/* Animation delays for grid */
.projects-grid .project-card:nth-child(1) { animation-delay: 0ms; }
.projects-grid .project-card:nth-child(2) { animation-delay: 50ms; }
.projects-grid .project-card:nth-child(3) { animation-delay: 100ms; }
.projects-grid .project-card:nth-child(4) { animation-delay: 150ms; }
.projects-grid .project-card:nth-child(5) { animation-delay: 200ms; }
.projects-grid .project-card:nth-child(6) { animation-delay: 250ms; }

/* ═══════════════════════════════════════
   MOBILE — Projects List (≤ 640px)
═══════════════════════════════════════ */
@media (max-width: 640px) {
  .projects-header-inner { padding: 12px 16px; gap: 10px; }
  .projects-logo > div > h1 { font-size: 18px; }
  .projects-logo > div > span { display: none; }
  .projects-logo svg { width: 26px; height: 26px; }
  .projects-main { padding: 20px 14px 60px; }
  .projects-section-header { flex-direction: column; align-items: stretch; margin-bottom: 18px; gap: 12px; }
  .projects-section-header h2 { font-size: 20px; }
  .projects-search-wrap { min-width: unset; }
  .projects-grid { grid-template-columns: 1fr; gap: 14px; }
  .project-card-header { padding: 16px; }
  .project-card-icon { width: 38px; height: 38px; }
  /* Acciones siempre visibles en mobile */
  .project-card-actions { opacity: 1 !important; }
  .card-action-btn { padding: 8px; }
  .project-card-body { padding: 14px; }
  .project-card-name { font-size: 15px; }
  .project-card-desc { font-size: 12px; }
  .project-card-footer { padding: 10px 14px; flex-wrap: wrap; gap: 10px; }
  .open-btn { padding: 8px 20px; font-size: 13px; font-weight: 700; border-radius: 8px; }
  .modal-box { width: calc(100vw - 32px) !important; max-width: 420px; margin: 16px; }
  .modal-body { padding: 16px; }
  .modal-footer { padding: 12px 16px; }
}

