.recording-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:16px}.recording-content{display:flex;flex-direction:column;align-items:center;gap:20px;background:#fffffff2;padding:40px;border-radius:12px;box-shadow:0 20px 60px #0000004d}.recording-indicator{display:flex;align-items:center;gap:12px;font-size:1.3rem;font-weight:600;color:#e74c3c}.recording-dot{width:12px;height:12px;border-radius:50%;background:#e74c3c;animation:recording-pulse 1s infinite}@keyframes recording-pulse{0%,to{opacity:1}50%{opacity:.5}}.recording-progress-bar{width:300px;height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden}.recording-progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .1s linear}.recording-text{font-size:1.1rem;font-weight:600;color:#2c3e50}@media (max-width: 480px){.recording-content{padding:30px}.recording-progress-bar{width:200px}}.svg-animator{width:100%;height:100%;display:flex;flex-direction:column;background:#fff}.animator-container{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fafafa,#f5f5f5);position:relative}.svg-container{display:flex;align-items:center;justify-content:center}.svg-container svg{max-width:100%;max-height:100%;border:none;border-radius:8px;box-shadow:0 10px 40px #00000014}.animator-info{padding:28px;border-top:1px solid #e8e8e8;background:linear-gradient(135deg,#fff,#f9f9f9);max-height:300px;overflow-y:auto}.progress-info{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.line-count{font-size:.9rem;color:#666;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.progress-bar{width:100%;height:8px;background:#e8e8e8;border-radius:4px;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .15s ease;border-radius:4px;box-shadow:0 2px 8px #667eea66}.lengths-info{margin-top:24px}.no-lengths{color:#999;font-size:.95rem;font-style:italic;padding:16px;text-align:center;background:#f5f5f5;border-radius:8px}.lengths-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.length-row{display:flex;align-items:center;gap:12px;font-size:.9rem;color:#333;background:#fff;padding:14px 16px;border-radius:10px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000a;transition:all .3s ease}.length-row:hover{border-color:#ddd;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.color-swatch{width:24px;height:20px;border-radius:4px;border:2px solid rgba(0,0,0,.1);display:inline-block;flex-shrink:0;box-shadow:0 2px 4px #0000001f}.color-label{flex:1;color:#555;font-weight:500;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem}.length-value{font-weight:700;color:#667eea;margin-left:auto;font-size:.95rem}.length-total{color:#999;font-size:.8rem;white-space:nowrap}.controls{background:#fff;border-radius:20px;padding:20px;box-shadow:0 20px 60px #0000001f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);animation:slideUp .6s ease-out .3s both;position:sticky;bottom:10px;z-index:100}.controls-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px}.control-section{display:flex;flex-direction:column;gap:12px}.control-label{font-size:.8rem;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:1px}.button-group{display:flex;gap:10px;flex-wrap:wrap}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:10px;font-size:.95rem;font-weight:700;transition:all .3s cubic-bezier(.34,1.56,.64,1);cursor:pointer;border:none;letter-spacing:.3px;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#fff3;transition:left .5s ease;z-index:0}.btn:hover:before{left:100%}.btn>*{position:relative;z-index:1}.btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #00000026}.btn:active{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex:1;box-shadow:0 4px 15px #667eea4d}.btn-primary.playing{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 15px #f5576c4d}.btn-primary:hover{box-shadow:0 8px 25px #667eea66}.btn-secondary{background:#f5f7fa;color:#2c3e50;border:2px solid #e8eaed;flex:1;font-weight:700}.btn-secondary:hover{background:#eef1f8;border-color:#667eea;color:#667eea;box-shadow:0 4px 12px #667eea26}.btn-record{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;width:100%;animation:pulse 2.5s cubic-bezier(.4,0,.6,1) infinite;box-shadow:0 4px 15px #f5576c4d}.btn-record:hover{box-shadow:0 8px 25px #f5576c66;animation:pulse 1.5s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{box-shadow:0 0 #f5576cb3}50%{box-shadow:0 0 0 8px #f5576c00}}.speed-controls{display:flex;gap:8px;flex-wrap:wrap}.speed-btn{padding:10px 14px;border-radius:8px;font-size:.9rem;font-weight:700;background:#f5f7fa;color:#2c3e50;border:2px solid #e8eaed;transition:all .3s cubic-bezier(.34,1.56,.64,1);cursor:pointer;flex:1;min-width:54px;letter-spacing:.3px}.speed-btn:hover{background:#eef1f8;border-color:#667eea;color:#667eea;transform:scale(1.05)}.speed-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 15px #667eea4d;transform:scale(1.05)}@media (max-width: 768px){.controls{padding:20px}.controls-group{grid-template-columns:1fr;gap:20px}.btn{font-size:.85rem;padding:14px 16px}.speed-controls{justify-content:space-between}.speed-btn{flex:1;min-width:48px;padding:10px 8px;font-size:.85rem}}.example-selector{display:flex;flex-direction:column;gap:12px;padding:20px;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000001f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);animation:slideUp .6s ease-out both}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.selector-label{font-size:.8rem;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:1px}.selector-options{display:flex;flex-wrap:wrap;gap:10px}.example-btn{padding:10px 16px;border-radius:10px;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#2c3e50;border:2px solid #e8eaed;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);letter-spacing:.3px;position:relative;overflow:hidden}.example-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#667eea1a;transition:left .5s ease;z-index:0}.example-btn:hover:before{left:100%}.example-btn>*{position:relative;z-index:1}.example-btn:hover{background:linear-gradient(135deg,#eef1f8,#b8c5d6);border-color:#667eea;color:#667eea;transform:translateY(-3px);box-shadow:0 8px 20px #667eea33}.example-btn:active{transform:translateY(-1px)}.loading{color:#999;font-size:.9rem;text-align:center;padding:12px;font-style:italic}@media (max-width: 768px){.example-selector{padding:16px}.selector-options{gap:8px}.example-btn{font-size:.85rem;padding:8px 12px;flex:1;min-width:100px}}.app{width:100%;min-height:100vh;padding:24px;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed}.container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.header{text-align:center;margin-bottom:20px;animation:slideDown .6s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.header h1{font-size:3.2rem;margin-bottom:12px;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:-1px;text-shadow:0 4px 20px rgba(0,0,0,.1)}.header p{font-size:1.15rem;color:#ffffffe6;font-weight:500}.main{display:grid;grid-template-columns:1fr;gap:32px;animation:fadeIn .8s ease-out .2s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.canvas-section{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0003;min-height:500px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.upload-area{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .4s ease;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);gap:24px;position:relative;overflow:hidden}.upload-area:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(102,126,234,.1) 0%,transparent 50%);pointer-events:none}.upload-area:hover{background:linear-gradient(135deg,#f0f2f5,#b8c5d6);transform:scale(1.02)}.upload-icon{font-size:5.5rem;animation:float 3s ease-in-out infinite;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.upload-text{font-size:1.4rem;color:#2c3e50;font-weight:700;z-index:1}.upload-subtext{font-size:1rem;color:#7f8c8d;z-index:1}.footer{text-align:center;color:#ffffffd9;padding:24px;font-size:.95rem;font-weight:500}@media (max-width: 768px){.app{padding:16px}.container{gap:24px}.header h1{font-size:2.2rem}.header p{font-size:.95rem}.canvas-section{min-height:350px;border-radius:16px}.upload-icon{font-size:3.5rem}.upload-text{font-size:1.1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;color:#333}#app{width:100%;min-height:100vh}button{background:none;border:none;cursor:pointer;padding:0;font:inherit}button:disabled{opacity:.5;cursor:not-allowed}input{font-family:inherit}input[type=file]{display:none}
