/* ============================================================
   BackBox Labs — Blog & article styles
   Layered on top of tokens.css + components.css + layout.css.
   ============================================================ */


/* ------------------------------------------------------------
   Blog hero (index)
   ------------------------------------------------------------ */
.blog-hero {
    padding-block: clamp(3rem, 6vw, 5rem) clamp(2.25rem, 4vw, 3.5rem);
    border-bottom: var(--hairline);
    background:
        radial-gradient(80% 100% at 100% 0%, var(--accent-trace), transparent 60%);
}
.blog-hero .eyebrow { margin-bottom: var(--sp-md); }
.blog-hero h1 {
    font: 800 var(--fs-4xl)/var(--lh-tight) var(--font-display);
    letter-spacing: var(--tracking-display);
    color: var(--text);
    margin-bottom: var(--sp-md);
    max-width: 22ch;
}
.blog-hero-subtitle {
    font: 400 clamp(1.05rem, 1.4vw, 1.25rem)/1.55 var(--font-display);
    color: var(--text-dim);
    max-width: 48rem;
}


/* ------------------------------------------------------------
   Blog grid
   ------------------------------------------------------------ */
.blog-section { padding-block: var(--section-y); }

.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
    gap: var(--sp-md);
}

.blog-card {
    display: block;
    padding: var(--sp-lg);
    background: var(--surface);
    border: var(--hairline);
    border-radius: var(--radius-sm);
    transition: border-color var(--t-fast), transform var(--t-fast),
                background var(--t-fast);
    position: relative;
    overflow: hidden;
}
.blog-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--accent);
    transition: width var(--t-base);
}
.blog-card:hover {
    border-color: var(--accent);
    transform: translateY(-3px);
    background: var(--surface-2);
}
.blog-card:hover::before { width: 100%; }

.blog-card-content { display: flex; flex-direction: column; gap: var(--sp-sm); }

.blog-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-md);
    font: 500 var(--fs-xs)/1 var(--font-mono);
    color: var(--text-mute);
    letter-spacing: var(--tracking-mono);
    text-transform: uppercase;
}
.blog-card-meta i { color: var(--accent); margin-right: 0.4rem; }
.blog-card-category { color: var(--accent); }

.blog-card-title {
    font: 700 var(--fs-xl)/1.25 var(--font-display);
    letter-spacing: var(--tracking-tight);
}
.blog-card-title a { color: var(--text); transition: color var(--t-fast); }
.blog-card:hover .blog-card-title a { color: var(--accent); }

.blog-card-excerpt {
    font-size: var(--fs-sm);
    color: var(--text-dim);
    line-height: 1.55;
}

.blog-card-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: var(--sp-xs);
    font: 600 var(--fs-sm)/1 var(--font-mono);
    color: var(--accent);
    letter-spacing: var(--tracking-mono);
    text-transform: uppercase;
    transition: gap var(--t-fast);
}
.blog-card-link:hover { gap: 0.75rem; color: var(--accent-hi); }


/* ------------------------------------------------------------
   Article page
   ------------------------------------------------------------ */
.article-page {
    padding-block: clamp(2.25rem, 5vw, 4rem) clamp(2.5rem, 5vw, 5rem);
}
.article-page .container { max-width: 920px; }

.back-to-blog {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: var(--sp-lg);
    padding: 0.45rem 0.75rem;
    border: var(--hairline);
    border-radius: var(--radius-sm);
    color: var(--text-dim);
    font: 500 var(--fs-xs)/1 var(--font-mono);
    letter-spacing: var(--tracking-mono);
    text-transform: uppercase;
    transition: border-color var(--t-fast), color var(--t-fast);
}
.back-to-blog:hover { border-color: var(--accent); color: var(--accent); }

.article-header {
    padding-bottom: var(--sp-xl);
    border-bottom: var(--hairline);
    margin-bottom: var(--sp-xl);
}
.article-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-md);
    margin-bottom: var(--sp-md);
    font: 500 var(--fs-xs)/1 var(--font-mono);
    color: var(--text-mute);
    letter-spacing: var(--tracking-mono);
    text-transform: uppercase;
}
.article-meta i { color: var(--accent); margin-right: 0.4rem; }
.article-category { color: var(--accent); }

.article-title {
    font: 800 clamp(2rem, 4.4vw, 3.4rem)/var(--lh-tight) var(--font-display);
    letter-spacing: var(--tracking-display);
    color: var(--text);
    margin-bottom: var(--sp-md);
}
.article-excerpt {
    font: 400 clamp(1.05rem, 1.4vw, 1.25rem)/1.55 var(--font-display);
    color: var(--text-dim);
    max-width: 56rem;
}

