.spinner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:9999}.lottie-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center}.lottie-spinner-text{margin-top:16px;color:#fff;text-align:center;font-size:16px}.button-spinner{display:inline-flex;align-items:center;justify-content:center}.loading-animation{display:flex;justify-content:center;align-items:center;height:100vh;width:100%}.spinner{width:40px;height:40px;background-color:#333;border-radius:50%;animation:spin .8s linear infinite}.notify{display:flex;align-items:center;background-color:transparent;color:#fff;padding:15px;border-radius:10px;margin-bottom:15px;max-width:320px;position:relative;transition:opacity .5s ease-in-out}.notify-image{width:40px;height:40px;margin-right:10px}.notify-content{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.notify-title{margin:0 25px 0 0;font-size:16px;font-weight:700}.notify-details{margin:0;font-size:14px}.notify-message-container{background-color:#0009;border-radius:8px;padding:8px 15px;margin-top:5px;width:100%;text-align:center}.notify-message{margin:0;font-size:16px;color:#fff;text-align:center}.notify-close{background:none;border:none;color:#fff;cursor:pointer;font-size:24px;font-weight:700;outline:none;padding:0 5px;position:absolute;right:10px;top:10px;text-shadow:0 0 3px rgba(0,0,0,.5)}.notify-close:focus{outline:2px solid white;outline-offset:-2px}.notify-close:hover{color:#ff5c5c}.notification-container{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;align-items:flex-end;z-index:1000}@media (max-width: 768px){.notification-container{top:0;right:0;left:0;align-items:center}.notify{max-width:100%;border-radius:0}}.app-layout{display:flex;height:100vh;height:100dvh;overflow:hidden;background-color:var(--color-bg-secondary)}.sidebar{display:none;flex-direction:column;width:var(--sidebar-width);height:100vh;position:fixed;left:0;top:0;background-color:var(--color-bg-primary);border-right:1px solid var(--color-border-light);z-index:var(--z-sticky)}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--color-border-light)}.sidebar-logo{width:36px;height:36px;filter:invert(24%) sepia(31%) saturate(1959%) hue-rotate(235deg) brightness(94%) contrast(89%)}.sidebar-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-dark)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);overflow-y:auto}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);width:100%;text-align:left}.sidebar-nav-item:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.sidebar-nav-item.active{background-color:var(--color-primary-bg);color:var(--color-primary)}.sidebar-nav-icon{display:flex;align-items:center;justify-content:center}.sidebar-nav-label{flex:1}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:var(--font-weight-bold);color:#fff;background-color:var(--color-error);border-radius:var(--radius-full)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-border-light);position:relative}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);text-align:left}.sidebar-user:hover{background-color:var(--color-bg-tertiary)}.sidebar-user-chevron{margin-left:auto;color:var(--color-text-muted);transition:transform var(--transition-fast)}.sidebar-user-chevron.open{transform:rotate(180deg)}.sidebar-dropdown{position:absolute;bottom:calc(100% + var(--space-2));left:var(--space-3);right:var(--space-3);background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-light);padding:var(--space-2);z-index:var(--z-dropdown)}.sidebar-dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-3);background:none;border:none;cursor:pointer;color:var(--color-text-primary);font-size:var(--font-size-sm);border-radius:var(--radius-md);text-decoration:none;transition:background-color var(--transition-fast)}.sidebar-dropdown-item:hover{background-color:var(--color-bg-tertiary)}.sidebar-dropdown-divider{height:1px;background-color:var(--color-border-light);margin:var(--space-2) 0}.sidebar-dropdown-logout{color:var(--color-error)}.sidebar-dropdown-logout:hover{background-color:var(--color-error-light)}.sidebar-user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.sidebar-user-info{flex:1;overflow:hidden}.sidebar-user-email{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main-content{flex:1;display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border-light);flex-shrink:0;z-index:var(--z-sticky)}.mobile-header-left{display:flex;align-items:center;gap:var(--space-2)}.mobile-logo{width:32px;height:32px;filter:invert(24%) sepia(31%) saturate(1959%) hue-rotate(235deg) brightness(94%) contrast(89%)}.mobile-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-dark)}.mobile-menu-btn{background:none;border:none;cursor:pointer;padding:var(--space-1)}.mobile-avatar{width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.page-content{flex:1;padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--space-4));max-width:var(--max-content-width);width:100%;margin:0 auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background-color:var(--color-bg-primary);border-top:1px solid var(--color-border-light);padding:var(--space-2) 0;padding-bottom:max(var(--space-2),env(safe-area-inset-bottom));z-index:var(--z-sticky)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:none;border:none;cursor:pointer;color:var(--color-text-muted);transition:color var(--transition-fast);min-height:var(--min-touch-target)}.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--color-primary)}.bottom-nav-icon{position:relative;display:flex;align-items:center;justify-content:center}.bottom-nav-badge{position:absolute;top:-4px;right:-8px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:var(--font-weight-bold);color:#fff;background-color:var(--color-error);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.bottom-nav-label{font-size:10px;font-weight:var(--font-weight-medium)}.menu-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:var(--z-modal-backdrop)}.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:85%;background-color:var(--color-bg-primary);transform:translate(100%);transition:transform var(--transition-normal);z-index:var(--z-modal);display:flex;flex-direction:column}.mobile-menu.open{transform:translate(0)}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border-light)}.mobile-menu-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.mobile-menu-close{background:none;border:none;cursor:pointer;padding:var(--space-2);color:var(--color-text-secondary);border-radius:var(--radius-md)}.mobile-menu-close:hover{background-color:var(--color-bg-tertiary)}.mobile-menu-user{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6) var(--space-4);background-color:var(--color-bg-secondary)}.mobile-menu-avatar{width:64px;height:64px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xl)}.mobile-menu-email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.mobile-menu-items{flex:1;padding:var(--space-2)}.mobile-menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;color:var(--color-text-primary);font-size:var(--font-size-base);border-radius:var(--radius-md);text-decoration:none;transition:background-color var(--transition-fast)}.mobile-menu-item:hover{background-color:var(--color-bg-tertiary)}.mobile-menu-footer{padding:var(--space-4);border-top:1px solid var(--color-border-light)}.mobile-menu-logout{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;color:var(--color-error);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.mobile-menu-logout:hover{background-color:var(--color-error-light)}@media (min-width: 768px){.sidebar{display:flex}.main-content{margin-left:var(--sidebar-width)}.mobile-header,.bottom-nav{display:none}.page-content{padding:var(--space-6);padding-bottom:var(--space-6)}.mobile-menu,.menu-overlay-backdrop{display:none}}@media (min-width: 1024px){.page-content{padding:var(--space-8)}}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#f5f5f5;padding:20px;box-sizing:border-box;overflow:visible}.login-title{font-size:1.5rem;margin:1rem 0 1.5rem;color:#f5f5f5}.login-form{display:flex;flex-direction:column;width:100%;max-width:300px;background:#151515;padding:2rem;border-radius:10px;box-shadow:0 4px 8px #0000001a;box-sizing:border-box}.login-input{font-size:1rem;padding:.75rem;margin-bottom:1rem;border:1px solid #7b7b7b;border-radius:5px;background:#151515}.login-button{font-size:1rem;padding:.75rem;border:none;border-radius:5px;background-color:#0c2743;color:#fff;cursor:pointer;transition:background-color .3s;box-sizing:border-box}.login-button:hover{background-color:#00366f}.google-button{display:flex;align-items:center;justify-content:center;font-size:1rem;padding:.75rem;margin-top:1rem;border:none;border-radius:5px;background-color:#151515;color:#fff;cursor:pointer;text-align:center;transition:background-color .3s,border-color .3s;width:100%;max-width:300px;box-sizing:border-box}.google-button img{margin-right:10px}.google-button:hover{background-color:#2b2b2b}.sign-up-link{margin-top:1rem;font-size:1rem;color:#888}.sign-up-link a{color:#f5f5f5;text-decoration:none}.sign-up-link a:hover{color:#d7d7d7;text-decoration:underline}@media (prefers-color-scheme: light){.login-container,.login-title{color:#1c1c1c}.login-form{background:#fff;box-shadow:none;border:1px solid #c0c0c0}.login-input{border:1px solid #c0c0c0;background:#fff}.google-button{background-color:#fff;color:#1c1c1c;border:1px solid #c0c0c0}.google-button:hover{background-color:#fdfdfd;border:1px solid #000000}.sign-up-link a{color:#0c2743}.sign-up-link a:hover{color:#0c2743cb}}@media (max-height: 500px){.login-container{justify-content:flex-start}.login-logo,.login-form{margin-top:20px}}.back-button{position:absolute;top:10px;left:10px;padding:.5rem .75rem;border-radius:5px;background-color:#151515;color:#fff;text-decoration:none;font-size:.9rem;transition:background-color .3s}.back-button:hover{background-color:#2b2b2b;text-decoration:none}@media (prefers-color-scheme: light){.back-button{background-color:#fff;color:#1c1c1c;border:1px solid #c0c0c0}.back-button:hover{background-color:#fdfdfd;border:1px solid #000000;color:#1c1c1c}}.sign-up-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#f5f5f5;margin-bottom:2rem}.sign-up-title{font-size:1.5rem;margin:1rem 0 1.5rem;color:#f5f5f5}.sign-up-form{display:flex;flex-direction:column;width:300px;background:#151515;padding:2rem;border-radius:10px;box-shadow:0 4px 8px #0000001a}.sign-up-input{font-size:1rem;padding:.75rem;margin-bottom:1rem;border:1px solid #7b7b7b;border-radius:5px;background:#151515}.sign-up-button{font-size:1rem;padding:.75rem;border:none;border-radius:5px;background-color:#0c2743;color:#fff;cursor:pointer;transition:background-color .3s}.sign-up-button:hover{background-color:#00366f}@media (prefers-color-scheme: light){.sign-up-container,.sign-up-title{color:#1c1c1c}.sign-up-form{background:#fff;box-shadow:none;border:1px solid #c0c0c0}.sign-up-input{border:1px solid #c0c0c0;background:#fff}.sign-up-button{background-color:#0c2743;color:#fff}.sign-up-button:hover{background-color:#00366f}}.forgot-password-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#f5f5f5;padding:20px;box-sizing:border-box}.forgot-password-container h1{font-size:1.5rem;margin:1rem 0 1.5rem;color:#f5f5f5}.forgot-password-container p{font-size:1rem;color:#888;margin-bottom:1rem;text-align:center}.forgot-password-form{display:flex;flex-direction:column;width:100%;max-width:300px;background:#151515;padding:2rem;border-radius:10px;box-shadow:0 4px 8px #0000001a}.forgot-password-input{font-size:1rem;padding:.75rem;margin-bottom:1rem;border:1px solid #7b7b7b;border-radius:5px;background:#151515;color:#f5f5f5}.forgot-password-button{font-size:1rem;padding:.75rem;border:none;border-radius:5px;background-color:#0c2743;color:#fff;cursor:pointer;transition:background-color .3s}.forgot-password-button:hover{background-color:#00366f}.back-to-login-link{margin-top:1rem;font-size:1rem;color:#888}.link-button{background:none;border:none;color:#f5f5f5;text-decoration:underline;cursor:pointer}.link-button:hover{color:#d7d7d7;text-decoration:none}@media (prefers-color-scheme: light){.forgot-password-container{color:#1c1c1c}.forgot-password-form{background:#fff;box-shadow:none;border:1px solid #c0c0c0}.forgot-password-input{border:1px solid #c0c0c0;background:#fff;color:#1c1c1c}.forgot-password-button{background-color:#0c2743;color:#fff}.forgot-password-button:hover{background-color:#00366f}.back-to-login-link,.link-button{color:#0c2743}.link-button:hover{color:#0c2743cb}}.login-logo{margin-bottom:1rem;max-width:200px;width:200px;height:auto}.test-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4)}.test-modal{position:relative;width:100%;max-width:400px;background:var(--color-bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden}.test-modal-close{position:absolute;top:var(--space-3);right:var(--space-3);padding:var(--space-2);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast);z-index:1}.test-modal-close:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.test-modal-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6) var(--space-6) var(--space-4);text-align:center;background:linear-gradient(135deg,#4c278e1a,#9b4dff0d);border-bottom:1px solid var(--color-border-light)}.test-modal-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,#4c278e,#9b4dff);border-radius:var(--radius-full);color:#fff}.test-modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.test-modal-device{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;font-family:monospace;background:var(--color-bg-tertiary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.test-modal-content{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.test-modal-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6);color:var(--color-text-secondary)}.test-select-group{display:flex;flex-direction:column;gap:var(--space-2)}.test-select-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.test-select{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background-color:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.test-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #9b4dff33}.test-select option{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.test-select-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);font-style:italic}.test-liquid-button{position:relative;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);color:#fff;border:2px solid #9b4dff;border-radius:40px;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);background-color:#4c278e33;cursor:pointer;overflow:hidden;transition:all .3s ease,transform .1s ease;z-index:1;margin-top:var(--space-2);min-height:48px}.test-liquid-button span{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:var(--space-2);transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.7)}.test-liquid-button .liquid{position:absolute;top:-80px;left:0;width:100%;height:200px;background:#6a3fb9;box-shadow:inset 0 0 50px #00000080;transition:.5s ease}.test-liquid-button .liquid:before,.test-liquid-button .liquid:after{content:"";position:absolute;width:200%;height:200%;top:0;left:50%;transform:translate(-50%,-75%)}.test-liquid-button .liquid:before{border-radius:45%;background:#141414cc;animation:liquidRotate 5s linear infinite}.test-liquid-button .liquid:after{border-radius:40%;background:#1414144d;animation:liquidRotate 10s linear infinite}.test-liquid-button:hover:not(:disabled){background-color:#ffffff1a;box-shadow:0 0 20px #9b4dffb3;animation:liquidGlow 1.5s ease-in-out infinite}.test-liquid-button:hover:not(:disabled) span{text-shadow:0 1px 2px rgba(0,0,0,.3)}.test-liquid-button:hover:not(:disabled) .liquid{top:-120px}.test-liquid-button:active:not(:disabled){background-color:#fff3;transform:scale(.98)}.test-liquid-button.processing .liquid{top:-120px;animation:liquidColorChange 3s linear infinite}.test-liquid-button.processing{animation:liquidGlow 1.2s ease-in-out infinite}.test-liquid-button .bubble{position:absolute;bottom:-20px;border-radius:50%;opacity:0;animation:bubbleRise var(--rise-duration) ease-in infinite var(--rise-delay)}.test-liquid-button .bubble:before{content:"";position:absolute;width:100%;height:100%;background:radial-gradient(circle at 75% 25%,#fff9 5%,#fff3 40%,#fff0 60%);border-radius:50%}.test-liquid-button .bubble:nth-child(1){left:10%;width:20px;height:20px;--rise-duration: 4s;--rise-delay: 0s}.test-liquid-button .bubble:nth-child(2){left:25%;width:15px;height:15px;--rise-duration: 3.5s;--rise-delay: .5s}.test-liquid-button .bubble:nth-child(3){left:40%;width:10px;height:10px;--rise-duration: 3s;--rise-delay: 1s}.test-liquid-button .bubble:nth-child(4){left:55%;width:22px;height:22px;--rise-duration: 4.5s;--rise-delay: 1.5s}.test-liquid-button .bubble:nth-child(5){left:70%;width:18px;height:18px;--rise-duration: 3.8s;--rise-delay: 2s}.test-liquid-button .bubble:nth-child(6){left:85%;width:12px;height:12px;--rise-duration: 3.2s;--rise-delay: 2.5s}.test-liquid-button:disabled{background-color:var(--color-bg-tertiary);border-color:var(--color-border);cursor:not-allowed;box-shadow:none;color:var(--color-text-muted)}.test-liquid-button:disabled .liquid{display:none}@keyframes liquidRotate{0%{transform:translate(-50%,-75%) rotate(0)}to{transform:translate(-50%,-75%) rotate(360deg)}}@keyframes bubbleRise{0%{bottom:-20px;opacity:0}5%{opacity:.8}95%{opacity:.8}to{bottom:120%;opacity:0}}@keyframes liquidGlow{0%,to{box-shadow:0 0 5px #9b4dffb3}50%{box-shadow:0 0 20px #9b4dffe6}}@keyframes liquidColorChange{0%{filter:hue-rotate(0deg)}50%{filter:hue-rotate(30deg)}to{filter:hue-rotate(0deg)}}@media (min-width: 768px){.test-modal{max-width:420px}.test-modal-header{padding:var(--space-8) var(--space-8) var(--space-5)}.test-modal-content{padding:var(--space-6)}.test-modal-icon{width:64px;height:64px}.test-modal-icon svg{width:32px;height:32px}}.device-status-bar{display:flex;flex-direction:column;gap:var(--space-2)}.device-status-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border:2px solid transparent;transition:box-shadow .3s ease}.device-status-item.device-online{border-color:#28a745;animation:device-pulse-border 2s infinite}.device-status-item.device-offline{border-color:#dc3545}@keyframes device-pulse-border{0%{box-shadow:0 0 #28a745b3}70%{box-shadow:0 0 0 8px #28a74500}to{box-shadow:0 0 #28a74500}}.device-status-info{display:flex;align-items:center;gap:var(--space-3)}.device-status-details{display:flex;flex-direction:column;gap:2px}.device-status-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.device-status-id{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:monospace}.device-test-btn-liquid{position:relative;display:flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-3);color:#fff;border:1.5px solid #9b4dff;border-radius:20px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background-color:#4c278e33;cursor:pointer;overflow:hidden;transition:all .3s ease,transform .1s ease;z-index:1;min-height:32px}.device-test-btn-liquid span{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:var(--space-1);transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.5)}.device-test-btn-liquid .liquid{position:absolute;top:-50px;left:0;width:100%;height:120px;background:#6a3fb9;box-shadow:inset 0 0 30px #0006;transition:.4s ease}.device-test-btn-liquid .liquid:before,.device-test-btn-liquid .liquid:after{content:"";position:absolute;width:200%;height:200%;top:0;left:50%;transform:translate(-50%,-75%)}.device-test-btn-liquid .liquid:before{border-radius:45%;background:#141414cc;animation:deviceLiquidRotate 5s linear infinite}.device-test-btn-liquid .liquid:after{border-radius:40%;background:#1414144d;animation:deviceLiquidRotate 10s linear infinite}.device-test-btn-liquid:hover:not(:disabled){background-color:#ffffff1a;box-shadow:0 0 12px #9b4dffb3;animation:deviceLiquidGlow 1.5s ease-in-out infinite}.device-test-btn-liquid:hover:not(:disabled) .liquid{top:-70px}.device-test-btn-liquid:active:not(:disabled){transform:scale(.96)}.device-test-btn-liquid .bubble{position:absolute;bottom:-10px;border-radius:50%;opacity:0;animation:deviceBubbleRise var(--rise-duration) ease-in infinite var(--rise-delay)}.device-test-btn-liquid .bubble:before{content:"";position:absolute;width:100%;height:100%;background:radial-gradient(circle at 75% 25%,#fff9 5%,#fff3 40%,#fff0 60%);border-radius:50%}.device-test-btn-liquid .bubble:nth-child(1){left:15%;width:8px;height:8px;--rise-duration: 3s;--rise-delay: 0s}.device-test-btn-liquid .bubble:nth-child(2){left:45%;width:6px;height:6px;--rise-duration: 2.5s;--rise-delay: .8s}.device-test-btn-liquid .bubble:nth-child(3){left:75%;width:7px;height:7px;--rise-duration: 2.8s;--rise-delay: 1.5s}.device-test-btn-liquid:disabled{background-color:var(--color-bg-tertiary);border-color:var(--color-border);cursor:not-allowed;box-shadow:none;color:var(--color-text-muted);opacity:.6}.device-test-btn-liquid:disabled .liquid{display:none}.device-test-btn-liquid:disabled span{text-shadow:none}@keyframes deviceLiquidRotate{0%{transform:translate(-50%,-75%) rotate(0)}to{transform:translate(-50%,-75%) rotate(360deg)}}@keyframes deviceBubbleRise{0%{bottom:-10px;opacity:0}10%{opacity:.7}90%{opacity:.7}to{bottom:100%;opacity:0}}@keyframes deviceLiquidGlow{0%,to{box-shadow:0 0 4px #9b4dff99}50%{box-shadow:0 0 12px #9b4dffe6}}@media (min-width: 768px){.device-status-bar{flex-direction:row;flex-wrap:wrap;gap:var(--space-3)}.device-status-item{flex:1;min-width:200px;max-width:300px}}.zapier-action-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.zapier-action-modal-content{background-color:#fff;padding:24px 28px;border-radius:12px;box-shadow:0 8px 32px #0003;text-align:center;width:90%;max-width:420px;max-height:90%;overflow-y:auto;animation:modalSlideIn .3s ease-out;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-close-btn{position:absolute;top:12px;right:12px;background:transparent;border:none;cursor:pointer;color:#888;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{color:#333;background-color:#f0f0f0}.modal-icon-wrapper{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;background:linear-gradient(135deg,#f5f5f5,#e8e8e8)}.modal-icon-wrapper .icon-pause{color:#f59e0b}.modal-icon-wrapper .icon-delete{color:#ef4444}.zapier-action-modal-content h2{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:#1d1d1f}.integration-name{color:#6a4cb3;font-weight:500;font-size:.95rem;margin:0 0 16px}.modal-body{text-align:left}.modal-body p{margin:0 0 12px;color:#444;font-size:.95rem;line-height:1.5}.info-box{background:#f8f5ff;border:1px solid #e0d4f5;border-radius:8px;padding:12px 14px;margin:16px 0}.info-box p{margin:0;font-size:.9rem;color:#5a3d8a}.info-box strong{color:#6a4cb3}.sync-hint{font-size:.875rem!important;color:#666!important;background:#f5f5f5;padding:10px 12px;border-radius:6px;margin-top:16px!important}.sync-hint strong{color:#6a4cb3}.modal-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.zapier-link-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;font-size:.95rem;font-weight:500;cursor:pointer;background:linear-gradient(135deg,#ff4a00,#ff6b2b);color:#fff;border:none;border-radius:8px;text-decoration:none;transition:all .2s ease}.zapier-link-btn:hover{background:linear-gradient(135deg,#e64400,#ff5a1a);transform:translateY(-1px);box-shadow:0 4px 12px #ff4a004d}.modal-cancel-btn{padding:10px 20px;font-size:.9rem;cursor:pointer;background-color:transparent;color:#666;border:1px solid #ddd;border-radius:8px;transition:all .2s ease}.modal-cancel-btn:hover{background-color:#f5f5f5;border-color:#ccc;color:#333}@media (max-width: 480px){.zapier-action-modal-content{padding:20px;margin:16px;width:calc(100% - 32px)}.modal-icon-wrapper{width:56px;height:56px}.modal-icon-wrapper svg{width:28px;height:28px}}.integration-card{padding:var(--space-4);transition:opacity var(--transition-fast),box-shadow var(--transition-fast)}.integration-card.disabled{opacity:.7}.integration-card:hover{box-shadow:var(--shadow-md)}.integration-card-main{display:flex;align-items:flex-start;gap:var(--space-3)}.integration-card-icon{width:44px;height:44px;border-radius:var(--radius-md);background-color:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;overflow:hidden}.integration-card-icon .integration-color-swatch{width:100%;height:100%;border-radius:0}.integration-card-icon-placeholder{width:100%;height:100%;background-color:var(--color-bg-tertiary)}.integration-card-content{flex:1;min-width:0}.integration-card-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.integration-card-app{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.integration-card-trigger{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-2)}.integration-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4)}.integration-card-detail{font-size:var(--font-size-xs);color:var(--color-text-muted)}.integration-card-actions{position:relative;flex-shrink:0}.integration-card-menu-btn{padding:var(--space-2);min-height:auto}.integration-card-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-dropdown)}.integration-card-menu{position:absolute;top:100%;right:0;background-color:var(--color-bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-light);min-width:140px;z-index:calc(var(--z-dropdown) + 1);overflow:hidden}.integration-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);transition:background-color var(--transition-fast)}.integration-menu-item:hover{background-color:var(--color-bg-tertiary)}.integration-menu-item:disabled{opacity:.5;cursor:not-allowed}.integration-menu-item-danger{color:var(--color-error)}.integration-menu-item-danger:hover{background-color:var(--color-error-light)}.integration-card-footer{display:flex;gap:var(--space-4);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border-light)}.integration-card-stat{font-size:var(--font-size-xs);color:var(--color-text-muted)}.integration-trigger-type{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-full);font-size:var(--font-size-xs)}.integration-trigger-type.instant{background-color:#fbbf2426;color:#f59e0b}.integration-trigger-type.polling{background-color:#3b82f626;color:#3b82f6}.integration-color-swatch{display:inline-flex;width:18px;height:18px;border-radius:var(--radius-sm);overflow:hidden}.integration-color-swatch .single-color-swatch{width:100%;height:100%;border-radius:var(--radius-sm)}.integration-color-swatch .single-color-swatch.pulse{animation:pulse-animation 1.5s ease-in-out infinite}.integration-color-swatch .single-color-swatch.sparkle{animation:sparkle-animation .5s ease-in-out infinite}.integration-color-swatch .rainbow-swatch{width:100%;height:100%;background:linear-gradient(135deg,red,#ff7f00,#ff0,#0f0,#00f,indigo,#9400d3);background-size:200% 200%;animation:rainbow-animation 2s linear infinite}.integration-color-swatch .fire-swatch{width:100%;height:100%;position:relative;overflow:hidden}.integration-color-swatch .fire-gradient{width:100%;height:100%;background:linear-gradient(to top,#ff4500,#ff6a00,orange,#fc0);animation:fire-animation .5s ease-in-out infinite alternate}.integration-color-swatch .dual-color-swatch{display:flex;width:100%;height:100%}.integration-color-swatch .dual-color-swatch>div{flex:1}.integration-color-swatch .dual-color-swatch.police-animation{animation:police-animation .5s ease-in-out infinite alternate}@keyframes pulse-animation{0%,to{opacity:1}50%{opacity:.4}}@keyframes sparkle-animation{0%,to{opacity:1}50%{opacity:.6}}@keyframes rainbow-animation{0%{background-position:0% 50%}to{background-position:100% 50%}}@keyframes fire-animation{0%{transform:translateY(0)}to{transform:translateY(-2px)}}@keyframes police-animation{0%{opacity:1}to{opacity:.7}}@media (min-width: 768px){.integration-card{padding:var(--space-5)}.integration-card-icon{width:52px;height:52px;font-size:28px}}.add-device-modal{max-width:420px}.add-device-modal .modal-header{display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.modal-close{background:none;border:none;cursor:pointer;padding:var(--space-2);color:var(--color-text-secondary);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.modal-close:hover{background-color:var(--color-bg-tertiary)}.add-device-instructions{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-5)}.add-device-modal .modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-4);border-top:none}.integrations-dashboard{display:flex;flex-direction:column;gap:var(--space-6)}.dashboard-section{display:flex;flex-direction:column;gap:var(--space-4)}.zapier-connection-section{gap:var(--space-3)}.zapier-status-loading{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.zapier-status-connected{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:var(--radius-md)}.zapier-status-indicator{display:flex;align-items:center;gap:var(--space-2);color:var(--color-success);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.zapier-disconnect-btn{color:var(--color-text-secondary);gap:var(--space-1)}.zapier-disconnect-btn:hover{color:var(--color-error)}.zapier-status-disconnected{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4);text-align:center}.zapier-status-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.zapier-error-text{color:var(--color-error);font-size:var(--font-size-xs);margin:0}.section-header-actions{display:flex;align-items:center;gap:var(--space-2)}.sync-btn{gap:var(--space-1)}.integrations-list{display:flex;flex-direction:column;gap:var(--space-3)}.integrations-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10);color:var(--color-text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.integrations-dashboard .empty-state.card{padding:var(--space-10) var(--space-6)}@media (min-width: 768px){.integrations-list{gap:var(--space-4)}}.mirt,.mirt *{box-sizing:border-box}.mirt{display:flex;background-color:#333;height:var(--mirt-height, 3rem);border-radius:var(--mirt-border-radius, .3rem);overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mirt__play-button{display:flex;justify-content:center;align-items:center;text-align:center;width:var(--mirt-button-width, 3rem);background-color:var(--mirt-background-color, #333);border-right-color:var(--mirt-button-border-color, #222);border-width:0 .0625rem 0 0;cursor:default}.mirt--initialized .mirt__play-button{cursor:pointer}.mirt--initialized .mirt__play-button:hover{background-color:var(--mirt-button-hover-color, #444)}.mirt__play-button-icon{width:var(--mirt-button-icon-width, 1rem);color:var(--mirt-button-icon-color, #fff)}.mirt--disabled .mirt__play-button-icon{opacity:.5}.mirt__timeline{position:relative;flex-grow:1;overflow:hidden}.mirt__range-handles{z-index:300}.mirt__range-handles,.mirt__range-handle-frame{position:absolute;top:0;right:0;bottom:0;left:0}.mirt__range-handle-playhead-track{position:absolute;top:0;right:calc(var(--mirt-handle-width, 1.2rem) - var(--mirt-playhead-width, .35rem));bottom:0;left:calc(var(--mirt-handle-width, 1.2rem) - var(--mirt-playhead-width, .35rem))}.mirt__range-handle--start,.mirt__range-handle--end{z-index:200;pointer-events:none}.mirt__range-handle--start::-moz-range-thumb,.mirt__range-handle--end::-moz-range-thumb{width:var(--mirt-handle-width, 1.2rem);pointer-events:all}.mirt__range-handle--start::-webkit-slider-thumb,.mirt__range-handle--end::-webkit-slider-thumb{width:var(--mirt-handle-width, 1.2rem);pointer-events:all}.mirt__range-handle--start::-ms-thumb,.mirt__range-handle--end::-ms-thumb{width:var(--mirt-handle-width, 1.2rem);pointer-events:all}.mirt__range-handle--start::-moz-range-track,.mirt__range-handle--end::-moz-range-track{pointer-events:none}.mirt__range-handle--start::-webkit-slider-runnable-track,.mirt__range-handle--end::-webkit-slider-runnable-track{pointer-events:none}.mirt__range-handle--start::-ms-track,.mirt__range-handle--end::-ms-track{pointer-events:none}.mirt__range-handle--start{padding-right:var(--mirt-handle-width, 1.2rem)}.mirt__range-handle--start::-moz-range-thumb{transform:translate(calc(var(--mirt-playhead-width, .35rem) * -1));cursor:default}.mirt--initialized .mirt__range-handle--start::-moz-range-thumb{cursor:e-resize}.mirt__range-handle--start::-webkit-slider-thumb{transform:translate(calc(var(--mirt-playhead-width, .35rem) * -1));cursor:default}.mirt--initialized .mirt__range-handle--start::-webkit-slider-thumb{cursor:e-resize}.mirt__range-handle--start::-ms-thumb{transform:translate(calc(var(--mirt-playhead-width, .35rem) * -1));cursor:default}.mirt--initialized .mirt__range-handle--start::-ms-thumb{cursor:e-resize}.mirt__range-handle--end{padding-left:var(--mirt-handle-width, 1.2rem)}.mirt__range-handle--end::-moz-range-thumb{transform:translate(var(--mirt-playhead-width, .35rem));cursor:default}.mirt--initialized .mirt__range-handle--end::-moz-range-thumb{cursor:w-resize}.mirt__range-handle--end::-webkit-slider-thumb{transform:translate(var(--mirt-playhead-width, .35rem));cursor:default}.mirt--initialized .mirt__range-handle--end::-webkit-slider-thumb{cursor:w-resize}.mirt__range-handle--end::-ms-thumb{transform:translate(var(--mirt-playhead-width, .35rem));cursor:default}.mirt--initialized .mirt__range-handle--end::-ms-thumb{cursor:w-resize}.mirt__range-handle--playhead{z-index:100;pointer-events:none}.mirt__range-handle--playhead::-moz-range-thumb{width:calc(var(--mirt-playhead-width, .35rem)*2);pointer-events:all;cursor:default}.mirt--initialized .mirt__range-handle--playhead::-moz-range-thumb{cursor:ew-resize}.mirt__range-handle--playhead::-webkit-slider-thumb{width:calc(var(--mirt-playhead-width, .35rem)*2);pointer-events:all;cursor:default}.mirt--initialized .mirt__range-handle--playhead::-webkit-slider-thumb{cursor:ew-resize}.mirt__range-handle--playhead::-ms-thumb{width:calc(var(--mirt-playhead-width, .35rem)*2);pointer-events:all;cursor:default}.mirt--initialized .mirt__range-handle--playhead::-ms-thumb{cursor:ew-resize}.mirt__range-handle--playhead::-moz-range-track{cursor:default}.mirt--initialized .mirt__range-handle--playhead::-moz-range-track{cursor:ew-resize}.mirt__range-handle--playhead::-webkit-slider-runnable-track{cursor:default}.mirt--initialized .mirt__range-handle--playhead::-webkit-slider-runnable-track{cursor:ew-resize}.mirt__range-handle--playhead::-ms-track{cursor:default}.mirt--initialized .mirt__range-handle--playhead::-ms-track{cursor:ew-resize}.mirt__range-handle{position:absolute;left:0;width:100%;height:var(--mirt-height, 3rem);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#0000;margin:0;opacity:0}.mirt__range-handle::-moz-range-thumb{border-radius:0;height:100%;-moz-appearance:none;-webkit-appearance:none;appearance:none}.mirt__range-handle::-webkit-slider-thumb{border-radius:0;height:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mirt__range-handle::-ms-thumb{border-radius:0;height:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mirt__range-handle::-moz-range-track{height:var(--mirt-height, 3rem);background:#0000;-moz-appearance:none;-webkit-appearance:none;appearance:none}.mirt__range-handle::-webkit-slider-runnable-track{height:var(--mirt-height, 3rem);background:#0000;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mirt__range-handle::-ms-track{height:var(--mirt-height, 3rem);background:#0000;-webkit-appearance:none;-moz-appearance:none;appearance:none}.mirt__range-handle::-moz-focus-outer{border:0}.mirt__range-handle:focus::-ms-thumb{border:0}.mirt__range-handle::-ms-tooltip{display:none}.mirt__handles{position:absolute;top:0;right:var(--mirt-handle-width, 1.2rem);bottom:0;left:var(--mirt-handle-width, 1.2rem);z-index:200}.mirt__handle-frame{position:absolute;top:0;right:0;bottom:0;left:0;margin:0 calc(var(--mirt-handle-width, 1.2rem)*-1);border-top-width:var(--mirt-frame-border-width, .3rem);border-right-width:var(--mirt-handle-width, 1.2rem);border-bottom-width:var(--mirt-frame-border-width, .3rem);border-left-width:var(--mirt-handle-width, 1.2rem);border-style:solid;border-color:var(--mirt-frame-color, #409f80);border-radius:var(--mirt-border-radius, .3rem);transition:left var(--mirt-handle-tranisiton-duration, .5s) ease,right var(--mirt-handle-tranisiton-duration, .5s) ease}.mirt__handle-frame.mirt__handle-frame--start-dragging{transition:right var(--mirt-handle-tranisiton-duration, .5s) ease}.mirt__handle-frame.mirt__handle-frame--end-dragging{transition:left var(--mirt-handle-tranisiton-duration, .5s) ease}.mirt__handle-frame:before,.mirt__handle-frame:after{display:block;position:absolute;top:0;bottom:0;background-color:var(--mirt-background-color, #333);opacity:.7;z-index:-1;content:""}.mirt__handle-frame:before{right:100%;left:-9999px}.mirt__handle-frame:after{left:100%;right:-9999px}.mirt__playhead-track{position:absolute;top:0;right:0;bottom:0;left:0}.mirt__playhead{position:absolute;top:0;bottom:0;left:0;width:calc(var(--mirt-playhead-width, .35rem)*2);transform:translate(calc(var(--mirt-playhead-width, .35rem) * -1));transition:left var(--mirt-handle-tranisiton-duration, .5s) ease}.mirt__playhead.mirt__playhead--dragging{transition:none}.mirt__playhead:before{display:block;position:absolute;top:calc(var(--mirt-frame-border-width, .3rem)/2);bottom:calc(var(--mirt-frame-border-width, .3rem)/2);left:50%;width:var(--mirt-playhead-width, .35rem);transform:translate(-50%);background-color:var(--mirt-playhead-color, #fff);border-radius:calc(var(--mirt-playhead-width, .35rem)/2);content:""}.mirt__handle-icon{position:absolute;top:50%;width:var(--mirt-handle-icon-width, .75rem);color:var(--mirt-handle-icon-color, #333);pointer-events:none}.mirt--disabled .mirt__handle-icon{opacity:.5}.mirt__handle-icon--start{left:calc(var(--mirt-handle-width, 1.2rem)/-2);transform:translate(-50%,-50%)}.mirt__handle-icon--end{right:calc(var(--mirt-handle-width, 1.2rem)/-2);transform:translate(50%,-50%)}.mirt__waveform{position:absolute;top:var(--mirt-frame-border-width, .3rem);right:var(--mirt-handle-width, 1.2rem);bottom:var(--mirt-frame-border-width, .3rem);left:var(--mirt-handle-width, 1.2rem);z-index:100}.mirt__waveform-canvas{width:100%;height:100%}.app-selector{display:flex;flex-direction:column;gap:16px}.app-search-container{position:relative}.app-search-input-wrapper{position:relative;display:flex;align-items:center}.app-search-input{width:100%;padding:12px 40px 12px 42px;font-size:.95rem;border:2px solid #e5e7eb;border-radius:12px;background-color:#f9fafb;transition:all .2s ease}.app-search-input:focus{outline:none;border-color:#6a4cb3;background-color:#fff;box-shadow:0 0 0 3px #6a4cb31a}.app-search-input::placeholder{color:#9ca3af}.search-icon{position:absolute;left:14px;color:#9ca3af;pointer-events:none}.search-clear-btn{position:absolute;right:40px;background:none;border:none;padding:4px;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.search-clear-btn:hover{color:#374151;background-color:#e5e7eb}.search-spinner{position:absolute;right:14px;color:#6a4cb3;animation:spin 1s linear infinite}.category-tabs-wrapper{position:relative}.category-tabs-wrapper:after{content:"";position:absolute;right:0;top:0;bottom:8px;width:40px;background:linear-gradient(to right,transparent,rgba(255,255,255,.95));pointer-events:none;opacity:1;transition:opacity .2s ease}.category-tabs-wrapper.scrolled-end:after{opacity:0}.category-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;padding-right:20px;scrollbar-width:thin;scrollbar-color:#d1d5db transparent;-webkit-overflow-scrolling:touch}.category-tabs::-webkit-scrollbar{height:4px}.category-tabs::-webkit-scrollbar-track{background:transparent}.category-tabs::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.category-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;font-weight:500;color:#6b7280;background-color:#f3f4f6;border:1px solid transparent;border-radius:20px;cursor:pointer;white-space:nowrap;transition:all .2s ease}.category-tab:hover{background-color:#e5e7eb;color:#374151}.category-tab.active{background-color:#6a4cb3;color:#fff;border-color:#6a4cb3}.category-icon{font-size:1rem}.category-name{font-size:.8rem}.apps-grid-container{min-height:200px}.apps-loading,.apps-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;color:#6b7280;text-align:center}.loading-spinner{animation:spin 1s linear infinite;color:#6a4cb3}.try-again-btn,.load-apps-btn{padding:8px 16px;font-size:.85rem;font-weight:500;color:#6a4cb3;background-color:#f3e8ff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.try-again-btn:hover,.load-apps-btn:hover{background-color:#e9d5ff}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}@media (min-width: 640px){.apps-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.app-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background-color:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative}.app-card:hover{border-color:#6a4cb3;background-color:#faf5ff;transform:translateY(-2px);box-shadow:0 4px 12px #6a4cb326}.app-card.selected{border-color:#6a4cb3;background-color:#f3e8ff}.app-card.selected:after{content:"✓";position:absolute;top:8px;right:8px;width:20px;height:20px;background-color:#6a4cb3;color:#fff;border-radius:50%;font-size:12px;display:flex;align-items:center;justify-content:center}.app-icon{width:48px;height:48px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6}.app-icon img{width:100%;height:100%;object-fit:contain}.app-icon-fallback{font-size:1.5rem;font-weight:600;color:#6a4cb3}.app-icon-fallback.hidden{display:none}.app-name{font-size:.85rem;font-weight:500;color:#374151;text-align:center;line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.app-arrow{display:none;color:#6a4cb3}.app-card:hover .app-arrow{display:block;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px 0 8px;border-top:1px solid #e5e7eb;margin-top:16px}.pagination-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;font-size:.85rem;font-weight:500;color:#6a4cb3;background-color:#f8f5ff;border:1px solid #e0d4f5;border-radius:8px;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:#ede9fe;border-color:#6a4cb3}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;color:#9ca3af;background-color:#f3f4f6;border-color:#e5e7eb}.pagination-pages{display:flex;align-items:center;gap:4px}.pagination-page{min-width:36px;height:36px;padding:0 8px;font-size:.9rem;font-weight:500;color:#6b7280;background-color:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease}.pagination-page:hover{background-color:#f3f4f6;color:#374151}.pagination-page.active{background-color:#6a4cb3;color:#fff;border-color:#6a4cb3}.pagination-ellipsis{padding:0 4px;color:#9ca3af;font-weight:500}.load-more-container{display:flex;justify-content:center;padding-top:8px}.load-more-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:500;color:#6a4cb3;background-color:#f8f5ff;border:2px solid #e0d4f5;border-radius:10px;cursor:pointer;transition:all .2s ease}.load-more-btn:hover:not(:disabled){background-color:#ede9fe;border-color:#6a4cb3}.load-more-btn:disabled{cursor:not-allowed;opacity:.7}@media (max-width: 480px){.category-tabs{gap:6px}.category-tab{padding:6px 10px}.category-name{display:none}.category-tab.active .category-name{display:inline}.apps-grid{grid-template-columns:repeat(2,1fr);gap:10px}.app-card{padding:12px 8px}.app-icon{width:40px;height:40px}.app-name{font-size:.8rem}.pagination-controls{gap:8px;padding:16px 0 8px}.pagination-btn{padding:6px 10px;font-size:.8rem}.pagination-btn span{display:none}.pagination-page{min-width:32px;height:32px;font-size:.85rem}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background-color:#fff;padding:20px 30px;border-radius:8px;box-shadow:0 4px 12px #0003;text-align:center;width:90%;max-width:500px;max-height:90%;overflow-y:auto;animation:fadeIn .3s ease-out;transform:translateY(0);transition:none}.color-picker-content{display:flex;flex-direction:column;align-items:center;gap:20px;margin:20px 0}.react-colorful{width:200px!important;height:200px!important}.color-display{display:flex;align-items:center;gap:12px;background-color:#f5f5f5;padding:12px;border-radius:8px}.color-preview{width:32px;height:32px;border-radius:6px;border:2px solid #ddd}.color-code{display:flex;align-items:center;gap:8px;font-family:monospace;font-size:1.1rem;color:#1d1d1f}.copy-button{background:none;border:none;padding:4px;cursor:pointer;color:#6a4cb3;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.copy-button:hover{background-color:#e0e0e0;color:#532c8c}.close-button{position:absolute;top:8px;right:8px;background:transparent;border:none;cursor:pointer;color:#888;transition:color .3s ease}.close-button:hover{color:#dc3545}.select-button{padding:10px 20px;margin:10px 5px 0;font-size:16px;cursor:pointer;background-color:#6a4cb3;color:#fff;border:none;border-radius:4px;transition:background-color .3s ease}.select-button:hover{background-color:#532c8c}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 576px){.react-colorful{width:180px!important;height:180px!important}}.color-name-input{margin-top:1rem;width:100%}.color-name-input input{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px}.color-name-input input.error{border-color:#f44}.error-message{color:#f44;font-size:.875rem;margin-top:.25rem;display:block}.saved-colors{margin:1rem 0;padding:.75rem;background:#f5f5f5;border-radius:8px}.saved-colors h3{margin:0 0 .5rem;font-size:1rem}.color-list{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.color-item{display:flex;align-items:center;gap:.5rem;padding:.375rem;background:#fff;border-radius:4px;box-shadow:0 1px 2px #0000001a}.color-swatch{width:20px;height:20px;min-width:20px;min-height:20px;border-radius:4px;border:1px solid #ddd;overflow:hidden;position:relative;display:flex}.color-swatch>div{width:100%;height:100%}.color-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.color-value{font-family:monospace;font-size:.75rem;color:#666;margin:0 .5rem}.delete-color-btn{padding:.25rem;border:none;background:none;color:#666;cursor:pointer;border-radius:4px}.delete-color-btn:hover{background:#f0f0f0;color:#f44}.color-picker-btn{gap:8px}.button-text{margin-left:4px}.rainbow-button{padding:10px 20px;margin:10px 5px 0;font-size:16px;cursor:pointer;color:#fff;border:none;border-radius:4px;animation:rainbow 5s infinite;transition:background-color .3s ease}.rainbow-button:hover{background-color:#e6b800}@keyframes rainbow{0%{background-color:red}14%{background-color:#ff7f00}28%{background-color:#ff0}42%{background-color:#0f0}57%{background-color:#0ff}71%{background-color:#00f}85%{background-color:indigo}to{background-color:red}}.rainbow-swatch{width:100%;height:100%;background:linear-gradient(90deg,red,#ff7f00,#ff0,#0f0,#0ff,#00f,indigo);background-size:200% 100%;animation:rainbow-move 2s linear infinite}.animation-select{width:100%;padding:8px;border-radius:4px;border:1px solid #ccc;margin-bottom:16px;font-size:16px}.color-pickers{display:flex;gap:24px;flex-wrap:wrap;justify-content:center}.color-picker-section{display:flex;flex-direction:column;align-items:center;gap:12px}.color-picker-section label{font-weight:500;color:#666}.animation-preview{width:200px;height:200px;border-radius:50%;margin-bottom:20px;position:relative;overflow:hidden;background:#fff;border:none;box-shadow:none}.preview-default,.preview-police{animation:rotate 2s linear infinite}.preview-pulse{animation:pulse 2s ease-in-out infinite}.preview-rainbow{background:linear-gradient(90deg,red,#ff7f00,#ff0,#0f0,#0ff,#00f,indigo);animation:rainbow-rotate 5s linear infinite}.preview-sparkle{animation:sparkle 1s ease-in-out infinite}.preview-fire{animation:flicker 2s infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@keyframes rainbow-rotate{0%{background-position:0% center}to{background-position:200% center}}@keyframes sparkle{0%{opacity:1}50%{opacity:.3}to{opacity:1}}@keyframes flicker{0%{opacity:1}25%{opacity:.8}50%{opacity:.9}75%{opacity:.7}to{opacity:1}}.dual-color-swatch{width:100%;height:100%;display:flex;border-radius:3px}.dual-color-swatch>div{width:50%;height:100%;flex-shrink:0}.single-color-swatch{width:100%;height:100%;border-radius:3px}.single-color-swatch.pulse{animation:pulse-preview 2s infinite}.single-color-swatch.sparkle{animation:sparkle-preview 1s infinite}@media (min-width: 768px){.color-swatch{width:20px;height:20px}.color-item{padding:.5rem}}.copy-color-btn{padding:.25rem;border:none;background:none;color:#666;cursor:pointer;border-radius:4px}.copy-color-btn:hover{background:#f0f0f0;color:#6a4cb3}.fire-swatch{width:100%;height:100%;position:relative;overflow:hidden;border-radius:3px}.fire-gradient{width:200%;height:100%;background:linear-gradient(90deg,red,#ff6b00,#fb0,#fec,red);background-size:200% 100%;animation:fire-move 2s linear infinite}.police-animation{position:relative;overflow:hidden}.police-animation>div{position:absolute;width:50%;height:100%;transition:transform 1s ease-in-out;animation:police-swap 2s infinite ease-in-out}.police-animation>div:first-child{left:0;animation-delay:-1s}.police-animation>div:last-child{right:0;animation-delay:0s}.dual-color-swatch.police-animation{position:relative;display:block}.led-ring-preview{width:150px;height:150px;position:relative;margin:50px auto;border-radius:50%;background:#1a1a1a;padding:15px;box-shadow:inset 0 0 20px #00000080}.led{width:12px;height:12px;position:absolute;left:69px;top:69px;border-radius:50%;transition:background-color .1s;box-shadow:0 0 5px #ffffff80}.led[style*=rgb]{box-shadow:0 0 5px currentColor,0 0 10px currentColor}.wizard-container{display:flex;flex-direction:column;min-height:calc(100vh - var(--bottom-nav-height) - var(--header-height))}.wizard-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.wizard-back-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-primary);transition:background-color var(--transition-fast)}.wizard-back-btn:hover{background-color:var(--color-bg-tertiary)}.wizard-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.wizard-progress{display:flex;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);padding:0 var(--space-4)}.wizard-progress-step{display:flex;align-items:center}.wizard-progress-dot{width:28px;height:28px;border-radius:var(--radius-full);background-color:var(--color-bg-tertiary);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.wizard-progress-step.current .wizard-progress-dot{background-color:var(--color-primary);color:#fff;transform:scale(1.1)}.wizard-progress-step.completed .wizard-progress-dot{background-color:var(--color-success);color:#fff}.wizard-progress-step.clickable{cursor:pointer}.wizard-progress-step.clickable:hover .wizard-progress-dot{transform:scale(1.15);box-shadow:0 2px 8px #00000026}.wizard-content{flex:1}.wizard-step{display:flex;flex-direction:column;gap:var(--space-4)}.step-description{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0;text-align:center}.wizard-auth-prompt{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);max-width:400px;margin:0 auto}.auth-prompt-icon{font-size:48px}.wizard-auth-prompt h2{font-size:var(--font-size-xl);margin:0}.wizard-auth-prompt p{color:var(--color-text-secondary);margin:0}.step-intro{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);max-width:400px;margin:0 auto}.step-intro-icon{width:64px;height:64px;border-radius:var(--radius-lg);background-color:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:32px}.step-intro-icon img{width:40px;height:40px;object-fit:contain}.step-intro h2{font-size:var(--font-size-xl);margin:0}.step-intro p{color:var(--color-text-secondary);margin:0}.existing-accounts{width:100%;display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.existing-accounts-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.account-option{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--color-bg-secondary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm)}.account-option:hover{border-color:var(--color-primary-light)}.account-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-bg)}.device-selector{margin-bottom:var(--space-4)}.trigger-list{display:flex;flex-direction:column;gap:var(--space-2)}.trigger-option{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:none;border:2px solid transparent;cursor:pointer;text-align:left;transition:all var(--transition-fast)}.trigger-option:hover{border-color:var(--color-primary-light)}.trigger-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-bg)}.trigger-option-content{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.trigger-option-name{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.trigger-option-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.trigger-option-arrow{color:var(--color-text-muted);flex-shrink:0}.config-fields{display:flex;flex-direction:column;gap:var(--space-4)}.field-description{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0 0 var(--space-2)}.field-loading{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background-color:var(--color-bg-tertiary);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.loading-spinner-small{width:16px;height:16px;border:2px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.form-group-checkbox{padding:var(--space-2) 0}.form-checkbox-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.form-checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.required{color:var(--color-error);margin-left:var(--space-1)}.sound-actions{display:flex;justify-content:center;margin-bottom:var(--space-2)}.sound-list{display:flex;flex-direction:column;gap:var(--space-2)}.sound-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:none;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.sound-option:hover{border-color:var(--color-primary-light)}.sound-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-bg)}.sound-play-btn{width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color var(--transition-fast)}.sound-play-btn:hover{background-color:var(--color-primary-dark)}.sound-name{flex:1;font-size:var(--font-size-base);color:var(--color-text-primary);text-align:left}.animation-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.animation-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:none;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.animation-option:hover{border-color:var(--color-primary-light)}.animation-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-bg)}.animation-swatch{width:48px;height:48px;border-radius:var(--radius-full);box-shadow:inset 0 2px 4px #0000001a}.animation-name{font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:center}.animation-list-compact{display:flex;flex-direction:column;gap:var(--space-2)}.animation-option-compact{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:none;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);text-align:left}.animation-option-compact:hover{border-color:var(--color-primary-light)}.animation-option-compact.selected{border-color:var(--color-primary);background-color:var(--color-primary-bg)}.animation-option-compact .animation-name{flex:1;text-align:left}.color-swatch-mini{width:36px;height:36px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.color-swatch-mini .single-color-swatch{width:100%;height:100%;border-radius:var(--radius-md)}.color-swatch-mini .single-color-swatch.pulse{animation:pulse-swatch 2s ease-in-out infinite}.color-swatch-mini .single-color-swatch.sparkle{animation:sparkle-swatch .5s ease-in-out infinite}@keyframes pulse-swatch{0%,to{opacity:1}50%{opacity:.5}}@keyframes sparkle-swatch{0%,to{opacity:1}50%{opacity:.7}}.color-swatch-mini .rainbow-swatch{width:100%;height:100%;background:linear-gradient(90deg,red,#ff8000,#ff0,#0f0,#0080ff,#8000ff,red);background-size:200% 100%;animation:rainbow-shift 2s linear infinite}@keyframes rainbow-shift{0%{background-position:0% 50%}to{background-position:200% 50%}}.color-swatch-mini .fire-swatch{width:100%;height:100%;position:relative;overflow:hidden}.color-swatch-mini .fire-gradient{width:100%;height:100%;background:linear-gradient(0deg,red,#ff6b00,#fb0,#fec);animation:fire-flicker .3s ease-in-out infinite alternate}@keyframes fire-flicker{0%{opacity:.8;transform:scaleY(.95)}to{opacity:1;transform:scaleY(1)}}.color-swatch-mini .dual-color-swatch{width:100%;height:100%;display:flex}.color-swatch-mini .dual-color-swatch>div{flex:1;height:100%}.color-swatch-mini .dual-color-swatch.police-animation>div:first-child{animation:police-flash-1 .5s ease-in-out infinite}.color-swatch-mini .dual-color-swatch.police-animation>div:last-child{animation:police-flash-2 .5s ease-in-out infinite}@keyframes police-flash-1{0%,50%{opacity:1}51%,to{opacity:.3}}@keyframes police-flash-2{0%,50%{opacity:.3}51%,to{opacity:1}}.review-summary{display:flex;flex-direction:column;gap:var(--space-4)}.review-summary h2{font-size:var(--font-size-xl);text-align:center;margin:0}.review-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-light)}.review-item:last-of-type{border-bottom:none}.review-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.review-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.review-value-with-swatch{display:flex;align-items:center;gap:var(--space-2)}.review-value-with-swatch .color-swatch-mini{width:24px;height:24px;border-radius:var(--radius-sm);flex-shrink:0}.loading-state{display:flex;justify-content:center;align-items:center;padding:var(--space-8);color:var(--color-text-secondary)}.connected-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4) 0;width:100%}.connected-state span{font-size:var(--font-size-base);color:var(--color-success);font-weight:var(--font-weight-medium)}.sound-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);background-color:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--space-1)}.sound-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast)}.sound-tab.active{background-color:var(--color-bg-primary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.inline-generator{display:flex;flex-direction:column;gap:var(--space-4)}.generator-mode-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-2)}.generator-mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);background:var(--color-bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast)}.generator-mode-tab:hover{border-color:var(--color-primary-light)}.generator-mode-tab.active{border-color:var(--color-primary);background-color:var(--color-primary-bg);color:var(--color-primary)}.generator-intro{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;margin:0 0 var(--space-3)}.generator-quick-form,.generator-custom-form{display:flex;flex-direction:column;gap:var(--space-3)}.lyrics-preview{background-color:var(--color-bg-secondary);border-radius:var(--radius-md);padding:var(--space-3);margin-top:var(--space-2)}.lyrics-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.lyrics-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.lyrics-textarea{min-height:120px;font-size:var(--font-size-sm);line-height:1.5}.lyrics-content{max-height:150px;overflow-y:auto;font-size:var(--font-size-sm);line-height:1.6}.lyrics-footer{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}.lyrics-style{font-size:var(--font-size-xs);color:var(--color-text-muted)}.char-count{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:right;margin-top:var(--space-1)}.tag-btn{padding:var(--space-1) var(--space-2);background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);font-family:monospace;color:var(--color-primary);transition:all var(--transition-fast)}.tag-btn:hover{background:var(--color-primary-bg);border-color:var(--color-primary-light)}.generating-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-6) 0}.generating-animation{margin-bottom:var(--space-4)}.generating-state h3{font-size:var(--font-size-lg);margin:0 0 var(--space-2)}.generating-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.preview-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-4) 0;gap:var(--space-3)}.preview-icon-large{width:64px;height:64px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));display:flex;align-items:center;justify-content:center;color:#fff}.preview-state h3{font-size:var(--font-size-lg);margin:0}.preview-play-btn-large{width:72px;height:72px;border-radius:var(--radius-full);background:var(--color-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.preview-play-btn-large:hover{background:var(--color-primary-dark);transform:scale(1.05)}.preview-play-btn-large:disabled{opacity:.5;cursor:not-allowed}.preview-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.preview-actions{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.trim-state{display:flex;flex-direction:column;gap:var(--space-3)}.trim-state h3{font-size:var(--font-size-lg);margin:0;text-align:center}.trim-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;margin:0}.trim-waveform{border-radius:var(--radius-md);overflow:hidden;--mirt-frame-color: #6a4cb3;--mirt-button-icon-color: #ffffff;--mirt-handle-icon-color: #ffffff;--mirt-playhead-color: #ffffff}.trim-duration{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.duration-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.duration-value.valid{color:var(--color-success)}.duration-value.invalid{color:var(--color-error)}.trim-controls{display:flex;flex-direction:column;gap:var(--space-3)}.bass-toggle{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.bass-toggle input{display:none}.toggle-track{width:44px;height:24px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);position:relative;transition:background var(--transition-fast)}.bass-toggle input:checked+.toggle-track{background:var(--color-primary)}.toggle-indicator{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.toggle-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.error-message{color:var(--color-error);font-size:var(--font-size-sm);text-align:center;margin:0}@media (min-width: 768px){.wizard-progress{gap:var(--space-3)}.wizard-progress-dot{width:32px;height:32px;font-size:var(--font-size-sm)}.animation-list{grid-template-columns:repeat(3,1fr)}.sound-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.style-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.animation-list{grid-template-columns:repeat(4,1fr)}}.sounds-library{display:flex;flex-direction:column;gap:var(--space-6)}.page-header{text-align:center;margin-bottom:var(--space-2)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-2)}.page-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.sounds-actions{display:flex;gap:var(--space-3);justify-content:center}.section-header{margin-bottom:var(--space-3)}.section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.upload-section{margin-bottom:var(--space-3)}.sounds-library .upload-zone{display:flex;align-items:center;justify-content:center;min-height:auto;padding:var(--space-3);border:1px dashed var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-secondary);cursor:pointer;transition:all var(--transition-fast)}.sounds-library .upload-zone:hover,.sounds-library .upload-zone.dragging{border-color:var(--color-primary);background-color:var(--color-primary-bg)}.sounds-library .upload-input{display:none}.sounds-library .upload-label{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:var(--space-2);cursor:pointer}.sounds-library .upload-icon{color:var(--color-primary);width:18px;height:18px;flex-shrink:0}.sounds-library .upload-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.sounds-library .upload-text-mobile{display:inline}.sounds-library .upload-text-desktop,.sounds-library .upload-hint{display:none}@media (min-width: 768px){.sounds-library .upload-zone{padding:var(--space-4)}.sounds-library .upload-icon{width:20px;height:20px}.sounds-library .upload-text-mobile{display:none}.sounds-library .upload-text-desktop{display:inline}.sounds-library .upload-hint{display:inline;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-left:var(--space-1)}}.trim-editor{padding:var(--space-5)}.trim-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.trim-filename{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.trim-waveform{margin-bottom:var(--space-4);border-radius:var(--radius-md);overflow:hidden;--mirt-frame-color: #6a4cb3;--mirt-button-icon-color: #ffffff;--mirt-handle-icon-color: #ffffff;--mirt-playhead-color: #ffffff}.trim-waveform .mirt-container{background-color:var(--color-bg-tertiary)!important;border-radius:var(--radius-md)}.trim-waveform .mirt{border:none!important;outline:none!important}.trim-waveform .mirt__wave-container{border:none!important}.trim-waveform .mirt__range-handle--end{padding-left:var(--mirt-handle-width, 0rem)}.trim-duration{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background-color:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-4);flex-wrap:wrap}.duration-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.duration-value{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.duration-value.valid{color:var(--color-success);background-color:#22c55e1a}.duration-value.invalid{color:var(--color-error);background-color:#ef44441a;animation:pulse-invalid 1s ease-in-out infinite}@keyframes pulse-invalid{0%,to{opacity:1}50%{opacity:.5}}.duration-hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.help-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:none;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast);margin-left:auto}.help-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.trim-controls{display:flex;flex-direction:column;gap:var(--space-4)}.trim-name-input{display:flex;flex-direction:column;gap:var(--space-2)}.bass-toggle{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.bass-toggle input[type=checkbox]{display:none}.toggle-track{width:44px;height:24px;background-color:var(--color-bg-tertiary);border-radius:var(--radius-full);position:relative;transition:background-color var(--transition-fast)}.bass-toggle input:checked+.toggle-track{background-color:var(--color-primary)}.toggle-indicator{position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:var(--radius-full);transition:transform var(--transition-fast)}.bass-toggle input:checked+.toggle-track .toggle-indicator{transform:translate(20px)}.toggle-label{font-size:var(--font-size-sm);color:var(--color-text-primary)}.sounds-section{margin-top:var(--space-2)}.sounds-grid{display:grid;grid-template-columns:1fr;gap:var(--space-3)}.sound-card{padding:var(--space-4)}.sound-card-main{display:flex;align-items:center;gap:var(--space-3)}.sound-play-btn{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),transform var(--transition-fast);flex-shrink:0;padding:0}.sound-play-btn svg{width:24px!important;height:24px!important;min-width:24px;min-height:24px}.sound-play-btn:hover{background-color:var(--color-primary-dark);transform:scale(1.05)}.sound-play-btn.playing{background-color:var(--color-success)}.sound-card-info{flex:1;min-width:0}.sound-card-name{display:block;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sound-card-type{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase}.sound-card-actions{position:relative;flex-shrink:0}.sound-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-dropdown)}.sound-menu{position:absolute;top:100%;right:0;background-color:var(--color-bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-light);min-width:120px;z-index:calc(var(--z-dropdown) + 1);overflow:hidden}.sound-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);transition:background-color var(--transition-fast)}.sound-menu-item:hover{background-color:var(--color-bg-tertiary)}.sound-menu-item-danger{color:var(--color-error)}.sound-menu-item-danger:hover{background-color:var(--color-error-light)}@media (min-width: 640px){.sounds-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.sounds-grid{grid-template-columns:repeat(3,1fr)}.page-header{text-align:left}.sounds-actions{justify-content:flex-start}}.demo-categories{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);margin-bottom:var(--space-4)}.demo-category-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);background-color:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.demo-category-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.demo-category-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.demo-category-icon{font-size:var(--font-size-base);flex-shrink:0}.demo-category-label{white-space:nowrap}.demo-category-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:10px;font-weight:var(--font-weight-bold);background-color:#0000001a;border-radius:var(--radius-full)}.demo-category-btn.active .demo-category-count{background-color:#fff3}@media (min-width: 768px){.demo-categories{grid-template-columns:repeat(4,1fr)}}.sound-generator{display:flex;flex-direction:column;gap:var(--space-4);padding-bottom:var(--space-6)}.generator-header{display:flex;align-items:center;gap:var(--space-3)}.generator-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.generator-tabs{display:flex;gap:var(--space-2);padding:var(--space-1);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg)}.generator-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:none;background:transparent;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.generator-tab:hover{color:var(--color-text-primary)}.generator-tab.active{background-color:var(--color-bg-primary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.generator-form{display:flex;flex-direction:column;gap:var(--space-5)}.generator-intro{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg)}.generator-icon{width:64px;height:64px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));display:flex;align-items:center;justify-content:center;color:#fff}.generator-description{color:var(--color-text-secondary);margin:0;max-width:320px}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-hint{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--color-text-muted)}.char-count{font-variant-numeric:tabular-nums}.generator-textarea{min-height:120px;resize:vertical;font-family:inherit;line-height:1.5}.example-prompts{display:flex;flex-direction:column;gap:var(--space-2)}.example-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.example-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.example-chip{padding:var(--space-2) var(--space-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.example-chip:hover{background-color:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.error-message{color:var(--color-error);font-size:var(--font-size-sm);margin:0;padding:var(--space-3);background-color:#ef44441a;border-radius:var(--radius-md)}.generate-btn{margin-top:var(--space-2)}.generating-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);padding:var(--space-8) var(--space-4)}.generating-animation{width:100px;height:100px;display:flex;align-items:center;justify-content:center}.generating-state h2{font-size:var(--font-size-xl);margin:0}.generating-hint{color:var(--color-text-secondary);margin:0;max-width:280px}.generating-progress{width:100%;max-width:200px}.progress-bar{height:4px;background-color:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;width:30%;background-color:var(--color-primary);animation:progress 2s ease-in-out infinite}@keyframes progress{0%{width:0%;margin-left:0%}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.preview-state{display:flex;flex-direction:column;gap:var(--space-4)}.preview-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);padding:var(--space-6)}.preview-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.preview-icon{width:64px;height:64px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-success),#059669);display:flex;align-items:center;justify-content:center;color:#fff}.preview-header h2{font-size:var(--font-size-xl);margin:0}.preview-play-btn{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.preview-play-btn:hover{transform:scale(1.05);box-shadow:var(--shadow-lg)}.preview-play-btn:active{transform:scale(.98)}.preview-play-btn.playing{background:linear-gradient(135deg,#ef4444,#dc2626);animation:pulse-ring 1.5s ease-out infinite}@keyframes pulse-ring{0%{box-shadow:0 0 #6366f166}70%{box-shadow:0 0 0 15px #6366f100}to{box-shadow:0 0 #6366f100}}.preview-hint{color:var(--color-text-muted);font-size:var(--font-size-sm);margin:0}.preview-actions{display:flex;gap:var(--space-3)}.save-section{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5)}.save-btn{width:100%}.saving-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);padding:var(--space-8) var(--space-4)}.saving-spinner{width:48px;height:48px;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.saving-state h2{font-size:var(--font-size-xl);margin:0}.saving-state p{color:var(--color-text-secondary);margin:0}.preview-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0;max-width:300px}.section-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0 0 var(--space-3) 0}.optional-tag{color:var(--color-text-muted);font-weight:var(--font-weight-normal)}.context-section{display:flex;flex-direction:column}.context-row{display:flex;gap:var(--space-3)}.dropdown-container{flex:1;position:relative}.dropdown-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);min-height:44px}.dropdown-trigger:hover{border-color:var(--color-border-hover)}.dropdown-trigger.open{border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f11a}.dropdown-trigger.disabled{opacity:.5;cursor:not-allowed}.dropdown-trigger .selected-item{display:flex;align-items:center;gap:var(--space-2);flex:1;color:var(--color-text-primary)}.dropdown-trigger .clear-btn{background:none;border:none;padding:0 var(--space-1);font-size:var(--font-size-lg);color:var(--color-text-muted);cursor:pointer;line-height:1}.dropdown-trigger .clear-btn:hover{color:var(--color-error)}.app-icon{width:20px;height:20px;border-radius:var(--radius-sm);object-fit:contain}.dropdown-menu{position:absolute;top:calc(100% + var(--space-1));left:0;right:0;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:280px;display:flex;flex-direction:column;overflow:hidden}.dropdown-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-bottom:1px solid var(--color-border)}.dropdown-search input{flex:1;border:none;background:transparent;font-size:var(--font-size-sm);color:var(--color-text-primary);outline:none}.dropdown-search input::placeholder{color:var(--color-text-muted)}.dropdown-options{flex:1;overflow-y:auto;max-height:220px}.dropdown-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;transition:background-color var(--transition-fast)}.dropdown-option:hover{background-color:var(--color-bg-secondary)}.dropdown-loading,.dropdown-empty,.dropdown-hint{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-muted)}.style-section{display:flex;flex-direction:column}.style-grid{display:grid;grid-template-columns:1fr;gap:var(--space-3)}.style-grid .form-group{gap:var(--space-1)}.style-grid .form-label{font-size:var(--font-size-xs)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);cursor:pointer}.generate-lyrics-btn{width:100%}.lyrics-preview{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.lyrics-preview-header{display:flex;justify-content:space-between;align-items:center}.lyrics-preview-header .section-label{margin:0}.lyrics-content{font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-primary)}.lyrics-content p{margin:0}.lyrics-content .lyrics-tag{color:var(--color-primary);font-weight:var(--font-weight-medium);margin-top:var(--space-2)}.lyrics-content .lyrics-tag:first-child{margin-top:0}.tag-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.tag-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.tag-btn{padding:var(--space-1) var(--space-2);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-family:monospace;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.tag-btn:hover{background-color:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.spin{animation:spin 1s linear infinite}@media (min-width: 768px){.generator-form{max-width:600px;margin:0 auto}.style-grid{grid-template-columns:repeat(3,1fr)}.context-row{gap:var(--space-4)}.preview-state{max-width:600px;margin:0 auto}.preview-card{padding:var(--space-8)}.preview-play-btn{width:120px;height:120px}.preview-play-btn svg{width:48px;height:48px}.preview-header h2{font-size:var(--font-size-2xl)}.preview-icon{width:80px;height:80px}.preview-icon svg{width:40px;height:40px}.preview-actions{gap:var(--space-4)}.preview-actions .btn{padding:var(--space-3) var(--space-5)}}.animations-library{display:flex;flex-direction:column;gap:var(--space-5)}.add-animation-btn{align-self:flex-start}.animations-section{display:flex;flex-direction:column;gap:var(--space-4)}.animations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-4)}.animation-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4);position:relative}.animation-preview-container{width:140px;height:140px;display:flex;align-items:center;justify-content:center;position:relative}.animation-preview-container .led-ring-preview{margin:0;background:transparent;box-shadow:none;transform:scale(.85);transform-origin:center center}.animation-info{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);text-align:center;width:100%}.animation-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);word-break:break-word}.animation-type{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:capitalize}.animation-delete-btn{position:absolute;top:var(--space-2);right:var(--space-2);opacity:0}.animation-card:hover .animation-delete-btn{opacity:1}.animation-delete-btn:hover{color:var(--color-error)!important;background-color:var(--color-error-light)!important}@media (max-width: 640px){.animations-grid{grid-template-columns:repeat(2,1fr)}.animation-preview-container{width:120px;height:120px}.animation-preview-container .led-ring-preview{margin:0;background:transparent;box-shadow:none;transform:scale(.7);transform-origin:center center}.animation-delete-btn{opacity:1}}@media (min-width: 1024px){.animations-grid{grid-template-columns:repeat(4,1fr)}}.devices-list{display:flex;flex-direction:column;gap:var(--space-6)}.devices-list .page-header{display:flex;flex-direction:column;gap:var(--space-4);text-align:center}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10);color:var(--color-text-secondary)}.devices-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.device-card{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5);border:2px solid transparent;transition:box-shadow .3s ease}.device-card.device-online{border-color:#28a745;animation:device-card-pulse 2s infinite}.device-card.device-offline{border-color:#dc3545}@keyframes device-card-pulse{0%{box-shadow:0 0 #28a745b3}70%{box-shadow:0 0 0 10px #28a74500}to{box-shadow:0 0 #28a74500}}.device-card-header{display:flex;align-items:center;gap:var(--space-3)}.device-status-indicator{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.device-status-indicator.online{background-color:var(--color-success-light);color:var(--color-success)}.device-status-indicator.offline{background-color:var(--color-error-light);color:var(--color-error)}.device-card-info{flex:1;min-width:0}.device-card-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-card-id{font-size:var(--font-size-sm);color:var(--color-text-muted);font-family:monospace}.device-card-meta{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background-color:var(--color-bg-secondary);border-radius:var(--radius-md)}.device-meta-row{display:flex;justify-content:space-between;align-items:center}.device-meta-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.device-meta-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-2)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.device-card-actions{display:flex;gap:var(--space-2)}.device-card-actions .btn-primary{flex:1}.device-card-remove{color:var(--color-text-muted)}.device-card-remove:hover{color:var(--color-error);background-color:var(--color-error-light)}@media (min-width: 640px){.devices-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.devices-list .page-header{flex-direction:row;justify-content:space-between;align-items:flex-start;text-align:left}}@media (min-width: 1024px){.devices-grid{grid-template-columns:repeat(3,1fr)}}.friends-page{display:flex;flex-direction:column;gap:var(--space-5)}.friends-page h2{display:none}.friends-page h3{display:flex;align-items:center;gap:var(--space-2);color:var(--color-primary-dark);margin-bottom:var(--space-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.friend-code-section{background:linear-gradient(135deg,var(--color-primary-bg) 0%,#ede9fe 100%);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center}.friend-code-section label{font-weight:600;color:#4c278e}.friend-code-display{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:10px}.friend-code{font-family:monospace;font-size:1.5em;font-weight:700;color:#4c278e;background:#fff;padding:10px 20px;border-radius:8px;border:2px dashed #a78bfa}.copy-button{background:#4c278e;color:#fff;border:none;border-radius:8px;padding:10px;cursor:pointer;transition:all .2s ease}.copy-button:hover{background:#3730a3;transform:scale(1.05)}.friend-code-hint{font-size:.85em;color:#6b7280;margin-top:10px}.add-friend-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px;background:linear-gradient(135deg,#4c278e,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:25px}.add-friend-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #7c3aed66}.pokebacks-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;padding:20px;margin-bottom:25px;border:2px solid #f59e0b}.pokebacks-section h3{color:#92400e}.section-hint{font-size:.9em;color:#78350f;margin-bottom:15px}.pokeback-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:15px;border-radius:8px;margin-bottom:10px}.pokeback-info{display:flex;flex-direction:column}.pokeback-sender{font-weight:600;color:#78350f}.pokeback-time{font-size:.85em;color:#a16207}.pokeback-button{display:flex;align-items:center;gap:6px;background:#f59e0b;color:#fff;border:none;border-radius:8px;padding:10px 15px;font-weight:600;cursor:pointer;transition:all .2s ease}.pokeback-button:hover{background:#d97706;transform:scale(1.05)}.pending-requests-section{background:#fef2f2;border-radius:12px;padding:20px;margin-bottom:25px;border:1px solid #fecaca}.pending-requests-section h3{color:#991b1b}.request-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:15px;border-radius:8px;margin-bottom:10px}.request-info{display:flex;align-items:center;gap:10px;color:#374151}.request-actions{display:flex;gap:8px}.accept-button{background:#10b981;color:#fff;border:none;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease}.accept-button:hover{background:#059669}.decline-button{background:#ef4444;color:#fff;border:none;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease}.decline-button:hover{background:#dc2626}.friends-list-section{margin-bottom:25px}.no-friends-message{text-align:center;color:#6b7280;padding:30px;background:#f9fafb;border-radius:12px;border:2px dashed #d1d5db}.friends-list{display:flex;flex-direction:column;gap:10px}.friend-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:15px 20px;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 2px 4px #0000000d;transition:all .2s ease}.friend-item:hover{border-color:#a78bfa;box-shadow:0 4px 12px #7c3aed1a}.friend-info{display:flex;align-items:center;gap:12px;color:#374151}.friend-email{font-weight:500}.friend-actions{display:flex;gap:8px}.trigger-button{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#4c278e,#7c3aed);color:#fff;border:none;border-radius:8px;padding:8px 15px;font-weight:500;cursor:pointer;transition:all .2s ease}.trigger-button:hover{transform:scale(1.05);box-shadow:0 2px 8px #7c3aed66}.settings-button{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease}.settings-button:hover{background:#e5e7eb}.friends-page .modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px;box-sizing:border-box}.friends-page .modal-content{background:#fff;padding:30px;border-radius:16px;max-width:450px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.friends-page .modal-content h3{text-align:center;margin-bottom:20px;color:#4c278e}.friends-page .modal-content input,.friends-page .modal-content select{width:100%;padding:12px 15px;border:1px solid #d1d5db;border-radius:8px;font-size:1em;margin-bottom:15px;box-sizing:border-box}.friends-page .modal-content input:focus,.friends-page .modal-content select:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.select-group{margin-bottom:15px}.select-group label{display:block;font-weight:500;color:#374151;margin-bottom:5px}.no-devices-hint{font-size:.85em;color:#ef4444;margin-top:5px}.rate-limit-hint,.pokeback-expires-hint{font-size:.85em;color:#6b7280;text-align:center;margin-bottom:15px}.settings-group{margin-bottom:20px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}.friends-page .modal-buttons{display:flex;flex-direction:column;gap:10px;margin-top:20px}.friends-page .modal-buttons button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:8px;font-size:1em;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.friends-page .modal-buttons button:first-child{background:linear-gradient(135deg,#4c278e,#7c3aed);color:#fff}.friends-page .modal-buttons button:first-child:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed66}.friends-page .modal-buttons button:first-child:disabled{opacity:.6;cursor:not-allowed}.friends-page .modal-buttons button:not(:first-child){background:#f3f4f6;color:#374151}.friends-page .modal-buttons button:not(:first-child):hover{background:#e5e7eb}.danger-button{background:#fee2e2!important;color:#dc2626!important}.danger-button:hover{background:#fecaca!important}.friends-page .loading-animation{height:200px;min-height:200px}@media (max-width: 600px){.friend-code{font-size:1.2em;padding:var(--space-2) var(--space-3)}.friend-item{flex-direction:column;gap:var(--space-3);align-items:stretch}.friend-info,.friend-actions{justify-content:center}.pokeback-item{flex-direction:column;gap:var(--space-2);text-align:center}.request-item{flex-direction:column;gap:var(--space-2)}.request-actions{justify-content:center}.friends-page .modal-content{padding:var(--space-5);margin:var(--space-2)}}.friends-page-wrapper{display:flex;flex-direction:column;gap:var(--space-6)}.friends-page-wrapper .page-header{text-align:center;margin-bottom:var(--space-2)}.friends-page-wrapper .page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-2)}.friends-page-wrapper .page-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}@media (min-width: 1024px){.friends-page-wrapper .page-header{text-align:left}}.settings-page{display:flex;flex-direction:column;gap:var(--space-6);max-width:600px;margin:0 auto}.settings-section{display:flex;flex-direction:column;gap:var(--space-3)}.settings-user-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.settings-user-avatar{width:72px;height:72px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-2xl)}.settings-user-email{font-size:var(--font-size-base);color:var(--color-text-secondary)}.settings-list{display:flex;flex-direction:column;overflow:hidden}.settings-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:none;border:none;cursor:pointer;font-size:var(--font-size-base);color:var(--color-text-primary);text-decoration:none;transition:background-color var(--transition-fast)}.settings-item:hover{background-color:var(--color-bg-tertiary)}.settings-item:not(:last-child){border-bottom:1px solid var(--color-border-light)}.settings-item span{flex:1;text-align:left}.settings-item-external{color:var(--color-text-muted)}.settings-logout{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-4);background:none;border:1px solid var(--color-error);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-error);transition:all var(--transition-fast)}.settings-logout:hover{background-color:var(--color-error);color:#fff}.settings-footer{text-align:center;padding-top:var(--space-6);border-top:1px solid var(--color-border-light)}.settings-footer p{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.settings-footer p:first-child{margin-bottom:var(--space-1)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.form-error{padding:var(--space-3);background-color:var(--color-error-light);color:var(--color-error);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-4)}.changelog-list{display:flex;flex-direction:column;gap:var(--space-4)}.changelog-entry{display:flex;flex-direction:column;gap:var(--space-2)}.changelog-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.changelog-meta{display:flex;align-items:center;gap:var(--space-3)}.changelog-date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.changelog-notes{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0;white-space:pre-wrap}.searchable-dropdown{position:relative;width:100%}.dropdown-label{display:block;font-size:.9rem;font-weight:500;color:#333;margin-bottom:6px}.dropdown-trigger{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background-color:#fff;border:1px solid #e5e5e5;border-radius:10px;cursor:pointer;transition:all .2s ease;min-height:44px}.dropdown-trigger:hover:not(.disabled){border-color:#6a4cb3}.dropdown-trigger.open{border-color:#6a4cb3;box-shadow:0 0 0 2px #6a4cb31a;border-bottom-left-radius:0;border-bottom-right-radius:0}.dropdown-trigger.disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.placeholder{color:#9ca3af;font-size:.9rem}.selected-value{display:flex;align-items:center;gap:8px;flex:1}.selected-value .option-icon{font-size:1.1rem}.selected-value .option-label{font-size:.9rem;font-weight:500;color:#333}.clear-button{display:flex;align-items:center;justify-content:center;padding:4px;margin-left:auto;margin-right:8px;color:#9ca3af;background:none;border:none;border-radius:4px;cursor:pointer;transition:all .15s ease}.clear-button:hover{color:#dc2626;background-color:#fef2f2}.chevron{color:#6b7280;transition:transform .2s ease;flex-shrink:0}.chevron.rotated{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid #6a4cb3;border-top:none;border-bottom-left-radius:10px;border-bottom-right-radius:10px;box-shadow:0 8px 30px #0000001f;z-index:9999;max-height:280px;overflow:hidden;display:flex;flex-direction:column}.search-container{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid #e5e5e5;background-color:#fafafa}.search-icon{color:#9ca3af;flex-shrink:0}.search-input{flex:1;padding:6px 10px;font-size:.85rem;border:none;background:transparent;outline:none}.search-input::placeholder{color:#9ca3af}.search-spinner{width:16px;height:16px;border:2px solid #e5e5e5;border-top-color:#6a4cb3;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.options-list{overflow-y:auto;max-height:220px;padding:4px 0}.no-options{padding:16px;text-align:center;color:#9ca3af;font-style:italic;font-size:.85rem}.option{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:background-color .15s ease}.option:hover:not(.disabled){background-color:#f4f0ff}.option.selected{background-color:#ede9fe}.option.disabled{opacity:.5;cursor:not-allowed}.option-content{display:flex;align-items:center;gap:10px}.option-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}.option-icon.custom-icon{display:flex;align-items:center;justify-content:center}.option-icon-img{width:24px;height:24px;border-radius:4px;object-fit:contain;flex-shrink:0}.option-text{display:flex;flex-direction:column;gap:1px}.option-label{font-size:.9rem;font-weight:500;color:#333}.option-description{font-size:.75rem;color:#6b7280}.check-icon{color:#6a4cb3;flex-shrink:0}@media (max-width: 576px){.dropdown-trigger{padding:10px 12px;min-height:42px}.option{padding:10px 12px}.option-icon{font-size:1rem;width:22px}}.integration-selector{display:flex;flex-direction:column;gap:24px;max-width:100%;overflow-x:hidden}.zapier-connection-status{padding:20px 24px;background-color:#fff;border:1px solid #e5e5e5;border-radius:12px}.integration-selector.loading{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:12px;padding:40px;color:#6e6e73}.integration-selector .spinner{animation:spin 1s linear infinite}.connection-loading{display:flex;align-items:center;gap:10px;color:#6a4cb3;font-weight:500}.connection-connected{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.connected-indicator{display:flex;align-items:center;gap:8px;color:#16a34a;font-weight:500}.disconnect-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;color:#dc2626;background-color:transparent;border:1px solid #fecaca;border-radius:6px;cursor:pointer;transition:all .2s ease}.disconnect-btn:hover{background-color:#fef2f2;border-color:#dc2626}.connection-required{display:flex;flex-direction:column;gap:12px}.not-connected-text{color:#6b7280;font-size:.9rem}.auth-error-text{color:#dc2626;font-size:.85rem;margin-top:8px}.connect-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6a4cb3,#4c278e);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;align-self:flex-start}.connect-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #6a4cb359}.connect-btn:disabled{opacity:.6;cursor:not-allowed}.wizard-section{display:flex;flex-direction:column}.start-wizard-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 28px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6a4cb3,#4c278e);border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;align-self:flex-start}.start-wizard-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6a4cb359}.wizard-card{background:#fff;border:1px solid #e5e5e5;border-radius:16px;overflow:visible;box-shadow:0 4px 20px #00000014;max-width:100%}.wizard-progress{display:flex;align-items:center;gap:0;padding:20px 24px;background:linear-gradient(135deg,#f8f6ff,#f0ebff);border-bottom:1px solid #e5e5e5;overflow-x:hidden}.progress-step{display:flex;align-items:center;gap:8px;cursor:pointer;flex-shrink:0;position:relative;padding-right:32px}.progress-step:last-child{padding-right:0}.progress-step:after{content:"";position:absolute;right:8px;top:50%;width:16px;height:2px;background:#d1d5db;transform:translateY(-50%)}.progress-step:last-child:after{display:none}.progress-step.completed:after{background:#6a4cb3}.progress-dot{width:28px;height:28px;min-width:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#e5e7eb;color:#6b7280;font-size:.75rem;font-weight:600;transition:all .2s ease}.progress-step.active .progress-dot{background:linear-gradient(135deg,#6a4cb3,#4c278e);color:#fff;box-shadow:0 2px 8px #6a4cb34d}.progress-step.completed .progress-dot{background:#16a34a;color:#fff}.progress-label{font-size:.8rem;font-weight:500;color:#6b7280;white-space:nowrap}.progress-step.active .progress-label{color:#4c278e;font-weight:600}.progress-step.completed .progress-label{color:#16a34a}.wizard-content{padding:24px;min-height:200px;overflow:visible;position:relative}.wizard-step-content{display:flex;flex-direction:column;gap:16px}.step-header{display:flex;align-items:flex-start;gap:12px}.step-icon{width:40px;height:40px;min-width:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.step-icon svg{width:20px;height:20px}.step-icon.app-icon{background:linear-gradient(135deg,#6a4cb3,#4c278e)}.step-icon.auth-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.step-icon.trigger-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.step-icon.config-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.step-icon.audio-icon{background:linear-gradient(135deg,#ec4899,#db2777)}.step-icon.color-icon{background:linear-gradient(135deg,#14b8a6,#0d9488)}.step-icon.review-icon{background:linear-gradient(135deg,#16a34a,#15803d)}.step-icon.bippybox-icon{background:linear-gradient(135deg,#6a4cb3,#4c278e)}.step-icon.setup-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.step-header-text h3{margin:0 0 2px;font-size:1.05rem;font-weight:600;color:#1f2937}.step-header-text p{margin:0;font-size:.8rem;color:#6b7280}.auth-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:32px;color:#6a4cb3;font-weight:500}.wizard-step-content .auth-status{display:flex;align-items:center;gap:16px;padding:20px 24px;border-radius:12px;flex-wrap:wrap}.wizard-step-content .auth-status.not-connected{background:#fffbeb;border:1px solid #fcd34d}.wizard-step-content .auth-status.expired{background:#fef2f2;border:1px solid #fecaca}.auth-status-info{display:flex;flex-direction:column;gap:2px;flex:1}.status-title{font-weight:600;color:#1f2937}.status-desc{font-size:.85rem;color:#6b7280}.auth-action-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease}.auth-action-btn.connect{color:#d97706;background:#fff;border:1px solid #fcd34d}.auth-action-btn.connect:hover{background:#fffbeb;border-color:#d97706}.auth-action-btn.reconnect{color:#dc2626;background:#fff;border:1px solid #fecaca}.auth-action-btn.reconnect:hover{background:#fef2f2;border-color:#dc2626}.wizard-step-content .auth-status.connected{background:#f0fdf4;border:1px solid #86efac}.wizard-step-content .auth-status.connected svg{color:#16a34a}.setup-content{display:flex;flex-direction:column;gap:20px}.setup-message{background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:20px}.setup-message p{margin:0;color:#92400e;font-size:.95rem;line-height:1.5}.setup-message p+p{margin-top:12px}.default-preview{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f9fafb;border-radius:10px}.preview-item{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#4b5563}.preview-item svg{color:#6a4cb3}.color-preview-dot{width:24px;height:24px;border-radius:6px;border:2px solid rgba(0,0,0,.1)}.add-defaults-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 32px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6a4cb3,#4c278e);border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;align-self:flex-start}.add-defaults-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6a4cb359}.add-defaults-btn:disabled{opacity:.7;cursor:wait}.account-selector{display:flex;align-items:center;gap:10px;padding-top:16px;border-top:1px solid #e5e5e5;margin-top:8px}.account-selector label{font-size:.85rem;color:#6b7280}.account-selector select{padding:8px 12px;font-size:.9rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer}.review-summary{display:flex;flex-direction:column;gap:12px;padding:20px;background:#f9fafb;border-radius:12px}.review-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e5e7eb}.review-item:last-child{border-bottom:none}.review-label{font-size:.9rem;color:#6b7280;font-weight:500}.review-value{font-size:.95rem;color:#1f2937;font-weight:600;display:flex;align-items:center;gap:8px}.color-preview{width:20px;height:20px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.create-integration-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 32px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff4f00,#e04500);border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;margin-top:8px}.create-integration-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff4f0059}.create-integration-btn:disabled{opacity:.7;cursor:not-allowed}.create-integration-btn.loading{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280;cursor:wait}.wizard-navigation{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 32px;background:#f9fafb;border-top:1px solid #e5e5e5}.wizard-nav-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.wizard-nav-btn.back{color:#6b7280;background:#fff;border:1px solid #d1d5db}.wizard-nav-btn.back:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.wizard-nav-btn.back:disabled{opacity:.5;cursor:not-allowed}.wizard-nav-btn.cancel{color:#dc2626;background:transparent;border:none;margin-left:auto}.wizard-nav-btn.cancel:hover{background:#fef2f2}.wizard-nav-btn.next{color:#fff;background:linear-gradient(135deg,#6a4cb3,#4c278e);border:none}.wizard-nav-btn.next:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6a4cb34d}.wizard-nav-btn.next.loading{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#6b7280;cursor:wait}.wizard-nav-btn.next:disabled{opacity:1}.existing-integrations-section{padding-top:16px}.integrations-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.integrations-header h3{font-size:1.1rem;color:#1f2937;margin:0;font-weight:600}.sync-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;font-weight:500;color:#6a4cb3;background-color:#f8f5ff;border:1px solid #e0d4f5;border-radius:8px;cursor:pointer;transition:all .2s ease}.sync-btn:hover:not(:disabled){background-color:#ede9fe;border-color:#6a4cb3;transform:translateY(-1px)}.sync-btn:disabled{cursor:not-allowed;opacity:.7}.sync-btn svg{transition:transform .3s ease}.sync-btn:hover:not(:disabled) svg{transform:rotate(180deg)}.existing-integrations-section h3{font-size:1.1rem;color:#1f2937;margin-bottom:16px;font-weight:600}.integrations-list{display:flex;flex-direction:column;gap:10px}.integration-item{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background-color:#f0fdf4;border:1px solid #86efac;border-radius:10px;transition:all .2s ease}.integration-item.paused{background-color:#fafafa;border-color:#d1d5db;opacity:.8}.integration-details{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.integration-app{font-weight:500;color:#333}.integration-arrow{color:#9ca3af}.integration-trigger{color:#4c278e;font-weight:500}.integration-audio{color:#16a34a;font-size:.85rem;padding:2px 8px;background-color:#dcfce7;border-radius:4px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.integration-color{width:20px;height:20px;min-width:20px;border-radius:4px;border:1px solid rgba(0,0,0,.15)}.dropdown-color-swatch{width:24px;height:24px;min-width:24px;border-radius:4px;border:1px solid rgba(0,0,0,.1);overflow:hidden;position:relative;display:flex}.dropdown-color-swatch>div{width:100%;height:100%}.dropdown-color-swatch .fire-swatch{width:100%;height:100%;position:relative;overflow:hidden;border-radius:3px}.dropdown-color-swatch .fire-gradient{width:200%;height:100%;background:linear-gradient(90deg,red,#ff6b00,#fb0,#fec,red);background-size:200% 100%;animation:fire-move 2s linear infinite}.dropdown-color-swatch .rainbow-swatch{width:100%;height:100%;background:linear-gradient(90deg,red,#ff7f00,#ff0,#0f0,#0ff,#00f,indigo);background-size:200% 100%;animation:rainbow-move 2s linear infinite}.dropdown-color-swatch .dual-color-swatch{width:100%;height:100%;display:flex;border-radius:3px}.dropdown-color-swatch .dual-color-swatch>div{width:50%;height:100%;flex-shrink:0}.dropdown-color-swatch .single-color-swatch{width:100%;height:100%;border-radius:3px}.dropdown-color-swatch .single-color-swatch.pulse{animation:pulse-preview 2s infinite}.dropdown-color-swatch .single-color-swatch.sparkle{animation:sparkle-preview 1s infinite}.dropdown-color-swatch .police-animation{position:relative;overflow:hidden;display:block}.dropdown-color-swatch .police-animation>div{position:absolute;width:50%;height:100%;animation:police-swap 2s infinite ease-in-out}.dropdown-color-swatch .police-animation>div:first-child{left:0;animation-delay:-1s}.dropdown-color-swatch .police-animation>div:last-child{right:0;animation-delay:0s}@keyframes fire-move{0%{background-position:0% 50%}to{background-position:-100% 50%}}@keyframes rainbow-move{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes pulse-preview{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@keyframes sparkle-preview{0%{opacity:1}50%{opacity:.3}to{opacity:1}}@keyframes police-swap{0%,to{transform:translate(0)}50%{transform:translate(100%)}}.integration-status-badge{padding:2px 8px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;background-color:#e5e7eb;border-radius:4px}.integration-count{padding:2px 6px;font-size:.8rem;font-weight:500;color:#6a4cb3;background-color:#f3f0ff;border-radius:4px}.integration-last-triggered{font-size:.75rem;color:#6b7280;white-space:nowrap;margin-left:auto;padding-right:8px}.integration-trigger-type{display:inline-flex;align-items:center;justify-content:center;padding:3px;border-radius:4px;cursor:help;transition:transform .2s ease,background-color .2s ease}.integration-trigger-type:hover{transform:scale(1.1)}.integration-trigger-type.instant{color:#f59e0b;background-color:#fef3c7}.integration-trigger-type.instant:hover{background-color:#fde68a}.integration-trigger-type.polling{color:#6b7280;background-color:#f3f4f6}.integration-trigger-type.polling:hover{background-color:#e5e7eb}.integration-actions{display:flex;align-items:center;gap:8px}.pause-integration-button,.test-integration-button,.delete-integration-button{padding:8px;background-color:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.pause-integration-button{color:#ca8a04}.pause-integration-button:hover:not(:disabled){background-color:#fefce8}.test-integration-button{color:#6a4cb3}.test-integration-button:hover:not(:disabled){background-color:#f3f0ff}.delete-integration-button{color:#dc2626}.delete-integration-button:hover:not(:disabled){background-color:#fef2f2}.pause-integration-button:disabled,.test-integration-button:disabled,.delete-integration-button:disabled{opacity:.6;cursor:not-allowed}.trigger-input-fields{display:flex;flex-direction:column;gap:20px}.trigger-input-field{display:flex;flex-direction:column;gap:6px}.trigger-field-label{font-weight:500;color:#333;font-size:.9rem}.trigger-field-label .required{color:#dc2626;margin-left:4px}.trigger-field-description{font-size:.8rem;color:#6b7280;margin:0}.trigger-field-select,.trigger-field-input,.trigger-field-textarea{padding:12px 16px;font-size:.95rem;border:1px solid #d1d5db;border-radius:10px;background-color:#fff;color:#333;transition:border-color .2s ease,box-shadow .2s ease}.trigger-field-select:focus,.trigger-field-input:focus,.trigger-field-textarea:focus{outline:none;border-color:#6a4cb3;box-shadow:0 0 0 3px #6a4cb31a}.trigger-field-textarea{resize:vertical;min-height:80px}.trigger-input-checkbox{flex-direction:row;align-items:flex-start;gap:8px}.trigger-field-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#333}.trigger-field-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.field-loading{display:flex;align-items:center;gap:8px;color:#6a4cb3;font-size:.9rem;padding:10px 0}@media (max-width: 768px){.wizard-progress{padding:16px;gap:0}.progress-step{padding-right:24px}.progress-label{display:none}.progress-step.active .progress-label{display:block;position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.7rem}.wizard-content{padding:24px 20px}.step-header{flex-direction:column;align-items:center;text-align:center}.step-header-text{text-align:center}.wizard-navigation{padding:16px 20px;flex-wrap:wrap}.wizard-nav-btn{padding:10px 16px;font-size:.85rem}.wizard-nav-btn.cancel{order:3;width:100%;justify-content:center;margin-top:8px;margin-left:0}.integration-details{flex-direction:column;align-items:flex-start;gap:6px;width:100%;overflow:hidden}.integration-arrow{display:none}.integration-item{flex-direction:row;flex-wrap:wrap;gap:8px;padding:10px 12px;text-align:left}.integration-details{flex:1;flex-direction:row;flex-wrap:wrap;gap:4px 8px;min-width:0}.integration-app,.integration-trigger{font-size:.8rem;padding:2px 6px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.integration-audio{font-size:.75rem;padding:2px 6px;max-width:100%}.integration-color{width:16px;height:16px;min-width:16px}.integration-actions{flex-shrink:0}.integration-last-triggered{width:100%;text-align:right;margin-left:0;padding-right:0;order:10}.integration-actions button{padding:6px}.integration-status-badge,.integration-count{font-size:.65rem;padding:2px 4px}.review-item{flex-direction:column;align-items:flex-start;gap:4px}.create-integration-btn,.start-wizard-btn,.connect-btn{width:100%}.connection-connected{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.wizard-content{padding:20px 16px;min-height:240px}.step-icon{width:40px;height:40px;min-width:40px}.step-header-text h3{font-size:1.1rem}.step-header-text p{font-size:.85rem}.auth-status{flex-direction:column;text-align:center}.auth-action-btn{width:100%;justify-content:center}}.device-setup-container{max-width:1000px;margin:50px auto;padding:40px;background-color:#fff;box-shadow:0 6px 30px #4c278e26;border-radius:16px}.device-setup-nav{margin-bottom:30px}.device-setup-back-button{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;font-size:.95rem;color:#6a4cb3;background-color:transparent;border:1px solid #6a4cb3;border-radius:6px;cursor:pointer;transition:all .2s ease}.device-setup-back-button:hover{background-color:#6a4cb3;color:#fff}.device-setup-header{text-align:center;margin-bottom:30px}.device-setup-header h1{font-size:2rem;color:#4c278e;margin-bottom:10px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px}.device-name-badge{font-size:1rem;padding:6px 14px;background-color:#f4f0ff;color:#6a4cb3;border-radius:20px;font-weight:500}.device-id-display{font-size:.9rem;color:#6e6e73;font-family:monospace}.device-setup-loading{text-align:center;padding:40px;color:#6e6e73;font-size:1.1rem}.zapier-link-section{display:flex;justify-content:center;margin-bottom:24px}.zapier-link-content{display:flex;flex-direction:column;align-items:center;gap:8px}.zapier-advanced-link{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;font-size:.95rem;font-weight:500;color:#fff;background-color:#ff4a00;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.zapier-advanced-link:hover{background-color:#e64400;transform:translateY(-1px);box-shadow:0 4px 12px #ff4a004d}.zapier-advanced-link svg{width:16px;height:16px;color:#fff}.zapier-link-subtext{font-size:.8rem;color:#6e6e73;margin:0;text-align:center}.integrations-section{margin-top:20px}.integrations-section h2{font-size:1.5rem;color:#4c278e;margin-bottom:8px}.integrations-description{color:#6e6e73;margin-bottom:24px}@media (max-width: 768px){.device-setup-container{margin:20px;padding:20px}.device-setup-header h1{font-size:1.6rem;flex-direction:column;gap:8px}}@media (max-width: 576px){.device-setup-container{margin:10px;padding:15px}.device-setup-back-button{width:100%;justify-content:center}.device-setup-header h1{font-size:1.4rem}.device-name-badge{font-size:.9rem}.zapier-advanced-link{width:100%;justify-content:center}}.zapier-integrations-container{max-width:1200px;margin:50px auto;padding:40px;background-color:#fff;box-shadow:0 6px 30px #4c278e26;border-radius:16px;min-height:800px;overflow:visible}.zapier-breadcrumb{margin-bottom:30px}.zapier-back-button{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;font-size:.95rem;color:#6a4cb3;background-color:transparent;border:1px solid #6a4cb3;border-radius:6px;cursor:pointer;transition:all .2s ease}.zapier-back-button:hover{background-color:#6a4cb3;color:#fff}.zapier-header{text-align:center;margin-bottom:30px}.zapier-header h1{font-size:2.2rem;color:#4c278e;margin-bottom:10px}.zapier-subtitle{font-size:1.1rem;color:#6e6e73;margin-bottom:10px}.zapier-header small a{color:#6a4cb3;text-decoration:none;transition:color .2s ease}.zapier-header small a:hover{color:#532c8c;text-decoration:underline}.zapier-embed-wrapper{min-height:600px;border-radius:8px;overflow:visible}@media (max-width: 768px){.zapier-integrations-container{margin:20px;padding:20px}.zapier-header h1{font-size:1.8rem}.zapier-subtitle{font-size:1rem}}@media (max-width: 576px){.zapier-integrations-container{margin:10px;padding:15px}.zapier-back-button{width:100%;justify-content:center}.zapier-header h1{font-size:1.5rem}}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#fff;color:#000;padding:20px;box-sizing:border-box}.login-logo{width:150px;margin-bottom:30px}.login-title{font-size:28px;font-weight:700;margin-bottom:20px;text-align:center}.authorize-zapier-content{background-color:#f5f5f5;padding:25px;border-radius:8px;margin-bottom:30px;max-width:450px;width:100%;text-align:center;box-shadow:0 4px 15px #0000001a;color:#000}.authorize-zapier-content p{font-size:16px;line-height:1.6;margin-bottom:15px}.authorize-zapier-content strong{color:#6200ee}.authorize-zapier-actions{display:flex;justify-content:space-between;width:100%;max-width:450px;gap:20px}.deny-button,.allow-button{flex-grow:1;padding:12px 20px;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;border:none;transition:background-color .3s ease}.deny-button{background-color:#e91e63;color:#fff}.deny-button:hover{background-color:#c2185b}.allow-button{background-color:#007bff;color:#fff}.allow-button:hover{background-color:#0056b3}.allow-button:disabled,.deny-button:disabled{background-color:#ccc;color:#888;cursor:not-allowed}.error-message{color:#dc3545;margin-top:15px;font-size:14px;text-align:center}.centered-error{margin-top:20px}@media (max-width: 480px){.login-title{font-size:24px}.authorize-zapier-content{padding:20px}.deny-button,.allow-button{font-size:15px;padding:10px 15px}}.zapier-callback-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background-color:#f5f5f7}.zapier-callback-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px;background-color:#fff;border-radius:16px;box-shadow:0 4px 24px #0000001a;text-align:center;max-width:400px}.zapier-callback-card h2{margin:0;color:#1d1d1f;font-size:1.5rem}.zapier-callback-card p{margin:0;color:#6e6e73;font-size:1rem;line-height:1.5}.zapier-callback-card .spinner{color:#ff4a00;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.zapier-callback-card .success-icon{color:#16a34a}.zapier-callback-card .error-icon{color:#dc2626}.retry-button{margin-top:8px;padding:12px 24px;font-size:1rem;font-weight:500;color:#fff;background-color:#ff4a00;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.retry-button:hover{background-color:#e64400}:root{--color-primary: #6a4cb3;--color-primary-dark: #4c278e;--color-primary-light: #8b6dd4;--color-primary-bg: #f4f0ff;--color-success: #22c55e;--color-success-light: #dcfce7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-text-primary: #1d1d1f;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-text-inverse: #ffffff;--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-bg-dark: #242424;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-purple: 0 4px 15px rgba(76, 39, 142, .15);--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-toast: 500;--sidebar-width: 280px;--bottom-nav-height: 64px;--header-height: 64px;--max-content-width: 1200px;--min-touch-target: 44px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-secondary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1;text-decoration:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:var(--min-touch-target)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--color-border)}.btn-ghost{background-color:transparent;color:var(--color-text-primary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-bg-tertiary)}.btn-danger{background-color:var(--color-error);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-size-base);min-height:52px}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);min-height:36px}.btn-full{width:100%}.card{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.card-padding{padding:var(--space-4)}@media (min-width: 768px){.card-padding{padding:var(--space-6)}}.input{display:block;width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:var(--min-touch-target)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6a4cb31a}.input::placeholder{color:var(--color-text-muted)}.input:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-full)}.badge-primary{background-color:var(--color-primary-bg);color:var(--color-primary)}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-error{background-color:var(--color-error-light);color:var(--color-error)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.status-dot-online{background-color:var(--color-success);box-shadow:0 0 0 2px #22c55e33}.status-dot-offline{background-color:var(--color-error)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-4);text-align:center}.empty-state-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);max-width:320px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal-backdrop)}.modal-content{background-color:var(--color-bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light)}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);display:flex;gap:var(--space-3);justify-content:center}.toggle{position:relative;display:inline-block;width:48px;height:28px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background-color:var(--color-border);border-radius:var(--radius-full);transition:var(--transition-fast)}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;border-radius:50%;transition:var(--transition-fast)}.toggle input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;height:100%;width:100%;display:flex;align-items:flex-start;justify-content:center;min-width:340px;overflow:hidden}h1{font-size:3.2em;line-height:.2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
