:root {
    --bg-color: #f8fafc;
    --text-main: #0f172a;
    --text-muted: #475569;
    --grid-line-p: rgba(168, 85, 247, 0.1);
    --grid-line-o: rgba(249, 115, 22, 0.1);
    --glass-bg: rgba(255, 255, 255, 0.85);
    --glass-border: rgba(0, 0, 0, 0.05);
    --glass-hover: rgba(0, 0, 0, 0.02);
    --shadow-glow: rgba(0, 0, 0, 0.03);
    --card-bg: #ffffff;
}

.dark {
    --bg-color: #050505;
    --text-main: #e5e7eb;
    --text-muted: #9ca3af;
    --grid-line-p: rgba(168, 85, 247, 0.05);
    --grid-line-o: rgba(249, 115, 22, 0.05);
    --glass-bg: rgba(15, 15, 20, 0.7);
    --glass-border: rgba(255, 255, 255, 0.08);
    --glass-hover: rgba(255, 255, 255, 0.12);
    --shadow-glow: rgba(0, 0, 0, 0.5);
    --card-bg: rgba(255, 255, 255, 0.03);
}

body {
    background-color: var(--bg-color);
    color: var(--text-main);
    transition: background-color 0.4s ease, color 0.4s ease;
    -webkit-tap-highlight-color: transparent;
    overflow-x: hidden;
    overflow-y: auto;
}

a { color: inherit; text-decoration: none; }

.bg-grid {
    background-size: 40px 40px;
    background-image:
        linear-gradient(to right, var(--grid-line-p) 1px, transparent 1px),
        linear-gradient(to bottom, var(--grid-line-o) 1px, transparent 1px);
    background-attachment: fixed;
}

.glass-panel {
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    box-shadow: 0 10px 40px var(--shadow-glow);
}

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--glass-border); border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

.category-btn.active,
.category-btn.active:hover,
.category-btn.active:focus {
    background: var(--text-main) !important;
    color: var(--bg-color) !important;
    border-color: var(--text-main) !important;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.animate-fade-in {
    animation: fadeIn 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    opacity: 0;
}

.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }

.search-input:focus { outline: none; background: var(--glass-hover); }

/* Category badge / hover-color helpers */
.badge-cat-research      { color: #a855f7; border-color: rgba(168,85,247,.3); background: rgba(168,85,247,.1); }
.badge-cat-tech          { color: #f97316; border-color: rgba(249,115,22,.3); background: rgba(249,115,22,.1); }
.badge-cat-cases         { color: #229ED9; border-color: rgba(34,158,217,.3); background: rgba(34,158,217,.1); }
.badge-cat-thoughts      { color: #10b981; border-color: rgba(16,185,129,.3); background: rgba(16,185,129,.1); }
.badge-cat-news          { color: #ec4899; border-color: rgba(236,72,153,.3); background: rgba(236,72,153,.1); }
.badge-cat-announcements { color: #eab308; border-color: rgba(234,179,8,.3); background: rgba(234,179,8,.1); }

.title-hover-research      { transition: color .2s; }
.group:hover .title-hover-research      { color: #a855f7; }
.group:hover .title-hover-tech          { color: #f97316; }
.group:hover .title-hover-cases         { color: #229ED9; }
.group:hover .title-hover-thoughts      { color: #10b981; }
.group:hover .title-hover-news          { color: #ec4899; }
.group:hover .title-hover-announcements { color: #eab308; }

/* Calendar */
.cal-day {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-family: "Space Mono", monospace;
    font-size: 12px;
    color: var(--text-muted);
    cursor: default;
    user-select: none;
    border: 1px solid transparent;
}
.cal-day.has-posts { color: var(--text-main); border-color: var(--glass-border); cursor: pointer; }
.cal-day.has-posts:hover { background: var(--glass-hover); }
.cal-day.active { background: var(--text-main); color: var(--bg-color); border-color: var(--text-main); }
.cal-day.empty { visibility: hidden; }

/* Article body */
.prose-feed h1 { font-size: 1.75rem; font-weight: 700; margin: 1.4em 0 .6em; font-family: "Montserrat", sans-serif; }
.prose-feed h2 { font-size: 1.4rem;  font-weight: 700; margin: 1.4em 0 .6em; font-family: "Montserrat", sans-serif; }
.prose-feed h3 { font-size: 1.15rem; font-weight: 700; margin: 1.2em 0 .5em; font-family: "Montserrat", sans-serif; }
.prose-feed p  { margin: .9em 0; line-height: 1.7; color: var(--text-main); }
.prose-feed ul,
.prose-feed ol { padding-left: 1.4em; margin: .8em 0; color: var(--text-main); }
.prose-feed li { margin: .35em 0; line-height: 1.65; }
.prose-feed a  { color: #a855f7; text-decoration: underline; text-underline-offset: 3px; }
.prose-feed code {
    font-family: "Space Mono", monospace;
    font-size: .9em;
    background: var(--glass-hover);
    padding: .15em .4em;
    border-radius: .35em;
}
.prose-feed pre {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 1rem;
    padding: 1rem 1.25rem;
    overflow-x: auto;
    margin: 1.2em 0;
}
.prose-feed pre code { background: transparent; padding: 0; }
.prose-feed blockquote {
    border-left: 3px solid #a855f7;
    margin: 1em 0;
    padding: .2em 1em;
    color: var(--text-muted);
    font-style: italic;
}

/* scroll-top button visibility helper */
#scroll-top-btn.visible { opacity: 1; pointer-events: auto; }
