/* -- FakeCam.net - Articles (listing + single) ---------------- */

/* -- Breadcrumb ----------------------------------------------- */
.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--sp-xs);
    font-size: var(--fs-sm);
    color: var(--color-text-tertiary);
    margin-bottom: var(--sp-lg);
}
.breadcrumb a { color: var(--color-text-secondary); }
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb-sep { color: var(--color-text-tertiary); }
.breadcrumb [aria-current="page"] {
    color: var(--color-text-primary);
    font-weight: var(--fw-medium);
}

/* -- Listing grid + cards ------------------------------------- */
.articles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--sp-xl);
}

.articles-empty {
    text-align: center;
    color: var(--color-text-secondary);
    padding: var(--sp-2xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.article-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.article-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-border);
}
.article-card-link { display: block; color: inherit; }

.article-card-media {
    aspect-ratio: 16 / 9;
    background: var(--color-surface-hover);
    overflow: hidden;
}
.article-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}
.article-card:hover .article-card-media img { transform: scale(1.04); }

.article-card-body { padding: var(--sp-lg); }
.article-card-title {
    font-size: var(--fs-xl);
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: var(--sp-sm);
    color: var(--color-text-primary);
    line-height: 1.3;
}
.article-card-desc {
    font-size: var(--fs-sm);
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin-bottom: var(--sp-md);
}
.article-card-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--sp-xs);
    font-size: var(--fs-xs);
    color: var(--color-text-tertiary);
}
.article-meta-dot { opacity: 0.6; }

/* -- Single article ------------------------------------------- */
.article { padding: var(--sp-3xl) 0; }

.article-container {
    width: 100%;
    max-width: 760px;
    margin: 0 auto;
    padding: 0 var(--sp-lg);
}

.article-header { margin-bottom: var(--sp-xl); }
.article-title {
    font-size: var(--fs-3xl);
    text-transform: none;
    letter-spacing: 0;
    line-height: 1.15;
    margin-bottom: var(--sp-md);
}
.article-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--sp-xs);
    font-size: var(--fs-sm);
    color: var(--color-text-tertiary);
}
.article-author { color: var(--color-text-secondary); font-weight: var(--fw-medium); }
.article-updated { color: var(--color-text-tertiary); }

.article-hero {
    margin: 0 0 var(--sp-xl);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-surface-hover);
}
.article-hero img { width: 100%; height: auto; }

/* -- Table of contents ---------------------------------------- */
.article-toc {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-left: 3px solid var(--color-primary);
    border-radius: var(--radius-md);
    padding: var(--sp-lg) var(--sp-xl);
    margin-bottom: var(--sp-xl);
}
.article-toc-title {
    font-family: var(--font-heading);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-secondary);
    margin-bottom: var(--sp-sm);
}
.article-toc ul { list-style: none; }
.article-toc li { margin: var(--sp-xs) 0; }
.article-toc a { color: var(--color-text-secondary); font-size: var(--fs-sm); }
.article-toc a:hover { color: var(--color-primary); }

/* -- Article body (rendered Markdown) ------------------------- */
.article-body {
    font-size: var(--fs-lg);
    line-height: 1.8;
    color: var(--color-text-primary);
}
.article-body > *:first-child { margin-top: 0; }

.article-body h2 {
    font-size: var(--fs-2xl);
    text-transform: none;
    letter-spacing: 0;
    line-height: 1.25;
    margin: var(--sp-2xl) 0 var(--sp-md);
    scroll-margin-top: calc(var(--header-height) + var(--sp-md));
}
.article-body h3 {
    font-size: var(--fs-xl);
    text-transform: none;
    letter-spacing: 0;
    margin: var(--sp-xl) 0 var(--sp-sm);
    scroll-margin-top: calc(var(--header-height) + var(--sp-md));
}

.article-body p { margin-bottom: var(--sp-lg); }

