/* ============================================================
   pages.css — page-type-specific styles
   (archive index, news list, registration form, hub cards)
   ============================================================ */

/* ── Generic hub cards (e.g. "Авторам", section landings) ── */
.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);border-top:var(--border);border-left:var(--border);margin-top:8px}
.card-link{display:block;padding:26px;border-right:var(--border);border-bottom:var(--border);transition:background var(--t-fast)}
.card-link:hover{background:var(--bg-soft)}
.card-link .ct-tag{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--mute)}
.card-link h3{font-size:1.05rem;font-weight:600;margin:8px 0 6px;color:var(--ink)}
.card-link p{font-size:.86rem;color:var(--steel)}
.card-link .go{display:inline-block;margin-top:12px;font-family:var(--font-mono);font-size:.78rem;color:var(--accent)}

/* ── Archive index ── */
.year-block{margin-top:48px}
.year-block:first-of-type{margin-top:24px}
.year-head{display:flex;align-items:baseline;gap:16px;padding-bottom:12px;border-bottom:var(--border-strong);margin-bottom:0}
.year-num{font-size:1.8rem;font-weight:600;letter-spacing:-.01em}
.year-tag{font-family:var(--font-mono);font-size:.74rem;color:var(--mute)}
.archive-grid{display:grid;grid-template-columns:repeat(2,1fr);border-left:var(--border)}
.archive-card{padding:24px;border-right:var(--border);border-bottom:var(--border);transition:background var(--t-fast)}
.archive-card:hover{background:var(--bg-soft)}
.archive-card .ac-kind{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-line);background:var(--accent-soft);padding:2px 7px;display:inline-block}
.archive-card h3{font-size:1.05rem;font-weight:600;margin:12px 0 6px}
.archive-card h3 a{color:var(--ink)}
.archive-card h3 a:hover{color:var(--accent-ink)}
.archive-card .ac-meta{font-family:var(--font-mono);font-size:.74rem;color:var(--mute)}
.archive-card .ac-langs{margin-top:10px;display:flex;gap:8px;font-family:var(--font-mono);font-size:.72rem}
.archive-card .ac-langs a{border:var(--border);padding:2px 8px;color:var(--steel)}
.archive-card .ac-langs a:hover{border-color:var(--line-strong);color:var(--ink)}

/* ── News list ── */
.news-list{border-top:var(--border);margin-top:8px}
.news-item{padding:22px 0;border-bottom:var(--border)}
.news-item .ni-date{font-family:var(--font-mono);font-size:.74rem;color:var(--mute);margin-bottom:6px}
.news-item h3{font-size:1.1rem;font-weight:600;margin-bottom:6px}
.news-item h3 a:hover{color:var(--accent-ink)}
.news-item p{font-size:.9rem;color:var(--steel)}

/* ── Registration form ── */
.reg-form{max-width:640px;margin-top:8px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}  /* honeypot (anti-spam) */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form-row .field{margin-bottom:0}
.field label{font-size:.82rem;font-weight:500;color:var(--ink-70)}
.field .req{color:var(--accent)}
.field input,.field textarea,.field select{
  width:100%;padding:11px 14px;border:var(--border);background:var(--bg);
  font-size:.95rem;border-radius:var(--radius);transition:border-color var(--t-fast)
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:120px;resize:vertical}
.field .hint{font-size:.76rem;color:var(--mute)}
.field-check{display:flex;gap:10px;align-items:flex-start;margin-bottom:18px;font-size:.86rem;color:var(--steel)}
.field-check input{width:16px;height:16px;margin-top:3px;flex-shrink:0}
.field-check a{color:var(--accent-ink);border-bottom:1px solid var(--accent-line)}
.form-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:8px}
.form-status{font-size:.88rem;display:none}
.form-status.show{display:block}
.form-status.ok{color:var(--accent-ink)}
.form-status.err{color:#b00020}
.form-fallback{font-size:.82rem;color:var(--mute);margin-top:16px;line-height:1.6}
.form-fallback a{color:var(--accent-ink);border-bottom:1px solid var(--accent-line)}

/* ── 404 page ── */
.err{padding:64px var(--gutter) 80px}
.err-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.err-code{font-family:var(--font-mono);font-size:6rem;line-height:1;font-weight:600;color:var(--accent);letter-spacing:-.03em;margin:6px 0 16px}
.err h1{font-size:1.9rem;font-weight:600;line-height:1.15;letter-spacing:-.01em;margin-bottom:14px}
.err .err-sub{color:var(--steel)}
.err-lead{font-size:1rem;color:var(--steel);margin-bottom:28px;line-height:1.7}
.err-links{display:grid;grid-template-columns:1fr 1fr;border-top:var(--border);border-left:var(--border);max-width:520px}
.err-links a{padding:14px 16px;border-right:var(--border);border-bottom:var(--border);font-size:.95rem;font-weight:500;color:var(--ink);display:flex;justify-content:space-between;align-items:baseline;gap:10px;transition:background var(--t-fast)}
.err-links a:hover{background:var(--bg-soft)}
.err-links a span{font-family:var(--font-mono);font-size:.68rem;color:var(--mute);text-transform:uppercase;letter-spacing:.05em}
.err-visual{aspect-ratio:4/5;border:var(--border);overflow:hidden;background:var(--accent-soft)}
.err-visual img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:900px){.err-inner{grid-template-columns:1fr;gap:32px}.err-visual{order:-1;aspect-ratio:16/9}}
@media (max-width:700px){.err-links{grid-template-columns:1fr}.err-code{font-size:4.5rem}}

/* ── Simple two-column info layout for content pages with a sidebar ── */
.content-layout{display:grid;grid-template-columns:1fr;gap:48px}
@media (min-width:901px){
  .content-layout.has-aside{grid-template-columns:1fr 300px}
}
.aside-box{border:var(--border);padding:24px;align-self:start}
.aside-box h4{font-size:.95rem;font-weight:600;margin-bottom:12px;padding-bottom:10px;border-bottom:var(--border)}
.aside-box p{font-size:.85rem;color:var(--steel);margin-bottom:10px}
