:root{--foot-left-color: #4CAF50;--foot-left-light: #81C784;--foot-left-dark: #2E7D32;--foot-right-color: #2196F3;--foot-right-light: #64B5F6;--foot-right-dark: #1565C0}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#1a1d29,#2c3e50);color:#fff;min-height:100vh}.app{min-height:100vh;padding:20px}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:2rem}.error-boundary-content{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:2rem;text-align:center;max-width:500px;border:1px solid rgba(255,255,255,.2)}.error-boundary-content h2{color:#ff6b6b;margin-bottom:1rem;font-size:1.5rem}.error-boundary-content p{margin-bottom:1.5rem;color:#ccc;line-height:1.6}.error-boundary-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error-boundary-actions .btn-primary,.error-boundary-actions .btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease}.error-boundary-actions .btn-primary{background:#4caf50;color:#fff}.error-boundary-actions .btn-primary:hover{background:#45a049}.error-boundary-actions .btn-secondary{background:transparent;color:#ccc;border:1px solid rgba(255,255,255,.3)}.error-boundary-actions .btn-secondary:hover{background:#ffffff1a}.error-details{margin-top:1.5rem;text-align:left}.error-details summary{cursor:pointer;color:#ff6b6b;margin-bottom:.5rem}.error-details pre{background:#0000004d;padding:1rem;border-radius:4px;font-size:.85rem;overflow-x:auto;margin:.5rem 0}.error-message{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:6px;padding:1rem;margin:1rem 0;color:#ff6b6b}.error-message p{margin:0 0 .5rem}.error-message button{background:transparent;border:1px solid rgba(255,107,107,.5);color:#ff6b6b;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.error-message button:hover{background:#ff6b6b1a}.dance-floor-main{position:relative;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:12px;margin-bottom:16px;min-height:600px;width:100%}.dance-floor-container{position:absolute;top:0;left:0;right:0;bottom:0;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.dance-floor-container .dance-floor{width:100%;height:100%;border-radius:8px;background-image:linear-gradient(rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.1) 1px,transparent 1px);background-size:40px 40px}.overlay-card{position:absolute;background:#283246f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:6px;box-shadow:0 4px 12px #0000004d;padding:8px 12px;color:#fff;font-size:.8rem;z-index:10;max-width:160px;min-width:120px}.overlay-card.top-left{top:16px;left:16px}.overlay-card.top-right{top:16px;right:16px}.overlay-card.bottom-left{bottom:16px;left:16px}.overlay-header{font-weight:600;margin-bottom:6px;color:#ffffffe6;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:3px;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.overlay-card.top-left .dance-name{text-align:center;padding:0 0 8px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}.overlay-card.top-left .dance-name .dance-type{display:inline-block;background:#4fc3f733;color:#4fc3f7;padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(79,195,247,.3);margin-bottom:4px}.overlay-card.top-left .dance-name .pattern-name{margin:0;font-size:.8rem;font-weight:600;color:#fff;text-transform:capitalize;letter-spacing:.5px;line-height:1.2}.app-header{margin-bottom:40px}.header-content{display:flex;flex-direction:column;align-items:center;max-width:1200px;margin:0 auto;padding:0 20px;gap:20px}.app-title{font-size:2.5rem;font-weight:300;margin:0;color:#fff;letter-spacing:2px;text-align:center}.header-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.header-action-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.header-action-btn:hover{background:#ffffff1f;border-color:#ffffff4d;transform:translateY(-1px)}.header-action-btn:active{transform:translateY(0);background:#4fc3f733;border-color:#4fc3f7}@media (max-width: 768px){.app-title{font-size:2rem;letter-spacing:1px}.header-actions{gap:12px}.header-action-btn{padding:8px 12px;font-size:12px}}.dance-tabs{display:flex;justify-content:center;gap:4px}.tab-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:12px 24px;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tab-btn:hover{background:#ffffff26;color:#ffffffe6;transform:translateY(-1px)}.tab-btn.active{background:linear-gradient(45deg,#4fc3f7,#29b6f6);border-color:#29b6f6;color:#fff;box-shadow:0 4px 12px #4fc3f74d}.home-filters{max-width:800px;margin:0 auto 40px;display:flex;flex-direction:row;gap:24px;align-items:center;justify-content:center}.home-filters .dance-tiles{display:flex;gap:12px;flex-wrap:wrap}.home-filters .dance-tile{background:var(--form-bg-primary);border:1px solid var(--form-border-primary);color:var(--form-text-secondary);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:var(--form-transition);text-transform:capitalize;white-space:nowrap}.home-filters .dance-tile:hover{background:var(--form-bg-hover);border-color:var(--form-border-hover);color:var(--form-text-primary);transform:translateY(-1px)}.home-filters .dance-tile.selected{background:var(--form-bg-active);border-color:var(--form-border-active);color:var(--form-accent);box-shadow:0 0 0 1px var(--form-accent-glow)}.home-filters input[type=text]{background:var(--form-bg-primary);border:1px solid var(--form-border-primary);color:var(--form-text-primary);padding:12px 16px;border-radius:var(--form-radius);font-size:var(--form-font-size-large);font-family:inherit;transition:var(--form-transition);width:300px;min-width:250px}.home-filters input[type=text]:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 1px var(--form-accent-glow);background:var(--form-bg-secondary)}.home-filters input[type=text]::placeholder{color:var(--form-text-muted)}.search-section{max-width:600px;margin:0 auto 50px;display:flex;flex-direction:column;gap:20px;align-items:center}.search-input{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);color:#fff;padding:16px 20px;border-radius:8px;font-size:15px;font-family:inherit;transition:all .2s ease;width:100%;max-width:400px;text-align:center}.search-input:focus{outline:none;border-color:#4fc3f799;background:#ffffff14;text-align:left}.search-input::placeholder{color:#fff9;text-align:center}.search-input:focus::placeholder{text-align:left}.filters-row{display:flex;gap:32px;align-items:center;justify-content:center;flex-wrap:wrap}.filter-group-dance,.filter-group-source{display:flex;background:#ffffff0a;border-radius:20px;padding:2px;gap:0;box-shadow:0 2px 8px #0000001a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dance-filter,.source-filter{background:transparent;border:none;color:#ffffffb3;padding:8px 14px;font-size:12px;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;margin:0;position:relative;overflow:hidden;border-radius:0}.filter-group-dance .dance-filter:first-child,.filter-group-source .source-filter:first-child{border-radius:18px 0 0 18px}.filter-group-dance .dance-filter:last-child,.filter-group-source .source-filter:last-child{border-radius:0 18px 18px 0}.filter-group-dance .dance-filter:only-child,.filter-group-source .source-filter:only-child{border-radius:18px}.dance-filter:before,.source-filter:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff14;opacity:0;transition:opacity .25s ease}.dance-filter:hover:before,.source-filter:hover:before{opacity:1}.dance-filter:hover,.source-filter:hover{color:#fffffff2}.dance-filter.selected,.source-filter.selected{background:linear-gradient(135deg,#4fc3f740,#4fc3f726);color:#4fc3f7;box-shadow:inset 0 1px #ffffff1a}.dance-filter.selected:before,.source-filter.selected:before{opacity:0}@media (max-width: 768px){.filters-row{flex-direction:column;gap:20px;align-items:center}.filter-group-dance,.filter-group-source{flex-wrap:wrap;justify-content:center;max-width:100%;border-radius:16px}.search-section{margin-bottom:40px;padding:0 16px}.search-input{font-size:14px;padding:14px 16px}.dance-filter,.source-filter{font-size:11px;padding:6px 12px}.filter-group-dance .dance-filter:first-child,.filter-group-source .source-filter:first-child{border-radius:14px 0 0 14px}.filter-group-dance .dance-filter:last-child,.filter-group-source .source-filter:last-child{border-radius:0 14px 14px 0}.filter-group-dance .dance-filter:only-child,.filter-group-source .source-filter:only-child{border-radius:14px}}@media (max-width: 480px){.filters-row{gap:16px}.filter-group-dance,.filter-group-source{padding:2px;border-radius:14px}.dance-filter,.source-filter{font-size:10px;padding:5px 10px}.filter-group-dance .dance-filter:first-child,.filter-group-source .source-filter:first-child{border-radius:12px 0 0 12px}.filter-group-dance .dance-filter:last-child,.filter-group-source .source-filter:last-child{border-radius:0 12px 12px 0}.filter-group-dance .dance-filter:only-child,.filter-group-source .source-filter:only-child{border-radius:12px}}.dance-content{max-width:1200px;margin:0 auto}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 20px}.tab-header h2{font-size:1.8rem;font-weight:400;margin:0;color:#fff}.pattern-count{background:#ffffff1a;padding:6px 12px;border-radius:20px;font-size:.9rem;color:#fffc}.pattern-group{margin-bottom:60px}.dance-rows{display:flex;flex-direction:column;gap:32px}.dance-floor-skeleton{width:100%;height:500px;background:linear-gradient(135deg,#2d2d2d,#1a1a1a);border-radius:12px;border:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.skeleton-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;padding:20px}.skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:auto}.skeleton-title{width:200px;height:24px;background:#ffffff1a;border-radius:4px;position:relative;overflow:hidden}.skeleton-controls{width:120px;height:20px;background:#ffffff1a;border-radius:4px;position:relative;overflow:hidden}.skeleton-loading-text{position:absolute;bottom:50%;left:50%;transform:translate(-50%,50%);color:#fff9;font-size:1.1rem;font-weight:500}.skeleton-title:before,.skeleton-controls:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:skeleton-shimmer 2s infinite}@keyframes skeleton-shimmer{0%{left:-100%}to{left:100%}}.pattern-info{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px 20px;background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:8px;flex-wrap:wrap}.pattern-title{margin:0;color:#fff;font-size:1.2rem;font-weight:600;flex:1;min-width:200px}.pattern-dance-badge{background:#4fc3f733;color:#4fc3f7;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(79,195,247,.3);white-space:nowrap}.pattern-tags{display:flex;flex-wrap:wrap;gap:6px}.pattern-tag{background:#ffffff14;color:#fffc;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;border:1px solid rgba(255,255,255,.1);text-transform:lowercase}.pattern-source-badge{padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border:1px solid transparent}.pattern-source-badge.user{background:#4caf5026;color:#4caf50;border-color:#4caf504d}.pattern-source-badge.standard{background:#9c27b026;color:#9c27b0;border-color:#9c27b04d}.no-patterns{text-align:center;padding:60px 20px;color:#fff9;background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:12px;margin:20px}.no-patterns p{margin:0 0 8px;font-size:16px}.no-patterns p:last-child{margin:0;font-size:14px;color:#fff6}@media (max-width: 768px){.pattern-info{flex-direction:column;align-items:flex-start;gap:8px;padding:16px}.pattern-title{font-size:1.1rem;min-width:auto}.pattern-tags{width:100%}.tab-header{flex-direction:column;align-items:flex-start;gap:8px;padding:0 16px}}:root{--form-bg-primary: rgba(255, 255, 255, .05);--form-bg-secondary: rgba(255, 255, 255, .08);--form-bg-hover: rgba(255, 255, 255, .1);--form-bg-active: rgba(79, 195, 247, .2);--form-border-primary: rgba(255, 255, 255, .2);--form-border-hover: rgba(255, 255, 255, .3);--form-border-focus: #4fc3f7;--form-border-active: #4fc3f7;--form-text-primary: #ffffff;--form-text-secondary: rgba(255, 255, 255, .9);--form-text-muted: rgba(255, 255, 255, .7);--form-text-disabled: rgba(255, 255, 255, .4);--form-accent: #4fc3f7;--form-accent-glow: rgba(79, 195, 247, .3);--form-radius: 4px;--form-radius-large: 6px;--form-transition: all .2s ease;--form-font-size: 13px;--form-font-size-small: 11px;--form-font-size-large: 14px;--form-font-weight: 500;--form-font-weight-bold: 600}.form-section{margin-bottom:16px;padding:0;background:none;border:none}.form-section h3,.form-section h4{color:var(--form-text-secondary);font-size:12px;font-weight:var(--form-font-weight-bold);margin:0 0 8px;text-transform:uppercase;letter-spacing:.8px}.form-section.minimal{margin-bottom:12px}.form-section.minimal h4{font-size:11px;margin-bottom:6px}.form-row{display:flex;gap:16px;margin-bottom:16px}.form-group{flex:1;margin-bottom:12px}.form-group.compact{margin-bottom:8px}.form-group label,label{display:block;margin-bottom:6px;font-weight:var(--form-font-weight);color:var(--form-text-secondary);font-size:var(--form-font-size);text-transform:uppercase;letter-spacing:.5px}.form-group input[type=text],.form-group input[type=number],.form-group input[type=email],.form-group input[type=password],.form-group textarea,input[type=text],input[type=number],input[type=email],input[type=password],textarea{width:100%;padding:8px 12px;border:1px solid var(--form-border-primary);border-radius:var(--form-radius);background:var(--form-bg-primary);color:var(--form-text-primary);font-size:var(--form-font-size);font-family:inherit;font-weight:var(--form-font-weight);transition:var(--form-transition)}.form-group input:focus,.form-group textarea:focus,input:focus,textarea:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 2px var(--form-accent-glow);background:var(--form-bg-secondary)}.form-group input:hover:not(:disabled),.form-group textarea:hover:not(:disabled),input:hover:not(:disabled),textarea:hover:not(:disabled){border-color:var(--form-border-hover);background:var(--form-bg-secondary)}.form-group input:disabled,.form-group textarea:disabled,input:disabled,textarea:disabled{background:#ffffff05;color:var(--form-text-disabled);cursor:not-allowed;border-color:#ffffff1a}.form-group select,select{width:100%;padding:8px 32px 8px 12px;border:1px solid var(--form-border-primary);border-radius:var(--form-radius);background:var(--form-bg-primary);color:var(--form-text-primary);font-size:var(--form-font-size);font-family:inherit;font-weight:var(--form-font-weight);transition:var(--form-transition);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:12px}.form-group select:focus,select:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 2px var(--form-accent-glow);background-color:var(--form-bg-secondary)}.form-group select:hover:not(:disabled),select:hover:not(:disabled){border-color:var(--form-border-hover);background-color:var(--form-bg-secondary)}.form-group select option,select option{background:#333;color:var(--form-text-primary);padding:8px 12px}.form-group select:disabled,select:disabled{background:#ffffff05;color:var(--form-text-disabled);cursor:not-allowed;border-color:#ffffff1a}.btn-primary,button.btn-primary{background:var(--form-bg-active);color:var(--form-accent);border:1px solid var(--form-accent);padding:8px 16px;border-radius:var(--form-radius);font-size:var(--form-font-size);font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);text-transform:uppercase;letter-spacing:.3px;outline:none}.btn-primary:hover:not(:disabled){background:#4fc3f74d;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-secondary,button.btn-secondary{background:var(--form-bg-primary);color:var(--form-text-primary);border:1px solid var(--form-border-primary);padding:8px 16px;border-radius:var(--form-radius);font-size:var(--form-font-size);font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);text-transform:uppercase;letter-spacing:.3px;outline:none}.btn-secondary:hover:not(:disabled){background:var(--form-bg-hover);border-color:var(--form-border-hover);transform:translateY(-1px)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-danger,button.btn-danger{background:#f4433633;color:#f44336;border:1px solid #f44336;padding:8px 16px;border-radius:var(--form-radius);font-size:var(--form-font-size);font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);text-transform:uppercase;letter-spacing:.3px;outline:none}.btn-danger:hover:not(:disabled){background:#f443364d;transform:translateY(-1px)}.btn-danger:active:not(:disabled){transform:translateY(0)}input[type=radio]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border:2px solid var(--form-border-primary);border-radius:50%;background:transparent;margin:0;position:relative;cursor:pointer;transition:var(--form-transition);flex-shrink:0}input[type=radio]:checked{border-color:var(--form-accent);background:var(--form-bg-active)}input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:var(--form-accent)}input[type=radio]:hover:not(:disabled){border-color:var(--form-accent)}input[type=radio]:disabled{opacity:.4;cursor:not-allowed}.foot-buttons,.rotation-options,.size-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.foot-btn,.rotation-btn,.size-btn,.radio-option{display:flex;align-items:center;gap:8px;background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:var(--form-radius-large);padding:8px 12px;cursor:pointer;transition:var(--form-transition);flex:1;min-width:fit-content;color:var(--form-text-primary);font-size:var(--form-font-size);font-weight:var(--form-font-weight)}.foot-btn:hover,.rotation-btn:hover,.size-btn:hover,.radio-option:hover{background:var(--form-bg-hover);border-color:var(--form-border-hover)}.foot-btn.active,.rotation-btn.active,.size-btn.active,.radio-option.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent)}.foot-btn input[type=radio],.rotation-btn input[type=radio],.size-btn input[type=radio]{display:none}.size-btn{flex-direction:column;align-items:flex-start;gap:4px;min-width:140px}.size-label{color:currentColor;font-weight:var(--form-font-weight-bold);font-size:var(--form-font-size);text-transform:uppercase;letter-spacing:.3px}.size-description{color:var(--form-text-muted);font-size:var(--form-font-size-small);line-height:1.2}.foot-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.custom-rotation{margin-top:12px;margin-left:16px}.custom-rotation input{max-width:120px}.checkbox-option input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-radius:3px;background:transparent;margin:0;position:relative;cursor:pointer;transition:all .2s}.checkbox-option input[type=checkbox]:checked{border-color:#4fc3f7;background:#4fc3f7}.checkbox-option input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:10px;font-weight:700;line-height:1}.checkbox-option input[type=checkbox]:hover{border-color:#4fc3f7}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border:2px solid var(--form-border-primary);border-radius:3px;background:transparent;margin:0;position:relative;cursor:pointer;transition:var(--form-transition);flex-shrink:0}input[type=checkbox]:checked{border-color:var(--form-accent);background:var(--form-accent)}input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:10px;font-weight:700}input[type=checkbox]:hover:not(:disabled){border-color:var(--form-accent)}input[type=checkbox]:disabled{opacity:.4;cursor:not-allowed}.quick-select{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.quick-btn{background:var(--form-bg-primary);color:var(--form-text-muted);border:1px solid var(--form-border-primary);padding:4px 8px;border-radius:var(--form-radius);font-size:var(--form-font-size-small);font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);text-transform:uppercase;letter-spacing:.3px;min-width:32px;text-align:center}.quick-btn:hover:not(:disabled){background:var(--form-bg-hover);border-color:var(--form-border-hover);color:var(--form-text-primary)}.quick-btn.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent)}.quick-btn:disabled{opacity:.4;cursor:not-allowed}.quick-btn.smart-suggest{background:#4caf5033;border-color:#4caf50;color:#4caf50;font-weight:var(--form-font-weight-bold)}.quick-btn.smart-suggest:hover:not(:disabled){background:#4caf504d}.quick-btn.smart-beat{background:#2196f333;border-color:#2196f3;color:#2196f3;font-weight:var(--form-font-weight-bold);font-size:11px}.quick-btn.smart-beat:hover:not(:disabled){background:#2196f34d}.quick-btn.smart-beat.active{background:#2196f366;box-shadow:0 0 4px #2196f366}.movement-quick-buttons{margin-top:8px}.quick-moves{display:flex;flex-wrap:wrap;gap:6px}.movement-btn{background:var(--form-bg-primary);color:var(--form-text-muted);border:1px solid var(--form-border-primary);padding:6px 12px;border-radius:var(--form-radius);font-size:var(--form-font-size);font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);text-transform:uppercase;letter-spacing:.3px}.movement-btn:hover:not(:disabled){background:var(--form-bg-hover);border-color:var(--form-border-hover);color:var(--form-text-primary)}.number-stepper{display:flex;align-items:center;background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:var(--form-radius);overflow:hidden}.stepper-btn{background:var(--form-bg-secondary);border:none;color:var(--form-text-primary);padding:6px 8px;font-size:var(--form-font-size-small);font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);-webkit-user-select:none;user-select:none;min-width:24px;display:flex;align-items:center;justify-content:center}.stepper-btn:hover:not(:disabled){background:var(--form-bg-hover)}.stepper-btn:active:not(:disabled){background:var(--form-accent-glow)}.stepper-btn:disabled{opacity:.4;cursor:not-allowed}.stepper-value{padding:6px 12px;background:var(--form-bg-primary);color:var(--form-text-primary);font-size:var(--form-font-size-small);font-weight:var(--form-font-weight);text-align:center;min-width:30px;border-left:1px solid var(--form-border-primary);border-right:1px solid var(--form-border-primary)}.stepper-value.clickable{cursor:pointer;transition:var(--form-transition);-webkit-user-select:none;user-select:none}.stepper-value.clickable:hover{background:var(--form-bg-hover);color:var(--form-accent)}.stepper-value.clickable:active{background:var(--form-accent-glow);transform:scale(.95)}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.validation-feedback{margin-top:8px;padding:8px 12px;border-radius:var(--form-radius);font-size:var(--form-font-size-small);line-height:1.4}.validation-feedback.error{background:#f443361a;border:1px solid rgba(244,67,54,.3);color:#f44336}.validation-feedback.success{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:#4caf50}.validation-feedback.warning{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);color:#ffc107}.form-group input.error,.form-group select.error,.form-group textarea.error,input.error,select.error,textarea.error{border-color:#f44336;background:#f443360d}.form-group input.error:focus,.form-group select.error:focus,.form-group textarea.error:focus,input.error:focus,select.error:focus,textarea.error:focus{box-shadow:0 0 0 2px #f443364d}@media (max-width: 768px){.rotation-options,.size-options{flex-direction:column}.rotation-btn,.size-btn{flex:none;width:100%}.size-btn{min-width:auto}.form-row{flex-direction:column;gap:12px}.foot-buttons{grid-template-columns:1fr;gap:6px}.quick-select{justify-content:center}.form-actions{flex-direction:column-reverse;gap:8px}.form-actions .btn-primary,.form-actions .btn-secondary,.form-actions .btn-danger{width:100%;justify-content:center}}.role-controls{display:flex;flex-direction:column;gap:4px}.role-option,.checkbox-option{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.75rem;color:#ffffffe6;padding:2px 0;transition:color .2s}.role-option:hover,.checkbox-option:hover{color:#4fc3f7}.camera-controls{display:flex;gap:6px;margin-bottom:6px}.follow-btn,.zoom-level-btn{padding:4px 8px;border:1px solid rgba(255,255,255,.3);border-radius:3px;background:#ffffff1a;color:#fff;font-size:.7rem;cursor:pointer;transition:all .2s}.follow-btn:hover,.zoom-level-btn:hover{background:#fff3;border-color:#4fc3f7}.follow-btn.active{background:#4fc3f7;color:#fff;border-color:#4fc3f7}.zoom-hint{font-size:.65rem;color:#fff9;text-align:center}.zoom-controls{display:flex;gap:2px;margin-top:6px}.zoom-controls .stepper-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:3px;color:#fff;padding:4px 8px;font-size:.7rem;cursor:pointer;transition:all .2s;min-width:28px;height:26px;display:flex;align-items:center;justify-content:center}.zoom-controls .stepper-btn:hover:not(:disabled){background:#fff3;border-color:#4fc3f7}.zoom-controls .stepper-btn:active:not(:disabled){background:#4fc3f74d;border-color:#4fc3f7}.zoom-controls .stepper-btn:disabled{opacity:.4;cursor:not-allowed}.footstep-controls{display:flex;flex-direction:column;gap:12px}.footstep-control{display:flex;flex-direction:column;gap:6px;min-width:40px;color:#ffffffe6}.control-label{display:flex;align-items:center;gap:6px;font-size:.75rem;color:#fffc}.control-icon{font-size:.9rem;color:#3b82f6;font-weight:700}.playback-controls{display:flex;gap:8px;align-items:center}.control-btn{width:40px;height:40px;border:1px solid #555;border-radius:6px;background:#333;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.control-btn:hover:not(:disabled){background:#444;border-color:#007bff;transform:translateY(-1px)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.play-btn{background:#007bff;color:#fff;border-color:#007bff}.control-btn.play-btn:hover{background:#0056b3;border-color:#0056b3}.control-btn.play-btn.playing{background:#dc3545;border-color:#dc3545}.control-btn.play-btn.playing:hover{background:#c82333;border-color:#c82333}.step-controls-section{background:#2a2a2a;border:1px solid #444;border-radius:8px;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;height:60px}.step-info{font-size:.95rem;color:#ccc;font-weight:500}.control-section{display:flex;flex-direction:column;align-items:center;gap:8px}.control-section-label{font-size:.7rem;font-weight:500;color:#ffffff80;text-transform:uppercase;letter-spacing:.6px}.beat-timeline-section{background:#283246cc;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:16px;height:80px}.timeline-controls{flex-shrink:0;display:flex;flex-direction:column;gap:8px}.bpm-controls{display:flex;align-items:center;gap:8px}.bpm-label{font-weight:600;color:#ffffffe6;font-size:.9rem}.bpm-value{font-weight:600;color:#4fc3f7;min-width:40px;text-align:center}.bpm-btn{width:28px;height:28px;border:1px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff1a;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.bpm-btn:hover:not(:disabled){background:#fff3;border-color:#4fc3f7}.bpm-btn:disabled{opacity:.5;cursor:not-allowed}.timeline-container{flex:1;height:60px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:4px;overflow:hidden}.timeline-container .beat-timeline{background:transparent!important;margin:0!important;min-height:100%!important;height:100%!important;width:100%!important;overflow:hidden!important}.timeline-container .beat-current-indicator{background:#4fc3f7!important}.timeline-container .playhead{border-left:2px solid #4fc3f7!important;z-index:5}.timeline-container .events{height:100%!important}.timeline-container .beat-block{border:2px solid rgba(255,255,255,.2)!important;height:30px!important;top:15px!important;transition:all .15s ease!important}.timeline-container .beat-block.active{border-color:#fffc!important;transform:scaleY(1.3)!important;box-shadow:0 0 10px #fff6!important}.timeline-container .beat-tick{border-left:1px solid rgba(79,195,247,.5)!important;height:100%!important;top:0!important;bottom:0!important}.timeline-container .beat-label{color:#ffffffe6!important;font-size:9px!important;font-weight:600!important;top:auto!important;bottom:5px!important}.beat-timeline-container{display:flex;flex-direction:column;width:100%;margin:16px 0;padding:8px;background:#333;border:1px solid #555;border-radius:8px}.beat-timeline-header{text-align:center;color:#eee;font-weight:700}.beat-timeline{position:relative;width:100%!important;height:80px!important;background:#444!important;overflow:hidden!important;-webkit-user-select:none;user-select:none}.beat-block{position:absolute!important;height:40px!important;top:20px!important;border-radius:4px!important;opacity:.7!important;transition:transform .15s ease,opacity .15s ease,box-shadow .15s ease!important;border:2px solid transparent!important}.beat-block.active{transform:scaleY(1.2)!important;opacity:1!important;box-shadow:0 0 12px #ffffff4d!important;border-color:#fff9!important}.beat-block:hover{transform:scale(1.05);box-shadow:0 2px 8px #0000004d;z-index:10}.playhead{position:absolute!important;top:0;bottom:0;left:50%;border-left:3px solid #FFD700!important;pointer-events:none;z-index:10;box-shadow:0 0 8px #ffd70080!important}.beat-tick{position:absolute!important;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.8)!important}.beat-label{position:absolute!important;font-size:10px!important;color:#fff!important;font-weight:700!important;-webkit-user-select:none!important;user-select:none!important;pointer-events:none!important}.beat-timeline[style*=grabbing]{cursor:grabbing!important}.beat-timeline[style*=grab]{cursor:grab!important}.timeline-tooltip{border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.step-controls-inline{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px;margin-left:16px;padding-left:16px;border-left:1px solid rgba(255,255,255,.2);min-width:200px}.step-controls-inline .playback-controls{display:flex;gap:4px;align-items:center}.step-controls-inline .control-btn.small{width:32px;height:32px;border:1px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff1a;color:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.step-controls-inline .control-btn.small:hover:not(:disabled){background:#fff3;border-color:#4fc3f7;transform:translateY(-1px)}.step-controls-inline .control-btn.small:disabled{opacity:.5;cursor:not-allowed}.step-controls-inline .control-btn.small.play-btn{background:#4fc3f7;color:#fff;border-color:#4fc3f7}.step-controls-inline .control-btn.small.play-btn:hover{background:#29b6f6;border-color:#29b6f6}.step-controls-inline .control-btn.small.play-btn.playing{background:#f44336;border-color:#f44336}.step-controls-inline .control-btn.small.play-btn.playing:hover{background:#d32f2f;border-color:#d32f2f}.step-controls-inline .step-info{font-size:.8rem;color:#fffc;text-align:right;max-width:180px;line-height:1.2}.foot-glow-left{filter:drop-shadow(0 0 8px var(--foot-left-color))!important}.foot-glow-right{filter:drop-shadow(0 0 8px var(--foot-right-color))!important}.beat-block[data-foot=L]{background:var(--foot-left-color)!important;border-color:var(--foot-left-light)!important}.beat-block[data-foot=R]{background:var(--foot-right-color)!important;border-color:var(--foot-right-light)!important}.beat-block[data-foot=L].active{background:var(--foot-left-light)!important;box-shadow:0 0 4px var(--foot-left-color)!important}.beat-block[data-foot=R].active{background:var(--foot-right-light)!important;box-shadow:0 0 4px var(--foot-right-color)!important}.loop-indicator{pointer-events:none}.loop-indicator:hover .loop-label{opacity:1;background:#000c}.loop-label{transition:opacity .2s ease}.dance-designer{position:fixed;top:0;left:0;right:0;bottom:0;background:#1a1a1a;z-index:1000;display:flex;flex-direction:column}.dance-designer-header{display:flex;justify-content:space-between;align-items:center;background:#2a2a2a;padding:16px 24px;border-bottom:1px solid #444;transition:background-color .3s ease}.dance-designer-header.placement-active{background:#1e3a1e;border-bottom-color:#28a745}.header-left{display:flex;align-items:center;gap:16px}.back-btn{background:transparent;border:1px solid #666;color:#fff;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px}.back-btn:hover{background:#444;border-color:#888}.designer-title{color:#fff;margin:0;font-size:1.5rem;font-weight:600}.dance-name-display{color:#ccc;font-style:italic}.header-right{display:flex;align-items:center;gap:12px}.new-session-btn,.export-btn,.save-btn{background:transparent;border:1px solid #666;color:#fff;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.new-session-btn:hover,.export-btn:hover,.save-btn:hover{background:#444;border-color:#888}.save-btn.primary{background:#007acc;border-color:#007acc}.save-btn.primary:hover{background:#0068a3;border-color:#0068a3}.save-btn.secondary{background:#666;border-color:#666;margin-left:8px}.save-btn.secondary:hover{background:#777;border-color:#777}.new-session-btn:disabled,.export-btn:disabled,.save-btn:disabled{opacity:.5;cursor:not-allowed}.new-session-btn:disabled:hover,.export-btn:disabled:hover,.save-btn:disabled:hover{background:transparent;border-color:#666}.placement-mode-toggle{display:flex;align-items:center;gap:12px;margin-left:20px}.placement-mode-toggle .mode-btn{background:#2a2a2a;border:1px solid #444;color:#ccc;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.placement-mode-toggle .mode-btn:hover{background:#333;border-color:#555}.placement-mode-toggle .mode-btn.active{background:#28a745;border-color:#1e7e34;color:#fff;box-shadow:0 0 8px #28a74566}.placement-controls{display:flex;align-items:center;gap:8px}.placement-controls label{font-size:12px;color:#ccc;display:flex;align-items:center;gap:4px}.placement-controls select{background:#333;border:1px solid #555;color:#ccc;padding:2px 6px;border-radius:3px;font-size:11px}.dance-designer-content{display:flex;flex:1;overflow:hidden}.preview-panel{flex:0 0 60%;background:#222;border-right:1px solid #444;display:flex;flex-direction:column;overflow:hidden}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#333;border-bottom:1px solid #444;flex-wrap:wrap;gap:12px}.step-preview-live{font-size:12px;color:#ffffffe6;background:#4fc3f714;border:1px solid rgba(79,195,247,.25);border-radius:4px;padding:6px 10px;flex:1;min-width:200px}.step-preview-live strong{color:#4fc3f7;font-weight:600}.preview-header h3{color:#fff;margin:0;font-size:1.1rem}.validation-status .status-valid{color:#28a745;font-weight:500}.validation-status .status-invalid{color:#dc3545;font-weight:500}.placement-instructions{display:flex;align-items:center;gap:8px}.instruction-text{color:#28a745;font-size:14px;font-weight:500;background:#28a7451a;padding:4px 8px;border-radius:4px;border:1px solid rgba(40,167,69,.3)}.preview-container{flex:1;overflow:hidden}.preview-empty{display:flex;align-items:center;justify-content:center;height:100%;text-align:center}.empty-state h4{color:#888;margin:0 0 8px;font-size:1.2rem}.empty-state p{color:#666;margin:0}.validation-errors{background:#2d1b1b;border:1px solid #721c24;margin:16px;padding:16px;border-radius:4px}.validation-errors h4{color:#f5c6cb;margin:0 0 8px;font-size:1rem}.validation-errors ul{margin:0;padding-left:20px}.error-item{color:#f8d7da;margin-bottom:4px}.construction-panel{flex:0 0 40%;background:#2a2a2a;display:flex;flex-direction:column;overflow-y:auto;transition:flex-basis .3s ease}.panel-section{border-bottom:1px solid rgba(255,255,255,.08);padding:12px 16px;background:transparent}.panel-section:last-child{border-bottom:none}.panel-section h3{color:#fff;margin:0 0 12px;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;padding-bottom:4px;border-bottom:1px solid rgba(79,195,247,.3)}.panel-section h4{color:#ffffffe6;margin:0 0 8px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px}.dance-meta-editor{padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-sm)}.dance-meta-editor .form-row{display:grid;grid-template-columns:2fr 1fr .8fr .8fr;gap:var(--spacing-sm);margin-bottom:0}.dance-meta-editor .form-row .form-group{margin-bottom:0}.form-section{margin-bottom:12px;padding:0;background:none;border:none}.form-section h4{color:#ffffffe6;font-size:.8rem;font-weight:600;margin:0 0 6px;text-transform:uppercase;letter-spacing:.8px}.form-section:last-child{margin-bottom:0}.recovery-notification{position:fixed;top:20px;right:20px;max-width:400px;background:#333;border:1px solid #555;border-radius:8px;box-shadow:0 8px 24px #0000004d;z-index:1001;animation:slideInRight .3s ease-out}.recovery-content{padding:16px;display:flex;align-items:flex-start;gap:12px}.recovery-icon{font-size:24px;flex-shrink:0;margin-top:2px}.recovery-text{flex:1}.recovery-text h4{color:#fff;margin:0 0 6px;font-size:14px;font-weight:600}.recovery-text p{color:#fffc;margin:0 0 12px;font-size:12px;line-height:1.4}.recovery-actions{display:flex;gap:8px;margin-top:12px}.recovery-actions .btn-primary,.recovery-actions .btn-secondary{padding:6px 12px;font-size:12px;border-radius:4px;border:1px solid;cursor:pointer;transition:all .2s ease;font-weight:500}.recovery-actions .btn-primary{background:#4fc3f733;color:#4fc3f7;border-color:#4fc3f7}.recovery-actions .btn-primary:hover{background:#4fc3f74d}.recovery-actions .btn-secondary{background:#ffffff1a;color:#fffc;border-color:#ffffff4d}.recovery-actions .btn-secondary:hover{background:#ffffff26;color:#fff}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 400px){.dance-meta-editor .form-row{grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.dance-meta-editor .form-row .form-group:first-child{grid-column:span 2}.foot-buttons{grid-template-columns:1fr;gap:4px}.recovery-notification{top:10px;right:10px;left:10px;max-width:none}.recovery-content{flex-direction:column;text-align:center}.recovery-actions{justify-content:center}}.form-actions{display:flex;gap:8px;margin-top:16px;padding-top:0;border-top:none}.form-actions .btn-primary,.form-actions .btn-secondary{flex:1}.step-sequence h3{color:#fff;margin:0 0 16px;font-size:1.1rem}.sequence-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sequence-stats{display:flex;gap:16px;font-size:12px;color:#888}.empty-sequence{text-align:center;padding:40px 20px;color:#666}.step-list{display:flex;flex-direction:column;gap:8px}.step-item{background:#333;border:1px solid #555;border-radius:4px;padding:12px;cursor:pointer;transition:all .2s;position:relative}.step-item:hover{background:#3a3a3a;border-color:#666}.step-item.selected{background:#1a4480;border-color:#007bff}.step-item.conflict{border-color:#dc3545;background:#2d1b1b}.step-header{display:flex;align-items:center;gap:8px}.step-number{background:#666;color:#fff;padding:2px 6px;border-radius:3px;font-size:11px;font-weight:700}.step-beat{font-size:12px;color:#888}.conflict-indicator{color:#dc3545;font-weight:700}.step-description{color:#fff;font-weight:500;margin-bottom:4px}.step-timing{font-size:12px;color:#888}.step-actions{display:flex;gap:4px;margin-top:8px}.reorder-actions{position:absolute;right:8px;top:8px;display:flex;flex-direction:column;gap:2px}.bulk-actions{margin-top:16px;padding-top:16px;border-top:1px solid #444}.quick-select{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}.quick-btn{padding:4px 8px;border:1px solid #555;background:#2a2a2a;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s;color:#fff}.quick-btn:hover{background:#333;border-color:#777}.quick-btn.active{background:#007bff;color:#fff;border-color:#0056b3}.quick-btn.smart-suggest{background:#28a745;color:#fff;border-color:#1e7e34;font-weight:500}.quick-btn.smart-suggest:hover{background:#218838}.movement-quick-buttons{margin-top:12px}.movement-category{margin-bottom:8px}.category-label{font-size:12px;color:#ccc;margin-right:8px}.quick-moves{display:flex;gap:6px;flex-wrap:wrap}.movement-btn{padding:6px 10px;border:1px solid #555;background:#2a2a2a;border-radius:3px;color:#fffc;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.3px}.movement-btn:hover{background:#ffffff1a;border-color:#4fc3f780;color:#fff}.movement-btn.active{background:#4fc3f733;border-color:#4fc3f7;color:#4fc3f7}.validation-feedback{margin-top:8px;padding:8px 10px;border-radius:4px;font-size:12px;line-height:1.4}.validation-feedback.error{background:#ff475726;border:1px solid rgba(255,71,87,.3);color:#ff6b7d}.validation-feedback.error strong{color:#ff4757;font-weight:600}.validation-feedback ul{margin:4px 0 0;padding-left:16px}.validation-feedback li{margin-bottom:2px}.form-group input.error,.form-group select.error{border-color:#ff4757!important;box-shadow:0 0 0 2px #ff475740!important}.step-preview{margin-top:16px;padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:4px}.step-preview h4{color:#fff;margin:0 0 6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.step-preview .preview-text{color:#fffc;font-size:13px;line-height:1.4;margin:0;font-style:italic}.form-actions{display:flex;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.form-actions .btn-primary{flex:1;padding:8px 12px;background:#4fc3f733;color:#4fc3f7;border:1px solid #4fc3f7;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.form-actions .btn-primary:hover{background:#4fc3f74d;transform:translateY(-1px)}.form-actions .btn-secondary{padding:8px 12px;background:#ffffff0d;color:#fffc;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.form-actions .btn-secondary:hover{background:#ffffff1a;color:#fff;transform:translateY(-1px)}.movement-quick-buttons{margin-top:6px}.movement-quick-buttons .category-label{display:none}.quick-moves{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}.floating-help-btn{position:fixed;bottom:20px;right:20px;width:40px;height:40px;border-radius:50%;background:#4fc3f7e6;border:1px solid rgba(79,195,247,.3);color:#fff;font-size:18px;font-weight:700;cursor:pointer;z-index:1100;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.floating-help-btn:hover{background:#4fc3f7;transform:translateY(-2px);box-shadow:0 6px 16px #0006}.floating-help-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0000004d}.smart-mode-section{margin-bottom:20px}.smart-mode-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.smart-controls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.smart-control-item{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:12px;text-align:center;transition:all .3s ease;display:flex;flex-direction:column;gap:8px}.control-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff9;margin-bottom:8px;transition:all .3s ease}.control-label.auto{color:#4fc3f7}.control-input{display:flex;flex-direction:column;gap:6px;width:100%}.smart-input{width:100%;padding:6px 8px;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#ffffff0d;color:#fff;font-size:12px;font-weight:500;text-align:center;transition:all .3s ease}.smart-input:focus{outline:none;border-color:#4fc3f7;box-shadow:0 0 0 2px #4fc3f74d;background:#ffffff14}.smart-input:disabled{background:#ffffff05;color:#ffffff80;border-color:#ffffff1a;cursor:not-allowed}.smart-control-item .quick-select{display:flex;gap:3px;justify-content:center;flex-wrap:wrap}.smart-control-item .quick-btn{padding:3px 6px;font-size:10px;min-width:24px}.smart-control-item .foot-buttons{display:grid;grid-template-columns:1fr 1fr;gap:4px}.smart-control-item .foot-btn{padding:6px 8px;font-size:11px;border-radius:4px;transition:all .3s ease}.smart-control-item .foot-btn.disabled{opacity:.5;cursor:not-allowed;background:#ffffff05;color:#fff6}.smart-control-item .foot-btn.disabled:hover{background:#ffffff05;border-color:#ffffff1a}.smart-summary-inline{background:#4fc3f714;border:1px solid rgba(79,195,247,.25);border-radius:6px;padding:8px 12px;font-size:12px;color:#ffffffe6;animation:fadeIn .3s ease;flex:1}.smart-summary-inline strong{color:#4fc3f7;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.movement-controls{display:flex;gap:6px;align-items:stretch;flex-wrap:nowrap}.movement-btn,.advanced-movements{background:var(--form-bg-primary);color:var(--form-text-muted);border:1px solid var(--form-border-primary);padding:8px;border-radius:var(--form-radius);font-size:12px;font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);height:36px;display:flex;align-items:center;justify-content:center;flex:1;min-width:0}.movement-btn{text-transform:uppercase;letter-spacing:.3px}.movement-btn:hover:not(:disabled),.advanced-movements:hover{background:var(--form-bg-hover);border-color:var(--form-border-hover);color:var(--form-text-primary)}.movement-btn.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent)}.rotation-controls{display:flex;align-items:stretch;gap:6px;flex-wrap:nowrap}.rotation-btn,.rotation-controls .custom-rotation-input{background:var(--form-bg-primary);color:var(--form-text-muted);border:1px solid var(--form-border-primary);padding:8px;border-radius:var(--form-radius);font-size:12px;font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);height:36px;display:flex;align-items:center;justify-content:center;flex:1;min-width:0;box-sizing:border-box}.rotation-btn{flex-direction:column;gap:1px;text-align:center}.rotation-controls .custom-rotation-input{color:var(--form-text-primary);text-align:center}.rotation-label{font-size:10px;font-weight:600;text-transform:uppercase;line-height:1}.rotation-degrees{font-size:9px;opacity:.7;line-height:1}.rotation-btn:hover{background:var(--form-bg-hover);border-color:var(--form-border-hover);color:var(--form-text-primary)}.rotation-btn.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent)}.rotation-controls .custom-rotation-input:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 2px var(--form-accent-glow);background:var(--form-bg-secondary)}.rotation-controls .custom-rotation-input.active{border-color:var(--form-accent);background:var(--form-bg-active);color:var(--form-accent)}.size-controls{display:flex;gap:6px;align-items:stretch;flex-wrap:nowrap}.size-btn,.size-controls .custom-size-input{background:var(--form-bg-primary);color:var(--form-text-muted);border:1px solid var(--form-border-primary);padding:8px;border-radius:var(--form-radius);font-size:12px;font-weight:var(--form-font-weight);cursor:pointer;transition:var(--form-transition);height:36px;display:flex;align-items:center;justify-content:center;text-align:center;flex:1;min-width:0;box-sizing:border-box}.size-btn{flex-direction:column;gap:1px}.size-controls .custom-size-input{color:var(--form-text-primary)}.size-btn:hover:not(:disabled){background:var(--form-bg-hover);border-color:var(--form-border-hover);color:var(--form-text-primary)}.size-btn.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent)}.size-label{font-size:10px;font-weight:600;text-transform:uppercase;line-height:1}.size-multiplier{font-size:9px;opacity:.7;line-height:1}.size-controls .custom-size-input:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 2px var(--form-accent-glow);background:var(--form-bg-secondary)}.size-controls .custom-size-input.active{border-color:var(--form-accent);background:var(--form-bg-active);color:var(--form-accent)}.add-step-btn{background:linear-gradient(135deg,#4fc3f733,#4fc3f74d);border:2px solid var(--form-accent);color:var(--form-accent);font-weight:600;font-size:14px;padding:12px 20px;box-shadow:0 2px 8px #4fc3f733;flex:2}.add-step-btn:hover:not(:disabled){background:linear-gradient(135deg,#4fc3f74d,#4fc3f766);transform:translateY(-1px);box-shadow:0 4px 12px #4fc3f74d}.btn-clear{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:#ffffffb3;padding:8px 16px;border-radius:var(--form-radius);font-size:12px;font-weight:500;cursor:pointer;transition:var(--form-transition);text-transform:uppercase;letter-spacing:.3px;flex:1}.btn-clear:hover{background:#ffffff1a;border-color:#ffffff4d;color:#ffffffe6}@media (max-width: 600px){.smart-controls-grid{grid-template-columns:1fr;gap:8px}.smart-control-item{padding:8px}.movement-controls,.rotation-controls,.size-controls{flex-wrap:wrap}.movement-btn,.rotation-btn,.size-btn{min-width:50px}.advanced-movements,.custom-rotation-input,.custom-size-input{min-width:80px}}.mode-toggle{border-bottom:1px solid #333;padding-bottom:16px}.toggle-buttons{display:flex;gap:8px;margin-bottom:8px}.mode-btn{background:#2a2a2a;border:1px solid #444;color:#ccc;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.mode-btn:hover{background:#333;border-color:#555}.mode-btn.active{background:#007bff;border-color:#0056b3;color:#fff}.mode-description{color:#888;font-size:13px;margin:0;font-style:italic}.visual-placement-section{background:#2a2a2a;border:1px solid #444;border-radius:6px;padding:16px;margin-bottom:16px}.visual-controls{display:flex;align-items:center;gap:16px;padding:12px;background:#333;border-radius:4px}.placer-controls{display:flex;align-items:center;gap:16px;margin-bottom:12px;font-size:13px;color:#ccc}.step-preview{color:#28a745;font-weight:500}.detected-info{background:#333;padding:12px;border-radius:4px;border-left:3px solid #007bff}.detected-info p{margin:4px 0;color:#ccc;font-size:14px}.controls-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;width:100%}.control-group{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;flex:1}.control-group h4{margin-bottom:8px;color:#ffffffe6;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;text-align:center}.movement-dpad{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:2px;width:120px;height:120px;margin:0 auto;background:#ffffff1a;border-radius:8px;padding:4px}.dpad-btn{background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:4px;color:var(--form-text-primary);font-size:16px;font-weight:600;cursor:pointer;transition:var(--form-transition);display:flex;align-items:center;justify-content:center;min-height:32px;-webkit-user-select:none;user-select:none}.dpad-btn:hover:not(:disabled){background:var(--form-bg-hover);border-color:var(--form-border-hover);transform:translateY(-1px)}.dpad-btn.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent);box-shadow:0 0 8px #4fc3f74d}.dpad-diag-fwd-l{border-top-left-radius:8px}.dpad-diag-fwd-r{border-top-right-radius:8px}.dpad-diag-back-l{border-bottom-left-radius:8px}.dpad-diag-back-r{border-bottom-right-radius:8px}.dpad-center{background:var(--form-bg-secondary);border-radius:50%}.dpad-center.active{background:var(--form-bg-active);box-shadow:0 0 12px #4fc3f766}.advanced-movements-section{margin-top:8px}.advanced-movements-section .advanced-movements{width:100%;font-size:12px}.rotation-compass{display:grid;grid-template-areas:". none ." "left center right" ". half .";grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;gap:8px;width:180px;height:120px;margin:0 auto;padding:8px}.compass-btn{background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:50%;color:var(--form-text-primary);font-size:18px;font-weight:600;cursor:pointer;transition:var(--form-transition);display:flex;align-items:center;justify-content:center;min-height:32px;min-width:32px;-webkit-user-select:none;user-select:none}.compass-btn:hover:not(:disabled){background:var(--form-bg-hover);border-color:var(--form-border-hover);transform:scale(1.05)}.compass-btn.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent);box-shadow:0 0 8px #4fc3f74d}.compass-none{grid-area:none}.compass-left{grid-area:left}.compass-right{grid-area:right}.compass-half{grid-area:half}.compass-center{grid-area:center;background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:50%;color:var(--form-text-primary);font-size:12px;font-weight:600;text-align:center;padding:4px;width:36px;height:36px;transition:var(--form-transition)}.compass-center:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 2px var(--form-accent-glow);background:var(--form-bg-secondary)}.compass-center.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent);box-shadow:0 0 8px #4fc3f74d}.rotation-compass .compass-btn{width:36px;height:36px;border-radius:50%}.rotation-compass .compass-none,.rotation-compass .compass-half{justify-self:center}.rotation-compass input.compass-center{width:80px;border-radius:18px}.step-builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.step-builder-header h3{margin:0;color:#ffffffb3;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.smart-mode-toggle-header{display:flex;align-items:center;gap:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:6px 12px;cursor:pointer;transition:all .3s ease;color:#fffc;font-size:12px;font-weight:500}.smart-mode-toggle-header .toggle-icon{font-size:14px}.smart-mode-toggle-header .toggle-text{font-weight:600}.smart-mode-toggle-header .toggle-status{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.7;background:#ffffff1a;padding:2px 6px;border-radius:10px}.smart-mode-toggle-header:hover{background:#ffffff14;border-color:#ffffff4d;color:#ffffffe6}.smart-mode-toggle-header.active{background:#4fc3f71f;border-color:#4fc3f766;color:#4fc3f7;box-shadow:0 0 0 2px #4fc3f71a}.smart-mode-toggle-header.active .toggle-icon{transform:scale(1.1)}.smart-mode-toggle-header.active .toggle-status{background:#4fc3f733;color:#4fc3f7;opacity:1}.size-controls-unified{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;gap:4px;width:120px;margin:0 auto}.size-btn-compact{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:6px;padding:6px 4px;cursor:pointer;transition:var(--form-transition);font-size:10px;height:38px;text-align:center}.size-btn-compact input[type=radio]{display:none}.size-btn-compact .size-label{font-weight:600;color:var(--form-text-primary);line-height:1;margin-bottom:2px}.size-btn-compact .size-multiplier{font-size:8px;color:var(--form-text-secondary);line-height:1}.size-btn-compact:hover{background:var(--form-bg-secondary);border-color:var(--form-border-secondary)}.size-btn-compact.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent);box-shadow:0 0 8px #4fc3f74d}.size-btn-compact.active .size-label{color:var(--form-accent)}.custom-size-input-compact{background:var(--form-bg-primary);border:1px solid var(--form-border-primary);border-radius:6px;color:var(--form-text-primary);font-size:10px;font-weight:600;text-align:center;padding:6px 4px;height:38px;transition:var(--form-transition)}.custom-size-input-compact:focus{outline:none;border-color:var(--form-border-focus);box-shadow:0 0 0 2px var(--form-accent-glow);background:var(--form-bg-secondary)}.custom-size-input-compact.active{background:var(--form-bg-active);border-color:var(--form-accent);color:var(--form-accent);box-shadow:0 0 8px #4fc3f74d}.figure-library{background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;margin:0;max-height:450px;display:flex;flex-direction:column}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-shrink:0}.library-header h3{color:#ffffffe6;margin:0;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.library-filters{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;flex-shrink:0}.filter-row{display:flex;gap:8px;align-items:center;justify-content:flex-start;flex-wrap:wrap}.dance-filter-compact{flex-shrink:0}.dance-select{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:8px 32px 8px 12px;color:#ffffffe6;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:140px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:16px}.dance-select:hover{background:#ffffff14;border-color:#fff3}.dance-select:focus{outline:none;border-color:#4fc3f7;box-shadow:0 0 0 2px #4fc3f733}.dance-select option{background:#2a2a2a;color:#fff;padding:8px 12px}.dance-tabs,.source-tabs{display:flex;background:#ffffff0d;border-radius:20px;padding:2px;gap:0;border:1px solid rgba(255,255,255,.1)}.dance-tabs .dance-tab,.source-tabs .dance-tab{background:transparent;border:none;color:#ffffffb3;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;border-radius:0;text-transform:capitalize}.dance-tabs .dance-tab:first-child,.source-tabs .dance-tab:first-child{border-radius:18px 0 0 18px}.dance-tabs .dance-tab:last-child,.source-tabs .dance-tab:last-child{border-radius:0 18px 18px 0}.dance-tabs .dance-tab:only-child,.source-tabs .dance-tab:only-child{border-radius:18px}.dance-tabs .dance-tab:hover,.source-tabs .dance-tab:hover{color:#ffffffe6;background:#ffffff14}.dance-tabs .dance-tab.active,.source-tabs .dance-tab.active{background:#4fc3f7;color:#1a1a1a;font-weight:600}.search-group{flex:1;max-width:200px}.search-group input{width:100%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:8px 16px;color:#fff;font-size:14px}.search-group input::placeholder{color:#ffffff80}.search-group input:focus{outline:none;border-color:#4fc3f7;box-shadow:0 0 0 2px #4fc3f733}.figure-library .filters-top-row,.figure-library .filter-group,.figure-library .dance-tiles,.figure-library .dance-tile,.figure-library .filter-btn{display:none}.figures-grid{display:grid;grid-template-columns:1fr;gap:8px;overflow-y:auto;max-height:350px;padding-right:8px;margin-right:-8px}.figures-grid::-webkit-scrollbar{width:6px}.figures-grid::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.figures-grid::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.figures-grid::-webkit-scrollbar-thumb:hover{background:#fff6}.template-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:12px;transition:all .2s ease;cursor:default}.template-card:hover{background:#ffffff0d;border-color:#4fc3f74d}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.template-name{color:#fff;font-size:14px;font-weight:600;margin:0;line-height:1.2;text-transform:uppercase;letter-spacing:.3px}.template-category{background:#4fc3f733;color:#4fc3f7;padding:3px 6px;border-radius:8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.template-description{color:#ffffffb3;font-size:12px;line-height:1.3;margin:0 0 8px}.template-preview{margin-bottom:8px;display:flex;align-items:center;gap:6px}.preview-label{color:#fff9;font-size:11px;font-weight:500}.preview-sequence{color:#fff;font-family:monospace;font-size:12px;background:#ffffff0d;padding:3px 6px;border-radius:3px;flex:1}.step-count{color:#fff9;font-size:11px}.template-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.template-tag{background:#ffffff1a;color:#ffffffb3;padding:2px 6px;border-radius:6px;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.2px}.template-actions{display:flex;justify-content:flex-end;gap:6px}.no-templates{text-align:center;padding:20px 12px;color:#ffffff80;font-style:italic}.no-templates p{margin:0;font-size:13px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#333;color:#fff;border-radius:8px;padding:20px;max-width:450px;width:90%;box-shadow:0 10px 40px #00000080;border:1px solid rgba(255,255,255,.1)}.modal-content h3{color:#fff;margin:0 0 16px;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.modal-content .form-group{margin-bottom:14px}.modal-content .form-group label{display:block;color:#ffffffe6;font-weight:600;margin-bottom:5px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.modal-content .form-group input,.modal-content .form-group textarea{width:100%;background:#444;color:#fff;border:1px solid #555;border-radius:4px;padding:8px 10px;font-size:13px;font-family:inherit;transition:all .2s ease;box-sizing:border-box}.modal-content .form-group input:focus,.modal-content .form-group textarea:focus{outline:none;border-color:#4fc3f7;box-shadow:0 0 0 1px #4fc3f74d;background-color:#555}.modal-content .form-group textarea{resize:vertical;min-height:60px}.current-steps-preview{margin:16px 0;padding:12px;background:#ffffff05;border-radius:6px;border:1px solid rgba(255,255,255,.08)}.current-steps-preview h4{color:#ffffffe6;margin:0 0 8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.steps-list{max-height:100px;overflow-y:auto}.step-preview-item{color:#ffffffb3;font-size:12px;line-height:1.4;padding:2px 0;font-family:monospace}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}@media (max-width: 768px){.figures-grid{grid-template-columns:1fr}.library-filters{gap:10px}.filters-top-row{flex-direction:column;gap:16px;align-items:flex-start}.filter-group{flex-direction:column;gap:6px;align-items:flex-start;width:100%}.dance-tiles,.source-filter{width:100%;justify-content:flex-start;gap:6px}.dance-tile,.filter-btn{font-size:11px;padding:6px 12px}.library-header{flex-direction:column;align-items:stretch;gap:10px}.modal-content{margin:20px;width:calc(100% - 40px)}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions .btn-primary,.modal-actions .btn-secondary{width:100%;justify-content:center}.filter-row{flex-direction:column;align-items:stretch;gap:12px}.dance-tabs,.source-tabs{flex-wrap:wrap;border-radius:16px}.dance-tabs .dance-tab,.source-tabs .dance-tab{padding:6px 12px;font-size:13px;flex:1;min-width:0}.search-group{max-width:none}.search-group input{border-radius:16px;padding:6px 12px;font-size:13px}}.modal-content::-webkit-scrollbar,.steps-list::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track,.steps-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.modal-content::-webkit-scrollbar-thumb,.steps-list::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.modal-content::-webkit-scrollbar-thumb:hover,.steps-list::-webkit-scrollbar-thumb:hover{background:#fff6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:linear-gradient(135deg,#2c3e50,#1a1d29);border:1px solid rgba(255,255,255,.15);border-radius:12px;box-shadow:0 20px 40px #0000004d;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.figure-manager-modal{width:800px;height:600px}.import-export-modal{width:600px;height:500px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 12px;background:transparent}.modal-header h2{margin:0;color:#fff;font-weight:600}.modal-close-btn{background:transparent;border:none;font-size:20px;cursor:pointer;color:#fff9;padding:4px;border-radius:4px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:#ffffff1a;color:#fff}.modal-body{flex:1;padding:0;overflow-y:auto}.figure-manager{display:flex;flex-direction:column;height:100%;background:transparent;padding:0 24px 24px}.header-controls{display:flex;align-items:center;gap:15px}.view-toggle{display:flex;background:#ffffff1a;border-radius:6px;border:1px solid rgba(255,255,255,.2);overflow:hidden}.view-toggle button{padding:8px 12px;border:none;background:transparent;cursor:pointer;font-size:16px;font-weight:500;color:#ffffffb3;transition:all .2s}.view-toggle button:hover{background:#ffffff1a;color:#ffffffe6}.view-toggle button.active{background:linear-gradient(45deg,#4fc3f7,#29b6f6);color:#fff}.close-btn{background:#dc3545;color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:16px;line-height:1;transition:background-color .2s}.close-btn:hover{background:#c82333}.dance-selector{margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;padding:16px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px}.dance-selector-left{display:flex;align-items:center;gap:12px}.dance-selector label{font-weight:600;color:#ffffffe6;font-size:14px;white-space:nowrap}.dance-selector select{padding:10px 14px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0d;color:#fff;font-size:14px;font-weight:500;min-width:160px;cursor:pointer;transition:all .2s ease}.dance-selector select:hover{background:#ffffff14;border-color:#ffffff4d}.dance-selector select:focus{outline:none;border-color:#4fc3f799;background:#ffffff14}.dance-selector select option{background:#2c3e50;color:#fff}.loading-spinner{text-align:center;padding:40px;color:#ffffffb3;font-style:italic}.figure-manager.error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:16px}.error-message{color:#ff6b6b;text-align:center;padding:20px;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:6px;font-size:14px;font-weight:500}.figure-manager.error button{background:#4fc3f733;color:#4fc3f7;border:1px solid rgba(79,195,247,.3);padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.figure-manager.error button:hover{background:#4fc3f74d;color:#fff}.no-figures{text-align:center;padding:60px 40px;color:#ffffffb3;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px;margin:20px 0}.no-figures p{margin:10px 0;font-size:14px;line-height:1.5}.no-figures p:first-child{font-size:16px;font-weight:600;color:#ffffffe6;margin-bottom:8px}.no-figures p:last-child{color:#4fc3f7cc;font-size:13px}.figures-container{flex:1;overflow-y:auto}.figures-container.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;padding:10px 0}.figures-container.list{display:flex;flex-direction:column;gap:10px}.figure-card{background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:16px;transition:all .2s ease;color:#fff}.figure-card:hover{background:#ffffff0a;border-color:#ffffff1f}.figures-container.list .figure-card{padding:14px;border-radius:6px}.figures-container.list .figure-header{margin-bottom:6px;padding-bottom:4px}.figures-container.list .figure-tags{margin-bottom:8px;gap:4px}.figures-container.list .figure-tag{padding:2px 6px;font-size:10px}.figures-container.list .figure-actions{gap:6px;padding-top:4px}.figures-container.list .figure-actions button{padding:4px 8px;font-size:11px}.figure-difficulty{padding:6px 12px;border-radius:16px;color:#fff;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;background:linear-gradient(45deg,#4fc3f7,#29b6f6);border:1px solid rgba(79,195,247,.4);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);white-space:nowrap}.tag{background:#ffffff14;color:#fffc;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;border:1px solid rgba(255,255,255,.1)}.figure-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.figure-meta{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.figure-source{padding:2px 6px;border-radius:3px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border:1px solid transparent}.figure-source.user{background:#4caf5026;color:#4caf50;border-color:#4caf504d}.figure-source.standard{background:#9c27b026;color:#9c27b0;border-color:#9c27b04d}.figures-container.list .figure-name{font-size:13px}.figure-dance{background:#4fc3f733;color:#4fc3f7;padding:4px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(79,195,247,.3);white-space:nowrap}.difficulty-badge{padding:4px 8px;border-radius:4px;color:#fff;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border:1px solid rgba(255,255,255,.2)}.figure-description{color:#fff9;margin:0 0 12px;line-height:1.4;font-size:12px}.figures-container.list .figure-description{margin:0 0 10px;font-size:12px}.figure-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.figure-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:8px;border-top:1px solid rgba(255,255,255,.05);opacity:1}.btn-primary{background:#4fc3f733;color:#4fc3f7;border:1px solid rgba(79,195,247,.3);padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary:hover{background:#4fc3f74d;color:#fff}.btn-secondary{background:#ffffff0d;color:#fffc;border:1px solid rgba(255,255,255,.1);padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#ffffff1a;color:#fff}.btn-danger{background:#ff572233;color:#ff5722;border:1px solid rgba(255,87,34,.3);padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-danger:hover{background:#ff57224d;color:#fff}.tab-navigation{display:flex;background:#f8f9fa;border-bottom:1px solid #dee2e6}.tab-navigation button{flex:1;padding:15px 20px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;color:#6c757d;transition:all .2s}.tab-navigation button:hover{background:#e9ecef;color:#495057}.tab-navigation button.active{background:#fff;color:#007bff;border-bottom:2px solid #007bff}.import-section,.export-section{padding:30px}.import-section h3,.export-section h3{margin:0 0 10px;color:#343a40;font-weight:600}.import-section p,.export-section p{margin:0 0 20px;color:#6c757d;line-height:1.5}.file-input-container{margin:20px 0}.file-input{position:absolute;opacity:0;width:.1px;height:.1px}.file-input-label{display:inline-block;padding:12px 24px;background:#007bff;color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.file-input-label:hover{background:#0056b3}.success-message{background:#d4edda;color:#155724;padding:12px;border-radius:4px;margin:15px 0;border:1px solid #c3e6cb}.format-info{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.format-info h4{margin:0 0 15px;color:#343a40;font-size:14px;font-weight:600}.format-info pre{margin:0;background:#fff;padding:15px;border-radius:4px;border:1px solid #dee2e6;overflow-x:auto;font-size:12px;line-height:1.4}.export-controls{display:flex;gap:20px;margin-bottom:30px}.export-actions{display:flex;gap:15px;justify-content:center}.export-actions button{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.export-actions button:disabled{opacity:.6;cursor:not-allowed}.no-figures-message{text-align:center;padding:20px;color:#6c757d;font-style:italic;background:#f8f9fa;border-radius:4px;margin-top:20px}.figure-difficulty.beginner{background:linear-gradient(45deg,#4caf50,#66bb6a);border-color:#4caf5066}.figure-difficulty.intermediate{background:linear-gradient(45deg,#ff9800,#ffb74d);border-color:#ff980066}.figure-difficulty.advanced{background:linear-gradient(45deg,#f44336,#ef5350);border-color:#f4433666}.figure-difficulty.expert{background:linear-gradient(45deg,#9c27b0,#ba68c8);border-color:#9c27b066}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.loading-content{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);background-size:200px 100%;animation:shimmer 1.5s infinite}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes buttonPulse{0%{box-shadow:0 0 #007bffb3}70%{box-shadow:0 0 0 10px #007bff00}to{box-shadow:0 0 #007bff00}}.transition-all{transition:all .2s ease}.transition-colors{transition:background-color .2s ease,color .2s ease,border-color .2s ease}.transition-transform{transition:transform .2s ease}.hover-lift:hover{transform:translateY(-2px)}.hover-scale:hover{transform:scale(1.05)}.focus-outline:focus{outline:2px solid #007bff;outline-offset:2px}.focus-ring:focus{box-shadow:0 0 0 3px #007bff40}@media (max-width: 768px){.figure-import-export{margin:10px;max-width:none}.export-controls{flex-direction:column;gap:15px}.export-actions{flex-direction:column}.import-section,.export-section{padding:20px}.dance-designer-content{flex-direction:column}.preview-panel{flex:1;border-right:none;border-bottom:1px solid #444}.construction-panel{flex:0 0 40%}.app{padding:10px}.tab-header{flex-direction:column;align-items:flex-start;gap:12px}.form-row{flex-direction:column;gap:12px}.dance-tabs{flex-wrap:wrap;gap:8px}.tab-btn{font-size:.9rem;padding:10px 18px}}@media (max-width: 480px){.app-header h1{font-size:2rem}.header-right{flex-direction:column;gap:8px}.beat-timeline-section{flex-direction:column;height:auto;gap:12px}.timeline-container{height:80px}.step-controls-inline{min-width:auto;margin-left:0;padding-left:0;border-left:none;border-top:1px solid rgba(255,255,255,.2);padding-top:12px}.overlay-card{max-width:140px;min-width:100px;font-size:.7rem;padding:6px 8px}.modal-content{width:95vw;margin:10px}.dance-floor-main{min-height:400px}}.hide-mobile{display:block}.show-mobile{display:none}@media (max-width: 768px){.hide-mobile{display:none}.show-mobile{display:block}}.container{max-width:1200px;margin:0 auto;padding:0 20px}.container-fluid{width:100%;padding:0 20px}.m-0{margin:0}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-3{margin:1rem}.m-4{margin:1.5rem}.m-5{margin:3rem}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-4{padding:1.5rem}.p-5{padding:3rem}.d-flex{display:flex}.flex-column{flex-direction:column}.flex-row{flex-direction:row}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.align-center{align-items:center}.flex-1{flex:1}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-uppercase{text-transform:uppercase}.text-lowercase{text-transform:lowercase}.text-capitalize{text-transform:capitalize}.dance-dropdown-container{position:relative;display:inline-block;z-index:999999;isolation:isolate}.dance-dropdown-trigger{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:140px;justify-content:space-between}.dance-dropdown-trigger:hover{background:#ffffff14;border-color:#ffffff4d}.dance-dropdown-trigger.has-selection{background:#4fc3f733;border-color:#4fc3f7}.dropdown-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-arrow{font-size:10px;opacity:.7;transition:transform .2s ease}.dance-dropdown-trigger:hover .dropdown-arrow{opacity:1}.dance-dropdown-panel{position:fixed;z-index:999999;background:#141923fa;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:20px;width:720px;max-width:90vw;box-shadow:0 12px 48px #0006;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);animation:dropdownFadeIn .2s ease;max-height:70vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(79,195,247,.3) transparent}.dance-dropdown-panel:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;z-index:-1;background:#0000001a;pointer-events:none}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.15)}.dropdown-header span{font-size:15px;font-weight:600;color:#fff;letter-spacing:.3px}.clear-all-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:#ffffffe6;padding:6px 14px;border-radius:16px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-all-btn:hover{background:#ffffff1a;border-color:#ffffff80;color:#fff}.dance-category{margin-bottom:24px}.dance-category:last-child{margin-bottom:0}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(79,195,247,.2);position:sticky;top:0;background:#141923fa;z-index:10}.category-name{font-size:14px;font-weight:600;color:#4fc3f7;text-transform:uppercase;letter-spacing:.8px}.category-select-all{background:transparent;border:1px solid rgba(79,195,247,.3);color:#4fc3f7;font-size:11px;cursor:pointer;padding:4px 8px;border-radius:12px;transition:all .2s ease;font-weight:500}.category-select-all:hover{background:#4fc3f71a;border-color:#4fc3f780;color:#fff}.dance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px 12px;align-items:start;max-width:100%}.dance-checkbox{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative;border:1px solid transparent;min-width:0;width:100%}.dance-checkbox:hover{background:#ffffff0f;border-color:#ffffff1a}.dance-checkbox input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkmark{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-radius:4px;position:relative;flex-shrink:0;transition:all .2s ease;background:transparent}.dance-checkbox input:checked+.checkmark{background:linear-gradient(135deg,#4fc3f7,#29b6f6);border-color:#4fc3f7;box-shadow:0 2px 8px #4fc3f74d}.dance-checkbox input:checked+.checkmark:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.dance-name{font-size:13px;color:#ffffffe6;line-height:1.3;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.dropdown-footer{margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);text-align:right}.apply-filters-btn{background:linear-gradient(135deg,#4fc3f7,#29b6f6);border:none;color:#fff;padding:8px 16px;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.apply-filters-btn:hover{background:linear-gradient(135deg,#29b6f6,#4fc3f7);transform:translateY(-1px)}@media (max-width: 768px){.dance-dropdown-panel{width:90vw;max-width:500px;padding:16px}.dance-categories-container{grid-template-columns:1fr;gap:20px}.dance-category .dance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.dance-checkbox{padding:6px 8px}.dance-name{font-size:12px}}@media (max-width: 480px){.dance-dropdown-panel{width:95vw;max-width:320px}.dance-category .dance-grid{grid-template-columns:1fr}}.dance-checkbox:hover .dance-name{color:#fff}.dance-categories-container{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}.dance-category{margin-bottom:0}.dance-category .dance-grid{display:flex;flex-direction:column;gap:8px}.dance-category .dance-checkbox{width:100%}.page-content{padding:20px;max-width:1200px;margin:0 auto}.page-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.back-button{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;padding:8px 12px;cursor:pointer;font-size:14px;color:#333;transition:all .2s ease}.back-button:hover{background:#e8e8e8;border-color:#ccc}.page-header h2{margin:0;color:#333;font-size:24px;font-weight:600}.import-export-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px}.app-title-link,.app-title-link:hover{text-decoration:none;color:inherit}
