/**
 * Blueprint Commerce - Admin Premium Design System
 * Premium light theme with distinctive typography and micro-interactions
 */

/* Import Google Fonts - Syne (headers) + Outfit (body) for premium feel */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');

/* ========================================
   CSS VARIABLES - MATERIAL DESIGN PALETTE
   ======================================== */

:root {
    /* === PREMIUM LIGHT THEME COLORS === */

    /* Primary - Professional Blue */
    --md-primary-50: #E8F4FD;
    --md-primary-100: #C5E3FA;
    --md-primary-200: #9DD0F6;
    --md-primary-300: #70BCF2;
    --md-primary-400: #4AACEF;
    --md-primary-500: #0066CC;  /* Main primary - professional blue */
    --md-primary-600: #005BB8;
    --md-primary-700: #004FA3;
    --md-primary-800: #00438E;
    --md-primary-900: #003066;

    /* Accent - Cyan highlights */
    --md-accent-400: #33BBFF;
    --md-accent-500: #00AAFF;  /* Main accent */
    --md-accent-600: #0099E6;
    --md-accent-glow: rgba(0, 170, 255, 0.3);

    /* Secondary - Teal */
    --md-secondary-50: #E0F7F6;
    --md-secondary-100: #B3EBE7;
    --md-secondary-200: #80DED8;
    --md-secondary-300: #4DD1C9;
    --md-secondary-400: #26C6BC;
    --md-secondary-500: #00BBB0;  /* Main secondary */
    --md-secondary-600: #00A99F;
    --md-secondary-700: #00968D;
    --md-secondary-800: #00837B;
    --md-secondary-900: #006259;

    /* Grey Scale - Refined for premium light theme */
    --md-grey-50: #FAFBFC;
    --md-grey-100: #F4F6F8;
    --md-grey-200: #E9ECEF;
    --md-grey-300: #DEE2E6;
    --md-grey-400: #ADB5BD;
    --md-grey-500: #6C757D;
    --md-grey-600: #5A6169;
    --md-grey-700: #495057;
    --md-grey-800: #343A40;
    --md-grey-900: #1A1D21;

    /* Semantic Colors - Modern palette */
    --md-success: #10B981;
    --md-success-light: #34D399;
    --md-success-dark: #059669;

    --md-warning: #F59E0B;
    --md-warning-light: #FBBF24;
    --md-warning-dark: #D97706;

    --md-error: #EF4444;
    --md-error-light: #F87171;
    --md-error-dark: #DC2626;

    --md-info: #0066CC;
    --md-info-light: #4AACEF;
    --md-info-dark: #004FA3;

    /* Background Colors - Premium light */
    --md-bg-page: #FAFBFC;
    --md-bg-card: #FFFFFF;
    --md-bg-hover: rgba(0, 102, 204, 0.04);
    --md-bg-selected: rgba(0, 170, 255, 0.08);

    /* Text Colors - High contrast for readability */
    --md-text-primary: #1A1D21;
    --md-text-secondary: #5A6169;
    --md-text-disabled: #ADB5BD;
    --md-text-hint: #6C757D;

    /* === TYPOGRAPHY === */

    /* Font Families - Premium Syne + Outfit */
    --md-font: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --md-font-display: 'Syne', 'Outfit', sans-serif;
    --md-font-mono: 'JetBrains Mono', 'Consolas', 'Monaco', monospace;

    /* Font Sizes - Material Design Scale */
    --md-text-h1: 6rem;        /* 96px */
    --md-text-h2: 3.75rem;     /* 60px */
    --md-text-h3: 3rem;        /* 48px */
    --md-text-h4: 2.125rem;    /* 34px */
    --md-text-h5: 1.5rem;      /* 24px */
    --md-text-h6: 1.25rem;     /* 20px */
    --md-text-subtitle1: 1rem;      /* 16px */
    --md-text-subtitle2: 0.875rem;  /* 14px */
    --md-text-body1: 1rem;          /* 16px */
    --md-text-body2: 0.875rem;      /* 14px */
    --md-text-button: 0.875rem;     /* 14px */
    --md-text-caption: 0.75rem;     /* 12px */
    --md-text-overline: 0.625rem;   /* 10px */

    /* Font Weights */
    --md-font-light: 300;
    --md-font-regular: 400;
    --md-font-medium: 500;
    --md-font-bold: 700;

    /* Line Heights */
    --md-leading-none: 1;
    --md-leading-tight: 1.25;
    --md-leading-normal: 1.5;
    --md-leading-relaxed: 1.75;

    /* === SPACING === */

    /* Material 8dp grid system */
    --md-space-0: 0;
    --md-space-1: 0.25rem;    /* 4px */
    --md-space-2: 0.5rem;     /* 8px */
    --md-space-3: 0.75rem;    /* 12px */
    --md-space-4: 1rem;       /* 16px */
    --md-space-5: 1.25rem;    /* 20px */
    --md-space-6: 1.5rem;     /* 24px */
    --md-space-8: 2rem;       /* 32px */
    --md-space-10: 2.5rem;    /* 40px */
    --md-space-12: 3rem;      /* 48px */
    --md-space-16: 4rem;      /* 64px */

    /* Container Widths */
    --md-container-sm: 600px;
    --md-container-md: 960px;
    --md-container-lg: 1280px;
    --md-container-xl: 1920px;

    /* === ELEVATION === */

    /* Material Design elevation levels */
    --md-elevation-0: none;
    --md-elevation-1: 0px 2px 1px -1px rgba(0,0,0,0.2), 0px 1px 1px 0px rgba(0,0,0,0.14), 0px 1px 3px 0px rgba(0,0,0,0.12);
    --md-elevation-2: 0px 3px 1px -2px rgba(0,0,0,0.2), 0px 2px 2px 0px rgba(0,0,0,0.14), 0px 1px 5px 0px rgba(0,0,0,0.12);
    --md-elevation-3: 0px 3px 3px -2px rgba(0,0,0,0.2), 0px 3px 4px 0px rgba(0,0,0,0.14), 0px 1px 8px 0px rgba(0,0,0,0.12);
    --md-elevation-4: 0px 2px 4px -1px rgba(0,0,0,0.2), 0px 4px 5px 0px rgba(0,0,0,0.14), 0px 1px 10px 0px rgba(0,0,0,0.12);
    --md-elevation-6: 0px 3px 5px -1px rgba(0,0,0,0.2), 0px 6px 10px 0px rgba(0,0,0,0.14), 0px 1px 18px 0px rgba(0,0,0,0.12);
    --md-elevation-8: 0px 5px 5px -3px rgba(0,0,0,0.2), 0px 8px 10px 1px rgba(0,0,0,0.14), 0px 3px 14px 2px rgba(0,0,0,0.12);
    --md-elevation-12: 0px 7px 8px -4px rgba(0,0,0,0.2), 0px 12px 17px 2px rgba(0,0,0,0.14), 0px 5px 22px 4px rgba(0,0,0,0.12);
    --md-elevation-16: 0px 8px 10px -5px rgba(0,0,0,0.2), 0px 16px 24px 2px rgba(0,0,0,0.14), 0px 6px 30px 5px rgba(0,0,0,0.12);
    --md-elevation-24: 0px 11px 15px -7px rgba(0,0,0,0.2), 0px 24px 38px 3px rgba(0,0,0,0.14), 0px 9px 46px 8px rgba(0,0,0,0.12);

    /* === BORDERS === */

    --md-border-width: 1px;
    --md-border-color: rgba(0, 0, 0, 0.12);
    --md-border-color-light: rgba(0, 0, 0, 0.08);

    /* Border Radius */
    --md-radius-sm: 2px;
    --md-radius-md: 4px;
    --md-radius-lg: 8px;
    --md-radius-xl: 16px;
    --md-radius-full: 9999px;

    /* === TRANSITIONS === */

    /* Material Motion */
    --md-duration-shortest: 150ms;
    --md-duration-shorter: 200ms;
    --md-duration-short: 250ms;
    --md-duration-standard: 300ms;
    --md-duration-complex: 375ms;
    --md-duration-entering: 225ms;
    --md-duration-leaving: 195ms;

    /* Easing Functions */
    --md-easing-standard: cubic-bezier(0.4, 0.0, 0.2, 1);
    --md-easing-decelerate: cubic-bezier(0.0, 0.0, 0.2, 1);
    --md-easing-accelerate: cubic-bezier(0.4, 0.0, 1, 1);
    --md-easing-sharp: cubic-bezier(0.4, 0.0, 0.6, 1);

    /* === Z-INDEX SYSTEM === */

    --md-z-mobileStepper: 1000;
    --md-z-fab: 1050;
    --md-z-speedDial: 1050;
    --md-z-appBar: 1100;
    --md-z-drawer: 1200;
    --md-z-modal: 1300;
    --md-z-snackbar: 1400;
    --md-z-tooltip: 1500;
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

/* Container */
.md-container {
    width: 100%;
    max-width: var(--md-container-lg);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--md-space-6);
    padding-right: var(--md-space-6);
}

