/* ═══════════════════════════════════════════════════════════════════
   Flavor Theme — CSS
   A clean, writer-focused theme inspired by modern publishing platforms.
   Uses fl- prefix for all custom classes to avoid conflicts.
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Base Typography ──────────────────────────────────────────── */

.fl-prose {
    color: var(--fl-text);
}

.dark .fl-prose {
    color: #e0e0e0;
}

.fl-prose h1,
.fl-prose h2,
.fl-prose h3,
.fl-prose h4,
.fl-prose h5,
.fl-prose h6 {
    font-family: var(--fl-heading-font);
    color: var(--fl-text);
    letter-spacing: -0.01em;
}

.dark .fl-prose h1,
.dark .fl-prose h2,
.dark .fl-prose h3,
.dark .fl-prose h4,
.dark .fl-prose h5,
.dark .fl-prose h6 {
    color: #f3f4f6;
}

.fl-prose a {
    color: var(--fl-link);
    text-decoration: none;
}

.fl-prose a:hover {
    text-decoration: underline;
}

.fl-prose blockquote {
    border-left-color: var(--fl-primary);
    font-style: normal;
    padding-left: 1.25em;
}

.fl-prose figcaption {
    text-align: center;
    font-size: 0.875rem;
    color: #6b7280;
    margin-top: 0.75rem;
}

.dark .fl-prose figcaption {
    color: #9ca3af;
}

.fl-prose pre {
    border-radius: 0.5rem;
}

.fl-prose img {
    border-radius: 0.5rem;
}

/* ─── Hero Section ─────────────────────────────────────────────── */

.fl-hero {
    background-color: var(--fl-bg);
}

.dark .fl-hero {
    background-color: transparent;
}

/* ─── Tab Navigation ───────────────────────────────────────────── */

.fl-tab {
    position: relative;
    cursor: pointer;
    border: none;
    background: none;
}

.fl-tab-active {
    color: var(--fl-text);
    border-bottom: 1px solid var(--fl-text);
}

.dark .fl-tab-active {
    color: #f9fafb;
    border-bottom-color: #f9fafb;
}

.fl-tab-inactive {
    color: #9ca3af;
}

.fl-tab-inactive:hover {
    color: #6b7280;
}

.dark .fl-tab-inactive {
    color: #6b7280;
}

.dark .fl-tab-inactive:hover {
    color: #9ca3af;
}

/* ─── Post Cards ───────────────────────────────────────────────── */

.fl-card {
    transition: background-color 0.15s ease;
}

.fl-card:hover {
    background-color: rgba(0, 0, 0, 0.01);
}

.dark .fl-card:hover {
    background-color: rgba(255, 255, 255, 0.02);
}

/* ─── Category Pills / Tag Badges ──────────────────────────────── */

.fl-pill {
    transition: all 0.15s ease;
    white-space: nowrap;
}

.fl-pill:hover {
    transform: translateY(-1px);
}

.fl-tag {
    transition: all 0.15s ease;
}

.fl-tag:hover {
    transform: translateY(-1px);
}

/* ─── Sidebar ──────────────────────────────────────────────────── */

.fl-sidebar-section + .fl-sidebar-section {
    padding-top: 0;
}

.fl-sidebar-heading {
    letter-spacing: 0.08em;
}

/* ─── Author Bio Card ──────────────────────────────────────────── */

.fl-author-bio {
    transition: box-shadow 0.2s ease;
}

.fl-author-bio:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.dark .fl-author-bio:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* ─── Comments ─────────────────────────────────────────────────── */

.fl-comment + .fl-comment {
    padding-top: 1.5rem;
    border-top: 1px solid #e5e7eb;
}

.dark .fl-comment + .fl-comment {
    border-top-color: #1f2937;
}

/* ─── Article Page ─────────────────────────────────────────────── */

.fl-post-page {
    --fl-content-width: 720px;
}

.fl-post-header__title,
.fl-post-header__excerpt,
.fl-post-header__meta {
    width: 100%;
}

.fl-post-layout {
    align-items: flex-start;
}

