/*
Public-facing rendering helpers for CMS rich text.

We intentionally keep this file minimal and *scoped* so it doesn't affect
non-CMS pages.

Quill stores formatting via CSS classes (e.g. ql-align-center, ql-size-large).
Our sanitizer allowlist keeps `class` attributes, so we only need these class
rules on the frontend.
*/

.post-content,
.announcement-content,
.cms-richtext {
  line-height: 1.55;
}

/* Reader page header helpers (Phase 11)
   Keep styling minimal and scoped.
*/
.post-detail .cms-article-title,
.announcement-detail .cms-article-title {
  font-weight: 700;
  line-height: 1.2;
}

.post-detail .cms-article-time,
.announcement-detail .cms-article-time {
  white-space: nowrap;
}

/*
Reader-page paddings (Phase 13)

Paddings are stored in DB as cm (Word-like) and are applied per-article via a
<style nonce> block in the reader templates.

Why:
- Avoid surprises from CSS var() resolution / inline-style policies.
- Keep behavior deterministic even if global theme CSS resets paddings.

See:
- templates/cms/post_detail.html
- templates/cms/announcement_detail.html
*/

/* Alignment (Quill) */
.post-content .ql-align-center,
.announcement-content .ql-align-center,
.cms-richtext .ql-align-center {
  text-align: center;
}

.post-content .ql-align-right,
.announcement-content .ql-align-right,
.cms-richtext .ql-align-right {
  text-align: right;
}

.post-content .ql-align-justify,
.announcement-content .ql-align-justify,
.cms-richtext .ql-align-justify {
  text-align: justify;
}

/* Font size (Quill) */
.post-content .ql-size-small,
.announcement-content .ql-size-small,
.cms-richtext .ql-size-small {
  font-size: 0.875em;
}

.post-content .ql-size-large,
.announcement-content .ql-size-large,
.cms-richtext .ql-size-large {
  font-size: 1.25em;
}

.post-content .ql-size-huge,
.announcement-content .ql-size-huge,
.cms-richtext .ql-size-huge {
  font-size: 1.75em;
}

/* Images inside content */
.post-content img,
.announcement-content img,
.cms-richtext img {
  max-width: 100%;
  display: inline-block;
  height: auto;
}



/* Image size presets (Phase 6)
   We keep this class-based (no inline styles) to stay compatible with our sanitizer.
*/
.post-content img.cms-img-sm,
.announcement-content img.cms-img-sm,
.cms-richtext img.cms-img-sm {
  width: 25%;
  max-width: 25%;
  height: auto;
}

.post-content img.cms-img-md,
.announcement-content img.cms-img-md,
.cms-richtext img.cms-img-md {
  width: 50%;
  max-width: 50%;
  height: auto;
}

.post-content img.cms-img-lg,
.announcement-content img.cms-img-lg,
.cms-richtext img.cms-img-lg {
  width: 75%;
  max-width: 75%;
  height: auto;
}

.post-content img.cms-img-full,
.announcement-content img.cms-img-full,
.cms-richtext img.cms-img-full {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
}


/* YouTube embeds from Quill use iframe. Make them responsive. */
.post-content iframe,
.announcement-content iframe,
.cms-richtext iframe,
.post-content .ql-video,
.announcement-content .ql-video,
.cms-richtext .ql-video {
  width: 100%;
  max-width: 100%;
  border: 0;
  aspect-ratio: 16 / 9;
  height: auto;
}

/* Better spacing for lists and paragraphs */
.post-content ul,
.post-content ol,
.announcement-content ul,
.announcement-content ol,
.cms-richtext ul,
.cms-richtext ol {
  padding-left: 1.25rem;
}

.post-content p,
.announcement-content p,
.cms-richtext p {
  margin-bottom: 0.75rem;
}

/* Tables from Quill/HTML sections */
.post-content table,
.announcement-content table,
.cms-richtext table {
  width: 100%;
  border-collapse: collapse;
}

.post-content table th,
.post-content table td,
.announcement-content table th,
.announcement-content table td,
.cms-richtext table th,
.cms-richtext table td {
  border: 1px solid rgba(0, 0, 0, 0.15);
  padding: 0.4rem 0.5rem;
}
