781 lines
14 KiB
CSS
781 lines
14 KiB
CSS
@tailwind base;
|
|
@tailwind components;
|
|
@tailwind utilities;
|
|
|
|
@layer base {
|
|
:root {
|
|
color-scheme: light;
|
|
/* Light Mode - Smart-Admin Copilot Palette */
|
|
--background: 210 40% 98%;
|
|
--foreground: 222 47% 11%;
|
|
--card: 210 40% 98%;
|
|
--card-foreground: 222 47% 11%;
|
|
--popover: 0 0% 100%;
|
|
--popover-foreground: 222 47% 11%;
|
|
--primary: 221 83% 53%;
|
|
--primary-foreground: 0 0% 100%;
|
|
--secondary: 168 76% 40%;
|
|
--secondary-foreground: 0 0% 100%;
|
|
--accent: 262 83% 58%;
|
|
--accent-foreground: 0 0% 100%;
|
|
--muted: 210 40% 96%;
|
|
--muted-foreground: 215 16% 47%;
|
|
--destructive: 0 84% 60%;
|
|
--destructive-foreground: 0 0% 98%;
|
|
--border: 214 32% 91%;
|
|
--input: 214 32% 91%;
|
|
--ring: 221 83% 53%;
|
|
--radius: 0.75rem;
|
|
|
|
/* Custom Colors */
|
|
--success: 160 84% 39%;
|
|
--warning: 38 92% 50%;
|
|
--royal-blue: 221 83% 53%;
|
|
--teal: 168 76% 40%;
|
|
--violet: 262 83% 58%;
|
|
--emerald: 160 84% 39%;
|
|
--amber: 38 92% 50%;
|
|
--deep-slate: 222 47% 11%;
|
|
--medium-slate: 215 16% 47%;
|
|
--light-slate: 214 32% 91%;
|
|
--off-white: 210 40% 98%;
|
|
}
|
|
|
|
.dark {
|
|
color-scheme: dark;
|
|
/* Dark Mode - Smart-Admin Copilot Palette */
|
|
--background: 222 47% 5%;
|
|
--foreground: 210 40% 98%;
|
|
--card: 217 33% 17%;
|
|
--card-foreground: 210 40% 98%;
|
|
--popover: 217 33% 17%;
|
|
--popover-foreground: 210 40% 98%;
|
|
--primary: 217 91% 60%;
|
|
--primary-foreground: 0 0% 100%;
|
|
--secondary: 189 94% 43%;
|
|
--secondary-foreground: 0 0% 100%;
|
|
--accent: 258 90% 66%;
|
|
--accent-foreground: 0 0% 100%;
|
|
--muted: 217 33% 17%;
|
|
--muted-foreground: 215 20% 65%;
|
|
--destructive: 0 62% 30%;
|
|
--destructive-foreground: 0 0% 98%;
|
|
--border: 217 33% 25%;
|
|
--input: 217 33% 25%;
|
|
--ring: 217 91% 60%;
|
|
|
|
/* Custom Dark Colors */
|
|
--success: 158 64% 52%;
|
|
--warning: 48 96% 53%;
|
|
--bright-blue: 217 91% 60%;
|
|
--cyan: 189 94% 43%;
|
|
--purple: 258 90% 76%;
|
|
--green: 158 64% 52%;
|
|
--dark-slate: 217 33% 17%;
|
|
--almost-white: 210 40% 98%;
|
|
}
|
|
}
|
|
|
|
@layer base {
|
|
* {
|
|
@apply border-border;
|
|
}
|
|
|
|
html {
|
|
scroll-behavior: smooth;
|
|
}
|
|
|
|
body {
|
|
@apply bg-background text-foreground antialiased;
|
|
font-feature-settings:
|
|
"rlig" 1,
|
|
"calt" 1;
|
|
}
|
|
* {
|
|
@apply border-border;
|
|
}
|
|
|
|
body {
|
|
@apply bg-background text-foreground;
|
|
font-feature-settings:
|
|
"rlig" 1,
|
|
"calt" 1;
|
|
}
|
|
|
|
/* Smooth scrolling */
|
|
html {
|
|
scroll-behavior: smooth;
|
|
}
|
|
|
|
/* Better font rendering */
|
|
body {
|
|
-webkit-font-smoothing: antialiased;
|
|
-moz-osx-font-smoothing: grayscale;
|
|
text-rendering: optimizeLegibility;
|
|
}
|
|
|
|
/* Selection styles */
|
|
::selection {
|
|
@apply bg-primary/20;
|
|
}
|
|
|
|
/* Focus styles */
|
|
:focus-visible {
|
|
@apply outline-none ring-2 ring-primary ring-offset-2;
|
|
}
|
|
|
|
/* Global branded scrollbar */
|
|
* {
|
|
scrollbar-width: thin;
|
|
scrollbar-color: hsl(var(--primary) / 0.65) hsl(var(--muted));
|
|
}
|
|
|
|
*::-webkit-scrollbar {
|
|
width: 11px;
|
|
height: 11px;
|
|
}
|
|
|
|
*::-webkit-scrollbar-track {
|
|
background: linear-gradient(
|
|
180deg,
|
|
hsl(var(--muted)) 0%,
|
|
hsl(var(--background)) 100%
|
|
);
|
|
border-radius: 999px;
|
|
}
|
|
|
|
*::-webkit-scrollbar-thumb {
|
|
background: linear-gradient(
|
|
180deg,
|
|
hsl(var(--primary) / 0.85) 0%,
|
|
hsl(var(--secondary) / 0.8) 100%
|
|
);
|
|
border: 2px solid hsl(var(--background));
|
|
border-radius: 999px;
|
|
}
|
|
|
|
*::-webkit-scrollbar-thumb:hover {
|
|
background: linear-gradient(
|
|
180deg,
|
|
hsl(var(--primary)) 0%,
|
|
hsl(var(--accent) / 0.95) 100%
|
|
);
|
|
}
|
|
|
|
.dark * {
|
|
scrollbar-color: hsl(var(--primary) / 0.8) hsl(var(--muted));
|
|
}
|
|
|
|
.dark *::-webkit-scrollbar-track {
|
|
background: linear-gradient(
|
|
180deg,
|
|
hsl(var(--muted)) 0%,
|
|
hsl(var(--background) / 0.92) 100%
|
|
);
|
|
}
|
|
|
|
.dark *::-webkit-scrollbar-thumb {
|
|
border-color: hsl(var(--background));
|
|
}
|
|
}
|
|
|
|
@layer utilities {
|
|
/* Gradient Text */
|
|
.gradient-text {
|
|
@apply bg-clip-text text-transparent;
|
|
background-image: linear-gradient(
|
|
135deg,
|
|
hsl(var(--primary)) 0%,
|
|
hsl(var(--accent)) 50%,
|
|
hsl(var(--secondary)) 100%
|
|
);
|
|
}
|
|
|
|
.gradient-text-hero-light {
|
|
@apply bg-clip-text text-transparent;
|
|
background-image: linear-gradient(
|
|
135deg,
|
|
#0f172a 0%,
|
|
#1e40af 50%,
|
|
#0f172a 100%
|
|
);
|
|
}
|
|
|
|
.gradient-text-hero-dark {
|
|
@apply bg-clip-text text-transparent;
|
|
background-image: linear-gradient(
|
|
135deg,
|
|
#f8fafc 0%,
|
|
#93c5fd 50%,
|
|
#f8fafc 100%
|
|
);
|
|
}
|
|
|
|
/* Glass Morphism */
|
|
.glass {
|
|
@apply backdrop-blur-xl;
|
|
background: rgba(255, 255, 255, 0.7);
|
|
border: 1px solid rgba(226, 232, 240, 0.5);
|
|
}
|
|
|
|
.dark .glass {
|
|
background: rgba(30, 41, 59, 0.7);
|
|
border: 1px solid rgba(51, 65, 85, 0.5);
|
|
}
|
|
|
|
.glass-strong {
|
|
@apply backdrop-blur-2xl;
|
|
background: rgba(255, 255, 255, 0.85);
|
|
border: 1px solid rgba(226, 232, 240, 0.6);
|
|
}
|
|
|
|
.dark .glass-strong {
|
|
background: rgba(15, 23, 42, 0.85);
|
|
border: 1px solid rgba(51, 65, 85, 0.6);
|
|
}
|
|
|
|
/* Gradient Backgrounds */
|
|
.gradient-bg-mesh {
|
|
background:
|
|
radial-gradient(
|
|
ellipse at 20% 20%,
|
|
rgba(59, 130, 246, 0.15) 0%,
|
|
transparent 50%
|
|
),
|
|
radial-gradient(
|
|
ellipse at 80% 80%,
|
|
rgba(139, 92, 246, 0.15) 0%,
|
|
transparent 50%
|
|
),
|
|
radial-gradient(
|
|
ellipse at 50% 50%,
|
|
rgba(20, 184, 166, 0.1) 0%,
|
|
transparent 60%
|
|
);
|
|
}
|
|
|
|
.dark .gradient-bg-mesh {
|
|
background:
|
|
radial-gradient(
|
|
ellipse at 20% 20%,
|
|
rgba(59, 130, 246, 0.2) 0%,
|
|
transparent 50%
|
|
),
|
|
radial-gradient(
|
|
ellipse at 80% 80%,
|
|
rgba(139, 92, 246, 0.2) 0%,
|
|
transparent 50%
|
|
),
|
|
radial-gradient(
|
|
ellipse at 50% 50%,
|
|
rgba(6, 182, 212, 0.15) 0%,
|
|
transparent 60%
|
|
);
|
|
}
|
|
|
|
/* Button Gradients */
|
|
.btn-gradient {
|
|
background: linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.btn-gradient:hover {
|
|
background: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);
|
|
transform: scale(1.05);
|
|
box-shadow: 0 0 40px rgba(59, 130, 246, 0.4);
|
|
}
|
|
|
|
/* Glow Effects */
|
|
.glow-blue {
|
|
box-shadow: 0 0 40px rgba(59, 130, 246, 0.4);
|
|
}
|
|
|
|
.glow-violet {
|
|
box-shadow: 0 0 40px rgba(139, 92, 246, 0.4);
|
|
}
|
|
|
|
.glow-teal {
|
|
box-shadow: 0 0 40px rgba(20, 184, 166, 0.4);
|
|
}
|
|
|
|
/* Card Gradients */
|
|
.card-gradient-blue {
|
|
background: linear-gradient(
|
|
135deg,
|
|
rgba(37, 99, 235, 0.1) 0%,
|
|
rgba(139, 92, 246, 0.1) 100%
|
|
);
|
|
}
|
|
|
|
.card-gradient-teal {
|
|
background: linear-gradient(
|
|
135deg,
|
|
rgba(20, 184, 166, 0.1) 0%,
|
|
rgba(6, 182, 212, 0.1) 100%
|
|
);
|
|
}
|
|
|
|
.card-gradient-violet {
|
|
background: linear-gradient(
|
|
135deg,
|
|
rgba(139, 92, 246, 0.1) 0%,
|
|
rgba(168, 85, 247, 0.1) 100%
|
|
);
|
|
}
|
|
|
|
.card-gradient-amber {
|
|
background: linear-gradient(
|
|
135deg,
|
|
rgba(245, 158, 11, 0.1) 0%,
|
|
rgba(249, 115, 22, 0.1) 100%
|
|
);
|
|
}
|
|
|
|
.card-gradient-emerald {
|
|
background: linear-gradient(
|
|
135deg,
|
|
rgba(16, 185, 129, 0.1) 0%,
|
|
rgba(34, 197, 94, 0.1) 100%
|
|
);
|
|
}
|
|
|
|
/* Animated Border */
|
|
.animated-border {
|
|
position: relative;
|
|
background:
|
|
linear-gradient(var(--background), var(--background)) padding-box,
|
|
linear-gradient(
|
|
135deg,
|
|
hsl(var(--primary)),
|
|
hsl(var(--accent)),
|
|
hsl(var(--secondary))
|
|
)
|
|
border-box;
|
|
border: 1px solid transparent;
|
|
}
|
|
|
|
/* Noise Texture */
|
|
.noise-texture {
|
|
position: relative;
|
|
}
|
|
|
|
.noise-texture::before {
|
|
content: "";
|
|
position: absolute;
|
|
inset: 0;
|
|
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
|
|
opacity: 0.03;
|
|
pointer-events: none;
|
|
z-index: 1;
|
|
}
|
|
|
|
/* Grid Pattern */
|
|
.grid-pattern {
|
|
background-image:
|
|
linear-gradient(rgba(148, 163, 184, 0.1) 1px, transparent 1px),
|
|
linear-gradient(90deg, rgba(148, 163, 184, 0.1) 1px, transparent 1px);
|
|
background-size: 40px 40px;
|
|
}
|
|
|
|
.dark .grid-pattern {
|
|
background-image:
|
|
linear-gradient(rgba(71, 85, 105, 0.2) 1px, transparent 1px),
|
|
linear-gradient(90deg, rgba(71, 85, 105, 0.2) 1px, transparent 1px);
|
|
}
|
|
|
|
/* 3D Transform */
|
|
.perspective-1000 {
|
|
perspective: 1000px;
|
|
}
|
|
|
|
.transform-3d {
|
|
transform-style: preserve-3d;
|
|
}
|
|
|
|
/* Hide scrollbar */
|
|
.hide-scrollbar {
|
|
-ms-overflow-style: none;
|
|
scrollbar-width: none;
|
|
}
|
|
|
|
.hide-scrollbar::-webkit-scrollbar {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
/* Custom Animations */
|
|
@keyframes float {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0px);
|
|
}
|
|
50% {
|
|
transform: translateY(-20px);
|
|
}
|
|
}
|
|
|
|
@keyframes float-slow {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0px) translateX(0px);
|
|
}
|
|
50% {
|
|
transform: translateY(-15px) translateX(10px);
|
|
}
|
|
}
|
|
|
|
@keyframes pulse-glow {
|
|
0%,
|
|
100% {
|
|
box-shadow: 0 0 20px rgba(59, 130, 246, 0.3);
|
|
}
|
|
50% {
|
|
box-shadow: 0 0 40px rgba(59, 130, 246, 0.6);
|
|
}
|
|
}
|
|
|
|
@keyframes gradient-shift {
|
|
0% {
|
|
background-position: 0% 50%;
|
|
}
|
|
50% {
|
|
background-position: 100% 50%;
|
|
}
|
|
100% {
|
|
background-position: 0% 50%;
|
|
}
|
|
}
|
|
|
|
@keyframes shimmer {
|
|
0% {
|
|
background-position: -200% 0;
|
|
}
|
|
100% {
|
|
background-position: 200% 0;
|
|
}
|
|
}
|
|
|
|
@keyframes spin-slow {
|
|
from {
|
|
transform: rotate(0deg);
|
|
}
|
|
to {
|
|
transform: rotate(360deg);
|
|
}
|
|
}
|
|
|
|
@keyframes bounce-subtle {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0);
|
|
}
|
|
50% {
|
|
transform: translateY(-5px);
|
|
}
|
|
}
|
|
|
|
@keyframes slide-up {
|
|
from {
|
|
opacity: 0;
|
|
transform: translateY(30px);
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
|
|
@keyframes slide-down {
|
|
from {
|
|
opacity: 0;
|
|
transform: translateY(-30px);
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
|
|
@keyframes fade-in {
|
|
from {
|
|
opacity: 0;
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
}
|
|
}
|
|
|
|
@keyframes scale-in {
|
|
from {
|
|
opacity: 0;
|
|
transform: scale(0.9);
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
transform: scale(1);
|
|
}
|
|
}
|
|
|
|
@keyframes count-up {
|
|
from {
|
|
opacity: 0;
|
|
transform: translateY(10px);
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
|
|
@keyframes draw-line {
|
|
from {
|
|
stroke-dashoffset: 1000;
|
|
}
|
|
to {
|
|
stroke-dashoffset: 0;
|
|
}
|
|
}
|
|
|
|
@keyframes particle-float {
|
|
0%,
|
|
100% {
|
|
transform: translateY(0) translateX(0);
|
|
opacity: 0.5;
|
|
}
|
|
25% {
|
|
transform: translateY(-30px) translateX(10px);
|
|
opacity: 0.8;
|
|
}
|
|
50% {
|
|
transform: translateY(-20px) translateX(-10px);
|
|
opacity: 0.6;
|
|
}
|
|
75% {
|
|
transform: translateY(-40px) translateX(5px);
|
|
opacity: 0.9;
|
|
}
|
|
}
|
|
|
|
@keyframes ring {
|
|
0% {
|
|
transform: rotate(0deg);
|
|
}
|
|
25% {
|
|
transform: rotate(15deg);
|
|
}
|
|
50% {
|
|
transform: rotate(0deg);
|
|
}
|
|
75% {
|
|
transform: rotate(-15deg);
|
|
}
|
|
100% {
|
|
transform: rotate(0deg);
|
|
}
|
|
}
|
|
|
|
/* Animation Classes */
|
|
.animate-float {
|
|
animation: float 6s ease-in-out infinite;
|
|
}
|
|
|
|
.animate-float-slow {
|
|
animation: float-slow 8s ease-in-out infinite;
|
|
}
|
|
|
|
.animate-float-delayed {
|
|
animation: float 6s ease-in-out infinite;
|
|
animation-delay: 2s;
|
|
}
|
|
|
|
.animate-pulse-glow {
|
|
animation: pulse-glow 3s ease-in-out infinite;
|
|
}
|
|
|
|
.animate-gradient-shift {
|
|
background-size: 200% 200%;
|
|
animation: gradient-shift 8s ease infinite;
|
|
}
|
|
|
|
.animate-shimmer {
|
|
background: linear-gradient(
|
|
90deg,
|
|
transparent,
|
|
rgba(255, 255, 255, 0.2),
|
|
transparent
|
|
);
|
|
background-size: 200% 100%;
|
|
animation: shimmer 2s infinite;
|
|
}
|
|
|
|
.animate-spin-slow {
|
|
animation: spin-slow 20s linear infinite;
|
|
}
|
|
|
|
.animate-bounce-subtle {
|
|
animation: bounce-subtle 2s ease-in-out infinite;
|
|
}
|
|
|
|
.animate-slide-up {
|
|
animation: slide-up 0.6s ease-out forwards;
|
|
}
|
|
|
|
.animate-slide-down {
|
|
animation: slide-down 0.6s ease-out forwards;
|
|
}
|
|
|
|
.animate-fade-in {
|
|
animation: fade-in 0.5s ease-out forwards;
|
|
}
|
|
|
|
.animate-scale-in {
|
|
animation: scale-in 0.5s ease-out forwards;
|
|
}
|
|
|
|
.animate-particle-float {
|
|
animation: particle-float 10s ease-in-out infinite;
|
|
}
|
|
|
|
.animate-ring {
|
|
animation: ring 0.5s ease-in-out;
|
|
}
|
|
|
|
/* Stagger Animation Delays */
|
|
.stagger-1 {
|
|
animation-delay: 0.1s;
|
|
}
|
|
.stagger-2 {
|
|
animation-delay: 0.2s;
|
|
}
|
|
.stagger-3 {
|
|
animation-delay: 0.3s;
|
|
}
|
|
.stagger-4 {
|
|
animation-delay: 0.4s;
|
|
}
|
|
.stagger-5 {
|
|
animation-delay: 0.5s;
|
|
}
|
|
.stagger-6 {
|
|
animation-delay: 0.6s;
|
|
}
|
|
.stagger-7 {
|
|
animation-delay: 0.7s;
|
|
}
|
|
.stagger-8 {
|
|
animation-delay: 0.8s;
|
|
}
|
|
|
|
/* Scroll Animation Classes */
|
|
.scroll-animate {
|
|
opacity: 0;
|
|
transform: translateY(30px);
|
|
transition:
|
|
opacity 0.6s ease-out,
|
|
transform 0.6s ease-out;
|
|
}
|
|
|
|
.scroll-animate.visible {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
|
|
.scroll-animate-left {
|
|
opacity: 0;
|
|
transform: translateX(-50px);
|
|
transition:
|
|
opacity 0.6s ease-out,
|
|
transform 0.6s ease-out;
|
|
}
|
|
|
|
.scroll-animate-left.visible {
|
|
opacity: 1;
|
|
transform: translateX(0);
|
|
}
|
|
|
|
.scroll-animate-right {
|
|
opacity: 0;
|
|
transform: translateX(50px);
|
|
transition:
|
|
opacity 0.6s ease-out,
|
|
transform 0.6s ease-out;
|
|
}
|
|
|
|
.scroll-animate-right.visible {
|
|
opacity: 1;
|
|
transform: translateX(0);
|
|
}
|
|
|
|
.scroll-animate-scale {
|
|
opacity: 0;
|
|
transform: scale(0.9);
|
|
transition:
|
|
opacity 0.6s ease-out,
|
|
transform 0.6s ease-out;
|
|
}
|
|
|
|
.scroll-animate-scale.visible {
|
|
opacity: 1;
|
|
transform: scale(1);
|
|
}
|
|
|
|
/* Hover Effects */
|
|
.hover-lift {
|
|
transition:
|
|
transform 0.3s ease,
|
|
box-shadow 0.3s ease;
|
|
}
|
|
|
|
.hover-lift:hover {
|
|
transform: translateY(-4px);
|
|
box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
|
|
}
|
|
|
|
.dark .hover-lift:hover {
|
|
box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
|
|
}
|
|
|
|
.hover-scale {
|
|
transition: transform 0.3s ease;
|
|
}
|
|
|
|
.hover-scale:hover {
|
|
transform: scale(1.05);
|
|
}
|
|
|
|
.hover-glow {
|
|
transition: box-shadow 0.3s ease;
|
|
}
|
|
|
|
.hover-glow:hover {
|
|
box-shadow: 0 0 30px rgba(59, 130, 246, 0.4);
|
|
}
|
|
|
|
/* Focus States */
|
|
.focus-ring:focus-visible {
|
|
outline: none;
|
|
ring: 2px;
|
|
ring-color: hsl(var(--ring));
|
|
ring-offset: 2px;
|
|
ring-offset-color: hsl(var(--background));
|
|
}
|
|
|
|
/* Reduced Motion */
|
|
@media (prefers-reduced-motion: reduce) {
|
|
*,
|
|
*::before,
|
|
*::after {
|
|
animation-duration: 0.01ms !important;
|
|
animation-iteration-count: 1 !important;
|
|
transition-duration: 0.01ms !important;
|
|
}
|
|
|
|
.scroll-animate,
|
|
.scroll-animate-left,
|
|
.scroll-animate-right,
|
|
.scroll-animate-scale {
|
|
opacity: 1;
|
|
transform: none;
|
|
}
|
|
}
|