@@ -2,20 +2,26 @@ |
| 2 | 2 | /* |
| 3 | 3 | * shithub — base styles. |
| 4 | 4 | * |
| 5 | | - * S00 ships a tiny stylesheet sufficient for the hello page across light / |
| 6 | | - * dark / auto / high-contrast themes. S02 introduces the full theme system |
| 7 | | - * via Primer primitives; this file becomes one layer in a stack. |
| 5 | + * S02 layers our own chrome over the Primer CSS that ships in |
| 6 | + * /static/primer/primer.css. We pull a small set of token overrides so the |
| 7 | + * theme system (light / dark / auto / high-contrast) drives everything via |
| 8 | + * CSS custom properties. |
| 8 | 9 | * |
| 9 | | - * Color tokens follow Primer's naming so the migration in S02 is mechanical. |
| 10 | + * Color tokens follow Primer's naming so most of these become migration |
| 11 | + * candidates as Primer's primitives stabilize. |
| 10 | 12 | */ |
| 11 | 13 | |
| 12 | 14 | :root { |
| 13 | 15 | --canvas-default: #ffffff; |
| 14 | 16 | --canvas-subtle: #f6f8fa; |
| 17 | + --canvas-inset: #eaeef2; |
| 15 | 18 | --fg-default: #1f2328; |
| 16 | 19 | --fg-muted: #59636e; |
| 17 | 20 | --border-default: #d0d7de; |
| 21 | + --border-muted: #d8dee4; |
| 18 | 22 | --accent-fg: #0969da; |
| 23 | + --accent-emphasis: #0969da; |
| 24 | + --success-fg: #1a7f37; |
| 19 | 25 | --danger-fg: #cf222e; |
| 20 | 26 | --shithub-mark: var(--danger-fg); |
| 21 | 27 | } |
@@ -23,26 +29,32 @@ |
| 23 | 29 | [data-theme="dark"] { |
| 24 | 30 | --canvas-default: #0d1117; |
| 25 | 31 | --canvas-subtle: #161b22; |
| 32 | + --canvas-inset: #010409; |
| 26 | 33 | --fg-default: #f0f6fc; |
| 27 | 34 | --fg-muted: #9198a1; |
| 28 | 35 | --border-default: #3d444d; |
| 36 | + --border-muted: #232a33; |
| 29 | 37 | --accent-fg: #4493f8; |
| 38 | + --accent-emphasis: #1f6feb; |
| 39 | + --success-fg: #3fb950; |
| 30 | 40 | --danger-fg: #f85149; |
| 31 | 41 | } |
| 32 | 42 | |
| 33 | 43 | [data-theme="high-contrast"] { |
| 34 | 44 | --canvas-default: #000000; |
| 35 | 45 | --canvas-subtle: #0a0c10; |
| 46 | + --canvas-inset: #000000; |
| 36 | 47 | --fg-default: #ffffff; |
| 37 | 48 | --fg-muted: #d9dee3; |
| 38 | 49 | --border-default: #7a828e; |
| 50 | + --border-muted: #525964; |
| 39 | 51 | --accent-fg: #71b7ff; |
| 52 | + --accent-emphasis: #409eff; |
| 53 | + --success-fg: #4ed162; |
| 40 | 54 | --danger-fg: #ff6a69; |
| 41 | 55 | } |
| 42 | 56 | |
| 43 | | -* { |
| 44 | | - box-sizing: border-box; |
| 45 | | -} |
| 57 | +* { box-sizing: border-box; } |
| 46 | 58 | |
| 47 | 59 | html, body { |
| 48 | 60 | margin: 0; |
@@ -60,37 +72,136 @@ a { |
| 60 | 72 | } |
| 61 | 73 | a:hover { text-decoration: underline; } |
| 62 | 74 | |
| 75 | +code { |
| 76 | + font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace; |
| 77 | + font-size: 0.875em; |
| 78 | + background: var(--canvas-subtle); |
| 79 | + padding: 0.1em 0.35em; |
| 80 | + border-radius: 4px; |
| 81 | +} |
| 82 | + |
| 83 | +/* ========== Nav ========== */ |
| 84 | + |
| 85 | +.shithub-body { |
| 86 | + min-height: 100vh; |
| 87 | + display: flex; |
| 88 | + flex-direction: column; |
| 89 | +} |
| 90 | + |
| 91 | +.shithub-nav { |
| 92 | + display: flex; |
| 93 | + align-items: center; |
| 94 | + gap: 1.5rem; |
| 95 | + padding: 0.75rem 1.25rem; |
| 96 | + background: var(--canvas-subtle); |
| 97 | + border-bottom: 1px solid var(--border-default); |
| 98 | +} |
| 99 | + |
| 100 | +.shithub-nav-brand { |
| 101 | + display: flex; |
| 102 | + align-items: center; |
| 103 | + gap: 0.5rem; |
| 104 | + color: var(--fg-default); |
| 105 | + font-weight: 600; |
| 106 | + letter-spacing: -0.01em; |
| 107 | +} |
| 108 | +.shithub-nav-brand:hover { text-decoration: none; } |
| 109 | +.shithub-nav-brand svg { color: var(--shithub-mark); } |
| 110 | + |
| 111 | +.shithub-nav-links { |
| 112 | + display: flex; |
| 113 | + gap: 1rem; |
| 114 | + flex: 1; |
| 115 | +} |
| 116 | +.shithub-nav-links a { |
| 117 | + color: var(--fg-default); |
| 118 | + font-size: 0.9rem; |
| 119 | +} |
| 120 | + |
| 121 | +.shithub-nav-actions { |
| 122 | + display: flex; |
| 123 | + gap: 0.5rem; |
| 124 | +} |
| 125 | + |
| 126 | +.shithub-button { |
| 127 | + display: inline-flex; |
| 128 | + align-items: center; |
| 129 | + padding: 0.4rem 0.85rem; |
| 130 | + border-radius: 6px; |
| 131 | + font-size: 0.875rem; |
| 132 | + font-weight: 500; |
| 133 | + border: 1px solid transparent; |
| 134 | + cursor: pointer; |
| 135 | +} |
| 136 | +.shithub-button-ghost { |
| 137 | + color: var(--fg-default); |
| 138 | + border-color: var(--border-default); |
| 139 | + background: transparent; |
| 140 | +} |
| 141 | +.shithub-button-primary { |
| 142 | + color: #fff; |
| 143 | + background: var(--accent-emphasis); |
| 144 | + border-color: var(--accent-emphasis); |
| 145 | +} |
| 146 | +.shithub-button-primary:hover { text-decoration: none; opacity: 0.92; } |
| 147 | + |
| 148 | +/* ========== Main + Footer ========== */ |
| 149 | + |
| 150 | +.shithub-main { |
| 151 | + flex: 1; |
| 152 | + width: 100%; |
| 153 | +} |
| 154 | + |
| 155 | +.shithub-footer { |
| 156 | + border-top: 1px solid var(--border-default); |
| 157 | + background: var(--canvas-subtle); |
| 158 | + padding: 1.25rem; |
| 159 | + font-size: 0.85rem; |
| 160 | + color: var(--fg-muted); |
| 161 | +} |
| 162 | +.shithub-footer-inner { |
| 163 | + max-width: 1200px; |
| 164 | + margin: 0 auto; |
| 165 | + display: flex; |
| 166 | + justify-content: space-between; |
| 167 | + align-items: center; |
| 168 | + gap: 1rem; |
| 169 | +} |
| 170 | +.shithub-footer-brand { |
| 171 | + display: flex; |
| 172 | + align-items: center; |
| 173 | + gap: 0.4rem; |
| 174 | + color: var(--fg-default); |
| 175 | +} |
| 176 | +.shithub-footer-brand svg { color: var(--shithub-mark); } |
| 177 | +.shithub-footer-meta { color: var(--fg-muted); margin-left: 0.5rem; font-size: 0.8rem; } |
| 178 | +.shithub-footer-links { display: flex; gap: 1rem; } |
| 179 | + |
| 180 | +/* ========== Hello page ========== */ |
| 181 | + |
| 63 | 182 | .hello { |
| 64 | 183 | max-width: 640px; |
| 65 | 184 | margin: 4rem auto; |
| 66 | 185 | padding: 2rem 1.5rem; |
| 67 | 186 | text-align: center; |
| 68 | 187 | } |
| 69 | | - |
| 70 | 188 | .hello-logo { |
| 71 | 189 | margin: 0 auto 1.5rem; |
| 72 | 190 | width: 160px; |
| 73 | 191 | height: 160px; |
| 74 | 192 | color: var(--shithub-mark); |
| 75 | 193 | } |
| 76 | | - |
| 77 | | -.hello-logo svg { |
| 78 | | - width: 100%; |
| 79 | | - height: 100%; |
| 80 | | -} |
| 81 | | - |
| 194 | +.hello-logo svg { width: 100%; height: 100%; } |
| 82 | 195 | .hello-title { |
| 83 | 196 | font-size: 2.75rem; |
| 84 | 197 | margin: 0 0 0.5rem; |
| 85 | 198 | letter-spacing: -0.02em; |
| 86 | 199 | } |
| 87 | | - |
| 88 | 200 | .hello-tagline { |
| 89 | 201 | color: var(--fg-muted); |
| 90 | 202 | font-size: 1.15rem; |
| 91 | 203 | margin: 0 0 2rem; |
| 92 | 204 | } |
| 93 | | - |
| 94 | 205 | .hello-meta { |
| 95 | 206 | display: grid; |
| 96 | 207 | grid-template-columns: max-content 1fr; |
@@ -105,21 +216,13 @@ a:hover { text-decoration: underline; } |
| 105 | 216 | font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace; |
| 106 | 217 | font-size: 0.875rem; |
| 107 | 218 | } |
| 108 | | - |
| 109 | | -.hello-meta dt { |
| 110 | | - color: var(--fg-muted); |
| 111 | | -} |
| 112 | | - |
| 113 | | -.hello-meta dd { |
| 114 | | - margin: 0; |
| 115 | | -} |
| 116 | | - |
| 219 | +.hello-meta dt { color: var(--fg-muted); } |
| 220 | +.hello-meta dd { margin: 0; } |
| 117 | 221 | .hello-status { |
| 118 | 222 | color: var(--fg-muted); |
| 119 | 223 | margin: 0 auto 2rem; |
| 120 | 224 | max-width: 36rem; |
| 121 | 225 | } |
| 122 | | - |
| 123 | 226 | .hello-links { |
| 124 | 227 | display: flex; |
| 125 | 228 | justify-content: center; |
@@ -127,3 +230,53 @@ a:hover { text-decoration: underline; } |
| 127 | 230 | font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace; |
| 128 | 231 | font-size: 0.875rem; |
| 129 | 232 | } |
| 233 | + |
| 234 | +/* ========== Error pages ========== */ |
| 235 | + |
| 236 | +.error-page { |
| 237 | + max-width: 540px; |
| 238 | + margin: 6rem auto; |
| 239 | + padding: 2rem 1.5rem; |
| 240 | + text-align: center; |
| 241 | +} |
| 242 | +.error-glyph { |
| 243 | + display: inline-flex; |
| 244 | + width: 64px; height: 64px; |
| 245 | + align-items: center; justify-content: center; |
| 246 | + border-radius: 50%; |
| 247 | + background: var(--canvas-subtle); |
| 248 | + color: var(--danger-fg); |
| 249 | + margin-bottom: 1.5rem; |
| 250 | +} |
| 251 | +.error-glyph svg { width: 32px; height: 32px; } |
| 252 | +.error-status { |
| 253 | + margin: 0; |
| 254 | + font-size: 4rem; |
| 255 | + letter-spacing: -0.04em; |
| 256 | + color: var(--fg-default); |
| 257 | +} |
| 258 | +.error-title { |
| 259 | + margin: 0 0 0.75rem; |
| 260 | + font-size: 1.4rem; |
| 261 | + font-weight: 500; |
| 262 | +} |
| 263 | +.error-detail { |
| 264 | + color: var(--fg-muted); |
| 265 | + margin: 0 0 2rem; |
| 266 | + max-width: 36rem; |
| 267 | + margin-left: auto; |
| 268 | + margin-right: auto; |
| 269 | +} |
| 270 | +.error-hint a { |
| 271 | + display: inline-block; |
| 272 | + padding: 0.5rem 1rem; |
| 273 | + border: 1px solid var(--border-default); |
| 274 | + border-radius: 6px; |
| 275 | + color: var(--fg-default); |
| 276 | +} |
| 277 | +.error-hint a:hover { text-decoration: none; background: var(--canvas-subtle); } |
| 278 | +.error-request-id { |
| 279 | + margin-top: 2rem; |
| 280 | + color: var(--fg-muted); |
| 281 | + font-size: 0.8rem; |
| 282 | +} |