/* Paper / Card */
.md-paper {
    background-color: var(--md-bg-card);
    border-radius: var(--md-radius-md);
    box-shadow: var(--md-elevation-2);
    transition: box-shadow var(--md-duration-standard) var(--md-easing-standard);
}

.md-paper:hover {
    box-shadow: var(--md-elevation-4);
}

/* Material Button */
.md-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--md-space-2) var(--md-space-4);
    font-family: var(--md-font);
    font-size: var(--md-text-button);
    font-weight: var(--md-font-medium);
    text-transform: uppercase;
    letter-spacing: 0.02857em;
    border-radius: var(--md-radius-md);
    border: none;
    cursor: pointer;
    transition: all var(--md-duration-shorter) var(--md-easing-standard);
    position: relative;
    overflow: hidden;
}

.md-button-contained {
    background-color: var(--md-primary-500);
    color: white;
    box-shadow: var(--md-elevation-2);
}

.md-button-contained:hover {
    background-color: var(--md-primary-600);
    box-shadow: var(--md-elevation-4);
}

.md-button-contained:active {
    box-shadow: var(--md-elevation-8);
}

.md-button-outlined {
    background-color: transparent;
    color: var(--md-primary-500);
    border: 1px solid rgba(33, 150, 243, 0.5);
}

