/* Typography System for Blog and Content Areas */

/* Import configuration variables */
@import url('./typography-config.css');

/* Article Frame */
.article-frame {
    background: var(--article-frame-bg);
    border-radius: 24px;
    padding: 3rem 2.5rem;
    margin: 2rem 0;
    box-shadow: var(--article-frame-shadow);
    backdrop-filter: blur(10px);
    border: var(--article-frame-border);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.article-frame:hover {
    transform: translateY(-2px);
    box-shadow: var(--article-frame-shadow-hover);
}

.article-frame::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--article-frame-accent-top);
    border-radius: 24px 24px 0 0;
}

.article-frame::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--article-frame-accent-left);
    border-radius: 24px 0 0 24px;
}

/* Blog Typography Classes */

/* Blog Title Font Weight Variables - Easy to change */
:root {
    --blog-featured-title-weight: 300;
    /* Featured article title weight (300 = light) */
    --blog-card-title-weight: 300;
    /* Blog card title weight (300 = light) */
    --blog-section-title-weight: 300;
    /* Section title weight (300 = light) */
}

/* Blog Title Font Weight Classes */
.blog-featured-title {
    font-weight: var(--blog-featured-title-weight) !important;
}

.blog-card-title {
    font-weight: var(--blog-card-title-weight) !important;
}

.blog-section-title {
    font-weight: var(--blog-section-title-weight) !important;
}

.blog-typography {
    font-family: var(--font-secondary);
    color: var(--blog-content-color);
    background-color: transparent;
    position: relative;
    z-index: 1;
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1, "pnum" 1, "tnum" 0, "onum" 1, "lnum" 0, "dlig" 0;
    font-variant-ligatures: common-ligatures;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.blog-title {
    font-family: var(--blog-title-font);
    font-size: var(--blog-title-size);
    font-weight: var(--blog-title-weight);
    line-height: var(--blog-title-line-height);
    letter-spacing: var(--blog-title-spacing);
    color: var(--blog-title-color);
    margin-bottom: 1.5rem;
    text-shadow: 0 0 20px rgba(16, 185, 129, 0.1);
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.blog-meta {
    font-family: var(--blog-meta-font);
    font-size: var(--blog-meta-size);
    font-weight: var(--blog-meta-weight);
    color: var(--blog-meta-color);
    letter-spacing: var(--blog-meta-spacing);
    margin-bottom: 2rem;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    opacity: 0.9;
}

.blog-meta-text {
    font-family: var(--blog-meta-font);
    font-size: var(--blog-meta-size);
    font-weight: var(--blog-meta-weight);
    color: var(--blog-meta-color);
    letter-spacing: var(--blog-meta-spacing);
    margin: 0;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    opacity: 0.9;
}

/* Author and Date Above Image */
.author-date-above-image {
    margin: 2rem 0 1rem 0;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.blog-post-meta-above-image {
    margin: 0;
}

.post-meta-list-above-image {
    justify-content: flex-start;
    margin: 0;
    padding: 0;
}

.blog-meta-text-above-image {
    font-family: var(--blog-meta-font);
    font-size: 1.125rem;
    font-weight: var(--font-normal);
    color: var(--blog-meta-color);
    letter-spacing: var(--blog-meta-spacing);
    margin: 0;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    opacity: 0.9;
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Post Meta List Spacing */
.post-meta-list-above-image {
    gap: 0.25rem;
    /* 4px spacing between elements */
}

.post-meta-list-above-image .meta-list-divider {
    margin: 0 0.5rem;
    /* Additional spacing around divider */
}

/* Light mode text shadow adjustments */
@media (prefers-color-scheme: light) {
    .blog-meta-text-above-image {
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
    }

    .blog-title {
        text-shadow: 0 0 20px rgba(16, 185, 129, 0.05);
    }

    .post-tag {
        background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, rgba(5, 150, 105, 0.1) 100%);
        border: 1px solid rgba(16, 185, 129, 0.5);
        color: #059669;
        text-shadow: none;
    }

    .post-tag:hover {
        background: linear-gradient(135deg, rgba(16, 185, 129, 0.2) 0%, rgba(5, 150, 105, 0.15) 100%);
        border-color: rgba(16, 185, 129, 0.7);
        color: #047857;
        box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2);
    }
}

/* Force light mode styles with higher specificity */
body:not(.theme--dark) .blog-title,
body:not(.theme--dark) .blog-content,
body:not(.theme--dark) .blog-meta,
body:not(.theme--dark) .blog-meta-text-above-image,
body:not(.theme--dark) .blog-heading,
body:not(.theme--dark) .blog-blockquote {
    color: #1f2937 !important;
}

body:not(.theme--dark) .article-frame {
    background: linear-gradient(135deg, rgba(243, 244, 246, 0.95) 0%, rgba(229, 231, 235, 0.98) 100%) !important;
    border: 1px solid rgba(136, 110, 241, 0.3) !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1), 0 0 0 1px rgba(16, 185, 129, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.8) !important;
}

body:not(.theme--dark) .article-frame:hover {
    box-shadow: 0 32px 64px -12px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(16, 185, 129, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
}

body:not(.theme--dark) .post-tag {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, rgba(5, 150, 105, 0.1) 100%) !important;
    border: 1px solid rgba(16, 185, 129, 0.5) !important;
    color: #059669 !important;
    text-shadow: none !important;
}

body:not(.theme--dark) .post-tag:hover {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.2) 0%, rgba(5, 150, 105, 0.15) 100%) !important;
    border-color: rgba(16, 185, 129, 0.7) !important;
    color: #047857 !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2) !important;
}

