/* Shared layout for Idle landing pages. Loaded by index.html, install.html,
   privacy.html, terms.html. Single source of truth for tokens. */
:root {
    --bg: #0a0a0a;
    --panel: #141414;
    --border: rgba(255,255,255,0.08);
    --fg: #fafafa;
    --mute: #a3a3a3;
    --accent: #34d399;
    --warn: #f59e0b;
    --danger: #ef4444;
}
* { box-sizing: border-box; }
body {
    background: var(--bg);
    color: var(--fg);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Inter", system-ui, sans-serif;
    margin: 0;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,0.2); }
a:hover { color: var(--accent); text-decoration-color: var(--accent); }
.wrap { max-width: 760px; margin: 0 auto; padding: 0 24px; }
.wrap.wide { max-width: 980px; }
nav { padding: 24px 0; display: flex; align-items: center; justify-content: space-between; }
nav .brand { display: flex; align-items: center; gap: 8px; font-weight: 600; text-decoration: none; }
nav .brand .leaf { color: var(--accent); }
nav ul { display: flex; gap: 28px; list-style: none; padding: 0; margin: 0; color: var(--mute); }
nav ul a { text-decoration: none; }

article { padding: 24px 0 80px; }
article h1 { font-size: 40px; letter-spacing: -0.01em; margin: 0 0 8px; }
article .updated { color: var(--mute); font-size: 14px; margin: 0 0 32px; }
article h2 { font-size: 22px; margin: 32px 0 12px; }
article h3 { font-size: 17px; margin: 24px 0 8px; }
article p, article li { color: var(--mute); }
article strong { color: var(--fg); }
article code {
    background: var(--panel); padding: 2px 6px; border-radius: 4px;
    font-family: "SF Mono", Menlo, Consolas, monospace; font-size: 0.9em;
}
article pre {
    background: var(--panel); padding: 16px; border-radius: 8px;
    border: 1px solid var(--border); overflow-x: auto;
}
article ul, article ol { padding-left: 22px; }

footer {
    border-top: 1px solid var(--border); padding: 36px 0 80px;
    color: var(--mute); font-size: 14px;
    display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
footer ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; }
footer a { text-decoration: none; }