.md-button-outlined:hover {
    background-color: rgba(33, 150, 243, 0.04);
    border-color: var(--md-primary-500);
}

.md-button-text {
    background-color: transparent;
    color: var(--md-primary-500);
    box-shadow: none;
}

.md-button-text:hover {
    background-color: rgba(33, 150, 243, 0.04);
}

/* Material Fab (Floating Action Button) */
.md-fab {
    width: 56px;
    height: 56px;
    border-radius: var(--md-radius-full);
    background-color: var(--md-secondary-500);
    color: white;
    box-shadow: var(--md-elevation-6);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: none;
    transition: all var(--md-duration-standard) var(--md-easing-standard);
}

.md-fab:hover {
    box-shadow: var(--md-elevation-12);
    transform: scale(1.05);
}

/* Typography */
.md-text-h1 { font-size: var(--md-text-h1); font-weight: var(--md-font-light); }
.md-text-h2 { font-size: var(--md-text-h2); font-weight: var(--md-font-light); }
.md-text-h3 { font-size: var(--md-text-h3); font-weight: var(--md-font-regular); }
.md-text-h4 { font-size: var(--md-text-h4); font-weight: var(--md-font-regular); }
.md-text-h5 { font-size: var(--md-text-h5); font-weight: var(--md-font-regular); }
.md-text-h6 { font-size: var(--md-text-h6); font-weight: var(--md-font-medium); }

.md-text-subtitle1 { font-size: var(--md-text-subtitle1); font-weight: var(--md-font-regular); }
.md-text-subtitle2 { font-size: var(--md-text-subtitle2); font-weight: var(--md-font-medium); }

.md-text-body1 { font-size: var(--md-text-body1); font-weight: var(--md-font-regular); }
.md-text-body2 { font-size: var(--md-text-body2); font-weight: var(--md-font-regular); }

.md-text-caption { font-size: var(--md-text-caption); font-weight: var(--md-font-regular); color: var(--md-text-secondary); }
.md-text-overline { font-size: var(--md-text-overline); font-weight: var(--md-font-regular); text-transform: uppercase; letter-spacing: 0.15em; }