/* Text Highlighting Styles */
mark {
    background-color: rgba(16, 185, 129, 0.3);
    color: inherit;
    padding: 0.125rem 0.25rem;
    border-radius: 0.25rem;
}

/* Light mode highlighting */
body:not(.theme--dark) mark {
    background-color: rgba(16, 185, 129, 0.4) !important;
    color: #1f2937 !important;
}

/* Text selection styles */
::selection {
    background-color: rgba(16, 185, 129, 0.3);
    color: inherit;
}

body:not(.theme--dark) ::selection {
    background-color: rgba(16, 185, 129, 0.4) !important;
    color: #1f2937 !important;
}

/* Webkit selection styles */
::-moz-selection {
    background-color: rgba(16, 185, 129, 0.3);
    color: inherit;
}

body:not(.theme--dark) ::-moz-selection {
    background-color: rgba(16, 185, 129, 0.4) !important;
    color: #1f2937 !important;
}

/* Post Tags Styles */
.post-tags-container {
    margin: 1.5rem 0 2rem 0;
    padding: 0 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Featured and List Post Tags - Left Aligned */
.featured-post-tags-container,
.list-post-tags-container,
.single-post-tags-container {
    margin: 1.5rem 0 2rem 0;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    align-items: center;
}

.post-tag {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, rgba(5, 150, 105, 0.1) 100%);
    color: var(--blog-link-color);
    text-decoration: none;
    border-radius: 0.75rem;
    font-size: 0.75rem;
    font-weight: var(--font-medium);
    border: 1px solid rgba(16, 185, 129, 0.2);
    transition: all 0.3s ease;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(5px);
    font-family: var(--blog-content-font);
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.post-tag:hover {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.25) 0%, rgba(5, 150, 105, 0.2) 100%);
    color: var(--blog-link-hover-color);
    border-color: rgba(16, 185, 129, 0.4);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2);
    text-decoration: none;
}

.post-tag:focus {
    outline: 2px solid rgba(16, 185, 129, 0.5);
    outline-offset: 2px;
}

