.app-footer{background:var(--color-surface);border-top:1px solid var(--color-divider);padding:var(--spacing-md) var(--spacing-lg);margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.footer-links{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.footer-link{color:var(--color-onSurface);text-decoration:none;font-size:.875rem;transition:color var(--transition-fast);opacity:.8}.footer-link:hover{color:var(--color-primary);opacity:1}.footer-separator{color:var(--color-disabled);font-size:.875rem;opacity:.5}.footer-copyright{color:var(--color-disabled);font-size:.75rem;text-align:center}@media (max-width: 768px){.app-footer{padding:var(--spacing-md)}.footer-content{gap:var(--spacing-xs)}.footer-links{font-size:.813rem}.footer-copyright{font-size:.688rem}}.auth-container{min-height:100vh;display:flex;flex-direction:column;background:var(--color-background);padding:20px}.auth-container>.auth-card{display:flex;flex-direction:column;justify-content:center;margin:auto}.auth-card{background:var(--color-surface);border-radius:var(--radius-md);padding:40px;width:100%;max-width:420px;box-shadow:var(--elevation-16)}.auth-card h1{text-align:center;margin:0 0 5px;color:var(--color-primary);font-size:36px;font-weight:700}.auth-card .tagline{text-align:center;margin:0 0 20px;color:var(--color-primaryVariant);font-size:14px;font-weight:500;text-transform:uppercase;letter-spacing:2px}.auth-card h2{text-align:center;margin:0 0 30px;color:var(--color-onSurface);font-size:24px;font-weight:500}.form-group label{display:block;margin-bottom:6px;color:var(--color-onSurface);font-weight:500;font-size:14px;opacity:.8}.form-group input{width:100%;padding:12px;border:2px solid var(--color-divider);border-radius:var(--radius-sm);font-size:15px;transition:border-color .2s;box-sizing:border-box;background-color:var(--color-surface);color:var(--color-onSurface)}.form-group input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-surface);color:var(--color-onSurface)}.form-group input:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.5}.btn{width:100%;padding:14px;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}.auth-card .btn-primary{margin-bottom:20px}.btn-primary:hover:not(:disabled){background:var(--color-primaryVariant);transform:translateY(-1px);box-shadow:var(--elevation-4)}.btn-google{background:var(--color-surface);border:2px solid var(--color-divider);color:var(--color-onSurface);margin-top:16px}.btn-google:hover:not(:disabled){background:var(--color-background);border-color:var(--color-primary)}.btn-google svg{flex-shrink:0}.btn-facebook{background:var(--color-surface);border:2px solid var(--color-divider);color:var(--color-onSurface);margin-top:12px}.btn-facebook:hover:not(:disabled){background:var(--color-background);border-color:var(--color-primary)}.btn-facebook svg{flex-shrink:0}.divider{text-align:center;margin:24px 0;color:var(--color-disabled);font-size:13px;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--color-divider)}.divider:before{left:0}.divider:after{right:0}.error-message{background:var(--color-error);color:var(--color-onError);padding:12px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:14px;opacity:.9}.info-message{background:#2196F3;color:#fff;padding:12px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:14px}.info-message p{margin:8px 0 0}.auth-link{text-align:center;margin-top:24px;color:var(--color-onSurface);font-size:14px;opacity:.8}.auth-link a{color:var(--color-primary);text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline;color:var(--color-primaryVariant)}.login-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.login-prompt-modal{background-color:var(--color-surface, #ffffff);border-radius:12px;padding:2rem;max-width:450px;width:90%;box-shadow:0 10px 40px #0000004d;animation:slideIn .3s ease-out}.login-prompt-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.login-prompt-icon{font-size:2rem}.login-prompt-header h2{margin:0;font-size:1.5rem;color:var(--color-onSurface, #000000)}.login-prompt-content{margin-bottom:1.5rem}.login-prompt-message{margin-bottom:1rem;color:var(--color-onSurface, #000000);line-height:1.6}.login-prompt-benefits{background-color:var(--color-background, #f5f5f5);border-radius:8px;padding:1rem;margin-top:1rem}.login-prompt-benefits p{margin:0 0 .5rem;font-weight:600;color:var(--color-onSurface, #000000)}.login-prompt-benefits ul{margin:0;padding-left:1.5rem;list-style-type:disc}.login-prompt-benefits li{margin:.25rem 0;color:var(--color-onSurface, #000000);opacity:.8}.login-prompt-actions{display:flex;flex-direction:column;gap:.75rem}.login-prompt-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:center}.login-prompt-btn-primary{background-color:var(--color-primary, #1976d2);color:var(--color-onPrimary, #ffffff)}.login-prompt-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.login-prompt-btn-secondary{background-color:var(--color-secondary, #dc004e);color:var(--color-onSecondary, #ffffff)}.login-prompt-btn-secondary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.login-prompt-btn-text{background-color:transparent;color:var(--color-onSurface, #000000);opacity:.6}.login-prompt-btn-text:hover{opacity:.8;background-color:#0000000d}@media (max-width: 600px){.login-prompt-modal{padding:1.5rem;max-width:95%}.login-prompt-header h2{font-size:1.25rem}}.streak-counter{width:70px;height:70px;cursor:pointer;transition:transform .2s ease;position:relative}.streak-counter:hover{transform:translateY(-50%) scale(1.05)}.streak-counter.celebrating{animation:celebrate 2s ease-out forwards}@keyframes celebrate{0%{transform:translateY(-50%) scale(1)}10%{transform:translateY(-50%) scale(1.3) rotate(5deg)}20%{transform:translateY(-50%) scale(1.2) rotate(-5deg)}30%{transform:translateY(-50%) scale(1.35) rotate(5deg)}40%{transform:translateY(-50%) scale(1.25) rotate(-3deg)}50%{transform:translateY(-50%) scale(1.3) rotate(3deg)}60%{transform:translateY(-50%) scale(1.2) rotate(0)}70%{transform:translateY(-50%) scale(1.15)}80%{transform:translateY(-50%) scale(1.1)}90%{transform:translateY(-50%) scale(1.05)}to{transform:translateY(-50%) scale(1)}}.streak-counter:hover .streak-tooltip{opacity:1;visibility:visible}.streak-progress-circle{width:100%;height:100%}.progress-bar{transition:stroke-dashoffset .5s ease}.streak-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;color:var(--color-onSurface);pointer-events:none}.streak-tooltip{position:absolute;left:50%;transform:translate(-50%);background:var(--color-surface);border:2px solid var(--color-primary);padding:8px 14px;border-radius:8px;font-size:.85rem;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:100;pointer-events:none;box-shadow:0 4px 12px #0003;color:var(--color-onSurface)}.streak-tooltip:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid var(--color-primary)}.streak-tooltip:after{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid var(--color-surface)}.celebrating-number{animation:numberPulse 2s ease-out}@keyframes numberPulse{0%,to{transform:translate(-50%,-50%) scale(1);color:var(--color-onSurface)}15%{transform:translate(-50%,-50%) scale(1.6);color:var(--color-primary);text-shadow:0 0 20px var(--color-primary)}30%{transform:translate(-50%,-50%) scale(1.3)}50%{transform:translate(-50%,-50%) scale(1.5)}70%{transform:translate(-50%,-50%) scale(1.2)}}.sparkle{position:absolute;font-size:1.5rem;pointer-events:none;animation:sparkleAnimation 2s ease-out forwards}.sparkle-1{top:-10px;left:50%;animation-delay:0s}.sparkle-2{top:50%;right:-10px;animation-delay:.15s}.sparkle-3{bottom:-10px;left:50%;animation-delay:.3s}.sparkle-4{top:50%;left:-10px;animation-delay:.45s}@keyframes sparkleAnimation{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:0}20%{opacity:1}50%{transform:translate(-50%,-50%) scale(1.5) rotate(180deg);opacity:1}to{transform:translate(-50%,-50%) scale(.5) rotate(360deg);opacity:0}}.glow-ring{position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:50%;border:3px solid var(--color-primary);transform:translate(-50%,-50%);animation:glowPulse 2s ease-out forwards;pointer-events:none}@keyframes glowPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1;box-shadow:0 0 0 rgba(var(--color-primary-rgb, 25, 118, 210),.7)}50%{transform:translate(-50%,-50%) scale(1.8);opacity:.6;box-shadow:0 0 40px rgba(var(--color-primary-rgb, 25, 118, 210),.5)}to{transform:translate(-50%,-50%) scale(2.5);opacity:0;box-shadow:0 0 60px rgba(var(--color-primary-rgb, 25, 118, 210),0)}}.streak-warning-badge{position:absolute;top:-5px;right:-5px;width:24px;height:24px;background:var(--color-error, #f44336);border:2px solid var(--color-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;z-index:10;animation:warningPulse 2s ease-in-out infinite;pointer-events:none}@keyframes warningPulse{0%,to{transform:scale(1);box-shadow:0 0 #f44336b3}50%{transform:scale(1.1);box-shadow:0 0 10px #f4433680}}@media (max-width: 992px){.streak-number{font-size:1.3rem}.streak-complete-indicator{width:20px;height:20px;font-size:12px}}@media (max-width: 768px),(max-height: 768px){.streak-counter{width:50px;height:50px}.streak-number{font-size:1.1rem}.streak-tooltip{font-size:.75rem;padding:6px 10px}.streak-complete-indicator{width:18px;height:18px;font-size:11px}}@media (max-width: 480px){.streak-counter{width:45px;height:45px;left:4.5rem}.streak-number{font-size:1rem}.streak-complete-indicator{width:16px;height:16px;font-size:10px}}.main-navigation{background-color:var(--color-surface);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--elevation-2);position:relative;z-index:1000}.nav-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);position:relative}.nav-logo-link{text-decoration:none;color:inherit;flex-shrink:0}.nav-logo{margin:0;font-size:1.6rem;font-weight:600;color:var(--color-primary);cursor:pointer;transition:opacity .2s}.nav-logo:hover{opacity:.8}.streak-counter{position:absolute;left:8.5rem;top:50%;transform:translateY(-50%);z-index:10}.nav-header-right{display:flex;align-items:center;gap:16px;margin-left:auto}.hamburger-button{display:none;flex-direction:column;justify-content:space-around;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:4px;z-index:10}.hamburger-line{width:100%;height:3px;background-color:var(--color-onSurface);border-radius:10px;transition:all .3s ease;transform-origin:center}.hamburger-button .hamburger-line:nth-child(1).open{transform:translateY(9px) rotate(45deg)}.hamburger-button .hamburger-line:nth-child(2).open{opacity:0}.hamburger-button .hamburger-line:nth-child(3).open{transform:translateY(-9px) rotate(-45deg)}.nav-content{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-md)}.nav-links{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.nav-link{padding:var(--spacing-sm) var(--spacing-lg);text-decoration:none;color:var(--color-disabled);font-weight:500;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:16px;white-space:nowrap}.nav-link:hover{background-color:#0000000a;color:var(--color-primary)}.nav-link.active{background-color:var(--color-primary);color:var(--color-onPrimary)}.nav-lock-icon{font-size:.85em;margin-left:.25rem;opacity:.7}@media (max-width: 768px),(max-height: 768px){body{padding:0!important;margin:0!important}.main-navigation{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:0;border-radius:0}.hamburger-button{display:flex}.nav-content{position:absolute;top:100%;left:0;right:0;background-color:var(--color-surface);flex-direction:column;align-items:stretch;gap:var(--spacing-sm);padding:0;margin-top:0;border-radius:0;box-shadow:var(--elevation-4);max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease,opacity .3s ease,padding .3s ease;z-index:1001}.nav-content.open{max-height:600px;opacity:1;padding:var(--spacing-sm) 0}.nav-links{flex-direction:column;width:100%;gap:var(--spacing-xs)}.nav-link{width:100%;text-align:center;padding:var(--spacing-md);font-size:18px}}.workspace-container{display:grid;grid-template-areas:"left-drawer main-content right-drawer" "left-drawer bottom-drawer right-drawer";grid-template-columns:var(--left-drawer-width) var(--main-content-width) var(--right-drawer-width);grid-template-rows:1fr var(--bottom-drawer-height);height:calc(100vh - 132px);width:100%;overflow:hidden;transition:all .5s cubic-bezier(.34,1.56,.64,1);background:var(--color-background);color:var(--color-onBackground)}:root{--main-content-width: 1fr}.workspace-container[data-left=partial][data-right=partial],.workspace-container[data-left=partial][data-right=full],.workspace-container[data-left=full][data-right=partial],.workspace-container[data-left=full][data-right=full]{grid-template-areas:"left-drawer right-drawer" "bottom-drawer bottom-drawer";grid-template-columns:var(--left-drawer-width) var(--right-drawer-width);--main-content-width: 0px}.workspace-container[data-left=partial][data-right=collapsed],.workspace-container[data-left=full][data-right=collapsed]{grid-template-areas:"left-drawer main-content right-drawer" "bottom-drawer bottom-drawer right-drawer";--main-content-width: 1fr}.workspace-container[data-left=collapsed][data-right=partial],.workspace-container[data-left=collapsed][data-right=full]{grid-template-areas:"left-drawer main-content right-drawer" "left-drawer bottom-drawer bottom-drawer";--main-content-width: 1fr}.workspace-container[data-bottom=partial][data-left=partial],.workspace-container[data-bottom=partial][data-left=full],.workspace-container[data-bottom=partial][data-right=partial],.workspace-container[data-bottom=partial][data-right=full],.workspace-container[data-bottom=full][data-left=partial],.workspace-container[data-bottom=full][data-left=full],.workspace-container[data-bottom=full][data-right=partial],.workspace-container[data-bottom=full][data-right=full]{grid-template-rows:2fr 1fr}:root{--left-drawer-collapsed: 60px;--right-drawer-collapsed: 60px;--bottom-drawer-collapsed: 60px;--left-drawer-half: 50%;--right-drawer-half: 50%;--bottom-drawer-partial: 33%;--left-drawer-full: calc(100% - var(--right-drawer-width));--right-drawer-full: calc(100% - var(--left-drawer-width));--bottom-drawer-full: calc(100% - var(--bottom-drawer-collapsed))}.workspace-container[data-left=hidden]{--left-drawer-width: 0px}.workspace-container[data-left=collapsed]{--left-drawer-width: var(--left-drawer-collapsed)}.workspace-container[data-left=partial]{--left-drawer-width: var(--left-drawer-half)}.workspace-container[data-left=full]{--left-drawer-width: calc( 100% - var(--right-drawer-collapsed) )}.workspace-container[data-right=hidden]{--right-drawer-width: 0px}.workspace-container[data-right=collapsed]{--right-drawer-width: var(--right-drawer-collapsed)}.workspace-container[data-right=partial]{--right-drawer-width: var(--right-drawer-half)}.workspace-container[data-right=full]{--right-drawer-width: calc( 100% - var(--left-drawer-collapsed) )}.workspace-container[data-bottom=hidden]{--bottom-drawer-height: 0px}.workspace-container[data-bottom=collapsed]{--bottom-drawer-height: var(--bottom-drawer-collapsed)}.workspace-container[data-bottom=partial]{--bottom-drawer-height: var(--bottom-drawer-partial)}.workspace-container[data-bottom=full]{--bottom-drawer-height: calc(100% - var(--bottom-drawer-collapsed))}.drawer{position:relative;overflow:hidden;background:var(--color-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .4s cubic-bezier(.34,1.56,.64,1);z-index:10;color:var(--color-onSurface)}.drawer-left{grid-area:left-drawer;box-shadow:4px 0 20px #00000014}.drawer-right{grid-area:right-drawer;box-shadow:-4px 0 20px #00000014}.drawer-bottom{grid-area:bottom-drawer;box-shadow:0 -4px 20px #00000014}.drawer-left[data-state=partial],.drawer-left[data-state=full]{box-shadow:4px 0 40px rgba(var(--color-primary-rgb, 25, 118, 210),.2),4px 0 20px #00000014}.drawer-right[data-state=partial],.drawer-right[data-state=full]{box-shadow:-4px 0 40px rgba(var(--color-primary-rgb, 25, 118, 210),.2),-4px 0 20px #00000014}.drawer-bottom[data-state=partial],.drawer-bottom[data-state=full]{box-shadow:0 -4px 40px rgba(var(--color-primary-rgb, 25, 118, 210),.2),0 -4px 20px #00000014}.drawer-main-content{grid-area:main-content;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;background:var(--color-background);color:var(--color-onBackground);overflow:auto}.workspace-container[data-left=full] .drawer-main-content,.workspace-container[data-right=full] .drawer-main-content,.workspace-container[data-bottom=full] .drawer-main-content{padding:0}.workspace-container[data-left=partial][data-right=partial] .drawer-main-content,.workspace-container[data-left=partial][data-right=full] .drawer-main-content,.workspace-container[data-left=full][data-right=partial] .drawer-main-content,.workspace-container[data-left=full][data-right=full] .drawer-main-content{display:none}.drawer-content{width:100%;height:100%;overflow:auto;background:var(--color-surface);color:var(--color-onSurface)}.drawer-content.collapsed{display:flex;flex-direction:column;align-items:center;padding:10px 5px;gap:8px;background:linear-gradient(180deg,var(--color-background) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.02) 50%,var(--color-background) 100%);color:var(--color-onBackground);animation:none;position:relative}.drawer-content.collapsed:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.05) 50%,transparent 100%);opacity:0;animation:pulseGlow 3s ease-in-out infinite;pointer-events:none}@keyframes pulseGlow{0%,to{opacity:0}50%{opacity:1}}.drawer-left .drawer-content.collapsed,.drawer-right .drawer-content.collapsed{flex-direction:column}.drawer-bottom .drawer-content.collapsed{flex-direction:row;justify-content:space-around;padding:10px 20px}.drawer-content.partial,.drawer-content.full{padding:0}.drawer-control-button{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primaryVariant) 100%);color:var(--color-onPrimary);border:none;border-radius:12px;padding:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s cubic-bezier(.34,1.56,.64,1);min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026,0 0 0 0 var(--color-primary);position:relative;overflow:hidden}.drawer-action{font-size:1.1rem!important}.drawer-control-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}.drawer-control-button:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 8px 20px #0003,0 0 20px var(--color-primary)}.drawer-control-button:hover:before{width:120%;height:120%}.drawer-control-button:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px #00000026}.drawer-control-button.error{background:var(--color-error);color:var(--color-onError)}.drawer-control-button.error:hover{background:var(--color-errorVariant, var(--color-error));filter:brightness(.9)}.drawer-control-button:disabled{background:var(--color-disabled);color:var(--color-onDisabled);cursor:not-allowed;transform:none;opacity:.5}.drawer-expand-buttons{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.drawer-bottom .drawer-expand-buttons{flex-direction:row;margin-bottom:0;margin-left:auto}.expand-button{background:rgba(var(--color-primary-rgb, 25, 118, 210),.1);border:none;color:var(--color-primary);border-radius:10px;padding:10px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);min-width:40px;min-height:40px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.expand-button svg{transition:transform .2s ease}.expand-button:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.expand-button:hover{background:var(--color-primary);color:var(--color-onPrimary);transform:translateY(-2px) scale(1.05);box-shadow:inset 0 0 0 2px var(--color-primary),0 4px 12px #0003,0 0 20px rgba(var(--color-primary-rgb, 25, 118, 210),.3)}.expand-button:hover svg{transform:scale(1.1)}.expand-button:hover:after{left:100%}.expand-button:active{transform:translateY(0) scale(.95)}.drawer-tuner-info{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:none;border-radius:12px;padding:8px;cursor:default;font-size:18px;font-weight:700;transition:all .3s cubic-bezier(.34,1.56,.64,1);min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;color:var(--color-onPrimary);box-shadow:0 4px 16px #00000026,inset 0 1px #fff3;position:relative;overflow:hidden}.drawer-tuner-info:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.1),transparent 30%);animation:rotate 4s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mini-visual-container{flex:1;width:100%;min-height:200px;display:flex;align-items:flex-start;justify-content:center}.drawer-left .mini-visual-container,.drawer-right .mini-visual-container{min-height:240px}.drawer-bottom .mini-visual-container{min-width:200px;min-height:auto;height:100%}.drawer-collapsed-info{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:12px;color:var(--color-onSurface);text-align:center}.drawer-left .drawer-content.collapsed,.drawer-right .drawer-content.collapsed{overflow-x:hidden}.drawer-bottom .drawer-collapsed-info{flex-direction:row;gap:12px}.drawer-stat{padding:6px 12px;background:linear-gradient(135deg,rgba(var(--color-primary-rgb, 25, 118, 210),.15) 0%,rgba(var(--color-secondary-rgb, 220, 0, 78),.1) 100%);border-radius:12px;border:none;white-space:nowrap;color:var(--color-onSurface);font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.drawer-stat:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.drawer-stat-responsive{display:flex}@media (max-width: 600px){.drawer-stat-responsive{display:none!important}}@media (max-width: 768px){.min768{display:none!important}}@media (max-height: 768px){.vmin768{display:none!important}}@media (max-width: 768px),(max-height: 768px){:root{--left-drawer-collapsed: 50px;--right-drawer-collapsed: 50px;--bottom-drawer-collapsed: 50px}.workspace-container{height:calc(100vh - 58px)}.drawer{position:relative}.drawer-control-button,.drawer-tuner-info{min-width:44px;min-height:44px;font-size:16px}.drawer-stat{min-width:44px}.expand-button{min-width:44px;min-height:44px;font-size:14px}.drawer-backdrop{display:none}}@media (min-width: 768px) and (max-width: 1024px){:root{--left-drawer-collapsed: 50px;--right-drawer-collapsed: 50px;--bottom-drawer-collapsed: 50px}}@media (min-width: 1024px){.workspace-container{max-width:100%}}@keyframes slideInFromLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInFromBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.pulse{animation:pulse 2s infinite}.drawer:focus-within{outline:none}.drawer-control-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){.workspace-container,.drawer,.drawer-control-button,.expand-button{transition:none}.pulse{animation:none}}.drawer-header{display:flex;justify-content:space-between;align-items:center}.drawer-header h2{margin:0;color:var(--color-onBackground);font-size:1.5rem;font-weight:600}.drawer-header-controls{display:flex;gap:8px;align-items:center}.drawer-fab{position:absolute;top:8px;right:8px;z-index:100;display:flex;gap:8px}.theme-toggle-btn{width:48px;height:48px;min-height:48px;min-width:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 16px #00000026,0 0 0 0 rgba(var(--color-primary-rgb, 25, 118, 210),.4);padding:0;flex-shrink:0;color:var(--color-onPrimary);position:relative;overflow:hidden}.theme-toggle-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transition:opacity .3s}.theme-toggle-btn:hover{transform:translateY(-4px) scale(1.1) rotate(15deg);box-shadow:0 8px 32px #0003,0 0 30px rgba(var(--color-primary-rgb, 25, 118, 210),.6)}.theme-toggle-btn:hover:before{opacity:1}.theme-toggle-btn:active{transform:translateY(-2px) scale(1.05) rotate(0);box-shadow:0 4px 16px #00000026}.drawer-bpm-display{background:linear-gradient(135deg,var(--color-surface) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.05) 100%);border:none;border-radius:24px;padding:20px;margin-bottom:20px;box-shadow:0 8px 32px #0000001a,inset 0 1px #fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.drawer-bpm-display:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000026,inset 0 1px #ffffff4d}.drawer-bpm-label{font-size:.875rem;color:var(--color-onSurface);opacity:.7;margin-bottom:8px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.drawer-bpm-value{font-size:3rem;font-weight:700;color:var(--color-primary);text-align:center;line-height:1}.drawer-bpm-controls{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:12px}.drawer-bpm-input{width:100%;max-width:120px;padding:12px 16px;font-size:1.25rem;text-align:center;font-weight:600;border:none;border-radius:16px;background:linear-gradient(135deg,var(--color-background) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.05) 100%);color:var(--color-onBackground);transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:inset 0 2px 8px #00000014,0 0 0 0 var(--color-primary)}.drawer-bpm-input:focus{outline:none;transform:translateY(-2px);box-shadow:inset 0 2px 8px #00000014,0 0 0 3px rgba(var(--color-primary-rgb, 25, 118, 210),.2),0 4px 12px #0000001a;background:linear-gradient(135deg,var(--color-background) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.08) 100%)}.drawer-time-signature{background:linear-gradient(135deg,var(--color-surface) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.03) 100%);border:none;border-radius:16px;padding:16px;text-align:center;margin-bottom:20px;box-shadow:0 4px 16px #00000014,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.drawer-time-signature:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f,inset 0 1px #ffffff26}.drawer-time-signature-label{font-size:.75rem;color:var(--color-onSurface);opacity:.7;margin-bottom:4px;font-weight:500;text-transform:uppercase}.drawer-time-signature-value{font-size:1.5rem;font-weight:700;color:var(--color-onSurface)}.workspace-welcome{text-align:center;max-width:600px}.workspace-welcome-title{font-size:2rem;margin-bottom:20px;color:var(--color-onBackground);font-weight:600}.workspace-welcome-text{font-size:1.125rem;line-height:1.6;color:var(--color-onBackground);opacity:.8}.workspace-features{margin-top:40px;display:flex;flex-direction:column;gap:20px}.workspace-feature-card{padding:24px;background:linear-gradient(135deg,var(--color-surface) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.03) 100%);border-radius:20px;border:none;transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 16px #00000014;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;animation:fadeInUp .6s ease-out backwards}.workspace-feature-card:nth-child(1){animation-delay:.1s}.workspace-feature-card:nth-child(2){animation-delay:.2s}.workspace-feature-card:nth-child(3){animation-delay:.3s}.workspace-feature-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s}.workspace-feature-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 32px #00000026,0 0 0 1px rgba(var(--color-primary-rgb, 25, 118, 210),.1)}.workspace-feature-card:hover:before{left:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.workspace-feature-title{margin:0 0 10px;color:var(--color-primary);font-size:1.125rem;font-weight:600}.workspace-feature-desc{margin:0;font-size:.875rem;color:var(--color-onSurface);line-height:1.4}.workspace-help-text{margin-top:40px;font-size:.875rem;color:var(--color-onBackground);opacity:.6}.drawer-content-wrapper{width:100%;height:100%;padding:20px;display:flex;flex-direction:column;background-color:var(--color-background)}.drawer-visual-container{flex:1;display:flex;align-items:center;justify-content:center;position:relative;min-height:200px}.drawer-visual-loading{color:var(--color-onBackground)}.drawer-controls{display:flex;gap:10px;justify-content:center;margin-top:10px}.drawer-input-group{display:flex;align-items:center;gap:10px}.drawer-label{color:var(--color-onSurface)}.drawer-input{width:80px;padding:10px 12px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--color-surface) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.03) 100%);color:var(--color-onSurface);font-weight:500;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:inset 0 2px 6px #0000000f}.drawer-input:focus{outline:none;transform:translateY(-1px);box-shadow:inset 0 2px 6px #0000000f,0 0 0 3px rgba(var(--color-primary-rgb, 25, 118, 210),.15),0 2px 8px #0000001a;background:linear-gradient(135deg,var(--color-surface) 0%,rgba(var(--color-primary-rgb, 25, 118, 210),.06) 100%)}.drawer-bottom[data-state=partial] .calendar-day{min-height:30px!important;max-height:30px!important;height:30px!important;padding:2px!important;font-size:.75rem!important;width:100%!important}.drawer-bottom[data-state=partial] .calendar-section{padding:0!important}.drawer-bottom[data-state=partial] .drawer-content-wrapper{padding:0 20px!important}.drawer-bottom[data-state=partial] .drawer-header,.drawer-bottom[data-state=partial] .calendar-section,.drawer-bottom[data-state=partial] .calendar-header{margin-bottom:0!important}.drawer-bottom[data-state=partial] .calendar-legend{display:none!important}.drawer-bottom[data-state=partial] .calendar-day-number{font-size:.7rem!important;margin-bottom:1px!important}.drawer-bottom[data-state=partial] .calendar-day-stats{display:none!important}.drawer-bottom[data-state=partial] .calendar-grid{gap:2px!important}.drawer-bottom[data-state=partial] .calendar-header-day{font-size:.7rem!important;padding:4px 2px!important}.android-agc-warning{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;background:rgba(255,165,0,.1);border:1px solid rgba(255,165,0,.3);border-radius:8px;margin-bottom:1.5rem;max-width:600px;margin-left:auto;margin-right:auto}.android-agc-warning-icon{font-size:1.5rem;flex-shrink:0}.android-agc-warning-content{font-size:.875rem;line-height:1.6;color:var(--text-primary)}.android-agc-warning-content strong{font-weight:600}.android-agc-warning-content a{color:var(--primary);text-decoration:underline;font-weight:500}.android-agc-warning-content a:hover{color:var(--primary-dark)}.metronome-container{height:100vh;background-color:var(--color-background);display:flex;flex-direction:column;overflow:hidden}@keyframes radiate-glow{0%{box-shadow:0 0 5px var(--color-primary),0 0 10px var(--color-primary),0 0 15px var(--color-primary);transform:scale(1)}50%{box-shadow:0 0 10px var(--color-primary),0 0 20px var(--color-primary),0 0 30px var(--color-primary),0 0 40px var(--color-primary);transform:scale(1.05)}to{box-shadow:0 0 5px var(--color-primary),0 0 10px var(--color-primary),0 0 15px var(--color-primary);transform:scale(1)}}.metronome-unmute-glow{animation:radiate-glow 2s ease-in-out infinite;background:var(--color-primary)!important;color:var(--color-on-primary)!important}.metronome-content{position:relative;max-width:1200px;margin:0 auto;width:100%;flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg);align-items:center;min-height:0;overflow-y:auto}@media (min-width: 900px){.metronome-content{flex-direction:row;align-items:flex-start;gap:var(--spacing-xxl);overflow-y:visible;flex-wrap:wrap}.metronome-beat-display{flex:1 1 50%;max-height:none}.metronome-controls{flex:0 0 400px;max-width:400px}.metronome-beat-display,.metronome-controls{order:0}}.metronome-beat-display{display:flex;justify-content:center;align-items:center;width:100%;flex:0 1 50%;position:relative;min-height:200px;max-height:400px;margin-top:1rem}.metronome-controls-top{position:absolute;top:8px;right:8px;display:flex;gap:8px;z-index:10;margin-top:-1rem}.sound-toggle-btn,.theme-toggle-btn{width:32px;height:32px;min-height:32px;min-width:32px;border-radius:var(--radius-round);background:var(--color-background);border:2px solid var(--color-divider);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all var(--transition-fast);box-shadow:var(--elevation-2);padding:0;flex-shrink:0}.sound-toggle-btn:hover,.theme-toggle-btn:hover{transform:scale(1.1)}.theme-toggle-btn svg{width:20px;height:20px;min-width:20px;min-height:20px;stroke:currentColor;fill:none;display:block;flex-shrink:0}.theme-toggle-btn svg polygon{fill:currentColor;stroke:none}.metronome-unmute-glow svg{stroke:currentColor!important;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.metronome-unmute-glow svg polygon{fill:currentColor!important}.sound-toggle-btn:active,.theme-toggle-btn:active{box-shadow:var(--elevation-4);background:var(--color-surface);border-color:var(--color-primaryVariant, var(--color-primary))}.beat-circle{width:250px;height:250px;border-radius:var(--radius-round);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primaryVariant) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--elevation-8);transition:opacity var(--transition-normal),transform var(--transition-fast),box-shadow var(--transition-fast);color:var(--color-onPrimary)}.beat-circle.beat-pulse-primary{animation:pulse-primary .15s ease-out}.beat-circle.beat-pulse-offbeat{animation:pulse-offbeat .15s ease-out}.beat-circle.beat-pulse-subdivision{animation:pulse-subdivision .15s ease-out}@keyframes pulse-primary{0%{transform:scale(1)}50%{transform:scale(1.495);box-shadow:0 16px 48px #0006}to{transform:scale(1)}}@keyframes pulse-offbeat{0%{transform:scale(1)}50%{transform:scale(1.08);box-shadow:0 12px 36px #0000004d}to{transform:scale(1)}}@keyframes pulse-subdivision{0%{transform:scale(1)}50%{transform:scale(1.03);box-shadow:0 10px 28px #00000040}to{transform:scale(1)}}.beat-number-large{font-size:6rem;font-weight:700;line-height:1;margin-bottom:var(--spacing-xs)}.beat-label-small{font-size:1.5rem;opacity:.9}.beat-flame{width:250px;height:250px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.flame-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:180px;height:240px;filter:blur(2px)}.flame{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:90px;height:160px;background:linear-gradient(to top,#d84315 0%,#ff4500 15%,#ff6b35 35%,#ffa500 60%,#ffd700 80%,rgba(255,255,200,.3) 95%,rgba(255,215,0,0) 100%);border-radius:50%/70% 70% 30% 30%;clip-path:polygon(50% 0%,30% 20%,20% 40%,15% 60%,10% 75%,5% 85%,0% 100%,100% 100%,95% 85%,90% 75%,85% 60%,80% 40%,70% 20%);animation:flicker .08s infinite alternate,flickerShift .2s infinite alternate;transition:transform .1s ease-out}.flame.beat-active-primary{animation:flamebeat-primary .15s ease-out,flickerShift .2s infinite alternate!important}.flame.beat-active-offbeat{animation:flamebeat-offbeat .15s ease-out,flickerShift .2s infinite alternate!important}.flame.beat-active-subdivision{animation:flamebeat-subdivision .15s ease-out,flickerShift .2s infinite alternate!important}@keyframes flicker{0%{transform:translate(-50%) scaleY(.95) scaleX(1.03) rotate(-1deg)}to{transform:translate(-50%) scaleY(1.05) scaleX(.97) rotate(1deg)}}@keyframes flickerShift{0%{filter:brightness(1) hue-rotate(-5deg)}to{filter:brightness(1.1) hue-rotate(5deg)}}@keyframes flamebeat-primary{0%{transform:translate(-50%) scaleY(1) scaleX(1)}50%{transform:translate(-50%) scaleY(1.95) scaleX(1.625);filter:brightness(1.8) saturate(1.3)}to{transform:translate(-50%) scaleY(1) scaleX(1)}}@keyframes flamebeat-offbeat{0%{transform:translate(-50%) scaleY(1) scaleX(1)}50%{transform:translate(-50%) scaleY(1.25) scaleX(1.15);filter:brightness(1.4) saturate(1.2)}to{transform:translate(-50%) scaleY(1) scaleX(1)}}@keyframes flamebeat-subdivision{0%{transform:translate(-50%) scaleY(1) scaleX(1)}50%{transform:translate(-50%) scaleY(1.1) scaleX(1.05);filter:brightness(1.2)}to{transform:translate(-50%) scaleY(1) scaleX(1)}}.flame:before{content:"";position:absolute;top:15%;left:50%;transform:translate(-50%);width:50px;height:90px;background:linear-gradient(to top,#ff6b35 0%,#ffa500 35%,#ffd700 65%,#ffeb3b 85%,rgba(255,255,255,.9) 100%);border-radius:50%/75% 75% 25% 25%;clip-path:polygon(50% 0%,35% 20%,25% 45%,20% 70%,10% 90%,0% 100%,100% 100%,90% 90%,80% 70%,75% 45%,65% 20%);animation:innerflicker .12s infinite alternate}@keyframes innerflicker{0%{transform:translate(-50%) scaleY(.93) rotate(-2deg)}to{transform:translate(-50%) scaleY(1.07) rotate(2deg)}}.flame-numbers{position:relative;z-index:10;text-shadow:0 0 10px rgba(0,0,0,.5),0 0 20px rgba(255,100,0,.5);color:#fff;display:flex;flex-direction:column;align-items:center}.beat-raindrops{width:350px;height:350px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.water-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:350px;height:350px;display:flex;align-items:center;justify-content:center}.water-surface{position:absolute;bottom:35%;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,rgba(2,136,209,.6) 20%,rgba(0,188,212,.8) 50%,rgba(2,136,209,.6) 80%,transparent 100%);z-index:1}.falling-droplet{position:absolute;width:18px;height:24px;background:radial-gradient(ellipse at 30% 20%,#b3e5fc,#0288d1);border-radius:50% 50% 50% 0%;transform:rotate(45deg);box-shadow:inset -2px -2px 4px #0003,inset 2px 2px 4px #fff9,0 0 15px #0288d166;z-index:5}.falling-droplet-primary{animation:dropFall-primary .3s cubic-bezier(.25,.46,.45,.94)}.falling-droplet-offbeat{animation:dropFall-offbeat .25s cubic-bezier(.25,.46,.45,.94)}.falling-droplet-subdivision{animation:dropFall-subdivision .2s cubic-bezier(.25,.46,.45,.94)}@keyframes dropFall-primary{0%{top:-10%;opacity:1;transform:rotate(45deg) scale(1.2)}to{top:63%;opacity:0;transform:rotate(45deg) scale(.8)}}@keyframes dropFall-offbeat{0%{top:10%;opacity:1;transform:rotate(45deg) scale(1)}to{top:63%;opacity:0;transform:rotate(45deg) scale(.7)}}@keyframes dropFall-subdivision{0%{top:20%;opacity:1;transform:rotate(45deg) scale(.8)}to{top:63%;opacity:0;transform:rotate(45deg) scale(.6)}}.splash-crown{position:absolute;top:65%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;z-index:4}.crown-spike{position:absolute;bottom:50%;left:50%;width:4px;height:0;background:linear-gradient(to top,#0288d1,rgba(179,229,252,0));transform-origin:bottom center;opacity:0}.splash-crown-primary .crown-spike{animation:crownSplash-primary .4s ease-out}.splash-crown-offbeat .crown-spike{animation:crownSplash-offbeat .35s ease-out}.splash-crown-subdivision .crown-spike{animation:crownSplash-subdivision .25s ease-out}.crown-spike.spike-1{transform:translate(-50%) rotate(0)}.crown-spike.spike-2{transform:translate(-50%) rotate(45deg)}.crown-spike.spike-3{transform:translate(-50%) rotate(90deg)}.crown-spike.spike-4{transform:translate(-50%) rotate(135deg)}.crown-spike.spike-5{transform:translate(-50%) rotate(180deg)}.crown-spike.spike-6{transform:translate(-50%) rotate(225deg)}.crown-spike.spike-7{transform:translate(-50%) rotate(270deg)}.crown-spike.spike-8{transform:translate(-50%) rotate(315deg)}@keyframes crownSplash-primary{0%{height:0;opacity:1}40%{height:104px;opacity:1}to{height:130px;opacity:0}}@keyframes crownSplash-offbeat{0%{height:0;opacity:1}40%{height:50px;opacity:1}to{height:70px;opacity:0}}@keyframes crownSplash-subdivision{0%{height:0;opacity:1}40%{height:30px;opacity:1}to{height:40px;opacity:0}}.water-ripple{position:absolute;top:65%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:3px solid rgba(2,136,209,.6);pointer-events:none;z-index:2}.water-ripple.ripple-primary{border-color:#0288d1b3}.water-ripple-1.ripple-primary{animation:waterRipple-primary 1.2s ease-out}.water-ripple-2.ripple-primary{animation:waterRipple-primary 1.2s ease-out .15s}.water-ripple-3.ripple-primary{animation:waterRipple-primary 1.2s ease-out .3s}.water-ripple-4.ripple-primary{animation:waterRipple-primary 1.2s ease-out .45s}.water-ripple-5.ripple-primary{animation:waterRipple-primary 1.2s ease-out .6s}.water-ripple-6.ripple-primary{animation:waterRipple-primary 1.2s ease-out .75s}.water-ripple.ripple-offbeat{border-color:#00bcd499}.water-ripple-1.ripple-offbeat{animation:waterRipple-offbeat .9s ease-out}.water-ripple-2.ripple-offbeat{animation:waterRipple-offbeat .9s ease-out .12s}.water-ripple-3.ripple-offbeat{animation:waterRipple-offbeat .9s ease-out .24s}.water-ripple-4.ripple-offbeat{animation:waterRipple-offbeat .9s ease-out .36s}.water-ripple-5.ripple-offbeat{animation:waterRipple-offbeat .9s ease-out .48s}.water-ripple-6.ripple-offbeat{animation:waterRipple-offbeat .9s ease-out .6s}.water-ripple.ripple-subdivision{border-color:#00bcd466}.water-ripple-1.ripple-subdivision{animation:waterRipple-subdivision .6s ease-out}.water-ripple-2.ripple-subdivision{animation:waterRipple-subdivision .6s ease-out .08s}.water-ripple-3.ripple-subdivision{animation:waterRipple-subdivision .6s ease-out .16s}.water-ripple-4.ripple-subdivision{animation:waterRipple-subdivision .6s ease-out .24s}.water-ripple-5.ripple-subdivision{animation:waterRipple-subdivision .6s ease-out .32s}.water-ripple-6.ripple-subdivision{animation:waterRipple-subdivision .6s ease-out .4s}@keyframes waterRipple-primary{0%{width:52px;height:26px;opacity:1;border-width:3px}to{width:520px;height:260px;opacity:0;border-width:1px}}@keyframes waterRipple-offbeat{0%{width:40px;height:20px;opacity:1;border-width:2.5px}to{width:300px;height:150px;opacity:0;border-width:1px}}@keyframes waterRipple-subdivision{0%{width:40px;height:20px;opacity:1;border-width:2px}to{width:180px;height:90px;opacity:0;border-width:1px}}.water-numbers{position:relative;z-index:10;text-shadow:0 0 10px rgba(0,0,0,.5),0 0 20px rgba(2,136,209,.5);color:#fff;display:flex;flex-direction:column;align-items:center}.beat-flash{width:250px;height:250px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.flash-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;display:flex;align-items:center;justify-content:center}.flash-box{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:white;border-radius:var(--radius-sm);opacity:0}.flash-box.flash-active-primary{width:100%;height:100%;animation:flashFade-primary .25s ease-out}.flash-box.flash-active-offbeat{width:75%;height:75%;animation:flashFade-offbeat .2s ease-out}.flash-box.flash-active-subdivision{width:50%;height:50%;animation:flashFade-subdivision .15s ease-out}@keyframes flashFade-primary{0%{opacity:0}10%{opacity:1}to{opacity:0}}@keyframes flashFade-offbeat{0%{opacity:0}10%{opacity:.8}to{opacity:0}}@keyframes flashFade-subdivision{0%{opacity:0}10%{opacity:.6}to{opacity:0}}.flash-numbers{position:relative;z-index:10;text-shadow:0 0 10px rgba(0,0,0,.5);color:#fff;display:flex;flex-direction:column;align-items:center}.beat-blip{width:250px;height:250px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.blip-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:250px;height:250px;display:flex;align-items:center;justify-content:center}.blip-center{width:24px;height:24px;background:radial-gradient(circle at 30% 30%,#9c72ff,#7c4dff);border-radius:50%;box-shadow:0 0 15px #7c4dffcc,0 0 30px #7c4dff80;position:relative;z-index:10}.blip-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:2px solid;pointer-events:none}.blip-circle.blip-primary{border-color:#7c4dffcc}.blip-1.blip-primary{animation:blip-expand .6s ease-out}.blip-2.blip-primary{animation:blip-expand .6s ease-out .1s}.blip-3.blip-primary{animation:blip-expand .6s ease-out .2s}.blip-circle.blip-offbeat{border-color:#00e676b3}.blip-1.blip-offbeat{animation:blip-expand-medium .5s ease-out}.blip-2.blip-offbeat{animation:blip-expand-medium .5s ease-out .08s}.blip-3.blip-offbeat{animation:blip-expand-medium .5s ease-out .16s}.blip-circle.blip-subdivision{border-color:#00e67680}.blip-1.blip-subdivision{animation:blip-expand-small .4s ease-out}.blip-2.blip-subdivision{animation:blip-expand-small .4s ease-out .05s}.blip-3.blip-subdivision{animation:blip-expand-small .4s ease-out .1s}@keyframes blip-expand{0%{width:24px;height:24px;opacity:1;border-width:3px}to{width:286px;height:286px;opacity:0;border-width:1px}}@keyframes blip-expand-medium{0%{width:24px;height:24px;opacity:1;border-width:2.5px}to{width:160px;height:160px;opacity:0;border-width:1px}}@keyframes blip-expand-small{0%{width:24px;height:24px;opacity:1;border-width:2px}to{width:100px;height:100px;opacity:0;border-width:1px}}.blip-numbers{position:relative;z-index:10;text-shadow:0 0 10px rgba(0,0,0,.5),0 0 20px rgba(124,77,255,.5);color:#fff;display:flex;flex-direction:column;align-items:center}.metronome-controls{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%;max-width:500px;flex:0 0 auto}.control-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.control-group label{font-size:.9rem;font-weight:600;color:var(--color-disabled);text-transform:uppercase;letter-spacing:.5px}.tempo-control{display:flex;gap:var(--spacing-sm);align-items:center}.tempo-control button{min-width:60px;min-height:48px;font-size:1.2rem;touch-action:manipulation;background-color:var(--color-primary);color:var(--color-onPrimary);border:none}.tempo-control button:hover:not(:disabled){background-color:var(--color-primaryVariant)}.tempo-input{flex:1;padding:var(--spacing-md);border:2px solid var(--color-divider);border-radius:var(--radius-sm);font-size:1.5rem;font-weight:600;text-align:center;font-family:inherit;background-color:var(--color-surface);color:var(--color-onSurface);min-height:48px;touch-action:manipulation}.tempo-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-surface);color:var(--color-onSurface)}.tempo-input:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.6}.control-select{padding:var(--spacing-md);border:2px solid var(--color-divider);border-radius:var(--radius-sm);font-size:1.1rem;font-family:inherit;background-color:var(--color-surface);color:var(--color-onSurface);min-height:48px;touch-action:manipulation}.control-select:focus{outline:none;border-color:var(--color-primary)}.control-select:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.6}.subdivision-options{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.subdivision-option{flex:1;min-width:80px;padding:var(--spacing-sm);border:2px solid var(--color-divider);border-radius:var(--radius-sm);background-color:var(--color-surface);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);transition:all var(--transition-fast);touch-action:manipulation}.subdivision-option:hover{border-color:var(--color-primary);background-color:var(--color-background)}.subdivision-option.active{border-color:var(--color-primary);background-color:var(--color-primary);color:var(--color-onPrimary)}.subdivision-option input[type=radio]{display:none}.subdivision-visual{display:flex;align-items:center;justify-content:center;height:40px}.subdivision-icon{width:auto;height:30px}.subdivision-label{font-size:.85rem;font-weight:600;text-align:center}.metronome-action{display:flex;justify-content:center;width:100%}.btn-large-metro{padding:var(--spacing-lg) var(--spacing-xxl);font-size:1.5rem;min-width:250px;min-height:64px;border-radius:var(--radius-sm);font-weight:600;transition:all var(--transition-fast);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-large-metro:active{transform:scale(.98)}@media (max-width: 640px){.metronome-container{padding:0}.metronome-content{gap:var(--spacing-sm)}.metronome-beat-display{flex:0 1 45%;min-height:180px;max-height:300px}.beat-circle{width:200px;height:200px}.beat-number-large{font-size:4rem}.beat-label-small{font-size:1.1rem}.beat-flame{width:200px;height:200px}.flame-container{width:144px;height:192px}.flame{width:72px;height:128px}.beat-raindrops,.water-container{width:280px;height:280px}.beat-blip,.blip-container,.beat-flash{width:200px;height:200px}.metronome-controls{gap:var(--spacing-xs)}.control-group{gap:4px}.control-group label{font-size:.75rem}.tempo-input{font-size:1.2rem;padding:8px;min-height:44px}.tempo-control button{min-width:48px;min-height:44px;font-size:1rem;padding:8px}.control-select{font-size:.95rem;padding:8px;min-height:44px}.btn-large-metro{padding:12px var(--spacing-lg);font-size:1.2rem;min-width:100%;min-height:52px}.metronome-action{margin-top:0}}@media (max-width: 375px){.metronome-beat-display{flex:0 1 40%;min-height:160px}.beat-circle,.beat-flame,.beat-blip,.beat-flash{width:160px;height:160px}.beat-raindrops,.water-container{width:220px;height:220px}.beat-number-large{font-size:3rem}.beat-label-small{font-size:.95rem}.tempo-input{font-size:1.1rem}.tempo-control button{min-width:44px;font-size:.95rem}.control-select{font-size:.9rem}.btn-large-metro{font-size:1.1rem;min-height:48px}}.beat-classic{width:300px;height:400px;display:flex;align-items:center;justify-content:center}.classic-metronome-body{width:200px;height:350px;background:linear-gradient(135deg,#5d2e0f 0%,#8b4513 50%,#5d2e0f 100%);border-radius:100px 100px 20px 20px;position:relative;box-shadow:inset 0 2px 8px #0009,0 8px 24px #00000080;overflow:hidden}.wood-grain{position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,0,0,.05) 2px,rgba(0,0,0,.05) 4px),repeating-linear-gradient(180deg,transparent,transparent 8px,rgba(139,69,19,.1) 8px,rgba(139,69,19,.1) 16px);opacity:.6;pointer-events:none}.pendulum-pivot{position:absolute;bottom:120px;left:50%;transform:translate(-50%);width:20px;height:20px;background:radial-gradient(circle,#ffd700 0%,#cd853f 100%);border-radius:50%;box-shadow:0 2px 6px #0006,inset -1px -1px 3px #0000004d;z-index:10}.pendulum-arm{position:absolute;bottom:120px;left:50%;width:6px;height:200px;background:linear-gradient(180deg,#8b4513 0%,#a0522d 50%,#8b4513 100%);border-radius:3px;transform-origin:bottom center;transform:translate(-50%);box-shadow:2px 0 4px #0000004d,-2px 0 4px #0003;z-index:5}.pendulum-arm:before{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:6px;height:80px;background:linear-gradient(180deg,#8b4513 0%,#a0522d 100%);border-radius:3px;transform-origin:top center}.pendulum-arm.swinging{animation:pendulum-swing linear infinite}@keyframes pendulum-swing{0%{transform:translate(-50%) rotate(-25deg)}25%{transform:translate(-50%) rotate(0)}50%{transform:translate(-50%) rotate(25deg)}75%{transform:translate(-50%) rotate(0)}to{transform:translate(-50%) rotate(-25deg)}}.pendulum-weight{position:absolute;bottom:-80px;left:50%;transform:translate(-50%);width:50px;height:50px;background:radial-gradient(circle at 35% 35%,#ffd700 0%,#daa520 40%,#cd853f 70%,#8b4513 100%);border-radius:50%;box-shadow:0 4px 12px #00000080,inset -3px -3px 6px #0006,inset 3px 3px 6px #fff3}.classic-numbers{position:absolute;bottom:40px;left:50%;transform:translate(-50%);text-align:center;color:wheat;text-shadow:0 2px 4px rgba(0,0,0,.6);z-index:15}.classic-metronome-body:after{content:"";position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:4px;height:130px;background:rgba(255,215,0,.3);border-radius:2px;pointer-events:none}.beat-gighero{width:400px;height:500px;display:flex;align-items:center;justify-content:center}.note-highway{width:350px;height:450px;background:linear-gradient(180deg,#000000 0%,#1a1a1a 100%);position:relative;overflow:hidden;border-radius:12px;box-shadow:0 0 40px #00ff004d,inset 0 0 20px #000c}.note-highway:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:80%;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 20%,transparent 80%,rgba(255,255,255,.02) 100%);pointer-events:none}.fret-marker{position:absolute;left:0;width:100%;height:3px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);box-shadow:0 0 8px #ffffff4d}.fret-marker.fret-1{top:15%}.fret-marker.fret-2{top:30%}.fret-marker.fret-3{top:45%}.fret-marker.fret-4{top:60%}.fret-marker.fret-5{top:75%}.hit-zone{position:absolute;bottom:80px;left:0;width:100%;height:60px;background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);border-top:2px solid rgba(255,255,255,.3);border-bottom:2px solid rgba(255,255,255,.3);box-shadow:0 0 20px #fff3}.lane-divider{position:absolute;top:0;width:2px;height:100%;background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.15) 10%,rgba(255,255,255,.15) 90%,transparent 100%);pointer-events:none;z-index:1}.lane-divider.lane-1{left:33.33%}.lane-divider.lane-2{left:66.66%}.falling-button{position:absolute;top:-80px;width:80px;height:20px;border-radius:6px;transform:translate(-50%);animation:button-fall linear;animation-fill-mode:forwards;z-index:10;box-shadow:0 4px 12px #0009,inset 0 2px 8px #ffffff4d}.falling-button.button-primary{background:radial-gradient(ellipse at 50% 30%,#33ff33 0%,#00ff00 40%,#00cc00 100%);border:3px solid #00ff00;box-shadow:0 0 20px #0f0,0 0 40px #00ff0080,0 4px 12px #0009,inset 0 2px 8px #ffffff4d}.falling-button.button-offbeat{background:radial-gradient(ellipse at 50% 30%,#ff3333 0%,#ff0000 40%,#cc0000 100%);border:3px solid #ff0000;box-shadow:0 0 20px red,0 0 40px #ff000080,0 4px 12px #0009,inset 0 2px 8px #ffffff4d}.falling-button.button-subdivision{background:radial-gradient(ellipse at 50% 30%,#ffff33 0%,#ffff00 40%,#cccc00 100%);border:3px solid #ffff00;box-shadow:0 0 20px #ff0,0 0 40px #ffff0080,0 4px 12px #0009,inset 0 2px 8px #ffffff4d}@keyframes button-fall{0%{top:-80px;opacity:1;transform:translate(-50%) scale(1)}95%{top:330px;opacity:1;transform:translate(-50%) scale(1)}96%{top:330px;opacity:1;transform:translate(-50%) scale(1.5);filter:brightness(2.5)}98%{top:330px;opacity:1;transform:translate(-50%) scale(2);filter:brightness(4)}to{top:330px;opacity:0;transform:translate(-50%) scale(.2);filter:brightness(1)}}.gighero-numbers{position:absolute;top:20px;left:50%;transform:translate(-50%);text-align:center;color:#fff;text-shadow:0 0 10px rgba(0,255,0,.8),0 2px 4px rgba(0,0,0,.8);z-index:15;font-weight:700}.note-highway:after{content:"";position:absolute;top:0;left:33.33%;width:2px;height:100%;background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.1) 20%,rgba(255,255,255,.1) 80%,transparent 100%);pointer-events:none}.note-highway .fret-marker:after{content:"";position:absolute;top:-225px;left:66.66%;width:2px;height:450px;background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.1) 20%,rgba(255,255,255,.1) 80%,transparent 100%);pointer-events:none}.seasonal-numbers{position:absolute;bottom:60px;left:50%;transform:translate(-50%);text-align:center;width:100%;max-width:300px;z-index:10}.beat-newyear{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle,rgba(139,0,255,.1) 0%,transparent 70%)}.firework-container{position:absolute;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.firework-rocket{position:absolute;bottom:-20px;width:4px;height:40px;background:linear-gradient(180deg,transparent,#FFD700);animation:rocketLaunch .3s ease-out forwards}.firework-burst{position:absolute;width:200px;height:200px;background:radial-gradient(circle,#FFD700 0%,#8B00FF 50%,transparent 70%);border-radius:50%;opacity:0;animation:burstExplode .6s ease-out .3s forwards;box-shadow:0 0 40px gold,0 0 80px #8b00ff}.firework-primary .firework-burst{width:300px;height:300px;animation-duration:.8s}.firework-subdivision .firework-burst{width:120px;height:120px;animation-duration:.4s}@keyframes rocketLaunch{0%{bottom:-20px;opacity:1}to{bottom:50%;opacity:0}}@keyframes burstExplode{0%{transform:scale(0);opacity:1}50%{transform:scale(1);opacity:1}to{transform:scale(1.5);opacity:0}}.beat-winter{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.snowflake{position:absolute;width:80px;height:80px;animation:snowfallSpin 1.5s ease-in-out forwards,snowflakeRock 2.5s ease-in-out infinite;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg stroke='%23E0F7FF' stroke-width='2' fill='none' stroke-linecap='round'%3E%3C!-- Main axes --%3E%3Cline x1='50' y1='10' x2='50' y2='90' /%3E%3Cline x1='10' y1='50' x2='90' y2='50' /%3E%3Cline x1='20' y1='20' x2='80' y2='80' /%3E%3Cline x1='80' y1='20' x2='20' y2='80' /%3E%3Cline x1='30' y1='13' x2='70' y2='87' /%3E%3Cline x1='70' y1='13' x2='30' y2='87' /%3E%3C!-- Branch decorations --%3E%3Cline x1='50' y1='20' x2='40' y2='25' /%3E%3Cline x1='50' y1='20' x2='60' y2='25' /%3E%3Cline x1='50' y1='80' x2='40' y2='75' /%3E%3Cline x1='50' y1='80' x2='60' y2='75' /%3E%3Cline x1='20' y1='50' x2='25' y2='40' /%3E%3Cline x1='20' y1='50' x2='25' y2='60' /%3E%3Cline x1='80' y1='50' x2='75' y2='40' /%3E%3Cline x1='80' y1='50' x2='75' y2='60' /%3E%3Cline x1='28' y1='28' x2='23' y2='35' /%3E%3Cline x1='28' y1='28' x2='35' y2='23' /%3E%3Cline x1='72' y1='72' x2='65' y2='77' /%3E%3Cline x1='72' y1='72' x2='77' y2='65' /%3E%3Cline x1='72' y1='28' x2='65' y2='23' /%3E%3Cline x1='72' y1='28' x2='77' y2='35' /%3E%3Cline x1='28' y1='72' x2='23' y2='65' /%3E%3Cline x1='28' y1='72' x2='35' y2='77' /%3E%3C!-- Center circle --%3E%3Ccircle cx='50' cy='50' r='5' fill='%23E0F7FF' /%3E%3C/g%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center;filter:drop-shadow(0 0 10px #B0E0E6)}.snowflake-beat1{width:96px;height:96px;filter:drop-shadow(0 0 15px #B0E0E6)}.snowflake-regular{width:80px;height:80px;filter:drop-shadow(0 0 10px #B0E0E6)}.snowflake-primary{width:100px;height:100px;filter:drop-shadow(0 0 15px #B0E0E6)}.snowflake-subdivision{width:50px;height:50px;filter:drop-shadow(0 0 5px #B0E0E6)}@keyframes snowfallSpin{0%{top:0;transform:scale(.7) rotate(0);opacity:0}5%{top:5%;transform:scale(1) rotate(20deg);opacity:1}to{top:95%;transform:scale(.9) rotate(360deg);opacity:0}}@keyframes snowflakeRock{0%,to{margin-left:0}25%{margin-left:-24px}75%{margin-left:24px}}.beat-herospotlight{width:100%;height:100%;min-height:220px;overflow:visible;display:flex;align-items:center;justify-content:center}.hero-skyline{position:absolute;bottom:0;left:0;right:0;height:30%;background:linear-gradient(180deg,#000000 0%,#0A0A0A 100%);clip-path:polygon(0% 100%,0% 60%,5% 65%,10% 55%,12% 60%,15% 45%,18% 50%,20% 40%,25% 50%,28% 45%,30% 55%,35% 40%,38% 45%,40% 35%,45% 45%,48% 40%,50% 50%,55% 35%,58% 40%,60% 30%,65% 40%,68% 35%,70% 45%,75% 30%,78% 35%,80% 25%,85% 35%,88% 30%,90% 40%,95% 30%,98% 35%,100% 40%,100% 100%);z-index:2}.hero-skyline:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 15% 40%,#FFD700 1px,transparent 1px),radial-gradient(circle at 25% 35%,#FFD700 1px,transparent 1px),radial-gradient(circle at 40% 30%,#FFD700 1px,transparent 1px),radial-gradient(circle at 60% 25%,#FFD700 1px,transparent 1px),radial-gradient(circle at 75% 20%,#FFD700 1px,transparent 1px),radial-gradient(circle at 85% 30%,#FFD700 1px,transparent 1px);background-size:100% 100%;opacity:.8}.hero-spotlight{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:220px;height:220px;background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,255,255,.85) 70%,rgba(255,255,255,0) 100%);border-radius:50%;z-index:3;pointer-events:none}.hero-beat-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:72px;font-weight:900;color:#000;text-shadow:0 0 10px rgba(255,255,255,.8),0 0 20px rgba(255,215,0,.6),2px 2px 0 rgba(255,215,0,.8);z-index:4;font-family:Impact,sans-serif;letter-spacing:2px}.fight-balloon{position:absolute;padding:20px 40px;border:4px solid #000000;margin-left:-100px;margin-top:-40px;font-size:30px;font-weight:600;color:#000;text-shadow:2px 2px 0 #FFFFFF;font-family:Impact,sans-serif;letter-spacing:3px;text-align:center;z-index:5;animation:fightBalloonPop .8s ease-out forwards;transform-origin:center;min-width:200px;min-height:100px;clip-path:polygon(50% 0%,55% 10%,65% 5%,62% 18%,78% 12%,70% 28%,88% 22%,78% 38%,94% 35%,82% 48%,96% 50%,82% 52%,94% 65%,78% 62%,88% 78%,70% 72%,78% 88%,62% 82%,65% 95%,55% 90%,50% 100%,45% 90%,35% 95%,38% 82%,22% 88%,30% 72%,12% 78%,22% 62%,6% 65%,18% 52%,4% 50%,18% 48%,6% 35%,22% 38%,12% 22%,30% 28%,22% 12%,38% 18%,35% 5%,45% 10%)}.fight-balloon:nth-child(n){background:radial-gradient(ellipse at center,#FFD700 0%,#FFA500 100%)}.fight-balloon:nth-child(2n){background:radial-gradient(ellipse at center,#FF69B4 0%,#FF1493 100%)}.fight-balloon:nth-child(3n){background:radial-gradient(ellipse at center,#00CED1 0%,#1E90FF 100%)}.fight-balloon:nth-child(4n){background:radial-gradient(ellipse at center,#FF4500 0%,#DC143C 100%)}.fight-balloon:nth-child(5n){background:radial-gradient(ellipse at center,#32CD32 0%,#228B22 100%)}@keyframes fightBalloonPop{0%{transform:scale(0) rotate(0);opacity:0}30%{transform:scale(1.2) rotate(5deg);opacity:1}60%{transform:scale(1) rotate(-3deg);opacity:1}to{transform:scale(.9) rotate(0);opacity:0}}.beat-champagne{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.champagne-bottle{position:absolute;bottom:60px;width:40px;height:100px;background:linear-gradient(180deg,#DCC7A4 0%,#F7E7CE 100%);border-radius:5px 5px 10px 10px;z-index:1}.champagne-cork{position:absolute;bottom:160px;width:15px;height:20px;background:#8B7355;border-radius:3px;animation:corkPop .4s ease-out forwards}.champagne-bubbles{position:absolute;bottom:160px;width:100px;height:200px}.bubble{position:absolute;width:8px;height:8px;background:#F7E7CE;border-radius:50%;opacity:.7;animation:bubbleRise .8s ease-out forwards}.bubble-1{left:40%;animation-delay:0s}.bubble-2{left:50%;animation-delay:.1s}.bubble-3{left:60%;animation-delay:.2s}.bubbles-primary .bubble{width:12px;height:12px}@keyframes corkPop{0%{bottom:160px;transform:rotate(0);opacity:1}to{bottom:300px;transform:rotate(720deg);opacity:0}}@keyframes bubbleRise{0%{bottom:0;opacity:.7;transform:translate(0)}to{bottom:200px;opacity:0;transform:translate(20px)}}.beat-valentine{width:250px;height:250px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.valentine-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:250px;height:250px;display:flex;align-items:center;justify-content:center}.valentine-heart-center{position:relative;z-index:10;font-size:120px;filter:drop-shadow(0 0 20px rgba(255,23,68,.8)) drop-shadow(0 0 40px rgba(255,23,68,.5))}.valentine-heart-center:before{content:"💗"}.heart-pulse-primary .valentine-heart-center{animation:heart-pulse-beat .6s ease-in-out}.heart-pulse-offbeat .valentine-heart-center{animation:heart-pulse-beat .4s ease-in-out}.heart-pulse-subdivision .valentine-heart-center{animation:heart-pulse-beat .3s ease-in-out}@keyframes heart-pulse-beat{0%,to{transform:scale(1);filter:drop-shadow(0 0 20px rgba(255,23,68,.8)) drop-shadow(0 0 40px rgba(255,23,68,.5))}50%{transform:scale(1.3);filter:drop-shadow(0 0 30px rgba(255,23,68,1)) drop-shadow(0 0 60px rgba(255,23,68,.8))}}.valentine-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;font-size:120px;opacity:0}.valentine-ring:before{content:"💗";color:#ff1744}.valentine-ring.ring-primary{color:#ff1744cc}.valentine-ring-1.ring-primary{animation:heart-ring-expand .8s ease-out}.valentine-ring-2.ring-primary{animation:heart-ring-expand .8s ease-out .15s}.valentine-ring-3.ring-primary{animation:heart-ring-expand .8s ease-out .3s}.valentine-ring.ring-offbeat{color:#ff69b4b3}.valentine-ring-1.ring-offbeat{animation:heart-ring-expand-medium .6s ease-out}.valentine-ring-2.ring-offbeat{animation:heart-ring-expand-medium .6s ease-out .1s}.valentine-ring-3.ring-offbeat{animation:heart-ring-expand-medium .6s ease-out .2s}.valentine-ring.ring-subdivision{color:#ffb6c199}.valentine-ring-1.ring-subdivision{animation:heart-ring-expand-small .5s ease-out}.valentine-ring-2.ring-subdivision{animation:heart-ring-expand-small .5s ease-out .08s}.valentine-ring-3.ring-subdivision{animation:heart-ring-expand-small .5s ease-out .16s}@keyframes heart-ring-expand{0%{font-size:120px;opacity:1}to{font-size:480px;opacity:0}}@keyframes heart-ring-expand-medium{0%{font-size:120px;opacity:1}to{font-size:300px;opacity:0}}@keyframes heart-ring-expand-small{0%{font-size:120px;opacity:1}to{font-size:210px;opacity:0}}.beat-lunarnewyear{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.lantern{position:relative;width:60px;height:80px;transform-origin:top center}.lantern-top{width:60px;height:8px;background:#FFD700;border-radius:4px;margin-bottom:5px}.lantern-body{width:60px;height:60px;background:linear-gradient(180deg,#FF0000 0%,#CC0000 100%);border-radius:10px;box-shadow:inset 0 0 20px #ffd7004d,0 0 30px #f009}.lantern-tassel{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:3px;height:20px;background:#FFD700}.lantern-swing-primary{animation:lanternSwing .8s ease-in-out}.lantern-swing-offbeat{animation:lanternSwing .5s ease-in-out}.lantern-swing-subdivision{animation:lanternSwing .3s ease-in-out}@keyframes lanternSwing{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.beat-shamrock{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.shamrock{position:relative;width:80px;height:80px}.shamrock:before,.shamrock:after{content:"☘";position:absolute;font-size:80px;color:#0f0;text-shadow:0 0 20px rgba(0,255,0,.8);left:50%;top:50%;transform:translate(-50%,-50%)}.shamrock-spin-primary{animation:shamrockSpin .6s ease-in-out}.shamrock-spin-offbeat{animation:shamrockSpin .4s ease-in-out}.shamrock-spin-subdivision{animation:shamrockSpin .3s ease-in-out}.gold-coins{position:absolute;width:100%;height:100%}.coin{position:absolute;width:20px;height:20px;background:radial-gradient(circle,#FFD700 0%,#DAA520 100%);border-radius:50%;animation:coinFall .8s ease-in forwards;box-shadow:0 0 10px gold}.coin-1{left:30%;animation-delay:0s}.coin-2{left:50%;animation-delay:.1s}.coin-3{left:70%;animation-delay:.2s}@keyframes shamrockSpin{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(360deg) scale(1.2)}}@keyframes coinFall{0%{top:20%;opacity:1;transform:rotate(0)}to{top:80%;opacity:0;transform:rotate(720deg)}}.beat-spring{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.flower{position:relative;width:80px;height:80px}.flower:before{content:"🌸";position:absolute;font-size:80px;left:50%;top:50%;transform:translate(-50%,-50%) scale(.5);filter:drop-shadow(0 0 10px rgba(255,105,180,.6))}.flower-bloom-primary:before{animation:flowerBloom .6s ease-out}.flower-bloom-offbeat:before{animation:flowerBloom .4s ease-out}.flower-bloom-subdivision:before{animation:flowerBloom .3s ease-out}.butterfly{position:absolute;font-size:40px;animation:butterflyFly 1.2s ease-in-out forwards}.butterfly:before{content:"🦋"}@keyframes flowerBloom{0%{transform:translate(-50%,-50%) scale(.3) rotate(0);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2) rotate(180deg);opacity:1}to{transform:translate(-50%,-50%) scale(.5) rotate(360deg);opacity:.8}}@keyframes butterflyFly{0%{left:-10%;top:50%;opacity:0}50%{left:50%;top:30%;opacity:1}to{left:110%;top:50%;opacity:0}}.beat-easter{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.easter-egg{position:relative;width:70px;height:90px;background:linear-gradient(135deg,#FF69B4 0%,#FF1493 50%,#FF69B4 100%);border-radius:50%/60% 60% 40% 40%;box-shadow:0 0 20px #ff69b499}.easter-egg:before{content:"";position:absolute;top:35%;left:10%;right:10%;height:3px;background:#87CEEB;box-shadow:0 10px #87ceeb,0 -10px #87ceeb}.egg-bounce-primary{animation:eggBounce .5s ease-out}.egg-bounce-offbeat{animation:eggBounce .3s ease-out}.egg-bounce-subdivision{animation:eggBounce .2s ease-out}.bunny-ears{position:absolute;bottom:20%;left:50%;transform:translate(-50%);font-size:60px;animation:bunnyPeek .6s ease-out forwards}.bunny-ears:before{content:"🐰"}@keyframes eggBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.1)}}@keyframes bunnyPeek{0%{bottom:-20%;opacity:0}50%{bottom:20%;opacity:1}to{bottom:20%;opacity:0}}.beat-earthday{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.earth-globe{position:relative;width:100px;height:100px;background:radial-gradient(circle at 30% 30%,#00A550 0%,#007A3D 50%),radial-gradient(circle at 70% 60%,#0077BE 0%,#005A8E 50%);border-radius:50%;box-shadow:inset 0 0 30px #00000080,0 0 40px #0077be99}.globe-rotate-primary{animation:globeSpin 1s ease-in-out}.globe-rotate-offbeat{animation:globeSpin .6s ease-in-out}.globe-rotate-subdivision{animation:globeSpin .4s ease-in-out}.growing-vines{position:absolute;width:150px;height:150px;animation:vinesGrow .8s ease-out forwards}.growing-vines:before,.growing-vines:after{content:"🌿";position:absolute;font-size:40px;opacity:0;animation:vineAppear .8s ease-out forwards}.growing-vines:before{left:-20%;top:30%;animation-delay:.1s}.growing-vines:after{right:-20%;top:40%;animation-delay:.2s}@keyframes globeSpin{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}}@keyframes vineAppear{0%{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1.2)}to{opacity:0;transform:scale(.5)}}.beat-cincodemayo{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pinata{position:relative;width:80px;height:80px;background:linear-gradient(45deg,#FF0000 0%,#FF0000 25%,#00FF00 25%,#00FF00 50%,#FFD700 50%,#FFD700 75%,#FF0000 75%);border-radius:20px;transform-origin:top center;box-shadow:0 5px 15px #0000004d}.pinata:before{content:"";position:absolute;top:-15px;left:50%;transform:translate(-50%);width:3px;height:15px;background:#8B4513}.pinata-swing-primary{animation:pinataSwing .6s ease-in-out}.pinata-swing-offbeat{animation:pinataSwing .4s ease-in-out}.pinata-swing-subdivision{animation:pinataSwing .3s ease-in-out}.candy-burst{position:absolute;width:100%;height:100%}.candy{position:absolute;width:15px;height:15px;border-radius:3px;animation:candyExplode .8s ease-out forwards}.candy-1{background:#FF0000;left:40%;animation-delay:0s;transform:rotate(45deg)}.candy-2{background:#00FF00;left:50%;animation-delay:.1s;transform:rotate(90deg)}.candy-3{background:#FFD700;left:60%;animation-delay:.2s;transform:rotate(135deg)}@keyframes pinataSwing{0%,to{transform:rotate(0)}25%{transform:rotate(-20deg)}75%{transform:rotate(20deg)}}@keyframes candyExplode{0%{top:50%;opacity:1;transform:translate(-50%,-50%) scale(1)}to{top:80%;opacity:0;transform:translate(-50%,-50%) scale(.5) rotate(720deg)}}.beat-mothersday{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.rose{position:relative;width:80px;height:120px}.rose-stem{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:4px;height:60px;background:linear-gradient(180deg,#2E8B57 0%,#228B22 100%)}.rose-bud{position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:40px;background:radial-gradient(circle,#FFB6C1 0%,#FF1493 100%);border-radius:50%/60% 60% 40% 40%;box-shadow:0 0 20px #ff149399}.rose-bloom-primary .rose-bud{animation:roseBloom .6s ease-out}.rose-bloom-offbeat .rose-bud{animation:roseBloom .4s ease-out}.rose-bloom-subdivision .rose-bud{animation:roseBloom .3s ease-out}@keyframes roseBloom{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.3);box-shadow:0 0 40px #ff1493cc}}.beat-pride{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.rainbow-arc{position:absolute;width:200px;height:100px;border:15px solid transparent;border-top-color:red;border-radius:200px 200px 0 0;border-bottom:none;box-shadow:inset 0 15px #ff7f00,inset 0 30px #ff0,inset 0 45px #0f0,inset 0 60px #00f,inset 0 75px indigo,inset 0 90px #9400d3}.rainbow-pulse-primary{animation:rainbowPulse .6s ease-in-out}.rainbow-pulse-offbeat{animation:rainbowPulse .4s ease-in-out}.rainbow-pulse-subdivision{animation:rainbowPulse .3s ease-in-out}.rainbow-heart{position:absolute;width:60px;height:60px;background:linear-gradient(135deg,#FF0000,#FF7F00,#FFFF00,#00FF00,#0000FF,#4B0082,#9400D3);transform:rotate(45deg);border-radius:50% 0 50% 50%}.heart-beat-primary{animation:rainbowHeartBeat .6s ease-in-out}.heart-beat-offbeat{animation:rainbowHeartBeat .4s ease-in-out}.heart-beat-subdivision{animation:rainbowHeartBeat .3s ease-in-out}@keyframes rainbowPulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.2);filter:brightness(1.5)}}@keyframes rainbowHeartBeat{0%,to{transform:rotate(45deg) scale(1)}50%{transform:rotate(45deg) scale(1.3)}}.beat-summersolstice{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.sun-center{position:absolute;width:80px;height:80px;background:radial-gradient(circle,#FFD700 0%,#FFA500 100%);border-radius:50%;box-shadow:0 0 40px #ffd700cc;z-index:2}.sun-rays{position:absolute;width:150px;height:150px;z-index:1}.sun-rays:before,.sun-rays:after{content:"";position:absolute;top:50%;left:50%;width:100%;height:4px;background:linear-gradient(90deg,transparent 0%,#FF8C00 50%,transparent 100%);transform:translate(-50%,-50%)}.sun-rays:before{transform:translate(-50%,-50%) rotate(45deg)}.sun-rays:after{transform:translate(-50%,-50%) rotate(-45deg)}.rays-extend-primary{animation:raysExtend .6s ease-out}.rays-extend-offbeat{animation:raysExtend .4s ease-out}.rays-extend-subdivision{animation:raysExtend .3s ease-out}@keyframes raysExtend{0%{width:150px;height:150px;opacity:1}50%{width:200px;height:200px;opacity:1}to{width:250px;height:250px;opacity:.3}}.beat-independence{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.sparkler-stick{position:absolute;bottom:20%;width:4px;height:100px;background:linear-gradient(180deg,#8B4513 0%,#654321 100%);transform-origin:bottom center;z-index:1}.sparkler-sparks{position:absolute;width:100px;height:100px;top:30%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,#FFFFFF 0%,#FFD700 30%,transparent 60%);border-radius:50%;animation:sparklerBurst .5s ease-out forwards}.sparks-primary{width:150px;height:150px;animation-duration:.6s}.sparks-subdivision{width:60px;height:60px;animation-duration:.3s}.star-burst{position:absolute;width:200px;height:200px;top:30%;left:50%;transform:translate(-50%,-50%)}.star{position:absolute;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:15px solid;animation:starExplode .8s ease-out forwards}.star:after{content:"";position:absolute;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:15px solid;top:5px;left:-10px}.star-1{border-bottom-color:red;left:30%;animation-delay:0s}.star-1:after{border-top-color:red}.star-2{border-bottom-color:#fff;left:50%;animation-delay:.1s}.star-2:after{border-top-color:#fff}.star-3{border-bottom-color:#00f;left:70%;animation-delay:.2s}.star-3:after{border-top-color:#00f}@keyframes sparklerBurst{0%{opacity:1;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}@keyframes starExplode{0%{top:50%;opacity:1;transform:scale(0)}50%{opacity:1}to{top:10%;opacity:0;transform:scale(1) rotate(360deg)}}.beat-beach{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.sandcastle{position:absolute;bottom:15%;width:60px;height:40px;background:linear-gradient(180deg,#FFD700 0%,#DAA520 100%);clip-path:polygon(50% 0%,0% 100%,100% 100%);z-index:2}.ocean-wave{position:absolute;bottom:0;width:200px;height:60px;background:linear-gradient(180deg,transparent 0%,rgba(0,206,209,.6) 50%,rgba(0,206,209,.8) 100%);border-radius:50% 50% 0 0;animation:waveCrash .8s ease-in-out forwards}.wave-primary{height:80px;animation-duration:1s}.wave-subdivision{height:40px;animation-duration:.5s}@keyframes waveCrash{0%{bottom:-60px;width:100px;opacity:0}50%{bottom:0;width:200px;opacity:1}to{bottom:0;width:250px;opacity:0}}.beat-backtoschool{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.school-apple{position:relative;width:70px;height:70px;background:radial-gradient(circle,#FF0000 0%,#CC0000 100%);border-radius:50%/45% 45% 55% 55%;box-shadow:0 5px 15px #f006}.school-apple:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%);width:3px;height:15px;background:#8B4513}.apple-bounce-primary{animation:appleBounce .5s ease-out}.apple-bounce-offbeat{animation:appleBounce .3s ease-out}.apple-bounce-subdivision{animation:appleBounce .2s ease-out}.pencil{position:absolute;width:10px;height:100px;background:linear-gradient(180deg,#FFD700 0%,#FFD700 80%,#FFA500 80%,#FFA500 85%,#000000 85%);transform-origin:bottom center;left:60%;top:40%}.pencil-tap-primary{animation:pencilTap .4s ease-out}.pencil-tap-offbeat{animation:pencilTap .3s ease-out}.pencil-tap-subdivision{animation:pencilTap .2s ease-out}@keyframes appleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pencilTap{0%,to{transform:rotate(0)}50%{transform:rotate(-30deg)}}.beat-carnival{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.ferris-wheel{position:relative;width:120px;height:120px}.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#FFD700;border-radius:50%;z-index:3;box-shadow:0 0 20px #ffd700cc}.wheel-spoke{position:absolute;top:50%;left:50%;width:120px;height:3px;background:#FF1493;transform-origin:center}.spoke-1{transform:translate(-50%,-50%) rotate(45deg)}.spoke-2{transform:translate(-50%,-50%) rotate(-45deg)}.wheel-car{position:absolute;width:20px;height:25px;background:#00FFFF;border-radius:5px;box-shadow:0 0 15px #0ff9}.car-1{top:10px;left:50%;transform:translate(-50%)}.car-2{bottom:10px;left:50%;transform:translate(-50%)}.wheel-rotate-primary{animation:wheelRotate .8s ease-in-out}.wheel-rotate-offbeat{animation:wheelRotate .5s ease-in-out}.wheel-rotate-subdivision{animation:wheelRotate .3s ease-in-out}@keyframes wheelRotate{0%{transform:rotate(0)}to{transform:rotate(90deg)}}.beat-autumn{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.falling-leaf{position:absolute;width:50px;height:50px;top:0;left:50%;animation:leafFall 1.5s ease-in forwards}.falling-leaf:before{content:"🍂";position:absolute;font-size:50px}.leaf-primary{width:60px;height:60px;animation-duration:1.8s}.leaf-primary:before{font-size:60px}.leaf-subdivision{width:35px;height:35px;animation-duration:1s}.leaf-subdivision:before{font-size:35px}@keyframes leafFall{0%{top:0;transform:translate(-50%) rotate(0);opacity:1}25%{transform:translate(-30%) rotate(90deg)}50%{transform:translate(-70%) rotate(180deg)}75%{transform:translate(-40%) rotate(270deg)}to{top:100%;transform:translate(-50%) rotate(360deg);opacity:0}}.beat-oktoberfest{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.beer-stein{position:relative;width:70px;height:90px}.stein-body{width:70px;height:80px;background:linear-gradient(180deg,rgba(139,69,19,.3) 0%,#8B4513 100%);border:3px solid #FFD700;border-radius:5px;position:relative;overflow:hidden}.stein-handle{position:absolute;right:-15px;top:20px;width:25px;height:40px;border:3px solid #FFD700;border-left:none;border-radius:0 20px 20px 0}.stein-clink-primary{animation:steinClink .5s ease-out}.stein-clink-offbeat{animation:steinClink .3s ease-out}.stein-clink-subdivision{animation:steinClink .2s ease-out}.beer-foam{position:absolute;top:-20px;left:0;right:0;height:30px;background:radial-gradient(ellipse at center,#FFFFFF 0%,#F5F5DC 100%);border-radius:50% 50% 0 0;animation:foamOverflow .6s ease-out forwards}@keyframes steinClink{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-15px) rotate(-5deg)}75%{transform:translateY(-10px) rotate(5deg)}}@keyframes foamOverflow{0%{top:0;opacity:1}to{top:-30px;opacity:0}}.beat-halloween{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.jack-o-lantern{position:relative;width:100px;height:100px;background:radial-gradient(circle,#FF7F00 0%,#FF6347 100%);border-radius:50%;box-shadow:0 0 30px #ff7f0099}.pumpkin-eye{position:absolute;width:15px;height:20px;background:#000000;clip-path:polygon(50% 0%,0% 100%,100% 100%);top:35%}.eye-left{left:25%}.eye-right{right:25%}.pumpkin-mouth{position:absolute;bottom:25%;left:50%;transform:translate(-50%);width:50px;height:20px;border:3px solid #000000;border-top:none;border-radius:0 0 30px 30px}.pumpkin-mouth:before{content:"";position:absolute;width:8px;height:15px;background:#000000;left:15%;top:0}.pumpkin-mouth:after{content:"";position:absolute;width:8px;height:15px;background:#000000;right:15%;top:0}.pumpkin-glow-primary{animation:pumpkinGlow .6s ease-in-out}.pumpkin-glow-offbeat{animation:pumpkinGlow .4s ease-in-out}.pumpkin-glow-subdivision{animation:pumpkinGlow .3s ease-in-out}@keyframes pumpkinGlow{0%,to{box-shadow:0 0 30px #ff7f0099;filter:brightness(1)}50%{box-shadow:0 0 60px #ff7f00;filter:brightness(1.5)}}.beat-ghost{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.friendly-ghost{position:relative;width:80px;height:100px;background:radial-gradient(ellipse at center,#FFFFFF 0%,#E0E0E0 100%);border-radius:50% 50% 0 0;box-shadow:0 0 30px #fffc}.friendly-ghost:after{content:"";position:absolute;bottom:0;left:0;right:0;height:20px;background:#FFFFFF;clip-path:polygon(0 0,20% 50%,40% 0,60% 50%,80% 0,100% 50%,100% 100%,0 100%)}.ghost-eye{position:absolute;width:12px;height:12px;background:#000000;border-radius:50%;top:30%}.ghost-mouth{position:absolute;bottom:35%;left:50%;transform:translate(-50%);width:30px;height:15px;border:2px solid #000000;border-top:none;border-radius:0 0 15px 15px}.ghost-float-primary{animation:ghostFloat .8s ease-in-out}.ghost-float-offbeat{animation:ghostFloat .5s ease-in-out}.ghost-float-subdivision{animation:ghostFloat .3s ease-in-out}@keyframes ghostFloat{0%,to{transform:translateY(0);opacity:.9}50%{transform:translateY(-30px);opacity:1}}.beat-diadelosmuertos{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.sugar-skull{position:relative;width:90px;height:100px;background:radial-gradient(ellipse at center,#FFFFFF 0%,#F0F0F0 100%);border-radius:50% 50% 45% 45%;box-shadow:0 0 30px #ff149399}.skull-pattern{position:absolute;border-radius:50%}.pattern-1{width:20px;height:20px;border:3px solid #FF1493;top:25%;left:20%}.pattern-2{width:20px;height:20px;border:3px solid #00FFFF;top:25%;right:20%}.skull-glow-primary{animation:skullGlow .6s ease-in-out}.skull-glow-offbeat{animation:skullGlow .4s ease-in-out}.skull-glow-subdivision{animation:skullGlow .3s ease-in-out}.marigold-burst{position:absolute;width:100%;height:100%}.marigold{position:absolute;font-size:40px;animation:marigoldBurst .8s ease-out forwards}.marigold:before{content:"🌼"}.marigold-1{left:20%;top:50%;animation-delay:0s}.marigold-2{right:20%;top:50%;animation-delay:.1s}@keyframes skullGlow{0%,to{box-shadow:0 0 30px #ff149399;filter:brightness(1)}50%{box-shadow:0 0 60px #ff1493,0 0 80px #0ff9;filter:brightness(1.3)}}@keyframes marigoldBurst{0%{opacity:0;transform:scale(0) rotate(0)}50%{opacity:1;transform:scale(1.2) rotate(180deg)}to{opacity:0;transform:scale(.5) rotate(360deg)}}.beat-thanksgiving{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.turkey{position:relative;width:100px;height:100px}.turkey-tail{position:absolute;width:100px;height:80px;background:radial-gradient(ellipse at 20% 50%,#FF8C00 0%,transparent 30%),radial-gradient(ellipse at 40% 50%,#8B4513 0%,transparent 30%),radial-gradient(ellipse at 60% 50%,#FF0000 0%,transparent 30%),radial-gradient(ellipse at 80% 50%,#FFD700 0%,transparent 30%);border-radius:50% 50% 0 0;transform-origin:bottom center;z-index:1}.turkey-body{position:absolute;bottom:20px;left:50%;transform:translate(-50%);width:50px;height:60px;background:radial-gradient(ellipse at center,#8B4513 0%,#654321 100%);border-radius:50%;z-index:2;box-shadow:0 5px 15px #0000004d}.tail-fan-primary .turkey-tail{animation:tailFan .6s ease-in-out}.tail-fan-offbeat .turkey-tail{animation:tailFan .4s ease-in-out}.tail-fan-subdivision .turkey-tail{animation:tailFan .3s ease-in-out}@keyframes tailFan{0%,to{transform:scaleY(.6)}50%{transform:scaleY(1.2)}}.beat-cornucopia{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.horn-of-plenty{position:relative;width:120px;height:60px;background:linear-gradient(135deg,#DAA520 0%,#B8860B 100%);border-radius:50%/60% 60% 40% 40%;transform-origin:right center;box-shadow:0 5px 15px #0000004d}.horn-tip-primary{animation:hornTip .5s ease-in-out}.horn-tip-offbeat{animation:hornTip .3s ease-in-out}.horn-tip-subdivision{animation:hornTip .2s ease-in-out}.fruit-spill{position:absolute;width:100%;height:100%}.fruit{position:absolute;width:30px;height:30px;border-radius:50%;animation:fruitSpill .8s ease-out forwards}.fruit-1{background:radial-gradient(circle,#FF0000 0%,#CC0000 100%);left:40%;animation-delay:0s}.fruit-2{background:radial-gradient(circle,#FF8C00 0%,#D2691E 100%);left:50%;animation-delay:.1s}.fruit-3{background:radial-gradient(circle,#9400D3 0%,#8B008B 100%);left:60%;animation-delay:.2s}@keyframes hornTip{0%,to{transform:rotate(0)}50%{transform:rotate(-25deg)}}@keyframes fruitSpill{0%{top:40%;opacity:1;transform:scale(1) rotate(0)}to{top:70%;opacity:0;transform:scale(.5) rotate(360deg)}}.beat-diwali{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.diya-lamp{position:relative;width:80px;height:60px}.diya-base{position:absolute;bottom:0;width:80px;height:30px;background:linear-gradient(180deg,#FFD700 0%,#DAA520 100%);border-radius:50%/30% 30% 70% 70%;box-shadow:0 5px 15px #ffd70080}.diya-flame{position:absolute;top:-20px;left:50%;transform:translate(-50%);width:20px;height:30px;background:linear-gradient(180deg,#FFD700 0%,#FF4500 50%,#FF6347 100%);border-radius:50%/60% 60% 40% 40%;box-shadow:0 0 30px #ff4500cc}.flame-dance-primary .diya-flame{animation:flameDance .6s ease-in-out}.flame-dance-offbeat .diya-flame{animation:flameDance .4s ease-in-out}.flame-dance-subdivision .diya-flame{animation:flameDance .3s ease-in-out}.rangoli-pattern{position:absolute;width:150px;height:150px;background:radial-gradient(circle,#FF4500 0%,transparent 20%),conic-gradient(from 0deg,#FFD700,#FF4500,#9400D3,#00FFFF,#FFD700);border-radius:50%;opacity:0;animation:rangoliAppear .8s ease-out forwards}@keyframes flameDance{0%,to{transform:translate(-50%) scaleY(1);box-shadow:0 0 30px #ff4500cc}50%{transform:translate(-50%) scaleY(1.3);box-shadow:0 0 50px #ff4500}}@keyframes rangoliAppear{0%{opacity:0;transform:scale(0) rotate(0)}50%{opacity:.8;transform:scale(1) rotate(180deg)}to{opacity:0;transform:scale(1.5) rotate(360deg)}}.beat-christmas{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.ornament-string{position:absolute;top:10%;left:50%;transform:translate(-50%);width:2px;height:40px;background:#C0C0C0;z-index:1}.christmas-ornament{position:relative;width:80px;height:80px;background:radial-gradient(circle at 30% 30%,#FF0000 0%,#8B0000 100%);border-radius:50%;box-shadow:inset -10px -10px 20px #0000004d,0 0 30px #f009;transform-origin:top center}.christmas-ornament:before{content:"";position:absolute;top:20%;left:20%;width:30px;height:20px;background:rgba(255,255,255,.3);border-radius:50%;filter:blur(5px)}.ornament-swing-primary{animation:ornamentSwing .8s ease-in-out}.ornament-swing-offbeat{animation:ornamentSwing .5s ease-in-out}.ornament-swing-subdivision{animation:ornamentSwing .3s ease-in-out}.falling-snowflakes{position:absolute;width:100%;height:100%}.tiny-snowflake{position:absolute;color:#fff;font-size:20px;opacity:.8;animation:tinySnowfall 1.2s ease-in forwards}.tiny-snowflake:before{content:"❄"}.flake-1{left:30%;animation-delay:0s}.flake-2{left:50%;animation-delay:.2s}.flake-3{left:70%;animation-delay:.4s}@keyframes ornamentSwing{0%,to{transform:rotate(0)}25%{transform:rotate(-12deg)}75%{transform:rotate(12deg)}}@keyframes tinySnowfall{0%{top:10%;opacity:.8}to{top:90%;opacity:0}}.beat-hanukkah{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.menorah{position:relative;width:140px;height:100px}.menorah-base{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:120px;height:15px;background:linear-gradient(180deg,#FFD700 0%,#DAA520 100%);border-radius:5px}.menorah-candle{position:absolute;bottom:15px;width:8px;height:40px;background:linear-gradient(180deg,#FFFFFF 0%,#E0E0E0 100%);border-radius:3px 3px 0 0}.menorah-candle:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%);width:8px;height:12px;background:transparent;border-radius:50%/60% 60% 40% 40%;transition:background .3s ease}.menorah-candle.candle-lit:before{background:linear-gradient(180deg,#FFD700 0%,#FF8C00 100%);box-shadow:0 0 20px #ffd700cc}.candle-shamash{width:10px;left:50%;transform:translate(-50%);height:55px}.candle-1{left:36%}.candle-2{right:36%}.candle-3{left:27%}.candle-4{right:27%}.candle-5{left:18%}.candle-6{right:18%}.candle-7{left:9%}.candle-8{right:9%}.beat-newyearseve{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.disco-ball{position:relative;width:100px;height:100px;background:linear-gradient(45deg,#C0C0C0 25%,transparent 25%,transparent 75%,#C0C0C0 75%),linear-gradient(-45deg,#D3D3D3 25%,transparent 25%,transparent 75%,#D3D3D3 75%);background-size:20px 20px;background-position:0 0,10px 10px;border-radius:50%;box-shadow:inset -15px -15px 30px #0000004d,0 0 50px #ffd70080}.ball-sparkle-primary{animation:discoSparkle .8s ease-in-out}.ball-sparkle-offbeat{animation:discoSparkle .5s ease-in-out}.ball-sparkle-subdivision{animation:discoSparkle .3s ease-in-out}.confetti-burst{position:absolute;width:100%;height:100%}.confetti{position:absolute;width:10px;height:20px;animation:confettiDrop 1.2s ease-out forwards}.confetti-1{background:#FFD700;left:25%;animation-delay:0s;transform:rotate(45deg)}.confetti-2{background:#FF0000;left:40%;animation-delay:.1s;transform:rotate(90deg)}.confetti-3{background:#00FF00;left:60%;animation-delay:.2s;transform:rotate(135deg)}.confetti-4{background:#0000FF;left:75%;animation-delay:.3s;transform:rotate(180deg)}@keyframes discoSparkle{0%,to{transform:rotate(0) scale(1);box-shadow:0 0 50px #ffd70080}50%{transform:rotate(180deg) scale(1.1);box-shadow:0 0 80px gold}}@keyframes confettiDrop{0%{top:30%;opacity:1;transform:rotate(0)}to{top:100%;opacity:0;transform:rotate(720deg)}}.metronome-ad-container{width:100%;max-width:728px;margin:var(--spacing-lg) auto;padding:var(--spacing-md);display:flex;justify-content:center;align-items:center}.metronome-ad{width:100%;min-height:90px}@media (max-width: 768px){.metronome-ad-container{max-width:100%;padding:var(--spacing-sm)}.metronome-ad{min-height:50px}}.beat-spaceopera{position:relative;width:400px;height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.laser-container{position:relative;width:100%;height:100%;background:radial-gradient(circle at center,rgba(27,42,74,.3) 0%,transparent 70%);border-radius:8px;overflow:hidden}.target-reticle{position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid #ff4444;border-radius:50%;box-shadow:0 0 10px #ff444480,inset 0 0 10px #ff44444d;z-index:10}.target-reticle:before,.target-reticle:after{content:"";position:absolute;background:#ff4444;box-shadow:0 0 5px #f44c}.target-reticle:before{top:50%;left:-10px;right:-10px;height:1px;margin-top:-.5px}.target-reticle:after{left:50%;top:-10px;bottom:-10px;width:1px;margin-left:-.5px}.laser-blast{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;animation:laser-fade-out .5s ease-out forwards}.laser-beam{position:absolute;top:var(--origin-y);left:var(--origin-x);width:0;height:3px;transform-origin:left center;animation:laser-beam-shoot .15s ease-out forwards}.blast-primary .laser-beam{background:linear-gradient(90deg,rgba(255,212,71,1) 0%,rgba(255,212,71,.8) 50%,rgba(255,212,71,0) 100%);box-shadow:0 0 10px #ffd447cc,0 0 20px #ffd44766;height:4px}.blast-offbeat .laser-beam{background:linear-gradient(90deg,rgba(201,164,59,1) 0%,rgba(201,164,59,.8) 50%,rgba(201,164,59,0) 100%);box-shadow:0 0 8px #c9a43bcc,0 0 16px #c9a43b66;height:3px}.blast-subdivision .laser-beam{background:linear-gradient(90deg,rgba(74,247,201,1) 0%,rgba(74,247,201,.8) 50%,rgba(74,247,201,0) 100%);box-shadow:0 0 6px #4af7c9cc,0 0 12px #4af7c966;height:2px}.laser-impact{position:absolute;width:15px;height:15px;margin:-7.5px 0 0 -7.5px;border-radius:50%;animation:laser-impact-burst .3s ease-out forwards;opacity:0}.blast-primary .laser-impact{background:radial-gradient(circle,rgba(255,212,71,1) 0%,rgba(255,212,71,0) 70%);box-shadow:0 0 20px #ffd447,0 0 40px #ffd44799}.blast-offbeat .laser-impact{background:radial-gradient(circle,rgba(201,164,59,1) 0%,rgba(201,164,59,0) 70%);box-shadow:0 0 16px #c9a43b,0 0 32px #c9a43b99}.blast-subdivision .laser-impact{background:radial-gradient(circle,rgba(74,247,201,1) 0%,rgba(74,247,201,0) 70%);box-shadow:0 0 12px #4af7c9,0 0 24px #4af7c999}.spaceopera-numbers{position:absolute;bottom:30px;left:50%;transform:translate(-50%);text-align:center;color:#f7d54a;font-family:Courier New,monospace;text-shadow:0 0 10px rgba(247,213,74,.6);z-index:20}.spaceopera-numbers .beat-number-large{font-size:48px;font-weight:700;line-height:1}.spaceopera-numbers .beat-label-small{font-size:18px;color:#c9a43b;margin-top:5px}@keyframes laser-beam-shoot{0%{width:0;opacity:1;transform:rotate(var(--laser-angle))}50%{opacity:1}to{width:var(--laser-distance);transform:rotate(var(--laser-angle));opacity:.8}}@keyframes laser-impact-burst{0%{opacity:1;transform:scale(.5)}50%{opacity:1;transform:scale(1.5)}to{opacity:0;transform:scale(2.5)}}@keyframes laser-fade-out{0%{opacity:1}70%{opacity:1}to{opacity:0}}@media (max-width: 768px){.beat-spaceopera{width:300px;height:300px}.spaceopera-numbers .beat-number-large{font-size:36px}.spaceopera-numbers .beat-label-small{font-size:14px}}.beat-pixelducks{position:relative;width:400px;height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.pixel-sky{position:relative;width:100%;height:100%;background:#5C94FC;border-radius:8px;overflow:hidden;transition:background-color .05s;image-rendering:pixelated}.pixel-sky.sky-flash{background:#FFFFFF!important}.pixel-grass{position:absolute;bottom:0;left:0;right:0;height:25%;background:#00A800}.pixel-duck{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:384px;height:384px}.duck-body,.duck-head,.duck-beak,.duck-eye,.duck-eye-pupil,.duck-neck,.duck-tail,.duck-feet,.duck-wing{position:absolute;image-rendering:pixelated}.duck-body{width:54px;height:36px;background:#8B4513;left:148px;top:96px;box-shadow:-6px 0 #6b3410,6px 0 #6b3410,0 6px #6b3410,-6px 6px #6b3410,6px 6px #6b3410}.duck-head{width:42px;height:36px;background:#228B22;left:190px;top:66px;box-shadow:6px 0 #228b22,0 6px #228b22,6px 6px #228b22,-6px 6px #1a6b1a}.duck-beak{width:24px;height:12px;background:#FFA500;left:232px;top:84px;box-shadow:6px 0 orange,0 6px #ff8c00,6px 6px #ff8c00}.duck-eye{width:18px;height:18px;background:#FFFFFF;left:208px;top:72px;box-shadow:6px 0 #fff}.duck-eye-pupil{width:12px;height:12px;background:#000000;left:214px;top:78px}.duck-neck{width:42px;height:12px;background:#FFFFFF;left:166px;top:90px;box-shadow:6px 0 #fff,-6px 0 #fff}.duck-tail{width:24px;height:30px;background:#654321;left:130px;top:102px;box-shadow:-6px 0 #654321,0 -6px #8b4513,-6px -6px #8b4513,6px 0 #654321}.duck-wing{width:42px;height:30px;background:#654321;left:160px;top:102px;transition:transform .1s ease-out;box-shadow:6px 0 #654321,12px 0 #654321,0 6px #8b4513,6px 6px #8b4513,12px 6px #8b4513}.duck-feet{width:18px;height:18px;background:#FF8C00;left:150px;top:138px}.duck-flap-primary .duck-wing,.wing-primary{animation:wing-flap-primary .15s ease-out}.duck-flap-offbeat .duck-wing,.wing-offbeat{animation:wing-flap-offbeat .12s ease-out}.duck-flap-subdivision .duck-wing,.wing-subdivision{animation:wing-flap-subdivision .1s ease-out}@keyframes wing-flap-primary{0%{transform:translateY(0)}50%{transform:translateY(-36px)}to{transform:translateY(0)}}@keyframes wing-flap-offbeat{0%{transform:translateY(0)}50%{transform:translateY(-24px)}to{transform:translateY(0)}}@keyframes wing-flap-subdivision{0%{transform:translateY(0)}50%{transform:translateY(-18px)}to{transform:translateY(0)}}.bang-explosion{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:100;animation:bang-appear .15s ease-out}.bang-text{font-family:Comic Sans MS,"Press Start 2P",cursive,monospace;font-size:72px;font-weight:700;color:gold;text-shadow:-4px -4px 0 #FF4500,4px -4px 0 #FF4500,-4px 4px 0 #FF4500,4px 4px 0 #FF4500,0 0 10px #FF0000,0 0 20px #FF0000;letter-spacing:4px;animation:bang-shake .15s ease-out}.bang-burst{position:absolute;top:50%;left:50%;width:120px;height:120px;margin:-60px 0 0 -60px;background:radial-gradient(circle,rgba(255,215,0,.8) 0%,rgba(255,69,0,.6) 30%,rgba(255,0,0,.4) 60%,transparent 100%);animation:bang-burst-expand .15s ease-out;pointer-events:none}@keyframes bang-appear{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes bang-shake{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes bang-burst-expand{0%{transform:scale(.5);opacity:1}to{transform:scale(1.5);opacity:0}}.pixelducks-numbers{position:absolute;bottom:30px;left:50%;transform:translate(-50%);text-align:center;color:#fff;font-family:"Press Start 2P",monospace,sans-serif;text-shadow:-2px -2px 0 #000000,2px -2px 0 #000000,-2px 2px 0 #000000,2px 2px 0 #000000;z-index:20}.pixelducks-numbers .beat-number-large{font-size:48px;font-weight:700;line-height:1}.pixelducks-numbers .beat-label-small{font-size:16px;margin-top:8px}@media (max-width: 768px){.beat-pixelducks{width:300px;height:300px}.pixel-duck{width:96px;height:96px;transform:translate(-160%,-160%) scale(.85)}.bang-text{font-size:54px}.pixelducks-numbers .beat-number-large{font-size:36px}.pixelducks-numbers .beat-label-small{font-size:12px}}.beat-sixseven{position:relative;width:400px;height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.vhs-container{position:relative;width:100%;height:300px;background:linear-gradient(180deg,rgba(10,10,15,.95) 0%,rgba(26,26,36,.9) 50%,rgba(10,10,15,.95) 100%);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.hands-container{position:relative;width:280px;height:200px;padding-top:100px;display:flex;align-items:center;justify-content:space-between}.hand-emoji{position:relative;width:125px;height:86px;background-image:url(/sixseven-hand.png);background-size:contain;background-repeat:no-repeat;background-position:center;filter:drop-shadow(2px 0px 0px #7A4FFF) drop-shadow(-2px 0px 0px #4CFFB3) drop-shadow(0px 2px 4px rgba(0,0,0,.5));transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.hand-left{transform:translateY(0)}.hand-right{transform:translateY(0) scaleX(-1)}.hand-up{transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.hand-down{transition:transform .25s ease-out}.hand-left.intensity-primary.hand-up{transform:translateY(-80px);filter:drop-shadow(2px 0px 0px #7A4FFF) drop-shadow(-2px 0px 0px #4CFFB3) drop-shadow(0px 0px 15px #FF2E63) drop-shadow(0px 2px 4px rgba(0,0,0,.5))}.hand-right.intensity-primary.hand-up{transform:translateY(-80px) scaleX(-1);filter:drop-shadow(2px 0px 0px #7A4FFF) drop-shadow(-2px 0px 0px #4CFFB3) drop-shadow(0px 0px 15px #FF2E63) drop-shadow(0px 2px 4px rgba(0,0,0,.5))}.hand-left.intensity-offbeat.hand-up{transform:translateY(-50px)}.hand-right.intensity-offbeat.hand-up{transform:translateY(-50px) scaleX(-1)}.hand-left.intensity-subdivision.hand-up{transform:translateY(-30px)}.hand-right.intensity-subdivision.hand-up{transform:translateY(-30px) scaleX(-1)}.sixseven-numbers{margin-top:20px;text-align:center;color:#ff2e63;text-shadow:1px 0px #7A4FFF,-1px 0px #4CFFB3}.sixseven-numbers .beat-number-large{font-size:48px;font-weight:700;line-height:1;font-style:italic;transform:skew(-5deg)}.sixseven-numbers .beat-label-small{font-size:16px;margin-top:8px;color:#5d5dff;text-shadow:1px 0px #7A4FFF,-1px 0px #4CFFB3}@media (max-width: 768px){.beat-sixseven{width:300px;height:300px}.vhs-container{height:220px}.hands-container{width:200px;height:150px}.hand-emoji{width:94px;height:64px}.sixseven-numbers .beat-number-large{font-size:36px}.sixseven-numbers .beat-label-small{font-size:12px}}.activity-calendar{width:100%}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-header-cell{text-align:center;font-weight:600;color:var(--color-onSurface);opacity:.7;font-size:.85rem;padding:.5rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:1.5rem}.calendar-day{aspect-ratio:1;border:2px solid var(--color-divider);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:.25rem;transition:transform .2s,box-shadow .2s;cursor:default;background:var(--color-surface)}.calendar-day.current-month{cursor:pointer}.calendar-day.current-month:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026;z-index:10}.calendar-day.other-month{opacity:.3}.calendar-day.today{border-color:var(--color-primary);border-width:3px;font-weight:700}.calendar-day.streak-achieved{border-color:var(--color-primary)}.day-number{font-size:.9rem;font-weight:600;color:var(--color-onSurface);margin-bottom:.15rem}.day-minutes{font-size:.7rem;color:var(--color-onSurface);opacity:.8;font-weight:500}.day-check{position:absolute;top:2px;right:2px;font-size:.8rem;color:var(--color-primary)}.day-theme-indicator{position:absolute;bottom:2px;right:2px;font-size:.7rem;opacity:.7}.calendar-legend{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding-top:1rem;border-top:1px solid var(--color-divider)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--color-onSurface)}.legend-icon{width:24px;height:24px;border-radius:4px;border:2px solid var(--color-divider)}.legend-icon.no-activity{background:var(--color-surface)}.legend-icon.some-activity{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-background) 100%);opacity:.5}.legend-icon.high-activity{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-background) 100%)}.legend-icon.streak{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-background) 100%);border-color:var(--color-primary);position:relative}.legend-icon.streak:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--color-primary);font-weight:700;font-size:.9rem}@media (max-width: 768px){.calendar-header-cell{font-size:.75rem;padding:.25rem}.day-number{font-size:.8rem}.day-minutes{font-size:.6rem}.day-check{font-size:.7rem}.day-theme-indicator{font-size:.6rem}.calendar-legend{gap:.5rem}.legend-item{font-size:.75rem}.legend-icon{width:20px;height:20px}}.calendar-day-atomicmonitor-0{background:linear-gradient(135deg,#32FF6A00 0%,#020F06 100%)}.calendar-day-atomicmonitor-10{background:linear-gradient(135deg,#32FF6A19 0%,#020F06 100%)}.calendar-day-atomicmonitor-20{background:linear-gradient(135deg,#32FF6A33 0%,#020F06 100%)}.calendar-day-atomicmonitor-30{background:linear-gradient(135deg,#32FF6A4c 0%,#020F06 100%)}.calendar-day-atomicmonitor-40{background:linear-gradient(135deg,#32FF6A66 0%,#020F06 100%)}.calendar-day-atomicmonitor-50{background:linear-gradient(135deg,#32FF6A7f 0%,#020F06 100%)}.calendar-day-atomicmonitor-60{background:linear-gradient(135deg,#32FF6A99 0%,#020F06 100%)}.calendar-day-atomicmonitor-70{background:linear-gradient(135deg,#32FF6Ab2 0%,#020F06 100%)}.calendar-day-atomicmonitor-80{background:linear-gradient(135deg,#32FF6Acc 0%,#020F06 100%)}.calendar-day-atomicmonitor-90{background:linear-gradient(135deg,#32FF6Ae5 0%,#020F06 100%)}.calendar-day-atomicmonitor-100{background:linear-gradient(135deg,#32FF6Afe 0%,#020F06 100%)}.calendar-day-blip-0{background:linear-gradient(135deg,#7c4dff00 0%,#1a1a2e 100%)}.calendar-day-blip-10{background:linear-gradient(135deg,#7c4dff19 0%,#1a1a2e 100%)}.calendar-day-blip-20{background:linear-gradient(135deg,#7c4dff33 0%,#1a1a2e 100%)}.calendar-day-blip-30{background:linear-gradient(135deg,#7c4dff4c 0%,#1a1a2e 100%)}.calendar-day-blip-40{background:linear-gradient(135deg,#7c4dff66 0%,#1a1a2e 100%)}.calendar-day-blip-50{background:linear-gradient(135deg,#7c4dff7f 0%,#1a1a2e 100%)}.calendar-day-blip-60{background:linear-gradient(135deg,#7c4dff99 0%,#1a1a2e 100%)}.calendar-day-blip-70{background:linear-gradient(135deg,#7c4dffb2 0%,#1a1a2e 100%)}.calendar-day-blip-80{background:linear-gradient(135deg,#7c4dffcc 0%,#1a1a2e 100%)}.calendar-day-blip-90{background:linear-gradient(135deg,#7c4dffe5 0%,#1a1a2e 100%)}.calendar-day-blip-100{background:linear-gradient(135deg,#7c4dfffe 0%,#1a1a2e 100%)}.calendar-day-classic-0{background:linear-gradient(135deg,#8b451300 0%,#2f1810 100%)}.calendar-day-classic-10{background:linear-gradient(135deg,#8b451319 0%,#2f1810 100%)}.calendar-day-classic-20{background:linear-gradient(135deg,#8b451333 0%,#2f1810 100%)}.calendar-day-classic-30{background:linear-gradient(135deg,#8b45134c 0%,#2f1810 100%)}.calendar-day-classic-40{background:linear-gradient(135deg,#8b451366 0%,#2f1810 100%)}.calendar-day-classic-50{background:linear-gradient(135deg,#8b45137f 0%,#2f1810 100%)}.calendar-day-classic-60{background:linear-gradient(135deg,#8b451399 0%,#2f1810 100%)}.calendar-day-classic-70{background:linear-gradient(135deg,#8b4513b2 0%,#2f1810 100%)}.calendar-day-classic-80{background:linear-gradient(135deg,#8b4513cc 0%,#2f1810 100%)}.calendar-day-classic-90{background:linear-gradient(135deg,#8b4513e5 0%,#2f1810 100%)}.calendar-day-classic-100{background:linear-gradient(135deg,#8b4513fe 0%,#2f1810 100%)}.calendar-day-dark-0{background:linear-gradient(135deg,#90caf900 0%,#121212 100%)}.calendar-day-dark-10{background:linear-gradient(135deg,#90caf919 0%,#121212 100%)}.calendar-day-dark-20{background:linear-gradient(135deg,#90caf933 0%,#121212 100%)}.calendar-day-dark-30{background:linear-gradient(135deg,#90caf94c 0%,#121212 100%)}.calendar-day-dark-40{background:linear-gradient(135deg,#90caf966 0%,#121212 100%)}.calendar-day-dark-50{background:linear-gradient(135deg,#90caf97f 0%,#121212 100%)}.calendar-day-dark-60{background:linear-gradient(135deg,#90caf999 0%,#121212 100%)}.calendar-day-dark-70{background:linear-gradient(135deg,#90caf9b2 0%,#121212 100%)}.calendar-day-dark-80{background:linear-gradient(135deg,#90caf9cc 0%,#121212 100%)}.calendar-day-dark-90{background:linear-gradient(135deg,#90caf9e5 0%,#121212 100%)}.calendar-day-dark-100{background:linear-gradient(135deg,#90caf9fe 0%,#121212 100%)}.calendar-day-flames-0{background:linear-gradient(135deg,#ff6b3500 0%,#1a0000 100%)}.calendar-day-flames-10{background:linear-gradient(135deg,#ff6b3519 0%,#1a0000 100%)}.calendar-day-flames-20{background:linear-gradient(135deg,#ff6b3533 0%,#1a0000 100%)}.calendar-day-flames-30{background:linear-gradient(135deg,#ff6b354c 0%,#1a0000 100%)}.calendar-day-flames-40{background:linear-gradient(135deg,#ff6b3566 0%,#1a0000 100%)}.calendar-day-flames-50{background:linear-gradient(135deg,#ff6b357f 0%,#1a0000 100%)}.calendar-day-flames-60{background:linear-gradient(135deg,#ff6b3599 0%,#1a0000 100%)}.calendar-day-flames-70{background:linear-gradient(135deg,#ff6b35b2 0%,#1a0000 100%)}.calendar-day-flames-80{background:linear-gradient(135deg,#ff6b35cc 0%,#1a0000 100%)}.calendar-day-flames-90{background:linear-gradient(135deg,#ff6b35e5 0%,#1a0000 100%)}.calendar-day-flames-100{background:linear-gradient(135deg,#ff6b35fe 0%,#1a0000 100%)}.calendar-day-flash-0{background:linear-gradient(135deg,#90caf900 0%,#000000 100%)}.calendar-day-flash-10{background:linear-gradient(135deg,#90caf919 0%,#000000 100%)}.calendar-day-flash-20{background:linear-gradient(135deg,#90caf933 0%,#000000 100%)}.calendar-day-flash-30{background:linear-gradient(135deg,#90caf94c 0%,#000000 100%)}.calendar-day-flash-40{background:linear-gradient(135deg,#90caf966 0%,#000000 100%)}.calendar-day-flash-50{background:linear-gradient(135deg,#90caf97f 0%,#000000 100%)}.calendar-day-flash-60{background:linear-gradient(135deg,#90caf999 0%,#000000 100%)}.calendar-day-flash-70{background:linear-gradient(135deg,#90caf9b2 0%,#000000 100%)}.calendar-day-flash-80{background:linear-gradient(135deg,#90caf9cc 0%,#000000 100%)}.calendar-day-flash-90{background:linear-gradient(135deg,#90caf9e5 0%,#000000 100%)}.calendar-day-flash-100{background:linear-gradient(135deg,#90caf9fe 0%,#000000 100%)}.calendar-day-gighero-0{background:linear-gradient(135deg,#00ff0000 0%,#000000 100%)}.calendar-day-gighero-10{background:linear-gradient(135deg,#00ff0019 0%,#000000 100%)}.calendar-day-gighero-20{background:linear-gradient(135deg,#00ff0033 0%,#000000 100%)}.calendar-day-gighero-30{background:linear-gradient(135deg,#00ff004c 0%,#000000 100%)}.calendar-day-gighero-40{background:linear-gradient(135deg,#00ff0066 0%,#000000 100%)}.calendar-day-gighero-50{background:linear-gradient(135deg,#00ff007f 0%,#000000 100%)}.calendar-day-gighero-60{background:linear-gradient(135deg,#00ff0099 0%,#000000 100%)}.calendar-day-gighero-70{background:linear-gradient(135deg,#00ff00b2 0%,#000000 100%)}.calendar-day-gighero-80{background:linear-gradient(135deg,#00ff00cc 0%,#000000 100%)}.calendar-day-gighero-90{background:linear-gradient(135deg,#00ff00e5 0%,#000000 100%)}.calendar-day-gighero-100{background:linear-gradient(135deg,#00ff00fe 0%,#000000 100%)}.calendar-day-herospotlight-0{background:linear-gradient(135deg,#FFD70000 0%,#0A0A0A 100%)}.calendar-day-herospotlight-10{background:linear-gradient(135deg,#FFD70019 0%,#0A0A0A 100%)}.calendar-day-herospotlight-20{background:linear-gradient(135deg,#FFD70033 0%,#0A0A0A 100%)}.calendar-day-herospotlight-30{background:linear-gradient(135deg,#FFD7004c 0%,#0A0A0A 100%)}.calendar-day-herospotlight-40{background:linear-gradient(135deg,#FFD70066 0%,#0A0A0A 100%)}.calendar-day-herospotlight-50{background:linear-gradient(135deg,#FFD7007f 0%,#0A0A0A 100%)}.calendar-day-herospotlight-60{background:linear-gradient(135deg,#FFD70099 0%,#0A0A0A 100%)}.calendar-day-herospotlight-70{background:linear-gradient(135deg,#FFD700b2 0%,#0A0A0A 100%)}.calendar-day-herospotlight-80{background:linear-gradient(135deg,#FFD700cc 0%,#0A0A0A 100%)}.calendar-day-herospotlight-90{background:linear-gradient(135deg,#FFD700e5 0%,#0A0A0A 100%)}.calendar-day-herospotlight-100{background:linear-gradient(135deg,#FFD700fe 0%,#0A0A0A 100%)}.calendar-day-light-0{background:linear-gradient(135deg,#1976d200 0%,#fafafa 100%)}.calendar-day-light-10{background:linear-gradient(135deg,#1976d219 0%,#fafafa 100%)}.calendar-day-light-20{background:linear-gradient(135deg,#1976d233 0%,#fafafa 100%)}.calendar-day-light-30{background:linear-gradient(135deg,#1976d24c 0%,#fafafa 100%)}.calendar-day-light-40{background:linear-gradient(135deg,#1976d266 0%,#fafafa 100%)}.calendar-day-light-50{background:linear-gradient(135deg,#1976d27f 0%,#fafafa 100%)}.calendar-day-light-60{background:linear-gradient(135deg,#1976d299 0%,#fafafa 100%)}.calendar-day-light-70{background:linear-gradient(135deg,#1976d2b2 0%,#fafafa 100%)}.calendar-day-light-80{background:linear-gradient(135deg,#1976d2cc 0%,#fafafa 100%)}.calendar-day-light-90{background:linear-gradient(135deg,#1976d2e5 0%,#fafafa 100%)}.calendar-day-light-100{background:linear-gradient(135deg,#1976d2fe 0%,#fafafa 100%)}.calendar-day-pixelducks-0{background:linear-gradient(135deg,#5C94FC00 0%,#1A1A2E 100%)}.calendar-day-pixelducks-10{background:linear-gradient(135deg,#5C94FC19 0%,#1A1A2E 100%)}.calendar-day-pixelducks-20{background:linear-gradient(135deg,#5C94FC33 0%,#1A1A2E 100%)}.calendar-day-pixelducks-30{background:linear-gradient(135deg,#5C94FC4c 0%,#1A1A2E 100%)}.calendar-day-pixelducks-40{background:linear-gradient(135deg,#5C94FC66 0%,#1A1A2E 100%)}.calendar-day-pixelducks-50{background:linear-gradient(135deg,#5C94FC7f 0%,#1A1A2E 100%)}.calendar-day-pixelducks-60{background:linear-gradient(135deg,#5C94FC99 0%,#1A1A2E 100%)}.calendar-day-pixelducks-70{background:linear-gradient(135deg,#5C94FCb2 0%,#1A1A2E 100%)}.calendar-day-pixelducks-80{background:linear-gradient(135deg,#5C94FCcc 0%,#1A1A2E 100%)}.calendar-day-pixelducks-90{background:linear-gradient(135deg,#5C94FCe5 0%,#1A1A2E 100%)}.calendar-day-pixelducks-100{background:linear-gradient(135deg,#5C94FCfe 0%,#1A1A2E 100%)}.calendar-day-raindrops-0{background:linear-gradient(135deg,#0288d100 0%,#0a1929 100%)}.calendar-day-raindrops-10{background:linear-gradient(135deg,#0288d119 0%,#0a1929 100%)}.calendar-day-raindrops-20{background:linear-gradient(135deg,#0288d133 0%,#0a1929 100%)}.calendar-day-raindrops-30{background:linear-gradient(135deg,#0288d14c 0%,#0a1929 100%)}.calendar-day-raindrops-40{background:linear-gradient(135deg,#0288d166 0%,#0a1929 100%)}.calendar-day-raindrops-50{background:linear-gradient(135deg,#0288d17f 0%,#0a1929 100%)}.calendar-day-raindrops-60{background:linear-gradient(135deg,#0288d199 0%,#0a1929 100%)}.calendar-day-raindrops-70{background:linear-gradient(135deg,#0288d1b2 0%,#0a1929 100%)}.calendar-day-raindrops-80{background:linear-gradient(135deg,#0288d1cc 0%,#0a1929 100%)}.calendar-day-raindrops-90{background:linear-gradient(135deg,#0288d1e5 0%,#0a1929 100%)}.calendar-day-raindrops-100{background:linear-gradient(135deg,#0288d1fe 0%,#0a1929 100%)}.calendar-day-sixseven-0{background:linear-gradient(135deg,#FF2E6300 0%,#0A0A0F 100%)}.calendar-day-sixseven-10{background:linear-gradient(135deg,#FF2E6319 0%,#0A0A0F 100%)}.calendar-day-sixseven-20{background:linear-gradient(135deg,#FF2E6333 0%,#0A0A0F 100%)}.calendar-day-sixseven-30{background:linear-gradient(135deg,#FF2E634c 0%,#0A0A0F 100%)}.calendar-day-sixseven-40{background:linear-gradient(135deg,#FF2E6366 0%,#0A0A0F 100%)}.calendar-day-sixseven-50{background:linear-gradient(135deg,#FF2E637f 0%,#0A0A0F 100%)}.calendar-day-sixseven-60{background:linear-gradient(135deg,#FF2E6399 0%,#0A0A0F 100%)}.calendar-day-sixseven-70{background:linear-gradient(135deg,#FF2E63b2 0%,#0A0A0F 100%)}.calendar-day-sixseven-80{background:linear-gradient(135deg,#FF2E63cc 0%,#0A0A0F 100%)}.calendar-day-sixseven-90{background:linear-gradient(135deg,#FF2E63e5 0%,#0A0A0F 100%)}.calendar-day-sixseven-100{background:linear-gradient(135deg,#FF2E63fe 0%,#0A0A0F 100%)}.calendar-day-spaceopera-0{background:linear-gradient(135deg,#F7D54A00 0%,#000000 100%)}.calendar-day-spaceopera-10{background:linear-gradient(135deg,#F7D54A19 0%,#000000 100%)}.calendar-day-spaceopera-20{background:linear-gradient(135deg,#F7D54A33 0%,#000000 100%)}.calendar-day-spaceopera-30{background:linear-gradient(135deg,#F7D54A4c 0%,#000000 100%)}.calendar-day-spaceopera-40{background:linear-gradient(135deg,#F7D54A66 0%,#000000 100%)}.calendar-day-spaceopera-50{background:linear-gradient(135deg,#F7D54A7f 0%,#000000 100%)}.calendar-day-spaceopera-60{background:linear-gradient(135deg,#F7D54A99 0%,#000000 100%)}.calendar-day-spaceopera-70{background:linear-gradient(135deg,#F7D54Ab2 0%,#000000 100%)}.calendar-day-spaceopera-80{background:linear-gradient(135deg,#F7D54Acc 0%,#000000 100%)}.calendar-day-spaceopera-90{background:linear-gradient(135deg,#F7D54Ae5 0%,#000000 100%)}.calendar-day-spaceopera-100{background:linear-gradient(135deg,#F7D54Afe 0%,#000000 100%)}.calendar-day-autumn-0{background:linear-gradient(135deg,#FF8C0000 0%,#F4A460 100%)}.calendar-day-autumn-10{background:linear-gradient(135deg,#FF8C0019 0%,#F4A460 100%)}.calendar-day-autumn-20{background:linear-gradient(135deg,#FF8C0033 0%,#F4A460 100%)}.calendar-day-autumn-30{background:linear-gradient(135deg,#FF8C004c 0%,#F4A460 100%)}.calendar-day-autumn-40{background:linear-gradient(135deg,#FF8C0066 0%,#F4A460 100%)}.calendar-day-autumn-50{background:linear-gradient(135deg,#FF8C007f 0%,#F4A460 100%)}.calendar-day-autumn-60{background:linear-gradient(135deg,#FF8C0099 0%,#F4A460 100%)}.calendar-day-autumn-70{background:linear-gradient(135deg,#FF8C00b2 0%,#F4A460 100%)}.calendar-day-autumn-80{background:linear-gradient(135deg,#FF8C00cc 0%,#F4A460 100%)}.calendar-day-autumn-90{background:linear-gradient(135deg,#FF8C00e5 0%,#F4A460 100%)}.calendar-day-autumn-100{background:linear-gradient(135deg,#FF8C00fe 0%,#F4A460 100%)}.calendar-day-backtoschool-0{background:linear-gradient(135deg,#FF000000 0%,#4169E1 100%)}.calendar-day-backtoschool-10{background:linear-gradient(135deg,#FF000019 0%,#4169E1 100%)}.calendar-day-backtoschool-20{background:linear-gradient(135deg,#FF000033 0%,#4169E1 100%)}.calendar-day-backtoschool-30{background:linear-gradient(135deg,#FF00004c 0%,#4169E1 100%)}.calendar-day-backtoschool-40{background:linear-gradient(135deg,#FF000066 0%,#4169E1 100%)}.calendar-day-backtoschool-50{background:linear-gradient(135deg,#FF00007f 0%,#4169E1 100%)}.calendar-day-backtoschool-60{background:linear-gradient(135deg,#FF000099 0%,#4169E1 100%)}.calendar-day-backtoschool-70{background:linear-gradient(135deg,#FF0000b2 0%,#4169E1 100%)}.calendar-day-backtoschool-80{background:linear-gradient(135deg,#FF0000cc 0%,#4169E1 100%)}.calendar-day-backtoschool-90{background:linear-gradient(135deg,#FF0000e5 0%,#4169E1 100%)}.calendar-day-backtoschool-100{background:linear-gradient(135deg,#FF0000fe 0%,#4169E1 100%)}.calendar-day-beach-0{background:linear-gradient(135deg,#00CED100 0%,#87CEEB 100%)}.calendar-day-beach-10{background:linear-gradient(135deg,#00CED119 0%,#87CEEB 100%)}.calendar-day-beach-20{background:linear-gradient(135deg,#00CED133 0%,#87CEEB 100%)}.calendar-day-beach-30{background:linear-gradient(135deg,#00CED14c 0%,#87CEEB 100%)}.calendar-day-beach-40{background:linear-gradient(135deg,#00CED166 0%,#87CEEB 100%)}.calendar-day-beach-50{background:linear-gradient(135deg,#00CED17f 0%,#87CEEB 100%)}.calendar-day-beach-60{background:linear-gradient(135deg,#00CED199 0%,#87CEEB 100%)}.calendar-day-beach-70{background:linear-gradient(135deg,#00CED1b2 0%,#87CEEB 100%)}.calendar-day-beach-80{background:linear-gradient(135deg,#00CED1cc 0%,#87CEEB 100%)}.calendar-day-beach-90{background:linear-gradient(135deg,#00CED1e5 0%,#87CEEB 100%)}.calendar-day-beach-100{background:linear-gradient(135deg,#00CED1fe 0%,#87CEEB 100%)}.calendar-day-carnival-0{background:linear-gradient(135deg,#FF149300 0%,#9370DB 100%)}.calendar-day-carnival-10{background:linear-gradient(135deg,#FF149319 0%,#9370DB 100%)}.calendar-day-carnival-20{background:linear-gradient(135deg,#FF149333 0%,#9370DB 100%)}.calendar-day-carnival-30{background:linear-gradient(135deg,#FF14934c 0%,#9370DB 100%)}.calendar-day-carnival-40{background:linear-gradient(135deg,#FF149366 0%,#9370DB 100%)}.calendar-day-carnival-50{background:linear-gradient(135deg,#FF14937f 0%,#9370DB 100%)}.calendar-day-carnival-60{background:linear-gradient(135deg,#FF149399 0%,#9370DB 100%)}.calendar-day-carnival-70{background:linear-gradient(135deg,#FF1493b2 0%,#9370DB 100%)}.calendar-day-carnival-80{background:linear-gradient(135deg,#FF1493cc 0%,#9370DB 100%)}.calendar-day-carnival-90{background:linear-gradient(135deg,#FF1493e5 0%,#9370DB 100%)}.calendar-day-carnival-100{background:linear-gradient(135deg,#FF1493fe 0%,#9370DB 100%)}.calendar-day-champagne-0{background:linear-gradient(135deg,#F7E7CE00 0%,#1C1C1C 100%)}.calendar-day-champagne-10{background:linear-gradient(135deg,#F7E7CE19 0%,#1C1C1C 100%)}.calendar-day-champagne-20{background:linear-gradient(135deg,#F7E7CE33 0%,#1C1C1C 100%)}.calendar-day-champagne-30{background:linear-gradient(135deg,#F7E7CE4c 0%,#1C1C1C 100%)}.calendar-day-champagne-40{background:linear-gradient(135deg,#F7E7CE66 0%,#1C1C1C 100%)}.calendar-day-champagne-50{background:linear-gradient(135deg,#F7E7CE7f 0%,#1C1C1C 100%)}.calendar-day-champagne-60{background:linear-gradient(135deg,#F7E7CE99 0%,#1C1C1C 100%)}.calendar-day-champagne-70{background:linear-gradient(135deg,#F7E7CEb2 0%,#1C1C1C 100%)}.calendar-day-champagne-80{background:linear-gradient(135deg,#F7E7CEcc 0%,#1C1C1C 100%)}.calendar-day-champagne-90{background:linear-gradient(135deg,#F7E7CEe5 0%,#1C1C1C 100%)}.calendar-day-champagne-100{background:linear-gradient(135deg,#F7E7CEfe 0%,#1C1C1C 100%)}.calendar-day-christmas-0{background:linear-gradient(135deg,#FF000000 0%,#F8F8FF 100%)}.calendar-day-christmas-10{background:linear-gradient(135deg,#FF000019 0%,#F8F8FF 100%)}.calendar-day-christmas-20{background:linear-gradient(135deg,#FF000033 0%,#F8F8FF 100%)}.calendar-day-christmas-30{background:linear-gradient(135deg,#FF00004c 0%,#F8F8FF 100%)}.calendar-day-christmas-40{background:linear-gradient(135deg,#FF000066 0%,#F8F8FF 100%)}.calendar-day-christmas-50{background:linear-gradient(135deg,#FF00007f 0%,#F8F8FF 100%)}.calendar-day-christmas-60{background:linear-gradient(135deg,#FF000099 0%,#F8F8FF 100%)}.calendar-day-christmas-70{background:linear-gradient(135deg,#FF0000b2 0%,#F8F8FF 100%)}.calendar-day-christmas-80{background:linear-gradient(135deg,#FF0000cc 0%,#F8F8FF 100%)}.calendar-day-christmas-90{background:linear-gradient(135deg,#FF0000e5 0%,#F8F8FF 100%)}.calendar-day-christmas-100{background:linear-gradient(135deg,#FF0000fe 0%,#F8F8FF 100%)}.calendar-day-cincodemayo-0{background:linear-gradient(135deg,#FF000000 0%,#FFD700 100%)}.calendar-day-cincodemayo-10{background:linear-gradient(135deg,#FF000019 0%,#FFD700 100%)}.calendar-day-cincodemayo-20{background:linear-gradient(135deg,#FF000033 0%,#FFD700 100%)}.calendar-day-cincodemayo-30{background:linear-gradient(135deg,#FF00004c 0%,#FFD700 100%)}.calendar-day-cincodemayo-40{background:linear-gradient(135deg,#FF000066 0%,#FFD700 100%)}.calendar-day-cincodemayo-50{background:linear-gradient(135deg,#FF00007f 0%,#FFD700 100%)}.calendar-day-cincodemayo-60{background:linear-gradient(135deg,#FF000099 0%,#FFD700 100%)}.calendar-day-cincodemayo-70{background:linear-gradient(135deg,#FF0000b2 0%,#FFD700 100%)}.calendar-day-cincodemayo-80{background:linear-gradient(135deg,#FF0000cc 0%,#FFD700 100%)}.calendar-day-cincodemayo-90{background:linear-gradient(135deg,#FF0000e5 0%,#FFD700 100%)}.calendar-day-cincodemayo-100{background:linear-gradient(135deg,#FF0000fe 0%,#FFD700 100%)}.calendar-day-cornucopia-0{background:linear-gradient(135deg,#DAA52000 0%,#F0E68C 100%)}.calendar-day-cornucopia-10{background:linear-gradient(135deg,#DAA52019 0%,#F0E68C 100%)}.calendar-day-cornucopia-20{background:linear-gradient(135deg,#DAA52033 0%,#F0E68C 100%)}.calendar-day-cornucopia-30{background:linear-gradient(135deg,#DAA5204c 0%,#F0E68C 100%)}.calendar-day-cornucopia-40{background:linear-gradient(135deg,#DAA52066 0%,#F0E68C 100%)}.calendar-day-cornucopia-50{background:linear-gradient(135deg,#DAA5207f 0%,#F0E68C 100%)}.calendar-day-cornucopia-60{background:linear-gradient(135deg,#DAA52099 0%,#F0E68C 100%)}.calendar-day-cornucopia-70{background:linear-gradient(135deg,#DAA520b2 0%,#F0E68C 100%)}.calendar-day-cornucopia-80{background:linear-gradient(135deg,#DAA520cc 0%,#F0E68C 100%)}.calendar-day-cornucopia-90{background:linear-gradient(135deg,#DAA520e5 0%,#F0E68C 100%)}.calendar-day-cornucopia-100{background:linear-gradient(135deg,#DAA520fe 0%,#F0E68C 100%)}.calendar-day-diadelosmuertos-0{background:linear-gradient(135deg,#FF149300 0%,#000000 100%)}.calendar-day-diadelosmuertos-10{background:linear-gradient(135deg,#FF149319 0%,#000000 100%)}.calendar-day-diadelosmuertos-20{background:linear-gradient(135deg,#FF149333 0%,#000000 100%)}.calendar-day-diadelosmuertos-30{background:linear-gradient(135deg,#FF14934c 0%,#000000 100%)}.calendar-day-diadelosmuertos-40{background:linear-gradient(135deg,#FF149366 0%,#000000 100%)}.calendar-day-diadelosmuertos-50{background:linear-gradient(135deg,#FF14937f 0%,#000000 100%)}.calendar-day-diadelosmuertos-60{background:linear-gradient(135deg,#FF149399 0%,#000000 100%)}.calendar-day-diadelosmuertos-70{background:linear-gradient(135deg,#FF1493b2 0%,#000000 100%)}.calendar-day-diadelosmuertos-80{background:linear-gradient(135deg,#FF1493cc 0%,#000000 100%)}.calendar-day-diadelosmuertos-90{background:linear-gradient(135deg,#FF1493e5 0%,#000000 100%)}.calendar-day-diadelosmuertos-100{background:linear-gradient(135deg,#FF1493fe 0%,#000000 100%)}.calendar-day-diwali-0{background:linear-gradient(135deg,#FFD70000 0%,#4B0082 100%)}.calendar-day-diwali-10{background:linear-gradient(135deg,#FFD70019 0%,#4B0082 100%)}.calendar-day-diwali-20{background:linear-gradient(135deg,#FFD70033 0%,#4B0082 100%)}.calendar-day-diwali-30{background:linear-gradient(135deg,#FFD7004c 0%,#4B0082 100%)}.calendar-day-diwali-40{background:linear-gradient(135deg,#FFD70066 0%,#4B0082 100%)}.calendar-day-diwali-50{background:linear-gradient(135deg,#FFD7007f 0%,#4B0082 100%)}.calendar-day-diwali-60{background:linear-gradient(135deg,#FFD70099 0%,#4B0082 100%)}.calendar-day-diwali-70{background:linear-gradient(135deg,#FFD700b2 0%,#4B0082 100%)}.calendar-day-diwali-80{background:linear-gradient(135deg,#FFD700cc 0%,#4B0082 100%)}.calendar-day-diwali-90{background:linear-gradient(135deg,#FFD700e5 0%,#4B0082 100%)}.calendar-day-diwali-100{background:linear-gradient(135deg,#FFD700fe 0%,#4B0082 100%)}.calendar-day-earthday-0{background:linear-gradient(135deg,#00A55000 0%,#000033 100%)}.calendar-day-earthday-10{background:linear-gradient(135deg,#00A55019 0%,#000033 100%)}.calendar-day-earthday-20{background:linear-gradient(135deg,#00A55033 0%,#000033 100%)}.calendar-day-earthday-30{background:linear-gradient(135deg,#00A5504c 0%,#000033 100%)}.calendar-day-earthday-40{background:linear-gradient(135deg,#00A55066 0%,#000033 100%)}.calendar-day-earthday-50{background:linear-gradient(135deg,#00A5507f 0%,#000033 100%)}.calendar-day-earthday-60{background:linear-gradient(135deg,#00A55099 0%,#000033 100%)}.calendar-day-earthday-70{background:linear-gradient(135deg,#00A550b2 0%,#000033 100%)}.calendar-day-earthday-80{background:linear-gradient(135deg,#00A550cc 0%,#000033 100%)}.calendar-day-earthday-90{background:linear-gradient(135deg,#00A550e5 0%,#000033 100%)}.calendar-day-earthday-100{background:linear-gradient(135deg,#00A550fe 0%,#000033 100%)}.calendar-day-easter-0{background:linear-gradient(135deg,#FF69B400 0%,#98FB98 100%)}.calendar-day-easter-10{background:linear-gradient(135deg,#FF69B419 0%,#98FB98 100%)}.calendar-day-easter-20{background:linear-gradient(135deg,#FF69B433 0%,#98FB98 100%)}.calendar-day-easter-30{background:linear-gradient(135deg,#FF69B44c 0%,#98FB98 100%)}.calendar-day-easter-40{background:linear-gradient(135deg,#FF69B466 0%,#98FB98 100%)}.calendar-day-easter-50{background:linear-gradient(135deg,#FF69B47f 0%,#98FB98 100%)}.calendar-day-easter-60{background:linear-gradient(135deg,#FF69B499 0%,#98FB98 100%)}.calendar-day-easter-70{background:linear-gradient(135deg,#FF69B4b2 0%,#98FB98 100%)}.calendar-day-easter-80{background:linear-gradient(135deg,#FF69B4cc 0%,#98FB98 100%)}.calendar-day-easter-90{background:linear-gradient(135deg,#FF69B4e5 0%,#98FB98 100%)}.calendar-day-easter-100{background:linear-gradient(135deg,#FF69B4fe 0%,#98FB98 100%)}.calendar-day-ghost-0{background:linear-gradient(135deg,#FFFFFF00 0%,#1C1C1C 100%)}.calendar-day-ghost-10{background:linear-gradient(135deg,#FFFFFF19 0%,#1C1C1C 100%)}.calendar-day-ghost-20{background:linear-gradient(135deg,#FFFFFF33 0%,#1C1C1C 100%)}.calendar-day-ghost-30{background:linear-gradient(135deg,#FFFFFF4c 0%,#1C1C1C 100%)}.calendar-day-ghost-40{background:linear-gradient(135deg,#FFFFFF66 0%,#1C1C1C 100%)}.calendar-day-ghost-50{background:linear-gradient(135deg,#FFFFFF7f 0%,#1C1C1C 100%)}.calendar-day-ghost-60{background:linear-gradient(135deg,#FFFFFF99 0%,#1C1C1C 100%)}.calendar-day-ghost-70{background:linear-gradient(135deg,#FFFFFFb2 0%,#1C1C1C 100%)}.calendar-day-ghost-80{background:linear-gradient(135deg,#FFFFFFcc 0%,#1C1C1C 100%)}.calendar-day-ghost-90{background:linear-gradient(135deg,#FFFFFFe5 0%,#1C1C1C 100%)}.calendar-day-ghost-100{background:linear-gradient(135deg,#FFFFFFfe 0%,#1C1C1C 100%)}.calendar-day-halloween-0{background:linear-gradient(135deg,#FF7F0000 0%,#000000 100%)}.calendar-day-halloween-10{background:linear-gradient(135deg,#FF7F0019 0%,#000000 100%)}.calendar-day-halloween-20{background:linear-gradient(135deg,#FF7F0033 0%,#000000 100%)}.calendar-day-halloween-30{background:linear-gradient(135deg,#FF7F004c 0%,#000000 100%)}.calendar-day-halloween-40{background:linear-gradient(135deg,#FF7F0066 0%,#000000 100%)}.calendar-day-halloween-50{background:linear-gradient(135deg,#FF7F007f 0%,#000000 100%)}.calendar-day-halloween-60{background:linear-gradient(135deg,#FF7F0099 0%,#000000 100%)}.calendar-day-halloween-70{background:linear-gradient(135deg,#FF7F00b2 0%,#000000 100%)}.calendar-day-halloween-80{background:linear-gradient(135deg,#FF7F00cc 0%,#000000 100%)}.calendar-day-halloween-90{background:linear-gradient(135deg,#FF7F00e5 0%,#000000 100%)}.calendar-day-halloween-100{background:linear-gradient(135deg,#FF7F00fe 0%,#000000 100%)}.calendar-day-hanukkah-0{background:linear-gradient(135deg,#0047AB00 0%,#FFFFFF 100%)}.calendar-day-hanukkah-10{background:linear-gradient(135deg,#0047AB19 0%,#FFFFFF 100%)}.calendar-day-hanukkah-20{background:linear-gradient(135deg,#0047AB33 0%,#FFFFFF 100%)}.calendar-day-hanukkah-30{background:linear-gradient(135deg,#0047AB4c 0%,#FFFFFF 100%)}.calendar-day-hanukkah-40{background:linear-gradient(135deg,#0047AB66 0%,#FFFFFF 100%)}.calendar-day-hanukkah-50{background:linear-gradient(135deg,#0047AB7f 0%,#FFFFFF 100%)}.calendar-day-hanukkah-60{background:linear-gradient(135deg,#0047AB99 0%,#FFFFFF 100%)}.calendar-day-hanukkah-70{background:linear-gradient(135deg,#0047ABb2 0%,#FFFFFF 100%)}.calendar-day-hanukkah-80{background:linear-gradient(135deg,#0047ABcc 0%,#FFFFFF 100%)}.calendar-day-hanukkah-90{background:linear-gradient(135deg,#0047ABe5 0%,#FFFFFF 100%)}.calendar-day-hanukkah-100{background:linear-gradient(135deg,#0047ABfe 0%,#FFFFFF 100%)}.calendar-day-independence-0{background:linear-gradient(135deg,#FF000000 0%,#FFFFFF 100%)}.calendar-day-independence-10{background:linear-gradient(135deg,#FF000019 0%,#FFFFFF 100%)}.calendar-day-independence-20{background:linear-gradient(135deg,#FF000033 0%,#FFFFFF 100%)}.calendar-day-independence-30{background:linear-gradient(135deg,#FF00004c 0%,#FFFFFF 100%)}.calendar-day-independence-40{background:linear-gradient(135deg,#FF000066 0%,#FFFFFF 100%)}.calendar-day-independence-50{background:linear-gradient(135deg,#FF00007f 0%,#FFFFFF 100%)}.calendar-day-independence-60{background:linear-gradient(135deg,#FF000099 0%,#FFFFFF 100%)}.calendar-day-independence-70{background:linear-gradient(135deg,#FF0000b2 0%,#FFFFFF 100%)}.calendar-day-independence-80{background:linear-gradient(135deg,#FF0000cc 0%,#FFFFFF 100%)}.calendar-day-independence-90{background:linear-gradient(135deg,#FF0000e5 0%,#FFFFFF 100%)}.calendar-day-independence-100{background:linear-gradient(135deg,#FF0000fe 0%,#FFFFFF 100%)}.calendar-day-lunarnewyear-0{background:linear-gradient(135deg,#FF000000 0%,#8B0000 100%)}.calendar-day-lunarnewyear-10{background:linear-gradient(135deg,#FF000019 0%,#8B0000 100%)}.calendar-day-lunarnewyear-20{background:linear-gradient(135deg,#FF000033 0%,#8B0000 100%)}.calendar-day-lunarnewyear-30{background:linear-gradient(135deg,#FF00004c 0%,#8B0000 100%)}.calendar-day-lunarnewyear-40{background:linear-gradient(135deg,#FF000066 0%,#8B0000 100%)}.calendar-day-lunarnewyear-50{background:linear-gradient(135deg,#FF00007f 0%,#8B0000 100%)}.calendar-day-lunarnewyear-60{background:linear-gradient(135deg,#FF000099 0%,#8B0000 100%)}.calendar-day-lunarnewyear-70{background:linear-gradient(135deg,#FF0000b2 0%,#8B0000 100%)}.calendar-day-lunarnewyear-80{background:linear-gradient(135deg,#FF0000cc 0%,#8B0000 100%)}.calendar-day-lunarnewyear-90{background:linear-gradient(135deg,#FF0000e5 0%,#8B0000 100%)}.calendar-day-lunarnewyear-100{background:linear-gradient(135deg,#FF0000fe 0%,#8B0000 100%)}.calendar-day-mothersday-0{background:linear-gradient(135deg,#FFB6C100 0%,#FFF5EE 100%)}.calendar-day-mothersday-10{background:linear-gradient(135deg,#FFB6C119 0%,#FFF5EE 100%)}.calendar-day-mothersday-20{background:linear-gradient(135deg,#FFB6C133 0%,#FFF5EE 100%)}.calendar-day-mothersday-30{background:linear-gradient(135deg,#FFB6C14c 0%,#FFF5EE 100%)}.calendar-day-mothersday-40{background:linear-gradient(135deg,#FFB6C166 0%,#FFF5EE 100%)}.calendar-day-mothersday-50{background:linear-gradient(135deg,#FFB6C17f 0%,#FFF5EE 100%)}.calendar-day-mothersday-60{background:linear-gradient(135deg,#FFB6C199 0%,#FFF5EE 100%)}.calendar-day-mothersday-70{background:linear-gradient(135deg,#FFB6C1b2 0%,#FFF5EE 100%)}.calendar-day-mothersday-80{background:linear-gradient(135deg,#FFB6C1cc 0%,#FFF5EE 100%)}.calendar-day-mothersday-90{background:linear-gradient(135deg,#FFB6C1e5 0%,#FFF5EE 100%)}.calendar-day-mothersday-100{background:linear-gradient(135deg,#FFB6C1fe 0%,#FFF5EE 100%)}.calendar-day-newyear-0{background:linear-gradient(135deg,#FFD70000 0%,#0A0A1A 100%)}.calendar-day-newyear-10{background:linear-gradient(135deg,#FFD70019 0%,#0A0A1A 100%)}.calendar-day-newyear-20{background:linear-gradient(135deg,#FFD70033 0%,#0A0A1A 100%)}.calendar-day-newyear-30{background:linear-gradient(135deg,#FFD7004c 0%,#0A0A1A 100%)}.calendar-day-newyear-40{background:linear-gradient(135deg,#FFD70066 0%,#0A0A1A 100%)}.calendar-day-newyear-50{background:linear-gradient(135deg,#FFD7007f 0%,#0A0A1A 100%)}.calendar-day-newyear-60{background:linear-gradient(135deg,#FFD70099 0%,#0A0A1A 100%)}.calendar-day-newyear-70{background:linear-gradient(135deg,#FFD700b2 0%,#0A0A1A 100%)}.calendar-day-newyear-80{background:linear-gradient(135deg,#FFD700cc 0%,#0A0A1A 100%)}.calendar-day-newyear-90{background:linear-gradient(135deg,#FFD700e5 0%,#0A0A1A 100%)}.calendar-day-newyear-100{background:linear-gradient(135deg,#FFD700fe 0%,#0A0A1A 100%)}.calendar-day-newyearseve-0{background:linear-gradient(135deg,#FFD70000 0%,#C0C0C0 100%)}.calendar-day-newyearseve-10{background:linear-gradient(135deg,#FFD70019 0%,#C0C0C0 100%)}.calendar-day-newyearseve-20{background:linear-gradient(135deg,#FFD70033 0%,#C0C0C0 100%)}.calendar-day-newyearseve-30{background:linear-gradient(135deg,#FFD7004c 0%,#C0C0C0 100%)}.calendar-day-newyearseve-40{background:linear-gradient(135deg,#FFD70066 0%,#C0C0C0 100%)}.calendar-day-newyearseve-50{background:linear-gradient(135deg,#FFD7007f 0%,#C0C0C0 100%)}.calendar-day-newyearseve-60{background:linear-gradient(135deg,#FFD70099 0%,#C0C0C0 100%)}.calendar-day-newyearseve-70{background:linear-gradient(135deg,#FFD700b2 0%,#C0C0C0 100%)}.calendar-day-newyearseve-80{background:linear-gradient(135deg,#FFD700cc 0%,#C0C0C0 100%)}.calendar-day-newyearseve-90{background:linear-gradient(135deg,#FFD700e5 0%,#C0C0C0 100%)}.calendar-day-newyearseve-100{background:linear-gradient(135deg,#FFD700fe 0%,#C0C0C0 100%)}.calendar-day-oktoberfest-0{background:linear-gradient(135deg,#8B451300 0%,#0047AB 100%)}.calendar-day-oktoberfest-10{background:linear-gradient(135deg,#8B451319 0%,#0047AB 100%)}.calendar-day-oktoberfest-20{background:linear-gradient(135deg,#8B451333 0%,#0047AB 100%)}.calendar-day-oktoberfest-30{background:linear-gradient(135deg,#8B45134c 0%,#0047AB 100%)}.calendar-day-oktoberfest-40{background:linear-gradient(135deg,#8B451366 0%,#0047AB 100%)}.calendar-day-oktoberfest-50{background:linear-gradient(135deg,#8B45137f 0%,#0047AB 100%)}.calendar-day-oktoberfest-60{background:linear-gradient(135deg,#8B451399 0%,#0047AB 100%)}.calendar-day-oktoberfest-70{background:linear-gradient(135deg,#8B4513b2 0%,#0047AB 100%)}.calendar-day-oktoberfest-80{background:linear-gradient(135deg,#8B4513cc 0%,#0047AB 100%)}.calendar-day-oktoberfest-90{background:linear-gradient(135deg,#8B4513e5 0%,#0047AB 100%)}.calendar-day-oktoberfest-100{background:linear-gradient(135deg,#8B4513fe 0%,#0047AB 100%)}.calendar-day-pride-0{background:linear-gradient(135deg,#FF000000 0%,#000000 100%)}.calendar-day-pride-10{background:linear-gradient(135deg,#FF000019 0%,#000000 100%)}.calendar-day-pride-20{background:linear-gradient(135deg,#FF000033 0%,#000000 100%)}.calendar-day-pride-30{background:linear-gradient(135deg,#FF00004c 0%,#000000 100%)}.calendar-day-pride-40{background:linear-gradient(135deg,#FF000066 0%,#000000 100%)}.calendar-day-pride-50{background:linear-gradient(135deg,#FF00007f 0%,#000000 100%)}.calendar-day-pride-60{background:linear-gradient(135deg,#FF000099 0%,#000000 100%)}.calendar-day-pride-70{background:linear-gradient(135deg,#FF0000b2 0%,#000000 100%)}.calendar-day-pride-80{background:linear-gradient(135deg,#FF0000cc 0%,#000000 100%)}.calendar-day-pride-90{background:linear-gradient(135deg,#FF0000e5 0%,#000000 100%)}.calendar-day-pride-100{background:linear-gradient(135deg,#FF0000fe 0%,#000000 100%)}.calendar-day-shamrock-0{background:linear-gradient(135deg,#00FF0000 0%,#0D3B0D 100%)}.calendar-day-shamrock-10{background:linear-gradient(135deg,#00FF0019 0%,#0D3B0D 100%)}.calendar-day-shamrock-20{background:linear-gradient(135deg,#00FF0033 0%,#0D3B0D 100%)}.calendar-day-shamrock-30{background:linear-gradient(135deg,#00FF004c 0%,#0D3B0D 100%)}.calendar-day-shamrock-40{background:linear-gradient(135deg,#00FF0066 0%,#0D3B0D 100%)}.calendar-day-shamrock-50{background:linear-gradient(135deg,#00FF007f 0%,#0D3B0D 100%)}.calendar-day-shamrock-60{background:linear-gradient(135deg,#00FF0099 0%,#0D3B0D 100%)}.calendar-day-shamrock-70{background:linear-gradient(135deg,#00FF00b2 0%,#0D3B0D 100%)}.calendar-day-shamrock-80{background:linear-gradient(135deg,#00FF00cc 0%,#0D3B0D 100%)}.calendar-day-shamrock-90{background:linear-gradient(135deg,#00FF00e5 0%,#0D3B0D 100%)}.calendar-day-shamrock-100{background:linear-gradient(135deg,#00FF00fe 0%,#0D3B0D 100%)}.calendar-day-spring-0{background:linear-gradient(135deg,#FF69B400 0%,#F0F8FF 100%)}.calendar-day-spring-10{background:linear-gradient(135deg,#FF69B419 0%,#F0F8FF 100%)}.calendar-day-spring-20{background:linear-gradient(135deg,#FF69B433 0%,#F0F8FF 100%)}.calendar-day-spring-30{background:linear-gradient(135deg,#FF69B44c 0%,#F0F8FF 100%)}.calendar-day-spring-40{background:linear-gradient(135deg,#FF69B466 0%,#F0F8FF 100%)}.calendar-day-spring-50{background:linear-gradient(135deg,#FF69B47f 0%,#F0F8FF 100%)}.calendar-day-spring-60{background:linear-gradient(135deg,#FF69B499 0%,#F0F8FF 100%)}.calendar-day-spring-70{background:linear-gradient(135deg,#FF69B4b2 0%,#F0F8FF 100%)}.calendar-day-spring-80{background:linear-gradient(135deg,#FF69B4cc 0%,#F0F8FF 100%)}.calendar-day-spring-90{background:linear-gradient(135deg,#FF69B4e5 0%,#F0F8FF 100%)}.calendar-day-spring-100{background:linear-gradient(135deg,#FF69B4fe 0%,#F0F8FF 100%)}.calendar-day-summersolstice-0{background:linear-gradient(135deg,#FFD70000 0%,#87CEEB 100%)}.calendar-day-summersolstice-10{background:linear-gradient(135deg,#FFD70019 0%,#87CEEB 100%)}.calendar-day-summersolstice-20{background:linear-gradient(135deg,#FFD70033 0%,#87CEEB 100%)}.calendar-day-summersolstice-30{background:linear-gradient(135deg,#FFD7004c 0%,#87CEEB 100%)}.calendar-day-summersolstice-40{background:linear-gradient(135deg,#FFD70066 0%,#87CEEB 100%)}.calendar-day-summersolstice-50{background:linear-gradient(135deg,#FFD7007f 0%,#87CEEB 100%)}.calendar-day-summersolstice-60{background:linear-gradient(135deg,#FFD70099 0%,#87CEEB 100%)}.calendar-day-summersolstice-70{background:linear-gradient(135deg,#FFD700b2 0%,#87CEEB 100%)}.calendar-day-summersolstice-80{background:linear-gradient(135deg,#FFD700cc 0%,#87CEEB 100%)}.calendar-day-summersolstice-90{background:linear-gradient(135deg,#FFD700e5 0%,#87CEEB 100%)}.calendar-day-summersolstice-100{background:linear-gradient(135deg,#FFD700fe 0%,#87CEEB 100%)}.calendar-day-thanksgiving-0{background:linear-gradient(135deg,#8B451300 0%,#F4A460 100%)}.calendar-day-thanksgiving-10{background:linear-gradient(135deg,#8B451319 0%,#F4A460 100%)}.calendar-day-thanksgiving-20{background:linear-gradient(135deg,#8B451333 0%,#F4A460 100%)}.calendar-day-thanksgiving-30{background:linear-gradient(135deg,#8B45134c 0%,#F4A460 100%)}.calendar-day-thanksgiving-40{background:linear-gradient(135deg,#8B451366 0%,#F4A460 100%)}.calendar-day-thanksgiving-50{background:linear-gradient(135deg,#8B45137f 0%,#F4A460 100%)}.calendar-day-thanksgiving-60{background:linear-gradient(135deg,#8B451399 0%,#F4A460 100%)}.calendar-day-thanksgiving-70{background:linear-gradient(135deg,#8B4513b2 0%,#F4A460 100%)}.calendar-day-thanksgiving-80{background:linear-gradient(135deg,#8B4513cc 0%,#F4A460 100%)}.calendar-day-thanksgiving-90{background:linear-gradient(135deg,#8B4513e5 0%,#F4A460 100%)}.calendar-day-thanksgiving-100{background:linear-gradient(135deg,#8B4513fe 0%,#F4A460 100%)}.calendar-day-valentine-0{background:linear-gradient(135deg,#FF174400 0%,#FFF0F5 100%)}.calendar-day-valentine-10{background:linear-gradient(135deg,#FF174419 0%,#FFF0F5 100%)}.calendar-day-valentine-20{background:linear-gradient(135deg,#FF174433 0%,#FFF0F5 100%)}.calendar-day-valentine-30{background:linear-gradient(135deg,#FF17444c 0%,#FFF0F5 100%)}.calendar-day-valentine-40{background:linear-gradient(135deg,#FF174466 0%,#FFF0F5 100%)}.calendar-day-valentine-50{background:linear-gradient(135deg,#FF17447f 0%,#FFF0F5 100%)}.calendar-day-valentine-60{background:linear-gradient(135deg,#FF174499 0%,#FFF0F5 100%)}.calendar-day-valentine-70{background:linear-gradient(135deg,#FF1744b2 0%,#FFF0F5 100%)}.calendar-day-valentine-80{background:linear-gradient(135deg,#FF1744cc 0%,#FFF0F5 100%)}.calendar-day-valentine-90{background:linear-gradient(135deg,#FF1744e5 0%,#FFF0F5 100%)}.calendar-day-valentine-100{background:linear-gradient(135deg,#FF1744fe 0%,#FFF0F5 100%)}.calendar-day-winter-0{background:linear-gradient(135deg,#E0F7FF00 0%,#1A2B3C 100%)}.calendar-day-winter-10{background:linear-gradient(135deg,#E0F7FF19 0%,#1A2B3C 100%)}.calendar-day-winter-20{background:linear-gradient(135deg,#E0F7FF33 0%,#1A2B3C 100%)}.calendar-day-winter-30{background:linear-gradient(135deg,#E0F7FF4c 0%,#1A2B3C 100%)}.calendar-day-winter-40{background:linear-gradient(135deg,#E0F7FF66 0%,#1A2B3C 100%)}.calendar-day-winter-50{background:linear-gradient(135deg,#E0F7FF7f 0%,#1A2B3C 100%)}.calendar-day-winter-60{background:linear-gradient(135deg,#E0F7FF99 0%,#1A2B3C 100%)}.calendar-day-winter-70{background:linear-gradient(135deg,#E0F7FFb2 0%,#1A2B3C 100%)}.calendar-day-winter-80{background:linear-gradient(135deg,#E0F7FFcc 0%,#1A2B3C 100%)}.calendar-day-winter-90{background:linear-gradient(135deg,#E0F7FFe5 0%,#1A2B3C 100%)}.calendar-day-winter-100{background:linear-gradient(135deg,#E0F7FFfe 0%,#1A2B3C 100%)}.calendar-day-themed{transition:background .3s ease}.calendar-day-themed:hover{filter:brightness(1.1)}.activity-trend-chart{width:100%}.trend-chart-empty{text-align:center;padding:3rem;color:var(--color-onSurface);opacity:.5}.chart-container{display:flex;gap:1rem;margin-bottom:1.5rem}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding:1rem 0;min-width:40px}.y-axis-label{font-size:.75rem;color:var(--color-onSurface);opacity:.6;text-align:right}.chart-area{flex:1;display:flex;align-items:flex-end;gap:2px;height:250px;border-bottom:2px solid var(--color-divider);border-left:2px solid var(--color-divider);padding:1rem .5rem 0;overflow-x:auto;overflow-y:hidden}.chart-bar-container{flex:1;min-width:20px;display:flex;flex-direction:column;align-items:center;gap:.25rem}.chart-bar-cluster{width:100%;display:flex;flex-direction:row;align-items:flex-end;justify-content:center;gap:2px;min-height:2px}.chart-bar{flex:1;min-width:3px;max-width:8px;min-height:2px;transition:opacity .2s;cursor:pointer;border-radius:2px 2px 0 0}.chart-bar:hover{opacity:.8}.chart-bar-label{font-size:.7rem;color:var(--color-onSurface);opacity:.6;transform:rotate(-45deg);transform-origin:center;margin-top:1rem}.chart-legend{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-bottom:1.5rem;padding:1rem 0;border-bottom:1px solid var(--color-divider)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--color-onSurface)}.legend-color{width:20px;height:20px;border-radius:4px}.chart-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.summary-item{text-align:center;padding:1rem;background:var(--color-background);border-radius:8px}.summary-label{font-size:.85rem;color:var(--color-onSurface);opacity:.7;margin-bottom:.25rem}.summary-value{font-size:1.3rem;font-weight:700;color:var(--color-primary)}@media (max-width: 768px){.chart-area{height:200px}.chart-bar-label{font-size:.6rem}.y-axis-label{font-size:.7rem}.legend-item{font-size:.8rem}.legend-color{width:16px;height:16px}.summary-item{padding:.75rem}.summary-label{font-size:.75rem}.summary-value{font-size:1.1rem}}.home-page{min-height:100vh;background:var(--color-background)}.home-container{max-width:1200px;margin:0 auto}.home-header{text-align:center;margin-top:1rem}.home-title{font-size:2.5rem;font-weight:700;color:var(--color-onBackground);margin-bottom:.5rem}.home-subtitle{font-size:1.1rem;color:var(--color-onBackground);opacity:.7}.home-warning-banner{background:var(--color-error);color:var(--color-onError);padding:1rem;margin-bottom:2rem;display:flex;align-items:flex-start;gap:1rem;border-left:4px solid var(--color-onError)}.warning-icon{font-size:1.5rem;flex-shrink:0}.warning-content{flex:1}.warning-content h3{margin:0 0 .5rem;font-size:1rem;font-weight:600}.warning-content p{margin:0 0 .75rem;opacity:.9;font-size:.9rem}.warning-action-button{background:var(--color-onError);color:var(--color-error);border:none;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .2s}.warning-action-button:hover{opacity:.9}.streak-stats{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2rem;padding:1rem 0;border-bottom:2px solid var(--color-divider)}.stat-card{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.stat-icon{font-size:2rem;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:.25rem}.stat-label{font-size:.8rem;color:var(--color-onBackground);opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.today-progress-card.achieved .stat-value{color:var(--color-primary)}.today-progress-card.achieved .stat-label{color:var(--color-onBackground);opacity:.8}.chartboard-card{cursor:pointer;transition:opacity .2s;border-left:2px solid var(--color-primary);padding-left:.75rem}.chartboard-card:hover{opacity:.8}.chartboard-card .stat-label{color:var(--color-primary);opacity:1;font-weight:600;white-space:normal}.month-navigation{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:0 1rem}.month-title{font-size:1.5rem;font-weight:600;color:var(--color-onBackground)}.month-nav-button{background:transparent;border:1px solid var(--color-divider);color:var(--color-onBackground);padding:.5rem 1rem;font-weight:600;cursor:pointer;transition:all .2s}.month-nav-button:hover:not(:disabled){background:var(--color-divider);border-color:var(--color-primary);color:var(--color-primary)}.month-nav-button:disabled{opacity:.3;cursor:not-allowed}.calendar-section,.chart-section{background:var(--color-surface);padding:2rem;margin-bottom:2rem;border-top:2px solid var(--color-divider)}.section-title{font-size:1.5rem;font-weight:600;color:var(--color-onSurface);margin-bottom:1.5rem}.streak-info-section{background:var(--color-surface);padding:2rem;border-top:2px solid var(--color-divider)}.streak-info-section h3{font-size:1.3rem;font-weight:600;color:var(--color-onSurface);margin-bottom:1rem}.streak-info-section ul{list-style:none;padding:0;margin:0}.streak-info-section li{padding:.75rem 0 .75rem 2rem;position:relative;color:var(--color-onSurface);line-height:1.5}.streak-info-section li:before{content:"✓";position:absolute;left:0;color:var(--color-primary);font-weight:700;font-size:1.2rem}.loading-spinner{text-align:center;padding:3rem;color:var(--color-onSurface);opacity:.7}.modal-content{background:var(--color-surface);padding:2rem;max-width:500px;width:90%;box-shadow:0 8px 24px #0000004d;border:1px solid var(--color-divider)}.modal-content h3{margin:0 0 1rem;font-size:1.5rem;color:var(--color-onSurface)}.modal-content p{margin:0 0 1.5rem;color:var(--color-onSurface);line-height:1.6}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-button{padding:.75rem 1.5rem;font-weight:600;cursor:pointer;border:1px solid var(--color-divider);transition:opacity .2s}.modal-button.cancel{background:transparent;color:var(--color-onSurface)}.modal-button.confirm{background:var(--color-error);color:var(--color-onError);border-color:var(--color-error)}.modal-button:hover{opacity:.8}@media (max-width: 768px){.home-title{font-size:2rem}.streak-stats{align-items:stretch;gap:1rem}.stat-card{padding:.75rem 0;border-bottom:1px solid var(--color-divider)}.chartboard-card{border-left:none;border-bottom:2px solid var(--color-primary);padding-left:0;padding-bottom:.75rem}.month-navigation{padding:0}.month-title{font-size:1.2rem}.calendar-section,.chart-section,.streak-info-section{padding:1rem}}.rewarded-ad-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--spacing-md)}.rewarded-ad-modal{background:var(--color-surface);border-radius:var(--radius-md);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--elevation-16);display:flex;flex-direction:column}.rewarded-ad-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-divider);text-align:center}.rewarded-ad-header h2{margin:0 0 var(--spacing-sm) 0;color:var(--color-onSurface);font-size:1.5rem}.rewarded-ad-description{margin:0;color:var(--color-disabled);font-size:.875rem}.rewarded-ad-content{padding:var(--spacing-lg);flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.rewarded-ad-unit{min-height:250px;display:flex;align-items:center;justify-content:center;background:var(--color-background);border-radius:var(--radius-sm);padding:var(--spacing-md)}.rewarded-ad-timer{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg)}.timer-circle{width:120px;height:120px;border-radius:50%;border:4px solid var(--color-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-surfaceVariant)}.timer-value{font-size:2.5rem;font-weight:700;color:var(--color-primary);line-height:1}.timer-label{font-size:.75rem;color:var(--color-disabled);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--spacing-xs)}.timer-complete{width:120px;height:120px;border-radius:50%;background:#4caf50;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#fff;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.timer-instruction{margin:0;color:var(--color-onSurface);font-size:1rem;text-align:center}.rewarded-ad-actions{padding:var(--spacing-lg);border-top:1px solid var(--color-divider);display:flex;justify-content:center;gap:var(--spacing-md)}.rewarded-ad-actions .btn{min-width:200px}@media (max-width: 768px){.rewarded-ad-modal{max-width:100%;max-height:100vh;border-radius:0}.timer-circle,.timer-complete{width:100px;height:100px}.timer-value{font-size:2rem}.rewarded-ad-actions .btn{min-width:150px}}.theme-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.theme-modal{background-color:var(--color-surface, #ffffff);border-radius:12px;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.theme-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--color-divider, rgba(0, 0, 0, .12))}.theme-modal-header h2{margin:0;font-size:1.5rem;color:var(--color-onSurface, #000000)}.theme-modal-close{background:none;border:none;font-size:2rem;color:var(--color-onSurface, #000000);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.theme-modal-close:hover{background-color:#0000000d}.theme-modal-content{flex:1;overflow-y:auto;padding:1.5rem 2rem}.theme-modal-loading{text-align:center;padding:2rem;color:var(--color-onSurface, #000000);opacity:.6}.theme-modal-description{margin-bottom:1.5rem;color:var(--color-onSurface, #000000);opacity:.7;text-align:center}.section-description{margin:1rem 0 .5rem;color:var(--color-onSurface, #000000);opacity:.6;font-size:.9rem;font-weight:500}.theme-section-divider{margin:1.5rem 0;border:none;border-top:2px solid var(--color-divider, rgba(0, 0, 0, .12))}.theme-toggle-container{display:flex;gap:.5rem;margin-bottom:1.5rem;justify-content:center}.theme-toggle-btn{padding:.5rem 1rem;border:2px solid var(--color-divider, rgba(0, 0, 0, .12));background-color:transparent;color:var(--color-onSurface, #000000);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.theme-toggle-btn:hover{border-color:var(--color-primary, #1976d2);background-color:#1976d20d}.theme-toggle-btn.active{border-color:var(--color-primary, #1976d2);background-color:var(--color-primary, #1976d2);color:var(--color-onPrimary, #ffffff)}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;padding:.5rem 0}.theme-card{cursor:pointer;border-radius:12px;overflow:hidden;background-color:var(--color-background, #fafafa);transition:transform .2s ease,box-shadow .2s ease;border:2px solid transparent}.theme-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.theme-card.active{border-color:var(--color-primary, #1976d2)}.theme-card.locked{cursor:default;opacity:.8}.theme-preview{position:relative;width:100%;padding-top:66.67%;border-radius:8px 8px 0 0}.theme-preview .active-indicator{position:absolute;top:8px;left:8px;background-color:var(--color-primary, #1976d2);color:var(--color-onPrimary, #ffffff);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.theme-preview .favorite-btn{position:absolute;top:8px;right:8px;background-color:#ffffffe6;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.theme-preview .favorite-btn:hover{transform:scale(1.1)}.theme-preview .lock-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background-color:#0006}.theme-preview .lock-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.theme-preview .watch-ad-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fffffff2;border:none;width:48px;height:48px;border-radius:50%;cursor:pointer;color:var(--color-primary, #1976d2);display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.theme-preview .watch-ad-btn:hover{transform:translate(-50%,-50%) scale(1.1)}.theme-preview .lock-indicators{position:absolute;bottom:8px;right:8px;display:flex;gap:4px;background-color:#0009;padding:4px 8px;border-radius:12px}.theme-preview .lock-indicators span{font-size:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.theme-info{padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.theme-info h3{margin:0;font-size:.9rem;color:var(--color-onSurface, #000000);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-info .next-date{font-size:.75rem;color:var(--color-onSurface, #000000);opacity:.7}.theme-info .premium-badge{font-size:.7rem;padding:.2rem .5rem;background-color:var(--color-secondary, #dc004e);color:var(--color-onSecondary, #ffffff);border-radius:4px;white-space:nowrap}.theme-colors{display:flex;gap:4px;padding:0 .75rem .75rem}.theme-colors .color-dot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.theme-modal-login-prompt{text-align:center;padding:1rem;margin-top:1rem;background-color:var(--color-primary, #1976d2);color:var(--color-onPrimary, #ffffff);border-radius:8px;font-weight:500}.theme-modal-actions{padding:1rem 2rem;border-top:1px solid var(--color-divider, rgba(0, 0, 0, .12));display:flex;justify-content:center}.theme-modal-btn-primary{padding:.75rem 2rem;background-color:var(--color-primary, #1976d2);color:var(--color-onPrimary, #ffffff);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.theme-modal-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.error-message{padding:1rem;background-color:var(--color-error, #b00020);color:var(--color-onError, #ffffff);border-radius:8px;margin-bottom:1rem;text-align:center}@media (max-width: 768px){.theme-modal{width:95%;max-height:95vh}.theme-modal-header,.theme-modal-content{padding:1rem}.theme-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.theme-preview{padding-top:8%}.theme-modal-actions{padding:1rem}}.spectrum-analyzer-page{min-height:100vh;background:#0a0a0a;color:#e0e0e0}.spectrum-container{max-width:1400px;margin:0 auto;padding:2rem}.spectrum-container h1{font-size:2.5rem;margin-bottom:.5rem;color:#fff}.subtitle{font-size:1.1rem;color:#aaa;margin-bottom:2rem}.controls-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem;background:#1a1a1a;padding:1.5rem;border-radius:8px;border:1px solid #333}.control-group{display:flex;flex-direction:column;gap:.75rem}.control-group h3{margin:0 0 .5rem;font-size:1.1rem;color:#fff;border-bottom:1px solid #333;padding-bottom:.5rem}.control-group label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:#ddd}.control-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.control-group input[type=range]{flex:1;margin-left:.5rem}.control-group select{padding:.4rem;background:#2a2a2a;color:#fff;border:1px solid #444;border-radius:4px;cursor:pointer;margin-left:.5rem}.start-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s;margin-bottom:1rem}.start-button.start{background:linear-gradient(135deg,#4CAF50,#45a049);color:#fff}.start-button.start:hover{background:linear-gradient(135deg,#45a049,#3d8b40);transform:translateY(-1px);box-shadow:0 4px 12px #4caf5066}.start-button.stop{background:linear-gradient(135deg,#f44336,#da190b);color:#fff}.start-button.stop:hover{background:linear-gradient(135deg,#da190b,#c41106);transform:translateY(-1px);box-shadow:0 4px 12px #f4433666}.constraint-controls{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#252525;border-radius:4px;border:1px solid #333}.metrics-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;background:#1a1a1a;padding:1.5rem;border-radius:8px;border:1px solid #333}.metric{display:flex;flex-direction:column;gap:.25rem}.metric-label{font-size:.85rem;color:#999;font-weight:500}.metric-value{font-size:1.2rem;color:#4caf50;font-weight:600;font-family:Courier New,monospace}.constraints-panel{background:#1a1a1a;padding:1.5rem;border-radius:8px;border:2px solid #ff9800;margin-bottom:2rem}.constraints-panel h3{margin:0 0 .5rem;color:#ff9800}.warning-text{color:#ffb74d;font-size:.9rem;margin-bottom:1rem;line-height:1.5}.constraints-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.75rem}.constraint-item{display:flex;justify-content:space-between;padding:.5rem;background:#252525;border-radius:4px;font-size:.9rem}.constraint-item .enabled{color:#4caf50;font-weight:600}.constraint-item .disabled{color:#f44336;font-weight:600}.device-id{font-family:Courier New,monospace;font-size:.8rem;color:#aaa}.visualization-area{margin-bottom:2rem}.visualization-area h3{margin:1.5rem 0 .5rem;color:#fff}.legend{display:flex;gap:2rem;margin-bottom:.75rem;font-size:.9rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-item:before{content:"";display:inline-block;width:20px;height:3px;border-radius:2px}.legend-item.raw:before{background:rgba(255,100,100,.9)}.legend-item.filtered:before{background:rgba(100,255,100,.9)}.legend-item.pitch:before{background:rgba(255,255,0,.9)}.spectrum-canvas,.waveform-canvas{width:100%;height:auto;border:1px solid #333;border-radius:4px;background:#000;display:block}.waveform-canvas{margin-top:.75rem}.debug-info{background:#1a1a1a;padding:1.5rem;border-radius:8px;border:1px solid #333;margin-top:2rem}.debug-info h3{margin:0 0 1rem;color:#fff}.debug-info ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.debug-info li{padding:.75rem;background:#252525;border-radius:4px;border-left:3px solid #4CAF50;line-height:1.6}.debug-info strong{color:#4caf50;display:block;margin-bottom:.25rem}@media (max-width: 768px){.spectrum-container{padding:1rem}.spectrum-container h1{font-size:1.8rem}.controls-panel{grid-template-columns:1fr}.metrics-panel{grid-template-columns:repeat(2,1fr)}.constraints-grid{grid-template-columns:1fr}.legend{flex-direction:column;gap:.5rem}.spectrum-canvas,.waveform-canvas{width:100%;height:auto}}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--color-primary);border:2px solid var(--color-primary);position:relative}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primaryVariant, var(--color-primary)) 100%);color:#fff;font-weight:600;-webkit-user-select:none;user-select:none}.avatar-small{width:24px;height:24px}.avatar-small .avatar-fallback{font-size:10px}.avatar-medium{width:28px;height:28px}.avatar-medium .avatar-fallback{font-size:11px}.avatar-large{width:80px;height:80px;border-width:3px}.avatar-large .avatar-fallback{font-size:28px}.avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-surface);opacity:0;animation:avatar-pulse 1.5s ease-in-out infinite;pointer-events:none}.avatar:has(img) :before{animation:none}@keyframes avatar-pulse{0%,to{opacity:0}50%{opacity:.1}}.clicktrack-player-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1000}.clicktrack-player-modal{background:var(--color-surface);border-radius:var(--radius-md);width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d}.player-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-divider)}.player-header h2{margin:0;font-size:1.5rem;color:var(--color-onSurface)}.btn-close{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--color-disabled);line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center}.pan-buttons{display:flex;gap:.5rem}.btn-pan{padding:.5rem 1rem;border:1px solid var(--color-divider);background:var(--color-surface);border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s;color:var(--color-onSurface)}.btn-pan:hover:not(:disabled){background:var(--color-background);border-color:var(--color-primary)}.btn-pan.active{background:var(--color-primary);color:var(--color-onPrimary);border-color:var(--color-primary)}.btn-pan:disabled{opacity:.5;cursor:not-allowed}.global-controls{margin-top:1.5rem;padding:1rem;border:1px solid var(--color-divider);border-radius:8px;background:var(--color-background)}.global-controls h3{margin-top:0;margin-bottom:1rem;font-size:1.1rem}.transpose-controls{display:flex;align-items:center;gap:.75rem}.transpose-value{min-width:120px;text-align:center;font-weight:500}justify-content: center; border-radius: 4px; transition: all .2s; } .btn-close:hover{background:var(--color-background);color:var(--color-onSurface)}.player-body{padding:2rem;overflow-y:auto;display:flex;flex-direction:column;gap:2rem}.progress-container{display:flex;flex-direction:column;gap:.5rem}.progress-bar{height:8px;background:var(--color-divider);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primaryVariant));transition:width .1s linear}.progress-info{display:flex;justify-content:space-between;font-size:.85rem;color:var(--color-onSurface)}.player-controls-top{display:flex;justify-content:center;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-divider);margin-bottom:1rem}.btn-control{padding:.75rem 2rem;font-size:1.125rem;min-width:120px}.btn-control:disabled{opacity:.5;cursor:not-allowed}.beat-measure-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.measure-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);border-radius:12px;color:#fff;box-shadow:0 4px 12px #f093fb4d}.measure-number{font-size:4rem;font-weight:700;line-height:1;margin-bottom:.5rem}.measure-label{font-size:1rem;opacity:.95;text-align:center}.beat-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;color:#fff;box-shadow:0 4px 12px #667eea4d}.beat-number{font-size:4rem;font-weight:700;line-height:1;margin-bottom:.5rem}.beat-label{font-size:1rem;opacity:.95;text-align:center}.tempo-display{display:flex;align-items:baseline;justify-content:center;gap:.5rem;padding:1rem;background:var(--color-background);border-radius:8px}.tempo-number{font-size:2.5rem;font-weight:600;color:var(--color-onSurface)}.tempo-label{font-size:1rem;color:var(--color-onSurface);text-transform:uppercase;letter-spacing:1px;opacity:.8}.sections-preview{background:var(--color-background);border-radius:8px;padding:1rem}.sections-preview h3{margin:0 0 .75rem;font-size:1rem;color:var(--color-onSurface);text-transform:uppercase;letter-spacing:.5px;opacity:.8}.sections-list-compact{display:flex;flex-direction:column;gap:.5rem}.section-item-compact{display:flex;gap:.75rem;align-items:center;padding:.75rem;background:var(--color-surface);border-radius:6px;font-size:.9rem;border:2px solid transparent;transition:all .2s;color:var(--color-onSurface)}.section-item-compact.active{border-color:var(--color-primary);background:var(--color-background);font-weight:600}.section-num{font-weight:600;color:var(--color-onSurface);min-width:2rem;opacity:.8}@media (max-width: 640px){.clicktrack-player-modal{width:95%;max-height:95vh}.player-body{padding:1.5rem}.beat-measure-container{grid-template-columns:1fr}.beat-number,.measure-number{font-size:3rem}.tempo-number{font-size:2rem}.btn-control{padding:.625rem 1.5rem;font-size:1rem;min-width:100px}}.countdown-modal .player-body{padding:3rem 2rem;text-align:center}.countdown-display{margin-bottom:2rem}.countdown-number{font-size:8rem;font-weight:700;color:var(--color-primary);line-height:1;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.countdown-label{font-size:1.5rem;color:var(--color-onSurface);margin-top:1rem;font-weight:500}.track-start-info{display:flex;justify-content:space-around;gap:1rem;margin:2rem 0;padding:1.5rem;background:var(--color-background);border-radius:8px}.info-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.info-label{font-size:.875rem;color:var(--color-onSurface);text-transform:uppercase;letter-spacing:.5px;opacity:.8}.info-value{font-size:1.25rem;font-weight:600;color:var(--color-onSurface)}.leader-controls{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-divider);display:flex;justify-content:center}.leader-controls .btn{min-width:200px}.performance-setup-modal{max-width:700px}.performance-track-info{margin-bottom:1.5rem;padding:1.5rem;background:var(--color-background);border-radius:8px}.performance-track-info h3{margin:0 0 .5rem;font-size:1.5rem;color:var(--color-onSurface)}.track-description{color:var(--color-onSurface);margin:.5rem 0 1rem;opacity:.8}.track-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.stat-item{display:flex;gap:.5rem;align-items:baseline}.stat-label{font-size:.875rem;color:var(--color-onSurface);opacity:.8}.countdown-input-group{display:flex;gap:.5rem;align-items:center}.countdown-input{width:100px;text-align:center;font-size:1.25rem;font-weight:600;padding:.5rem;border:1px solid var(--color-divider);border-radius:4px;background:var(--color-surface);color:var(--color-onSurface)}.form-help{display:block;margin-top:.5rem;color:var(--color-onSurface);font-size:.875rem;opacity:.8}.advanced-options{margin:1.5rem 0;padding:1rem;background:var(--color-background);border-radius:8px}.advanced-options summary{cursor:pointer;font-weight:600;color:var(--color-primary);-webkit-user-select:none;user-select:none}.advanced-options summary:hover{color:var(--color-primaryVariant)}.advanced-options .form-group{margin-top:1rem}.control-input,.control-select{width:100%;padding:.5rem;border:1px solid var(--color-divider);border-radius:4px;font-size:1rem;background:var(--color-surface);color:var(--color-onSurface)}.section-type{text-transform:uppercase;font-size:.75rem;font-weight:600;color:var(--color-onSurface);opacity:.8}.block-type-badge{font-size:.75rem;font-weight:600;color:var(--color-onSurface);text-transform:uppercase;background:var(--color-background);padding:2px 6px;border-radius:3px;margin-left:4px;opacity:.8}.block-type-display{font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;color:var(--color-onPrimary)}.countdown-text{font-size:.85rem;font-weight:500;margin-top:.5rem;padding:.5rem;background:rgba(255,152,0,.15);border-radius:4px;color:#e65100;text-align:center;animation:pulse-warning 1.5s ease-in-out infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}.measure-sublabel{font-size:.75rem;color:var(--color-disabled);margin-top:4px}.section-item-compact .block-type{font-weight:600;text-transform:uppercase;font-size:.7rem;padding:2px 6px;background:var(--color-background);border-radius:3px;color:var(--color-primary)}.clicktrack-player-container{background:var(--color-surface);border-radius:var(--radius-md);width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;overflow:hidden}.player-content{padding:1.5rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1rem}.player-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-divider);display:flex;justify-content:center}.parts-controls{display:flex;flex-direction:column;gap:.75rem}.parts-controls h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-onSurface)}.parts-list{display:flex;flex-direction:column;gap:.25rem;overflow-y:auto;padding:.5rem;border:1px solid var(--color-divider);background:var(--color-background)}.parts-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.parts-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.parts-list::-webkit-scrollbar-thumb:hover{background:#555}.part-control{background:var(--color-surface);border:1px solid var(--color-divider);padding:.5rem}.part-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.part-name{flex:1;font-weight:500;color:var(--color-onSurface)}.part-type{font-size:.75rem;text-transform:uppercase;padding:2px 8px;background:var(--color-background);color:var(--color-primary);border-radius:3px;font-weight:600}.loading-message,.error-message{padding:1rem;border-radius:6px;text-align:center;font-weight:500}.loading-message{background:var(--color-background);color:var(--color-primary)}.error-message{background:var(--color-error);color:var(--color-onError)}.playing-indicator{padding:.75rem;background:#e8f5e9;color:#2e7d32;border-radius:6px;text-align:center;font-weight:600;font-size:1.1rem}.parts-selection{margin-top:1.5rem;padding:1rem;border:1px solid var(--color-divider);border-radius:8px;background:var(--color-background)}.parts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.parts-header h4{margin:0;font-size:1rem;font-weight:600}.parts-actions{display:flex;gap:.5rem}.parts-list-compact{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.part-item-compact{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--color-surface);border:2px solid var(--color-divider);border-radius:6px;cursor:pointer;transition:all .2s}.part-item-compact:hover,.part-item-compact.enabled{border-color:var(--color-primary);background:var(--color-background)}.part-item-compact.disabled{opacity:.6}.part-item-compact input[type=checkbox]{margin:0;cursor:pointer;width:18px;height:18px}.part-item-compact .part-name{flex:1;font-weight:500;font-size:.95rem;color:var(--color-onSurface)}.part-item-compact .part-type{font-size:.85rem;color:var(--color-onSurface);background:var(--color-background);padding:.25rem .5rem;border-radius:4px}.part-item-compact .part-channel{font-size:.85rem;color:var(--color-onSurface);background:var(--color-background);padding:.25rem .5rem;border-radius:4px;opacity:.8}.measure-beat-display{display:flex;gap:1rem;justify-content:center;margin:2rem 0}.measure-box,.beat-box{flex:1;max-width:200px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 4px 12px #00000026}.beat-box{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.measure-label,.beat-label{font-size:.85rem;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:.5rem}.measure-number,.beat-number{font-size:3rem;font-weight:700;line-height:1}.tempo-info{display:flex;gap:1.5rem;justify-content:center;margin:1.5rem 0;padding:1rem;background:var(--color-background);border-radius:8px}.tempo-item{display:flex;gap:.5rem;align-items:center}.tempo-label{font-weight:600;color:var(--color-onSurface);opacity:.8}.tempo-value{font-size:1.1rem;font-weight:700;color:var(--color-onSurface)}.progress-container{margin-top:2rem}.progress-container .progress-bar{width:100%;height:24px;background:var(--color-divider);border-radius:12px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.progress-container .progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primaryVariant) 100%);transition:width .1s linear;border-radius:12px}.progress-text{text-align:center;margin-top:.5rem;font-size:.9rem;color:var(--color-onSurface);font-weight:600}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:16px 20px;min-width:300px;max-width:400px;display:flex;align-items:center;gap:12px;pointer-events:all;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast.exiting{animation:slideOut .3s ease-in}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.toast-icon{font-size:24px;flex-shrink:0}.toast-content{flex:1}.toast-title{font-weight:600;margin-bottom:4px;font-size:14px}.toast-message{font-size:13px;color:#666;line-height:1.4}.toast-close{background:none;border:none;font-size:20px;cursor:pointer;color:#999;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.toast-close:hover{background:#f0f0f0;color:#333}.toast.success{border-left:4px solid #4CAF50}.toast.success .toast-icon{color:#4caf50}.toast.error{border-left:4px solid #f44336}.toast.error .toast-icon{color:#f44336}.toast.warning{border-left:4px solid #ff9800}.toast.warning .toast-icon{color:#ff9800}.toast.info{border-left:4px solid #2196F3}.toast.info .toast-icon{color:#2196f3}.midi-import-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:3000}.midi-import-modal{background:var(--color-surface);border-radius:var(--radius-md);width:90%;max-width:500px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-divider)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--color-onSurface)}.btn-close{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--color-disabled);line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.btn-close:hover:not(:disabled){color:var(--color-onSurface)}.btn-close:disabled{opacity:.3;cursor:not-allowed}.modal-body{padding:2rem;min-height:250px;display:flex;flex-direction:column;justify-content:center}.drop-zone{border:3px dashed var(--color-divider);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s}.drop-zone:hover{border-color:var(--color-primary);background:var(--color-background)}.drop-zone-content{pointer-events:none}.drop-icon{font-size:4rem;margin-bottom:1rem}.drop-text{font-size:1.1rem;color:var(--color-onSurface);margin:0 0 .5rem}.drop-hint{font-size:.875rem;color:var(--color-disabled);margin:0}.file-selected{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--color-background);border-radius:8px;border:1px solid var(--color-divider)}.file-icon{font-size:2.5rem}.file-info{flex:1}.file-name{font-weight:600;color:var(--color-onSurface);margin-bottom:.25rem}.file-size{font-size:.875rem;color:var(--color-disabled)}.btn-remove{background:none;border:none;font-size:1.5rem;color:var(--color-disabled);cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.btn-remove:hover{background:var(--color-error);color:var(--color-onError)}.uploading{text-align:center;padding:2rem}.spinner{width:50px;height:50px;border:4px solid var(--color-divider);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.uploading p{color:var(--color-onSurface);margin:.5rem 0}.progress-bar{width:100%;height:8px;background:var(--color-divider);border-radius:4px;margin:1rem 0 .5rem;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primaryVariant));border-radius:4px;transition:width .3s ease}.progress-text{font-size:.875rem;color:var(--color-primary);font-weight:600;margin:.5rem 0 0}.import-success{text-align:center;padding:1rem 0}.success-icon{width:60px;height:60px;background:#4CAF50;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}.import-success h3{color:var(--color-onSurface);margin:0 0 1.5rem;font-size:1.3rem}.import-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:1.5rem}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary)}.stat-label{font-size:.875rem;color:var(--color-disabled);text-transform:uppercase;letter-spacing:.5px}.success-message{color:var(--color-onSurface);margin:0;font-size:.95rem}.error-message{padding:1rem;background:#ffebee;border:1px solid #f44336;border-radius:8px;color:#c62828;display:flex;align-items:center;gap:.75rem}.error-icon{font-size:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-divider);display:flex;justify-content:flex-end;gap:.75rem}.btn{padding:.625rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary{background:var(--color-surface);color:var(--color-onSurface);border:1px solid var(--color-divider)}.btn-secondary:hover{background:var(--color-background)}.btn-primary{background:var(--color-primary);color:var(--color-onPrimary)}.btn-primary:hover{background:var(--color-primaryVariant)}.tracks-container{height:100vh;background-color:var(--color-background);display:flex;flex-direction:column;overflow:auto}.tracks-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-shrink:0;padding:0 20px}.tracks-list{flex:1;overflow-y:auto;min-height:0;padding:20px}.tracks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg);padding-bottom:var(--spacing-lg)}.track-card{background-color:var(--color-surface);padding:var(--spacing-lg);transition:all var(--transition-fast);box-shadow:var(--elevation-2);display:flex;flex-direction:column;gap:var(--spacing-sm)}.track-card:hover{transform:translateY(-2px);box-shadow:var(--elevation-4)}.track-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.track-header h3{margin:0;color:var(--color-onSurface);font-size:20px;flex:1}.favorite-btn{background:none;border:none;font-size:24px;cursor:pointer;padding:0;color:var(--color-divider);transition:color var(--transition-fast),transform var(--transition-fast);line-height:1}.favorite-btn:hover{transform:scale(1.2)}.favorite-btn.favorited{color:gold}.track-description{color:var(--color-disabled);font-size:14px;margin:0;line-height:1.5}.track-footer{padding-top:var(--spacing-sm);font-size:13px;color:var(--color-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.track-meta{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;width:100%}.track-creator{display:flex;align-items:center;gap:var(--spacing-xs)}.track-viewed{color:var(--color-disabled);font-size:13px}.track-actions{margin-top:auto;display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.btn-danger{background-color:var(--color-error);color:var(--color-onError)}.btn-danger:hover:not(:disabled){background-color:#c0392b;box-shadow:var(--elevation-2)}.share-instructions{color:var(--color-disabled);font-size:14px;margin:0 0 var(--spacing-md) 0;line-height:1.5}.share-url-container{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.share-url-input{flex:1;padding:var(--spacing-sm);border:2px solid var(--color-divider);font-size:14px;font-family:monospace;background-color:var(--color-background);color:var(--color-onSurface)}.share-url-input:focus{outline:none;border-color:var(--color-primary)}.share-uuid-info{background-color:var(--color-background);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.share-uuid-info p{margin:0;font-size:13px;color:var(--color-disabled);word-break:break-all}.share-uuid-info strong{color:var(--color-onSurface)}@media (max-width: 640px){.tracks-container{padding:0}.tracks-actions{padding:0 var(--spacing-sm);margin-bottom:var(--spacing-sm)}.tracks-list{padding:0 var(--spacing-sm)}.tracks-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.track-actions{width:100%}.track-actions .btn-sm{flex:1}}.groups-container{height:100vh;background-color:var(--color-background);display:flex;flex-direction:column;overflow:auto}.groups-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-shrink:0;padding:0 20px}.groups-list{flex:1;overflow-y:auto;min-height:0;padding:20px}.empty-state{background-color:var(--color-surface);padding:60px var(--spacing-xl);text-align:center;color:var(--color-disabled);box-shadow:var(--elevation-1)}.empty-state p{margin:var(--spacing-sm) 0;font-size:16px}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg);padding-bottom:var(--spacing-lg)}.group-card{background-color:var(--color-surface);padding:var(--spacing-lg);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--elevation-2);display:flex;flex-direction:column;gap:var(--spacing-sm)}.group-card:hover{transform:translateY(-2px);box-shadow:var(--elevation-4)}.group-card h3{margin:0;color:var(--color-onSurface);font-size:20px}.group-description{color:var(--color-disabled);font-size:14px;margin:0;line-height:1.5}.group-meta{display:flex;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-divider);font-size:13px;color:var(--color-disabled)}.group-footer{margin-top:auto;padding-top:var(--spacing-sm);font-size:13px;color:var(--color-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.group-owner{display:flex;align-items:center;gap:var(--spacing-xs)}.checkbox-group label{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;margin:0}@media (max-width: 640px){.groups-container{padding:0}.groups-actions{padding:0 var(--spacing-sm);margin-bottom:var(--spacing-sm)}.groups-list{padding:0 var(--spacing-sm)}.groups-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}.invite-code-modal{max-width:500px;width:90%}.invite-sections{display:flex;flex-direction:column;gap:24px;margin:24px 0}.invite-section{padding:20px;background:var(--surface-bg);border-radius:8px;border:1px solid var(--border-color)}.invite-section h3{margin:0 0 8px;font-size:18px;color:var(--text-primary)}.section-description{margin:0 0 16px;font-size:14px;color:var(--text-secondary)}.code-display{display:flex;flex-direction:column;gap:12px}.code-value{font-family:Courier New,monospace;font-size:24px;font-weight:700;letter-spacing:4px;padding:16px;background:var(--background-color);border:2px solid var(--primary-color);border-radius:8px;text-align:center;cursor:pointer;-webkit-user-select:all;user-select:all;transition:all .2s ease}.code-value:hover{background:var(--hover-bg);transform:scale(1.02)}.code-value:active{transform:scale(.98)}.countdown{text-align:center;font-size:16px;font-weight:600;color:var(--primary-color);padding:8px;background:var(--primary-color-alpha);border-radius:4px}.modal-footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.hint-text{margin:0;font-size:13px;color:var(--text-secondary);text-align:center;font-style:italic}.group-detail-container{height:100vh;background-color:var(--color-background);display:flex;flex-direction:column;overflow:auto}.group-content{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:var(--spacing-lg);width:100%;margin:0 auto;padding:0 20px var(--spacing-lg) 20px}.group-header-section{flex-shrink:0;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-divider);display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.group-actions{display:flex;gap:12px;flex-shrink:0}.group-info h1{margin:0 0 var(--spacing-xs) 0;font-size:2rem;color:var(--color-onBackground)}.group-description{margin:0 0 var(--spacing-xs) 0;color:var(--color-disabled)}.group-stats{display:flex;gap:var(--spacing-md);color:var(--color-disabled);font-size:.9rem}.group-stats span{display:flex;align-items:center}.group-main-content{flex:1;display:grid;grid-template-columns:1fr 300px;gap:var(--spacing-lg);min-height:0;overflow:hidden}.materials-section{display:flex;flex-direction:column;min-height:0;overflow-y:auto}.section-actions{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-shrink:0}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg)}.material-card{background-color:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg);transition:all var(--transition-fast);box-shadow:var(--elevation-2);display:flex;flex-direction:column;gap:var(--spacing-sm)}.material-card:hover{transform:translateY(-2px);box-shadow:var(--elevation-4)}.material-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.material-header h3{margin:0;font-size:20px;flex:1;color:var(--color-onSurface)}.material-actions{margin-top:auto;display:flex;gap:var(--spacing-xs);flex-wrap:wrap;flex-shrink:0}.material-actions .btn{white-space:nowrap;width:90px;height:32px;padding:6px 8px;display:inline-flex;align-items:center;justify-content:center;line-height:1.2;font-size:13px}.material-description{color:var(--color-disabled);font-size:14px;margin:0;line-height:1.5}.material-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md);background-color:#00000005;border-radius:var(--radius-sm)}.stat{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{font-size:.75rem;color:var(--color-disabled);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.material-blocks-preview{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.block-preview{display:flex;gap:var(--spacing-sm);align-items:center;padding:var(--spacing-xs);background-color:#00000005;border-radius:var(--radius-sm);font-size:.85rem;color:var(--color-onSurface)}.block-type{font-weight:600;text-transform:uppercase;font-size:.75rem;padding:var(--spacing-xs) var(--spacing-xs);background-color:var(--color-primary);color:var(--color-onPrimary);border-radius:var(--radius-sm);min-width:60px;text-align:center}.material-footer{padding-top:var(--spacing-sm);font-size:13px;color:var(--color-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.material-creator{display:flex;align-items:center;gap:var(--spacing-xs)}.performers-section{background-color:var(--color-surface);padding:var(--spacing-lg);box-shadow:var(--elevation-2);display:flex;flex-direction:column;min-height:0;overflow-y:auto}.performers-header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-shrink:0}.performers-header-actions{display:flex;width:100%;gap:var(--spacing-sm)}.performers-header-actions>*{flex:1}.performers-header h3{margin:0;font-size:1.1rem;color:var(--color-onSurface)}.performers-header-controls{display:block;width:100%}.performers-section h3{margin:0;font-size:1.1rem;color:var(--color-onSurface)}.connection-status{display:flex;align-items:center;justify-content:center;font-size:.75rem;padding:var(--spacing-xs) var(--spacing-xs);text-transform:uppercase;font-weight:600}.connection-status.connected{background-color:#d4edda;color:#155724}.performers-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.performer-item{padding:var(--spacing-sm);background-color:var(--color-background);border:1px solid var(--color-divider)}.performer-info{display:flex;justify-content:space-between;align-items:center}.performer-name-wrapper{display:flex;align-items:center;gap:var(--spacing-xs)}.presence-indicator{width:8px;height:8px;border-radius:var(--radius-round);flex-shrink:0}.presence-indicator.online{background-color:#28a745;box-shadow:0 0 0 2px #28a74533}.presence-indicator.offline{background-color:var(--color-disabled)}.performer-name{font-weight:500;color:var(--color-onSurface);font-size:.9rem}.performer-role{font-size:.7rem;padding:2px 6px;text-transform:uppercase;font-weight:600}.role-owner{background-color:gold;color:#996500}.role-leader{background-color:#e3f2fd;color:#1976d2}.role-member{background-color:#f3e5f5;color:#7b1fa2}.time-sync-info{position:fixed;bottom:0;left:0;right:0;background:var(--color-surfaceVariant);border-top:1px solid var(--color-divider);padding:8px 16px;display:flex;justify-content:center;align-items:center;gap:12px;z-index:100;font-size:.875rem}.time-sync-offset{color:var(--color-onSurface);font-family:Courier New,monospace}.time-sync-clock{color:var(--color-onSurface);font-family:Courier New,monospace;font-size:1rem;font-weight:600}.recalibrate-button{margin-left:auto;width:140px!important}@media (max-width: 900px){.group-main-content{grid-template-columns:1fr;overflow-y:auto}.performers-section{max-height:400px}}@media (max-width: 640px){.group-detail-container{padding:0}.group-content{padding:0 var(--spacing-sm);padding-bottom:var(--spacing-lg)}.materials-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.time-sync-info{font-size:.75rem;padding:6px 12px}}.audio-visualizer-bar{position:absolute;top:0;left:0;width:100%;height:100%;opacity:.3;pointer-events:none;z-index:0}.part-controls-panel{background:#fafafa;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100%;width:280px;overflow:hidden;min-height:0}.panel-header{padding:12px 16px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:white;flex-shrink:0}.panel-header h3{margin:0;font-size:14px;font-weight:600;color:#333}.panel-header-actions{display:flex;align-items:center;gap:8px}.btn-add-part{width:28px;height:28px;padding:0;border:1px solid #4A90E2;background:#4A90E2;color:#fff;border-radius:4px;font-size:18px;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;line-height:1}.btn-add-part:hover{background:#357ABD;border-color:#357abd;transform:scale(1.05)}.parts-count{font-size:12px;color:#666;background:#f0f0f0;padding:2px 8px;border-radius:10px;min-width:20px;text-align:center}.parts-list{flex:1;overflow-y:auto;padding:4px}.part-control{background:white;border:1px solid #e0e0e0;transition:all .15s ease;cursor:pointer;display:flex;flex-direction:column}.part-control:hover{border-color:#999;box-shadow:0 1px 4px #0000001a}.part-control.selected{border-color:#4a90e2;background:#f5f9ff}.part-control.muted{opacity:.5}.part-control.expanded{height:auto}.part-header{position:relative;display:flex;align-items:center;gap:8px;padding:0 12px;flex-shrink:0;overflow:hidden;min-height:60px}.part-info{position:relative;z-index:1;flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.part-name-row{display:flex;align-items:center;gap:4px}.part-name{font-weight:500;font-size:13px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;flex:1}.part-name-input{flex:1;font-size:13px;font-weight:500;padding:4px 6px;border:1px solid #4A90E2;border-radius:3px;outline:none;min-width:120px}.part-edit-btn{background:transparent;border:none;cursor:pointer;font-size:12px;padding:2px;opacity:.4;transition:opacity .15s ease;flex-shrink:0}.part-edit-btn:hover{opacity:1}.part-meta{font-size:11px;color:#888;margin-top:2px;line-height:1.2}.part-actions{display:flex;gap:4px;flex-shrink:0}.icon-btn{width:28px;height:28px;padding:0;border:1px solid #e0e0e0;background:white;border-radius:4px;font-size:14px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.icon-btn:hover{background:#f5f5f5;border-color:#999}.icon-btn.btn-mute.active{background:#ff5252;border-color:#ff5252;filter:none}.icon-btn.btn-solo.active{background:#ffd54f;border-color:#ffd54f}.part-details{padding:0 12px 12px;border-top:1px solid #f0f0f0;background:#fafafa}.control-row{margin-bottom:12px}.control-row:last-child{margin-bottom:0}.control-label{display:block;font-size:11px;font-weight:500;color:#666;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.control-with-value{display:flex;align-items:center;gap:8px}.control-slider{flex:1;height:4px;border-radius:2px;background:#e0e0e0;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#4A90E2;cursor:pointer;transition:all .15s ease}.control-slider::-webkit-slider-thumb:hover{background:#357ABD;transform:scale(1.15)}.control-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#4A90E2;cursor:pointer;border:none;transition:all .15s ease}.control-slider::-moz-range-thumb:hover{background:#357ABD;transform:scale(1.15)}.control-value{font-size:11px;font-weight:500;color:#666;min-width:40px;text-align:right}.btn-delete-part{width:100%;padding:8px;border:1px solid #e0e0e0;background:white;border-radius:4px;font-size:12px;font-weight:500;color:#d32f2f;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:6px}.btn-delete-part:hover{background:#d32f2f;border-color:#d32f2f;color:#fff}.btn-collapse{width:100%;margin-top:8px;padding:6px;border:1px solid #e0e0e0;background:white;border-radius:4px;font-size:11px;font-weight:500;color:#666;cursor:pointer;transition:all .15s ease}.btn-collapse:hover{background:#f5f5f5;border-color:#999}.parts-list::-webkit-scrollbar{width:8px}.parts-list::-webkit-scrollbar-track{background:#f1f3f5}.parts-list::-webkit-scrollbar-thumb{background:#adb5bd;border-radius:4px}.parts-list::-webkit-scrollbar-thumb:hover{background:#6c757d}.piano-roll-container{overflow:auto;background:#fafafa;border:1px solid #ccc;border-radius:4px;outline:none}.piano-roll-container canvas{display:block;cursor:crosshair}.piano-roll-container:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.staff-notation-container{width:100%;height:100%;display:flex;flex-direction:column;background:white;overflow:auto}.staff-notation-canvas{flex:1;overflow-x:auto;overflow-y:auto;padding:20px;min-height:300px}.staff-notation-canvas svg{display:block}.staff-notation-info{padding:12px 20px;border-top:1px solid #e0e0e0;background:#fafafa;font-size:12px;color:#666}.staff-notation-info p{margin:4px 0}.midi-error-container{max-width:700px;margin:2rem auto;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.midi-error-header{text-align:center;margin-bottom:1.5rem}.midi-error-icon{font-size:3rem;margin-bottom:.5rem}.midi-error-header h3{margin:0;font-size:1.5rem;color:#333}.midi-error-content{color:#555;line-height:1.6}.midi-error-message{font-size:1.1rem;margin-bottom:1.5rem;color:#666;text-align:center}.midi-error-instructions{background:#f8f9fa;padding:1.5rem;border-radius:6px;margin:1.5rem 0}.midi-error-instructions h4{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.1rem}.midi-error-instructions ol{margin:0;padding-left:1.5rem}.midi-error-instructions ol li{margin-bottom:.75rem;color:#555}.midi-error-instructions ul{list-style:none;padding:0}.midi-error-instructions ul li{padding:.5rem;margin-bottom:.5rem;background:#fff;border-radius:4px;font-weight:500}.midi-os-section{margin:1.5rem 0;padding:1rem;background:#fff;border-radius:6px;border-left:3px solid #0066cc}.midi-os-section h5{margin:0 0 .75rem;color:#06c;font-size:1rem;font-weight:600}.midi-os-section ol{margin:0;padding-left:1.5rem}.midi-os-section ol li{margin-bottom:.5rem;color:#555;line-height:1.6}.midi-os-section code{background:#f8f9fa;padding:.2rem .4rem;border-radius:3px;font-family:Courier New,monospace;font-size:.875rem;color:#d73a49}.midi-os-section kbd{background:#f8f9fa;color:#333;padding:.2rem .4rem;border-radius:3px;border:1px solid #ccc;font-family:monospace;font-size:.85rem;font-weight:600;box-shadow:0 1px 2px #0000001a}.midi-error-settings{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #dee2e6}.midi-error-settings p{margin:.5rem 0}.midi-settings-url-container{display:flex;gap:.5rem;align-items:stretch;margin:.5rem 0}.midi-settings-url{flex:1;display:block;padding:.75rem;background:#fff;border:1px solid #dee2e6;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;color:#06c;word-break:break-all;text-decoration:none;cursor:pointer;transition:all .2s}.midi-settings-url:hover{background:#f0f7ff;border-color:#06c}.btn-copy{padding:.75rem 1rem;background:#0066cc;color:#fff;border:1px solid #0066cc;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.btn-copy:hover{background:#0052a3;border-color:#0052a3}.midi-settings-note{font-size:.9rem;color:#666;font-style:italic;margin-top:.5rem}.midi-error-actions{display:flex;gap:1rem;margin:1.5rem 0;flex-wrap:wrap}.midi-retry-btn{flex:1;min-width:200px;padding:.75rem 1.5rem;font-size:1rem}.midi-details-btn{padding:.75rem 1.5rem;font-size:.9rem}.midi-error-details{background:#f8f9fa;padding:1.5rem;border-radius:6px;margin-top:1rem;border-left:4px solid #0066cc}.midi-error-details h4{margin-top:1.5rem;margin-bottom:.75rem;color:#333;font-size:1rem}.midi-error-details h4:first-child{margin-top:0}.midi-error-details pre{background:#fff;padding:1rem;border-radius:4px;font-size:.85rem;overflow-x:auto;border:1px solid #dee2e6;color:#d73a49}.midi-error-details p{margin:.5rem 0;font-size:.95rem;color:#555}.midi-error-help{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #dee2e6;text-align:center;font-size:.9rem;color:#666}.midi-error-help p{margin:0}.midi-error-suggestion{text-align:center;font-size:1rem;color:#666;margin-top:1rem}@media (max-width: 600px){.midi-error-container{margin:1rem;padding:1.5rem}.midi-error-actions{flex-direction:column}.midi-retry-btn,.midi-details-btn{width:100%}.midi-settings-url-container{flex-direction:column}.btn-copy{width:100%}}.beat-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .2s ease}.beat-modal{background:white;border-radius:12px;max-width:1000px;width:90%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}.modal-header{padding:20px 24px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.btn-close{width:32px;height:32px;border:none;background:transparent;font-size:28px;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s ease;line-height:1;padding:0}.btn-close:hover{background:#f5f5f5;color:#333}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-body-two-column{display:grid;grid-template-columns:1fr 350px;gap:24px;padding:24px;overflow-y:auto;flex:1;min-height:0}.modal-column{display:flex;flex-direction:column;min-height:0}.modal-column-left{min-width:0}.modal-column-right{overflow-y:auto}@media (max-width: 768px){.modal-body-two-column{grid-template-columns:1fr;gap:16px;padding:16px}.modal-column-left{order:2}.modal-column-right{order:1;overflow-y:visible}.pattern-grid-tall{max-height:400px}}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:13px;font-weight:600;color:#333;margin-bottom:8px}.form-select,.form-input{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;color:#333;background:white;transition:all .15s ease}.form-select:focus,.form-input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.pattern-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;max-height:300px;overflow-y:auto;padding:4px}.pattern-grid-tall{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;overflow-y:auto;padding:4px;flex:1;min-height:0}.pattern-card{padding:12px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .15s ease;background:white}.pattern-card:hover{border-color:#4a90e2;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.pattern-card.selected{border-color:#4a90e2;background:#f5f9ff;box-shadow:0 0 0 3px #4a90e21a}.pattern-name{font-weight:600;font-size:14px;color:#333;margin-bottom:4px}.pattern-style{font-size:11px;color:#4a90e2;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.pattern-description{font-size:12px;color:#666;line-height:1.4}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px;border:1px solid #e0e0e0;border-radius:6px;transition:all .15s ease}.radio-label:hover{background:#f9f9f9;border-color:#ccc}.radio-label input[type=radio]{cursor:pointer}.radio-label input[type=radio]:disabled{cursor:not-allowed}.radio-label:has(input[type=radio]:checked){background:#f5f9ff;border-color:#4a90e2}.radio-label:has(input[type=radio]:disabled){opacity:.5;cursor:not-allowed;background:#f9f9f9}.warning-message{padding:10px 12px;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;font-size:13px;color:#856404;margin-bottom:12px}.modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-primary{background:#4A90E2;color:#fff}.btn-primary:hover:not(:disabled){background:#357ABD;transform:translateY(-1px);box-shadow:0 2px 8px #4a90e24d}.btn-primary:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.btn-secondary{background:white;color:#666;border:1px solid #e0e0e0}.btn-secondary:hover{background:#f5f5f5;border-color:#999}.pattern-grid::-webkit-scrollbar,.pattern-grid-tall::-webkit-scrollbar,.modal-body::-webkit-scrollbar,.modal-column-right::-webkit-scrollbar{width:8px}.pattern-grid::-webkit-scrollbar-track,.pattern-grid-tall::-webkit-scrollbar-track,.modal-body::-webkit-scrollbar-track,.modal-column-right::-webkit-scrollbar-track{background:#f1f3f5}.pattern-grid::-webkit-scrollbar-thumb,.pattern-grid-tall::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb,.modal-column-right::-webkit-scrollbar-thumb{background:#adb5bd;border-radius:4px}.pattern-grid::-webkit-scrollbar-thumb:hover,.pattern-grid-tall::-webkit-scrollbar-thumb:hover,.modal-body::-webkit-scrollbar-thumb:hover,.modal-column-right::-webkit-scrollbar-thumb:hover{background:#6c757d}.bass-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .2s ease}.bass-modal{background:white;border-radius:12px;max-width:1000px;width:90%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.bass-modal .modal-header{padding:20px 24px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.bass-modal .modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.bass-modal .btn-close{width:32px;height:32px;border:none;background:transparent;font-size:28px;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s ease;line-height:1;padding:0}.bass-modal .btn-close:hover{background:#f5f5f5;color:#333}.bass-modal .modal-body{padding:24px;overflow-y:auto;flex:1}.bass-modal .modal-body-two-column{display:grid;grid-template-columns:1fr 350px;gap:24px;padding:24px;overflow-y:auto;flex:1;min-height:0}.bass-modal .modal-column{display:flex;flex-direction:column;min-height:0}.bass-modal .modal-column-left{min-width:0}.bass-modal .modal-column-right{overflow-y:auto}@media (max-width: 768px){.bass-modal .modal-body-two-column{grid-template-columns:1fr;gap:16px;padding:16px}.bass-modal .modal-column-left{order:2}.bass-modal .modal-column-right{order:1;overflow-y:visible}.bass-modal .pattern-grid-tall{max-height:400px}}.bass-modal .form-group{margin-bottom:20px}.bass-modal .form-group:last-child{margin-bottom:0}.bass-modal .form-label{display:block;font-size:13px;font-weight:600;color:#333;margin-bottom:8px}.bass-modal .form-select,.bass-modal .form-input{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;color:#333;background:white;transition:all .15s ease}.bass-modal .form-select:focus,.bass-modal .form-input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.bass-modal .pattern-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;max-height:300px;overflow-y:auto;padding:4px}.bass-modal .pattern-grid-tall{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;overflow-y:auto;padding:4px;flex:1;min-height:0}.bass-modal .pattern-card{padding:12px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .15s ease;background:white}.bass-modal .pattern-card:hover{border-color:#4a90e2;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.bass-modal .pattern-card.selected{border-color:#4a90e2;background:#f5f9ff;box-shadow:0 0 0 3px #4a90e21a}.bass-modal .pattern-name{font-weight:600;font-size:14px;color:#333;margin-bottom:4px}.bass-modal .pattern-style{font-size:11px;color:#4a90e2;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.bass-modal .pattern-description{font-size:12px;color:#666;line-height:1.4}.bass-modal .radio-group{display:flex;flex-direction:column;gap:10px}.bass-modal .radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px;border:1px solid #e0e0e0;border-radius:6px;transition:all .15s ease}.bass-modal .radio-label:hover{background:#f9f9f9;border-color:#ccc}.bass-modal .radio-label input[type=radio]{cursor:pointer}.bass-modal .radio-label input[type=radio]:disabled{cursor:not-allowed}.bass-modal .radio-label:has(input[type=radio]:checked){background:#f5f9ff;border-color:#4a90e2}.bass-modal .radio-label:has(input[type=radio]:disabled){opacity:.5;cursor:not-allowed;background:#f9f9f9}.bass-modal .warning-message{padding:10px 12px;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;font-size:13px;color:#856404;margin-bottom:12px}.bass-modal .error-message{padding:8px 10px;background:#ffebee;border:1px solid #ef5350;border-radius:4px;font-size:12px;color:#c62828;margin-top:6px}.bass-modal .help-text{font-size:11px;color:#888;margin-top:6px;line-height:1.4}.bass-modal .mode-toggle{display:flex;gap:0;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;background:#f9f9f9}.bass-modal .mode-btn{flex:1;padding:8px 12px;border:none;background:transparent;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .15s ease}.bass-modal .mode-btn:not(:last-child){border-right:1px solid #e0e0e0}.bass-modal .mode-btn:hover{background:#f0f0f0}.bass-modal .mode-btn.active{background:#4A90E2;color:#fff}.bass-modal .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#333}.bass-modal .checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.bass-modal .progression-group{padding-left:16px;border-left:3px solid #e0e0e0}.bass-modal .progression-info{margin-top:12px;padding:10px 12px;background:#f5f9ff;border:1px solid #4A90E2;border-radius:6px}.bass-modal .progression-notation{font-size:14px;font-weight:600;color:#4a90e2;margin-bottom:4px}.bass-modal .progression-desc{font-size:12px;color:#666}.bass-modal .input-error{border-color:#ef5350!important}.bass-modal .input-error:focus{box-shadow:0 0 0 3px #ef53501a!important}.bass-modal .modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0}.bass-modal .btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.bass-modal .btn-primary{background:#4A90E2;color:#fff}.bass-modal .btn-primary:hover:not(:disabled){background:#357ABD;transform:translateY(-1px);box-shadow:0 2px 8px #4a90e24d}.bass-modal .btn-primary:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.bass-modal .btn-secondary{background:white;color:#666;border:1px solid #e0e0e0}.bass-modal .btn-secondary:hover{background:#f5f5f5;border-color:#999}.bass-modal .pattern-grid::-webkit-scrollbar,.bass-modal .pattern-grid-tall::-webkit-scrollbar,.bass-modal .modal-body::-webkit-scrollbar,.bass-modal .modal-column-right::-webkit-scrollbar{width:8px}.bass-modal .pattern-grid::-webkit-scrollbar-track,.bass-modal .pattern-grid-tall::-webkit-scrollbar-track,.bass-modal .modal-body::-webkit-scrollbar-track,.bass-modal .modal-column-right::-webkit-scrollbar-track{background:#f1f3f5}.bass-modal .pattern-grid::-webkit-scrollbar-thumb,.bass-modal .pattern-grid-tall::-webkit-scrollbar-thumb,.bass-modal .modal-body::-webkit-scrollbar-thumb,.bass-modal .modal-column-right::-webkit-scrollbar-thumb{background:#adb5bd;border-radius:4px}.bass-modal .pattern-grid::-webkit-scrollbar-thumb:hover,.bass-modal .pattern-grid-tall::-webkit-scrollbar-thumb:hover,.bass-modal .modal-body::-webkit-scrollbar-thumb:hover,.bass-modal .modal-column-right::-webkit-scrollbar-thumb:hover{background:#6c757d}.track-editor-full-page{display:flex;flex-direction:column;height:100%;min-height:calc(100vh - 100px);background:white}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid #e0e0e0;background:white;flex-shrink:0}.editor-title{display:flex;flex-direction:row;align-items:flex-start;gap:8px}.title-row,.subtitle-row{display:flex;align-items:center;gap:6px}.editor-title h2{margin:0;font-size:18px;font-weight:600;color:#333}.btn-edit-metadata{background:transparent;border:none;cursor:pointer;font-size:14px;padding:2px 6px;opacity:.5;transition:opacity .15s ease;display:flex;align-items:center;justify-content:center;margin-top:2px}.btn-edit-metadata:hover{opacity:1}.editor-title-edit{display:flex;flex-direction:column;gap:8px}.track-name-input{font-size:18px;font-weight:600;padding:6px 10px;border:1px solid #4A90E2;border-radius:4px;outline:none;background:white;min-width:400px;box-shadow:0 1px 3px #0000001a}.track-name-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.track-description-input{font-size:14px;font-weight:400;color:#666;padding:6px 10px;border:1px solid #cbd5e1;border-radius:4px;outline:none;background:white;min-width:400px}.track-description-input:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.editor-title-edit{display:flex;flex-direction:row;gap:8px;align-items:flex-start}.editor-title-edit>div{display:flex;flex-direction:column;gap:6px}.editor-subtitle{font-size:13px;color:#888}.edit-icon-btn{background:transparent;border:none;cursor:pointer;font-size:14px;padding:2px 4px;opacity:.5;transition:opacity .15s ease;display:flex;align-items:center;justify-content:center}.edit-icon-btn:hover{opacity:1}.editor-actions{display:flex;gap:8px;align-items:center}.draft-indicator{font-size:12px;color:#888;background:#fff8e1;padding:4px 10px;border-radius:12px;border:1px solid #ffd54f;font-weight:500}.editor-layout{display:flex;flex:1;overflow:auto;min-height:0}.editor-main{display:flex;flex-direction:column;flex:1;overflow:auto;min-height:0}.editor-toolbar{display:flex;align-items:center;gap:16px;padding:10px 16px;background:#fafafa;border-bottom:1px solid #e0e0e0;flex-wrap:wrap;flex-shrink:0}.toolbar-group{display:flex;align-items:center;gap:6px}.toolbar-group label{font-size:12px;color:#666;font-weight:500}.toolbar-group.stats{margin-left:auto}.stat{font-size:12px;color:#888;background:color: var(--color-onSurface);padding:4px 10px;border-radius:10px;border:1px solid #e0e0e0}.transpose-select{padding:4px 8px;border:1px solid #d0d0d0;border-radius:4px;font-size:12px;background:white;cursor:pointer;transition:border-color .15s ease;min-width:60px}.transpose-select:hover{border-color:#999}.transpose-select:focus{outline:none;border-color:#4a90e2}.zoom-value{font-size:12px;color:#666;font-weight:500;min-width:40px;text-align:center}.btn.btn-sm{padding:4px 10px;font-size:13px;min-width:32px}.btn.btn-sm.active{background:#4A90E2;color:#fff;border-color:#357abd}.editor-content{flex:1;overflow:auto;padding:1rem;background:#fafafa;min-height:0}.no-part-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#999}.no-part-selected p{margin-bottom:1rem}.editor-info-panel{padding:1rem 1.5rem;background:#f8f8f8;border-top:1px solid #e0e0e0;max-height:200px;overflow-y:auto}.editor-info-panel h3{margin:0 0 .75rem;font-size:1rem;color:#333}.editor-info-panel h4{margin:1rem 0 .5rem;font-size:.875rem;color:#666;font-weight:600}.editor-info-panel ul{margin:0;padding-left:1.5rem;font-size:.875rem;color:#666;line-height:1.6}.part-stats{display:flex;gap:1.5rem;font-size:.875rem;color:#666}.part-stats div{background:white;padding:.25rem .75rem;border-radius:4px;border:1px solid #e0e0e0}.btn{padding:6px 14px;border:1px solid #d0d0d0;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;background:background: var(--primary);transition:all .15s ease}.btn.btn-primary{background:#4A90E2;color:#fff;border-color:#357abd}.btn.btn-primary:hover:not(:disabled){background:#357ABD}.btn.btn-secondary{background:#888;color:#fff;border-color:#666}.btn.btn-secondary:hover:not(:disabled){background:#666}.btn.btn-danger{background:#E74C3C;color:#fff;border-color:#c0392b}.btn.btn-danger:hover:not(:disabled){background:#C0392B}.btn.btn-accent{background:#9C27B0;color:#fff;border-color:#7b1fa2}.btn.btn-accent:hover:not(:disabled){background:#7B1FA2}.btn.btn-help{background:white;color:#666;border-color:#d0d0d0;font-size:16px;padding:4px 10px}.btn.btn-help:hover:not(:disabled){background:#f5f5f5;border-color:#999}.shortcuts-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shortcuts-panel{background:white;border-radius:12px;width:90%;max-width:700px;max-height:80vh;overflow:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out;display:flex;flex-direction:column}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e0e0e0;background:linear-gradient(to bottom,#f8f8f8,#fff)}.shortcuts-header h3{margin:0;font-size:1.25rem;color:#333}.shortcuts-content{padding:1.5rem;max-height:calc(80vh - 80px);overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.shortcuts-section{background:#f8f9fa;padding:1rem;border-radius:8px}.shortcuts-section h4{margin:0 0 .75rem;font-size:.875rem;color:#666;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e0e0e0}.shortcut-item:last-child{border-bottom:none}.shortcut-item kbd{background:white;color:#333;padding:.25rem .5rem;border-radius:4px;border:1px solid #ccc;font-family:monospace;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px #0000001a;white-space:nowrap}.shortcut-item span{font-size:.875rem;color:#666}.btn-close{background:none;border:none;font-size:1.75rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-close:hover{background:#f0f0f0;color:#333}@media (max-width: 1024px){.editor-layout{flex-direction:column}.part-controls-panel{width:100%;height:200px;border-right:none;border-bottom:1px solid #dee2e6}.parts-list{display:flex;gap:.25rem;overflow-x:auto}.part-control{min-width:280px}}@media (max-width: 768px){.track-editor-full-page{min-height:100vh}.editor-toolbar{flex-direction:column;align-items:stretch}.toolbar-group{justify-content:space-between}.toolbar-group.stats{margin-left:0}}.track-editor-page{display:flex;flex-direction:column;min-height:100vh;background:#f5f7fa}.track-editor-container{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.track-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;background:color: var(--color-onSurface);border-radius:12px;box-shadow:0 2px 8px #0000001a}.track-title h1{margin:0 0 .5rem;font-size:1.75rem;color:#333}.track-title p{margin:0;color:#666;font-size:.95rem}.track-actions{display:flex;gap:.75rem;align-items:center}.btn-import,.btn-save{padding:.625rem 1.25rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-import{background:#f0f0f0;color:#333}.btn-import:hover{background:#e0e0e0}.btn-save{background:#2196F3;color:#fff}.btn-save:hover{background:#1976D2}.player-section{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:1rem}.playback-controls{display:flex;justify-content:center;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.btn-play,.btn-stop{padding:.75rem 2rem;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.btn-play{background:#4CAF50;color:#fff}.btn-play:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.btn-stop{background:#f44336;color:#fff}.btn-stop:hover{background:#da190b;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.loading,.error{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.1rem;color:#666}.error{color:#f44336}@media (max-width: 768px){.track-editor-container{padding:1rem}.track-header{flex-direction:column;gap:1rem}.track-actions{width:100%;justify-content:stretch}.btn-import,.btn-save{flex:1}}.profile-layout{min-height:calc(100vh - 60px);display:flex;flex-direction:column;background:var(--color-background);padding:20px}.profile-header{background:var(--color-surface);border-bottom:1px solid var(--color-divider);padding:1rem 2rem;box-shadow:var(--elevation-2)}.profile-header h1{margin:0;color:var(--color-onSurface);font-size:1.5rem}.profile-content{display:flex;flex:1;overflow:auto;width:100%;min-height:0}.profile-sidebar{width:250px;min-width:250px;background:var(--color-surface);border-right:1px solid var(--color-divider);padding:1rem 0;overflow-y:auto;display:flex;flex-direction:column}.profile-nav-link{display:block;padding:.75rem 1.5rem;color:var(--color-onSurface);text-decoration:none;transition:all .2s;border-left:3px solid transparent;border:none;background:transparent;text-align:left;font-size:1rem;cursor:pointer;font-family:inherit}.profile-nav-link:hover{background:var(--color-surfaceVariant);color:var(--color-primary)}.profile-nav-link.active{background:var(--color-surfaceVariant);color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.profile-nav-signout{margin-top:auto}.profile-nav-signout:hover{background-color:#f443361a;color:#f44336}.profile-main{flex:1;overflow-y:auto;padding:2rem;background:var(--color-background);width:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg);max-width:400px;width:90%;box-shadow:var(--elevation-8)}.modal-content h2{margin:0 0 var(--spacing-md) 0;color:var(--color-onSurface);font-size:1.25rem}.modal-content p{margin:0 0 var(--spacing-lg) 0;color:var(--color-onSurface);font-size:.875rem}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}@media (max-width: 768px){.profile-content{flex-direction:column}.profile-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-divider);display:flex;overflow-x:auto;padding:0}.profile-nav-link{flex:1;text-align:center;border-left:none;border-bottom:3px solid transparent;white-space:nowrap}.profile-nav-link.active{border-left:none;border-bottom-color:var(--color-primary)}.profile-main{padding:1rem}}.profile-account-container{max-width:800px}.profile-section{margin-bottom:var(--spacing-lg);position:relative}.profile-section h2{margin-top:0;margin-bottom:var(--spacing-md);color:var(--color-onSurface);font-size:1.5rem}.section-description{color:var(--color-disabled);margin-bottom:var(--spacing-md);font-size:.875rem}.profile-info{display:flex;flex-direction:column;gap:var(--spacing-md)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-divider)}.info-row:last-child{border-bottom:none}.info-row label{font-weight:600;color:var(--color-onSurface);font-size:.875rem}.info-row span{color:var(--color-onSurface);font-size:.875rem}.text-disabled{color:var(--color-disabled)!important;font-family:monospace;font-size:.75rem!important}.avatar-desktop{position:absolute;top:-12px;right:-12px;display:inline-block}.avatar-mobile{display:none}.info-row-with-avatar{align-items:center;margin-top:10px}.info-row-content{display:flex;justify-content:space-between;align-items:center;flex:1}.avatar-toggle-btn{position:absolute;bottom:0;left:0;width:32px;height:32px;border-radius:50%;background:var(--color-surface);border:2px solid var(--color-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--elevation-2);padding:0}.avatar-toggle-btn:hover{transform:scale(1.1);box-shadow:var(--elevation-4);background:var(--color-surface);border-color:var(--color-primaryVariant, var(--color-primary))}.visibility-icon{position:relative;width:18px;height:18px;display:flex;align-items:center;justify-content:center}.eye-shape{width:18px;height:11px;border:2px solid var(--color-primary);border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center}.eye-shape:after{content:"";width:6px;height:6px;background:var(--color-primary);border-radius:50%;position:absolute}.slash-line{position:absolute;width:20px;height:2px;background:var(--color-primary);transform:rotate(-45deg);top:50%;left:50%;margin-left:-10px;margin-top:-1px}.avatar-toggle-btn:hover .eye-shape,.avatar-toggle-btn:hover .slash-line{border-color:var(--color-primaryVariant, var(--color-primary));background:var(--color-primaryVariant, var(--color-primary))}.avatar-toggle-btn:hover .eye-shape:after{background:var(--color-primaryVariant, var(--color-primary))}.display-name-container{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-edit{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:var(--spacing-xs);font-size:1rem;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);display:flex;align-items:center;justify-content:center;width:28px;height:28px}.btn-edit:hover{background-color:var(--color-surfaceVariant)}.edit-name-container{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%}.edit-name-input{width:100%;padding:var(--spacing-sm);border:2px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.875rem;background:var(--color-surface);color:var(--color-onSurface)}.edit-name-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 98, 0, 238),.1)}.edit-name-actions{display:flex;gap:var(--spacing-xs)}.edit-name-error{color:#c00;font-size:.75rem;margin-top:var(--spacing-xs)}.settings-placeholder{padding:var(--spacing-xl);text-align:center;color:var(--color-disabled);background:var(--color-surfaceVariant);border-radius:var(--radius-sm)}.settings-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.setting-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-divider);gap:var(--spacing-lg)}.setting-item:last-child{border-bottom:none}.setting-info{flex:1}.setting-label{font-weight:600;color:var(--color-onSurface);font-size:.875rem;display:block;margin-bottom:var(--spacing-xs)}.setting-description{color:var(--color-disabled);font-size:.813rem;line-height:1.4;margin:0}.toggle-switch{position:relative;display:inline-block;width:48px;height:28px;flex-shrink:0;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-divider);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 98, 0, 238),.2)}@media (max-width: 768px){.profile-section h2{margin-right:0}.avatar-desktop{display:none}.avatar-mobile{display:inline-block;position:relative;margin-left:var(--spacing-md)}.info-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.info-row-with-avatar{flex-direction:row;justify-content:space-between;align-items:center;margin-top:-10px}.info-row-content{flex-direction:column;align-items:flex-start}}.profile-subscriptions-container{max-width:900px}.profile-section h2{margin:0;color:var(--color-onSurface);font-size:1.5rem}.subscriptions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.loading-state,.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-disabled)}.subscriptions-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.subscription-item{border:1px solid var(--color-divider);border-radius:var(--radius-sm);padding:var(--spacing-md);background:var(--color-background);transition:box-shadow var(--transition-fast)}.subscription-item:hover{box-shadow:var(--elevation-2)}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);gap:var(--spacing-md)}.subscription-content{font-weight:600;color:var(--color-onSurface);font-size:1rem}.subscription-type-badge{padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;white-space:nowrap}.type-free_trial{background:#e3f2fd;color:#1976d2}.type-ad_supported{background:#fff3e0;color:#f57c00}.type-purchase{background:#e8f5e9;color:#388e3c}.type-paid_subscription{background:#f3e5f5;color:#7b1fa2}.subscription-dates{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.date-item{display:flex;flex-direction:column;gap:.25rem}.date-label{font-size:.75rem;color:var(--color-disabled);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.date-item span:last-child{font-size:.875rem;color:var(--color-onSurface)}@media (max-width: 768px){.subscriptions-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.subscription-header{flex-direction:column;align-items:flex-start}}.profile-appearance-container{max-width:900px}.profile-section h2{margin:0;margin-bottom:var(--spacing-md);color:var(--color-onSurface);font-size:1.5rem}.section-description{color:var(--color-disabled);font-size:.875rem;margin-bottom:var(--spacing-lg)}.theme-section-divider{margin:1.5rem 0;border:none;border-top:2px solid var(--color-divider)}.card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--elevation-2)}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.theme-card{border:2px solid transparent;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-fast);background-color:var(--color-background)}.theme-card:hover{transform:translateY(-2px);box-shadow:var(--elevation-4)}.theme-card.active{border-color:var(--color-primary);box-shadow:var(--elevation-4)}.theme-preview{height:70px;position:relative;display:flex;align-items:center;justify-content:center}.active-indicator{width:48px;height:48px;background-color:#ffffffe6;border-radius:var(--radius-round);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#4caf50;box-shadow:var(--elevation-4)}.theme-info{padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:.25rem}.theme-info h3{font-size:1rem;font-weight:500;color:var(--color-onSurface);margin:0}.theme-info .next-date{font-size:.75rem;color:var(--color-onSurface);opacity:.7}.premium-badge{background:linear-gradient(135deg,#ffd700,#ffa000);color:#000;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.125rem .5rem;border-radius:var(--radius-sm)}.theme-colors{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--color-divider)}.color-dot{width:24px;height:24px;border-radius:var(--radius-round);border:2px solid var(--color-divider)}.favorite-btn{position:absolute;top:8px;right:8px;background:rgba(255,255,255,.9);border:none;border-radius:var(--radius-round);width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;color:gold;transition:all var(--transition-fast);box-shadow:var(--elevation-2);z-index:10}.favorite-btn:hover{transform:scale(1.2);box-shadow:var(--elevation-4);background:rgba(255,255,255,1)}.theme-toggle-container{display:inline-flex;background:var(--color-surface);border-radius:8px;padding:.25rem;box-shadow:var(--elevation-2);margin-bottom:var(--spacing-md)}.theme-toggle-container .theme-toggle-btn{padding:1.25rem 3.5rem;font-weight:500;font-size:.875rem}.theme-toggle-btn{padding:.5rem 1.25rem;border:none;background:transparent;color:var(--color-onSurface);border-radius:6px;cursor:pointer;transition:all .2s}.theme-toggle-btn:hover{background:var(--color-background)}.theme-toggle-btn.active{background:var(--color-primary);color:var(--color-onPrimary);font-weight:600}.theme-card.locked{border:2px dashed #9e9e9e;opacity:.7;cursor:default}.theme-card.locked:hover{transform:none;box-shadow:var(--elevation-2)}.watch-ad-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:var(--radius-round);background:rgba(0,0,0,.7);border:3px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all var(--transition-fast);z-index:5}.watch-ad-btn:hover{transform:translate(-50%,-50%) scale(1.1);background:rgba(0,0,0,.9)}.lock-indicators{position:absolute;bottom:8px;right:8px;display:flex;gap:4px;background-color:#0009;padding:4px 8px;border-radius:12px;z-index:5}.lock-indicators span{font-size:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}@media (max-width: 768px){.theme-grid{grid-template-columns:1fr}}.profile-cache-container h2{margin-top:0;margin-bottom:1rem;color:var(--color-onBackground)}.cache-disclaimer{background:var(--color-surfaceVariant);border-left:4px solid var(--color-primary);padding:1rem;margin-bottom:1.5rem;border-radius:var(--radius-sm)}.cache-disclaimer p{margin:0;font-size:.875rem;color:var(--color-onSurface);line-height:1.5}.cache-disclaimer strong{color:var(--color-primary);font-weight:600}.cache-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--elevation-2)}.stat-label{font-size:.875rem;color:var(--color-disabled);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-onSurface)}.cache-actions{display:flex;justify-content:flex-end;margin-bottom:1.5rem}.databases-list{display:flex;flex-direction:column;gap:1rem}.database-card{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-md);padding:1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--elevation-1);transition:box-shadow var(--transition-fast)}.database-card:hover{box-shadow:var(--elevation-3)}.database-info{flex:1}.database-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.database-header h3{margin:0;font-size:1.125rem;color:var(--color-onSurface);font-weight:600}.database-stats{display:flex;gap:1rem;align-items:center}.database-count,.database-size{font-size:.813rem;color:var(--color-disabled);background:var(--color-surfaceVariant);padding:.25rem .75rem;border-radius:var(--radius-sm)}.database-name{font-size:.813rem;color:var(--color-disabled);font-family:Courier New,monospace}.database-actions{margin-left:1rem}.loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-disabled);font-size:.938rem}.empty-state{background:var(--color-surface);border:2px dashed var(--color-divider);border-radius:var(--radius-md);padding:3rem;text-align:center}.empty-state p{margin:0;color:var(--color-disabled);font-size:.938rem}.success-message,.error-message{padding:.875rem 1.25rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem;font-weight:500}.profile-cache-container .btn-danger{background:var(--color-error);color:#fff;border:none;font-weight:500}.profile-cache-container .btn-danger:hover:not(:disabled){background:#d32f2f;box-shadow:var(--elevation-2)}.profile-cache-container .btn-danger:disabled{opacity:.6;cursor:not-allowed}.profile-cache-container .btn-sm{padding:.5rem 1rem;font-size:.875rem}.take-stage-modal{max-width:1000px;min-width:720px;max-height:90vh;overflow-y:auto;position:relative}.take-stage-header{text-align:center;margin-bottom:24px;padding-top:1rem}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:var(--color-onSurface);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease;z-index:10}.modal-close:hover{background-color:#0000000d}.take-stage-header h2{font-size:2rem;margin:0 0 8px;color:var(--color-primary)}.take-stage-subtitle{font-size:1rem;color:var(--color-onSurface-muted);margin:0}.take-stage-step{margin-bottom:24px}.take-stage-step h3{font-size:1.5rem;margin:0 0 16px}.step-description{color:var(--color-onSurface-muted);margin-bottom:20px}.info-notice{display:flex;gap:12px;background:var(--color-surface-variant);padding:16px;border-radius:8px;margin-bottom:24px;border-left:4px solid var(--color-primary)}.info-icon{font-size:24px;flex-shrink:0}.info-text{flex:1}.info-text strong{display:block;margin-bottom:8px}.info-text ul{margin:8px 0;padding-left:20px}.info-text li{margin-bottom:4px}.warning-text{margin-top:12px;padding:8px;background:rgba(255,152,0,.1);border-radius:4px;color:var(--color-warning, #ff9800)}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:var(--color-onSurface)}.form-group .required{color:var(--color-error, #f44336)}.form-group .help-text{font-size:.875rem;color:var(--color-onSurface-muted);margin-top:4px;display:block}.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:10px 12px;border:1px solid var(--color-divider);border-radius:6px;font-size:1rem;background:var(--color-surface);color:var(--color-onSurface)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-group input.error{border-color:var(--color-error, #f44336)}.form-group input.success{border-color:var(--color-success, #4caf50)}.alias-input-group{position:relative;display:flex;align-items:center;gap:8px}.alias-input-group .checking,.alias-input-group .available,.alias-input-group .unavailable{font-size:.875rem;font-weight:600;white-space:nowrap}.alias-input-group .checking{color:var(--color-onSurface-muted)}.alias-input-group .available{color:var(--color-success, #4caf50)}.alias-input-group .unavailable{color:var(--color-error, #f44336)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-group{margin-bottom:16px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.error-message{padding:12px;background:rgba(244,67,54,.1);border-left:4px solid var(--color-error, #f44336);border-radius:4px;color:var(--color-error, #f44336);margin-bottom:16px}.modal-actions{display:flex;justify-content:space-between;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-divider)}.modal-actions .btn{flex:1;padding:12px 24px;font-size:1rem;font-weight:600}.chartboard-benefits{background:linear-gradient(135deg,var(--color-primary-variant) 0%,var(--color-secondary-variant) 100%);padding:20px;border-radius:8px;margin-top:24px}.chartboard-benefits h4{margin:0 0 12px;color:var(--color-onPrimary, white)}.chartboard-benefits ul{list-style:none;padding:0;margin:0 0 16px}.chartboard-benefits li{padding:8px 0;color:var(--color-onPrimary, white);opacity:.95}.chartboard-benefits li strong{display:block;margin-bottom:2px}.benefits-footer{margin:16px 0 0;padding:12px;background:rgba(255,255,255,.1);border-radius:4px;color:var(--color-onPrimary, white);font-size:.875rem}@media (max-width: 640px){.take-stage-modal{max-width:100%;min-width:400px;margin:0;border-radius:0}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.chartboard-streak-card{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);padding:32px;border-radius:12px;color:#fff;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}.streak-main{text-align:center}.streak-number-large{font-size:4rem;font-weight:700;line-height:1;margin-bottom:8px}.streak-label{font-size:1.25rem;opacity:.9}.streak-stats{display:flex;flex-direction:row;gap:16px}.streak-stat{display:flex;flex-direction:column;align-items:flex-end}.stat-label{font-size:.875rem;opacity:.8;margin-bottom:4px}.stat-value{font-size:1.5rem;font-weight:600}.chartboard-section{background:var(--color-surface);padding:24px;border-radius:8px;margin-bottom:24px;box-shadow:var(--elevation-1)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{margin:0}.demographics-display{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.demo-item{display:flex;justify-content:space-between;padding:12px;background:var(--color-surface-variant);border-radius:6px}.demo-label{font-weight:600;color:var(--color-onSurface-muted)}.demo-value{font-weight:500;color:var(--color-onSurface)}.demographics-edit .form-group{margin-bottom:16px}.demographics-edit label{display:block;font-weight:600;margin-bottom:8px;color:var(--color-onSurface)}.demographics-edit input[type=text],.demographics-edit input[type=number],.demographics-edit select{width:100%;padding:10px 12px;border:1px solid var(--color-divider);border-radius:6px;font-size:1rem;background:var(--color-surface);color:var(--color-onSurface)}.demographics-edit .checkbox-group label{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer}.demographics-edit .checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}.leaderboard-controls{display:flex;align-items:center;gap:12px;margin-bottom:20px}.leaderboard-controls label{font-weight:600}.leaderboard-controls select{padding:8px 12px;border:1px solid var(--color-divider);border-radius:6px;background:var(--color-surface);color:var(--color-onSurface)}.leaderboard-summary{margin-bottom:16px;padding:12px;background:var(--color-surface-variant);border-radius:6px;text-align:center}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.leaderboard-entry{display:flex;align-items:center;padding:12px 16px;background:var(--color-surface-variant);border-radius:6px;transition:transform .2s ease}.leaderboard-entry:hover{transform:translate(4px)}.leaderboard-entry.current-user{background:linear-gradient(90deg,var(--color-primary-variant) 0%,var(--color-surface-variant) 100%);border-left:4px solid var(--color-primary);font-weight:600}.entry-rank{font-size:1.25rem;font-weight:700;color:var(--color-primary);min-width:60px}.entry-info{flex:1;margin-left:12px}.entry-alias{font-size:1rem;font-weight:600}.entry-meta{font-size:.875rem;color:var(--color-onSurface-muted);margin-top:2px}.entry-score{font-size:1.125rem;font-weight:700;color:var(--color-onSurface);min-width:80px;text-align:right}.empty-state{text-align:center;padding:60px 20px}.empty-icon{font-size:4rem;margin-bottom:16px}.empty-state h3{font-size:1.5rem;margin:0 0 12px}.empty-state p{color:var(--color-onSurface-muted);margin-bottom:24px}.loading{text-align:center;padding:40px;color:var(--color-onSurface-muted)}@media (max-width: 768px){.chartboard-streak-card{flex-direction:column;gap:24px}.streak-stats{flex-direction:row;justify-content:space-around;width:100%}.streak-stat{align-items:center}.demographics-display{grid-template-columns:1fr}.leaderboard-entry{flex-wrap:wrap}.entry-rank{min-width:50px}.entry-score{min-width:60px}}.store-container{min-height:100vh;background:var(--background)}.store-content{max-width:1200px;margin:0 auto;padding:2rem}.store-header{text-align:center;margin-bottom:4rem}.store-header h1{font-size:3rem;font-weight:700;color:var(--on-background);margin-bottom:.5rem}.store-subtitle{font-size:1.25rem;color:var(--on-background-muted);margin:0}.store-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:4rem}.store-category-card{background:var(--surface);border-radius:16px;padding:3rem 2rem;text-align:center;box-shadow:0 4px 12px #0000001a;transition:all .3s;cursor:pointer}.store-category-card:hover{transform:translateY(-8px);box-shadow:0 8px 24px #00000026}.category-icon{font-size:4rem;margin-bottom:1rem}.store-category-card h2{font-size:1.75rem;font-weight:600;color:var(--on-surface);margin-bottom:.75rem}.store-category-card p{font-size:1rem;color:var(--on-surface-muted);margin-bottom:1.5rem;line-height:1.5}.store-category-card .btn{padding:.75rem 2rem;border-radius:8px;font-weight:600;font-size:.875rem;border:none;cursor:pointer;transition:all .2s;background:var(--primary);color:var(--on-primary)}.store-category-card .btn:hover{opacity:.9;transform:translateY(-2px)}.store-info{margin-top:5rem;text-align:center}.store-info h2{font-size:2rem;font-weight:600;color:var(--on-background);margin-bottom:2rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.info-item{padding:2rem 1.5rem;text-align:center}.info-icon{font-size:3rem;margin-bottom:1rem}.info-item h3{font-size:1.25rem;font-weight:600;color:var(--on-background);margin-bottom:.5rem}.info-item p{font-size:.875rem;color:var(--on-background-muted);line-height:1.6;margin:0}@media (max-width: 768px){.store-content{padding:1.5rem}.store-header h1{font-size:2rem}.store-subtitle{font-size:1rem}.store-categories{grid-template-columns:1fr;gap:1.5rem}.store-category-card{padding:2rem 1.5rem}.info-grid{grid-template-columns:1fr;gap:1.5rem}}.store-themes-container{min-height:100vh;background:var(--background)}.store-themes-content{max-width:1200px;margin:0 auto;padding:2rem}.store-themes-header{margin-bottom:3rem;text-align:center}.store-themes-header h1{font-size:2.5rem;font-weight:700;color:var(--on-background);margin-bottom:.5rem}.store-themes-subtitle{font-size:1.125rem;color:var(--on-background-muted);margin:0}.themes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-bottom:2rem}.theme-card{background:var(--surface);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;position:relative}.theme-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.theme-preview-wrapper{position:relative}.theme-preview-wrapper .badge{position:absolute;top:0;right:8px;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;z-index:10;letter-spacing:.5px}.store-subscriptions-container .badge{position:absolute;top:12px;right:12px;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;z-index:10;letter-spacing:.5px}.badge-premium{background:#f59e0b;color:#fff}.badge-unlocked{background:#3b82f6;color:#fff}.badge-limited{background:#ef4444;color:#fff;margin-right:.5rem}.store-themes-container .theme-preview{height:150px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:1.5rem!important}.theme-preview-card{border-radius:8px;padding:1rem;box-shadow:0 4px 6px #0000001a;min-width:120px}.theme-preview-button{padding:.5rem 1rem;border-radius:6px;font-weight:600;text-align:center;font-size:.875rem}.store-themes-container .theme-info{padding:1.5rem!important}.theme-info h3{font-size:1.25rem;font-weight:600;color:var(--on-surface);margin:0 0 .5rem}.theme-description{font-size:.875rem;color:var(--on-surface-muted);margin:0 0 1rem;line-height:1.5}.theme-limited{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.theme-expires{font-size:.75rem;color:var(--on-surface-muted)}.theme-card-actions{padding:0 1.5rem 1.5rem}.theme-actions{display:flex;flex-direction:column;gap:.75rem}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;border:none;cursor:pointer;transition:all .2s;text-align:center}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-secondary{background:var(--surface-variant);color:var(--on-surface-variant);border:1px solid var(--outline)}.btn-secondary:hover:not(:disabled){background:var(--surface-variant);opacity:.8;transform:translateY(-1px)}@media (max-width: 768px){.store-themes-content{padding:1.5rem}.store-themes-header h1{font-size:2rem}.themes-grid{grid-template-columns:1fr;gap:1.5rem}.theme-card-actions{padding:0 1rem 1rem}.theme-info{padding:1rem}}.store-subscriptions-container{min-height:100vh;background:var(--background)}.store-subscriptions-container .btn{flex:none}.store-subscriptions-content{max-width:1400px;margin:0 auto;padding:2rem}.store-subscriptions-header{text-align:center;margin-bottom:4rem}.store-subscriptions-header h1{font-size:2.5rem;font-weight:700;color:var(--on-background);margin-bottom:.5rem}.store-subscriptions-subtitle{font-size:1.125rem;color:var(--on-background-muted);margin:0}.loading{text-align:center;padding:4rem;font-size:1.25rem;color:var(--on-background-muted)}.success-message{background:#efe;border:1px solid #cfc;border-radius:8px;padding:1rem 1.25rem;margin-bottom:2rem;color:#060;display:flex;justify-content:space-between;align-items:center;font-weight:500}.success-message .btn-close{color:#060}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem 1.25rem;margin-bottom:2rem;color:#c00;display:flex;justify-content:space-between;align-items:center}.btn-close{background:none;border:none;font-size:1.5rem;color:#c00;cursor:pointer;padding:0;margin-left:1rem;line-height:1}.btn-close:hover{opacity:.7}.subscription-section{margin-bottom:4rem}.subscription-section h2{font-size:2rem;font-weight:600;color:var(--on-background);margin-bottom:1rem}.section-description{font-size:1rem;color:var(--on-background-muted);margin-bottom:2rem;text-align:center}.subscriptions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.subscription-card{background:var(--surface);border-radius:16px;padding:2.5rem 2rem;box-shadow:0 4px 12px #0000001a;transition:all .3s;position:relative;display:flex;flex-direction:column;border:2px solid transparent}.subscription-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.ad-removal-section{margin-bottom:3rem}.ad-removal-section h2{font-size:1.5rem;margin-bottom:1.5rem}.subscriptions-grid-compact{display:flex;flex-direction:column;gap:1rem}.subscription-card-compact{background:var(--surface);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .2s;position:relative;border:2px solid var(--primary)}.subscription-card-compact:hover{box-shadow:0 4px 12px #00000026}.compact-content{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1rem}.compact-left{display:flex;align-items:center;gap:1rem;flex:1}.subscription-icon-small{font-size:2rem}.subscription-card-compact h3{font-size:1.25rem;font-weight:600;color:var(--on-surface);margin:0 0 .25rem}.subscription-description-compact{font-size:.875rem;color:var(--on-surface-muted);margin:0;line-height:1.4}.compact-right{display:flex;align-items:center;gap:1.5rem}.subscription-price-compact{text-align:right;margin-top:25px;position:relative}.savings-badge{position:absolute;top:-20px;right:0;background:#10b981;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.price-amount-compact{font-size:2rem;font-weight:700;color:var(--on-surface)}.price-period-compact{font-size:.875rem;color:var(--on-surface-muted);margin-left:.25rem}.feature-list-compact{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem;max-width:100%}@supports (grid-template-columns: subgrid){.feature-list-compact{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (min-width: 900px){.feature-list-compact{grid-template-columns:repeat(3,1fr)}}.feature-list-compact li{padding:.25rem 0;color:var(--on-surface);font-size:.875rem;display:flex;align-items:flex-start;line-height:1.4}.section-header-with-toggle{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.billing-toggle{display:flex;background:var(--surface);border-radius:8px;padding:.25rem;box-shadow:0 2px 4px #0000001a}.toggle-btn{padding:.5rem 1.25rem;border:none;background:transparent;color:var(--on-surface);font-weight:500;font-size:.875rem;border-radius:6px;cursor:pointer;transition:all .2s}.toggle-btn:hover{background:var(--surface-variant)}.toggle-btn.active{background:var(--primary);color:var(--on-primary);font-weight:600}.store-subscriptions-container .badge{position:absolute;top:12px;right:12px;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;z-index:-99}.badge-active{background:#10b981;color:#fff}.badge-available{background:#3b82f6;color:#fff}.subscription-icon{font-size:4rem;text-align:center;margin-bottom:1.5rem}.subscription-card h3{font-size:1.75rem;font-weight:600;color:var(--on-surface);margin-bottom:.75rem;text-align:center}.subscription-description{font-size:.9375rem;color:var(--on-surface-muted);margin-bottom:1.5rem;text-align:center;line-height:1.6;min-height:3rem}.tier-highlight{text-align:center;padding:.75rem;background:var(--primary);color:var(--on-primary);border-radius:8px;margin-bottom:1.5rem;font-size:.9375rem}.tier-highlight strong{font-weight:700;font-size:1.25rem}.subscription-price{text-align:center;margin-bottom:2rem}.price-amount{font-size:3rem;font-weight:700;color:var(--on-surface)}.price-period{font-size:1rem;color:var(--on-surface-muted);margin-left:.25rem}.feature-list{list-style:none;padding:0;margin:0 0 2rem;flex:1}.feature-list li{padding:.75rem 0;color:var(--on-surface);font-size:.9375rem;display:flex;align-items:flex-start;line-height:1.5}.feature-check{color:#10b981;font-weight:700;margin-right:.75rem;font-size:1.125rem}.btn{padding:.875rem 1.5rem;border-radius:8px;font-weight:600;font-size:.9375rem;border:none;cursor:pointer;transition:all .2s;text-align:center;height:3rem;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--on-primary)}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}.btn-block{width:100%}.empty-state{text-align:center;padding:4rem 2rem;color:var(--on-background-muted)}.empty-state p{font-size:1.125rem;margin:0}@media (max-width: 768px){.store-subscriptions-content{padding:1.5rem}.store-subscriptions-header h1{font-size:2rem}.subscription-section h2{font-size:1.5rem}.subscriptions-grid{grid-template-columns:1fr;gap:1.5rem}.subscription-card{padding:2rem 1.5rem}.price-amount{font-size:2.5rem}.compact-content{flex-direction:column;align-items:flex-start;gap:1rem}.compact-left{width:100%}.compact-right{width:100%;justify-content:space-between}.feature-list-compact{grid-template-columns:1fr}.section-header-with-toggle{flex-direction:column;gap:1rem}.billing-toggle{width:100%;justify-content:center}}.privacy-policy-container{min-height:100vh;background-color:var(--color-background);display:flex;flex-direction:column}.privacy-policy-content{max-width:900px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg);color:var(--color-onBackground)}.privacy-policy-content h1{font-size:2.5rem;margin-bottom:var(--spacing-sm);color:var(--color-onBackground);font-weight:700}.last-updated{color:var(--color-disabled);font-size:.875rem;margin-bottom:var(--spacing-xl);font-style:italic}.policy-section{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-divider)}.policy-section:last-of-type{border-bottom:none}.policy-section h2{font-size:1.75rem;margin-bottom:var(--spacing-md);color:var(--color-onBackground);font-weight:600}.policy-section h3{font-size:1.25rem;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm);color:var(--color-onBackground);font-weight:600}.policy-section p{margin-bottom:var(--spacing-md);line-height:1.8;color:var(--color-onBackground)}.policy-section ul{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md);list-style-type:disc}.policy-section li{margin-bottom:var(--spacing-sm);line-height:1.8;color:var(--color-onBackground)}.policy-section li strong{color:var(--color-onBackground);font-weight:600}.policy-section a{color:var(--color-primary);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.policy-section a:hover{border-bottom-color:var(--color-primary)}.contact-info{background:var(--color-surface);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0;border-left:4px solid var(--color-primary)}.contact-info p{margin-bottom:var(--spacing-xs)}.contact-info p:last-child{margin-bottom:0}.policy-footer{margin-top:var(--spacing-xxl);padding-top:var(--spacing-xl);border-top:2px solid var(--color-divider);text-align:center}.policy-footer p{color:var(--color-disabled);font-size:.875rem;margin-bottom:var(--spacing-sm)}.copyright{font-weight:600;color:var(--color-onBackground)!important}@media (max-width: 768px){.privacy-policy-content{padding:var(--spacing-lg) var(--spacing-md)}.privacy-policy-content h1{font-size:2rem}.policy-section h2{font-size:1.5rem}.policy-section h3{font-size:1.125rem}.policy-section ul{margin-left:var(--spacing-md)}}@media print{.privacy-policy-container{background:white}.privacy-policy-content{max-width:100%;padding:0;color:#000}.policy-section a{color:#000;text-decoration:underline}}.apk-download-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--background)}.apk-download-card{max-width:600px;width:100%;background:var(--surface);border-radius:12px;padding:3rem;box-shadow:0 4px 6px #0000001a;text-align:center}.apk-download-title{font-size:2rem;font-weight:700;margin-bottom:1.5rem;color:var(--text-primary)}.apk-download-icon{font-size:4rem;margin-bottom:1.5rem}.apk-download-description{font-size:1.125rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.apk-download-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;text-align:left}.apk-feature{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--background);border-radius:8px}.apk-feature-icon{color:var(--primary);font-weight:700;font-size:1.25rem}.apk-download-button{display:inline-block;padding:1rem 2.5rem;background:var(--primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.125rem;transition:all .2s;margin-bottom:2rem}.apk-download-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.apk-download-info{text-align:left;background:var(--background);padding:1.5rem;border-radius:8px;margin-top:2rem}.apk-download-info h3{margin-bottom:1rem;color:var(--text-primary)}.apk-download-info ol{margin-left:1.5rem;margin-bottom:1rem;color:var(--text-secondary)}.apk-download-info ol li{margin-bottom:.5rem}.apk-download-note,.apk-download-requirements{font-size:.875rem;color:var(--text-secondary);margin-top:1rem;line-height:1.6}.apk-download-note strong,.apk-download-requirements strong{color:var(--text-primary)}@media (max-width: 640px){.apk-download-card{padding:2rem 1.5rem}.apk-download-title{font-size:1.5rem}.apk-download-icon{font-size:3rem}}.admin-layout{min-height:calc(100vh - 60px);display:flex;flex-direction:column;background:var(--color-background)}.admin-header{background:var(--color-surface);border-bottom:1px solid var(--color-divider);padding:1rem 2rem;box-shadow:var(--elevation-2)}.admin-header h1{margin:0;color:var(--color-onSurface);font-size:1.5rem}.admin-content{display:flex;flex:1;overflow:auto;min-height:0}.admin-sidebar{width:250px;background:var(--color-surface);border-right:1px solid var(--color-divider);padding:1rem 0;overflow-y:auto}.admin-nav-link{display:block;padding:.75rem 1.5rem;color:var(--color-onSurface);text-decoration:none;transition:all .2s;border-left:3px solid transparent}.admin-nav-link:hover{background:var(--color-surfaceVariant);color:var(--color-primary)}.admin-nav-link.active{background:var(--color-surfaceVariant);color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.admin-main{flex:1;overflow-y:auto;padding:2rem;background:var(--color-background)}.access-denied{text-align:center;padding:3rem;background:var(--color-surface);border-radius:var(--radius-md);margin:2rem;box-shadow:var(--elevation-2)}.admin-users-container{max-width:1200px;margin:0 auto;padding:2rem}.admin-users-container h2{margin-bottom:2rem;color:var(--color-onBackground)}.access-denied{text-align:center;padding:3rem;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2)}.access-denied h2{color:var(--color-error);margin-bottom:1rem}.admin-search{margin-bottom:2rem}.admin-search form{display:flex;gap:1rem}.admin-search input{flex:1;padding:.75rem;border:1px solid var(--color-divider);border-radius:var(--radius-sm);font-size:1rem;background:var(--color-surface);color:var(--color-onSurface)}.admin-search button{padding:.75rem 2rem;background:var(--color-primary);color:var(--color-onPrimary);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;transition:all var(--transition-fast)}.admin-search button:hover{background:var(--color-primaryVariant);box-shadow:var(--elevation-2)}.loading{text-align:center;padding:2rem;color:var(--color-disabled)}.users-table{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);overflow:hidden}.users-table table{width:100%;border-collapse:collapse}.users-table th{background:var(--color-surfaceVariant);padding:1rem;text-align:left;font-weight:600;color:var(--color-onSurface);border-bottom:2px solid var(--color-divider)}.users-table td{padding:1rem;border-bottom:1px solid var(--color-divider);color:var(--color-onSurface)}.users-table tr:last-child td{border-bottom:none}.role-badges{display:flex;flex-wrap:wrap;gap:.5rem}.role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.role-badge-none{background:#e9ecef;color:#6c757d}.role-badge-admin{background:#dc3545;color:#fff}.role-badge-user_admin{background:#fd7e14;color:#fff}.role-badge-store_admin{background:#20c997;color:#fff}.role-badge-store_manager{background:#17a2b8;color:#fff}.role-remove{background:rgba(255,255,255,.3);border:none;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;line-height:1;padding:0}.role-remove:hover{background:rgba(255,255,255,.5)}.btn-grant{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:all var(--transition-fast)}.btn-grant:hover{background:#388e3c;box-shadow:var(--elevation-2)}.modal-body{margin-bottom:1.5rem}.modal-body label{display:block;margin-bottom:1rem;font-weight:500;color:var(--color-onSurface)}.modal-body select,.modal-body textarea{width:100%;padding:.75rem;border:1px solid var(--color-divider);border-radius:var(--radius-sm);font-size:1rem;margin-top:.5rem;background:var(--color-surface);color:var(--color-onSurface)}.modal-body textarea{min-height:100px;resize:vertical}.btn-primary{background:var(--color-primary)!important;color:var(--color-onPrimary)!important}.btn-primary:hover{background:var(--color-primaryVariant)!important;box-shadow:var(--elevation-2)}.btn-primary:disabled{background:var(--color-disabled)!important;cursor:not-allowed;opacity:.5}.btn-danger{background:var(--color-error)!important;color:var(--color-onError)!important}.btn-danger:hover{background:var(--color-error)!important;box-shadow:var(--elevation-2);filter:brightness(.9)}.admin-container{min-height:100vh;display:flex;flex-direction:column;background:var(--surface-background)}.admin-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem}.admin-content h1{margin-bottom:2rem;color:var(--primary)}.admin-controls{display:flex;gap:1rem;align-items:center;margin-bottom:2rem;padding:1rem;background:var(--surface);border-radius:8px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--surface);padding:1.5rem;border-radius:8px;text-align:center;box-shadow:0 2px 4px #0000001a}.stat-value{font-size:2rem;font-weight:700;color:var(--primary);margin-bottom:.5rem}.stat-label{font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.tracks-table{background:var(--surface);border-radius:8px;overflow:auto;box-shadow:0 2px 4px #0000001a}.tracks-table table{width:100%;border-collapse:collapse}.tracks-table thead{background:var(--primary);color:#fff}.tracks-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.tracks-table td{padding:1rem;border-bottom:1px solid var(--border)}.tracks-table tbody tr:hover{background:var(--surface-hover)}.tracks-table tbody tr:last-child td{border-bottom:none}.deleted-track{opacity:.6;background:rgba(255,0,0,.05)}.track-name{font-weight:600;margin-bottom:.25rem}.track-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.track-id{font-size:.75rem;color:var(--text-tertiary);font-family:monospace}.email{font-size:.875rem;color:var(--text-secondary)}.date-cell{font-size:.875rem;white-space:nowrap}.status-active{display:inline-block;padding:.25rem .75rem;background:#10b981;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-deleted{display:inline-block;padding:.25rem .75rem;background:#ef4444;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600}.empty-row{text-align:center;padding:3rem!important;color:var(--text-secondary)}.loading{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.125rem}.btn-danger{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:600;transition:background .2s}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.375rem .75rem;font-size:.875rem}@media (prefers-color-scheme: dark){.tracks-table,.stat-card{box-shadow:0 2px 4px #0000004d}.deleted-track{background:rgba(255,0,0,.1)}}.admin-themes-container{padding:0}.admin-themes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-themes-header h2{margin:0}.sync-btn{padding:.5rem 1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:8px;padding:1.5rem;text-align:center}.stat-card h3{margin:0 0 .5rem;font-size:.875rem;font-weight:500;color:var(--color-onBackground);opacity:.7}.admin-main .stat-value{font-size:2rem}.stat-value.success{color:#10b981}.stat-value.warning{color:#f59e0b}.themes-table-container{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:8px;overflow:hidden}.themes-table{width:100%;border-collapse:collapse}.themes-table thead{background:var(--color-background);border-bottom:2px solid var(--color-divider)}.themes-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--color-onBackground);text-transform:uppercase;letter-spacing:.05em}.themes-table td{padding:1rem;border-bottom:1px solid var(--color-divider)}.themes-table tbody tr:hover{background:var(--color-background)}.theme-name-cell{display:flex;align-items:center;gap:.75rem}.theme-color-preview{width:40px;height:40px;border-radius:6px;border:2px solid var(--color-divider);flex-shrink:0}.theme-display-name{font-weight:600;color:var(--color-onSurface)}.theme-internal-name{font-size:.75rem;color:var(--color-onSurface);opacity:.6;font-family:monospace}.theme-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.badge-free{background:#10b981;color:#fff}.badge-premium{background:#8b5cf6;color:#fff}.badge-seasonal{background:#f59e0b;color:#fff}.toggle-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.toggle-btn.enabled{background:#10b981;color:#fff}.toggle-btn.disabled{background:#6b7280;color:#fff}.toggle-btn.featured{background:#f59e0b;color:#fff}.toggle-btn.not-featured{background:transparent;color:var(--color-onSurface);border:1px solid var(--color-divider)}.toggle-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.display-order-input{width:80px;padding:.5rem;border:1px solid var(--color-divider);border-radius:6px;background:var(--color-background);color:var(--color-onSurface);font-size:.875rem}.display-order-input:focus{outline:none;border-color:var(--color-primary)}.date-cell{font-size:.875rem;color:var(--color-onSurface)}.btn-sm{padding:.5rem .75rem;font-size:.875rem}.modal-content{background:var(--color-surface);border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h3{margin:0 0 .5rem;color:var(--color-onSurface)}.modal-subtitle{margin:0 0 2rem;color:var(--color-onSurface);opacity:.7;font-size:.875rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-onSurface);font-size:.875rem}.form-group input{width:100%;padding:.75rem;border:1px solid var(--color-divider);border-radius:6px;background:var(--color-background);color:var(--color-onSurface);font-size:.875rem}.form-group input:focus{outline:none;border-color:var(--color-primary)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.error-message,.success-message{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.error-message{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.success-message{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;color:inherit;opacity:.6}.btn-close:hover{opacity:1}.loading{text-align:center;padding:2rem;color:var(--color-onBackground);opacity:.7}.admin-subscriptions-container{max-width:1400px}.subscriptions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.subscriptions-header h2{margin:0;color:var(--color-onBackground)}.btn-primary{padding:.75rem 1.5rem;background:var(--color-primary);color:var(--color-onPrimary);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;transition:all var(--transition-fast)}.btn-primary:hover{background:var(--color-primaryVariant);box-shadow:var(--elevation-2)}.btn-primary:disabled{background:var(--color-disabled);cursor:not-allowed;opacity:.5}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-md);box-shadow:var(--elevation-2)}.stat-value.active{color:#4caf50}.stat-value.inactive{color:var(--color-error)}.filters-section{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-md);box-shadow:var(--elevation-2);margin-bottom:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:var(--color-onSurface)}.filter-group select,.filter-group input{padding:.5rem;border:1px solid var(--color-divider);border-radius:var(--radius-sm);font-size:.875rem;background:var(--color-surface);color:var(--color-onSurface)}.btn-clear-filters{padding:.5rem 1rem;background:var(--color-surfaceVariant);color:var(--color-onSurface);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;height:fit-content;transition:all var(--transition-fast)}.btn-clear-filters:hover{background:var(--color-divider);box-shadow:var(--elevation-2)}.alert{padding:1rem;margin-bottom:1rem;border-radius:var(--radius-sm);display:flex;justify-content:space-between;align-items:center}.alert-error{background:var(--color-error);color:var(--color-onError);border:1px solid var(--color-error)}.alert-success{background:#4caf50;color:#fff;border:1px solid #4caf50}.alert button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0 .5rem;opacity:.6}.alert button:hover{opacity:1}.loading{text-align:center;padding:3rem;color:var(--color-disabled)}.subscriptions-table-wrapper{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);overflow-x:auto}.subscriptions-table{width:100%;border-collapse:collapse;font-size:.875rem}.subscriptions-table thead{background:var(--color-surfaceVariant);position:sticky;top:0}.subscriptions-table th{padding:1rem;text-align:left;font-weight:600;color:var(--color-onSurface);border-bottom:2px solid var(--color-divider);white-space:nowrap}.subscriptions-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.subscriptions-table th.sortable:hover{background:var(--color-divider)}.subscriptions-table td{padding:1rem;border-bottom:1px solid var(--color-divider);color:var(--color-onSurface)}.subscriptions-table tr:hover{background:var(--color-surfaceVariant)}.user-cell{display:flex;flex-direction:column;gap:.25rem}.user-email{font-weight:500}.user-name{font-size:.75rem;color:var(--color-disabled)}.type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.type-free_trial{background:#e7f3ff;color:#007bff}.type-ad_supported{background:#fff3cd;color:#856404}.type-purchase{background:#d4edda;color:#155724}.type-paid_subscription{background:#d1ecf1;color:#0c5460}.content-cell{display:flex;flex-direction:column;gap:.25rem}.content-id{font-size:.75rem;color:var(--color-disabled)}.date-cell{font-size:.813rem;color:var(--color-onSurface);white-space:nowrap}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.btn-delete{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;opacity:.6;transition:opacity .2s}.btn-delete:hover{opacity:1}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;padding:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--color-surface);border-radius:var(--radius-md);padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--elevation-16)}.modal-large{max-width:600px}.modal h2{margin-top:0;margin-bottom:1.5rem;color:var(--color-onSurface)}.modal-body,.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-onSurface)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--color-divider);border-radius:var(--radius-sm);font-size:1rem;background:var(--color-surface);color:var(--color-onSurface)}.form-group textarea{min-height:100px;resize:vertical}.help-text{font-size:.75rem;color:var(--color-disabled);margin-top:.25rem}.user-search{position:relative}.search-results{position:absolute;top:100%;left:0;right:0;background:var(--color-surface);border:1px solid var(--color-divider);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);max-height:200px;overflow-y:auto;z-index:10;box-shadow:var(--elevation-4)}.search-result-item{padding:.75rem;cursor:pointer;transition:background var(--transition-fast);color:var(--color-onSurface)}.search-result-item:hover{background:var(--color-surfaceVariant)}.search-result-item .small{font-size:.75rem;color:var(--color-disabled);margin-top:.25rem}.selected-user{margin-top:.5rem;padding:.5rem;background:var(--color-surfaceVariant);border-radius:var(--radius-sm);color:var(--color-primary);font-size:.875rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end}.modal-footer button{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;transition:all var(--transition-fast)}.modal-footer button:first-child{background:var(--color-surfaceVariant);color:var(--color-onSurface)}.modal-footer button:first-child:hover{background:var(--color-divider);box-shadow:var(--elevation-2)}.admin-database-container h2{margin-top:0;margin-bottom:2rem;color:var(--color-onBackground)}.database-layout{display:flex;gap:1.5rem;height:calc(100vh - 200px)}.database-sidebar{width:250px;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);overflow:hidden;display:flex;flex-direction:column}.database-sidebar h3{margin:0;padding:1rem;background:var(--color-surfaceVariant);border-bottom:1px solid var(--color-divider);font-size:1rem;color:var(--color-onSurface)}.table-list{overflow-y:auto;flex:1}.table-item{width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-divider);display:flex;flex-direction:column;gap:.25rem;color:var(--color-onSurface)}.table-item:hover{background:var(--color-surfaceVariant)}.table-item.active{background:var(--color-surfaceVariant);color:var(--color-primary);font-weight:600}.table-name-small{font-size:.75rem;color:var(--color-disabled);font-weight:400}.database-main{flex:1;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);padding:1.5rem;overflow:hidden;display:flex;flex-direction:column}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid var(--color-divider)}.table-header h3{margin:0;color:var(--color-onSurface)}.table-stats{font-size:.875rem;color:var(--color-disabled)}.table-wrapper{flex:1;overflow:auto;border:1px solid var(--color-divider);border-radius:var(--radius-sm)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{position:sticky;top:0;background:var(--color-surfaceVariant);z-index:1}.data-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--color-onSurface);border-bottom:2px solid var(--color-divider);white-space:nowrap}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background:var(--color-divider)}.data-table th.sorted{background:var(--color-surfaceVariant);color:var(--color-primary)}.th-content{display:flex;align-items:center;gap:.5rem}.sort-indicator{font-size:1rem;line-height:1}.column-type{font-size:.75rem;color:var(--color-disabled);font-weight:400;margin-top:.25rem}.data-table td{padding:.75rem;border-bottom:1px solid var(--color-divider);max-width:300px;color:var(--color-onSurface)}.data-table tr:hover{background:var(--color-surfaceVariant)}.cell-content{overflow:hidden;text-overflow:ellipsis;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.data-table th.actions-column,.data-table td.actions-column{text-align:center;width:120px;min-width:120px;max-width:120px}.data-table th.actions-column{cursor:default!important}.data-table th.actions-column:hover{background:var(--color-surfaceVariant)!important}.data-table td.actions-column .btn{font-size:.75rem;padding:.375rem .75rem;white-space:nowrap}.data-table td.actions-column .btn-danger{background:var(--color-error);border-color:var(--color-error);color:#fff}.data-table td.actions-column .btn-danger:hover:not(:disabled){background:#d32f2f;border-color:#d32f2f;box-shadow:var(--elevation-2)}.data-table td.actions-column .btn-danger:disabled{opacity:.5;cursor:not-allowed}.admin-cache-container h2{margin-top:0;margin-bottom:1.5rem;color:var(--color-onBackground)}.cache-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--color-surface);padding:1rem 1.5rem;border-radius:var(--radius-md);box-shadow:var(--elevation-2);flex:1}.stat-label{font-size:.875rem;color:var(--color-disabled);margin-bottom:.5rem}.admin-main .stat-value{font-size:1.5rem;font-weight:600}.cache-layout{display:flex;gap:1.5rem;height:calc(100vh - 300px)}.cache-sidebar{width:250px;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);overflow:hidden;display:flex;flex-direction:column}.cache-sidebar h3{margin:0;padding:1rem;background:var(--color-surfaceVariant);border-bottom:1px solid var(--color-divider);font-size:1rem;color:var(--color-onSurface)}.pattern-list{overflow-y:auto;flex:1}.pattern-item{width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-divider);display:flex;justify-content:space-between;align-items:center;color:var(--color-onSurface)}.pattern-item:hover{background:var(--color-surfaceVariant)}.pattern-item.active{background:var(--color-surfaceVariant);color:var(--color-primary);font-weight:600}.pattern-name{font-size:.875rem}.pattern-count{font-size:.75rem;color:var(--color-disabled);background:var(--color-surfaceVariant);padding:.125rem .5rem;border-radius:12px}.pattern-item.active .pattern-count{background:var(--color-primary);color:var(--color-onPrimary)}.cache-main{flex:1;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);padding:1.5rem;overflow:hidden;display:flex;flex-direction:column}.empty-state,.loading,.error{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-disabled)}.error{color:var(--color-error)}.keys-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.key-card{border:1px solid var(--color-divider);border-radius:var(--radius-sm);overflow:hidden}.key-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-surfaceVariant);cursor:pointer;transition:background var(--transition-fast)}.key-header:hover{background:var(--color-divider)}.key-info{flex:1}.key-name{font-family:Courier New,monospace;font-size:.875rem;color:var(--color-onSurface);margin-bottom:.25rem;word-break:break-all}.key-meta{display:flex;gap:1rem;font-size:.75rem;color:var(--color-disabled)}.key-type{background:var(--color-surfaceVariant);color:var(--color-primary);padding:.125rem .5rem;border-radius:var(--radius-sm);font-weight:500}.expand-btn{background:none;border:none;font-size:1.25rem;color:var(--color-onSurface);cursor:pointer;padding:.25rem .5rem;line-height:1}.key-value{padding:1rem;background:var(--color-surfaceVariant);border-top:1px solid var(--color-divider)}.key-value pre{margin:0;font-family:Courier New,monospace;font-size:.813rem;color:var(--color-onSurface);white-space:pre-wrap;word-break:break-all;max-height:400px;overflow-y:auto}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-divider)}.pagination button{padding:.5rem 1rem;border:1px solid var(--color-primary);background:var(--color-surface);color:var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.pagination button:hover:not(:disabled){background:var(--color-primary);color:var(--color-onPrimary);box-shadow:var(--elevation-2)}.pagination button:disabled{border-color:var(--color-divider);color:var(--color-disabled);cursor:not-allowed;opacity:.5}.pagination span{color:var(--color-onSurface);font-size:.875rem}.success-message,.error-message{padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem}.success-message{background:rgba(76,175,80,.1);color:#4caf50;border:1px solid rgba(76,175,80,.3)}.error-message{background:rgba(244,67,54,.1);color:var(--color-error);border:1px solid rgba(244,67,54,.3)}.pattern-item-wrapper{position:relative;display:flex;align-items:stretch;border-bottom:1px solid var(--color-divider)}.pattern-item-wrapper .pattern-item{flex:1;border-bottom:none}.delete-pattern-btn{background:none;border:none;border-left:1px solid var(--color-divider);color:var(--color-error);cursor:pointer;padding:0 .75rem;font-size:1.25rem;line-height:1;transition:all var(--transition-fast);min-width:40px}.delete-pattern-btn:hover:not(:disabled){background:rgba(244,67,54,.1)}.delete-pattern-btn:disabled{opacity:.5;cursor:not-allowed}.key-actions{display:flex;align-items:center;gap:.5rem}.delete-key-btn{background:var(--color-error);color:#fff;border:none;padding:.375rem .75rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;font-weight:500;transition:all var(--transition-fast)}.delete-key-btn:hover:not(:disabled){background:#d32f2f;box-shadow:var(--elevation-2)}.delete-key-btn:disabled{opacity:.5;cursor:not-allowed}.support-container{max-width:1200px;margin:0 auto;padding:2rem}.support-container h1{margin-bottom:2rem;color:#333}.access-denied{text-align:center;padding:3rem;background:#f8f9fa;border-radius:8px}.access-denied h2{color:#dc3545;margin-bottom:1rem}.support-info{margin-bottom:2rem}.info-card{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.info-card h3{margin-top:0;margin-bottom:1rem;color:#495057}.role-list{display:flex;flex-wrap:wrap;gap:.5rem}.role-badge{display:inline-block;padding:.5rem 1rem;border-radius:12px;font-size:.875rem;font-weight:500}.role-badge-support_admin{background:#6f42c1;color:#fff}.role-badge-support_manager{background:#6610f2;color:#fff}.role-badge-support{background:#007bff;color:#fff}.support-content{background:white;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.support-content h2{margin-top:0;color:#333}.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.feature-item{padding:1.5rem;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.feature-item h3{margin-top:0;margin-bottom:.5rem;color:#495057}.feature-item p{margin:0;color:#6c757d}.midi-demo-container{min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:2rem}.midi-demo-header{text-align:center;color:#fff;margin-bottom:3rem}.midi-demo-header h1{font-size:3rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.midi-demo-header .subtitle{font-size:1.2rem;opacity:.9}.midi-demo-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:2rem}.info-panel,.controls-panel,.parts-panel,.log-panel,.technical-panel{background:white;border-radius:12px;padding:2rem;box-shadow:0 10px 30px #0003}.info-panel h2,.controls-panel h2,.parts-panel h2,.log-panel h2,.technical-panel h2{margin-top:0;color:#667eea;font-size:1.5rem;margin-bottom:1rem}.info-panel ul{list-style:none;padding:0}.info-panel li{padding:.5rem 0;border-bottom:1px solid #f0f0f0}.info-panel li:last-child{border-bottom:none}.info-panel strong{color:#764ba2;display:inline-block;min-width:150px}.controls-panel{display:flex;flex-direction:column;gap:1.5rem}.parts-panel{display:flex;flex-direction:column;gap:1rem}.parts-list{display:flex;flex-direction:column}.part-row{padding:.75rem;background:#f7fafc;border-radius:8px;transition:background .2s}.part-row:hover{background:#edf2f7}.part-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.part-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.part-toggle input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.part-name{font-size:1.1rem;font-weight:500;color:#2d3748}.part-toggle input[type=checkbox]:not(:checked)+.part-name{color:#a0aec0;text-decoration:line-through}.btn-analyze{background:#9f7aea;color:#fff}.btn-analyze:hover:not(:disabled){background:#805ad5;transform:translateY(-2px);box-shadow:0 5px 15px #9f7aea66}.button-group{display:flex;gap:1rem;flex-wrap:wrap}.btn-primary,.btn-secondary,.btn-tertiary{padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;flex:1;min-width:150px}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-secondary{background:#f56565;color:#fff}.btn-secondary:hover:not(:disabled){background:#e53e3e;transform:translateY(-2px);box-shadow:0 5px 15px #f5656566}.btn-tertiary{background:#48bb78;color:#fff}.btn-tertiary:hover:not(:disabled){background:#38a169;transform:translateY(-2px);box-shadow:0 5px 15px #48bb7866}button:disabled{opacity:.5;cursor:not-allowed}.status-indicator{padding:1rem;background:#f7fafc;border-radius:8px;text-align:center;font-size:1.1rem}.error-message{padding:1rem;background:#fff5f5;border:1px solid #fc8181;border-radius:8px;color:#c53030}.log-panel{grid-column:1 / -1}.log-content{background:#1a202c;color:#e2e8f0;padding:1rem;border-radius:8px;font-family:Courier New,monospace;font-size:.9rem;max-height:400px;overflow-y:auto}.log-entry{padding:.25rem 0;border-bottom:1px solid #2d3748}.log-entry:last-child{border-bottom:none}.log-empty{color:#718096;font-style:italic;text-align:center;padding:2rem}.technical-panel{grid-column:1 / -1}.tech-details{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.tech-details h3{color:#764ba2;font-size:1.2rem;margin-top:0;margin-bottom:1rem}.tech-details ul,.tech-details ol{padding-left:1.5rem}.tech-details li{margin-bottom:.5rem;line-height:1.6}.tech-details code{background:#f7fafc;padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:#d53f8c}@media (max-width: 768px){.midi-demo-content{grid-template-columns:1fr}.log-panel,.technical-panel{grid-column:1}.tech-details{grid-template-columns:1fr}.button-group{flex-direction:column}.btn-primary,.btn-secondary,.btn-tertiary{width:100%}}.classification-panel{grid-column:1 / -1;background:white;border-radius:12px;padding:2rem;box-shadow:0 10px 30px #0003}.classification-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.classification-header h2{margin:0;color:#667eea;font-size:1.5rem}.btn-close{background:none;border:none;font-size:1.5rem;color:#a0aec0;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s}.btn-close:hover{background:#edf2f7;color:#2d3748}.classification-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.classification-card{background:#f7fafc;border-radius:8px;padding:1.5rem;border-left:4px solid;transition:transform .2s,box-shadow .2s}.classification-card:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.category-rhythm{border-left-color:#f56565}.category-lead{border-left-color:#4299e1}.category-ensemble{border-left-color:#48bb78}.category-fx{border-left-color:#9f7aea}.card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;gap:1rem}.card-header h3{margin:0;font-size:1.1rem;color:#2d3748;flex:1}.category-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap}.badge-rhythm{background:#fed7d7;color:#c53030}.badge-lead{background:#bee3f8;color:#2c5282}.badge-ensemble{background:#c6f6d5;color:#2f855a}.badge-fx{background:#e9d8fd;color:#6b46c1}.confidence-bar{position:relative;height:24px;background:#edf2f7;border-radius:12px;overflow:hidden;margin-bottom:1rem}.confidence-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.confidence-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:#2d3748;text-shadow:0 1px 2px rgba(255,255,255,.8)}.heuristics{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.heuristic-item{display:flex;justify-content:space-between;font-size:.85rem;padding:.5rem;background:white;border-radius:4px}.heuristic-item .label{color:#718096;font-weight:500}.heuristic-item .value{color:#2d3748;font-weight:600}.reasoning-details{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.reasoning-details summary{cursor:pointer;font-weight:600;color:#667eea;padding:.5rem;border-radius:4px;transition:background .2s}.reasoning-details summary:hover{background:#edf2f7}.reasoning-list{list-style:none;padding:0;margin:1rem 0 0}.reasoning-list li{padding:.5rem;margin-bottom:.25rem;font-size:.85rem;color:#4a5568;background:white;border-radius:4px;border-left:2px solid #cbd5e0}.reasoning-list li:last-child{font-weight:600;color:#2d3748;border-left-color:#667eea}.app-wrapper{width:100%}.nav-bar{max-width:800px;margin:0 auto 30px;background:rgba(255,255,255,.15);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:8px;display:flex;gap:8px}.nav-bar button{flex:1;padding:12px 24px;background:transparent;border:none;color:#fff;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.nav-bar button:hover{background:rgba(255,255,255,.1)}.nav-bar button.active{background:white;color:#667eea;box-shadow:0 4px 12px #00000026}.app{width:100%}.card{background:white;border-radius:16px;padding:40px;box-shadow:0 20px 60px #0000004d}h1{margin:0 0 8px;font-size:32px;color:#1a1a1a}.subtitle{color:#666;margin:0 0 32px;font-size:16px}.button-group{display:flex;gap:12px;margin-bottom:24px}.btn{flex:1;padding:14px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-secondary{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);color:#fff}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #f5576c66}.error{background:#fee;border:1px solid #fcc;border-radius:8px;padding:16px;margin-bottom:24px;color:#c33}.error-help{margin:8px 0 0;font-size:14px;color:#666}.results{margin-top:32px}h2{margin:0 0 20px;font-size:24px;color:#1a1a1a}h3{margin:0 0 16px;font-size:18px;color:#1a1a1a}.time-display{background:linear-gradient(135deg,#667eea15 0%,#764ba215 100%);border-radius:12px;padding:24px;margin-bottom:24px}.time-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:18px}.time-item.highlight{background:rgba(102,126,234,.1);margin:0 -16px;padding:12px 16px;border-radius:8px}.time-item .label{font-weight:600;color:#555}.time-item .value{font-family:Courier New,monospace;font-size:20px;font-weight:700;color:#667eea}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-item{background:var(--color-surface);border-radius:var(--radius-sm);padding:20px;text-align:center;border:1px solid var(--color-divider)}.stat-label{display:block;font-size:14px;color:var(--color-onSurface);opacity:.7;margin-bottom:8px;font-weight:500}.stat-value{display:block;font-size:1.15rem;font-weight:700;color:var(--color-onSurface);font-family:Courier New,monospace}.explanation{background:#f8f9fa;border-radius:12px;padding:24px;margin-bottom:32px}.explanation ol{margin:16px 0;padding-left:24px}.explanation li{margin:8px 0;line-height:1.6}.explanation code{background:#e9ecef;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:14px}.explanation strong{color:#667eea}.note{background:white;padding:16px;border-radius:8px;margin-top:16px;border-left:4px solid #667eea;font-size:14px;line-height:1.6}.sync-history{background:#f8f9fa;border-radius:12px;padding:24px}.history-table{margin-top:16px}.history-header,.history-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;padding:12px;font-size:14px}.history-header{font-weight:600;color:#666;border-bottom:2px solid #dee2e6}.history-row{border-bottom:1px solid #e9ecef;font-family:Courier New,monospace}.history-row:last-child{border-bottom:none}.welcome{background:linear-gradient(135deg,#667eea15 0%,#764ba215 100%);border-radius:12px;padding:32px;text-align:center;margin-top:24px}.welcome p{margin:12px 0;color:#555;font-size:16px;line-height:1.6}@media (max-width: 600px){.card{padding:24px}h1{font-size:24px}.button-group{flex-direction:column}.stats{grid-template-columns:1fr}.history-header,.history-row{grid-template-columns:1fr;gap:4px}.history-header span:before,.history-row span:before{content:attr(data-label);font-weight:600;margin-right:8px}}:root{--font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", "Oxygen", "Ubuntu", sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--radius-sm: 0px;--radius-md: 12px;--radius-lg: 0px;--radius-round: 50%;--elevation-1: 0 1px 3px var(--color-shadow);--elevation-2: 0 2px 6px var(--color-shadow);--elevation-4: 0 4px 12px var(--color-shadow);--elevation-8: 0 8px 24px var(--color-shadow);--elevation-16: 0 16px 48px var(--color-shadow);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-onBackground);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn{font-family:var(--font-family);font-weight:500;font-size:14px;letter-spacing:.75px;text-transform:uppercase;padding:10px var(--spacing-md);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);min-width:64px;height:36px;position:relative;overflow:hidden}.btn:hover{box-shadow:var(--elevation-2);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background-color:var(--color-primary);color:var(--color-onPrimary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primaryVariant)}.btn-secondary{background-color:var(--color-secondary);color:var(--color-onSecondary)}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondaryVariant)}.btn-surface{background-color:var(--color-surface);color:var(--color-onSurface);box-shadow:var(--elevation-1)}.btn-surface:hover:not(:disabled){background-color:var(--color-surface);box-shadow:var(--elevation-4)}.btn-text{background-color:transparent;color:var(--color-onSurface);box-shadow:none;opacity:.7}.btn-text:hover:not(:disabled){background-color:#00000014;box-shadow:none;opacity:1;transform:none}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline;padding:0;font-size:inherit;font-weight:500;text-transform:none;letter-spacing:normal;box-shadow:none}.btn-link:hover:not(:disabled){color:var(--color-primaryVariant);transform:none;box-shadow:none}.btn-sm{padding:8px var(--spacing-sm);font-size:12px;min-width:48px;height:32px}.btn-lg{padding:12px var(--spacing-lg);font-size:16px;min-width:96px;height:44px}.card{background-color:var(--color-surface);color:var(--color-onSurface);border-radius:var(--radius-md);box-shadow:var(--elevation-2);padding:var(--spacing-md);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--elevation-4)}.card-clickable{cursor:pointer}.card-clickable:active{box-shadow:var(--elevation-8)}input,textarea,select{font-family:var(--font-family);font-size:16px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-divider);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-onSurface);transition:all var(--transition-fast);width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-surface);color:var(--color-onSurface);box-shadow:none}input:disabled,textarea:disabled,select:disabled{opacity:.5;cursor:not-allowed}label{display:block;font-weight:500;margin-bottom:var(--spacing-xs);color:var(--color-onSurface)}hr{border:none;height:1px;background-color:var(--color-divider);margin:var(--spacing-md) 0}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-error{color:var(--color-error)}.text-disabled{color:var(--color-disabled)}.error-message{background-color:var(--color-error);color:var(--color-onError);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);margin:var(--spacing-sm) 0;font-size:14px}.success-message{background-color:#4caf50;color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);margin:var(--spacing-sm) 0;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background-color:var(--color-surface);color:var(--color-onSurface);border-radius:var(--radius-md);box-shadow:var(--elevation-16);padding:var(--spacing-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-content h2{margin-bottom:var(--spacing-md);color:var(--color-onSurface)}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg)}.modal-actions .btn{min-width:100px}.form-group{margin-bottom:var(--spacing-md)}.container{max-width:1200px;margin:0 auto;padding:var(--spacing-md)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-disabled)}[data-theme=sixseven] body,[data-theme=sixseven] .btn,[data-theme=sixseven] input,[data-theme=sixseven] textarea,[data-theme=sixseven] select,[data-theme=sixseven] label,[data-theme=sixseven] h1,[data-theme=sixseven] h2,[data-theme=sixseven] h3,[data-theme=sixseven] h4,[data-theme=sixseven] h5,[data-theme=sixseven] h6,[data-theme=sixseven] p,[data-theme=sixseven] span{text-shadow:1px 0px #7A4FFF,-1px 0px #4CFFB3}
