/* 16. wwwroot/css/elegant-styles.css - Custom Elegant Styling */

/* Import fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:wght@400;500;600;700&display=swap');

/* Root variables for consistent theming */
:root {
    --elegant-border-radius: 12px;
    --elegant-shadow-light: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --elegant-shadow-medium: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --elegant-shadow-large: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    --elegant-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Glass morphism effects */
.glass-card {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: var(--elegant-shadow-medium);
    border-radius: var(--elegant-border-radius);
}

.glass-card-dark {
    background: rgba(30, 41, 59, 0.1);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(148, 163, 184, 0.2);
}

/* Elegant button styles */
.elegant-button {
    background: linear-gradient(45deg, #1e40af, #3b82f6);
    border: none;
    box-shadow: var(--elegant-shadow-light);
    transition: var(--elegant-transition);
    border-radius: var(--elegant-border-radius);
}

    .elegant-button:hover {
        transform: translateY(-2px);
        box-shadow: var(--elegant-shadow-medium);
    }

    .elegant-button:active {
        transform: translateY(0);
    }

/* Floating card animations */
.floating-card {
    transition: var(--elegant-transition);
    border-radius: var(--elegant-border-radius);
}

    .floating-card:hover {
        transform: translateY(-4px);
        box-shadow: var(--elegant-shadow-large);
    }

/* Gradient text */
.gradient-text {
    background: linear-gradient(45deg, #1e40af, #7c3aed);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.gradient-text-restaurant {
    background: linear-gradient(45deg, #ea580c, #dc2626);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Animated borders */
.animated-border {
    position: relative;
    overflow: hidden;
}

    .animated-border::before {
        content: '';
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(90deg, transparent, rgba(59, 130, 246, 0.4), transparent);
        transition: left 0.5s;
    }

    .animated-border:hover::before {
        left: 100%;
    }

/* Layout specific styles */
.elegant-appbar {
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(148, 163, 184, 0.1);
}

.elegant-drawer {
    border-right: 1px solid rgba(148, 163, 184, 0.1);
}

.elegant-drawer-header {
    background: linear-gradient(135deg, rgba(30, 64, 175, 0.1), rgba(124, 58, 237, 0.1));
    border-bottom: 1px solid rgba(148, 163, 184, 0.1);
}

.elegant-main-content {
    min-height: calc(100vh - 64px);
    background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
}

.elegant-footer {
    background: rgba(255, 255, 255, 0.8);
    border-top: 1px solid rgba(148, 163, 184, 0.1);
    backdrop-filter: blur(10px);
}

/* Navigation styles */
.nav-menu .nav-button {
    margin: 0 4px;
    border-radius: 8px;
    transition: var(--elegant-transition);
}

    .nav-menu .nav-button:hover {
        transform: translateY(-1px);
        box-shadow: var(--elegant-shadow-light);
    }

.desktop-nav {
    display: flex;
    align-items: center;
}

.mobile-nav {
    width: 100%;
}

/* Theme switcher styles */
.theme-switcher .mud-menu {
    border-radius: var(--elegant-border-radius);
}

/* User menu styles */
.user-menu .mud-avatar {
    transition: var(--elegant-transition);
}

    .user-menu .mud-avatar:hover {
        transform: scale(1.05);
    }

.white-text {
    color: white !important;
}

/* Responsive utilities */
@media (max-width: 960px) {
    .elegant-main-content {
        padding-top: 0;
    }

    .elegant-footer {
        margin-top: 2rem;
    }
}

/* Dark mode adjustments */
.mud-theme-dark .elegant-main-content {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
}

.mud-theme-dark .elegant-appbar {
    border-bottom-color: rgba(71, 85, 105, 0.3);
}

.mud-theme-dark .elegant-drawer {
    border-right-color: rgba(71, 85, 105, 0.3);
}

.mud-theme-dark .elegant-footer {
    background: rgba(30, 41, 59, 0.8);
    border-top-color: rgba(71, 85, 105, 0.3);
}

/* Loading and transition effects */
.page-transition-enter {
    opacity: 0;
    transform: translateY(20px);
}

.page-transition-enter-active {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 300ms, transform 300ms;
}

.page-transition-exit {
    opacity: 1;
    transform: translateY(0);
}

.page-transition-exit-active {
    opacity: 0;
    transform: translateY(-20px);
    transition: opacity 300ms, transform 300ms;
}

/* Custom scrollbar */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: rgba(148, 163, 184, 0.1);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.3);
    border-radius: 4px;
    transition: var(--elegant-transition);
}

    ::-webkit-scrollbar-thumb:hover {
        background: rgba(148, 163, 184, 0.5);
    }

/* Accessibility improvements */
.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;
}

/* Focus styles */
.mud-button:focus-visible,
.mud-icon-button:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* Animation keyframes */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

.animate-fade-in-up {
    animation: fadeInUp 0.6s ease-out;
}

.animate-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* Utility classes */
.text-shadow {
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.backdrop-blur {
    backdrop-filter: blur(10px);
}

.border-gradient {
    border: 1px solid;
    border-image: linear-gradient(45deg, #3b82f6, #8b5cf6) 1;
}

/* Print styles */
@media print {
    .elegant-appbar,
    .elegant-drawer,
    .theme-switcher,
    .user-menu {
        display: none !important;
    }

    .elegant-main-content {
        margin: 0 !important;
        padding: 0 !important;
    }
}
