UNPKG

muspe-cli

Version:

MusPE Advanced Framework v2.1.3 - Mobile User-friendly Simple Progressive Engine with Enhanced CLI Tools, Specialized E-Commerce Templates, Material Design 3, Progressive Enhancement, Mobile Optimizations, Performance Analysis, and Enterprise-Grade Develo

325 lines (283 loc) 10.1 kB
/* MusPE UI Components - Mobile-First CSS Framework * Optimized for touch interfaces and mobile devices * Based on Material Design principles with iOS-style touches */ /* ======================================== * CSS VARIABLES & DESIGN TOKENS * ======================================== */ :root { /* Colors */ --muspe-primary: #007AFF; --muspe-primary-light: #4DA2FF; --muspe-primary-dark: #0056CC; --muspe-secondary: #FF9500; --muspe-success: #34C759; --muspe-warning: #FF9500; --muspe-error: #FF3B30; --muspe-info: #5AC8FA; /* Neutral Colors */ --muspe-white: #FFFFFF; --muspe-gray-50: #F9FAFB; --muspe-gray-100: #F3F4F6; --muspe-gray-200: #E5E7EB; --muspe-gray-300: #D1D5DB; --muspe-gray-400: #9CA3AF; --muspe-gray-500: #6B7280; --muspe-gray-600: #4B5563; --muspe-gray-700: #374151; --muspe-gray-800: #1F2937; --muspe-gray-900: #111827; --muspe-black: #000000; /* Spacing */ --muspe-space-1: 0.25rem; /* 4px */ --muspe-space-2: 0.5rem; /* 8px */ --muspe-space-3: 0.75rem; /* 12px */ --muspe-space-4: 1rem; /* 16px */ --muspe-space-5: 1.25rem; /* 20px */ --muspe-space-6: 1.5rem; /* 24px */ --muspe-space-8: 2rem; /* 32px */ --muspe-space-10: 2.5rem; /* 40px */ --muspe-space-12: 3rem; /* 48px */ /* Typography */ --muspe-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; --muspe-font-size-xs: 0.75rem; /* 12px */ --muspe-font-size-sm: 0.875rem; /* 14px */ --muspe-font-size-base: 1rem; /* 16px */ --muspe-font-size-lg: 1.125rem; /* 18px */ --muspe-font-size-xl: 1.25rem; /* 20px */ --muspe-font-size-2xl: 1.5rem; /* 24px */ --muspe-font-size-3xl: 1.875rem; /* 30px */ /* Border Radius */ --muspe-radius-sm: 0.375rem; /* 6px */ --muspe-radius-md: 0.5rem; /* 8px */ --muspe-radius-lg: 0.75rem; /* 12px */ --muspe-radius-xl: 1rem; /* 16px */ --muspe-radius-full: 9999px; /* Shadows */ --muspe-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --muspe-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06); --muspe-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); --muspe-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); /* Transitions */ --muspe-transition-fast: 150ms ease; --muspe-transition-normal: 250ms ease; --muspe-transition-slow: 350ms ease; /* Z-Index */ --muspe-z-dropdown: 1000; --muspe-z-modal: 1050; --muspe-z-tooltip: 1100; --muspe-z-toast: 1200; } /* Dark Mode Variables */ @media (prefers-color-scheme: dark) { :root { --muspe-primary: #0A84FF; --muspe-gray-50: #1F2937; --muspe-gray-100: #374151; --muspe-gray-200: #4B5563; --muspe-gray-300: #6B7280; --muspe-gray-400: #9CA3AF; --muspe-gray-500: #D1D5DB; --muspe-gray-600: #E5E7EB; --muspe-gray-700: #F3F4F6; --muspe-gray-800: #F9FAFB; --muspe-gray-900: #FFFFFF; } } /* ======================================== * BASE STYLES & RESET * ======================================== */ *, *::before, *::after { box-sizing: border-box; -webkit-tap-highlight-color: transparent; } body { font-family: var(--muspe-font-family); font-size: var(--muspe-font-size-base); line-height: 1.5; color: var(--muspe-gray-900); background-color: var(--muspe-gray-50); margin: 0; padding: 0; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } /* Touch-friendly scrolling */ * { -webkit-overflow-scrolling: touch; } /* Remove default button styles */ button { font-family: inherit; font-size: 100%; margin: 0; padding: 0; border: none; background: none; cursor: pointer; } input, textarea, select { font-family: inherit; font-size: 100%; } /* ======================================== * UTILITY CLASSES * ======================================== */ /* Display */ .muspe-block { display: block; } .muspe-inline-block { display: inline-block; } .muspe-inline { display: inline; } .muspe-flex { display: flex; } .muspe-inline-flex { display: inline-flex; } .muspe-grid { display: grid; } .muspe-hidden { display: none; } /* Flexbox */ .muspe-flex-row { flex-direction: row; } .muspe-flex-col { flex-direction: column; } .muspe-flex-wrap { flex-wrap: wrap; } .muspe-items-start { align-items: flex-start; } .muspe-items-center { align-items: center; } .muspe-items-end { align-items: flex-end; } .muspe-justify-start { justify-content: flex-start; } .muspe-justify-center { justify-content: center; } .muspe-justify-end { justify-content: flex-end; } .muspe-justify-between { justify-content: space-between; } .muspe-flex-1 { flex: 1; } /* Spacing */ .muspe-p-1 { padding: var(--muspe-space-1); } .muspe-p-2 { padding: var(--muspe-space-2); } .muspe-p-3 { padding: var(--muspe-space-3); } .muspe-p-4 { padding: var(--muspe-space-4); } .muspe-p-5 { padding: var(--muspe-space-5); } .muspe-p-6 { padding: var(--muspe-space-6); } .muspe-p-8 { padding: var(--muspe-space-8); } .muspe-m-1 { margin: var(--muspe-space-1); } .muspe-m-2 { margin: var(--muspe-space-2); } .muspe-m-3 { margin: var(--muspe-space-3); } .muspe-m-4 { margin: var(--muspe-space-4); } .muspe-m-5 { margin: var(--muspe-space-5); } .muspe-m-6 { margin: var(--muspe-space-6); } .muspe-m-8 { margin: var(--muspe-space-8); } /* Typography */ .muspe-text-xs { font-size: var(--muspe-font-size-xs); } .muspe-text-sm { font-size: var(--muspe-font-size-sm); } .muspe-text-base { font-size: var(--muspe-font-size-base); } .muspe-text-lg { font-size: var(--muspe-font-size-lg); } .muspe-text-xl { font-size: var(--muspe-font-size-xl); } .muspe-text-2xl { font-size: var(--muspe-font-size-2xl); } .muspe-text-3xl { font-size: var(--muspe-font-size-3xl); } .muspe-font-normal { font-weight: 400; } .muspe-font-medium { font-weight: 500; } .muspe-font-semibold { font-weight: 600; } .muspe-font-bold { font-weight: 700; } .muspe-text-left { text-align: left; } .muspe-text-center { text-align: center; } .muspe-text-right { text-align: right; } /* Colors */ .muspe-text-primary { color: var(--muspe-primary); } .muspe-text-secondary { color: var(--muspe-secondary); } .muspe-text-success { color: var(--muspe-success); } .muspe-text-warning { color: var(--muspe-warning); } .muspe-text-error { color: var(--muspe-error); } .muspe-text-white { color: var(--muspe-white); } .muspe-text-gray-500 { color: var(--muspe-gray-500); } .muspe-text-gray-700 { color: var(--muspe-gray-700); } .muspe-text-gray-900 { color: var(--muspe-gray-900); } .muspe-bg-primary { background-color: var(--muspe-primary); } .muspe-bg-secondary { background-color: var(--muspe-secondary); } .muspe-bg-success { background-color: var(--muspe-success); } .muspe-bg-warning { background-color: var(--muspe-warning); } .muspe-bg-error { background-color: var(--muspe-error); } .muspe-bg-white { background-color: var(--muspe-white); } .muspe-bg-gray-50 { background-color: var(--muspe-gray-50); } .muspe-bg-gray-100 { background-color: var(--muspe-gray-100); } /* Border Radius */ .muspe-rounded-sm { border-radius: var(--muspe-radius-sm); } .muspe-rounded-md { border-radius: var(--muspe-radius-md); } .muspe-rounded-lg { border-radius: var(--muspe-radius-lg); } .muspe-rounded-xl { border-radius: var(--muspe-radius-xl); } .muspe-rounded-full { border-radius: var(--muspe-radius-full); } /* Shadows */ .muspe-shadow-sm { box-shadow: var(--muspe-shadow-sm); } .muspe-shadow-md { box-shadow: var(--muspe-shadow-md); } .muspe-shadow-lg { box-shadow: var(--muspe-shadow-lg); } .muspe-shadow-xl { box-shadow: var(--muspe-shadow-xl); } /* Width & Height */ .muspe-w-full { width: 100%; } .muspe-h-full { height: 100%; } .muspe-min-h-screen { min-height: 100vh; } /* Position */ .muspe-relative { position: relative; } .muspe-absolute { position: absolute; } .muspe-fixed { position: fixed; } .muspe-sticky { position: sticky; } /* ======================================== * COMPONENT STYLES * ======================================== */ /* Safe Area Support for modern devices */ .muspe-safe-area { padding-top: env(safe-area-inset-top); padding-bottom: env(safe-area-inset-bottom); padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); } /* Touch-friendly click targets */ .muspe-touch-target { min-height: 44px; min-width: 44px; display: flex; align-items: center; justify-content: center; } /* Active/Pressed states for touch */ .muspe-touch-feedback { transition: transform var(--muspe-transition-fast), opacity var(--muspe-transition-fast); cursor: pointer; } .muspe-touch-feedback:active { transform: scale(0.97); opacity: 0.8; } /* Smooth transitions */ .muspe-transition { transition: all var(--muspe-transition-normal); } /* ======================================== * RESPONSIVE DESIGN * ======================================== */ /* Mobile First Breakpoints */ @media (min-width: 640px) { .muspe-sm\:text-lg { font-size: var(--muspe-font-size-lg); } .muspe-sm\:p-6 { padding: var(--muspe-space-6); } } @media (min-width: 768px) { .muspe-md\:text-xl { font-size: var(--muspe-font-size-xl); } .muspe-md\:p-8 { padding: var(--muspe-space-8); } .muspe-md\:flex-row { flex-direction: row; } } @media (min-width: 1024px) { .muspe-lg\:text-2xl { font-size: var(--muspe-font-size-2xl); } .muspe-lg\:p-10 { padding: var(--muspe-space-10); } } /* Touch device optimizations */ @media (hover: none) and (pointer: coarse) { .muspe-touch-target { min-height: 48px; min-width: 48px; } } /* High DPI displays */ @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) { .muspe-crisp-edges { image-rendering: crisp-edges; image-rendering: -webkit-optimize-contrast; } } /* Reduced motion preference */ @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } }