| cf89d3c | | | 1 | @import url('https://fonts.googleapis.com/css2?family=Libre+Caslon+Text:ital,wght@0,400;1,400&family=JetBrains+Mono:wght@400;500&display=swap'); |
| 3e3af55 | | | 2 | @import "tailwindcss"; |
| 135dfe5 | | | 3 | |
| 135dfe5 | | | 4 | /* ── Light theme (default) ── */ |
| 135dfe5 | | | 5 | :root { |
| 135dfe5 | | | 6 | --bg-page: #faf8f5; |
| 135dfe5 | | | 7 | --bg-card: #f2efe9; |
| 135dfe5 | | | 8 | --bg-inset: #eae6df; |
| 135dfe5 | | | 9 | --bg-hover: #e2ddd5; |
| 135dfe5 | | | 10 | --bg-input: #ffffff; |
| 135dfe5 | | | 11 | |
| 135dfe5 | | | 12 | --text-primary: #2c2824; |
| 135dfe5 | | | 13 | --text-secondary: #4a4540; |
| 135dfe5 | | | 14 | --text-muted: #7a746c; |
| 135dfe5 | | | 15 | --text-faint: #a09888; |
| 135dfe5 | | | 16 | |
| 135dfe5 | | | 17 | --accent: #4d8a78; |
| 135dfe5 | | | 18 | --accent-hover: #3d7a68; |
| 135dfe5 | | | 19 | --accent-subtle: #e8f2ee; |
| 135dfe5 | | | 20 | --accent-text: #ffffff; |
| 135dfe5 | | | 21 | |
| 135dfe5 | | | 22 | --border: #d9d3ca; |
| 135dfe5 | | | 23 | --border-subtle: #e8e3db; |
| 135dfe5 | | | 24 | --divide: #e2ddd580; |
| 135dfe5 | | | 25 | |
| 135dfe5 | | | 26 | --status-open-bg: #e8f2ee; |
| 135dfe5 | | | 27 | --status-open-text: #2d6b56; |
| 135dfe5 | | | 28 | --status-open-border: #b0d4c5; |
| 135dfe5 | | | 29 | --status-merged-bg: #ede8f5; |
| 135dfe5 | | | 30 | --status-merged-text: #6b4fa0; |
| 135dfe5 | | | 31 | --status-merged-border: #c5b8dc; |
| 135dfe5 | | | 32 | --status-closed-bg: #f5e8e8; |
| 135dfe5 | | | 33 | --status-closed-text: #a05050; |
| 135dfe5 | | | 34 | --status-closed-border: #dcb8b8; |
| 135dfe5 | | | 35 | |
| 135dfe5 | | | 36 | --error-bg: #f5e8e8; |
| 135dfe5 | | | 37 | --error-border: #dcb8b8; |
| 135dfe5 | | | 38 | --error-text: #a05050; |
| 135dfe5 | | | 39 | |
| 135dfe5 | | | 40 | --code-bg: #f2efe9; |
| 12ffdd4 | | | 41 | |
| 12ffdd4 | | | 42 | --diff-add-bg: rgba(46, 160, 67, 0.08); |
| 12ffdd4 | | | 43 | --diff-add-text: #1a7f37; |
| 12ffdd4 | | | 44 | --diff-del-bg: rgba(248, 81, 73, 0.08); |
| 12ffdd4 | | | 45 | --diff-del-text: #cf222e; |
| 135dfe5 | | | 46 | } |
| 135dfe5 | | | 47 | |
| 135dfe5 | | | 48 | /* ── Dark theme (Photodesk warm) ── */ |
| 135dfe5 | | | 49 | [data-theme="dark"] { |
| 135dfe5 | | | 50 | --bg-page: #1a1918; |
| 135dfe5 | | | 51 | --bg-card: #242220; |
| 135dfe5 | | | 52 | --bg-inset: #2e2c29; |
| 135dfe5 | | | 53 | --bg-hover: #383532; |
| 135dfe5 | | | 54 | --bg-input: #2e2c29; |
| 135dfe5 | | | 55 | |
| 135dfe5 | | | 56 | --text-primary: #e8e4df; |
| 135dfe5 | | | 57 | --text-secondary: #c4bfb8; |
| 135dfe5 | | | 58 | --text-muted: #9a948c; |
| 135dfe5 | | | 59 | --text-faint: #6b665f; |
| 135dfe5 | | | 60 | |
| 135dfe5 | | | 61 | --accent: #7aab9c; |
| 135dfe5 | | | 62 | --accent-hover: #8dbdaf; |
| 135dfe5 | | | 63 | --accent-subtle: #2a3632; |
| 135dfe5 | | | 64 | --accent-text: #1a1918; |
| 135dfe5 | | | 65 | |
| 135dfe5 | | | 66 | --border: #3a3835; |
| 135dfe5 | | | 67 | --border-subtle: #302e2b; |
| 135dfe5 | | | 68 | --divide: #3a383580; |
| 135dfe5 | | | 69 | |
| 135dfe5 | | | 70 | --status-open-bg: #2a3632; |
| 135dfe5 | | | 71 | --status-open-text: #7aab9c; |
| 135dfe5 | | | 72 | --status-open-border: #3d5249; |
| 135dfe5 | | | 73 | --status-merged-bg: #2e2a38; |
| 135dfe5 | | | 74 | --status-merged-text: #a892cc; |
| 135dfe5 | | | 75 | --status-merged-border: #4a3d66; |
| 135dfe5 | | | 76 | --status-closed-bg: #382a2a; |
| 135dfe5 | | | 77 | --status-closed-text: #cc9292; |
| 135dfe5 | | | 78 | --status-closed-border: #664040; |
| 135dfe5 | | | 79 | |
| 135dfe5 | | | 80 | --error-bg: #382a2a; |
| 135dfe5 | | | 81 | --error-border: #664040; |
| 135dfe5 | | | 82 | --error-text: #cc9292; |
| 135dfe5 | | | 83 | |
| 135dfe5 | | | 84 | --code-bg: #242220; |
| 12ffdd4 | | | 85 | |
| 12ffdd4 | | | 86 | --diff-add-bg: rgba(46, 160, 67, 0.15); |
| 12ffdd4 | | | 87 | --diff-add-text: #3fb950; |
| 12ffdd4 | | | 88 | --diff-del-bg: rgba(248, 81, 73, 0.15); |
| 12ffdd4 | | | 89 | --diff-del-text: #f85149; |
| 135dfe5 | | | 90 | } |
| 135dfe5 | | | 91 | |
| 135dfe5 | | | 92 | /* ── Base styles ── */ |
| 8a2c7d4 | | | 93 | @media (pointer: fine) { |
| 8a2c7d4 | | | 94 | html { |
| 8a2c7d4 | | | 95 | scrollbar-gutter: stable both-edges; |
| 8a2c7d4 | | | 96 | } |
| a33b2b6 | | | 97 | } |
| a33b2b6 | | | 98 | |
| a33b2b6 | | | 99 | @supports not (scrollbar-gutter: stable) { |
| 8a2c7d4 | | | 100 | @media (pointer: fine) { |
| 8a2c7d4 | | | 101 | html { |
| 8a2c7d4 | | | 102 | overflow-y: scroll; |
| 8a2c7d4 | | | 103 | } |
| a33b2b6 | | | 104 | } |
| a33b2b6 | | | 105 | } |
| a33b2b6 | | | 106 | |
| 135dfe5 | | | 107 | body { |
| 135dfe5 | | | 108 | font-family: 'Libre Caslon Text', 'Georgia', serif; |
| 135dfe5 | | | 109 | background-color: var(--bg-page); |
| 135dfe5 | | | 110 | color: var(--text-primary); |
| 8a2c7d4 | | | 111 | overflow-x: hidden; |
| 135dfe5 | | | 112 | } |
| 135dfe5 | | | 113 | |
| 10621c5 | | | 114 | .grove-body { |
| 10621c5 | | | 115 | height: 100dvh; |
| 10621c5 | | | 116 | overflow: hidden; |
| 10621c5 | | | 117 | display: flex; |
| 10621c5 | | | 118 | flex-direction: column; |
| 10621c5 | | | 119 | } |
| 10621c5 | | | 120 | .grove-scroll { |
| 10621c5 | | | 121 | flex: 1; |
| 10621c5 | | | 122 | min-height: 0; |
| 10621c5 | | | 123 | overflow: auto; |
| 10621c5 | | | 124 | /* iOS momentum scrolling */ |
| 10621c5 | | | 125 | -webkit-overflow-scrolling: touch; |
| 10621c5 | | | 126 | } |
| 10621c5 | | | 127 | |
| 135dfe5 | | | 128 | code, pre, .font-mono, kbd, samp { |
| 135dfe5 | | | 129 | font-family: 'JetBrains Mono', 'Menlo', monospace; |
| 135dfe5 | | | 130 | } |
| bf5fc33 | | | 131 | |
| bf5fc33 | | | 132 | /* ── Shimmer skeleton ── */ |
| bf5fc33 | | | 133 | @keyframes shimmer { |
| bf5fc33 | | | 134 | 0% { background-position: -400px 0; } |
| bf5fc33 | | | 135 | 100% { background-position: 400px 0; } |
| bf5fc33 | | | 136 | } |
| bf5fc33 | | | 137 | .skeleton { |
| bf5fc33 | | | 138 | background: linear-gradient( |
| bf5fc33 | | | 139 | 90deg, |
| bf5fc33 | | | 140 | var(--bg-card) 0%, |
| bf5fc33 | | | 141 | var(--bg-hover) 40%, |
| bf5fc33 | | | 142 | var(--bg-card) 80% |
| bf5fc33 | | | 143 | ); |
| bf5fc33 | | | 144 | background-size: 800px 100%; |
| bf5fc33 | | | 145 | animation: shimmer 1.5s ease-in-out infinite; |
| bf5fc33 | | | 146 | } |
| bf5fc33 | | | 147 | |
| a011f1e | | | 148 | /* ── Badge activity cue for running states ── */ |
| fe3b509 | | | 149 | @keyframes badge-running-border { |
| a011f1e | | | 150 | 0%, 100% { |
| fe3b509 | | | 151 | border-color: currentColor; |
| a011f1e | | | 152 | } |
| a011f1e | | | 153 | 50% { |
| fe3b509 | | | 154 | border-color: transparent; |
| a011f1e | | | 155 | } |
| a011f1e | | | 156 | } |
| b2bd123 | | | 157 | .badge-running-text-pulse { |
| fe3b509 | | | 158 | animation: badge-running-border 2s ease-in-out infinite; |
| fe3b509 | | | 159 | } |
| fe3b509 | | | 160 | |
| bf5fc33 | | | 161 | /* ── Focus styles ── */ |
| bf5fc33 | | | 162 | *:focus-visible { |
| bf5fc33 | | | 163 | outline: 2px solid var(--accent); |
| bf5fc33 | | | 164 | outline-offset: 2px; |
| bf5fc33 | | | 165 | } |
| bf5fc33 | | | 166 | |
| fe3b509 | | | 167 | /* ── Thin scrollbars site-wide ── */ |
| fe3b509 | | | 168 | * { |
| fe3b509 | | | 169 | scrollbar-width: thin; |
| fe3b509 | | | 170 | scrollbar-color: var(--border) transparent; |
| fe3b509 | | | 171 | } |
| fe3b509 | | | 172 | *::-webkit-scrollbar { |
| fe3b509 | | | 173 | width: 6px; |
| fe3b509 | | | 174 | height: 6px; |
| fe3b509 | | | 175 | } |
| fe3b509 | | | 176 | *::-webkit-scrollbar-track { |
| fe3b509 | | | 177 | background: transparent; |
| fe3b509 | | | 178 | } |
| fe3b509 | | | 179 | *::-webkit-scrollbar-thumb { |
| fe3b509 | | | 180 | background: var(--border); |
| fe3b509 | | | 181 | border-radius: 3px; |
| fe3b509 | | | 182 | } |
| fe3b509 | | | 183 | *::-webkit-scrollbar-thumb:hover { |
| fe3b509 | | | 184 | background: var(--text-faint); |
| fe3b509 | | | 185 | } |
| fe3b509 | | | 186 | |
| bf5fc33 | | | 187 | /* ── Interactive row (file trees, lists) ── */ |
| bf5fc33 | | | 188 | .hover-row { |
| bf5fc33 | | | 189 | transition: background-color 0.1s; |
| bf5fc33 | | | 190 | } |
| 10621c5 | | | 191 | @media (hover: hover) { |
| 10621c5 | | | 192 | .hover-row:hover { |
| 10621c5 | | | 193 | background-color: var(--bg-hover); |
| 10621c5 | | | 194 | } |
| 10621c5 | | | 195 | } |
| 10621c5 | | | 196 | .hover-row:active { |
| bf5fc33 | | | 197 | background-color: var(--bg-hover); |
| bf5fc33 | | | 198 | } |
| bf5fc33 | | | 199 | |
| fe3b509 | | | 200 | /* ── Log line hover ── */ |
| fe3b509 | | | 201 | .log-line:hover { |
| fe3b509 | | | 202 | background-color: var(--bg-inset); |
| fe3b509 | | | 203 | } |
| fe3b509 | | | 204 | |
| fe3b509 | | | 205 | /* ── Docker group hover ── */ |
| fe3b509 | | | 206 | .docker-group-header:hover { |
| fe3b509 | | | 207 | background-color: var(--bg-inset) !important; |
| fe3b509 | | | 208 | } |
| fe3b509 | | | 209 | .docker-group-header:hover ~ .docker-group-body .log-line { |
| fe3b509 | | | 210 | background-color: var(--bg-inset); |
| fe3b509 | | | 211 | } |
| fe3b509 | | | 212 | .docker-group-header .docker-group-copy { |
| fe3b509 | | | 213 | opacity: 0; |
| fe3b509 | | | 214 | } |
| fe3b509 | | | 215 | .docker-group-header:hover .docker-group-copy { |
| fe3b509 | | | 216 | opacity: 1; |
| fe3b509 | | | 217 | } |
| fe3b509 | | | 218 | |
| bf5fc33 | | | 219 | /* ── Button resets ── */ |
| bf5fc33 | | | 220 | .btn-reset { |
| bf5fc33 | | | 221 | background: none; |
| bf5fc33 | | | 222 | border: none; |
| bf5fc33 | | | 223 | cursor: pointer; |
| bf5fc33 | | | 224 | font: inherit; |
| bf5fc33 | | | 225 | color: inherit; |
| bf5fc33 | | | 226 | padding: 0; |
| bf5fc33 | | | 227 | } |
| bf5fc33 | | | 228 | |
| 0b4b582 | | | 229 | /* ── Collab presence avatars ── */ |
| 0b4b582 | | | 230 | .collab-avatar { |
| 0b4b582 | | | 231 | transition: transform 0.15s ease; |
| 0b4b582 | | | 232 | } |
| 0b4b582 | | | 233 | .collab-avatar:hover { |
| 0b4b582 | | | 234 | transform: scale(1.15); |
| 0b4b582 | | | 235 | } |
| 0b4b582 | | | 236 | .collab-avatar::after { |
| 0b4b582 | | | 237 | content: attr(data-tooltip); |
| 0b4b582 | | | 238 | position: absolute; |
| 0b4b582 | | | 239 | top: calc(100% + 6px); |
| 0b4b582 | | | 240 | left: 50%; |
| 0b4b582 | | | 241 | transform: translateX(-50%) scale(0.9); |
| 0b4b582 | | | 242 | padding: 3px 8px; |
| 0b4b582 | | | 243 | border-radius: 4px; |
| 0b4b582 | | | 244 | background: var(--bg-inset, #333); |
| 0b4b582 | | | 245 | color: var(--text-primary); |
| 0b4b582 | | | 246 | font-size: 10px; |
| 0b4b582 | | | 247 | font-family: 'JetBrains Mono', Menlo, monospace; |
| 0b4b582 | | | 248 | white-space: nowrap; |
| 0b4b582 | | | 249 | pointer-events: none; |
| 0b4b582 | | | 250 | opacity: 0; |
| 0b4b582 | | | 251 | transition: opacity 0.15s ease, transform 0.15s ease; |
| 0b4b582 | | | 252 | border: 1px solid var(--border); |
| 0b4b582 | | | 253 | z-index: 50; |
| 0b4b582 | | | 254 | } |
| 0b4b582 | | | 255 | .collab-avatar:hover::after { |
| 0b4b582 | | | 256 | opacity: 1; |
| 0b4b582 | | | 257 | transform: translateX(-50%) scale(1); |
| 0b4b582 | | | 258 | } |
| 0b4b582 | | | 259 | |
| bf5fc33 | | | 260 | /* ── Markdown prose ── */ |
| bf5fc33 | | | 261 | .prose { |
| bf5fc33 | | | 262 | color: var(--text-secondary); |
| bf5fc33 | | | 263 | line-height: 1.7; |
| bf5fc33 | | | 264 | } |
| bf5fc33 | | | 265 | .prose h1, .prose h2, .prose h3, .prose h4, .prose h5, .prose h6 { |
| bf5fc33 | | | 266 | color: var(--text-primary); |
| bf5fc33 | | | 267 | margin-top: 1.5em; |
| bf5fc33 | | | 268 | margin-bottom: 0.5em; |
| bf5fc33 | | | 269 | line-height: 1.3; |
| bf5fc33 | | | 270 | } |
| bf5fc33 | | | 271 | .prose h1 { font-size: 1.5rem; } |
| bf5fc33 | | | 272 | .prose h2 { font-size: 1.25rem; } |
| bf5fc33 | | | 273 | .prose h3 { font-size: 1.1rem; } |
| bf5fc33 | | | 274 | .prose h1:first-child, .prose h2:first-child, .prose h3:first-child { |
| bf5fc33 | | | 275 | margin-top: 0; |
| bf5fc33 | | | 276 | } |
| bf5fc33 | | | 277 | .prose p { |
| bf5fc33 | | | 278 | margin: 0.75em 0; |
| bf5fc33 | | | 279 | } |
| bf5fc33 | | | 280 | .prose a { |
| bf5fc33 | | | 281 | color: var(--accent); |
| bf5fc33 | | | 282 | text-decoration: underline; |
| bf5fc33 | | | 283 | } |
| bf5fc33 | | | 284 | .prose a:hover { |
| bf5fc33 | | | 285 | color: var(--accent-hover); |
| bf5fc33 | | | 286 | } |
| bf5fc33 | | | 287 | .prose code { |
| bf5fc33 | | | 288 | background-color: var(--code-bg); |
| bf5fc33 | | | 289 | padding: 0.15em 0.35em; |
| bf5fc33 | | | 290 | font-size: 0.875em; |
| bf5fc33 | | | 291 | } |
| bf5fc33 | | | 292 | .prose pre { |
| bf5fc33 | | | 293 | background-color: var(--code-bg); |
| bf5fc33 | | | 294 | padding: 1em; |
| bf5fc33 | | | 295 | overflow-x: auto; |
| bf5fc33 | | | 296 | margin: 1em 0; |
| bf5fc33 | | | 297 | border: 1px solid var(--border-subtle); |
| bf5fc33 | | | 298 | } |
| bf5fc33 | | | 299 | .prose pre code { |
| bf5fc33 | | | 300 | background: none; |
| bf5fc33 | | | 301 | padding: 0; |
| bf5fc33 | | | 302 | } |
| bf5fc33 | | | 303 | .prose ul, .prose ol { |
| bf5fc33 | | | 304 | margin: 0.75em 0; |
| bf5fc33 | | | 305 | padding-left: 1.5em; |
| bf5fc33 | | | 306 | } |
| bf5fc33 | | | 307 | .prose ul { list-style: disc; } |
| bf5fc33 | | | 308 | .prose ol { list-style: decimal; } |
| bf5fc33 | | | 309 | .prose li { margin: 0.25em 0; } |
| bf5fc33 | | | 310 | .prose blockquote { |
| bf5fc33 | | | 311 | border-left: 3px solid var(--border); |
| bf5fc33 | | | 312 | padding-left: 1em; |
| bf5fc33 | | | 313 | margin: 1em 0; |
| bf5fc33 | | | 314 | color: var(--text-muted); |
| bf5fc33 | | | 315 | } |
| bf5fc33 | | | 316 | .prose table { |
| bf5fc33 | | | 317 | width: 100%; |
| bf5fc33 | | | 318 | border-collapse: collapse; |
| bf5fc33 | | | 319 | margin: 1em 0; |
| 8a2c7d4 | | | 320 | display: block; |
| 8a2c7d4 | | | 321 | overflow-x: auto; |
| bf5fc33 | | | 322 | } |
| bf5fc33 | | | 323 | .prose th, .prose td { |
| bf5fc33 | | | 324 | border: 1px solid var(--border-subtle); |
| bf5fc33 | | | 325 | padding: 0.4em 0.75em; |
| bf5fc33 | | | 326 | text-align: left; |
| bf5fc33 | | | 327 | } |
| bf5fc33 | | | 328 | .prose th { |
| bf5fc33 | | | 329 | background-color: var(--bg-card); |
| bf5fc33 | | | 330 | font-weight: 600; |
| bf5fc33 | | | 331 | } |
| bf5fc33 | | | 332 | .prose img { |
| bf5fc33 | | | 333 | max-width: 100%; |
| bf5fc33 | | | 334 | } |
| bf5fc33 | | | 335 | .prose hr { |
| bf5fc33 | | | 336 | border: none; |
| bf5fc33 | | | 337 | border-top: 1px solid var(--border); |
| bf5fc33 | | | 338 | margin: 1.5em 0; |
| bf5fc33 | | | 339 | } |
| bf5fc33 | | | 340 | |
| bf5fc33 | | | 341 | /* ── Shiki syntax highlighting (dual theme) ── */ |
| bf5fc33 | | | 342 | .shiki, |
| bf5fc33 | | | 343 | .shiki span { |
| bf5fc33 | | | 344 | color: var(--shiki-light) !important; |
| bf5fc33 | | | 345 | background-color: transparent !important; |
| bf5fc33 | | | 346 | } |
| bf5fc33 | | | 347 | [data-theme="dark"] .shiki, |
| bf5fc33 | | | 348 | [data-theme="dark"] .shiki span { |
| bf5fc33 | | | 349 | color: var(--shiki-dark) !important; |
| bf5fc33 | | | 350 | } |
| 4dfd09b | | | 351 | |
| 4dfd09b | | | 352 | /* ── Card hover states ── */ |
| 4dfd09b | | | 353 | .card-hover { |
| 4dfd09b | | | 354 | transition: background-color 0.15s, border-color 0.15s; |
| 4dfd09b | | | 355 | } |
| 4dfd09b | | | 356 | .card-hover:hover { |
| 4dfd09b | | | 357 | background-color: var(--bg-hover); |
| 4dfd09b | | | 358 | border-color: var(--border); |
| 4dfd09b | | | 359 | } |
| 4dfd09b | | | 360 | |
| 4dfd09b | | | 361 | /* ── Dialog ── */ |
| ab61b9d | | | 362 | @keyframes dialog-enter { |
| ab61b9d | | | 363 | from { |
| ab61b9d | | | 364 | opacity: 0; |
| ab61b9d | | | 365 | transform: scale(0.96) translateY(8px); |
| ab61b9d | | | 366 | } |
| ab61b9d | | | 367 | to { |
| ab61b9d | | | 368 | opacity: 1; |
| ab61b9d | | | 369 | transform: scale(1) translateY(0); |
| ab61b9d | | | 370 | } |
| ab61b9d | | | 371 | } |
| ab61b9d | | | 372 | @keyframes backdrop-enter { |
| ab61b9d | | | 373 | from { opacity: 0; } |
| ab61b9d | | | 374 | to { opacity: 1; } |
| ab61b9d | | | 375 | } |
| 4dfd09b | | | 376 | dialog::backdrop { |
| 4dfd09b | | | 377 | background-color: rgba(0, 0, 0, 0.4); |
| ab61b9d | | | 378 | animation: backdrop-enter 0.15s ease-out; |
| 4dfd09b | | | 379 | } |
| 4dfd09b | | | 380 | [data-theme="dark"] dialog::backdrop { |
| 4dfd09b | | | 381 | background-color: rgba(0, 0, 0, 0.6); |
| 4dfd09b | | | 382 | } |
| 4dfd09b | | | 383 | dialog { |
| 4dfd09b | | | 384 | border: none; |
| 4dfd09b | | | 385 | padding: 0; |
| 4dfd09b | | | 386 | max-width: calc(100vw - 2rem); |
| 4dfd09b | | | 387 | } |
| ab61b9d | | | 388 | dialog[open] { |
| ab61b9d | | | 389 | animation: dialog-enter 0.2s ease-out; |
| ab61b9d | | | 390 | } |
| 4dfd09b | | | 391 | |
| 4dfd09b | | | 392 | /* ── Toast entrance ── */ |
| 4dfd09b | | | 393 | @keyframes toast-enter { |
| 4dfd09b | | | 394 | from { opacity: 0; transform: translateY(8px); } |
| 4dfd09b | | | 395 | to { opacity: 1; transform: translateY(0); } |
| 4dfd09b | | | 396 | } |
| 4dfd09b | | | 397 | .toast-enter { |
| 4dfd09b | | | 398 | animation: toast-enter 0.15s ease-out; |
| 4dfd09b | | | 399 | } |