:root{--font-display: "Libre Baskerville", serif;--font-body: "Open Sans", sans-serif;--color-bg: #f5f0e8;--color-bg-card: #ebe5db;--color-bg-input: #ffffff;--color-accent: #b63d3d;--color-accent-hover: #d44a3d;--color-accent-dark: #a42a1d;--color-text: #2d2a26;--color-text-muted: #6b6560;--color-text-light: #8a8580;--color-card-frame: #8b1a1a;--color-card-inner: #ffffff;--color-border: #d5d0c8;--color-border-dark: #c5c0b8;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 20px;--transition-fast: .15s ease;--transition-normal: .25s ease;--max-width: 1100px}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{margin:0;font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.3;margin:0;color:var(--color-text)}p{margin:0}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}button{font-family:var(--font-body);cursor:pointer;border:none;background:none;padding:0}input,select,textarea{font-family:var(--font-body);font-size:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:12px 24px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:var(--color-accent);color:#fff;border:none}.btn-primary:hover{filter:brightness(.9)}.btn-secondary{background:transparent;color:var(--color-accent);border:none}.btn-secondary:hover{color:var(--color-accent-hover)}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-lg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media (max-width: 600px){html{font-size:15px}.container{padding:0 var(--spacing-md)}.btn{padding:10px 18px;font-size:.9rem}}@media (max-width: 400px){html{font-size:14px}.container{padding:0 var(--spacing-md)}}.user-info.svelte-ytjtvq.svelte-ytjtvq{display:flex;align-items:center;gap:12px}.user-email.svelte-ytjtvq.svelte-ytjtvq{font-size:.85rem;color:var(--color-text-muted);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-sm.svelte-ytjtvq.svelte-ytjtvq{padding:6px 12px;font-size:.85rem}.modal-overlay.svelte-ytjtvq.svelte-ytjtvq{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content.svelte-ytjtvq.svelte-ytjtvq{background:#fff;border-radius:var(--radius-lg);padding:32px;width:100%;max-width:400px;position:relative}.modal-close.svelte-ytjtvq.svelte-ytjtvq{position:absolute;top:16px;right:16px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted)}.modal-close.svelte-ytjtvq.svelte-ytjtvq:hover{color:var(--color-text)}h2.svelte-ytjtvq.svelte-ytjtvq{margin:0 0 24px;font-family:var(--font-display);color:var(--color-accent)}.form-group.svelte-ytjtvq.svelte-ytjtvq{margin-bottom:16px}.form-group.svelte-ytjtvq label.svelte-ytjtvq{display:block;margin-bottom:6px;font-weight:600;font-size:.9rem}.form-group.svelte-ytjtvq input.svelte-ytjtvq{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem}.form-group.svelte-ytjtvq input.svelte-ytjtvq:focus{outline:none;border-color:var(--color-accent)}.btn-full.svelte-ytjtvq.svelte-ytjtvq{width:100%;margin-top:8px}.error-message.svelte-ytjtvq.svelte-ytjtvq{color:#dc2626;font-size:.9rem;margin:0 0 12px}.toggle-mode.svelte-ytjtvq.svelte-ytjtvq{text-align:center;margin-top:20px;font-size:.9rem;color:var(--color-text-muted)}.link-btn.svelte-ytjtvq.svelte-ytjtvq{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:inherit;text-decoration:underline}.link-btn.svelte-ytjtvq.svelte-ytjtvq:hover{color:var(--color-accent-hover)}.sync-container.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{position:relative}.sync-btn.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;transition:all .15s}.sync-btn.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6:hover{border-color:var(--color-accent)}.sync-btn.syncing.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{opacity:.7;cursor:wait}.sync-btn.error.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{border-color:#dc2626;color:#dc2626}.sync-icon.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{font-size:1rem}.sync-icon.spinning.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{animation:svelte-1ljv5w6-spin 1s linear infinite}@keyframes svelte-1ljv5w6-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-menu.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;min-width:200px;z-index:100;overflow:hidden}.sync-menu.svelte-1ljv5w6 button.svelte-1ljv5w6.svelte-1ljv5w6{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:none;border:none;font-size:.9rem;cursor:pointer;text-align:left}.sync-menu.svelte-1ljv5w6 button.svelte-1ljv5w6.svelte-1ljv5w6:hover{background:var(--color-bg)}.sync-menu.svelte-1ljv5w6 button.svelte-1ljv5w6+button.svelte-1ljv5w6{border-top:1px solid var(--color-border)}.menu-icon.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{font-size:1.1rem;width:20px;text-align:center}.sync-info.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6,.sync-result.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{padding:10px 16px;font-size:.8rem;color:var(--color-text-muted);background:var(--color-bg);border-top:1px solid var(--color-border)}.sync-result.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{color:#059669}.sync-error.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{padding:10px 16px;font-size:.8rem;color:#dc2626;background:#fef2f2;border-top:1px solid var(--color-border)}.menu-backdrop.svelte-1ljv5w6.svelte-1ljv5w6.svelte-1ljv5w6{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.modal-overlay.svelte-61ab2k.svelte-61ab2k{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal-content.svelte-61ab2k.svelte-61ab2k{background:var(--color-bg);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;position:relative;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden}.modal-header.svelte-61ab2k.svelte-61ab2k{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title.svelte-61ab2k.svelte-61ab2k{font-size:1.5rem;margin:0}.close-btn.svelte-61ab2k.svelte-61ab2k{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all .15s;display:flex;align-items:center;justify-content:center}.close-btn.svelte-61ab2k.svelte-61ab2k:hover{color:var(--color-text);background:var(--color-bg-card)}.modal-body.svelte-61ab2k.svelte-61ab2k{padding:24px;overflow-y:auto;flex:1;min-height:0}.scroll-indicator.svelte-61ab2k.svelte-61ab2k{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 0;background:linear-gradient(to bottom,#f5f5f000,#f5f5f0e6 40%,#f5f5f0);color:#555;font-size:.85rem;font-weight:600;border:none;cursor:pointer;z-index:5}.scroll-indicator.svelte-61ab2k.svelte-61ab2k:hover{color:var(--color-accent)}.scroll-indicator.svelte-61ab2k svg.svelte-61ab2k{animation:svelte-61ab2k-settingsBounce 1s ease-in-out infinite}@keyframes svelte-61ab2k-settingsBounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.settings-section.svelte-61ab2k.svelte-61ab2k{padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--color-border)}.settings-section.svelte-61ab2k.svelte-61ab2k:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.settings-section.svelte-61ab2k h2.svelte-61ab2k{font-size:1.1rem;margin:0 0 8px}.section-desc.svelte-61ab2k.svelte-61ab2k{font-size:.9rem;color:var(--color-text-muted);margin:0 0 16px}.dice-settings-row.svelte-61ab2k.svelte-61ab2k{display:flex;gap:20px;margin-bottom:16px}.dice-setting.svelte-61ab2k.svelte-61ab2k{flex:1}.dice-setting.svelte-61ab2k label.svelte-61ab2k{display:block;font-weight:500;margin-bottom:6px;font-size:.9rem}.select-wrapper.svelte-61ab2k select.svelte-61ab2k{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text);font-size:.95rem;cursor:pointer}.rainbow-toggle.svelte-61ab2k.svelte-61ab2k{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;font-weight:500;padding:6px 12px;margin-top:12px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#ff00001a,#ff7f001a,#ffff001a,#00ff001a,#0000ff1a,#9400d31a);border:1px solid var(--color-border);transition:all .15s}.rainbow-toggle.svelte-61ab2k.svelte-61ab2k:hover{border-color:var(--color-accent)}.rainbow-toggle.svelte-61ab2k input[type=checkbox].svelte-61ab2k{width:16px;height:16px;accent-color:var(--color-accent);cursor:pointer;margin:0}.rainbow-label.svelte-61ab2k.svelte-61ab2k{white-space:nowrap}.color-presets.svelte-61ab2k.svelte-61ab2k{display:flex;flex-wrap:wrap;gap:8px;transition:opacity .2s}.color-presets.greyed-out.svelte-61ab2k.svelte-61ab2k{opacity:.4;pointer-events:none}.color-preset.svelte-61ab2k.svelte-61ab2k{width:32px;height:32px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .15s;outline:none}.color-preset.svelte-61ab2k.svelte-61ab2k:hover:not(:disabled){transform:scale(1.1)}.color-preset.svelte-61ab2k.svelte-61ab2k:disabled{cursor:not-allowed}.color-preset.active.svelte-61ab2k.svelte-61ab2k{border-color:var(--color-text);box-shadow:0 0 0 3px var(--color-bg),0 0 0 5px var(--color-text);transform:scale(1.05)}.dice-actions.svelte-61ab2k.svelte-61ab2k{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:20px}.save-btn.svelte-61ab2k.svelte-61ab2k{padding:8px 20px}.save-btn.svelte-61ab2k.svelte-61ab2k:disabled{opacity:.5;cursor:not-allowed}.save-message.svelte-61ab2k.svelte-61ab2k{font-size:.85rem;color:var(--color-accent)}.reset-link.svelte-61ab2k.svelte-61ab2k{background:none;border:none;color:var(--color-accent);font-size:.85rem;cursor:pointer;padding:0}.reset-link.svelte-61ab2k.svelte-61ab2k:hover{text-decoration:underline}.color-grid.svelte-61ab2k.svelte-61ab2k{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.color-book-item.svelte-61ab2k.svelte-61ab2k{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-size:.9rem}.color-book-item.svelte-61ab2k.svelte-61ab2k:hover{background:var(--color-border)}.color-book-item.selected.svelte-61ab2k.svelte-61ab2k{border-color:var(--color-accent)}.color-swatch.svelte-61ab2k.svelte-61ab2k{width:20px;height:20px;border-radius:4px;flex-shrink:0}.color-book-name.svelte-61ab2k.svelte-61ab2k{font-size:.9rem}.color-editor.svelte-61ab2k.svelte-61ab2k{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.color-picker-label.svelte-61ab2k.svelte-61ab2k{display:flex;align-items:center;gap:10px;font-size:.9rem}.color-box.svelte-61ab2k.svelte-61ab2k{display:block;width:50px;height:30px;border-radius:6px;cursor:pointer;overflow:hidden;border:1px solid var(--color-border)}.color-box.svelte-61ab2k input.svelte-61ab2k{width:100%;height:100%;border:none;cursor:pointer;opacity:0}.btn.svelte-61ab2k.svelte-61ab2k{padding:8px 16px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;border:none}.btn-primary.svelte-61ab2k.svelte-61ab2k{background:var(--color-accent);color:#fff}.btn-primary.svelte-61ab2k.svelte-61ab2k:hover{background:var(--color-accent-hover)}@media (max-width: 500px){.modal-content.svelte-61ab2k.svelte-61ab2k{max-height:95vh}.modal-body.svelte-61ab2k.svelte-61ab2k{padding:16px}.dice-settings-row.svelte-61ab2k.svelte-61ab2k{flex-direction:column;gap:16px}}.header.svelte-56t7x4.svelte-56t7x4{border-bottom:2px solid var(--color-accent)}.nav.svelte-56t7x4.svelte-56t7x4{display:flex;align-items:center;justify-content:space-between;padding:8px 20px}.header-right.svelte-56t7x4.svelte-56t7x4{display:flex;align-items:center;gap:12px}.auth-controls.svelte-56t7x4.svelte-56t7x4{display:flex;align-items:center;gap:10px}.header-logo.svelte-56t7x4.svelte-56t7x4{width:40px;height:40px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}.nav-content.svelte-56t7x4.svelte-56t7x4{flex:1;max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-lg)}.tabs.svelte-56t7x4.svelte-56t7x4{display:flex;gap:24px}.tab.svelte-56t7x4.svelte-56t7x4{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--color-accent);background:none;border:none;padding:8px 4px;cursor:pointer;position:relative;transition:color var(--transition-fast);text-decoration:none}.tab.active.svelte-56t7x4.svelte-56t7x4{border-bottom:2px solid var(--color-accent);margin-bottom:-2px}.tab.svelte-56t7x4.svelte-56t7x4:hover{color:var(--color-accent-hover)}.settings-btn.svelte-56t7x4.svelte-56t7x4{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--color-accent);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.settings-btn.svelte-56t7x4.svelte-56t7x4:hover{background:var(--color-bg-card)}.settings-btn.active.svelte-56t7x4.svelte-56t7x4{color:var(--color-accent);background:var(--color-bg-card)}@media (max-width: 480px){.nav.svelte-56t7x4.svelte-56t7x4{padding:6px 12px}.nav-content.svelte-56t7x4.svelte-56t7x4{padding:0 8px}.tab.svelte-56t7x4.svelte-56t7x4{font-size:.95rem;padding:6px 2px}.header-logo.svelte-56t7x4.svelte-56t7x4{width:32px;height:32px}.settings-btn.svelte-56t7x4.svelte-56t7x4{width:34px;height:34px}.settings-btn.svelte-56t7x4 svg.svelte-56t7x4{width:18px;height:18px}.header-right.svelte-56t7x4.svelte-56t7x4{gap:8px}.auth-controls.svelte-56t7x4.svelte-56t7x4{gap:6px}}.app.svelte-t25zbx{min-height:100vh;display:flex;flex-direction:column}.main.svelte-t25zbx{flex:1}.footer.svelte-t25zbx{border-top:1px solid var(--color-border);padding:24px 0;margin-top:auto}.footer-content.svelte-t25zbx{text-align:center}.made-by.svelte-t25zbx{font-size:.9rem;color:var(--color-text-muted);margin:0}.srd-info.svelte-t25zbx{font-size:.85rem;color:var(--color-text-muted);margin:4px 0 0}
