/* ============================================================
   Tako — Journal + Admin (usa los tokens de style.css)
   ============================================================ */

/* ---------- Journal: listado ---------- */
.journal-hero { padding: var(--space-12) 0 var(--space-6); }
.journal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-4);
  padding-bottom: var(--space-12);
}
.article-card {
  background: var(--black-elev);
  border: 1px solid var(--black-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  color: var(--white);
  display: flex;
  flex-direction: column;
  transition: transform .3s var(--ease), border-color .3s var(--ease);
}
.article-card:hover { transform: translateY(-4px); border-color: var(--white-line-strong); }
.article-card__cover { aspect-ratio: 16/9; width: 100%; object-fit: cover; background: var(--black-line); }
.article-card__body { padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-1); flex: 1; }
.article-card__title { font-family: var(--font-display); font-size: 1.25rem; line-height: 1.25; }
.article-card__excerpt { color: var(--white-dim); font-size: .95rem; flex: 1; }
.article-card__meta { color: var(--white-mute); font-size: .8rem; margin-top: var(--space-1); }
.journal-empty, .journal-loading { color: var(--white-dim); text-align: center; padding: var(--space-12) 0; }

/* ---------- Post individual ---------- */
.post-wrap { max-width: 760px; margin: 0 auto; padding: var(--space-8) 0 var(--space-12); }
.post-cover { width: 100%; border-radius: var(--radius-lg); margin-bottom: var(--space-4); }
.post-title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3rem); line-height: 1.1; margin-bottom: var(--space-2); }
.post-meta { color: var(--white-mute); margin-bottom: var(--space-6); }
.post-body { color: var(--white-dim); font-size: 1.08rem; line-height: 1.75; }
.post-body h2, .post-body h3 { font-family: var(--font-display); color: var(--white); margin: var(--space-6) 0 var(--space-2); }
.post-body p { margin-bottom: var(--space-3); }
.post-body a { color: var(--yellow); }
.post-body img { max-width: 100%; border-radius: var(--radius); margin: var(--space-3) 0; }
.post-body code { background: var(--black-elev); padding: 2px 6px; border-radius: var(--radius-sm); font-size: .9em; }
.post-body pre { background: var(--black-elev); border: 1px solid var(--black-line); padding: var(--space-3); border-radius: var(--radius); overflow-x: auto; }
.post-body blockquote { border-left: 3px solid var(--yellow); padding-left: var(--space-3); color: var(--white-dim); margin: var(--space-3) 0; }

/* ============================================================
   ADMIN
   ============================================================ */
.admin-shell { min-height: 100vh; background: var(--black); color: var(--white); font-family: var(--font-body); }
.admin-container { max-width: 980px; margin: 0 auto; padding: var(--space-6) var(--gutter); }

/* login */
.admin-login { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--gutter); }
.admin-card {
  width: 100%; max-width: 420px;
  background: var(--black-elev); border: 1px solid var(--black-line);
  border-radius: var(--radius-lg); padding: var(--space-6);
}
.admin-card img.logo { height: 32px; margin-bottom: var(--space-4); }
.admin-card h1 { font-family: var(--font-display); font-size: 1.5rem; margin-bottom: var(--space-1); }
.admin-card p.sub { color: var(--white-dim); margin-bottom: var(--space-4); font-size: .95rem; }

.field { margin-bottom: var(--space-3); }
.field label { display: block; font-size: .85rem; color: var(--white-dim); margin-bottom: 6px; }
.field input, .field select, .field textarea {
  width: 100%; background: var(--black); color: var(--white);
  border: 1px solid var(--black-line); border-radius: var(--radius-sm);
  padding: 11px 13px; font-family: inherit; font-size: .95rem;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--yellow-dim); }
.field textarea { min-height: 360px; resize: vertical; font-family: ui-monospace, monospace; line-height: 1.6; }

.btn-admin {
  background: var(--yellow); color: var(--black); border: none;
  border-radius: var(--radius-sm); padding: 11px 20px; font-weight: 600;
  font-family: var(--font-display); cursor: pointer; font-size: .95rem;
}
.btn-admin:hover { filter: brightness(1.05); }
.btn-admin:disabled { opacity: .5; cursor: not-allowed; }
.btn-ghost {
  background: transparent; color: var(--white); border: 1px solid var(--black-line);
  border-radius: var(--radius-sm); padding: 9px 16px; cursor: pointer; font-size: .9rem;
}
.btn-ghost:hover { border-color: var(--white-line-strong); }
.btn-danger { color: #ff6b6b; border-color: rgba(255,107,107,.3); }

.admin-msg { padding: 11px 14px; border-radius: var(--radius-sm); margin-bottom: var(--space-3); font-size: .9rem; }
.admin-msg.error { background: rgba(255,107,107,.12); color: #ff8a8a; }
.admin-msg.ok { background: var(--yellow-soft); color: var(--yellow); }

.admin-topbar { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--gutter); border-bottom: 1px solid var(--black-line); }
.admin-topbar img { height: 26px; }
.admin-topbar .who { color: var(--white-mute); font-size: .85rem; }

.admin-row { display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }
.admin-row.between { justify-content: space-between; }
.admin-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
@media (max-width: 640px) { .admin-two-col { grid-template-columns: 1fr; } }

.art-list { list-style: none; padding: 0; margin: var(--space-4) 0 0; }
.art-item {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-2);
  padding: var(--space-3); border: 1px solid var(--black-line);
  border-radius: var(--radius); margin-bottom: var(--space-2); background: var(--black-elev);
}
.art-item__info { min-width: 0; }
.art-item__title { font-weight: 600; font-family: var(--font-display); }
.art-item__meta { color: var(--white-mute); font-size: .8rem; margin-top: 2px; }
.badge { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.badge.published { background: var(--yellow-soft); color: var(--yellow); }
.badge.draft { background: var(--white-line); color: var(--white-dim); }
.badge.archived { background: rgba(255,107,107,.12); color: #ff8a8a; }
.cover-preview { max-width: 200px; border-radius: var(--radius-sm); margin-top: var(--space-1); }
.hidden { display: none !important; }
