@import "tailwindcss"; @import "tw-animate-css"; @custom-variant dark (&:is(.dark *)); @theme inline { --color-background: hsl(var(--background)); --color-foreground: hsl(var(--foreground)); --color-border: hsl(var(--border)); --color-input: hsl(var(--input)); --color-ring: hsl(var(--ring)); --color-card: hsl(var(--card)); --color-card-foreground: hsl(var(--card-foreground)); --color-primary: hsl(var(--primary)); --color-primary-foreground: hsl(var(--primary-foreground)); --color-secondary: hsl(var(--secondary)); --color-secondary-foreground: hsl(var(--secondary-foreground)); --color-muted: hsl(var(--muted)); --color-muted-foreground: hsl(var(--muted-foreground)); --color-accent: hsl(var(--accent)); --color-accent-foreground: hsl(var(--accent-foreground)); --color-destructive: hsl(var(--destructive)); --color-destructive-foreground: hsl(var(--destructive-foreground)); --font-sans: var(--app-font-sans); --radius-sm: calc(var(--radius) - 4px); --radius-md: calc(var(--radius) - 2px); --radius-lg: var(--radius); } :root { --background: 0 0% 4%; --foreground: 0 0% 98%; --border: 0 0% 14%; --input: 0 0% 14%; --ring: 25 100% 50%; --card: 0 0% 8%; --card-foreground: 0 0% 98%; --primary: 25 100% 50%; --primary-foreground: 0 0% 100%; --secondary: 0 0% 12%; --secondary-foreground: 0 0% 90%; --muted: 0 0% 12%; --muted-foreground: 0 0% 55%; --accent: 25 100% 50%; --accent-foreground: 0 0% 100%; --destructive: 0 84% 60%; --destructive-foreground: 0 0% 98%; --app-font-sans: 'Cairo', 'Segoe UI', sans-serif; --radius: 0.75rem; } @layer base { * { @apply border-border; } body { @apply bg-background text-foreground antialiased; direction: rtl; font-family: 'Cairo', 'Segoe UI', system-ui, sans-serif; } html { scroll-behavior: smooth; } } /* Extra brand scrollbar */ ::-webkit-scrollbar { width: 6px; height: 6px; } ::-webkit-scrollbar-track { background: hsl(var(--background)); } ::-webkit-scrollbar-thumb { background: hsl(var(--primary)); border-radius: 3px; } /* Image fade-in */ img { transition: opacity 0.3s ease; } img.loaded { opacity: 1; } /* Announcement marquee */ @keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-33.333%); } } /* Toast animations */ @keyframes slideInRight { from { opacity: 0; transform: translateX(100px); } to { opacity: 1; transform: translateX(0); } } @keyframes slideOutRight { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(100px); } } @keyframes slideInLeft { from { opacity: 0; transform: translateX(-60px); } to { opacity: 1; transform: translateX(0); } } @keyframes slideInDown { from { opacity: 0; margin-top: -20px; } to { opacity: 1; margin-top: 0; } }