*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Space Grotesk', sans-serif; background: #0d0d0f; color: #e8e6e0; line-height: 1.6; min-height: 100vh; }

/* Nav */
nav { display: flex; justify-content: space-between; align-items: center; padding: 1.25rem 3rem; border-bottom: 1px solid #1f1f24; gap: 2rem; }
nav .name { font-size: 0.95rem; font-weight: 700; letter-spacing: -0.01em; color: #fff; text-decoration: none; white-space: nowrap; }
nav ul { list-style: none; display: flex; gap: 1.5rem; flex-wrap: nowrap; }
nav ul a { text-decoration: none; color: #9a9895; font-size: 0.78rem; transition: color 0.2s; white-space: nowrap; }
nav ul a:hover, nav ul a.active { color: #e8e6e0; }

/* Home page */
.home-divider { height: 1px; background: #1f1f24; }
.home-section-label { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 1.25rem; }

/* Split hero */
.home-split { display: grid; grid-template-columns: 1fr 1fr; min-height: calc(100vh - 57px); }
.home-left { padding: 3.5rem 3rem; border-right: 1px solid #1f1f24; display: flex; flex-direction: column; justify-content: center; }
.home-h1 { font-size: clamp(1.9rem, 3.5vw, 3rem); font-weight: 700; line-height: 1.08; letter-spacing: -0.03em; margin-bottom: 1rem; }
.home-h1 span { color: #7c6fff; }
.home-right { display: flex; flex-direction: column; }
.home-right-card { padding: 2.5rem 3rem; border-bottom: 1px solid #1f1f24; flex: 1; display: flex; flex-direction: column; justify-content: center; gap: 0.6rem; }
.home-right-card--muted { background: #0a0a0c; }
.home-right-label { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.25rem; }
.home-right-card p { font-size: 0.85rem; color: #b8b6b2; font-weight: 300; line-height: 1.8; }
.home-right-card strong { color: #bbb; font-weight: 500; }
.home-right-closing { font-style: italic; color: #787882 !important; }

/* Inline explore (left column) */
.home-explore-inline { margin-top: 2rem; border-top: 1px solid #1f1f24; padding-top: 1.5rem; }
.home-explore-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; margin-top: 1rem; }
.home-explore-card { display: flex; align-items: center; gap: 0.6rem; background: #111115; border: 1px solid #1f1f24; border-radius: 8px; padding: 0.7rem 0.9rem; text-decoration: none; transition: border-color 0.2s; }
.home-explore-card:hover { border-color: #7c6fff44; }
.home-explore-num { font-family: 'Space Mono', monospace; font-size: 0.55rem; color: #7c6fff; flex-shrink: 0; }
.home-explore-title { font-size: 0.75rem; font-weight: 500; color: #c4c2be; flex: 1; line-height: 1.3; }
.home-explore-card p { display: none; }
.home-explore-arrow { font-size: 0.75rem; color: #7c6fff44; flex-shrink: 0; }
.home-explore-card:hover .home-explore-arrow { color: #7c6fff; }

/* Right column footer card */
.home-right-card--footer { flex: 0; gap: 1rem; flex-direction: row; align-items: center; justify-content: space-between; border-top: 1px solid #1f1f24; padding: 1.25rem 3rem; }
.home-right-card--footer p { font-size: 0.8rem; color: #6e6e78; font-style: italic; margin: 0; }

/* Hero (index) */
.hero { padding: 6rem 3rem 5rem; max-width: 900px; }
.eyebrow, .hero .eyebrow { font-family: 'Space Mono', monospace; font-size: 0.75rem; color: #7c6fff; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 1.5rem; }
.hero h1 { font-size: clamp(2.5rem, 6vw, 4.5rem); font-weight: 700; line-height: 1.05; letter-spacing: -0.03em; margin-bottom: 1.25rem; }
.hero h1 span { color: #7c6fff; }
.hero-sub { font-size: 1.05rem; color: #7c6fff; font-weight: 400; font-style: italic; margin-bottom: 1.25rem; white-space: nowrap; }
.hero-body { font-size: 1rem; color: #c4c2be; max-width: 560px; font-weight: 300; line-height: 1.75; margin-bottom: 1rem; }
.hero-closing { font-size: 0.85rem; color: #9a9895; font-weight: 400; letter-spacing: 0.03em; margin-bottom: 2.5rem; }
.cta { display: inline-flex; gap: 1rem; }

/* Buttons */
.btn { padding: 0.65rem 1.5rem; border-radius: 6px; font-size: 0.85rem; font-weight: 500; text-decoration: none; transition: all 0.2s; display: inline-block; font-family: 'Space Grotesk', sans-serif; }
.btn-primary { background: #7c6fff; color: #fff; }
.btn-primary:hover { background: #6a5ef0; }
.btn-ghost { border: 1px solid #2a2a30; color: #d0cecc; }
.btn-ghost:hover { border-color: #9a9895; color: #e8e6e0; }

/* Page layout (inner pages) */
.page { padding: 4rem 3rem; max-width: 900px; }
.page-header { margin-bottom: 3rem; }
.page-eyebrow { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.75rem; }
.page-title { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; }
.page-title span { color: #7c6fff; }

/* Divider */
.divider { height: 1px; background: #1f1f24; margin: 0 3rem; }

/* About page */
.about-block { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.about-primary p { font-size: 0.95rem; color: #d0cecc; font-weight: 300; line-height: 1.85; margin-bottom: 1.25rem; }
.about-primary p:last-child { margin-bottom: 0; }
.about-secondary { border-left: 1px solid #1f1f24; padding-left: 3rem; display: flex; align-items: center; }
.about-quiet { font-size: 0.9rem; color: #9a9895; font-style: italic; line-height: 1.85; }

/* About links */
.about-links { display: flex; gap: 1rem; margin-bottom: 2.5rem; }
.about-link { display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; color: #aeacaa; font-size: 0.85rem; border: 1px solid #1f1f24; padding: 0.5rem 1rem; border-radius: 6px; transition: all 0.2s; }
.about-link:hover { border-color: #7c6fff44; color: #e8e6e0; }

/* Research page */
.research-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem; }
.card { background: #111115; border: 1px solid #1f1f24; border-radius: 10px; padding: 1.5rem; transition: border-color 0.2s; }
.card:hover { border-color: #7c6fff44; }
.card .year { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #9a9895; margin-bottom: 0.75rem; }
.card h3 { font-size: 0.95rem; font-weight: 500; line-height: 1.4; margin-bottom: 0.5rem; }
.card p { font-size: 0.8rem; color: #aeacaa; }

/* Resume page */
.resume-section { margin-bottom: 2.5rem; }
.resume-section h3 { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 1.25rem; padding-bottom: 0.5rem; border-bottom: 1px solid #1f1f24; }
.resume-item { display: grid; grid-template-columns: 1fr auto; gap: 1rem; padding: 0.9rem 0; border-bottom: 1px solid #111115; }
.resume-item:last-child { border-bottom: none; }
.resume-item-title { font-size: 0.95rem; font-weight: 500; margin-bottom: 0.2rem; }
.resume-item-sub { font-size: 0.8rem; color: #aeacaa; }
.resume-item-date { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #9a9895; white-space: nowrap; padding-top: 0.1rem; }

/* Work & Thinking page */
.work-page { max-width: 960px; }
.work-section { margin-bottom: 3.5rem; }
.work-divider { height: 1px; background: #1f1f24; margin-bottom: 3.5rem; }

.section-label-row { margin-bottom: 0.75rem; }
.section-tag { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; }
.section-intro { font-size: 0.9rem; color: #9a9895; font-style: italic; margin-bottom: 2rem; }

.work-card { border: 1px solid #1f1f24; border-radius: 12px; padding: 2rem; margin-bottom: 1.25rem; background: #111115; transition: border-color 0.2s; }
.work-card:hover { border-color: #7c6fff33; }
.work-card-header { margin-bottom: 1.5rem; }
.work-context { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 0.4rem; }
.work-title { font-size: 1.15rem; font-weight: 600; letter-spacing: -0.01em; line-height: 1.3; }
.work-card-body { display: grid; grid-template-columns: 1fr 280px; gap: 2.5rem; }
.work-block-label { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #9a9895; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 0.5rem; }
.work-col p { font-size: 0.875rem; color: #c4c2be; font-weight: 300; line-height: 1.8; }
.work-extended { background: #0d0d0f; border: 1px solid #1f1f24; border-radius: 8px; padding: 1.25rem; align-self: start; }
.work-extended-label { font-family: 'Space Mono', monospace; font-size: 0.6rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.6rem; }
.work-extended p { font-size: 0.8rem; color: #aeacaa; line-height: 1.75; font-style: italic; }

.concept-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.concept-card { background: #111115; border: 1px solid #1f1f24; border-radius: 10px; padding: 1.5rem; transition: border-color 0.2s; }
.concept-card:hover { border-color: #7c6fff44; }
.concept-icon { font-size: 1.25rem; margin-bottom: 0.75rem; color: #7c6fff; }
.concept-card h3 { font-size: 0.9rem; font-weight: 600; line-height: 1.4; margin-bottom: 0.75rem; }
.concept-card p { font-size: 0.8rem; color: #aeacaa; line-height: 1.75; margin-bottom: 1rem; font-weight: 300; }
.concept-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.concept-tags span { font-family: 'Space Mono', monospace; font-size: 0.6rem; color: #9a9895; border: 1px solid #1f1f24; padding: 0.2rem 0.6rem; border-radius: 3px; }

.how-i-think { }
.think-lead { font-size: 1.1rem; font-weight: 400; color: #d0cecc; margin-bottom: 2rem; max-width: 520px; }
.think-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-bottom: 2.5rem; }
.think-pillar { border-left: 2px solid #7c6fff33; padding-left: 1.25rem; }
.pillar-label { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.5rem; }
.think-pillar p { font-size: 0.85rem; color: #9a9895; line-height: 1.7; font-weight: 300; }
.think-closing { font-size: 0.95rem; color: #848280; font-style: italic; border-top: 1px solid #1f1f24; padding-top: 1.5rem; }

/* Thinking & Insights page */
.thinking-page { max-width: 960px; }
.thinking-intro { font-size: 0.95rem; color: #aeacaa; font-weight: 300; max-width: 560px; margin-top: 1rem; line-height: 1.8; font-style: italic; }
.thinking-section { margin-bottom: 3rem; }
.thinking-section-label { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 1rem; }
.thinking-lead { font-size: 1rem; color: #d0cecc; font-weight: 300; max-width: 600px; line-height: 1.8; margin-bottom: 1.5rem; }
.thinking-divider { height: 1px; background: #1f1f24; margin-bottom: 3rem; }
.thinking-wide { }

.principles-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
.principle { display: flex; align-items: flex-start; gap: 1rem; background: #111115; border: 1px solid #1f1f24; border-radius: 8px; padding: 1.1rem 1.25rem; }
.principle-num { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #7c6fff; padding-top: 0.15rem; flex-shrink: 0; }
.principle p { font-size: 0.875rem; color: #c4c2be; font-weight: 300; line-height: 1.6; }

.thinking-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-bottom: 3rem; }
.thinking-framework { background: #111115; border: 1px solid #1f1f24; border-radius: 12px; padding: 1.75rem; }
.framework-subtitle { font-size: 0.8rem; color: #9a9895; margin-bottom: 1rem; font-style: italic; }
.framework-body { font-size: 0.875rem; color: #c4c2be; font-weight: 300; line-height: 1.8; margin-bottom: 1.25rem; }
.framework-body em { color: #d0cecc; font-style: italic; }
.framework-callout { background: #0d0d0f; border-left: 2px solid #7c6fff33; border-radius: 0 6px 6px 0; padding: 1rem 1.25rem; margin-bottom: 1.25rem; }
.framework-callout p { font-size: 0.8rem; color: #aeacaa; margin-bottom: 0.5rem; }
.framework-callout ul { list-style: none; padding: 0; }
.framework-callout ul li { font-size: 0.8rem; color: #aeacaa; padding: 0.2rem 0; font-style: italic; }
.framework-callout ul li::before { content: '— '; color: #7c6fff44; }
.framework-close { font-size: 0.8rem; color: #9a9895; font-style: italic; line-height: 1.7; }

.hypothesis-steps { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.25rem; }
.h-step { display: flex; align-items: center; gap: 1rem; padding: 0.6rem 0; border-bottom: 1px solid #1a1a1f; }
.h-step:last-child { border-bottom: none; }
.h-label { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #7c6fff; letter-spacing: 0.06em; text-transform: uppercase; width: 90px; flex-shrink: 0; }
.h-desc { font-size: 0.8rem; color: #aeacaa; font-style: italic; }

.ai-block { display: grid; grid-template-columns: 1fr auto; gap: 3rem; align-items: center; }
.ai-left p { font-size: 0.95rem; color: #c4c2be; font-weight: 300; line-height: 1.85; margin-bottom: 1rem; }
.ai-left p:last-child { margin-bottom: 0; }
.ai-right { border-left: 1px solid #1f1f24; padding-left: 3rem; }
.ai-quote { font-size: 1.05rem; color: #7c6fff; font-style: italic; font-weight: 300; line-height: 1.6; white-space: nowrap; }

.decision-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.decision-pillar { border-top: 2px solid #7c6fff33; padding-top: 1rem; }
.decision-pillar-title { font-size: 0.85rem; font-weight: 600; margin-bottom: 0.5rem; color: #ccc; }
.decision-pillar p { font-size: 0.8rem; color: #9a9895; line-height: 1.7; font-weight: 300; }

.thinking-reflection { }
.reflection-body { font-size: 0.95rem; color: #aeacaa; font-weight: 300; line-height: 1.9; max-width: 600px; margin-bottom: 2rem; }
.reflection-closing { font-family: 'Space Mono', monospace; font-size: 0.8rem; color: #7c6fff; letter-spacing: 0.04em; }

/* Always Learning page */
.learning-intro { max-width: 640px; margin-bottom: 3rem; }
.learning-intro-main p { font-size: 0.95rem; color: #c4c2be; font-weight: 300; line-height: 1.85; margin-bottom: 1.1rem; }
.learning-intro-main p:last-child { margin-bottom: 0; }
.learning-emphasis { font-size: 1rem; color: #ccc; font-style: italic; line-height: 1.75; border-left: 2px solid #7c6fff33; padding-left: 1.25rem; margin: 1.25rem 0 !important; }

.timeline-section { margin-bottom: 3rem; }
.timeline-header { margin-bottom: 2.5rem; }
.timeline-subhead { font-size: 0.85rem; color: #9a9895; font-style: italic; margin-top: 0.5rem; }

.timeline { display: flex; flex-direction: column; }
.timeline-item { display: grid; grid-template-columns: 200px 28px 1fr; gap: 0; min-height: 80px; }
.timeline-item--current .timeline-degree { color: #e8e6e0; }

.timeline-left { text-align: right; padding-right: 1.5rem; padding-top: 0.1rem; padding-bottom: 1.5rem; }
.timeline-years { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #7c6fff; letter-spacing: 0.05em; margin-bottom: 0.3rem; }
.timeline-narrative { font-size: 0.75rem; color: #848280; font-style: italic; }

.timeline-node { display: flex; flex-direction: column; align-items: center; }
.timeline-dot { width: 10px; height: 10px; border-radius: 50%; background: #2a2a35; border: 2px solid #7c6fff44; flex-shrink: 0; margin-top: 0.2rem; }
.timeline-dot--active { background: #7c6fff; border-color: #7c6fff; box-shadow: 0 0 10px #7c6fff55; }
.timeline-line { flex: 1; width: 1px; background: #1f1f24; margin-top: 4px; }
.timeline-item:last-child .timeline-line { display: none; }

.timeline-right { padding-left: 1.5rem; padding-bottom: 2rem; }
.timeline-degree { font-size: 0.9rem; font-weight: 500; color: #d0cecc; line-height: 1.4; margin-bottom: 0.4rem; }
.timeline-note { font-size: 0.78rem; color: #848280; font-weight: 300; line-height: 1.7; font-style: italic; }
.timeline-badge { display: inline-block; margin-top: 0.6rem; font-family: 'Space Mono', monospace; font-size: 0.6rem; color: #7c6fff; border: 1px solid #7c6fff44; padding: 0.2rem 0.6rem; border-radius: 3px; letter-spacing: 0.06em; text-transform: uppercase; }

.learning-meaning { margin-bottom: 3rem; }
.learning-meaning-lead { font-size: 0.95rem; color: #c4c2be; font-weight: 300; margin-bottom: 1.5rem; }
.learning-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 1.75rem; }
.learning-pillar { background: #111115; border: 1px solid #1f1f24; border-radius: 8px; padding: 1.25rem; }
.learning-pillar-title { font-size: 0.85rem; font-weight: 600; color: #ccc; margin-bottom: 0.5rem; }
.learning-pillar p { font-size: 0.8rem; color: #9a9895; line-height: 1.75; font-weight: 300; }
.learning-meaning-close { font-size: 0.9rem; color: #9a9895; font-style: italic; line-height: 1.8; }
.learning-meaning-close em { color: #7c6fff; font-style: normal; }

.learning-shift { margin-bottom: 3rem; }
.shift-flow { display: flex; flex-direction: column; gap: 0.75rem; max-width: 600px; margin-top: 1.25rem; }
.shift-item { display: grid; grid-template-columns: 1fr 32px 1fr; align-items: center; gap: 0.5rem; background: #111115; border: 1px solid #1f1f24; border-radius: 8px; padding: 0.9rem 1.25rem; }
.shift-from { font-size: 0.8rem; color: #848280; font-weight: 300; }
.shift-arrow { font-family: 'Space Mono', monospace; color: #7c6fff44; text-align: center; font-size: 0.85rem; }
.shift-to { font-size: 0.85rem; color: #d0cecc; font-weight: 500; }

/* Now page */
.now-updated { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #848280; margin-top: 0.5rem; }
.now-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.now-card { background: #111115; border: 1px solid #1f1f24; border-radius: 10px; padding: 1.5rem; }
.now-card-label { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #7c6fff; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 0.75rem; }
.now-card p { font-size: 0.875rem; color: #aeacaa; font-weight: 300; line-height: 1.8; }
.now-closing { font-size: 0.85rem; color: #6e6e78; font-style: italic; margin-top: 2.5rem; border-top: 1px solid #1f1f24; padding-top: 1.5rem; }

/* Connect page */
.connect-intro { font-size: 0.95rem; color: #aeacaa; font-weight: 300; max-width: 520px; margin-top: 1rem; line-height: 1.85; }
.connect-links { display: flex; flex-direction: column; gap: 0.75rem; margin: 2.5rem 0; max-width: 560px; }
.connect-card { display: flex; align-items: center; gap: 1.25rem; background: #111115; border: 1px solid #1f1f24; border-radius: 10px; padding: 1.25rem 1.5rem; text-decoration: none; transition: border-color 0.2s; color: #e8e6e0; }
.connect-card:hover { border-color: #7c6fff44; }
.connect-card-icon { color: #7c6fff; flex-shrink: 0; }
.connect-card-title { font-size: 0.9rem; font-weight: 600; margin-bottom: 0.15rem; }
.connect-card-sub { font-size: 0.75rem; color: #9a9895; }
.connect-card-arrow { margin-left: auto; color: #333; font-size: 1rem; transition: color 0.2s; }
.connect-card:hover .connect-card-arrow { color: #7c6fff; }
.connect-note { font-size: 0.8rem; color: #6e6e78; font-style: italic; max-width: 420px; line-height: 1.8; }

/* Page closing line */
.page-closing { font-size: 0.9rem; color: #6e6e78; font-style: italic; margin-top: 3rem; border-top: 1px solid #1f1f24; padding-top: 1.5rem; line-height: 1.7; }

/* Exploring page extras */
.explore-list { list-style: none; padding: 0; margin: 0.75rem 0; }
.explore-list li { font-size: 0.8rem; color: #9a9895; padding: 0.25rem 0; font-weight: 300; line-height: 1.6; }
.explore-list li::before { content: '— '; color: #7c6fff44; }
.concept-closing { font-size: 0.78rem; color: #9a9895; font-style: italic; margin-top: 0.75rem; line-height: 1.6; }

/* Lens page */
.lens-page { max-width: 900px; }
.lens-opening { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.lens-opening-main p { font-size: 0.95rem; color: #c4c2be; font-weight: 300; line-height: 1.85; margin-bottom: 1rem; }
.lens-opening-main p:last-child { margin-bottom: 0; }
.lens-opening-aside { border-left: 1px solid #1f1f24; padding-left: 3rem; display: flex; align-items: center; }
.lens-pause { font-size: 1rem; color: #848280; font-style: italic; line-height: 2; font-weight: 300; }

.lens-themes-section { margin-bottom: 1.5rem; }
.lens-themes { display: flex; gap: 1rem; margin-top: 1rem; }
.lens-theme { background: #111115; border: 1px solid #1f1f24; border-radius: 8px; padding: 1rem 1.5rem; text-align: center; flex: 1; }
.lens-theme-icon { font-size: 1.25rem; margin-bottom: 0.4rem; }
.lens-theme-label { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #9a9895; letter-spacing: 0.06em; text-transform: uppercase; }

.lens-reflection-block { max-width: 640px; margin-bottom: 0.5rem; }
.lens-reflection-text p { font-size: 0.9rem; color: #9a9895; font-weight: 300; line-height: 1.9; margin-bottom: 1rem; font-style: italic; }
.lens-reflection-text p:last-child { margin-bottom: 0; }
.lens-page-closing { font-size: 0.95rem; }

/* Hero tags */
.hero-tags { display: flex; gap: 0.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.hero-tags span { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #7c6fff; border: 1px solid #7c6fff33; padding: 0.25rem 0.75rem; border-radius: 3px; letter-spacing: 0.04em; }

/* Photography page */
.photo-strip { display: flex; gap: 0.75rem; overflow-x: auto; padding-bottom: 0.5rem; }
.photo-strip .photo { flex: 0 0 200px; height: 140px; border-radius: 8px; background: linear-gradient(135deg, #1a1a22, #12121a); border: 1px solid #1f1f24; display: flex; align-items: center; justify-content: center; font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #333; }
.photo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; }
.photo-grid .photo-cell { aspect-ratio: 4/3; border-radius: 8px; background: linear-gradient(135deg, #1a1a22, #12121a); border: 1px solid #1f1f24; display: flex; align-items: flex-end; padding: 0.75rem; font-family: 'Space Mono', monospace; font-size: 0.65rem; color: #848280; overflow: hidden; position: relative; }
.photo-cell--image { padding: 0; cursor: zoom-in; }
.photo-cell--image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 8px; transition: transform 0.3s ease, filter 0.3s ease; }
.photo-cell--image:hover img { transform: scale(1.04); filter: brightness(1.08); }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.25s ease; padding: 0 4rem; }
.lightbox.is-open { opacity: 1; pointer-events: all; }
.lightbox-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.92); }
.lightbox-content { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 1rem; max-width: 90vw; max-height: 90vh; transform: scale(0.92); transition: transform 0.25s ease; }
.lightbox.is-open .lightbox-content { transform: scale(1); }
.lightbox-img { max-width: 90vw; max-height: 82vh; object-fit: contain; border-radius: 6px; box-shadow: 0 30px 80px rgba(0,0,0,0.6); }
.lightbox-caption { font-family: 'Space Mono', monospace; font-size: 0.7rem; color: #9a9895; letter-spacing: 0.06em; text-transform: uppercase; }
.lightbox-close { position: fixed; top: 1.5rem; right: 1.5rem; z-index: 2; background: none; border: 1px solid #333; color: #9a9895; width: 36px; height: 36px; border-radius: 50%; font-size: 0.8rem; cursor: pointer; transition: all 0.2s; display: flex; align-items: center; justify-content: center; }
.lightbox-close:hover { border-color: #7c6fff; color: #e8e6e0; }
.lightbox-nav { position: fixed; top: 50%; transform: translateY(-50%); z-index: 2; background: rgba(20,20,24,0.85); border: 1px solid rgba(255,255,255,0.15); color: #e8e6e0; width: 48px; height: 48px; border-radius: 50%; font-size: 1.2rem; cursor: pointer; transition: all 0.2s; display: flex; align-items: center; justify-content: center; }
.lightbox-prev { left: 1.5rem; }
.lightbox-next { right: 1.5rem; }
.lightbox-nav:hover { background: rgba(124,111,255,0.4); border-color: #7c6fff; color: #fff; }