/* Featured and List Post Tags - Smaller Font Size */
.featured-post-tag,
.list-post-tag {
    display: inline-block;
    padding: 0.2rem 0.45rem;
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, rgba(5, 150, 105, 0.1) 100%);
    color: var(--blog-link-color);
    text-decoration: none;
    border-radius: 0.7rem;
    font-size: 0.65rem;
    font-weight: var(--font-medium);
    border: 1px solid rgba(16, 185, 129, 0.2);
    transition: all 0.3s ease;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(5px);
    font-family: var(--blog-content-font);
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.featured-post-tag:hover,
.list-post-tag:hover {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.25) 0%, rgba(5, 150, 105, 0.2) 100%);
    color: var(--blog-link-hover-color);
    border-color: rgba(16, 185, 129, 0.4);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2);
    text-decoration: none;
}

.featured-post-tag:focus,
.list-post-tag:focus {
    outline: 2px solid rgba(16, 185, 129, 0.5);
    outline-offset: 2px;
}

/* Social Sharing Icons Fix */
.share-social-icons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.share-social-icons li {
    display: flex;
    align-items: center;
    justify-content: center;
}

.share-social-icons .share-ico {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    transition: all 0.3s ease;
}

.share-social-icons .share-ico:hover {
    background: rgba(16, 185, 129, 0.1);
    transform: translateY(-2px);
}

.share-social-icons [class*="flaticon-"] {
    font-size: 1.25rem !important;
    line-height: 1 !important;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.share-social-icons [class*="flaticon-"]:before {
    font-size: 1.25rem !important;
    line-height: 1 !important;
    vertical-align: middle;
    display: inline-block;
}


.blog-content {
    font-family: var(--blog-content-font);
    font-size: var(--blog-content-size);
    font-weight: var(--font-normal);
    line-height: var(--blog-content-line-height);
    letter-spacing: var(--blog-content-spacing);
    color: var(--blog-content-color);
    max-width: none;
    margin: 0 auto;
    padding: 0;
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1, "pnum" 1, "tnum" 0, "onum" 1, "lnum" 0;
    font-variant-ligatures: common-ligatures;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.blog-content h1 {
    font-family: var(--blog-heading-font);
    font-size: var(--blog-heading-1-size);
    font-weight: var(--blog-heading-1-weight);
    line-height: var(--blog-heading-1-line-height);
    letter-spacing: var(--blog-heading-1-spacing);
    color: var(--blog-heading-color);
    margin-top: var(--blog-heading-1-margin-top);
    margin-bottom: var(--blog-heading-1-margin-bottom);
}

.blog-content h2 {
    font-family: var(--blog-heading-font);
    font-size: var(--blog-heading-2-size);
    font-weight: var(--blog-heading-2-weight);
    line-height: var(--blog-heading-2-line-height);
    letter-spacing: var(--blog-heading-2-spacing);
    color: var(--blog-heading-color);
    margin-top: var(--blog-heading-margin-top);
    margin-bottom: var(--blog-heading-margin-bottom);
}

.blog-content h3 {
    font-family: var(--blog-heading-font);
    font-size: var(--blog-heading-3-size);
    font-weight: var(--blog-heading-3-weight);
    line-height: var(--blog-heading-3-line-height);
    letter-spacing: var(--blog-heading-3-spacing);
    color: var(--blog-heading-color);
    margin-top: var(--blog-heading-3-margin-top);
    margin-bottom: var(--blog-heading-3-margin-bottom);
}

.blog-content h4,
.blog-content h5,
.blog-content h6 {
    font-family: var(--blog-heading-font);
    font-size: var(--blog-heading-4-6-size);
    font-weight: var(--blog-heading-4-6-weight);
    line-height: var(--blog-heading-4-6-line-height);
    color: var(--blog-heading-color);
    margin-top: var(--blog-heading-4-6-margin-top);
    margin-bottom: var(--blog-heading-4-6-margin-bottom);
}

.blog-content p {
    margin-bottom: var(--blog-paragraph-margin-bottom);
}

.blog-content ul,
.blog-content ol {
    margin-bottom: var(--blog-list-margin-bottom);
    padding-left: var(--blog-list-padding-left);
}

.blog-content li {
    margin-bottom: var(--blog-list-item-margin-bottom);
}

.blog-content blockquote {
    border-left: var(--blog-blockquote-border-width) solid var(--blog-blockquote-border-color);
    padding-left: var(--blog-blockquote-padding);
    margin: 2rem 0;
    font-style: normal;
    color: var(--blog-blockquote-color);
    background-color: var(--blog-blockquote-bg);
    padding: var(--blog-blockquote-padding);
    border-radius: var(--blog-blockquote-radius);
}

.blog-content a {
    color: var(--blog-link-color);
    text-decoration: var(--blog-link-decoration);
    text-decoration-thickness: var(--blog-link-decoration-thickness);
    text-underline-offset: var(--blog-link-underline-offset);
    transition: color 0.2s ease;
}

.blog-content a:hover {
    color: var(--blog-link-hover-color);
    text-decoration: none;
}

.blog-content strong {
    font-weight: var(--font-medium);
    color: var(--blog-heading-color);
}

.blog-content em {
    font-style: normal;
}

.blog-content code {
    background-color: var(--blog-code-bg);
    padding: var(--blog-code-padding);
    border-radius: var(--blog-code-radius);
    font-size: var(--blog-code-size);
    font-family: var(--blog-code-font);
    color: var(--blog-code-color);
}

.blog-content pre {
    background-color: #1f2937;
    color: #f9fafb;
    padding: 1.5rem;
    border-radius: 0.5rem;
    overflow-x: auto;
    margin: 1.5rem 0;
}

.blog-content pre code {
    background-color: transparent;
    color: inherit;
    padding: 0;
}

.blog-content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--blog-image-radius);
    margin: var(--blog-image-margin);
    box-shadow: var(--blog-image-shadow);
}

