:root { --bg: #f7f4ee; --surface: #ffffff; --border: #ddd9d0; --accent: #8b6200; --accent-dim: #b8892a; --text: #1c1a16; --muted: #6b6560; --mono: ui-monospace, 'Cascadia Mono', 'Fira Code', 'Courier New', monospace; --display: system-ui, -apple-system, 'Segoe UI', sans-serif; } * { box-sizing: border-box; margin: 0; padding: 0; } body { background: var(--bg); color: var(--text); font-family: var(--mono); min-height: 100vh; } #header { position: sticky; top: 0; z-index: 10; background: var(--bg); border-bottom: 1px solid var(--border); padding: 0 2rem; height: 52px; display: flex; align-items: center; gap: 1.5rem; } #header h1 { font-family: var(--display); font-size: 1.5rem; letter-spacing: 0.12em; color: var(--accent); text-transform: uppercase; } #header .sep { color: var(--muted); } #header .channel { font-size: 0.7rem; color: var(--muted); text-decoration: none; letter-spacing: 0.05em; } #header .channel:hover { color: var(--text); } .rss-link { margin-left: auto; display: flex; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--muted); font-size: 0.6rem; letter-spacing: 0.08em; text-transform: uppercase; } .rss-link:hover { color: var(--accent); } .rss-link:hover svg { fill: var(--accent); } .rss-link svg { width: 14px; height: 14px; fill: var(--muted); transition: fill 0.15s; } .live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); animation: pulse 2s ease-in-out infinite; } @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.2; } } #last-updated { font-size: 0.65rem; color: var(--muted); } #ticker-wrap { overflow: hidden; background: var(--bg); border-bottom: 1px solid var(--border); height: 28px; display: flex; align-items: center; } #ticker-label { flex-shrink: 0; position: relative; z-index: 1; font-size: 0.6rem; letter-spacing: 0.15em; color: var(--bg); background: var(--accent); padding: 0 0.75rem; height: 100%; display: flex; align-items: center; } #ticker-track { display: flex; gap: 4rem; padding-left: 2rem; white-space: nowrap; animation: scroll 120s linear infinite; } #ticker-track:hover { animation-play-state: paused; } #ticker-track span { font-size: 0.65rem; color: var(--text); letter-spacing: 0.04em; } @keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } } #feed { max-width: 780px; margin: 0 auto; padding: 2rem 1.5rem; display: flex; flex-direction: column; gap: 1px; } .card { background: var(--surface); border: 1px solid var(--border); border-left: 3px solid var(--accent-dim); padding: 1.1rem 1.3rem; display: grid; grid-template-columns: 90px 1fr; gap: 0 1.2rem; animation: slide-in 0.35s ease both; } .card.new { border-left-color: var(--accent); } .card:hover { border-color: var(--border); border-left-color: var(--accent); } @keyframes slide-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } } .card-time { font-size: 0.62rem; color: var(--muted); line-height: 1.6; padding-top: 2px; } .card-time .date { display: block; } .card-time .time { display: block; color: var(--accent); font-size: 0.7rem; } .card-title { font-family: var(--display); font-size: 1.05rem; line-height: 1.35; letter-spacing: 0.02em; color: var(--text); margin-bottom: 0.5rem; } .card-img { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 0.5rem; } .card-img img { max-height: 140px; max-width: 200px; object-fit: cover; border: 1px solid var(--border); cursor: zoom-in; transition: opacity 0.15s; } .card-img img:hover { opacity: 0.85; } .card-link { font-size: 0.6rem; letter-spacing: 0.1em; color: var(--accent-dim); text-decoration: none; text-transform: uppercase; } .card-link:hover { color: var(--accent); } #status { text-align: center; padding: 4rem 2rem; font-size: 0.7rem; color: var(--muted); letter-spacing: 0.1em; } #lb { display: none; position: fixed; inset: 0; background: rgba(0, 0, 0, 0.92); z-index: 100; align-items: center; justify-content: center; cursor: zoom-out; } #lb.open { display: flex; } #lb img { max-width: 90vw; max-height: 90vh; object-fit: contain; } #footer { max-width: 780px; margin: 0 auto; padding: 2rem 1.5rem; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: center; gap: 0.5rem; flex-wrap: wrap; } #footer a { font-size: 0.6rem; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; color: var(--muted); padding: 0.25rem 0.6rem; border: 1px solid transparent; } #footer a:hover { color: var(--text); border-color: var(--border); } #footer a.active { color: var(--accent); border-color: var(--accent-dim); } @media (max-width: 600px) { .card { grid-template-columns: 1fr; gap: 0.4rem 0; } #header { padding: 0 1rem; flex-wrap: wrap; height: auto; padding-top: 0.5rem; padding-bottom: 0.5rem; } #feed { padding: 1rem; } #footer { padding: 1.5rem 1rem; } }