/* Divider */
.md-divider {
    height: 1px;
    background-color: var(--md-border-color);
    margin: var(--md-space-4) 0;
}

/* Material Ripple Effect (CSS-only approximation) */
@keyframes md-ripple {
    to {
        transform: scale(4);
        opacity: 0;
    }
}

/* Focus States - Accessibility */
*:focus-visible {
    outline: 2px solid var(--md-primary-500);
    outline-offset: 2px;
}

/* Selection */
::selection {
    background-color: var(--md-primary-200);
    color: var(--md-text-primary);
}

/* ========================================
   TOUCH-FRIENDLY TABLES & RESPONSIVE DESIGN
   ======================================== */

/* Touch-friendly table rows (48px minimum for Material Design touch targets) */
.rz-datatable-data tr,
.rz-datagrid-data tr,
table tbody tr {
    min-height: 48px;
}

.rz-datatable-data td,
.rz-datagrid-data td,
table tbody td {
    padding: var(--md-space-4) var(--md-space-3);
}

/* Responsive table behavior on mobile */
@media (max-width: 599px) {
    /* Make tables scrollable horizontally on mobile */
    .rz-datatable,
    .rz-datagrid,
    .orders-table table,
    table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }
    
    /* Ensure table headers stick during horizontal scroll */
    .rz-datatable-header,
    .rz-datagrid-header,
    table thead {
        position: sticky;
        left: 0;
        z-index: 10;
    }
    
    /* Touch-friendly spacing for mobile */
    .rz-datatable-data td,
    .rz-datagrid-data td,
    table tbody td {
        padding: var(--md-space-3) var(--md-space-2);
        font-size: var(--md-text-body2);
    }
    
    /* Show scroll hint for mobile users */
    .rz-datatable::after,
    .rz-datagrid::after,
    .orders-table::after {
        content: '← Swipe to see more →';
        display: block;
        text-align: center;
        padding: var(--md-space-2);
        font-size: var(--md-text-caption);
        color: var(--md-text-secondary);
        background: var(--md-grey-50);
        border-top: 1px solid var(--md-border-color);
    }
}

/* Tablet optimization (600px - 960px) */
@media (min-width: 600px) and (max-width: 959px) {
    /* Slightly smaller padding for tablet */
    .rz-datatable-data td,
    .rz-datagrid-data td,
    table tbody td {
        padding: var(--md-space-3);
    }
}

/* Desktop optimization (960px+) */
@media (min-width: 960px) {
    /* Full padding for desktop */
    .rz-datatable-data td,
    .rz-datagrid-data td,
    table tbody td {
        padding: var(--md-space-4);
    }

    /* Enhanced hover effect on desktop */
    .rz-datatable-row:hover,
    .rz-datagrid-row:hover,
    table tbody tr:hover {
        background: var(--md-bg-hover);
        cursor: pointer;
        transition: background var(--md-duration-shorter) var(--md-easing-standard);
    }
}

/* ========================================
   PREMIUM MICRO-INTERACTIONS
   ======================================== */

/* Card hover lift effect */
.card-premium,
.rz-card {
    transition: transform var(--md-duration-standard) var(--md-easing-standard),
                box-shadow var(--md-duration-standard) var(--md-easing-standard);
}

.card-premium:hover,
.rz-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--md-elevation-6), 0 0 20px var(--md-accent-glow) !important;
}

/* Button press effect */
.rz-button:active,
.btn:active,
.md-button:active {
    transform: translateY(1px);
}

/* Premium focus glow */
.rz-textbox:focus,
.rz-dropdown:focus,
.rz-datepicker:focus,
input:focus,
textarea:focus,
select:focus,
.rz-textbox:focus-within,
.rz-dropdown:focus-within {
    border-color: var(--md-accent-500) !important;
    box-shadow: 0 0 0 3px var(--md-accent-glow) !important;
    outline: none;
}

/* Focus visible for accessibility */
*:focus-visible {
    outline: 2px solid var(--md-accent-500);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--md-accent-glow);
}

/* Headers use Syne display font */
h1, h2, h3, h4, h5, h6,
.rz-text-h1, .rz-text-h2, .rz-text-h3,
.rz-text-h4, .rz-text-h5, .rz-text-h6,
.page-title, .card-header {
    font-family: var(--md-font-display);
    letter-spacing: -0.02em;
}