.article-body a {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.article-body a:hover { color: var(--color-primary-hover); }

.article-body ul,
.article-body ol {
    margin: 0 0 var(--sp-lg) var(--sp-xl);
    line-height: 1.8;
}
.article-body ul { list-style: disc; }
.article-body ol { list-style: decimal; }
.article-body li { margin-bottom: var(--sp-xs); }

.article-body strong { font-weight: var(--fw-semibold); }

.article-body blockquote {
    margin: var(--sp-xl) 0;
    padding: var(--sp-md) var(--sp-lg);
    border-left: 3px solid var(--color-primary);
    background: var(--color-primary-light);
    border-radius: var(--radius-sm);
    color: var(--color-text-secondary);
}
.article-body blockquote p:last-child { margin-bottom: 0; }

.article-body code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.9em;
    background: var(--color-surface-hover);
    padding: 0.15em 0.4em;
    border-radius: var(--radius-sm);
}
.article-body pre {
    background: var(--color-text-primary);
    color: #fff;
    padding: var(--sp-lg);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin: var(--sp-xl) 0;
    line-height: 1.6;
}
.article-body pre code {
    background: none;
    padding: 0;
    font-size: var(--fs-sm);
    color: inherit;
}

/* Figures (images with optional caption) */
.article-figure {
    margin: var(--sp-xl) 0;
    text-align: center;
}
.article-figure img {
    width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-light);
}
.article-figure figcaption {
    margin-top: var(--sp-sm);
    font-size: var(--fs-sm);
    color: var(--color-text-tertiary);
}

/* Tables (comparison tables) */
.article-body table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--sp-xl) 0;
    font-size: var(--fs-base);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.article-body th,
.article-body td {
    padding: var(--sp-sm) var(--sp-md);
    text-align: left;
    border-bottom: 1px solid var(--color-border-light);
}
.article-body thead th {
    background: var(--color-surface-hover);
    font-family: var(--font-heading);
    font-size: var(--fs-sm);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-secondary);
}
.article-body tbody tr:last-child td { border-bottom: none; }

.article-body hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--sp-2xl) 0;
}

/* -- FAQ (reused accordion, self-contained for article pages) - */
.article-faq { margin-top: var(--sp-3xl); }
.article-faq h2 {
    font-size: var(--fs-2xl);
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: var(--sp-lg);
}
.article-faq .faq-item {
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    margin-bottom: var(--sp-sm);
    background: var(--color-surface);
    overflow: hidden;
}
.article-faq .faq-question {
    cursor: pointer;
    padding: var(--sp-md) var(--sp-lg);
    font-weight: var(--fw-semibold);
    list-style: none;
    position: relative;
    padding-right: var(--sp-2xl);
}
.article-faq .faq-question::-webkit-details-marker { display: none; }
.article-faq .faq-question::after {
    content: "+";
    position: absolute;
    right: var(--sp-lg);
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--fs-xl);
    color: var(--color-primary);
    transition: transform var(--transition-fast);
}
.article-faq .faq-item[open] .faq-question::after {
    content: "\2212"; /* minus */
}
.article-faq .faq-answer {
    padding: 0 var(--sp-lg) var(--sp-md);
    color: var(--color-text-secondary);
    line-height: 1.8;
}

/* -- Download CTA --------------------------------------------- */
.article-cta {
    margin-top: var(--sp-3xl);
    padding: var(--sp-2xl);
    text-align: center;
    background: var(--color-primary-light);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}
.article-cta h2 {
    font-size: var(--fs-2xl);
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: var(--sp-sm);
}
.article-cta p {
    color: var(--color-text-secondary);
    max-width: 460px;
    margin: 0 auto var(--sp-lg);
}

/* -- Related -------------------------------------------------- */
.article-related { margin-top: var(--sp-3xl); }
.article-related-title {
    font-size: var(--fs-2xl);
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: var(--sp-lg);
}

@media (max-width: 600px) {
    .article-title { font-size: var(--fs-2xl); }
    .article-body { font-size: var(--fs-base); }
    .articles-grid { grid-template-columns: 1fr; }
}