.blog-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.5rem 0;
}

.blog-content th,
.blog-content td {
    padding: 0.75rem;
    text-align: left;
    border-bottom: 1px solid #e5e7eb;
}

.blog-content th {
    font-weight: var(--font-semibold);
    background-color: #f9fafb;
}

/* Responsive Typography */
@media (max-width: var(--mobile-breakpoint)) {
    .article-frame {
        padding: 2rem 1.5rem;
        margin: 1rem 0;
        border-radius: 20px;
    }

    .author-date-above-image {
        margin: 1.5rem 0 0.75rem 0;
        padding: 0;
    }

    .blog-meta-text-above-image {
        font-size: 1rem;
    }

    .blog-title {
        font-size: var(--blog-title-size-mobile);
    }

    .blog-content {
        font-size: var(--blog-content-size-mobile);
    }

    .blog-content h1 {
        font-size: var(--blog-heading-1-size-mobile);
    }

    .blog-content h2 {
        font-size: var(--blog-heading-2-size-mobile);
    }

    .blog-content h3 {
        font-size: var(--blog-heading-3-size-mobile);
    }
}

/* Blog Card Image Sizing */
.blog-card-img {
    width: 100%;
    height: 240px;
    object-fit: cover;
    border-radius: 16px !important;
}

/* Featured blog post image container */
.wide-post .blog-post-img {
    border-radius: 16px !important;
    overflow: hidden !important;
    position: relative !important;
    height: 100% !important;
    display: flex !important;
    align-items: stretch !important;
}

/* Featured card image with maximum specificity */
.wide-post .blog-post-img .featured-card-img,
.wide-post .blog-post-img img.featured-card-img,
img.featured-card-img.rounded-\[16px\] {
    width: 100% !important;
    height: 100% !important;
    min-height: 400px !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 16px !important;
    overflow: hidden !important;
}


/* Typography Utilities for Easy Customization */
.text-balance {
    text-wrap: balance;
}

.text-pretty {
    text-wrap: pretty;
}

/* Focus styles for accessibility */
.blog-content a:focus {
    outline: 2px solid #059669;
    outline-offset: 2px;
    border-radius: 0.25rem;
}

/* Print styles */
@media print {
    .blog-content {
        font-size: 12pt;
        line-height: 1.4;
        color: #000;
    }

    .blog-content a {
        color: #000;
        text-decoration: none;
    }

    .blog-content a:after {
        content: " (" attr(href) ")";
        font-size: 10pt;
        color: #666;
    }
}