.article-content {
    font-size: var(--fs-md);
    color: var(--text);
    line-height: 1.75;
}
.article-content > * + * { margin-top: var(--sp-md); }
.article-content > h2 { margin-top: var(--sp-xl); }
.article-content > h3 { margin-top: var(--sp-lg); }

.article-content h2 {
    font: 700 var(--fs-2xl)/1.2 var(--font-display);
    letter-spacing: var(--tracking-tight);
    color: var(--text);
    padding-bottom: var(--sp-xs);
    border-bottom: var(--hairline);
}
.article-content h3 {
    font: 600 var(--fs-xl)/1.25 var(--font-display);
    color: var(--text);
}
.article-content h4 {
    font: 600 var(--fs-lg)/1.3 var(--font-display);
    color: var(--text-dim);
}

.article-content p { color: var(--text); line-height: 1.75; }

.article-content ul,
.article-content ol { padding-left: 1.5rem; }
.article-content ul { list-style: none; }
.article-content ul li {
    position: relative;
    padding-left: 1.25rem;
    margin-bottom: 0.5rem;
}
.article-content ul li::before {
    content: '+';
    position: absolute;
    left: 0;
    top: 0;
    color: var(--accent);
    font-family: var(--font-mono);
}
.article-content ol { list-style: decimal; }
.article-content ol li { margin-bottom: 0.5rem; padding-left: 0.25rem; }
.article-content ol li::marker { color: var(--accent); font-family: var(--font-mono); font-weight: 600; }

.article-content blockquote {
    padding: var(--sp-md) var(--sp-lg);
    border-left: 2px solid var(--accent);
    background: var(--surface);
    color: var(--text-dim);
    font-style: italic;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.article-content blockquote p { color: var(--text-dim); }

.article-content a {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    text-decoration-color: rgba(61, 139, 255, 0.4);
    transition: text-decoration-color var(--t-fast), color var(--t-fast);
}
.article-content a:hover {
    color: var(--accent-hi);
    text-decoration-color: var(--accent-hi);
}

.article-content code {
    padding: 0.15em 0.4em;
    background: var(--surface);
    border: var(--hairline-sm);
    border-radius: var(--radius-xs);
    font: 500 0.875em/1.4 var(--font-mono);
    color: var(--accent-cyan);
}
.article-content pre {
    padding: var(--sp-md);
    background: var(--bg-elev);
    border: var(--hairline);
    border-radius: var(--radius-sm);
    overflow-x: auto;
    font: 400 var(--fs-sm)/1.6 var(--font-mono);
}
.article-content pre code {
    padding: 0;
    background: transparent;
    border: 0;
    color: inherit;
    font-size: inherit;
}

.article-content img {
    margin-block: var(--sp-md);
    border: var(--hairline);
    border-radius: var(--radius-sm);
    cursor: zoom-in;
}

/* Tables: wrap them in a horizontal-scroll container on overflow, so
   wide tables stay readable on mobile without forcing the page to scroll. */
.article-content table {
    display: block;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-collapse: collapse;
    border: var(--hairline);
    border-radius: var(--radius-sm);
    font-size: var(--fs-sm);
}
.article-content table tbody,
.article-content table thead { display: table; width: 100%; }
.article-content th,
.article-content td {
    padding: 0.6rem 0.75rem;
    text-align: left;
    border-bottom: var(--hairline-sm);
}
.article-content th {
    background: var(--surface);
    color: var(--text);
    font: 600 var(--fs-xs)/1 var(--font-mono);
    text-transform: uppercase;
    letter-spacing: var(--tracking-mono);
}
.article-content td { color: var(--text-dim); }
.article-content tr:hover td { background: var(--surface); }

.article-content hr {
    margin-block: var(--sp-xl);
    border: 0;
    border-top: var(--hairline);
}

.article-content strong { color: var(--text); font-weight: 600; }
.article-content em { color: var(--text); font-style: italic; }

.article-footer {
    margin-top: var(--sp-xl);
    padding-top: var(--sp-xl);
    border-top: var(--hairline);
    display: flex;
    justify-content: center;
}


/* ------------------------------------------------------------
   Responsive
   ------------------------------------------------------------ */
@media (max-width: 768px) {
    .blog-grid { grid-template-columns: 1fr; }
    .article-content pre { font-size: 0.8rem; }
}
