` injected on tenant-scoped pages. */ --tenant-brand: #E0654B; /* primary tenant brand accent */ --tenant-brand-deep: #B84F39; /* hover / pressed */ --tenant-brand-soft: #FBE4DC; /* tinted backgrounds */ --tenant-brand-wash: #FCEEE9; /* lightest tint, e.g. nav-item active state */ --tenant-brand-ink: #6B2A1B; /* text on tenant-brand-wash backgrounds */ --shadow-card: 0 1px 0 rgba(255,255,255,.65) inset, 0 1px 2px rgba(80,55,20,.05), 0 8px 24px -12px rgba(80,55,20,.12); /* Layout width tokens --layout-narrow (860px) : reading/focused — profile, inbox, single-column forms --layout-medium (1100px) : standard marketing/feature pages, moderate tables --layout-wide (1400px) : data-heavy tables with many columns, admin lists full-width (no max-width): ops dashboards, analytics, multi-panel data pages → use padding: 1.5rem 2rem on the content wrapper; omit max-width entirely */ --layout-narrow: 860px; --layout-medium: 1100px; --layout-wide: 1400px; /* Typography */ --leading-tight: 1.25; --leading-normal: 1.5; --leading-relaxed: 1.625; --tracking-tight: -0.01em; --tracking-normal: 0; --tracking-wide: 0.05em; --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; --font-display: 'Instrument Serif', Georgia, 'Times New Roman', serif; --font-mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', Consolas, monospace; --text-xs: 0.75rem; --text-sm: 0.8125rem; --text-base: 0.9375rem; --text-md: 1rem; --text-lg: 1.0625rem; --text-xl: 1.25rem; --text-2xl: 1.5rem; --text-3xl: 2rem; /* Spacing scale (4px base) */ --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px; --space-6: 24px; --space-8: 32px; --space-10: 40px; --space-12: 48px; /* Shape */ --radius-sm: 6px; --radius-md: 8px; --radius-lg: 12px; --radius-pill: 20px; --shadow-sm: 0 1px 3px rgba(80, 55, 20, 0.06); --shadow-md: 0 4px 12px rgba(80, 55, 20, 0.08); --shadow-lg: 0 8px 24px rgba(80, 55, 20, 0.12); } /* Dark mode via class (manual toggle) or system preference */ /* v2 note: dark mode uses a lighter teal (#7AC9C3) against navy for readability; */ /* the v2 light-mode teal (#0E6B6B) is too dark to read against a dark page bg. */ .dark-mode, [data-theme="dark"] { --color-primary: #7AC9C3; --color-primary-dark: #5EB8B5; --color-primary-light: #A6DCD6; --color-accent: #5BC47A; --color-cta: #E8A555; --color-success: #34d399; --color-success-bg: #064e3b; --color-warning: #fbbf24; --color-warning-bg: #78350f; --color-error: #f87171; --color-error-bg: #7f1d1d; --color-info: #22d3ee; --color-info-bg: #164e63; --color-text-primary: #e8e6e3; --color-text-secondary: #b8b4b0; --color-text-muted: #8a8480; --color-text-faint: #625d5b; --color-text-dark: #d4d0cc; --color-text-mid: #a8a4a0; --color-text-light: #88847f; --color-text-lighter: #625d5b; --color-text-lightest: #4a4641; --color-bg-page: #1c1917; --color-bg-card: rgba(40, 36, 33, 0.8); --color-bg-hover: #292524; --color-bg-sidebar: #141210; --color-bg-light: #292524; --color-bg-off-white: #292524; --color-border: rgba(80, 75, 70, 0.6); --color-border-light: rgba(80, 75, 70, 0.3); --color-border-medium: rgba(80, 75, 70, 0.5); --color-border-faint: rgba(80, 75, 70, 0.2); --color-error-alt: #ef4444; --color-warning-alt: #f59e0b; --color-accent-gold: #fbbf24; --color-cat-seo: #34d399; --color-cat-email: #22d3ee; --color-cat-ads: #fbbf24; --color-cat-general: #a78bfa; --glass-bg: rgba(40, 36, 33, 0.8); --glass-bg-elevated: rgba(50, 46, 43, 0.9); --glass-border: 1px solid rgba(80, 75, 70, 0.4); --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3); --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4); --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5); --shadow-glass: 0 4px 24px rgba(0, 0, 0, 0.2); --shadow-glass-elevated: 0 8px 32px rgba(0, 0, 0, 0.3); --color-bg-elevated: rgba(50, 46, 43, 0.9); } @media (prefers-color-scheme: dark) { :root:not(.light-mode) { --color-primary: #7AC9C3; --color-primary-dark: #5EB8B5; --color-primary-light: #A6DCD6; --color-accent: #5BC47A; --color-cta: #E8A555; --color-success: #34d399; --color-success-bg: #064e3b; --color-warning: #fbbf24; --color-warning-bg: #78350f; --color-error: #f87171; --color-error-bg: #7f1d1d; --color-info: #22d3ee; --color-info-bg: #164e63; --color-text-primary: #e8e6e3; --color-text-secondary: #b8b4b0; --color-text-muted: #8a8480; --color-text-faint: #625d5b; --color-text-dark: #d4d0cc; --color-text-mid: #a8a4a0; --color-text-light: #88847f; --color-text-lighter: #625d5b; --color-text-lightest: #4a4641; --color-bg-page: #1c1917; --color-bg-card: rgba(40, 36, 33, 0.8); --color-bg-hover: #292524; --color-bg-sidebar: #141210; --color-bg-light: #292524; --color-bg-off-white: #292524; --color-border: rgba(80, 75, 70, 0.6); --color-border-light: rgba(80, 75, 70, 0.3); --color-border-medium: rgba(80, 75, 70, 0.5); --color-border-faint: rgba(80, 75, 70, 0.2); --color-error-alt: #ef4444; --color-warning-alt: #f59e0b; --color-accent-gold: #fbbf24; --color-cat-seo: #34d399; --color-cat-email: #22d3ee; --color-cat-ads: #fbbf24; --color-cat-general: #a78bfa; --glass-bg: rgba(40, 36, 33, 0.8); --glass-bg-elevated: rgba(50, 46, 43, 0.9); --glass-border: 1px solid rgba(80, 75, 70, 0.4); --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3); --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4); --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5); --shadow-glass: 0 4px 24px rgba(0, 0, 0, 0.2); --shadow-glass-elevated: 0 8px 32px rgba(0, 0, 0, 0.3); --color-bg-elevated: rgba(50, 46, 43, 0.9); } } /* Focus visible — keyboard-only focus rings */ :focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; } :focus:not(:focus-visible) { outline: none; } /* Respect reduced motion preference */ @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } } * { margin: 0; padding: 0; box-sizing: border-box; } html { overflow-y: scroll; } body { font-family: var(--font-family); background: var(--color-bg-page); color: var(--color-text-primary); line-height: 1.6; } html.theme-transition, html.theme-transition *, html.theme-transition *::before, html.theme-transition *::after { transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease !important; } .footer { text-align: center; padding: 2rem 1rem; color: var(--color-text-muted); font-size: 0.8rem; margin-top: auto; } .footer a { color: var(--color-primary); text-decoration: none; } .footer a:hover { text-decoration: underline; } /* ── Buttons ── */ .btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem; padding: 0.5rem 1.1rem; font-family: var(--font-family); font-size: var(--text-base); font-weight: 500; border-radius: var(--radius-md); border: 1px solid transparent; cursor: pointer; text-decoration: none; white-space: nowrap; transition: background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s, opacity 0.15s; line-height: 1; } .btn:active:not(:disabled) { transform: scale(0.97); } .btn:disabled, .btn[disabled] { opacity: 0.45; cursor: not-allowed; pointer-events: none; } .btn-primary { background: var(--color-primary); color: #fff; border-color: var(--color-primary); } .btn-primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); } .btn-primary:active { opacity: 0.9; } .btn-cta { background: var(--color-cta); color: #fff; border-color: var(--color-cta); } .btn-cta:hover { background: #b45309; border-color: #b45309; } .btn-secondary { background: var(--glass-bg); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); color: var(--color-primary); border: 1px solid rgba(14, 107, 107, 0.25); } .btn-secondary:hover { background: var(--color-bg-hover); color: var(--color-primary-dark); border-color: rgba(14, 107, 107, 0.4); } .btn-danger { background: transparent; color: var(--color-error); border-color: var(--color-error); } .btn-danger:hover { background: var(--color-error-bg); } .btn-ghost { background: transparent; border-color: transparent; color: var(--color-text-muted); } .btn-ghost:hover { background: var(--color-bg-hover); color: var(--color-text-primary); } .btn-sm { padding: 0.3rem 0.75rem; font-size: var(--text-sm); border-radius: var(--radius-sm); } .btn-icon { padding: 0.45rem; border-radius: var(--radius-md); aspect-ratio: 1; background: transparent; border-color: var(--color-border); color: var(--color-text-muted); } .btn-icon:hover { background: var(--color-bg-hover); color: var(--color-text-primary); } @media (max-width: 768px) { .btn { min-height: 40px; } } /* ── Forms ── */ .form-group { margin-bottom: 1.25rem; } .form-label { display: block; font-size: var(--text-sm); font-weight: 600; color: var(--color-text-secondary); margin-bottom: 0.4rem; } .form-input, .form-select, .form-textarea { width: 100%; padding: 0.55rem 0.85rem; font-family: var(--font-family); font-size: var(--text-base); color: var(--color-text-primary); background: var(--glass-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); outline: none; transition: border-color 0.15s, box-shadow 0.15s; appearance: none; } .form-input:focus, .form-select:focus, .form-textarea:focus { border-color: rgba(14, 107, 107, 0.5); box-shadow: 0 0 0 3px rgba(14, 107, 107, 0.08); } .dark-mode .form-input:focus, .dark-mode .form-select:focus, .dark-mode .form-textarea:focus { box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.15); } .form-textarea { resize: vertical; min-height: 100px; } .form-select { padding-right: 2rem; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.7rem center; } .form-hint { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: 0.35rem; } .form-error .form-input, .form-error .form-select, .form-error .form-textarea { border-color: var(--color-error); } .form-error-msg { font-size: var(--text-xs); color: var(--color-error); margin-top: 0.35rem; } .form-row { display: flex; gap: 1rem; align-items: flex-start; } .form-row .form-label { min-width: 140px; padding-top: 0.55rem; margin-bottom: 0; } .form-row .form-field { flex: 1; } .form-actions { display: flex; align-items: center; justify-content: flex-end; gap: 0.5rem; padding-top: 0.75rem; } @media (max-width: 768px) { .form-row { flex-direction: column; } .form-row .form-label { min-width: 0; padding-top: 0; } } body { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%); margin: 0; padding: 2rem; } .auth-card { background: var(--color-bg-card); border-radius: 16px; box-shadow: 0 8px 32px rgba(0,0,0,0.3); max-width: 420px; width: 100%; overflow: hidden; } .auth-card-header { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%); padding: 2.5rem 2rem; text-align: center; } .auth-card-header h1 { color: white; margin: 0 0 0.5rem 0; font-size: 1.75rem; font-weight: 700; } .auth-card-header p { color: rgba(255,255,255,0.8); margin: 0; font-size: 0.9375rem; } .auth-card-body { padding: 2rem; } .message { padding: 0.875rem 1rem; border-radius: var(--radius-md); font-size: 0.9375rem; margin-bottom: 1.5rem; } .message.error { background: var(--color-error-bg); border: 1px solid #fca5a5; color: var(--color-error); } .message.success { background: var(--color-success-bg); border: 1px solid #86efac; color: var(--color-success); } /* Auth form overrides */ .auth-card-body .form-input { padding: 0.875rem; box-sizing: border-box; } .auth-card-body .btn { width: 100%; padding: 0.875rem; font-size: 1rem; font-weight: 600; } .back-link { display: block; text-align: center; margin-top: 1.5rem; font-size: 0.875rem; color: var(--color-text-muted); text-decoration: none; } .back-link:hover { color: var(--color-text-primary); text-decoration: underline; }

Forgot Password?

We'll send you a reset link

Enter the email address associated with your account

← Back to Sign In