/* news.css — page-specific styles for news/index.html */

/* ── CURSOR ── */




/* ── NAV ── */


























/* ── PAGE ── */
main { max-width: 1100px; margin: 0 auto; padding: 9rem 3rem 6rem; }

.page-eyebrow { font-family: 'DM Mono', monospace; font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--blue); margin-bottom: 1.25rem; }
.page-title { font-family: 'Playfair Display', serif; font-size: clamp(2.6rem, 6vw, 4.4rem); font-weight: 400; line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 1.5rem; }
.page-title em { font-style: italic; color: var(--blue); }
.page-sub { font-size: 1.1rem; color: var(--w80); max-width: 640px; }
.rss-link {
  display: inline-flex; align-items: center; gap: 0.4rem;
  margin-top: 1.5rem;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--w60); text-decoration: none;
  padding: 0.5rem 0.9rem;
  border: 0.5px solid var(--border-bright);
  border-radius: 3px;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.rss-link:hover { color: var(--white); border-color: #ff8a3d; background: rgba(255,138,61,0.08); }
.rss-link svg { width: 12px; height: 12px; flex-shrink: 0; }

.loading { margin-top: 3rem; font-family: 'DM Mono', monospace; font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--w60); display: flex; align-items: center; gap: 0.6rem; }
.loading-dot { width: 6px; height: 6px; background: var(--blue); border-radius: 50%; animation: pulse 1.2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 0.3; } 50% { opacity: 1; } }

.empty-state { margin-top: 4rem; padding: 3rem 2rem; border: 0.5px dashed var(--border-bright); border-radius: 8px; text-align: center; }
.empty-state h3 { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 400; margin-bottom: 0.6rem; }
.empty-state p { color: var(--w60); font-size: 0.95rem; max-width: 520px; margin: 0 auto; }

/* ── LIST GRID ── */
.posts-grid { margin-top: 4rem; display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.post-card { background: var(--bg2); border: 0.5px solid var(--border); border-radius: 10px; overflow: hidden; cursor: pointer; transition: border-color 0.25s, transform 0.25s; display: flex; flex-direction: column; }
.post-card:hover { border-color: var(--border-bright); transform: translateY(-3px); }
.post-card-image { aspect-ratio: 16 / 9; background: var(--bg3); position: relative; overflow: hidden; }
.post-card-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s ease; }
.post-card:hover .post-card-image img { transform: scale(1.04); }
.post-card-image.placeholder { background: linear-gradient(135deg, var(--bg3), var(--bg4)); display: flex; align-items: center; justify-content: center; color: var(--w20); font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase; }
.post-card-body { padding: 1.4rem 1.6rem 1.6rem; flex: 1; display: flex; flex-direction: column; }
.post-card-meta { display: flex; gap: 0.7rem; font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--w40); margin-bottom: 0.7rem; flex-wrap: wrap; }
.post-card-meta .tag { color: var(--blue); }
.post-card-title { font-family: 'Playfair Display', serif; font-size: 1.45rem; font-weight: 400; line-height: 1.2; letter-spacing: -0.01em; margin-bottom: 0.6rem; color: var(--white); }
.post-card-excerpt { color: var(--w60); font-size: 0.95rem; line-height: 1.55; flex: 1; }
.post-card-read { margin-top: 1rem; font-family: 'DM Mono', monospace; font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--blue); display: flex; align-items: center; gap: 0.4rem; }
.post-card-read::after { content: '→'; transition: transform 0.2s; }
.post-card:hover .post-card-read::after { transform: translateX(3px); }

/* ── ARTICLE VIEW ── */
.article-back { margin-bottom: 2rem; display: inline-flex; align-items: center; gap: 0.5rem; font-family: 'DM Mono', monospace; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--w60); text-decoration: none; transition: color 0.2s, transform 0.2s; }
.article-back:hover { color: var(--white); }
.article-back::before { content: '←'; }
.article-hero { aspect-ratio: 21 / 9; background: var(--bg3); border-radius: 12px; overflow: hidden; margin-bottom: 2.5rem; }
.article-hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.article-meta { display: flex; gap: 0.8rem; font-family: 'DM Mono', monospace; font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--w40); margin-bottom: 1.2rem; flex-wrap: wrap; }
.article-meta .tag { color: var(--blue); }
.article-meta .author { color: var(--w60); }
.article-title { font-family: 'Playfair Display', serif; font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 400; line-height: 1.1; letter-spacing: -0.015em; margin-bottom: 2rem; color: var(--white); }
.article-title em { font-style: italic; color: var(--blue); }

/* Article body typography */
.article-body { max-width: 740px; font-size: 1.05rem; line-height: 1.75; color: var(--white); }
.article-body p { margin-bottom: 1.4rem; color: var(--w80); }
.article-body p:last-child { margin-bottom: 0; }
.article-body strong { color: var(--white); font-weight: 500; }
.article-body em { color: var(--white); }
.article-body a { color: var(--blue); text-decoration: none; border-bottom: 1px solid rgba(91,138,255,0.35); transition: color 0.2s, border-color 0.2s; }
.article-body a:hover { color: var(--blue2); border-color: var(--blue); }
.article-body h2 { font-family: 'Playfair Display', serif; font-size: 1.8rem; font-weight: 400; line-height: 1.2; margin: 3rem 0 1.2rem; letter-spacing: -0.01em; color: var(--white); }
.article-body h3 { font-family: 'Playfair Display', serif; font-size: 1.35rem; font-weight: 400; line-height: 1.25; margin: 2.5rem 0 1rem; color: var(--white); }
.article-body h4 { font-family: 'DM Mono', monospace; font-size: 0.78rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--blue); margin: 2rem 0 0.8rem; }
.article-body ul, .article-body ol { margin: 0 0 1.4rem 1.4rem; color: var(--w80); }
.article-body li { margin-bottom: 0.5rem; }
.article-body code { font-family: 'DM Mono', monospace; font-size: 0.88em; background: var(--bg3); padding: 0.15em 0.45em; border-radius: 4px; color: var(--green); }
.article-body pre { background: var(--bg3); border: 0.5px solid var(--border); border-radius: 8px; padding: 1.2rem 1.4rem; overflow-x: auto; margin-bottom: 1.4rem; }
.article-body pre code { background: transparent; padding: 0; color: var(--white-80); font-size: 0.88rem; }
.article-body blockquote { border-left: 2px solid var(--green); padding-left: 1.4rem; margin: 1.8rem 0; color: var(--white); font-style: italic; font-family: 'Playfair Display', serif; font-size: 1.2rem; line-height: 1.5; }
.article-body img { max-width: 100%; border-radius: 8px; margin: 2rem 0; display: block; }
.article-body hr { border: none; border-top: 0.5px solid var(--border); margin: 2.5rem 0; }

/* ── FADE ── */


  

/* ── FOOTER ── */






/* ── MOBILE ── */
@media (max-width: 900px) {
  
  
  
  
  
  
  main { padding: 7rem 1.25rem 4rem; }
  .posts-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .article-body { font-size: 1rem; }
  
}

/* ── MOBILE CTA (Say hello) ── */



/* ── MAURICE SLIDEOUT ── */