/* Staggered fade-in animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* Apply staggered animations to list items */
.fade-in-stagger > *,
.rz-datalist-item,
.rz-datagrid-row {
    animation: fadeInUp var(--md-duration-standard) var(--md-easing-decelerate) backwards;
}

.fade-in-stagger > *:nth-child(1) { animation-delay: 0s; }
.fade-in-stagger > *:nth-child(2) { animation-delay: 0.05s; }
.fade-in-stagger > *:nth-child(3) { animation-delay: 0.1s; }
.fade-in-stagger > *:nth-child(4) { animation-delay: 0.15s; }
.fade-in-stagger > *:nth-child(5) { animation-delay: 0.2s; }
.fade-in-stagger > *:nth-child(6) { animation-delay: 0.25s; }
.fade-in-stagger > *:nth-child(7) { animation-delay: 0.3s; }
.fade-in-stagger > *:nth-child(8) { animation-delay: 0.35s; }
.fade-in-stagger > *:nth-child(9) { animation-delay: 0.4s; }
.fade-in-stagger > *:nth-child(10) { animation-delay: 0.45s; }

/* Page content fade-in */
.content,
.page-content {
    animation: fadeIn var(--md-duration-standard) var(--md-easing-decelerate);
}

/* Premium scrollbar */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: var(--md-grey-100);
    border-radius: var(--md-radius-full);
}

::-webkit-scrollbar-thumb {
    background: var(--md-grey-400);
    border-radius: var(--md-radius-full);
    border: 2px solid var(--md-grey-100);
    transition: background var(--md-duration-shorter) var(--md-easing-standard);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--md-accent-500);
}

/* Loading skeleton animation */
@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

.skeleton {
    background: linear-gradient(
        90deg,
        var(--md-grey-200) 25%,
        var(--md-grey-100) 50%,
        var(--md-grey-200) 75%
    );
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: var(--md-radius-md);
}

/* Required field indicator */
.required-field::after,
[required] + label::after {
    content: ' *';
    color: var(--md-error);
    font-weight: var(--md-font-medium);
}

/* Premium badge styles */
.badge-success { background: var(--md-success); color: white; }
.badge-warning { background: var(--md-warning); color: white; }
.badge-error { background: var(--md-error); color: white; }
.badge-info { background: var(--md-accent-500); color: white; }

/* Radzen overrides for premium feel */
.rz-dialog {
    border-radius: var(--md-radius-lg) !important;
    box-shadow: var(--md-elevation-24), 0 0 40px rgba(0, 0, 0, 0.1) !important;
    animation: fadeInUp var(--md-duration-standard) var(--md-easing-decelerate);
}

.rz-dialog-titlebar {
    font-family: var(--md-font-display);
    font-weight: 600;
    letter-spacing: -0.01em;
}

/* Radzen FormField label styling */
.rz-form-field-label {
    font-family: var(--md-font);
    font-weight: 500;
    color: var(--md-text-secondary);
}

/* Notification toast styling */
.rz-notification {
    border-radius: var(--md-radius-lg) !important;
    animation: slideInRight var(--md-duration-standard) var(--md-easing-decelerate);
}

/* Data grid premium styling */
.rz-datatable,
.rz-datagrid {
    border-radius: var(--md-radius-lg);
    overflow: hidden;
}

.rz-datatable-header th,
.rz-datagrid-header th {
    font-family: var(--md-font);
    font-weight: 600;
    text-transform: uppercase;
    font-size: var(--md-text-caption);
    letter-spacing: 0.08em;
    color: var(--md-text-secondary);
    background: var(--md-grey-50);
}

/* Speech to text button styling */
.rz-speech-to-text-button {
    color: var(--md-accent-500);
    transition: color var(--md-duration-shorter) var(--md-easing-standard),
                transform var(--md-duration-shorter) var(--md-easing-standard);
}

.rz-speech-to-text-button:hover {
    color: var(--md-accent-600);
    transform: scale(1.1);
}

.rz-speech-to-text-button.rz-state-recording {
    color: var(--md-error);
    animation: pulse 1s infinite;
}
