.canvas-container{width:100%;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(102,126,234,0.3)}.canvas-header{background:rgba(255,255,255,0.98);padding:14px 24px;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;backdrop-filter:blur(10px)}.header-content h1{margin:0;font-size:24px;font-weight:700;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-0.5px;line-height:1.2}.canvas-subtitle{margin:4px 0 0 0;color:#666;font-size:12px;font-weight:400;line-height:1.4}.canvas-controls{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.canvas-controls .button{padding:6px 12px;font-size:12px;font-weight:600;border-radius:6px;transition:all 0.2s cubic-bezier(0.4,0,0.2,1);box-shadow:0 1px 4px rgba(0,0,0,0.08);white-space:nowrap;line-height:1.4}.canvas-controls .button:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,0.12)}.canvas-controls .button:active{transform:translateY(0);box-shadow:0 1px 4px rgba(0,0,0,0.1)}#fullscreen-toggle-btn{min-width:60px}#new-canvas-btn{min-width:48px}#template-btn{min-width:48px}#inspire-btn{min-width:58px}#save-btn{min-width:48px}#export-btn{min-width:48px}.toolbar{background:linear-gradient(to bottom,#fff 0,#f8f9fa 100%);padding:12px 20px;border-bottom:2px solid #e9ecef;display:flex;gap:16px;flex-wrap:wrap;align-items:center;box-shadow:0 2px 8px rgba(0,0,0,0.06)}.toolbar-separator{width:1px;height:32px;background:linear-gradient(to bottom,transparent 0,rgba(102,126,234,0.15) 20%,rgba(102,126,234,0.15) 80%,transparent 100%);margin:0 4px}.tool-group{display:flex;gap:6px;align-items:center;padding:5px 10px;background:white;border-radius:8px;border:1px solid #e0e6ed;box-shadow:0 1px 3px rgba(0,0,0,0.05);transition:all 0.2s cubic-bezier(0.4,0,0.2,1);min-height:44px}.tool-group:hover{border-color:rgba(102,126,234,0.2);box-shadow:0 2px 8px rgba(102,126,234,0.12)}.font-tools:hover,.batch-tools:hover,.align-tools:hover,.selection-info:hover{transform:translateY(-1px)}.tool-group label,.tool-group .batch-label,.tool-group .selection-count{font-size:12px;color:#64748b;font-weight:600;letter-spacing:0.3px;white-space:nowrap;line-height:1;display:flex;align-items:center;margin:0;padding:0}.tool-btn{width:38px;height:38px;border:1.5px solid #e0e6ed;background:white;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:all 0.2s cubic-bezier(0.4,0,0.2,1);position:relative}.tool-btn::before{content:'';position:absolute;inset:0;border-radius:6px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);opacity:0;transition:opacity 0.2s ease}.tool-btn:hover{background:#f8f9fa;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,0.2)}.tool-btn:active{transform:translateY(0)}.tool-btn.active{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-color:#667eea;color:white;transform:scale(1.05);box-shadow:0 4px 16px rgba(102,126,234,0.4);animation:btnPulse 0.3s ease}@keyframes btnPulse{0%,100%{transform:scale(1.05)}50%{transform:scale(1.1)}}.tool-btn span{pointer-events:none;position:relative;z-index:1}.color-picker-group,.line-width-group{display:flex;align-items:center;gap:6px}.color-picker-group input[type="color"]{width:36px;height:36px;border:1.5px solid #e0e6ed;border-radius:6px;cursor:pointer;transition:all 0.2s ease;padding:2px}.color-picker-group input[type="color"]:hover{border-color:#667eea;transform:scale(1.08);box-shadow:0 2px 6px rgba(102,126,234,0.15)}.color-picker-group input[type="color"]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,0.15)}.line-width-group input[type="range"]{width:100px;height:6px;border-radius:3px;background:linear-gradient(to right,#e9ecef 0,#667eea 100%);outline:none}.line-width-group input[type="range"]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.2)}.line-width-group input[type="range"]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);cursor:pointer;border:none;box-shadow:0 2px 6px rgba(0,0,0,0.2)}#line-width-value{font-size:12px;color:#334155;min-width:22px;font-weight:700;background:#f1f5f9;padding:3px 6px;border-radius:4px;line-height:1.4}.font-tools{background:linear-gradient(135deg,rgba(102,126,234,0.04) 0,rgba(118,75,162,0.04) 100%);border:1.5px solid rgba(102,126,234,0.2);padding:5px 10px;gap:8px;transition:all 0.2s cubic-bezier(0.4,0,0.2,1)}.font-tools:hover{border-color:rgba(102,126,234,0.35);box-shadow:0 2px 8px rgba(102,126,234,0.15);transform:translateY(-1px)}.font-select{padding:5px 8px;font-size:12px;border:1.5px solid #e0e6ed;border-radius:6px;background:white;cursor:pointer;transition:all 0.2s ease;font-weight:500;min-width:95px;outline:none;height:32px;line-height:1.4}.font-select:hover{border-color:#667eea;background:#f8f9fc}.font-select:focus{border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,0.1)}.font-size-group{display:flex;align-items:center;gap:2px;background:white;border:1.5px solid #e0e6ed;border-radius:6px;padding:2px;transition:all 0.2s ease;height:32px}.font-size-group:hover{border-color:#667eea;background:#f8f9fc}.font-size-group:focus-within{border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,0.1)}.font-size-btn{width:26px;height:26px;border:none;background:transparent;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:#64748b;transition:all 0.15s ease;font-weight:700}.font-size-btn:hover{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;transform:scale(1.05)}.font-size-btn:active{transform:scale(0.98)}.font-size-input{width:42px;border:none;background:transparent;text-align:center;font-size:12px;font-weight:600;color:#334155;outline:none;padding:0;line-height:1.4}.font-size-input::-webkit-inner-spin-button,.font-size-input::-webkit-outer-spin-button{opacity:1;height:24px}.font-color-group{display:flex;align-items:center;gap:6px}.font-color-picker{width:32px;height:32px;border:1.5px solid #e0e6ed;border-radius:6px;cursor:pointer;transition:all 0.2s ease;padding:2px;background:white}.font-color-picker:hover{border-color:#667eea;transform:scale(1.08);box-shadow:0 2px 6px rgba(102,126,234,0.2)}.font-color-picker:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,0.15)}.zoom-level{font-size:12px;color:#334155;font-weight:700;padding:5px 10px;background:white;border-radius:6px;border:1.5px solid #e0e6ed;min-width:48px;text-align:center;line-height:1.4;transition:all 0.2s ease;user-select:none;cursor:default}.canvas-wrapper{position:relative;width:100%;height:650px;background:#fff;overflow:hidden;cursor:default;border-top:2px solid #e9ecef}.canvas-wrapper.panning{cursor:grab}.canvas-wrapper.grabbing{cursor:grabbing}#main-canvas{display:block;position:absolute;top:0;left:0;background:#fff;background-image:linear-gradient(rgba(102,126,234,0.08) 1px,transparent 1px),linear-gradient(90deg,rgba(102,126,234,0.08) 1px,transparent 1px);background-size:24px 24px}.minimap{position:absolute;bottom:24px;right:24px;width:160px;height:160px;background:rgba(255,255,255,0.98);border:3px solid #667eea;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px rgba(102,126,234,0.3);backdrop-filter:blur(10px);transition:all 0.3s ease}.minimap:hover{transform:scale(1.05);box-shadow:0 12px 32px rgba(102,126,234,0.4)}#minimap-canvas{width:100%;height:100%}.pan-indicator{position:absolute;top:24px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:600;box-shadow:0 8px 24px rgba(102,126,234,0.4);z-index:50;animation:slideDown 0.3s ease;backdrop-filter:blur(10px)}@keyframes slideDown{from{transform:translateX(-50%) translateY(-20px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.6);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn 0.25s ease;backdrop-filter:blur(4px)}#inspire-modal{background:radial-gradient( circle at 30% 20%,rgba(102,126,234,0.15) 0,rgba(0,0,0,0.6) 50%,rgba(118,75,162,0.15) 100% );animation:inspireBackdropIn 0.4s ease}@keyframes inspireBackdropIn{from{opacity:0;backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(8px)}}@keyframes fadeIn{from{opacity:0;backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(4px)}}.modal-content{background:linear-gradient(to bottom,#fff 0,#fafbfc 100%);border-radius:24px;max-width:800px;width:92%;max-height:90vh;overflow-y:auto;box-shadow:0 30px 90px rgba(0,0,0,0.35),0 0 0 1px rgba(102,126,234,0.15),inset 0 1px 0 rgba(255,255,255,0.8);animation:slideUp 0.3s cubic-bezier(0.4,0,0.2,1)}#inspire-modal .modal-content{background:linear-gradient( to bottom,#fff 0,rgba(255,255,255,0.98) 50%,rgba(102,126,234,0.03) 100% );border-radius:16px;max-width:500px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 40px 120px rgba(102,126,234,0.4),0 0 0 2px rgba(102,126,234,0.2),inset 0 2px 0 rgba(255,255,255,1);animation:inspireSlideUp 0.5s cubic-bezier(0.34,1.56,0.64,1);position:relative;overflow:hidden}#inspire-modal .modal-content::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient( circle,rgba(102,126,234,0.05) 0,transparent 70% );animation:floatingGlow 6s ease-in-out infinite;pointer-events:none;z-index:0}#inspire-modal .modal-header{flex-shrink:0;position:relative;z-index:1}#inspire-modal .modal-body{flex:1;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1;padding:16px 20px 20px 20px}#inspire-modal .modal-body::-webkit-scrollbar{width:6px}#inspire-modal .modal-body::-webkit-scrollbar-track{background:rgba(102,126,234,0.05);border-radius:10px}#inspire-modal .modal-body::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:10px;transition:background 0.3s ease}#inspire-modal .modal-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2 0,#667eea 100%)}@keyframes floatingGlow{0%,100%{transform:translate(0,0) scale(1);opacity:0.6}50%{transform:translate(10%,10%) scale(1.1);opacity:0.8}}@keyframes inspireSlideUp{from{transform:translateY(80px) scale(0.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes slideUp{from{transform:translateY(60px) scale(0.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{padding:14px 20px;border-bottom:1px solid rgba(102,126,234,0.12);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,rgba(102,126,234,0.04) 0,rgba(255,255,255,0.95) 100%);position:sticky;top:0;z-index:10;backdrop-filter:blur(12px) saturate(180%);box-shadow:0 1px 3px rgba(0,0,0,0.04)}.modal-header h2{margin:0;font-size:17px;font-weight:700;color:#2d3748;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:5px;letter-spacing:-0.3px}.close-btn{width:30px;height:30px;border:none;background:rgba(102,126,234,0.08);border-radius:50%;font-size:19px;cursor:pointer;color:#667eea;transition:all 0.25s cubic-bezier(0.4,0,0.2,1);display:flex;align-items:center;justify-content:center;line-height:1;flex-shrink:0}.close-btn:hover{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;transform:rotate(90deg) scale(1.15);box-shadow:0 6px 16px rgba(102,126,234,0.4)}.modal-body{padding:22px 26px 26px 26px}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}.template-item{padding:18px 14px 16px 14px;border:1.5px solid rgba(102,126,234,0.12);border-radius:14px;text-align:center;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);background:linear-gradient(135deg,#fff 0,rgba(102,126,234,0.02) 100%);position:relative;overflow:hidden}.template-item::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;background:linear-gradient(90deg,#667eea 0,#764ba2 50%,#667eea 100%);transform:scaleX(0);transform-origin:center;transition:transform 0.35s cubic-bezier(0.4,0,0.2,1)}.template-item:hover{border-color:rgba(102,126,234,0.4);box-shadow:0 10px 28px rgba(102,126,234,0.25),0 0 0 1px rgba(102,126,234,0.1);transform:translateY(-5px) scale(1.02);background:white}.template-item:hover::before{transform:scaleX(1)}.template-icon{font-size:42px;margin-bottom:8px;filter:drop-shadow(0 3px 6px rgba(102,126,234,0.15));line-height:1;transition:transform 0.3s ease}.template-item:hover .template-icon{transform:scale(1.1) rotateZ(5deg)}.template-item h3{margin:6px 0 5px 0;font-size:15px;font-weight:700;color:#2d3748;line-height:1.3;letter-spacing:-0.2px}.template-item p{margin:0;font-size:12.5px;color:#6c757d;line-height:1.5;letter-spacing:0.1px}.inspire-content{max-width:100%;margin:0;padding:0;position:relative}.inspire-content::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient( 90deg,#667eea 0,#764ba2 25%,#f093fb 50%,#764ba2 75%,#667eea 100% );background-size:200% 100%;animation:flowingGradient 3s ease infinite;border-radius:2px 2px 0 0}@keyframes flowingGradient{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}.inspire-section{margin-bottom:6px;padding:8px;background:linear-gradient( 135deg,rgba(102,126,234,0.05) 0,rgba(255,255,255,0.95) 30%,#fff 100% );border-radius:8px;border:1.5px solid transparent;background-clip:padding-box;position:relative;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);box-shadow:0 2px 8px rgba(102,126,234,0.08),0 4px 16px rgba(102,126,234,0.04),inset 0 1px 0 rgba(255,255,255,0.9)}.inspire-section::before{content:'';position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient( 135deg,rgba(102,126,234,0.3) 0,rgba(118,75,162,0.3) 50%,rgba(102,126,234,0.3) 100% );border-radius:16px;z-index:-1;opacity:0;transition:opacity 0.4s ease}.inspire-section:hover{transform:translateY(-2px) scale(1.005);box-shadow:0 6px 18px rgba(102,126,234,0.15),0 12px 36px rgba(102,126,234,0.1),inset 0 1px 0 rgba(255,255,255,1)}.inspire-section:hover::before{opacity:1}.inspire-section h3{margin:0 0 5px 0;font-size:12px;font-weight:700;color:#2d3748;display:flex;align-items:center;gap:4px;letter-spacing:-0.3px;text-shadow:0 1px 2px rgba(102,126,234,0.1)}.inspire-word{font-size:18px;font-weight:900;background:linear-gradient( 135deg,#667eea 0,#764ba2 50%,#f093fb 100% );-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;padding:6px 8px;background-color:white;border-radius:6px;border:1.5px solid rgba(102,126,234,0.2);letter-spacing:1.5px;line-height:1.2;position:relative;box-shadow:0 4px 12px rgba(102,126,234,0.12),0 8px 24px rgba(102,126,234,0.08),inset 0 1px 0 rgba(255,255,255,0.9);transition:all 0.4s cubic-bezier(0.4,0,0.2,1)}.inspire-word:hover{transform:scale(1.03);box-shadow:0 6px 16px rgba(102,126,234,0.18),0 12px 32px rgba(102,126,234,0.12),inset 0 1px 0 rgba(255,255,255,1)}.inspire-question{font-size:12px;color:#2d3748;padding:6px 10px;background:linear-gradient( 135deg,#fff 0,rgba(102,126,234,0.02) 100% );border-radius:6px;font-style:italic;text-align:center;line-height:1.5;border:1.5px solid rgba(102,126,234,0.2);font-weight:500;position:relative;box-shadow:0 4px 12px rgba(102,126,234,0.12),0 8px 24px rgba(102,126,234,0.08),inset 0 1px 0 rgba(255,255,255,0.9);transition:all 0.4s cubic-bezier(0.4,0,0.2,1)}.inspire-question::before,.inspire-question::after{content:'"';font-size:16px;color:rgba(102,126,234,0.25);font-weight:900;position:absolute;line-height:1}.inspire-question::before{top:2px;left:5px}.inspire-question::after{bottom:2px;right:5px}.inspire-question:hover{transform:scale(1.015);box-shadow:0 6px 16px rgba(102,126,234,0.18),0 12px 32px rgba(102,126,234,0.12),inset 0 1px 0 rgba(255,255,255,1)}.inspire-image-container{min-height:60px;background:linear-gradient( 135deg,rgba(102,126,234,0.03) 0,#fff 50%,rgba(118,75,162,0.03) 100% );border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1.5px solid rgba(102,126,234,0.2);position:relative;box-shadow:0 4px 12px rgba(102,126,234,0.12),0 8px 24px rgba(102,126,234,0.08),inset 0 1px 0 rgba(255,255,255,0.9);transition:all 0.4s cubic-bezier(0.4,0,0.2,1)}.inspire-image-container::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient( 45deg,transparent 30%,rgba(255,255,255,0.3) 50%,transparent 70% );transform:rotate(45deg);opacity:0;transition:opacity 0.6s ease}.inspire-image-container:hover::before{opacity:1;animation:shimmer 2s ease infinite}@keyframes shimmer{0%{transform:translateX(-100%) rotate(45deg)}100%{transform:translateX(100%) rotate(45deg)}}.inspire-image-container:hover{transform:scale(1.015);box-shadow:0 6px 16px rgba(102,126,234,0.18),0 12px 32px rgba(102,126,234,0.12),inset 0 1px 0 rgba(255,255,255,1)}.inspire-placeholder{color:#94a3b8;font-style:italic;text-align:center;padding:6px;font-size:11px;font-weight:500;letter-spacing:0.3px;position:relative;z-index:1}.inspire-image-container img{width:100%;height:auto;border-radius:6px;position:relative;z-index:1}.inspire-actions{display:flex;gap:6px;justify-content:center;margin-top:6px;padding-top:6px;border-top:1.5px solid rgba(102,126,234,0.1);position:relative}.inspire-actions::before{content:'';position:absolute;top:-1.5px;left:50%;transform:translateX(-50%);width:40px;height:3px;background:linear-gradient( 90deg,transparent 0,rgba(102,126,234,0.4) 50%,transparent 100% );border-radius:2px}.inspire-actions .button{min-width:100px;padding:6px 12px;font-size:12px;font-weight:700;border-radius:8px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:0 2px 8px rgba(102,126,234,0.2),0 4px 16px rgba(102,126,234,0.1);position:relative;overflow:hidden}.inspire-actions .button::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,0.3);transform:translate(-50%,-50%);transition:width 0.6s ease,height 0.6s ease}.inspire-actions .button:hover::before{width:300px;height:300px}.inspire-actions .button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,0.25),0 8px 24px rgba(102,126,234,0.15)}.inspire-actions .button:active{transform:translateY(-1px)}.export-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:12px}.export-option{padding:18px 12px 16px 12px;border:1.5px solid rgba(102,126,234,0.12);border-radius:14px;background:linear-gradient(135deg,#fff 0,rgba(102,126,234,0.02) 100%);cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);text-align:center;position:relative;overflow:hidden}.export-option::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;background:linear-gradient(90deg,#667eea 0,#764ba2 50%,#667eea 100%);transform:scaleX(0);transform-origin:center;transition:transform 0.35s cubic-bezier(0.4,0,0.2,1)}.export-option:hover{border-color:rgba(102,126,234,0.4);box-shadow:0 10px 28px rgba(102,126,234,0.25),0 0 0 1px rgba(102,126,234,0.1);transform:translateY(-5px) scale(1.02);background:white}.export-option:hover::before{transform:scaleX(1)}.export-icon{font-size:38px;display:block;margin-bottom:8px;filter:drop-shadow(0 3px 6px rgba(102,126,234,0.15));line-height:1;transition:transform 0.3s ease}.export-option:hover .export-icon{transform:scale(1.1) rotateZ(-5deg)}.export-option h3{margin:6px 0 5px 0;font-size:14px;font-weight:700;color:#2d3748;line-height:1.3;letter-spacing:-0.2px}.export-option p{margin:0;font-size:11.5px;color:#6c757d;line-height:1.4;letter-spacing:0.1px}.text-input-box{position:absolute;background:linear-gradient(135deg,#fff 0,#faf8ff 100%);border:none;border-radius:12px;padding:0;box-shadow:0 10px 40px rgba(102,126,234,0.15),0 0 0 1px rgba(102,126,234,0.1),0 4px 12px rgba(0,0,0,0.08);z-index:100;min-width:280px;max-width:400px;backdrop-filter:blur(10px);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);animation:textBoxFadeIn 0.25s ease;overflow:hidden}@keyframes textBoxFadeIn{from{opacity:0;transform:scale(0.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.text-input-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea 0,#764ba2 50%,#f093fb 100%);background-size:200% 100%;animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}.text-input-box:hover{box-shadow:0 15px 50px rgba(102,126,234,0.2),0 0 0 1px rgba(102,126,234,0.15),0 6px 16px rgba(0,0,0,0.1);transform:translateY(-2px)}.text-input-box::after{content:'📝 输入文字';display:block;padding:10px 16px;font-size:12px;font-weight:600;color:#667eea;background:linear-gradient(135deg,rgba(102,126,234,0.05) 0,rgba(118,75,162,0.05) 100%);border-bottom:1px solid rgba(102,126,234,0.1);letter-spacing:0.5px}#text-input{width:100%;min-height:80px;max-height:200px;border:none;border-radius:0;padding:14px 16px;font-size:14px;resize:vertical;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;transition:all 0.2s ease;background:transparent;line-height:1.6;color:#2d3748}#text-input::placeholder{color:#a0aec0;font-style:italic}#text-input:focus{outline:none;background:rgba(255,255,255,0.8)}.text-input-actions{display:flex;gap:8px;padding:12px 16px;background:linear-gradient(135deg,rgba(102,126,234,0.03) 0,rgba(118,75,162,0.03) 100%);border-top:1px solid rgba(102,126,234,0.08)}.text-input-actions .button{flex:1;padding:9px 16px;font-size:13px;font-weight:600;border-radius:7px;transition:all 0.2s cubic-bezier(0.4,0,0.2,1);border:none;cursor:pointer;position:relative;overflow:hidden}.text-input-actions .button::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,0.3);transform:translate(-50%,-50%);transition:width 0.4s,height 0.4s}.text-input-actions .button:active::before{width:300px;height:300px}.text-input-actions .button:first-child{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;box-shadow:0 3px 10px rgba(102,126,234,0.3);font-weight:700}.text-input-actions .button:first-child:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(102,126,234,0.4)}.text-input-actions .button:first-child:active{transform:translateY(0)}.text-input-actions .button.secondary{background:white;color:#667eea;border:1.5px solid rgba(102,126,234,0.3);font-weight:600}.text-input-actions .button.secondary:hover{border-color:#667eea;background:rgba(102,126,234,0.05);transform:translateY(-1px)}.text-input-actions .button.secondary:active{transform:translateY(0)}.canvas-instructions{background:white;padding:40px;margin-top:32px;border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,0.08);border:2px solid #f0f0f0}.canvas-instructions h3{margin:0 0 28px 0;font-size:28px;font-weight:700;color:#2d3748;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.canvas-instructions h4{margin:32px 0 16px 0;font-size:20px;font-weight:700;color:#2d3748}.instructions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:36px}.instruction-item{display:flex;gap:18px;padding:24px;background:linear-gradient(135deg,#f8f9fa 0,#fff 100%);border-radius:12px;border-left:4px solid #667eea;box-shadow:0 2px 8px rgba(0,0,0,0.05);transition:all 0.3s ease}.instruction-item:hover{transform:translateX(6px);box-shadow:0 6px 20px rgba(102,126,234,0.15);border-left-color:#764ba2}.instruction-icon{font-size:36px;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.1))}.instruction-text{flex:1}.instruction-text strong{display:block;margin-bottom:6px;color:#2d3748;font-size:17px;font-weight:700}.instruction-text br + text{color:#6c757d;line-height:1.6}.canvas-tips{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);padding:35px;border-radius:16px;box-shadow:0 10px 40px rgba(102,126,234,0.25);position:relative;overflow:hidden}.canvas-tips::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ffd700,#ff6b6b,#51cf66,#4dabf7,#ffd700);background-size:200% 100%;animation:gradientFlow 3s linear infinite}@keyframes gradientFlow{0%{background-position:0 0}100%{background-position:200% 0}}.canvas-tips h4{margin:0 0 25px 0;font-size:24px;color:white;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,0.2);letter-spacing:0.5px}.usage-sections{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:0}.usage-section{background:white;padding:20px;border-radius:12px;border:2px solid rgba(255,255,255,0.3);box-shadow:0 4px 20px rgba(0,0,0,0.1);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);min-width:0;backdrop-filter:blur(10px);position:relative;overflow:hidden}.usage-section::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease}.usage-section:hover::before{transform:scaleX(1)}.usage-section:hover{border-color:rgba(255,255,255,0.5);box-shadow:0 8px 30px rgba(0,0,0,0.15);transform:translateY(-3px)}.usage-section h5{margin:0 0 14px 0;font-size:15px;font-weight:700;color:#667eea;display:flex;align-items:center;gap:6px;padding-bottom:10px;border-bottom:2px solid rgba(102,126,234,0.15)}.usage-section ul{margin:0;padding:0;list-style:none}.usage-section li{margin:0;padding:8px 12px;color:#495057;line-height:1.5;font-size:12px;border-radius:6px;transition:all 0.2s ease;position:relative;padding-left:20px}.usage-section li::before{content:'▸';position:absolute;left:6px;color:#667eea;font-size:10px;top:50%;transform:translateY(-50%)}.usage-section li:hover{background:rgba(102,126,234,0.08);padding-left:24px}.usage-section li strong{color:#2d3748;font-weight:600;font-size:13px}.canvas-tips ul{margin:16px 0;padding-left:28px}.canvas-tips li{margin:14px 0;color:#495057;line-height:1.8;font-size:15px}.canvas-tips li::marker{color:#667eea}.canvas-container:fullscreen,.canvas-container:-webkit-full-screen,.canvas-container:-moz-full-screen,.canvas-container:-ms-fullscreen{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.canvas-container:fullscreen .canvas-header,.canvas-container:-webkit-full-screen .canvas-header,.canvas-container:-moz-full-screen .canvas-header,.canvas-container:-ms-fullscreen .canvas-header{flex-shrink:0}.canvas-container:fullscreen .toolbar,.canvas-container:-webkit-full-screen .toolbar,.canvas-container:-moz-full-screen .toolbar,.canvas-container:-ms-fullscreen .toolbar{flex-shrink:0}.canvas-container:fullscreen .canvas-wrapper,.canvas-container:-webkit-full-screen .canvas-wrapper,.canvas-container:-moz-full-screen .canvas-wrapper,.canvas-container:-ms-fullscreen .canvas-wrapper{flex:1;min-height:0;height:auto;overflow:hidden}.canvas-container:fullscreen ~ .canvas-instructions,.canvas-container:-webkit-full-screen ~ .canvas-instructions,.canvas-container:-moz-full-screen ~ .canvas-instructions,.canvas-container:-ms-fullscreen ~ .canvas-instructions{display:none}@media (max-width:768px){.canvas-header{flex-direction:column;align-items:flex-start;padding:20px 24px}.header-content h1{font-size:26px}.toolbar{gap:12px;padding:12px 16px}.tool-group{padding:6px 8px;gap:8px}.tool-btn{width:38px;height:38px;font-size:18px}.canvas-wrapper{height:500px}.minimap{width:120px;height:120px;bottom:16px;right:16px}.pan-indicator{font-size:12px;padding:10px 20px}.template-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.template-item{padding:20px 16px}.template-icon{font-size:44px}.instructions-grid{grid-template-columns:1fr}.canvas-instructions{padding:28px 24px}.usage-sections{grid-template-columns:1fr;gap:12px}.usage-section{padding:16px}.usage-section h5{font-size:14px}.usage-section li{font-size:11px;padding:6px 10px}.modal-content{width:95%;max-height:90vh}.modal-header{padding:20px 24px}.modal-header h2{font-size:22px}.modal-body{padding:24px}}@media (max-width:480px){.header-content h1{font-size:22px}.canvas-controls .button{padding:10px 16px;font-size:13px}.tool-btn{width:36px;height:36px;font-size:16px}.canvas-wrapper{height:400px}.minimap{width:100px;height:100px;bottom:12px;right:12px}.template-grid,.export-options{grid-template-columns:1fr}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.button:active{animation:pulse 0.3s ease}.canvas-element-selected{outline:2px dashed #667eea;outline-offset:2px}.theme-group{display:flex;align-items:center;gap:6px}#theme-select{padding:5px 10px;border:1.5px solid #e0e6ed;border-radius:6px;background:white;color:#334155;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s ease;outline:none;height:32px;line-height:1.4;min-width:80px}#theme-select:hover{border-color:#667eea;background:#f8f9fc;box-shadow:0 2px 6px rgba(102,126,234,0.12)}#theme-select:focus{border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,0.1)}.batch-tools{background:linear-gradient(135deg,rgba(102,126,234,0.04) 0,rgba(118,75,162,0.04) 100%);border:1.5px solid rgba(102,126,234,0.2);border-radius:8px;padding:5px 10px;animation:batchSlideIn 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:0 1px 3px rgba(102,126,234,0.1)}.batch-tools:hover{border-color:rgba(102,126,234,0.35);box-shadow:0 2px 8px rgba(102,126,234,0.15);transform:translateY(-1px)}@keyframes batchSlideIn{0%{opacity:0;transform:translateX(-30px) scale(0.9)}60%{transform:translateX(5px) scale(1.02)}100%{opacity:1;transform:translateX(0) scale(1)}}@keyframes batchSlideOut{from{opacity:1;transform:translateX(0) scale(1)}to{opacity:0;transform:translateX(-30px) scale(0.9)}}.batch-label{font-size:11px;font-weight:700;color:#667eea;letter-spacing:0.3px;white-space:nowrap;line-height:1;display:flex;align-items:center;margin:0;padding:0}.batch-tools .tool-btn{background:white;transition:all 0.2s ease;width:38px;height:38px;font-size:17px}.batch-tools .tool-btn:hover{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;border-color:#667eea;transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px rgba(102,126,234,0.3)}#batch-delete-btn{border-color:#ef4444;position:relative;overflow:hidden}#batch-delete-btn::before{content:'';position:absolute;inset:0;background:radial-gradient(circle,rgba(239,68,68,0.3) 0,transparent 70%);opacity:0;transition:opacity 0.3s ease}#batch-delete-btn:hover::before{opacity:1}#batch-delete-btn:hover{background:linear-gradient(135deg,#ef4444 0,#dc2626 100%);border-color:#ef4444;color:white;animation:shakeDelete 0.4s ease}@keyframes shakeDelete{0%,100%{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}.selection-info{background:linear-gradient(135deg,rgba(16,185,129,0.06) 0,rgba(5,150,105,0.06) 100%);border:1.5px solid rgba(16,185,129,0.25);border-radius:8px;padding:5px 10px;animation:selectionPulse 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:0 1px 3px rgba(16,185,129,0.1)}.selection-info:hover{border-color:rgba(16,185,129,0.4);box-shadow:0 2px 8px rgba(16,185,129,0.15);transform:translateY(-1px)}@keyframes selectionPulse{0%{opacity:0;transform:scale(0.8)}50%{transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}.selection-count{font-size:11px;font-weight:600;color:#059669;letter-spacing:0.3px;line-height:1;display:flex;align-items:center;margin:0;padding:0}.selection-count strong{font-size:14px;font-weight:800;color:#10b981;background:rgba(16,185,129,0.1);padding:2px 6px;border-radius:4px;margin-left:4px;animation:countChange 0.3s ease}@keyframes countChange{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}#ai-expand-btn{background:linear-gradient(135deg,rgba(168,85,247,0.1) 0,rgba(139,92,246,0.1) 100%);border-color:#a855f7;position:relative;overflow:hidden}#ai-expand-btn::after{content:'✨';position:absolute;top:-2px;right:-2px;font-size:10px;opacity:0.7}#ai-expand-btn:hover{background:linear-gradient(135deg,#a855f7 0,#8b5cf6 100%);border-color:#a855f7;color:white;box-shadow:0 4px 16px rgba(168,85,247,0.4);animation:aiGlow 1.5s ease infinite}@keyframes aiGlow{0%,100%{box-shadow:0 4px 16px rgba(168,85,247,0.4)}50%{box-shadow:0 4px 24px rgba(168,85,247,0.6),0 0 12px rgba(168,85,247,0.3)}}#ai-expand-btn.active{background:linear-gradient(135deg,#a855f7 0,#8b5cf6 100%);border-color:#a855f7;animation:aiPulse 2s ease infinite}@keyframes aiPulse{0%,100%{transform:scale(1.05)}50%{transform:scale(1.08)}}#multi-select-btn.active{background:linear-gradient(135deg,#10b981 0,#059669 100%);border-color:#10b981;color:white;box-shadow:0 4px 16px rgba(16,185,129,0.4);animation:multiSelectActive 0.5s ease}@keyframes multiSelectActive{0%{transform:scale(1)}30%{transform:scale(1.15) rotate(5deg)}60%{transform:scale(1.08) rotate(-5deg)}100%{transform:scale(1.05) rotate(0deg)}}#multi-select-btn:not(.active):hover{border-color:#10b981;background:rgba(16,185,129,0.1)}@media (max-width:1200px){.theme-group{flex-wrap:wrap}#theme-select{min-width:80px}}@media (max-width:768px){.batch-tools,.selection-info{display:none !important}.theme-group{display:none !important}}.keyboard-shortcuts-modal .modal-content{max-width:900px;max-height:85vh}.shortcuts-content .modal-body{padding:20px;max-height:70vh;overflow-y:auto}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.shortcuts-section{background:linear-gradient(135deg,rgba(102,126,234,0.03) 0,rgba(255,255,255,0.95) 100%);padding:16px;border-radius:12px;border:1px solid rgba(102,126,234,0.12);box-shadow:0 2px 8px rgba(0,0,0,0.04);transition:all 0.2s ease}.shortcuts-section:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,0.15);border-color:rgba(102,126,234,0.25)}.shortcuts-section h3{margin:0 0 12px 0;font-size:14px;font-weight:700;color:#667eea;display:flex;align-items:center;gap:6px;padding-bottom:8px;border-bottom:2px solid rgba(102,126,234,0.15)}.shortcut-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px dashed rgba(0,0,0,0.06);transition:all 0.15s ease}.shortcut-item:last-child{border-bottom:none}.shortcut-item:hover{padding-left:4px;background:rgba(102,126,234,0.05);border-radius:4px}.shortcut-item kbd{display:inline-block;padding:4px 8px;font-size:11px;font-weight:600;line-height:1;color:#495057;background:linear-gradient(135deg,#f8f9fa 0,#fff 100%);border:1.5px solid #dee2e6;border-radius:5px;box-shadow:0 2px 4px rgba(0,0,0,0.08),inset 0 -2px 0 rgba(0,0,0,0.1);font-family:'Monaco','Menlo','Courier New',monospace;text-transform:uppercase;transition:all 0.2s ease}.shortcut-item kbd:hover{transform:translateY(-1px);box-shadow:0 3px 6px rgba(0,0,0,0.12),inset 0 -2px 0 rgba(0,0,0,0.1)}.shortcut-item span{font-size:12px;color:#6c757d;font-weight:500;margin-left:8px}.shortcuts-footer{background:linear-gradient(135deg,rgba(102,126,234,0.08) 0,rgba(255,255,255,0.95) 100%);padding:16px;border-radius:12px;text-align:center;border:1px solid rgba(102,126,234,0.15);margin-top:20px}.shortcuts-footer p{margin:0 0 12px 0;font-size:13px;color:#495057}.shortcuts-footer strong{color:#667eea;font-weight:700}.shortcuts-footer .button{padding:8px 24px;font-size:13px}@keyframes shortcutsFadeIn{from{opacity:0;transform:translateY(-30px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}.keyboard-shortcuts-modal.show{animation:shortcutsFadeIn 0.3s cubic-bezier(0.4,0,0.2,1)}@media (max-width:768px){.shortcuts-grid{grid-template-columns:1fr}.keyboard-shortcuts-modal .modal-content{max-width:95%}}.export-modal-content{max-width:720px;max-height:85vh;overflow-y:auto}.export-format-section{margin-bottom:28px}.export-format-section h3{font-size:15px;font-weight:700;color:#333;margin:0 0 16px 0;padding-bottom:10px;border-bottom:2px solid #e9ecef}.export-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}.export-option{padding:16px 12px;background:linear-gradient(135deg,#fff 0,#f8f9fa 100%);border:2px solid #e9ecef;border-radius:10px;cursor:pointer;transition:all 0.25s cubic-bezier(0.4,0,0.2,1);text-align:center;position:relative;overflow:hidden}.export-option::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(102,126,234,0.05) 0,rgba(118,75,162,0.05) 100%);opacity:0;transition:opacity 0.25s ease}.export-option:hover{border-color:#667eea;transform:translateY(-3px);box-shadow:0 6px 20px rgba(102,126,234,0.2)}.export-option:hover::before{opacity:1}.export-option.active{border-color:#667eea;background:linear-gradient(135deg,rgba(102,126,234,0.1) 0,rgba(118,75,162,0.1) 100%);box-shadow:0 4px 16px rgba(102,126,234,0.25)}.export-icon{font-size:32px;display:block;margin-bottom:8px}.export-option h4{font-size:13px;font-weight:700;color:#333;margin:0 0 4px 0}.export-option p{font-size:11px;color:#6c757d;margin:0}.export-settings-section{padding:18px;background:linear-gradient(135deg,rgba(102,126,234,0.04) 0,rgba(118,75,162,0.04) 100%);border-radius:10px;border:1.5px solid rgba(102,126,234,0.12);margin-bottom:20px;animation:slideInDown 0.3s ease}@keyframes slideInDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.export-settings-section h3{font-size:14px;font-weight:700;color:#333;margin:0 0 14px 0;padding-bottom:8px;border-bottom:1.5px solid rgba(102,126,234,0.15);display:flex;align-items:center;gap:8px}.export-settings-section h3::before{content:'⚙️';font-size:16px}.setting-item{margin-bottom:16px}.setting-item:last-child{margin-bottom:0}.setting-item label{display:block;font-size:12px;font-weight:600;color:#495057;margin-bottom:8px}.resolution-options{display:flex;gap:10px}.resolution-btn{flex:1;padding:10px 16px;background:white;border:2px solid #e9ecef;border-radius:8px;font-size:12px;font-weight:600;color:#495057;cursor:pointer;transition:all 0.2s cubic-bezier(0.4,0,0.2,1);position:relative;overflow:hidden}.resolution-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);opacity:0;transition:opacity 0.2s ease}.resolution-btn:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,0.2)}.resolution-btn.active{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-color:#667eea;color:white;box-shadow:0 4px 16px rgba(102,126,234,0.4)}.resolution-btn span{position:relative;z-index:1}.quality-slider{display:flex;align-items:center;gap:12px}.quality-slider input[type="range"]{flex:1;height:6px;background:linear-gradient(to right,#e9ecef 0,#667eea 100%);border-radius:3px;outline:none;-webkit-appearance:none}.quality-slider input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px rgba(102,126,234,0.4);transition:all 0.2s ease}.quality-slider input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 12px rgba(102,126,234,0.6)}.quality-slider input[type="range"]::-moz-range-thumb{width:18px;height:18px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border:none;border-radius:50%;cursor:pointer;box-shadow:0 2px 8px rgba(102,126,234,0.4);transition:all 0.2s ease}.quality-slider input[type="range"]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 12px rgba(102,126,234,0.6)}#quality-value{font-size:13px;font-weight:700;color:#667eea;min-width:45px;text-align:right}.export-info{margin-top:16px;padding:12px;background:rgba(255,255,255,0.6);border-radius:8px;border:1px solid rgba(102,126,234,0.15)}.export-info p{margin:0;font-size:12px;color:#495057}#estimated-size{font-weight:700;color:#667eea}.export-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:2px solid #e9ecef}.export-actions .button{padding:10px 24px;font-size:13px;font-weight:600;border-radius:8px;transition:all 0.2s ease}#confirm-export-btn{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;border:none;box-shadow:0 4px 12px rgba(102,126,234,0.3)}#confirm-export-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,0.4)}#cancel-export-btn{background:white;color:#495057;border:2px solid #e9ecef}#cancel-export-btn:hover{border-color:#667eea;color:#667eea}@media (max-width:640px){.export-options{grid-template-columns:repeat(2,1fr)}.resolution-options{flex-direction:column}}.ai-loading-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;transition:opacity 0.3s ease}.ai-loading-overlay.show{opacity:1}.ai-loading-content{background:white;border-radius:16px;padding:40px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,0.3);min-width:280px;animation:aiLoadingBounce 0.4s cubic-bezier(0.68,-0.55,0.265,1.55)}@keyframes aiLoadingBounce{0%{transform:scale(0.8);opacity:0}100%{transform:scale(1);opacity:1}}.ai-loading-spinner{position:relative;width:80px;height:80px;margin:0 auto 24px}.spinner-ring{position:absolute;width:100%;height:100%;border:4px solid transparent;border-top-color:#667eea;border-radius:50%;animation:spinRotate 1.2s cubic-bezier(0.5,0,0.5,1) infinite}.spinner-ring:nth-child(1){animation-delay:-0.45s;border-top-color:#667eea}.spinner-ring:nth-child(2){animation-delay:-0.3s;border-top-color:#764ba2}.spinner-ring:nth-child(3){animation-delay:-0.15s;border-top-color:#10b981}@keyframes spinRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.ai-loading-text h3{margin:0 0 8px 0;font-size:20px;font-weight:700;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ai-loading-text p{margin:0;font-size:14px;color:#6c757d}.undo-count,.redo-count{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white;font-size:9px;font-weight:700;border-radius:8px;padding:2px 5px;min-width:16px;text-align:center;box-shadow:0 2px 6px rgba(102,126,234,0.4);opacity:0;transform:scale(0.8);transition:all 0.2s cubic-bezier(0.68,-0.55,0.265,1.55);pointer-events:none}.undo-count.active,.redo-count.active{opacity:1;transform:scale(1)}.tool-btn{position:relative}#undo-btn:disabled .undo-count,#redo-btn:disabled .redo-count{background:#ced4da;box-shadow:none}.align-tools{background:linear-gradient(135deg,rgba(102,126,234,0.04) 0,rgba(118,75,162,0.04) 100%);border:1.5px solid rgba(102,126,234,0.2);border-radius:8px;padding:5px 10px;animation:slideInRight 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:0 1px 3px rgba(102,126,234,0.1)}.align-tools:hover{border-color:rgba(102,126,234,0.35);box-shadow:0 2px 8px rgba(102,126,234,0.15);transform:translateY(-1px)}@keyframes slideInRight{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.align-tools .tool-btn{background:white;border:1.5px solid rgba(102,126,234,0.15);width:38px;height:38px;font-size:14px}.align-tools .tool-btn:hover{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-color:#667eea;color:white;transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px rgba(102,126,234,0.4)}.align-tools .tool-btn:active{transform:translateY(0) scale(0.98)}.align-tools .tool-btn span{display:inline-block;transition:transform 0.2s ease}.align-tools .tool-btn:hover span{transform:scale(1.15)}.context-menu{position:fixed;background:white;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,0.15),0 0 0 1px rgba(0,0,0,0.05);padding:6px;min-width:220px;z-index:10000;backdrop-filter:blur(10px);animation:contextMenuFadeIn 0.15s ease-out}@keyframes contextMenuFadeIn{from{opacity:0;transform:scale(0.95) translateY(-5px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:5px;cursor:pointer;transition:all 0.15s ease;font-size:13px;color:#333;user-select:none}.context-menu-item:hover{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:white}.context-menu-item .ctx-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.context-menu-item span:nth-child(2){flex:1;font-weight:500}.context-menu-item .ctx-shortcut{font-size:11px;color:#999;font-weight:400;opacity:0.8}.context-menu-item:hover .ctx-shortcut{color:rgba(255,255,255,0.8)}.context-menu-divider{height:1px;background:#e9ecef;margin:4px 0}.context-menu-item.disabled{opacity:0.4;cursor:not-allowed;pointer-events:none}