:root { --bg: #fff; --card: #fff; --ink: #171717; --muted: #5d625f; --line: rgba(23, 23, 23, 0.14); --accent: #166f54; --accent-soft: #e9f5f1; --shadow: 0 16px 38px rgba(25, 31, 28, 0.08); }
* { box-sizing: border-box; }
body { margin: 0; min-height: 100vh; font-family: "Trebuchet MS", "Segoe UI", Tahoma, sans-serif; color: var(--ink); background: #fff; }
a { color: inherit; }
.topbar { background: rgba(255,255,255,.86); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 10; backdrop-filter: blur(12px); }
.topbar-inner { width: min(1120px, calc(100vw - 2rem)); margin: 0 auto; min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.topbar-home { display: inline-flex; align-items: center; gap: .75rem; text-decoration: none; min-width: 0; }
.topbar-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.topbar-copy { display: grid; gap: .18rem; }
.topbar-name { font-weight: 900; }
.topbar-tagline { color: var(--muted); font-size: .86rem; }
.topbar-links, .actions, .article-actions { display: flex; align-items: center; gap: .65rem; flex-wrap: wrap; }
.topbar-link, .button { display: inline-flex; align-items: center; justify-content: center; min-height: 40px; padding: .62rem .9rem; border: 1px solid var(--line); border-radius: 999px; background: #fff; text-decoration: none; font-weight: 800; }
.topbar-link:hover, .button:hover { border-color: rgba(22,111,84,.36); background: var(--accent-soft); }
.button.primary { background: var(--ink); color: #fff; border-color: var(--ink); }
.wrap, .article-wrap { width: min(1080px, calc(100vw - 2rem)); margin: 0 auto; padding: 2.5rem 0 4rem; }
.hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(16rem, .36fr); gap: 1.4rem; align-items: stretch; margin-bottom: 1.4rem; }
.hero-copy, .hero-panel, .article-card, .article-row, .about-ricky { border: 1px solid var(--line); border-radius: 12px; background: var(--card); box-shadow: var(--shadow); }
.hero-copy { padding: clamp(1.4rem, 4vw, 3rem); }
.hero-panel { padding: 1.2rem; display: grid; align-content: center; gap: .7rem; }
.eyebrow, .impact { margin: 0 0 .65rem; color: var(--accent); text-transform: uppercase; letter-spacing: .1em; font-size: .74rem; font-weight: 900; }
h1 { margin: 0; font-size: clamp(2.35rem, 5.8vw, 5rem); line-height: .96; letter-spacing: 0; }
.lede, .subtitle { color: var(--muted); font-size: 1.12rem; line-height: 1.65; max-width: 48rem; }
.actions { margin-top: 1.2rem; }
.article-list { display: grid; gap: 1rem; }
.article-row { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: 1rem; padding: 1rem; align-items: center; text-decoration: none; transition: transform 120ms ease, border-color 120ms ease; }
.rank { width: 2.45rem; height: 2.45rem; border-radius: 50%; display: grid; place-items: center; background: var(--ink); color: #fff; font-weight: 900; }
.article-row h2 { margin: 0; font-size: 1.28rem; }
.article-row p { margin: .35rem 0 0; color: var(--muted); line-height: 1.5; }
.article-row:hover { border-color: rgba(22,111,84,.36); transform: translateY(-1px); }
.article-card { width: min(820px, 100%); margin: 0 auto; padding: clamp(1.25rem, 4vw, 3rem); }
.crumbs { display: flex; gap: .5rem; flex-wrap: wrap; color: var(--muted); margin-bottom: 1.4rem; }
.crumbs a { text-decoration: none; font-weight: 800; }
.article-body { margin-top: 2rem; }
.article-body p, .article-body li, .about-ricky p { font-size: 1.08rem; line-height: 1.78; }
.article-body p, .about-ricky p { margin: 0 0 1.15rem; }
.article-body h1, .article-body h2, .article-body h3 { line-height: 1.16; letter-spacing: 0; }
.article-body h1 { margin: 2.4rem 0 .9rem; font-size: clamp(2rem, 5vw, 3.2rem); }
.article-body h2 { margin: 2rem 0 .7rem; font-size: 1.45rem; }
.article-body h3 { margin: 1.55rem 0 .55rem; font-size: 1.15rem; }
.article-body ul, .article-body ol { margin: 0 0 1.3rem 1.35rem; padding: 0; }
.article-body li { margin: 0 0 .55rem; padding-left: .25rem; }
.article-body strong, .article-body b { font-weight: 900; }
.article-body em, .article-body i { font-style: italic; }
.article-body blockquote { margin: 1.6rem 0; padding: .1rem 0 .1rem 1.2rem; border-left: 4px solid var(--accent); color: #303734; }
.article-body blockquote p { font-size: 1.18rem; line-height: 1.7; }
.article-actions { margin-top: 2.2rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }
.about-ricky { width: min(820px, 100%); margin: 1.2rem auto 0; padding: clamp(1.2rem, 3vw, 2rem); }
.about-ricky h2 { margin: 0 0 .75rem; font-size: clamp(1.45rem, 3vw, 2rem); line-height: 1.18; }
.about-ricky p:last-child { margin-bottom: 0; }
.about-ricky summary { display: inline-flex; cursor: pointer; color: var(--accent); font-weight: 900; }
.about-ricky summary::-webkit-details-marker { display: none; }
.about-ricky details[open] summary { display: none; }
.about-ricky-more { margin-top: 1rem; }
.site-footer-links { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: .35rem; width: min(1080px, calc(100vw - 2rem)); margin: 0 auto; padding: 0 0 4rem; line-height: 1.75; text-align: center; color: inherit; font-size: .74rem; letter-spacing: 0; }
.site-footer-links a { color: inherit; text-decoration: none; }
.site-footer-links a:hover, .site-footer-links a:focus-visible { text-decoration: underline; text-underline-offset: .18em; }
.site-footer-links a, .site-footer-links span { display: inline; }
@media (max-width: 760px) { .topbar-inner, .hero, .article-row { grid-template-columns: 1fr; flex-direction: column; align-items: flex-start; } .topbar-inner { padding: .75rem 0; } .topbar-links, .topbar-link, .button { width: 100%; } .article-row { align-items: start; } }
