/* Page-scoped styles for blog/index.html */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --bg: #0a0a0a; --bg2: #111111;
      --border: rgba(255,255,255,0.07); --border-bright: rgba(255,255,255,0.14);
      --lime: #bfff5e; --lime-dim: rgba(191,255,94,0.10); --lime-glow: rgba(191,255,94,0.28);
      --white: #f0f0ec; --muted: rgba(240,240,236,0.45); --faint: rgba(240,240,236,0.18);
      --mono: 'DM Mono', monospace;
      --sans: 'Bodoni Moda', Georgia, serif;
      --body: 'Instrument Sans', system-ui, sans-serif;
    }
    html { scroll-behavior: smooth; }
    body { background: var(--bg); color: var(--white); font-family: var(--body); line-height: 1.7; overflow-x: hidden; }
    body::before { content: ''; position: fixed; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E"); pointer-events: none; z-index: 1000; opacity: 0.6; }

    .page-hero { padding: 160px 48px 80px; border-bottom: 1px solid var(--border); position: relative; overflow: hidden; }
    .hero-grid-bg { position: absolute; inset: 0; background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px); background-size: 60px 60px; mask-image: radial-gradient(ellipse 100% 100% at 0% 50%, black 20%, transparent 80%); }
    .page-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--lime); margin-bottom: 24px; position: relative; }
    .page-title { font-family: var(--sans); font-size: clamp(44px, 6vw, 80px); font-weight: 900; font-variation-settings: 'opsz' 96; line-height: 1.0; letter-spacing: -0.02em; margin-bottom: 28px; position: relative; max-width: 640px; }
    .page-title em { font-style: italic; color: var(--lime); }
    .page-intro { font-size: 17px; color: var(--muted); max-width: 480px; line-height: 1.75; position: relative; }

    /* Post list */
    .post-list { max-width: 800px; margin: 0 auto; padding: 80px 48px 100px; }

    .post-card { display: block; text-decoration: none; border: 1px solid var(--border); border-radius: 6px; padding: 36px; margin-bottom: 20px; background: var(--bg2); transition: border-color 0.2s, transform 0.15s; }
    .post-card:hover { border-color: var(--border-bright); transform: translateY(-2px); }

    .post-meta { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
    .post-date { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--faint); }
    .post-tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--lime); background: var(--lime-dim); border: 1px solid rgba(191,255,94,0.2); border-radius: 3px; padding: 3px 8px; }

    .post-title { font-family: var(--sans); font-size: clamp(20px, 2.5vw, 28px); font-weight: 700; font-variation-settings: 'opsz' 48; line-height: 1.15; letter-spacing: -0.015em; color: var(--white); margin-bottom: 12px; }

    .post-excerpt { font-size: 15px; color: var(--muted); line-height: 1.75; margin-bottom: 20px; }

    .post-read-more { font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; color: var(--lime); display: inline-flex; align-items: center; gap: 6px; }
    .post-read-more svg { transition: transform 0.15s; }
    .post-card:hover .post-read-more svg { transform: translateX(3px); }

    /* Coming soon cards */
    .post-card-upcoming { border: 1px solid var(--border); border-radius: 6px; padding: 36px; margin-bottom: 20px; opacity: 0.4; }
    .post-upcoming-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
    .post-upcoming-title { font-family: var(--sans); font-size: clamp(18px, 2vw, 24px); font-weight: 700; font-variation-settings: 'opsz' 48; line-height: 1.2; letter-spacing: -0.01em; color: var(--muted); }

    .section-break { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--lime); margin: 48px 0 24px; }

    @media (max-width: 768px) {
      .page-hero { padding: 120px 24px 60px; }
      .post-list { padding: 60px 24px 80px; }
    }
