@font-face { font-family: 'Geist'; font-style: normal; font-weight: 400; font-display: swap; src: url('/assets/fonts/geist/400.woff2') format('woff2'); } @font-face { font-family: 'Geist'; font-style: normal; font-weight: 500; font-display: swap; src: url('/assets/fonts/geist/500.woff2') format('woff2'); } @font-face { font-family: 'Geist'; font-style: normal; font-weight: 700; font-display: swap; src: url('/assets/fonts/geist/700.woff2') format('woff2'); } @font-face { font-family: 'Geist'; font-style: normal; font-weight: 900; font-display: swap; src: url('/assets/fonts/geist/900.woff2') format('woff2'); } @font-face { font-family: 'Fraunces'; font-style: normal; font-weight: 100 900; font-display: swap; src: url('/assets/fonts/fraunces/400.woff2') format('woff2-variations'), url('/assets/fonts/fraunces/400.woff2') format('woff2'); } @font-face { font-family: 'Fraunces'; font-style: italic; font-weight: 100 900; font-display: swap; src: url('/assets/fonts/fraunces/400-italic.woff2') format('woff2-variations'), url('/assets/fonts/fraunces/400-italic.woff2') format('woff2'); } :root { --bg: #f6f5f1; --surface: #ffffff; --surface-2: #faf9f5; --fg: #1b1a17; --muted: #6f6e67; --rule: #e4e2db; --rule-strong: #d6d3ca; --accent: #157068; --accent-fg: #ffffff; --shadow-sm: 0 1px 2px rgba(20, 19, 15, 0.04), 0 1px 1px rgba(20, 19, 15, 0.03); --shadow-md: 0 18px 40px -18px rgba(20, 19, 15, 0.22), 0 6px 14px -10px rgba(20, 19, 15, 0.14); --radius: 16px; --radius-sm: 10px; --font-display: 'Fraunces', Georgia, 'Times New Roman', serif; --font-body: 'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; --content-width: 680px; --shell-width: 1180px; } @media (prefers-color-scheme: dark) { :root { --bg: #15161a; --surface: #1d1e23; --surface-2: #212329; --fg: #ecebe4; --muted: #9b9a92; --rule: #2e2f35; --rule-strong: #3a3c43; --accent: color-mix(in oklab, #157068 62%, white); --accent-fg: #15161a; --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4); --shadow-md: 0 22px 48px -20px rgba(0, 0, 0, 0.7), 0 8px 18px -12px rgba(0, 0, 0, 0.5); } } * { box-sizing: border-box; } html { background: var(--bg); color: var(--fg); font-family: var(--font-body); font-size: 17px; line-height: 1.65; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; } body.w-25c { margin: 0; min-height: 100vh; display: flex; flex-direction: column; } img { max-width: 100%; height: auto; display: block; } a { color: inherit; } ::selection { background: var(--accent); color: var(--accent-fg); } .atlas-topbar { height: 3px; width: 100%; background: linear-gradient(90deg, var(--accent), color-mix(in oklab, var(--accent) 55%, transparent)); } .t-aef { width: 100%; max-width: var(--shell-width); margin: 0 auto; padding-left: clamp(1.25rem, 4vw, 2.5rem); padding-right: clamp(1.25rem, 4vw, 2.5rem); } .atlas-header { position: sticky; top: 0; z-index: 20; background: color-mix(in oklab, var(--bg) 86%, transparent); -webkit-backdrop-filter: saturate(180%) blur(12px); backdrop-filter: saturate(180%) blur(12px); border-bottom: 1px solid var(--rule); } .atlas-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; min-height: 68px; } .atlas-brand { font-family: var(--font-display); font-weight: 500; font-size: 1.4rem; letter-spacing: -0.01em; text-decoration: none; color: var(--fg); white-space: nowrap; } .atlas-nav .atlas-menu { display: flex; flex-wrap: wrap; align-items: center; gap: clamp(1rem, 2.4vw, 2rem); margin: 0; padding: 0; list-style: none; } .atlas-menu a { position: relative; font-size: 0.95rem; font-weight: 500; color: var(--muted); text-decoration: none; padding: 0.35rem 0; transition: color 0.18s ease; } .atlas-menu a::after { content: ''; position: absolute; left: 0; bottom: 0; height: 2px; width: 0; background: var(--accent); transition: width 0.22s cubic-bezier(0.2, 0.7, 0.2, 1); } .atlas-menu a:hover { color: var(--fg); } .atlas-menu a:hover::after { width: 100%; } .atlas-main { flex: 1 1 auto; width: 100%; } .atlas-kicker { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin: 0 0 0.85rem; } .atlas-kicker--accent { color: var(--accent); } .atlas-byline { display: flex; align-items: center; gap: 0.5rem; font-size: 0.85rem; color: var(--muted); margin: 0; } .atlas-dot { opacity: 0.6; } .atlas-arrow { margin-left: auto; font-size: 1rem; color: var(--accent); transition: transform 0.22s cubic-bezier(0.2, 0.7, 0.2, 1); } .atlas-index { padding-top: clamp(2.5rem, 6vw, 5rem); padding-bottom: clamp(3rem, 7vw, 6rem); } .atlas-index-head { max-width: 760px; margin: 0 0 clamp(2.5rem, 5vw, 4rem); } .atlas-index-title { font-family: var(--font-display); font-weight: 400; font-size: clamp(2rem, 5.2vw, 3.4rem); line-height: 1.06; letter-spacing: -0.02em; margin: 0; color: var(--fg); text-wrap: balance; } .atlas-feature { display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(1.5rem, 3.5vw, 3rem); align-items: center; text-decoration: none; color: inherit; padding-bottom: clamp(2.5rem, 5vw, 4rem); margin-bottom: clamp(2.5rem, 5vw, 4rem); border-bottom: 1px solid var(--rule); } .atlas-feature-photo { margin: 0; border-radius: var(--radius); overflow: hidden; aspect-ratio: 16 / 10; background: var(--surface-2); box-shadow: var(--shadow-sm); } .atlas-feature-photo img, .atlas-feature-photo svg { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s cubic-bezier(0.2, 0.7, 0.2, 1); } .atlas-feature:hover .atlas-feature-photo img, .atlas-feature:hover .atlas-feature-photo svg { transform: scale(1.04); } .atlas-feature-title { font-family: var(--font-display); font-weight: 400; font-size: clamp(1.6rem, 3.2vw, 2.6rem); line-height: 1.1; letter-spacing: -0.018em; margin: 0 0 0.9rem; color: var(--fg); text-wrap: balance; } .atlas-feature-dek { font-size: 1.05rem; line-height: 1.6; color: var(--muted); margin: 0 0 1.4rem; max-width: 46ch; } .atlas-feature:hover .atlas-arrow { transform: translateX(5px); } .atlas-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: clamp(1.5rem, 2.6vw, 2.25rem); margin: 0; padding: 0; list-style: none; } .atlas-card { background: var(--surface); border: 1px solid var(--rule); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform 0.24s cubic-bezier(0.2, 0.7, 0.2, 1), box-shadow 0.24s ease, border-color 0.24s ease; } .atlas-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--rule-strong); } .atlas-card-link { text-decoration: none; color: inherit; display: block; } .atlas-card-photo { margin: 0; aspect-ratio: 16 / 9; overflow: hidden; background: var(--surface-2); } .atlas-card-photo img, .atlas-card-photo svg { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s cubic-bezier(0.2, 0.7, 0.2, 1); } .atlas-card:hover .atlas-card-photo img, .atlas-card:hover .atlas-card-photo svg { transform: scale(1.05); } .atlas-card-body { padding: 1.35rem 1.4rem 1.25rem; } .atlas-card-title { font-family: var(--font-display); font-weight: 400; font-size: 1.3rem; line-height: 1.18; letter-spacing: -0.012em; margin: 0 0 0.55rem; color: var(--fg); } .atlas-card-dek { font-size: 0.94rem; line-height: 1.55; color: var(--muted); margin: 0 0 1.1rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } .atlas-card:hover .atlas-arrow { transform: translateX(5px); } .atlas-aside { margin-top: clamp(3rem, 6vw, 5rem); padding-top: 2rem; border-top: 1px solid var(--rule); } .atlas-aside-list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 0.6rem 1.6rem; } .atlas-aside-list a { font-size: 0.95rem; color: var(--muted); text-decoration: none; border-bottom: 1px solid transparent; transition: color 0.18s ease, border-color 0.18s ease; } .atlas-aside-list a:hover { color: var(--accent); border-color: var(--accent); } .atlas-read { max-width: var(--content-width); padding-top: clamp(2.5rem, 5vw, 4.5rem); padding-bottom: clamp(3rem, 6vw, 5.5rem); } .atlas-read-head { margin-bottom: 2rem; } .atlas-read-title { font-family: var(--font-display); font-weight: 400; font-size: clamp(2rem, 5vw, 3.1rem); line-height: 1.07; letter-spacing: -0.022em; margin: 0; color: var(--fg); text-wrap: balance; } .atlas-lead { font-size: 1.2rem; line-height: 1.55; color: var(--muted); margin: 1.1rem 0 0; } .atlas-byline--read { margin-top: 1.4rem; padding-top: 1.2rem; border-top: 1px solid var(--rule); font-size: 0.82rem; letter-spacing: 0.04em; } .atlas-read-photo { margin: 2.25rem 0; border-radius: var(--radius); overflow: hidden; background: var(--surface-2); box-shadow: var(--shadow-sm); } .atlas-read-photo img { width: 100%; } .atlas-prose { font-size: 1.0625rem; line-height: 1.78; color: var(--fg); } .atlas-prose > p:first-of-type::first-letter { font-family: var(--font-display); font-weight: 400; font-size: 3.4em; line-height: 0.82; float: left; margin: 0.08em 0.12em 0 0; color: var(--accent); } .atlas-prose p { margin: 0 0 1.4rem; } .atlas-prose h2 { font-family: var(--font-display); font-weight: 400; font-size: 1.7rem; line-height: 1.18; letter-spacing: -0.015em; margin: 2.6rem 0 1rem; color: var(--fg); } .atlas-prose h3 { font-weight: 700; font-size: 1.22rem; letter-spacing: -0.005em; margin: 2rem 0 0.8rem; color: var(--fg); } .atlas-prose a { color: var(--fg); text-decoration: none; background-image: linear-gradient(var(--accent), var(--accent)); background-position: 0 100%; background-repeat: no-repeat; background-size: 100% 1px; padding-bottom: 1px; transition: background-size 0.2s ease, color 0.2s ease; } .atlas-prose a:hover { color: var(--accent); background-size: 100% 2px; } .atlas-prose ul, .atlas-prose ol { margin: 0 0 1.4rem; padding-left: 1.4rem; } .atlas-prose li { margin: 0.4rem 0; } .atlas-prose li::marker { color: var(--accent); } .atlas-prose blockquote { margin: 1.8rem 0; padding: 0.4rem 0 0.4rem 1.4rem; border-left: 3px solid var(--accent); font-family: var(--font-display); font-style: italic; font-size: 1.22rem; line-height: 1.5; color: var(--fg); } .atlas-prose img { border-radius: var(--radius-sm); margin: 1.8rem 0; } .atlas-prose code { font-family: ui-monospace, 'JetBrains Mono', Menlo, Consolas, monospace; font-size: 0.88em; background: var(--surface-2); border: 1px solid var(--rule); border-radius: 5px; padding: 0.1em 0.4em; } .atlas-prose pre { background: var(--surface-2); border: 1px solid var(--rule); border-radius: var(--radius-sm); padding: 1.1rem 1.25rem; overflow-x: auto; margin: 1.6rem 0; } .atlas-prose pre code { background: none; border: 0; padding: 0; } .atlas-prose hr { border: 0; width: 56px; height: 3px; background: var(--accent); margin: 2.6rem 0; border-radius: 2px; } .atlas-prose table { width: 100%; border-collapse: collapse; margin: 1.6rem 0; font-size: 0.95rem; } .atlas-prose th, .atlas-prose td { text-align: left; padding: 0.6rem 0.8rem; border-bottom: 1px solid var(--rule); } .atlas-prose th { font-weight: 600; } .atlas-footer { border-top: 1px solid var(--rule); margin-top: auto; padding: clamp(2.25rem, 4vw, 3.25rem) 0; } .atlas-footer-inner { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 1.75rem; } .atlas-brand--sm { font-size: 1.1rem; text-decoration: none; color: var(--fg); } .atlas-footer-menu { display: flex; flex-wrap: wrap; gap: 0.6rem 1.4rem; margin: 0; padding: 0; list-style: none; } .atlas-footer-menu a { font-size: 0.92rem; color: var(--muted); text-decoration: none; transition: color 0.18s ease; } .atlas-footer-menu a:hover { color: var(--accent); } .atlas-colophon { margin: 0; margin-left: auto; font-size: 0.85rem; color: var(--muted); } @media (prefers-reduced-motion: no-preference) { .atlas-feature, .atlas-card { animation: atlas-rise 0.6s cubic-bezier(0.2, 0.7, 0.2, 1) both; } .atlas-card:nth-child(1) { animation-delay: 0.04s; } .atlas-card:nth-child(2) { animation-delay: 0.09s; } .atlas-card:nth-child(3) { animation-delay: 0.14s; } .atlas-card:nth-child(4) { animation-delay: 0.19s; } .atlas-card:nth-child(5) { animation-delay: 0.24s; } .atlas-card:nth-child(6) { animation-delay: 0.29s; } } @keyframes atlas-rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } } @media (max-width: 880px) { .atlas-feature { grid-template-columns: 1fr; gap: 1.4rem; } .atlas-feature-photo { aspect-ratio: 16 / 9; } } @media (max-width: 560px) { html { font-size: 16px; } .atlas-header-inner { min-height: 60px; gap: 1rem; } .atlas-nav .atlas-menu { gap: 0.9rem; } .atlas-grid { grid-template-columns: 1fr; } .atlas-colophon { margin-left: 0; width: 100%; } }