/* bulletin.css — public bulletin feed (/bulletin).
   Tokens from tokens.css. Dark-mode cue: posts gain a thin cyan
   left-edge — the same attention-grabbing pattern used by the
   moncash-prompt banner in Phase 3. */

body.bulletin-page {
    background:
        radial-gradient(circle at top right, var(--bg-radial) 0, transparent 28rem),
        linear-gradient(180deg, var(--bg-edge) 0%, var(--bg) 48%, var(--bg-edge) 100%);
    color: var(--text);
}
body.bulletin-page header {
    background: var(--surface);
    border-bottom-color: var(--border);
}
body.bulletin-page .site-name { color: var(--text); }
body.bulletin-page header nav a { color: var(--accent); }
body.bulletin-page main { max-width: 44rem; padding: 2rem 1rem 3rem; }

/* --- Hero --------------------------------------------------------- */

.bulletin-hero { margin-bottom: 1.25rem; }
.bulletin-hero .page-label {
    margin: 0 0 0.35rem;
    color: var(--accent);
    font-size: 0.85rem;
    font-weight: 700;
}
.bulletin-hero h1 {
    margin: 0;
    font-size: clamp(2rem, 5vw, 3rem);
    color: var(--text);
    line-height: 1.15;
}
.bulletin-hero .page-subhead {
    margin: 0.5rem 0 0;
    color: var(--text-muted);
    line-height: 1.6;
}
.bulletin-retention-note {
    margin: 0.4rem 0 0;
    color: var(--text-muted);
    font-size: 0.85rem;
    font-style: italic;
}

/* --- Publish CTA -------------------------------------------------- */

.bulletin-publish-cta {
    display: inline-block;
    margin: 0 0 2rem;
    padding: 0.6rem 1.5rem;
    border-radius: 999px;
    background: var(--accent);
    color: var(--text-on-accent);
    font-weight: 600;
    text-decoration: none;
}
.bulletin-publish-cta:hover { background: var(--accent-dark); }

/* --- Post list ---------------------------------------------------- */

.bulletin-list { display: flex; flex-direction: column; gap: 1rem; }
.bulletin-post {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 1rem;
    padding: 1.25rem;
    box-shadow: var(--shadow-card);
}
/* Dark-mode cue: thin cyan left edge — same attention pattern as
   the Phase 3 moncash-prompt banner, applied per-post here. */
html[data-theme="dark"] .bulletin-post {
    border-left: 3px solid var(--accent-2);
}
.bulletin-post-head {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 0.6rem;
    flex-wrap: wrap;
}
.bulletin-post-author { font-weight: 700; color: var(--text); font-size: 0.95rem; }
.bulletin-post-time { color: var(--text-muted); font-size: 0.82rem; }
.bulletin-post-body {
    margin: 0;
    color: var(--text);
    line-height: 1.65;
    overflow-wrap: anywhere;
}

/* Photo — capped so portraits don't fill the viewport. */
.bulletin-post-photo {
    margin-top: 0.9rem;
    border-radius: 0.75rem;
    overflow: hidden;
    background: var(--image-placeholder);
}
.bulletin-post-photo img {
    display: block;
    width: 100%;
    max-height: 400px;
    object-fit: contain;
}

/* Author-only delete — small ghost button */
.bulletin-post-actions { margin-top: 0.9rem; }
.bulletin-post-delete {
    padding: 0.35rem 0.85rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    color: var(--danger);
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
}
.bulletin-post-delete:hover { background: var(--danger-bg); border-color: var(--danger-border); }

/* --- Empty state -------------------------------------------------- */

.bulletin-page .empty-state {
    max-width: 30rem;
    margin: 3.5rem auto;
    padding: 2rem;
    text-align: center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 1rem;
}
.bulletin-page .empty-state-icon {
    width: 56px;
    height: 56px;
    margin-bottom: 1rem;
    color: #c7b8e6;
}
.bulletin-page .empty-state-title { margin: 0 0 0.5rem; font-size: 1.25rem; font-weight: 700; color: var(--text); }
.bulletin-page .empty-state-text { margin: 0 0 1.25rem; color: var(--text-muted); line-height: 1.6; }
.bulletin-page .empty-state-cta {
    display: inline-block;
    padding: 0.6rem 1.5rem;
    border-radius: 999px;
    background: var(--accent);
    color: var(--text-on-accent);
    font-weight: 600;
    text-decoration: none;
}
.bulletin-page .empty-state-cta:hover { background: var(--accent-dark); }

/* --- Mobile ------------------------------------------------------- */

@media (max-width: 600px) {
    body.bulletin-page main { padding: 1.5rem 1rem 2.5rem; }
    .bulletin-hero h1 { font-size: 1.75rem; }
    .bulletin-post { padding: 1rem; }
    .bulletin-post-photo img { max-height: 300px; }
    .bulletin-page .empty-state { margin: 2.5rem auto; padding: 1.5rem; }
}
