.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:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.auth-container>.auth-card{flex:1;display:flex;flex-direction:column;justify-content:center;margin:auto}.auth-card{background:white;border-radius:12px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.auth-card h1{text-align:center;margin:0 0 5px;color:#667eea;font-size:36px;font-weight:700}.auth-card .tagline{text-align:center;margin:0 0 20px;color:#764ba2;font-size:14px;font-weight:500;text-transform:uppercase;letter-spacing:2px}.auth-card h2{text-align:center;margin:0 0 30px;color:#333;font-size:24px;font-weight:500}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;border:2px solid #e1e8ed;border-radius:8px;font-size:15px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f8fa;cursor:not-allowed}.btn{width:100%;padding:14px;border:none;border-radius:8px;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){transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.btn-google{background:white;border:2px solid #e1e8ed;color:#333;margin-top:16px}.btn-google:hover:not(:disabled){background:#f8f9fa;border-color:#d1d8dd}.btn-google svg{flex-shrink:0}.divider{text-align:center;margin:24px 0;color:#999;font-size:13px;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#e1e8ed}.divider:before{left:0}.divider:after{right:0}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.auth-link{text-align:center;margin-top:24px;color:#666;font-size:14px}.auth-link a{color:#667eea;text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.main-navigation{background-color:var(--color-surface);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);box-shadow:var(--elevation-2);position:relative;z-index:1000}.nav-header{display:flex;justify-content:space-between;align-items:center}.nav-logo{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-primary)}.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)}@media (max-width: 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:300px;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}}.metronome-container{height:100vh;background-color:var(--color-background);display:flex;flex-direction:column;overflow:hidden}.metronome-content{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}.metronome-beat-display{flex:1 1 50%;max-height:none}.metronome-controls{flex:0 0 400px;max-width:400px}}.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}.sound-toggle-btn{position:absolute;top:8px;right:8px;width:32px;height: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:18px;transition:all var(--transition-fast);box-shadow:var(--elevation-2);padding:0;z-index:10}.sound-toggle-btn:hover{transform:scale(1.1);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}.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)}.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:20px;left:50%;transform:translate(-50%);text-align:center;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{position:relative;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}.snowflake:before,.snowflake:after{content:"";position:absolute;top:50%;left:50%;width:60px;height:2px;background:#E0F7FF;transform:translate(-50%,-50%);box-shadow:0 0 10px #b0e0e6}.snowflake:before{transform:translate(-50%,-50%) rotate(60deg)}.snowflake:after{transform:translate(-50%,-50%) rotate(-60deg)}.snowflake-primary{width:100px;height:100px}.snowflake-primary:before,.snowflake-primary:after{width:80px;height:3px}.snowflake-subdivision{width:50px;height:50px}.snowflake-subdivision:before,.snowflake-subdivision:after{width:40px;height:1px}@keyframes snowfallSpin{0%{top:0;transform:scale(0) rotate(0);opacity:0}20%{top:10%;transform:scale(1) rotate(72deg);opacity:1}to{top:100%;transform:scale(.5) rotate(360deg);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{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.valentine-heart{position:relative;width:100px;height:100px}.valentine-heart:before{content:"";position:absolute;top:50%;left:50%;width:80px;height:80px;background:#FF1744;transform:translate(-50%,-50%) rotate(45deg);border-radius:50% 0 50% 50%;box-shadow:0 0 20px #ff174499}.heart-pulse-primary:before{animation:heartPulse .6s ease-in-out}.heart-pulse-offbeat:before{animation:heartPulse .4s ease-in-out}.heart-pulse-subdivision:before{animation:heartPulse .3s ease-in-out}.cupid-arrow{position:absolute;width:60px;height:3px;background:#FFD700;left:-70px;top:50%;transform:translateY(-50%) rotate(-30deg);animation:arrowPierce .4s ease-out forwards}.cupid-arrow:before{content:"";position:absolute;right:-8px;top:-3px;width:0;height:0;border-left:10px solid #FFD700;border-top:5px solid transparent;border-bottom:5px solid transparent}@keyframes heartPulse{0%,to{transform:translate(-50%,-50%) rotate(45deg) scale(1)}50%{transform:translate(-50%,-50%) rotate(45deg) scale(1.2)}}@keyframes arrowPierce{0%{left:-70px;opacity:1}60%{left:30px;opacity:1}to{left:30px;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}}.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:white;border-radius:12px;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 #e0e0e0}.player-header h2{margin:0;font-size:1.5rem}.btn-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#999;line-height:1;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}.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:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .1s linear}.progress-info{display:flex;justify-content:space-between;font-size:.85rem;color:#666}.player-controls-top{display:flex;justify-content:center;gap:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0;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:#f8f9fa;border-radius:8px}.tempo-number{font-size:2.5rem;font-weight:600;color:#333}.tempo-label{font-size:1rem;color:#666;text-transform:uppercase;letter-spacing:1px}.sections-preview{background:#f8f9fa;border-radius:8px;padding:1rem}.sections-preview h3{margin:0 0 .75rem;font-size:1rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.sections-list-compact{display:flex;flex-direction:column;gap:.5rem}.section-item-compact{display:flex;gap:.75rem;align-items:center;padding:.75rem;background:white;border-radius:6px;font-size:.9rem;border:2px solid transparent;transition:all .2s}.section-item-compact.active{border-color:#007bff;background:#e7f3ff;font-weight:600}.section-num{font-weight:600;color:#666;min-width:2rem}@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:#2196f3;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:#666;margin-top:1rem;font-weight:500}.track-start-info{display:flex;justify-content:space-around;gap:1rem;margin:2rem 0;padding:1.5rem;background:#f5f5f5;border-radius:8px}.info-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.info-label{font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1.25rem;font-weight:600;color:#333}.leader-controls{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0;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:#f5f5f5;border-radius:8px}.performance-track-info h3{margin:0 0 .5rem;font-size:1.5rem}.track-description{color:#666;margin:.5rem 0 1rem}.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:#666}.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 #ddd;border-radius:4px}.form-help{display:block;margin-top:.5rem;color:#666;font-size:.875rem}.advanced-options{margin:1.5rem 0;padding:1rem;background:#f9f9f9;border-radius:8px}.advanced-options summary{cursor:pointer;font-weight:600;color:#2196f3;-webkit-user-select:none;user-select:none}.advanced-options summary:hover{color:#1976d2}.advanced-options .form-group{margin-top:1rem}.control-input,.control-select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.section-type{text-transform:uppercase;font-size:.75rem;font-weight:600;color:#666}.block-type-badge{font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;background:rgba(0,0,0,.05);padding:2px 6px;border-radius:3px;margin-left:4px}.block-type-display{font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.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:#999;margin-top:4px}.section-item-compact .block-type{font-weight:600;text-transform:uppercase;font-size:.7rem;padding:2px 6px;background:rgba(0,123,255,.1);border-radius:3px;color:#007bff}.tracks-container{height:100vh;background-color:var(--color-background);display:flex;flex-direction:column;overflow:hidden}.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:hidden}.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:hidden}.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}}.material-editor-container{margin:0}.material-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.material-info{flex:1}.material-info h1{margin:0 0 .5rem;font-size:1.75rem}.material-info p{margin:0;color:#666}.material-editor-content{display:flex;flex-direction:column;gap:2rem;padding:20px}.block-placeholder{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;border:2px dashed #ddd;border-radius:8px;background:#f8f9fa}.block-placeholder.disabled{opacity:.6;cursor:not-allowed}.placeholder-icon{font-size:2.5rem}.placeholder-content{flex:1}.placeholder-content h3{margin:0 0 .25rem;font-size:1.1rem}.placeholder-content p{margin:0;color:#666;font-size:.9rem}.badge{display:inline-block;padding:.25rem .5rem;background:#ffc107;color:#000;font-size:.75rem;font-weight:600;border-radius:3px;text-transform:uppercase;margin-top:.5rem}.sections-container{background:white;border:1px solid #ddd;border-radius:8px;padding:2rem}.sections-container h2{margin:0 0 .5rem;font-size:1.5rem}.sections-help{margin:0 0 1.5rem;color:#666;font-size:.9rem}.empty-sections{text-align:center;padding:3rem 1rem;color:#666}.sections-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.section-row{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border:2px solid #e9ecef;border-radius:6px;transition:all .2s}.section-row:hover{border-color:#cbd5e0;box-shadow:0 2px 8px #0000001a}.section-row.dragging{opacity:.5;cursor:grabbing}.drag-handle{font-size:1.25rem;color:#999;cursor:grab;-webkit-user-select:none;user-select:none;padding:.25rem}.drag-handle:active{cursor:grabbing}.section-number{font-weight:600;color:#666;min-width:2rem;font-size:.9rem}.section-inputs{display:flex;gap:1rem;flex:1;flex-wrap:wrap}.input-group{display:flex;flex-direction:column;gap:.25rem;min-width:120px}.input-group label{font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.5rem}.btn-link{background:none;border:none;color:#007bff;font-size:.7rem;padding:.125rem .25rem;cursor:pointer;text-transform:none;letter-spacing:normal;font-weight:500;text-decoration:underline}.btn-link:hover{color:#0056b3}.time-sig-advanced{display:flex;align-items:center;gap:.5rem}.time-sig-advanced span{font-size:1.25rem;font-weight:600;color:#666}.input-group input,.input-group select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.input-group input:focus,.input-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.input-group input[type=number],.input-group select{width:100px}.btn-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.btn-icon:hover{background:rgba(0,0,0,.05)}.btn-delete:hover{background:rgba(220,53,69,.1)}.btn-add-section{width:100%;padding:.75rem;font-size:.95rem}@media (max-width: 768px){.material-editor-header{flex-direction:column;align-items:stretch}.section-row{flex-wrap:wrap}.drag-handle{order:-1;width:100%}.section-inputs{width:100%}.btn-delete{position:absolute;top:.5rem;right:.5rem}}.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:hidden;width:100%}.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}}.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}}.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)}.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;align-items:center;justify-content:space-between}.theme-info h3{font-size:1rem;font-weight:500;color:var(--color-onSurface);margin:0}.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-btn{padding:.5rem 1.25rem;border:none;background:transparent;color:var(--color-onSurface);font-weight:500;font-size:.875rem;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)}@media (max-width: 768px){.theme-grid{grid-template-columns:1fr}}.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}}.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:hidden}.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-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}.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:#f8f9fa;border-radius:8px;padding:20px;text-align:center}.stat-label{display:block;font-size:14px;color:#666;margin-bottom:8px;font-weight:500}.stat-value{display:block;font-size:1.15rem;font-weight:700;color:var(--color-primary);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: 0px;--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-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);box-shadow:0 0 0 2px #1976d233}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)}
