/* smoriy.info — encyclopedia/reference clean theme */
* { box-sizing: border-box; }
:root {
  --bg: #f9f9f7;
  --paper: #ffffff;
  --ink: #202122;
  --muted: #54595d;
  --accent: #36c;
  --accent2: #1d6dcc;
  --line: #c8ccd1;
  --hover: #f8f9fa;
}
html, body { margin: 0; padding: 0; }
body { font-family: 'Linux Libertine', 'Georgia', serif; background: var(--bg); color: var(--ink); line-height: 1.6; font-size: 16px; }
.wrap { max-width: 760px; margin: 0 auto; padding: 0 24px; }
.topbar { background: var(--paper); border-bottom: 1px solid var(--line); padding: 16px 0; }
.topbar .wrap { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.logo { font-family: 'Linux Libertine', Georgia, serif; font-weight: 700; font-size: 22px; color: var(--ink); text-decoration: none; }
.logo:after { content: '.info'; color: var(--muted); font-weight: 400; font-size: 16px; }
nav a { color: var(--accent); text-decoration: none; margin-left: 16px; font-size: 14px; }
nav a:hover { text-decoration: underline; }
main { padding: 28px 0 60px; }
article h1 { font-family: 'Linux Libertine', Georgia, serif; font-weight: 400; font-size: 32px; line-height: 1.25; margin: 0 0 8px; border-bottom: 3px solid var(--line); padding-bottom: 12px; }
article h2 { font-size: 22px; margin-top: 32px; margin-bottom: 12px; font-weight: 400; border-bottom: 1px solid var(--line); padding-bottom: 6px; }
article h3 { font-size: 18px; margin-top: 24px; font-weight: 700; }
.meta { color: var(--muted); font-size: 13px; margin-bottom: 22px; font-style: italic; }
.lead { font-size: 17px; margin: 0 0 22px; }
article p { margin: 14px 0; }
article a { color: var(--accent); }
article a:hover { text-decoration: underline; }
article ul, article ol { padding-left: 22px; }
article li { margin: 4px 0; }
.infobox { background: var(--paper); border: 1px solid var(--line); padding: 14px 18px; margin: 22px 0; font-size: 14px; }
.infobox h3 { margin-top: 0; font-size: 15px; }
.cta { background: var(--paper); border: 2px solid var(--accent); padding: 22px 24px; margin: 30px 0; }
.cta h3 { margin-top: 0; }
.btn { display: inline-block; background: var(--accent); color: #fff !important; font-weight: 600; padding: 10px 22px; text-decoration: none !important; margin-top: 6px; border-radius: 2px; }
.btn:hover { background: var(--accent2); }
.small { font-size: 13px; color: var(--muted); margin-top: 8px; }
table { width: 100%; border-collapse: collapse; margin: 20px 0; font-size: 14px; }
th, td { padding: 8px 10px; text-align: left; border: 1px solid var(--line); vertical-align: top; }
th { background: var(--hover); font-weight: 700; }
.notice { background: #fff8e6; border-left: 4px solid #f4c430; padding: 12px 18px; margin: 22px 0; font-size: 14px; }
footer { background: var(--paper); border-top: 1px solid var(--line); padding: 22px 0; margin-top: 50px; color: var(--muted); font-size: 13px; }
footer a { color: var(--accent); }
@media (max-width: 600px) { article h1 { font-size: 24px; } }
