.skip-link{position:absolute;top:-40px;left:6px;background:#8B5CF6;color:#fff;padding:8px;border-radius:4px;text-decoration:none;transition:top .3s;z-index:1000}.skip-link:focus{top:6px}.custom-scrollbar::-webkit-scrollbar{width:8px}.custom-scrollbar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#a78bfa;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#8b5cf6}body{font-family:Inter var,Inter,sans-serif}@media (max-width: 768px){.touch-target{min-height:48px;min-width:48px}.mobile-padding{padding:1rem}.mobile-text-lg{font-size:1.125rem;line-height:1.5rem}.mobile-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.mobile-button{padding:.875rem 1.25rem;font-size:1rem;border-radius:.625rem;font-weight:600}.mobile-input{padding:.875rem;font-size:1rem;border-radius:.5rem;min-height:48px}.mobile-grid-gap{gap:.75rem}.mobile-safe-bottom{padding-bottom:env(safe-area-inset-bottom,1rem)}.mobile-color-picker{width:48px;height:48px;border-radius:.5rem}.mobile-accordion-header{padding:1rem;font-size:1rem}.mobile-scroll-container{max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}}@media (min-width: 769px) and (max-width: 1024px){.tablet-grid{grid-template-columns:repeat(3,1fr)}}.lazy-load{opacity:0;transition:opacity .3s}.lazy-load.loaded{opacity:1}@keyframes slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.animate-slide-in{animation:slide-in .3s ease-out}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
