/* ============================================================
   KirinVerse – Layout-Hilfklassen
   ============================================================ */

/* Flex */
.flex         { display: flex; }
.flex-col     { flex-direction: column; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }
.flex-wrap { flex-wrap: wrap; }

/* Grid */
.grid { display: grid; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

/* Spacing */
.mt-4  { margin-top: var(--space-4); }
.mt-8  { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mb-4  { margin-bottom: var(--space-4); }
.mb-8  { margin-bottom: var(--space-8); }
.p-4   { padding: var(--space-4); }
.p-6   { padding: var(--space-6); }
.p-8   { padding: var(--space-8); }

/* Text */
.text-center  { text-align: center; }
.text-left    { text-align: left; }
.text-right   { text-align: right; }
.text-muted   { color: var(--color-text-muted); }
.text-subtle  { color: var(--color-text-subtle); }
.text-primary { color: var(--color-primary-light); }
.text-sm      { font-size: var(--text-sm); }
.text-lg      { font-size: var(--text-lg); }
.font-heading { font-family: var(--font-heading); }
.font-reading { font-family: var(--font-reading); }
.italic       { font-style: italic; }
.uppercase    { text-transform: uppercase; }
.tracking-wide { letter-spacing: 0.08em; }

/* Visibility */
.hidden { display: none !important; }
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* Divider */
.divider {
    height: 1px;
    background: var(--color-border-subtle);
    margin: var(--space-8) 0;
}

/* Card */
.card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
}

/* Prose (Leseansicht) */
.prose {
    font-family: var(--font-reading);
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--color-text);
    max-width: 720px;
}
.prose h1, .prose h2, .prose h3 { margin-top: 2em; margin-bottom: 0.5em; }
.prose p { margin-bottom: 1.2em; }
.prose blockquote {
    border-left: 3px solid var(--color-primary);
    padding-left: var(--space-4);
    color: var(--color-text-muted);
    font-style: italic;
    margin: var(--space-6) 0;
}
.prose hr { border: none; border-top: 1px solid var(--color-border-subtle); margin: var(--space-8) 0; }
.prose a { color: var(--color-primary-light); text-decoration: underline; }
.prose strong { color: var(--color-text-heading); }
.prose em { color: var(--color-text-muted); }
