/* Content Pages + Blog Single */

/* Journal hero (blog list page) */
.journal_hero {
    background: var(--gradient-cta);
    padding: 160px 0 var(--space-16);
    position: relative;
    overflow: hidden;
}

.journal_hero_title {
    font-family: var(--font-headline);
    font-size: 3.5rem;
    font-weight: 800;
    color: var(--on-primary);
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin-bottom: var(--space-4);
}

.journal_hero_subtitle {
    font-size: 1.125rem;
    color: var(--primary-fixed);
    max-width: 540px;
    line-height: 1.6;
}

.overline-label-light {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--primary-fixed-dim);
    margin-bottom: var(--space-4);
}

/* Content pages */
.content_area {
    background: var(--surface);
    padding: var(--space-16) 0;
}

.content_area .container {
    max-width: 780px;
}

.content_single {
    padding: 0;
    overflow: hidden;
}

.content-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.25rem;
    color: var(--outline);
    font-size: 0.875rem;
    margin-bottom: var(--space-8);
    padding: var(--space-4) 0;
}

.content-meta i {
    margin-right: 0.35rem;
    color: var(--primary);
}

.content-meta a {
    color: var(--primary);
    text-decoration: none;
}

.content-meta a:hover {
    color: var(--on-secondary-fixed);
}

/* Content typography (shared by content pages + blog) */
.content-body h1,
.blog_content h1 {
    font-size: 1.75rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--on-secondary-fixed);
    margin-bottom: var(--space-4);
    font-family: var(--font-headline);
}

.content-body h2,
.blog_content h2 {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--on-secondary-fixed);
    margin-top: var(--space-8);
    margin-bottom: var(--space-4);
    font-family: var(--font-headline);
}

.content-body h3,
.blog_content h3 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--on-background);
    margin-top: var(--space-6);
    margin-bottom: var(--space-2);
    font-family: var(--font-headline);
}

.content-body p,
.blog_content p {
    margin-bottom: 1.25rem;
    line-height: 1.7;
    color: var(--on-surface-variant);
}

.content-body ul,
.content-body ol,
.blog_content ul,
.blog_content ol {
    margin-bottom: var(--space-6);
    padding-left: var(--space-6);
}

.content-body ul li,
.blog_content ul li {
    margin-bottom: 0.5rem;
    line-height: 1.7;
    color: var(--on-surface-variant);
}

.content-body hr,
.blog_content hr {
    margin: var(--space-8) 0;
    border: none;
    border-top: 1px solid rgba(189, 201, 202, 0.15);
}

.content-body blockquote,
.blog_content blockquote {
    border-left: 4px solid var(--primary);
    padding: var(--space-6);
    margin: var(--space-8) 0;
    background: var(--surface-container-low);
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    font-style: italic;
    font-size: 1.125rem;
    line-height: 1.6;
    color: var(--on-surface-variant);
}

.content-body strong,
.blog_content strong {
    color: var(--on-background);
}

.content-body img,
.blog_content img {
    display: block;
    max-width: 100%;
    width: auto;
    height: auto;
    border-radius: var(--radius-lg);
    margin: var(--space-4) 0;
    box-shadow: var(--shadow-md);
}

.content-body a,
.blog_content a {
    color: var(--primary);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1.5px;
    text-decoration-color: rgba(0, 102, 110, 0.3);
}

.content-body a:hover,
.blog_content a:hover {
    color: var(--on-secondary-fixed);
    text-decoration-color: var(--on-secondary-fixed);
}

.blog_content h5 {
    color: var(--on-background);
    font-family: var(--font-headline);
}

.blog_content h5:hover {
    color: var(--primary);
}

/* Blog single */
.blog_area_custom {
    overflow: hidden;
    background: var(--surface);
    padding-top: 0;
}

.blog_area_custom .container {
    max-width: 820px;
}

.blog_area_custom .blog_content {
    padding: var(--space-8) var(--space-6);
    line-height: 1.7;
}

.blog_single .blog_content {
    padding: var(--space-8);
    box-shadow: none;
}

.blog-content-image {
    max-width: 100%;
    display: block;
    margin: var(--space-8) 0;
    border-radius: var(--radius-lg);
}

.highlight pre {
    padding: var(--space-8);
    border-radius: var(--radius-lg);
}
