/* ============================================================ CODEX OBSCURA — A Dark Academia Pixel Theme Fall Palette × Candlelit Library × Cozy Stationery ============================================================ */ @import url('https://fonts.googleapis.com/css2?family=VT323&family=IM+Fell+English:ital@0;1&family=Courier+Prime:ital,wght@0,400;0,700;1,400&display=swap'); @import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap'); /* ── Variables ───────────────────────────────────────────── */ :root { /* Fall × Dark Academia Palette */ --bg-void: #0b0804; --bg-primary: #130e07; --bg-secondary: #1c1509; --bg-surface: #261c0e; --bg-elevated: #312414; --bg-hover: #3d2e1a; --text-parchment: #e8d5a3; --text-warm: #c9b07a; --text-muted: #8a7050; --text-dim: #5a4830; --amber: #d4a228; --amber-light: #f0c040; --amber-dark: #a07818; --orange: #c4601c; --orange-light: #e07828; --rust: #8a2e08; --crimson: #7a1a1a; --forest: #3a5c20; --forest-light: #4e7830; --umber: #5c3a18; --border-dim: #3a2a14; --border-mid: #5a4020; --border-bright: #8a6030; --border-amber: #a07820; --glow-amber: rgba(212, 162, 40, 0.12); --glow-text: rgba(232, 213, 163, 0.06); --font-terminal: 'VT323', 'Courier New', monospace; --font-body: 'Josefin Sans', Georgia, 'Times New Roman', serif; --font-mono: 'Courier Prime', 'Courier New', Courier, monospace; --px: 2px; --transition: 150ms ease; --transition-slow: 400ms ease; } /* ── Reset & Base ────────────────────────────────────────── */ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } html { font-size: 18px; scroll-behavior: smooth; background: var(--bg-void); } ::selection { background: var(--amber-dark); color: var(--bg-void); } /* ── Body ────────────────────────────────────────────────── */ body { font-family: var(--font-body); font-size: 1.05rem; line-height: 1.75; color: var(--text-parchment); background: var(--bg-primary); min-height: 100vh; position: relative; } /* ── Layout Shell ────────────────────────────────────────── */ .site-wrapper { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; overflow-x: hidden; position: relative; z-index: 1; } .content-grid { display: grid; grid-template-columns: 1fr 280px; gap: 2.5rem; margin-top: 2rem; align-items: start; } @media (max-width: 768px) { .content-grid { grid-template-columns: 1fr; } .sidebar { order: -1; } } /* ── Pixel Border Utility ────────────────────────────────── */ .pixel-border { border: var(--px) solid var(--border-mid); box-shadow: inset 0 0 0 var(--px) var(--border-dim), var(--px) var(--px) 0 var(--border-bright), calc(var(--px) * -1) calc(var(--px) * -1) 0 var(--border-dim); position: relative; } .pixel-border--amber { border-color: var(--border-amber); box-shadow: inset 0 0 0 var(--px) rgba(212, 162, 40, 0.15), var(--px) var(--px) 0 var(--amber), calc(var(--px) * -1) calc(var(--px) * -1) 0 var(--amber-dark); } /* ── Site Header ─────────────────────────────────────────── */ .site-header { padding: 2rem 0 1.5rem; border-bottom: var(--px) solid var(--border-mid); position: relative; margin-bottom: 0; } .site-header::after { content: ''; display: block; height: var(--px); background: linear-gradient(90deg, transparent, var(--amber-dark) 20%, var(--amber) 50%, var(--amber-dark) 80%, transparent ); margin-top: var(--px); } .header-inner { display: flex; flex-direction: column; gap: 1rem; } /* Cozy pixel deco banner — replaces the heavy ASCII art */ .site-deco { font-family: var(--font-terminal); font-size: 1.1rem; color: var(--amber-dark); letter-spacing: 0.3em; opacity: 0.7; user-select: none; } /* Site title */ .site-title { display: flex; align-items: baseline; gap: 0.5rem; text-decoration: none; } .site-title__prompt { font-family: var(--font-terminal); font-size: 1.4rem; color: var(--forest-light); } .site-title__name { font-family: var(--font-terminal); font-size: clamp(1.8rem, 4vw, 2.8rem); color: var(--text-parchment); text-shadow: 2px 2px 0 var(--umber); letter-spacing: 0.05em; line-height: 1; transition: color var(--transition); } .site-title:hover .site-title__name { color: var(--amber); } .site-title__cursor { font-family: var(--font-terminal); font-size: 0.6rem; color: var(--amber); animation: blink 1.1s step-end infinite; } @keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } } .site-tagline { font-family: var(--font-body); font-style: italic; font-size: 0.9rem; color: var(--text-muted); letter-spacing: 0.08em; margin-top: 0.2rem; } /* ── Navigation ──────────────────────────────────────────── */ .site-nav { display: flex; flex-wrap: wrap; gap: 0; font-family: var(--font-terminal); font-size: 1.1rem; margin-top: 0.5rem; border-top: var(--px) solid var(--border-dim); padding-top: 0.75rem; } .nav-item a { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0.3rem 1rem 0.3rem 0.5rem; color: var(--text-warm); text-decoration: none; letter-spacing: 0.05em; transition: color var(--transition), background var(--transition); } .nav-item a::before { content: './'; color: var(--forest-light); font-size: 0.9em; opacity: 0.7; transition: opacity var(--transition); } .nav-item a:hover { color: var(--amber-light); background: var(--bg-elevated); } .nav-item a:hover::before { opacity: 1; color: var(--amber); } .nav-item--active a { color: var(--amber); background: var(--bg-elevated); } .nav-item--active a::before { color: var(--orange); } /* ── Main Content ────────────────────────────────────────── */ main { min-width: 0; } /* ── Post Card ───────────────────────────────────────────── */ .post-list { list-style: none; display: flex; flex-direction: column; gap: 1.5rem; } .post-card { background: var(--bg-secondary); padding: 1.5rem; position: relative; transition: background var(--transition), border-color var(--transition); } .post-card.pixel-border:hover { background: var(--bg-surface); border-color: var(--border-amber); box-shadow: inset 0 0 0 var(--px) rgba(212, 162, 40, 0.1), var(--px) var(--px) 0 var(--amber-dark), calc(var(--px) * -1) calc(var(--px) * -1) 0 var(--umber); } /* small pixel icon top-right */ .post-card::before { content: attr(data-index); font-family: var(--font-terminal); font-size: 0.75rem; color: var(--text-dim); position: absolute; top: 0.5rem; right: 0.75rem; letter-spacing: 0.1em; } .post-card__meta { font-family: var(--font-terminal); font-size: 0.9rem; color: var(--forest-light); margin-bottom: 0.4rem; display: flex; align-items: center; gap: 0.5rem; letter-spacing: 0.05em; } .post-card__meta .prompt { color: var(--text-dim); } .post-card__date { color: var(--text-muted); } .post-card__title { font-family: var(--font-terminal); font-size: clamp(1.3rem, 2.5vw, 1.7rem); line-height: 1.2; margin-bottom: 0.6rem; letter-spacing: 0.03em; } .post-card__title a { color: var(--text-parchment); text-decoration: none; transition: color var(--transition); text-shadow: 1px 1px 0 var(--umber); } .post-card__title a:hover { color: var(--amber); } .post-card__summary { font-size: 0.92rem; color: var(--text-warm); line-height: 1.7; font-style: italic; border-left: 2px solid var(--border-mid); padding-left: 0.8rem; margin-bottom: 0.8rem; } .post-card__tags { display: flex; flex-wrap: wrap; gap: 0.4rem; } .tag { font-family: var(--font-terminal); font-size: 0.78rem; padding: 0.1rem 0.5rem; background: var(--bg-elevated); color: var(--text-muted); border: var(--px) solid var(--border-dim); text-decoration: none; letter-spacing: 0.08em; transition: all var(--transition); } .tag:hover { background: var(--bg-hover); color: var(--amber); border-color: var(--amber-dark); } .tag::before { content: '#'; color: var(--amber-dark); opacity: 0.7; } /* ── Single Post ─────────────────────────────────────────── */ .post-header { margin-bottom: 2rem; padding-bottom: 1.5rem; border-bottom: var(--px) solid var(--border-mid); position: relative; } .post-header::after { content: ''; display: block; height: var(--px); background: linear-gradient(90deg, var(--amber-dark), var(--orange) 40%, var(--rust) 70%, transparent ); margin-top: var(--px); } .post-breadcrumb { font-family: var(--font-terminal); font-size: 0.85rem; color: var(--text-dim); margin-bottom: 0.8rem; letter-spacing: 0.05em; } .post-breadcrumb a { color: var(--forest-light); text-decoration: none; } .post-breadcrumb a:hover { color: var(--amber); } .post-breadcrumb span { color: var(--border-bright); margin: 0 0.3rem; } .post-title { font-family: var(--font-terminal); font-size: clamp(1.8rem, 4vw, 3rem); color: var(--text-parchment); line-height: 1.15; letter-spacing: 0.04em; text-shadow: 2px 2px 0 var(--umber); margin-bottom: 0.75rem; } .post-title::before { content: '> '; color: var(--orange); font-size: 0.85em; } .post-meta { font-family: var(--font-terminal); font-size: 0.9rem; color: var(--text-muted); display: flex; flex-wrap: wrap; align-items: center; gap: 0.3rem 1rem; letter-spacing: 0.05em; } .post-meta__item { display: flex; align-items: center; gap: 0.3rem; } .post-meta__label { color: var(--forest-light); } .post-meta__value { color: var(--amber); } .post-reading-time { color: var(--text-dim); } /* ── Article Body ────────────────────────────────────────── */ .post-body { max-width: 68ch; } .post-body h1, .post-body h2, .post-body h3, .post-body h4, .post-body h5, .post-body h6 { font-family: var(--font-terminal); color: var(--amber-light); letter-spacing: 0.05em; margin: 2rem 0 0.75rem; line-height: 1.2; } .post-body h2 { font-size: 1.7rem; } .post-body h3 { font-size: 1.4rem; } .post-body h4 { font-size: 1.2rem; } # .post-body h2::before { content: '## '; color: var(--orange); opacity: 0.7; } # .post-body h3::before { content: '### '; color: var(--orange); opacity: 0.6; } # .post-body h4::before { content: '#### '; color: var(--orange); opacity: 0.5; } .post-body p { margin-bottom: 1.3rem; color: var(--text-warm); } .post-body a { color: var(--amber); text-decoration: none; border-bottom: var(--px) solid var(--amber-dark); padding-bottom: 1px; transition: color var(--transition), border-color var(--transition); } .post-body a:hover { color: var(--amber-light); border-color: var(--amber-light); } .post-body strong { color: var(--text-parchment); font-weight: 700; } .post-body em { color: var(--text-parchment); font-style: italic; } .post-body blockquote { margin: 1.5rem 0; padding: 1rem 1.25rem; background: var(--bg-secondary); border-left: 4px solid var(--amber-dark); border-right: var(--px) solid var(--border-dim); position: relative; font-style: italic; color: var(--text-warm); } .post-body blockquote::before { content: '"'; font-family: var(--font-terminal); font-size: 3rem; color: var(--amber-dark); position: absolute; top: -0.5rem; left: 0.75rem; line-height: 1; opacity: 0.5; } .post-body blockquote p { margin: 0; padding-left: 1rem; } .post-body code { font-family: var(--font-mono); font-size: 0.88em; background: var(--bg-secondary); color: var(--orange-light); padding: 0.15em 0.45em; border: var(--px) solid var(--border-dim); } .post-body pre { background: var(--bg-void); border: var(--px) solid var(--border-mid); box-shadow: inset 0 0 0 var(--px) var(--border-dim), var(--px) var(--px) 0 var(--forest); padding: 1.25rem; overflow-x: auto; margin: 1.5rem 0; position: relative; } .post-body pre::before { content: '~/codex $ '; display: block; font-family: var(--font-terminal); font-size: 0.8rem; color: var(--forest-light); margin-bottom: 0.5rem; letter-spacing: 0.05em; } .post-body pre code { background: none; border: none; padding: 0; color: var(--text-parchment); font-size: 0.9rem; line-height: 1.6; } .post-body hr { border: none; margin: 2rem 0; height: 1px; background: repeating-linear-gradient( 90deg, var(--border-mid) 0px, var(--border-mid) 4px, transparent 4px, transparent 8px ); position: relative; } .post-body hr::after { content: '✦ ✦ ✦'; font-size: 0.7rem; color: var(--amber-dark); position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--bg-primary); padding: 0 0.75rem; letter-spacing: 0.4em; } .post-body ul, .post-body ol { margin: 0 0 1.3rem 1.2rem; color: var(--text-warm); } .post-body li { margin-bottom: 0.35rem; position: relative; } .post-body ul > li { list-style: none; } .post-body ul > li::before { content: '›'; font-family: var(--font-terminal); color: var(--orange); position: absolute; left: -1.1rem; top: 0; } .post-body table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 0.88rem; margin: 1.5rem 0; } .post-body th { background: var(--bg-elevated); color: var(--amber); font-family: var(--font-terminal); letter-spacing: 0.08em; padding: 0.5rem 0.75rem; border: var(--px) solid var(--border-mid); text-align: left; } .post-body td { padding: 0.45rem 0.75rem; border: var(--px) solid var(--border-dim); color: var(--text-warm); border-bottom-color: var(--border-mid); } .post-body tr:nth-child(even) td { background: var(--bg-secondary); } .post-body img { max-width: 100%; height: auto; display: block; margin: 1.5rem auto; border: var(--px) solid var(--border-mid); box-shadow: var(--px) var(--px) 0 var(--umber); image-rendering: auto; } .post-body figcaption { font-family: var(--font-terminal); font-size: 0.8rem; color: var(--text-dim); text-align: center; margin-top: 0.4rem; letter-spacing: 0.05em; } /* ── Post Footer ─────────────────────────────────────────── */ .post-footer { margin-top: 3rem; padding-top: 1.5rem; border-top: var(--px) solid var(--border-mid); } .post-tags-section { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-bottom: 1.5rem; font-family: var(--font-terminal); font-size: 0.85rem; color: var(--text-dim); } .post-tags-section__label { color: var(--forest-light); letter-spacing: 0.05em; } .post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; } .post-nav__item { background: var(--bg-secondary); padding: 1rem; text-decoration: none; transition: background var(--transition); border: var(--px) solid var(--border-dim); } .post-nav__item:hover { background: var(--bg-elevated); border-color: var(--border-bright); } .post-nav__item--next { text-align: right; } .post-nav__label { font-family: var(--font-terminal); font-size: 0.75rem; color: var(--forest-light); letter-spacing: 0.1em; display: block; margin-bottom: 0.25rem; } .post-nav__title { font-family: var(--font-terminal); font-size: 0.95rem; color: var(--text-parchment); transition: color var(--transition); } .post-nav__item:hover .post-nav__title { color: var(--amber); } /* ── Sidebar ─────────────────────────────────────────────── */ .sidebar { font-family: var(--font-terminal); position: sticky; top: 1.5rem; display: flex; flex-direction: column; gap: 1.5rem; } .sidebar-widget { background: var(--bg-secondary); padding: 1rem; } .sidebar-widget__header { font-size: 0.85rem; color: var(--amber); letter-spacing: 0.12em; text-transform: uppercase; padding-bottom: 0.6rem; margin-bottom: 0.75rem; border-bottom: var(--px) solid var(--border-dim); display: flex; align-items: center; gap: 0.5rem; } /* pixel icon before widget title */ .sidebar-widget__header .widget-icon { font-size: 1rem; line-height: 1; } .sidebar-posts { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; } .sidebar-post { border-left: 2px solid var(--border-dim); padding-left: 0.6rem; transition: border-color var(--transition); } .sidebar-post:hover { border-left-color: var(--amber-dark); } .sidebar-post a { font-size: 0.85rem; color: var(--text-muted); text-decoration: none; display: block; transition: color var(--transition); line-height: 1.3; } .sidebar-post a:hover { color: var(--amber); } .sidebar-post__date { font-size: 0.7rem; color: var(--text-dim); display: block; margin-top: 0.1rem; } .sidebar-tags { display: flex; flex-wrap: wrap; gap: 0.35rem; } .sys-info { font-size: 0.8rem; color: var(--text-dim); line-height: 1.9; } .sys-info__row { display: flex; gap: 0.5rem; } .sys-info__key { color: var(--forest-light); min-width: 80px; } .sys-info__val { color: var(--text-muted); } /* ── Homepage Hero ───────────────────────────────────────── */ .hero { padding: 2.5rem 0 2rem; border-bottom: var(--px) solid var(--border-dim); margin-bottom: 2rem; } /* Cozy intro card — like the RPG status box in the reference */ .hero__card { background: var(--bg-secondary); padding: 1.5rem; margin-bottom: 1.5rem; display: grid; grid-template-columns: auto 1fr; gap: 2.5rem; align-items: start; } .hero__pixel-art { font-family: var(--font-terminal); font-size: 0.72rem; line-height: 1.25; color: var(--amber); white-space: pre; user-select: none; flex-shrink: 0; } .hero__info { display: flex; flex-direction: column; gap: 0.75rem; } .hero__name-bar { font-family: var(--font-terminal); font-size: 1.1rem; color: var(--text-parchment); background: var(--bg-elevated); padding: 0.3rem 0.75rem; display: flex; align-items: center; justify-content: space-between; border: var(--px) solid var(--border-dim); } .hero__name-bar .label { color: var(--text-dim); font-size: 0.85em; } .hero__name-bar .value { color: var(--amber); } .hero__desc { font-family: var(--font-mono); font-size: 0.92rem; color: var(--text-warm); line-height: 1.7; } /* Cozy status pip row */ .hero__status { display: flex; align-items: center; gap: 0.4rem; font-family: var(--font-terminal); font-size: 0.8rem; color: var(--text-dim); } .pip { display: inline-block; width: 10px; height: 10px; background: var(--amber); border: var(--px) solid var(--amber-dark); image-rendering: pixelated; } .pip--dim { background: var(--bg-elevated); border-color: var(--border-mid); } @media (max-width: 600px) { .hero__card { grid-template-columns: 1fr; } .hero__pixel-art { display: none; } } .hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; } .btn { font-family: var(--font-terminal); font-size: 1rem; letter-spacing: 0.08em; padding: 0.55rem 1.4rem; text-decoration: none; border: var(--px) solid; transition: all var(--transition); cursor: pointer; display: inline-flex; align-items: center; gap: 0.4rem; } .btn--primary { background: var(--amber-dark); color: var(--bg-void); border-color: var(--amber); box-shadow: var(--px) var(--px) 0 var(--umber); } .btn--primary:hover { background: var(--amber); box-shadow: var(--px) var(--px) 0 var(--amber-dark); transform: translate(-1px, -1px); } .btn--secondary { background: transparent; color: var(--text-warm); border-color: var(--border-mid); } .btn--secondary:hover { color: var(--amber); border-color: var(--amber-dark); background: var(--bg-elevated); } /* ── Pagination ──────────────────────────────────────────── */ .pagination { display: flex; justify-content: center; align-items: center; gap: 0.5rem; margin: 2.5rem 0; font-family: var(--font-terminal); font-size: 0.9rem; } .pagination a, .pagination span { padding: 0.35rem 0.75rem; border: var(--px) solid var(--border-dim); text-decoration: none; transition: all var(--transition); } .pagination a { color: var(--text-muted); } .pagination a:hover { color: var(--amber); border-color: var(--amber-dark); background: var(--bg-elevated); } .pagination .current { background: var(--bg-elevated); color: var(--amber); border-color: var(--border-bright); } /* ── Taxonomy ────────────────────────────────────────────── */ .taxonomy-header { font-family: var(--font-terminal); font-size: 0.85rem; color: var(--text-dim); letter-spacing: 0.08em; margin-bottom: 1.5rem; } .taxonomy-list { display: flex; flex-wrap: wrap; gap: 0.6rem; list-style: none; } .taxonomy-list__item a { font-family: var(--font-terminal); font-size: 1rem; padding: 0.35rem 0.8rem; background: var(--bg-secondary); color: var(--text-muted); text-decoration: none; border: var(--px) solid var(--border-dim); display: inline-flex; align-items: center; gap: 0.4rem; transition: all var(--transition); letter-spacing: 0.05em; } .taxonomy-list__item a:hover { color: var(--amber); border-color: var(--amber-dark); background: var(--bg-elevated); } .taxonomy-list__item .count { color: var(--text-dim); font-size: 0.8em; } /* ── Site Footer ─────────────────────────────────────────── */ .site-footer { margin-top: 4rem; padding: 0; border-top: var(--px) solid var(--border-mid); position: relative; } .site-footer::before { content: ''; display: block; height: var(--px); background: linear-gradient(90deg, transparent, var(--amber-dark) 20%, var(--amber) 50%, var(--amber-dark) 80%, transparent ); } .footer-inner { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1.5rem; padding: 1.5rem 0; border-bottom: var(--px) solid var(--border-dim); } @media (max-width: 600px) { .footer-inner { grid-template-columns: 1fr; } } .footer-col__title { font-family: var(--font-terminal); font-size: 0.8rem; color: var(--forest-light); letter-spacing: 0.12em; margin-bottom: 0.6rem; } .footer-links { list-style: none; display: flex; flex-direction: column; gap: 0.3rem; } .footer-links a { font-family: var(--font-terminal); font-size: 0.85rem; color: var(--text-dim); text-decoration: none; transition: color var(--transition); } .footer-links a:hover { color: var(--amber); } .footer-links a::before { content: '> '; color: var(--border-bright); opacity: 0; transition: opacity var(--transition); } .footer-links a:hover::before { opacity: 1; } .footer-status { display: flex; align-items: center; justify-content: space-between; padding: 0.5rem 0; font-family: var(--font-terminal); font-size: 0.75rem; color: var(--text-dim); letter-spacing: 0.08em; flex-wrap: wrap; gap: 0.5rem; } .status-left, .status-right { display: flex; align-items: center; gap: 1rem; } .status-indicator { display: inline-flex; align-items: center; gap: 0.3rem; } .status-dot { width: 6px; height: 6px; background: var(--forest-light); display: inline-block; animation: pulse 3s ease-in-out infinite; } @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } } /* ── Utility ─────────────────────────────────────────────── */ .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; } /* ── Scrollbar ───────────────────────────────────────────── */ ::-webkit-scrollbar { width: 8px; height: 8px; } ::-webkit-scrollbar-track { background: var(--bg-void); } ::-webkit-scrollbar-thumb { background: var(--umber); border: var(--px) solid var(--bg-secondary); } ::-webkit-scrollbar-thumb:hover { background: var(--amber-dark); } /* ── Print ───────────────────────────────────────────────── */ @media print { body::before, body::after, .site-nav, .sidebar, .post-nav { display: none; } body { background: #fff; color: #000; } } /* ── Resume Page ─────────────────────────────────────────── */ .resume-header { background: var(--bg-secondary); padding: 1.5rem; margin-bottom: 2rem; } .resume-header__top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; font-family: var(--font-terminal); font-size: 0.85rem; } .resume-name { font-family: var(--font-terminal); font-size: clamp(2rem, 4vw, 3rem); color: var(--text-parchment); letter-spacing: 0.06em; text-shadow: 2px 2px 0 var(--umber); line-height: 1.1; margin-bottom: 0.3rem; } .resume-title { font-family: var(--font-body); font-style: italic; font-size: 1rem; color: var(--amber); margin-bottom: 0.75rem; letter-spacing: 0.05em; } .resume-contacts { display: flex; flex-wrap: wrap; gap: 0.4rem 1.5rem; font-family: var(--font-terminal); font-size: 0.82rem; } .resume-contact__label { color: var(--forest-light); } .resume-contact a { color: var(--text-muted); text-decoration: none; border-bottom: var(--px) solid var(--border-dim); transition: color var(--transition), border-color var(--transition); } .resume-contact a:hover { color: var(--amber); border-color: var(--amber-dark); } /* Resume sections inherit post-body styles but with some overrides */ .resume-body { max-width: 72ch; } .resume-body h2 { font-family: var(--font-terminal); font-size: 1.3rem; color: var(--amber-light); letter-spacing: 0.1em; text-transform: uppercase; margin: 2rem 0 1rem; padding-bottom: 0.4rem; border-bottom: var(--px) solid var(--border-mid); position: relative; } .resume-body h2::before { content: '▸ '; color: var(--orange); font-size: 0.9em; } /* Job/entry block */ .resume-body h3 { font-family: var(--font-terminal); font-size: 1.05rem; color: var(--text-parchment); letter-spacing: 0.04em; margin: 1.2rem 0 0.1rem; } .resume-body h3::before { content: none; } .resume-body h4 { font-family: var(--font-terminal); font-size: 0.85rem; color: var(--forest-light); letter-spacing: 0.08em; margin: 0 0 0.5rem; font-weight: normal; } .resume-body h4::before { content: none; } .resume-body p { color: var(--text-warm); font-size: 0.95rem; margin-bottom: 0.75rem; } .resume-body ul { margin: 0.25rem 0 0.75rem 1rem; color: var(--text-warm); } .resume-body ul > li { list-style: none; font-size: 0.92rem; margin-bottom: 0.25rem; position: relative; } .resume-body ul > li::before { content: '›'; font-family: var(--font-terminal); color: var(--orange); position: absolute; left: -1rem; } /* Skills tag row — wrap a group of words in a
inside a section */ .resume-body .skills-row { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.75rem; } /* Horizontal rule between sections */ .resume-body hr { border: none; margin: 1.5rem 0; height: var(--px); background: repeating-linear-gradient( 90deg, var(--border-dim) 0px, var(--border-dim) 4px, transparent 4px, transparent 8px ); } @media print { .resume-header__top .btn, .sidebar, .site-header, .site-footer, body::before, body::after { display: none !important; } .content-grid { grid-template-columns: 1fr !important; } .resume-name { font-size: 2rem; } body { background: #fff; color: #000; } .resume-header { border: 1px solid #ccc; } } /* ── Donate Page ─────────────────────────────────────────── */ .donate-header { background: var(--bg-secondary); padding: 1.5rem; margin-bottom: 2rem; } .donate-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; margin-bottom: 2.5rem; } .donate-card { background: var(--bg-secondary); padding: 1.25rem; text-decoration: none; display: flex; flex-direction: column; gap: 0.3rem; transition: background var(--transition), border-color var(--transition); } .donate-card:hover { background: var(--bg-elevated); border-color: var(--border-amber); } .donate-card__icon { font-size: 1.8rem; line-height: 1; margin-bottom: 0.25rem; } .donate-card__name { font-family: var(--font-terminal); font-size: 1.1rem; color: var(--amber); letter-spacing: 0.06em; } .donate-card__handle { font-family: var(--font-mono); font-size: 0.75rem; color: var(--forest-light); } .donate-card__desc { font-family: var(--font-body); font-style: italic; font-size: 0.85rem; color: var(--text-muted); margin-top: 0.25rem; } .donate-section { margin-top: 1rem; } .donate-section__title { font-family: var(--font-terminal); font-size: 1.1rem; color: var(--amber-light); letter-spacing: 0.1em; text-transform: uppercase; padding-bottom: 0.4rem; margin-bottom: 1rem; border-bottom: var(--px) solid var(--border-mid); } .donate-section__title::before { content: '▸ '; color: var(--orange); } .wallet-card { background: var(--bg-secondary); padding: 1rem 1.25rem; margin-bottom: 0.75rem; } .wallet-card__header { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; } .wallet-card__icon { font-family: var(--font-terminal); font-size: 1.2rem; color: var(--amber); width: 1.5rem; text-align: center; } .wallet-card__name { font-family: var(--font-terminal); font-size: 1rem; color: var(--text-parchment); letter-spacing: 0.05em; } .wallet-card__ticker { font-family: var(--font-terminal); font-size: 0.75rem; color: var(--text-dim); margin-left: auto; letter-spacing: 0.1em; } .wallet-card__address { display: flex; align-items: center; gap: 0.75rem; background: var(--bg-void); padding: 0.5rem 0.75rem; border: var(--px) solid var(--border-dim); flex-wrap: wrap; } .wallet-card__addr-text { font-family: var(--font-mono); font-size: 0.78rem; color: var(--orange-light); word-break: break-all; flex: 1; } .wallet-card__copy { font-family: var(--font-terminal); font-size: 0.82rem; color: var(--text-dim); background: none; border: none; cursor: pointer; padding: 0; transition: color var(--transition); white-space: nowrap; flex-shrink: 0; } .wallet-card__copy:hover { color: var(--amber); } /* ── Wallet QR codes ─────────────────────────────────────── */ .wallet-card__body { display: flex; align-items: flex-start; gap: 1rem; flex-wrap: wrap; } .wallet-card__address { flex: 1; min-width: 0; display: flex; align-items: center; gap: 0.75rem; background: var(--bg-void); padding: 0.5rem 0.75rem; border: var(--px) solid var(--border-dim); flex-wrap: wrap; } .wallet-qr { width: 160px; height: 160px; flex-shrink: 0; border: var(--px) solid var(--border-mid); box-shadow: var(--px) var(--px) 0 var(--umber); image-rendering: pixelated; } .post-subtitle { font-family: var(--font-body); font-style: italic; color: var(--text-muted); font-size: 0.9rem; margin-top: -0.3rem; margin-bottom: 0.6rem; letter-spacing: 0.02em; } .code-block__header { font-family: var(--font-terminal); font-size: 0.8rem; background: var(--bg-elevated); border: var(--px) solid var(--border-mid); border-bottom: none; padding: 0.3rem 1rem; display: flex; align-items: center; justify-content: space-between; letter-spacing: 0.08em; } .code-block__lang { color: var(--forest-light); } .code-block__title { color: var(--text-dim); font-style: normal; } .code-block__body pre { margin: 0; } .code-block__body pre::before { content: none; }