* { scrollbar-width: thin; scrollbar-color: #334155 transparent; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-thumb { background: #334155; border-radius: 999px; }

body { margin: 0; padding: 0; }

.sidebar-item { transition: all 0.2s ease; }
.sidebar-item:hover, .sidebar-item.active { background: rgba(249,115,22,0.15); color: #f97316; }
.sidebar-item.active { border-right: 3px solid #f97316; }

.menu-card { transition: all 0.2s ease; }
.menu-card:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(0,0,0,0.15); }
.menu-card:active { transform: scale(0.97); }

.fade-in { animation: fadeIn 0.3s ease-out; }
@keyframes fadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

.slide-in { animation: slideIn 0.3s ease-out; }
@keyframes slideIn { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }

.pulse-dot { animation: pulseDot 2s infinite; }
@keyframes pulseDot { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

.badge-bounce { animation: badgeBounce 0.4s ease; }
@keyframes badgeBounce { 0% { transform:scale(0); } 50% { transform:scale(1.3); } 100% { transform:scale(1); } }

.toast-slide { animation: toastSlide 0.3s ease; }
@keyframes toastSlide { from { transform:translateX(100%); opacity:0; } to { transform:translateX(0); opacity:1; } }

/* Project-wide pending state for mobile-friendly button feedback.
   The old global wait cursor was removed because it does not help on mobile
   and made the desktop app feel heavier. Buttons still disable, show spinners,
   and change labels while processing. */
html.is-saving,
html.is-pending,
body.is-saving,
body.is-pending,
html[aria-busy="true"],
body[aria-busy="true"] {
  -webkit-tap-highlight-color: transparent;
}

.btn-processing,
button.btn-processing,
a.btn-processing,
input.btn-processing,
[data-loading-active="true"] {
  opacity: 0.72 !important;
  pointer-events: none !important;
  user-select: none;
}


/* Theme accents. Default orange keeps the original SwiftServe look unchanged. */
:root { --brand-400:#fb923c; --brand-500:#f97316; --brand-600:#ea580c; --brand-700:#c2410c; --brand-soft:rgba(249,115,22,0.15); --brand-ring:rgba(249,115,22,0.30); }
:root[data-theme="blue"] { --brand-400:#60a5fa; --brand-500:#3b82f6; --brand-600:#2563eb; --brand-700:#1d4ed8; --brand-soft:rgba(59,130,246,0.15); --brand-ring:rgba(59,130,246,0.30); }
:root[data-theme="emerald"] { --brand-400:#34d399; --brand-500:#10b981; --brand-600:#059669; --brand-700:#047857; --brand-soft:rgba(16,185,129,0.15); --brand-ring:rgba(16,185,129,0.30); }
:root[data-theme="purple"] { --brand-400:#a78bfa; --brand-500:#8b5cf6; --brand-600:#7c3aed; --brand-700:#6d28d9; --brand-soft:rgba(139,92,246,0.15); --brand-ring:rgba(139,92,246,0.30); }
:root[data-theme="rose"] { --brand-400:#fb7185; --brand-500:#f43f5e; --brand-600:#e11d48; --brand-700:#be123c; --brand-soft:rgba(244,63,94,0.15); --brand-ring:rgba(244,63,94,0.30); }
:root[data-theme="amber"] { --brand-400:#fbbf24; --brand-500:#f59e0b; --brand-600:#d97706; --brand-700:#b45309; --brand-soft:rgba(245,158,11,0.15); --brand-ring:rgba(245,158,11,0.30); }
:root[data-theme="cyan"] { --brand-400:#22d3ee; --brand-500:#06b6d4; --brand-600:#0891b2; --brand-700:#0e7490; --brand-soft:rgba(6,182,212,0.15); --brand-ring:rgba(6,182,212,0.30); }
:root[data-theme="lime"] { --brand-400:#a3e635; --brand-500:#84cc16; --brand-600:#65a30d; --brand-700:#4d7c0f; --brand-soft:rgba(132,204,22,0.15); --brand-ring:rgba(132,204,22,0.30); }
:root[data-theme="pink"] { --brand-400:#f472b6; --brand-500:#ec4899; --brand-600:#db2777; --brand-700:#be185d; --brand-soft:rgba(236,72,153,0.15); --brand-ring:rgba(236,72,153,0.30); }
:root[data-theme="slate"] { --brand-400:#94a3b8; --brand-500:#64748b; --brand-600:#475569; --brand-700:#334155; --brand-soft:rgba(100,116,139,0.18); --brand-ring:rgba(100,116,139,0.32); }

.bg-brand-500, .hover\:bg-brand-500:hover { background-color: var(--brand-500) !important; }
.bg-brand-600, .hover\:bg-brand-600:hover { background-color: var(--brand-600) !important; }
.bg-brand-700, .hover\:bg-brand-700:hover { background-color: var(--brand-700) !important; }
.bg-brand-500\/20 { background-color: var(--brand-soft) !important; }
.bg-brand-500\/15 { background-color: var(--brand-soft) !important; }
.bg-brand-500\/10 { background-color: color-mix(in srgb, var(--brand-500) 10%, transparent) !important; }
.text-brand-300, .hover\:text-brand-300:hover { color: color-mix(in srgb, var(--brand-400) 80%, white) !important; }
.text-brand-400, .hover\:text-brand-400:hover { color: var(--brand-400) !important; }
.text-brand-500 { color: var(--brand-500) !important; }
.border-brand-500, .focus\:border-brand-500:focus { border-color: var(--brand-500) !important; }
.border-brand-500\/30 { border-color: var(--brand-ring) !important; }
.from-brand-500 { --tw-gradient-from: var(--brand-500) var(--tw-gradient-from-position) !important; --tw-gradient-to: color-mix(in srgb, var(--brand-500) 0%, transparent) var(--tw-gradient-to-position) !important; --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important; }
.to-brand-600 { --tw-gradient-to: var(--brand-600) var(--tw-gradient-to-position) !important; }
.to-brand-700 { --tw-gradient-to: var(--brand-700) var(--tw-gradient-to-position) !important; }
.hover\:from-brand-600:hover { --tw-gradient-from: var(--brand-600) var(--tw-gradient-from-position) !important; --tw-gradient-to: color-mix(in srgb, var(--brand-600) 0%, transparent) var(--tw-gradient-to-position) !important; --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important; }
.hover\:to-brand-700:hover { --tw-gradient-to: var(--brand-700) var(--tw-gradient-to-position) !important; }
.sidebar-item:hover, .sidebar-item.active { background: var(--brand-soft) !important; color: var(--brand-500) !important; }
.sidebar-item.active { border-right-color: var(--brand-500) !important; }


/* Light mode theme tokens. Dark mode remains the default/original SwiftServe look. */
:root[data-mode="light"] { color-scheme: light; }
:root[data-mode="light"] body { background: #f8fafc !important; color: #0f172a !important; }
:root[data-mode="light"] .bg-surface-950 { background-color: #f8fafc !important; }
:root[data-mode="light"] .bg-surface-950\/80 { background-color: rgba(248,250,252,0.86) !important; }
:root[data-mode="light"] .bg-surface-900 { background-color: #ffffff !important; }
:root[data-mode="light"] .bg-surface-800 { background-color: #f1f5f9 !important; }
:root[data-mode="light"] .bg-surface-800\/60 { background-color: rgba(241,245,249,0.72) !important; }
:root[data-mode="light"] .bg-surface-800\/50 { background-color: rgba(241,245,249,0.62) !important; }
:root[data-mode="light"] .bg-surface-700\/50 { background-color: rgba(203,213,225,0.62) !important; }
:root[data-mode="light"] .hover\:bg-surface-800:hover { background-color: #e2e8f0 !important; }
:root[data-mode="light"] .hover\:bg-surface-700:hover { background-color: #cbd5e1 !important; }
:root[data-mode="light"] .hover\:bg-surface-700\/50:hover { background-color: rgba(203,213,225,0.62) !important; }
:root[data-mode="light"] .text-white { color: #0f172a !important; }
:root[data-mode="light"] .text-surface-100 { color: #0f172a !important; }
:root[data-mode="light"] .text-surface-200 { color: #1e293b !important; }
:root[data-mode="light"] .text-surface-300 { color: #334155 !important; }
:root[data-mode="light"] .text-surface-400 { color: #64748b !important; }
:root[data-mode="light"] .text-surface-500 { color: #64748b !important; }
:root[data-mode="light"] .border-surface-700\/50 { border-color: rgba(203,213,225,0.9) !important; }
:root[data-mode="light"] .border-surface-700\/40 { border-color: rgba(203,213,225,0.8) !important; }
:root[data-mode="light"] .border-surface-700\/30 { border-color: rgba(203,213,225,0.7) !important; }
:root[data-mode="light"] .divide-surface-700\/30 > :not([hidden]) ~ :not([hidden]) { border-color: rgba(203,213,225,0.7) !important; }
:root[data-mode="light"] input,
:root[data-mode="light"] select,
:root[data-mode="light"] textarea { background-color: #f8fafc !important; color: #0f172a !important; }
:root[data-mode="light"] input::placeholder,
:root[data-mode="light"] textarea::placeholder { color: #94a3b8 !important; }
:root[data-mode="light"] .shadow-2xl { box-shadow: 0 24px 60px rgba(15,23,42,0.18) !important; }
:root[data-mode="light"] [data-company-logo] i,
:root[data-mode="light"] .bg-gradient-to-br i,
:root[data-mode="light"] .bg-brand-500 i,
:root[data-mode="light"] .from-brand-500 i { color: #ffffff !important; }
:root[data-mode="light"] .sidebar-item.active,
:root[data-mode="light"] .sidebar-item:hover { color: var(--brand-600) !important; }
:root[data-mode="light"] .bg-brand-500.text-white,
:root[data-mode="light"] .from-brand-500.text-white,
:root[data-mode="light"] button.bg-brand-500,
:root[data-mode="light"] button[class*="from-brand-500"],
:root[data-mode="light"] a.bg-brand-500,
:root[data-mode="light"] .file\:text-white::file-selector-button { color: #ffffff !important; }