.fl-article .fl-prose {
    line-height: 1.8;
    letter-spacing: -0.003em;
    word-break: break-word;
}

.fl-article .fl-prose p {
    margin-top: 1.5em;
    margin-bottom: 0;
}

.fl-article .fl-prose h2 {
    margin-top: 2em;
    margin-bottom: 0.5em;
    font-size: 1.5em;
    line-height: 1.3;
}

.fl-article .fl-prose h3 {
    margin-top: 1.75em;
    margin-bottom: 0.4em;
    font-size: 1.25em;
    line-height: 1.35;
}

.fl-article .fl-prose ul,
.fl-article .fl-prose ol {
    margin-top: 1em;
    margin-bottom: 1em;
}

.fl-article .fl-prose li {
    margin-top: 0.35em;
    margin-bottom: 0.35em;
}

/* ─── Newsletter Form ──────────────────────────────────────────── */

.fl-sidebar-section form input[type="email"]:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(26, 137, 23, 0.1);
    border-color: var(--fl-primary);
}

.fl-sidebar-section form button[type="submit"]:hover {
    opacity: 0.9;
    transform: translateY(-1px);
    transition: all 0.15s ease;
}

/* ─── Smooth Transitions ───────────────────────────────────────── */

a,
button {
    transition-property: color, background-color, border-color, opacity, box-shadow, transform;
    transition-duration: 0.15s;
    transition-timing-function: ease;
}

img {
    transition: transform 0.3s ease;
}

/* ─── Responsive ───────────────────────────────────────────────── */

@media (max-width: 639px) {
    .fl-hero h1 {
        font-size: 1.75rem;
    }

    .fl-hero p {
        font-size: 1rem;
    }

    .fl-article .fl-prose {
        font-size: 1rem;
        line-height: 1.75;
    }
}

@media (min-width: 640px) and (max-width: 1023px) {
    .fl-article .fl-prose {
        line-height: 1.8;
    }
}

@media (max-width: 1023px) {
    /* Sidebar stacks below on mobile/tablet */
    aside {
        border-top: 1px solid #e5e7eb;
        padding-top: 2rem;
    }

    .dark aside {
        border-top-color: #1f2937;
    }

    .fl-post-header__excerpt {
        max-width: 100%;
    }
}

/* ─── Selection Color ──────────────────────────────────────────── */

::selection {
    background-color: var(--fl-primary);
    color: #ffffff;
}

::-moz-selection {
    background-color: var(--fl-primary);
    color: #ffffff;
}

/* ─── Scrollbar (subtle) ───────────────────────────────────────── */

::-webkit-scrollbar {
    width: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background-color: #d1d5db;
    border-radius: 3px;
}

.dark ::-webkit-scrollbar-thumb {
    background-color: #374151;
}

/* ─── Line Clamp Utilities ─────────────────────────────────────── */

.line-clamp-2 {
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.line-clamp-3 {
    display: -webkit-box;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ─── Print Styles ─────────────────────────────────────────────── */

@media print {
    header,
    footer,
    aside,
    .fl-tabs,
    .fl-comment form,
    nav,
    button {
        display: none !important;
    }

    body {
        background: white !important;
        color: black !important;
        font-size: 12pt;
    }

    .fl-article {
        max-width: 100%;
    }

    .fl-prose {
        font-size: 12pt;
        line-height: 1.6;
        color: black !important;
    }

    .fl-prose a {
        color: black !important;
        text-decoration: underline;
    }

    .fl-prose a::after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
        color: #555;
    }

    img {
        max-width: 100% !important;
        page-break-inside: avoid;
    }

    h1, h2, h3, h4 {
        page-break-after: avoid;
    }

    .fl-author-bio {
        border: 1px solid #ccc;
    }
}

/* ─── Focus Styles (accessibility) ─────────────────────────────── */

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
    outline: 2px solid var(--fl-primary);
    outline-offset: 2px;
}

/* ─── Alpine.js cloak ──────────────────────────────────────────── */

[x-cloak] {
    display: none !important;
}
