.page-tabs{background:var(--bg-primary);border-bottom:1px solid var(--border-light);padding:0 var(--space-5);flex-shrink:0;margin:0}.page-tabs-list{display:flex;align-items:flex-end;gap:var(--space-1);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent;padding:0;margin:0}.page-tabs-list::-webkit-scrollbar{height:4px}.page-tabs-list::-webkit-scrollbar-track{background:transparent}.page-tabs-list::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-sm);transition:background var(--transition-base)}.page-tabs-list::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.page-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-light);border-bottom:none;border-radius:var(--radius-md) var(--radius-md) 0 0;cursor:pointer;transition:all var(--transition-base);position:relative;min-width:80px;max-width:180px;flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;margin:0}.page-tab.editing{min-width:200px;max-width:300px;background:var(--bg-primary);border-color:var(--color-primary-500);box-shadow:0 -2px 8px #3b82f626;animation:editModeEnter .2s ease-out;z-index:20}@keyframes editModeEnter{0%{transform:scale(.98);opacity:.9}to{transform:scale(1);opacity:1}}.page-tab:hover{background:var(--bg-hover);border-color:var(--border-medium)}.page-tab.active{background:var(--bg-primary);border-color:var(--color-primary-600);border-bottom-color:var(--bg-primary);color:var(--color-primary-600);z-index:10;margin-bottom:-1px;box-shadow:0 -2px 8px #3b82f61a;font-weight:var(--font-weight-semibold);font-family:var(--font-family);transform:translateY(-1px)}.page-tab-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:40px;padding-right:var(--space-1);display:block;visibility:visible;opacity:1}.page-tab-actions{display:flex;align-items:center;gap:var(--space-1);opacity:0;transition:opacity var(--transition-base)}.page-tab:hover .page-tab-actions{opacity:1}.page-tab-edit-btn,.page-tab-delete-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-base)}.page-tab-edit-btn:hover{background:var(--bg-hover);color:var(--color-primary-600)}.page-tab-delete-btn:hover{background:var(--color-error-light);color:var(--color-error)}.page-tab-add{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-base);flex-shrink:0;margin-left:var(--space-1)}.page-tab-add:hover{background:var(--bg-hover);border-color:var(--color-primary-500);color:var(--color-primary-600);box-shadow:var(--shadow-xs)}.page-tab-edit{display:flex;align-items:center;gap:var(--space-2);width:100%;min-width:0;padding:0}.page-tab-input{flex:1;min-width:0;padding:var(--space-1) var(--space-2);border:2px solid var(--color-primary-500);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);outline:none;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-base);box-shadow:0 0 0 3px #3b82f61a}.page-tab-input:focus{border-color:var(--color-primary-600);box-shadow:0 0 0 3px #3b82f626,var(--shadow-sm);transform:scale(1.02)}.page-tab-input::placeholder{color:var(--text-disabled);font-weight:var(--font-weight-normal)}.page-tab-save,.page-tab-cancel{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-base);flex-shrink:0}.page-tab-save:hover{color:var(--text-inverse);background:var(--color-success);border-color:var(--color-success);box-shadow:var(--shadow-sm);transform:scale(1.05)}.page-tab-save:active{transform:scale(.95)}.page-tab-cancel:hover{color:var(--text-inverse);background:var(--color-error);border-color:var(--color-error);box-shadow:var(--shadow-sm);transform:scale(1.05)}.page-tab-cancel:active{transform:scale(.95)}@media (max-width: 768px){.page-tabs{padding:0 var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.page-tabs-list{gap:var(--space-1);padding:0}.page-tab{min-width:90px;padding:var(--space-1) var(--space-3);min-height:32px;scroll-snap-align:start}.page-tab.editing{min-width:100px;max-width:90vw}.page-tab-input{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-2)}.page-tab-save,.page-tab-cancel{width:26px;height:26px}.page-tab-name{font-size:var(--font-size-xs)}.page-tab-actions{opacity:1;gap:var(--space-1)}.page-tab:active{transform:scale(.96);background:var(--bg-hover)}.page-tab-edit-btn:active,.page-tab-delete-btn:active,.page-tab-add:active{transform:scale(.9)}.page-tab-edit-btn,.page-tab-delete-btn,.page-tab-add{min-width:44px;min-height:44px;width:44px;height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}}@media (max-width: 480px){.page-tabs{padding:0 var(--space-2)}.page-tab{min-width:100px;scroll-snap-align:start;margin-top:10px;padding-left:10;padding-top:0;padding-bottom:0}.page-tab.editing{min-width:180px;max-width:85vw}.page-tab-input{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-2)}.page-tab-save,.page-tab-cancel{width:26px;height:26px}.page-tab-name{font-size:var(--font-size-xs)}.page-tab-edit-btn,.page-tab-delete-btn,.page-tab-add{min-width:44px;min-height:44px;width:44px;height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}}.component-wrapper{position:relative;margin:4px 0;cursor:pointer;transition:all .2s;width:100%;max-width:100%;touch-action:none;-webkit-user-select:none;user-select:none}.component-wrapper:hover{outline:2px dashed #667eea;outline-offset:4px;border-radius:8px}.component-wrapper.selected{outline:3px solid var(--color-primary-600);outline-offset:4px;background:#3b82f614;border-radius:var(--radius-lg);box-shadow:0 0 0 4px #3b82f61f,0 4px 16px #3b82f633,var(--shadow-md);transform:scale(1.01);transition:all var(--transition-base);position:relative;z-index:10}.component-wrapper.selected:after{content:"";position:absolute;top:-8px;left:-8px;right:-8px;bottom:-8px;border:2px solid var(--color-primary-500);border-radius:var(--radius-xl);opacity:.3;animation:pulse-selection 2s ease-in-out infinite;pointer-events:none;z-index:-1}@media (max-width: 768px){.component-wrapper.selected:after{top:-6px;left:-6px;right:-6px;bottom:-6px;border-width:2px}}@keyframes pulse-selection{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.02)}}.component-wrapper:active{transform:scale(.99)}.component-wrapper.dragging{opacity:.4;transform:rotate(2deg) scale(.98);box-shadow:0 8px 24px #0003;z-index:1000}.component-wrapper.drag-over{border-top:4px solid #2563eb;background-color:#2563eb1a;transition:all .2s ease;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb33}.component-wrapper.drag-over:before{content:"";position:absolute;top:-4px;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,#2563eb,#3b82f6,#2563eb,transparent);animation:slide-across .8s ease-in-out infinite;box-shadow:0 0 8px #2563eb80}.component-wrapper.drag-over:after{content:"Drop here";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#2563ebe6;color:#fff;padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600;z-index:1000;pointer-events:none;box-shadow:0 4px 12px #2563eb66;animation:fadeInOut .3s ease}@keyframes slide-across{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes componentAdded{0%{transform:scale(.95);opacity:.8;box-shadow:0 0 #10b98166}50%{transform:scale(1.02);box-shadow:0 0 0 8px #10b98100}to{transform:scale(1);opacity:1;box-shadow:0 0 #10b98100}}@keyframes fadeInOut{0%,to{opacity:0;transform:translate(-50%) translateY(-4px)}20%,80%{opacity:1;transform:translate(-50%) translateY(0)}}.component-wrapper.newly-added{animation:componentAdded .6s ease-out}.component-content{position:relative;width:100%;overflow-x:auto}.component-controls{position:absolute;top:-40px;right:0;display:flex;gap:4px;z-index:100;background:#fff;padding:4px;border-radius:6px;box-shadow:0 2px 8px #00000026}.control-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;width:44px;height:44px;background:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 4px #00000014}.control-btn:hover{background:#f9fafb;border-color:#667eea;transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #667eea33,0 2px 4px #0000001a}.control-btn:active{transform:translateY(0) scale(.95);box-shadow:0 1px 2px #0000001a}.delete-btn:hover{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff;box-shadow:0 4px 12px #ef44444d,0 2px 4px #ef444433}.delete-btn:active{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(0) scale(.95);box-shadow:0 2px 4px #ef444433}.component-container{min-height:100px;padding:16px;border:2px dashed #ddd;border-radius:8px;background:#fafafa;width:100%;box-sizing:border-box}.empty-container{color:#999;text-align:center;padding:20px;font-size:14px}.component-button{padding:16px 32px;min-height:52px;border-radius:14px;border:none;cursor:pointer;font-size:16px;font-weight:600;letter-spacing:.2px;transition:all .25s cubic-bezier(.4,0,.2,1);width:100%;max-width:100%;box-sizing:border-box;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014,0 1px 3px #0000000d;display:flex;align-items:center;justify-content:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.component-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:0 2px 4px #0000001a!important}.component-button:focus-visible{outline:2px solid #667eea;outline-offset:2px}.component-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.component-button:hover:before{width:300px;height:300px}.component-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 16px #667eea59,0 2px 6px #667eea33}.component-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea73,0 4px 8px #667eea40;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.component-button.primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #667eea59,0 1px 3px #667eea33}.component-button.secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;box-shadow:0 4px 14px #6b72804d}.component-button.secondary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6b728066}.component-button.secondary:active{transform:translateY(0);box-shadow:0 2px 8px #6b72804d}.component-button.success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 16px #10b98159,0 2px 6px #10b98133}.component-button.success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #10b98173,0 4px 8px #10b98140;background:linear-gradient(135deg,#059669,#047857)}.component-button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 16px #ef444459,0 2px 6px #ef444433}.component-button.danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #ef444473,0 4px 8px #ef444440;background:linear-gradient(135deg,#dc2626,#b91c1c)}.component-button.warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 16px #f59e0b59,0 2px 6px #f59e0b33}.component-button.warning:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #f59e0b73,0 4px 8px #f59e0b40;background:linear-gradient(135deg,#d97706,#b45309)}.component-button.info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 16px #3b82f659,0 2px 6px #3b82f633}.component-button.info:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #3b82f673,0 4px 8px #3b82f640;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.component-button.outline{background:transparent;color:#667eea;border:2px solid #667eea;box-shadow:none}.component-button.outline:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.component-button.ghost{background:transparent;color:#667eea;border:none;box-shadow:none}.component-button.ghost:hover:not(:disabled){background:#667eea1a;transform:translateY(-2px)}@keyframes progress-striped{0%{background-position:0 0}to{background-position:20px 0}}.component-card{padding:28px 24px;border-radius:18px;background:#fff;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d,0 0 0 1px #00000008;width:100%;box-sizing:border-box;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:16px}.component-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,0 0 0 1px #0000000a}.card-title{font-size:22px;font-weight:700;color:#111827;margin:0;letter-spacing:-.4px;line-height:1.3;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.card-content{font-size:16px;color:#6b7280;margin:0;line-height:1.65;font-weight:400;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.component-mobile-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;width:100%;box-sizing:border-box;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.05);overflow:hidden}.component-mobile-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000001f,0 2px 6px #00000014}@media (hover: none) and (pointer: coarse){.component-wrapper:hover{outline:none}.component-wrapper.selected{outline:2px solid #2563eb;outline-offset:4px}.component-controls{top:-48px;right:8px}.control-btn{min-width:48px;min-height:48px;width:48px;height:48px;box-shadow:0 2px 8px #00000026}}@media (max-width: 768px){.component-wrapper{margin:8px 0;padding:4px;touch-action:pan-y pinch-zoom}.component-wrapper.selected{outline:3px solid #2563eb;outline-offset:6px;background:#2563eb1a;border-radius:12px;padding:12px;margin:12px 0;box-shadow:0 0 0 4px #2563eb26,0 4px 16px #2563eb33}.component-controls{top:-56px;right:8px;padding:8px;gap:8px;box-shadow:0 4px 16px #00000040;border-radius:12px;background:#fff}.control-btn{min-width:48px;min-height:48px;width:48px;height:48px;border-radius:12px}.control-btn:active{transform:scale(.85)}.component-container{padding:16px;min-height:100px;border-radius:12px}.component-button{min-height:48px;padding:14px 20px;font-size:16px;border-radius:12px;margin:8px 0}.component-input,.component-textarea,.component-select{min-height:48px;padding:12px 16px;font-size:16px;border-radius:12px;margin:8px 0}.component-card{padding:16px;border-radius:16px;margin-bottom:12px}}.editable-text,.editable-heading,.editable-button{cursor:text;position:relative;transition:all .2s ease}.editable-text{font-size:16px;line-height:1.7;color:#374151;font-weight:400;margin:0}.editable-heading{font-weight:700;color:#111827;letter-spacing:-.5px;line-height:1.2;margin:0}.editable-text:hover,.editable-heading:hover,.editable-button:hover{outline:2px dashed #667eea;outline-offset:4px;border-radius:4px}.editable-text:after,.editable-heading:after,.editable-button:after{content:"Double-click to edit";position:absolute;top:-28px;left:0;font-size:11px;color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 10px;border-radius:6px;box-shadow:0 2px 8px #667eea4d;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;white-space:nowrap;font-weight:500;z-index:1000}.editable-text:hover:after,.editable-heading:hover:after,.editable-button:hover:after{opacity:1;transform:translateY(-2px)}.component-mobile-header{display:flex;align-items:center;width:100%;box-sizing:border-box;flex-shrink:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #0000001a}.component-bottom-nav{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-around!important;width:100%!important;min-height:60px!important;height:auto!important;box-sizing:border-box!important;flex-shrink:0!important;overflow:visible!important;visibility:visible!important;opacity:1!important;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative!important;z-index:1!important}.component-bottom-nav:before{content:"";display:none}.component-bottom-nav>*{visibility:visible!important;opacity:1!important}.component-bottom-nav button{display:flex!important;visibility:visible!important;opacity:1!important;min-width:0!important;flex:1 1 0!important;color:inherit!important}.component-bottom-nav button>div{display:flex!important;visibility:visible!important;opacity:1!important}.component-bottom-nav button svg{display:block!important;visibility:visible!important;opacity:1!important;width:auto!important;height:auto!important;color:inherit!important;fill:none!important}.component-bottom-nav button span{display:block!important;visibility:visible!important;opacity:1!important}.component-wrapper:has(.component-bottom-nav){overflow:visible!important;height:auto!important;min-height:60px!important}.bottom-nav-item{display:flex!important;visibility:visible!important;opacity:1!important;min-width:60px!important}.component-bottom-nav.nav-variant-glass{background:#ffffffd9!important;border-top:1px solid rgba(226,232,240,.5)!important}.component-bottom-nav.nav-variant-minimal{background:transparent!important;border-top:none!important;box-shadow:none!important}.bottom-nav-item{touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;outline:none;display:flex!important;visibility:visible!important;opacity:1!important;min-width:60px!important}.bottom-nav-item:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#667eea26;transform:translate(-50%,-50%);transition:width .3s cubic-bezier(.4,0,.2,1),height .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.bottom-nav-item:hover:before{width:56px;height:56px}.bottom-nav-item:active:before{width:48px;height:48px;background:#667eea33}.bottom-nav-item:active{transform:scale(.95)}.bottom-nav-item.active{transform:translateY(-2px)}.bottom-nav-item.active:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:inherit;background:linear-gradient(135deg,#667eea14,#764ba20d);pointer-events:none;z-index:-1}@media (max-width: 480px){.component-wrapper{margin:6px 0;padding:2px}.component-wrapper.selected{padding:10px;margin:10px 0}.component-controls{top:-52px;right:4px;padding:6px;gap:6px}.control-btn{min-width:44px;min-height:44px;width:44px;height:44px}.component-container{padding:10px;min-height:60px}.component-button{min-height:44px;padding:12px 16px;font-size:15px}.component-input,.component-textarea,.component-select{min-height:44px;padding:10px 14px;font-size:16px}.component-card{padding:12px}.card-title{font-size:14px}.component-mobile-header{height:56px;padding:0 12px}.component-bottom-nav{height:64px!important;min-height:64px!important;max-height:64px!important;padding:8px 0!important;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))!important}.bottom-nav-item{min-height:48px;padding:10px 4px!important}.bottom-nav-item svg{width:24px!important;height:24px!important}.editable-text{font-size:15px}.editable-heading h1{font-size:28px}.editable-heading h2{font-size:24px}.editable-heading h3{font-size:20px}}.editable-heading h1{font-size:32px;font-weight:800;line-height:1.2;letter-spacing:-.8px}.editable-heading h2{font-size:28px;font-weight:700;line-height:1.3;letter-spacing:-.6px}.editable-heading h3{font-size:24px;font-weight:700;line-height:1.3;letter-spacing:-.4px}.editable-heading h4{font-size:20px;font-weight:600;line-height:1.4;letter-spacing:-.2px}.editable-heading h5{font-size:18px;font-weight:600;line-height:1.4}.editable-heading h6{font-size:16px;font-weight:600;line-height:1.5}.builder-canvas{flex:1;display:flex;flex-direction:column;background:var(--bg-tertiary);overflow:hidden;min-width:0;position:relative;padding:20px}.builder-canvas.grid-visible .canvas-content{background-image:linear-gradient(to right,var(--border-light) 1px,transparent 1px),linear-gradient(to bottom,var(--border-light) 1px,transparent 1px);background-size:16px 16px;background-position:0 0,0 0}.builder-canvas.grid-visible .canvas-content:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(to right,var(--color-primary-200) 1px,transparent 1px),linear-gradient(to bottom,var(--color-primary-200) 1px,transparent 1px);background-size:80px 80px;background-position:0 0,0 0;opacity:.3;pointer-events:none;z-index:0}.builder-canvas.grid-visible .canvas-content>*{position:relative;z-index:1}.canvas-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-5);background:var(--bg-primary);border-bottom:1px solid var(--border-light);flex-shrink:0;box-shadow:var(--shadow-xs)}.canvas-header h2{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-primary);margin:0;text-transform:uppercase;letter-spacing:.5px}.canvas-info{font-size:12px;color:#6b7280;font-weight:500}.canvas-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;min-height:100%;transition:background-color var(--transition-base),border var(--transition-base);width:100%;position:relative;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent;box-sizing:border-box}.canvas-content::-webkit-scrollbar{width:8px;height:8px}.canvas-content::-webkit-scrollbar-track{background:transparent}.canvas-content::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-base)}.canvas-content::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.canvas-content.drag-over-active{background-color:#eff6ff;border:3px dashed #2563eb;border-radius:8px;animation:pulse-border 1.5s ease-in-out infinite;position:relative}.canvas-content.drag-over-active:before{content:"Drop component here";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#2563ebf2;color:#fff;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;z-index:1000;pointer-events:none;box-shadow:0 8px 24px #2563eb66;animation:fadeInOut .3s ease;white-space:nowrap}.device-screen.drag-over-active{animation:pulse-border 1.5s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:#2563eb;box-shadow:inset 0 0 20px #2563eb1a}50%{border-color:#3b82f6;box-shadow:inset 0 0 30px #2563eb33}}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;padding:48px 24px;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:16px;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px dashed #d1d5db;margin:20px}.canvas-empty.drag-over-active{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:16px;border:3px dashed #667eea;box-shadow:0 8px 24px #667eea33,inset 0 0 40px #667eea0d;transform:scale(1.02)}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;padding:40px 20px;text-align:center}.empty-icon{font-size:72px;margin-bottom:20px;opacity:.6;filter:grayscale(.3);transition:all .3s ease;animation:float 3s ease-in-out infinite}.canvas-empty.drag-over-active .empty-icon{opacity:1;filter:grayscale(0);transform:scale(1.1)}.canvas-empty h3{font-size:20px;font-weight:700;color:#111827;margin-bottom:12px;letter-spacing:-.3px}.canvas-empty p{font-size:15px;color:#6b7280;line-height:1.6;max-width:400px;margin:0 auto}.canvas-components{display:flex;flex-direction:column;gap:0;max-width:1200px;margin:0 auto;width:100%;min-height:100%}.builder-canvas.mobile-preview .canvas-components{gap:0;max-width:100%}.builder-canvas.preview-mode .canvas-content{background:#fff}.builder-canvas.mobile-preview{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);align-items:flex-start;justify-content:center;padding:32px 24px;padding-top:calc(32px + env(safe-area-inset-top,0px));position:relative;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.builder-canvas.mobile-preview:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 50%,rgba(102,126,234,.05) 0%,transparent 70%);pointer-events:none;z-index:0}.builder-canvas.mobile-preview .canvas-content{background:transparent;padding:0;overflow:visible;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:fit-content;margin-top:0;position:relative}.mobile-device-frame{position:relative;margin:0 auto 24px;z-index:1;filter:drop-shadow(0 20px 60px rgba(0,0,0,.4));transition:transform .3s ease;flex-shrink:0;width:100%;display:flex;flex-direction:column;align-items:center;padding:0}.builder-canvas.mobile-preview .mobile-device-frame:hover{transform:scale(1.02)}.device-screen{position:relative;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch;background:#fafbfc;touch-action:pan-y;overscroll-behavior:contain;padding:0;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent;width:100%;max-width:100%;box-sizing:border-box}.device-screen::-webkit-scrollbar{width:6px}.device-screen::-webkit-scrollbar-track{background:transparent}.device-screen::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.device-screen::-webkit-scrollbar-thumb:hover{background:#0000004d}.builder-canvas.mobile-preview .device-screen{scroll-behavior:smooth}.builder-canvas.mobile-preview .device-screen::-webkit-scrollbar{width:4px}.builder-canvas.mobile-preview .device-screen::-webkit-scrollbar-track{background:transparent}.builder-canvas.mobile-preview .device-screen::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}.device-notch{pointer-events:none;z-index:10}@media (max-width: 1024px){.canvas-content{padding:20px 16px}.canvas-header{padding:12px 16px}.canvas-header h2{font-size:13px}.canvas-components{max-width:100%}.builder-canvas.mobile-preview{padding:16px;padding-top:calc(16px + env(safe-area-inset-top,0px));overflow-y:auto;overflow-x:hidden}.builder-canvas.mobile-preview .mobile-device-frame{max-width:100%;width:100%;margin-top:0}}.device-selector-wrapper{position:relative;z-index:100}.device-selector-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs);min-width:120px;justify-content:space-between}.device-selector-button:hover{background:var(--bg-hover);border-color:var(--border-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.device-selector-button:active{transform:translateY(0)}.device-selector-icon{display:flex;align-items:center;color:var(--color-primary-600);flex-shrink:0}.device-selector-label{flex:1;text-align:left;white-space:nowrap}.device-selector-chevron{color:var(--text-tertiary);transition:transform var(--transition-base);flex-shrink:0}.device-selector-chevron.open{transform:rotate(180deg)}.device-selector-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99;background:transparent}.device-selector-dropdown{position:absolute;top:calc(100% + var(--space-1));right:0;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:160px;z-index:101;overflow:hidden;animation:dropdownEnter .2s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}@keyframes dropdownEnter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.device-selector-option{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:transparent;border:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);color:var(--text-primary);cursor:pointer;transition:all var(--transition-base);text-align:left;position:relative}.device-selector-option:hover{background:var(--bg-hover);color:var(--text-primary)}.device-selector-option.active{background:var(--color-primary-50);color:var(--color-primary-700)}.device-selector-option svg{color:var(--color-primary-600);flex-shrink:0}.device-selector-option.active svg{color:var(--color-primary-700)}.device-selector-option span{flex:1}.device-selector-check{width:20px;height:20px;border-radius:var(--radius-sm);background:var(--color-primary-600);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;box-shadow:var(--shadow-xs)}.device-selector-check:after{content:"";width:5px;height:9px;border:solid var(--text-inverse);border-width:0 2px 2px 0;transform:rotate(45deg);position:absolute;top:3px;left:6px}@media (max-width: 768px){.device-selector-button{min-width:100px;padding:var(--space-2) var(--space-2);gap:var(--space-1)}.device-selector-label{font-size:var(--font-size-xs)}.device-selector-dropdown{min-width:140px;right:0}.device-selector-option{padding:var(--space-3);gap:var(--space-2)}.builder-canvas{width:100%;max-width:100%;height:100%;min-height:100%}.canvas-content{padding:16px 12px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-behavior:smooth}.canvas-header{padding:12px 16px;flex-wrap:wrap;gap:8px;position:sticky;top:0;z-index:50;background:#fffffffa;box-shadow:0 2px 4px #0000000d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.builder-canvas.mobile-preview .canvas-header{background:#1a1a1afa;border-bottom:1px solid rgba(255,255,255,.1)}.builder-canvas.mobile-preview .canvas-header h2{color:#fff}.canvas-header h2{font-size:13px}.canvas-info{font-size:11px}.canvas-header select{font-size:13px;padding:6px 10px;min-height:36px}.canvas-properties-btn{font-size:12px!important;padding:6px 10px!important;min-height:36px}.canvas-empty{min-height:300px;padding:24px 16px;margin:16px 8px;border-radius:16px}.empty-icon{font-size:48px;margin-bottom:12px}.canvas-empty h3{font-size:18px}.canvas-empty p{font-size:13px}.builder-canvas.mobile-preview{padding:20px 16px;padding-top:calc(20px + env(safe-area-inset-top,0px));overflow-y:auto;overflow-x:hidden}.builder-canvas.mobile-preview .mobile-device-frame{max-width:calc(100vw - 32px);width:calc(100vw - 32px);margin-top:0}.builder-canvas.mobile-preview .device-screen{border-radius:24px}}@media (max-width: 480px){.canvas-content{padding:12px 8px;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}.builder-canvas.mobile-preview{padding:16px 12px;padding-top:calc(16px + env(safe-area-inset-top,0px));overflow-y:auto;overflow-x:hidden}.builder-canvas.mobile-preview .mobile-device-frame{max-width:calc(100vw - 24px);width:calc(100vw - 24px);margin-top:0}.canvas-header{padding:8px 10px;flex-direction:column;align-items:flex-start;gap:8px}.canvas-header h2{font-size:12px}.canvas-header>div{width:100%;display:flex;justify-content:space-between;align-items:center}.canvas-info{font-size:10px}.canvas-header select{font-size:12px;padding:5px 8px;min-height:32px;flex:1;max-width:120px}.canvas-properties-btn{font-size:11px!important;padding:5px 8px!important;min-height:32px}.canvas-components{gap:12px}.canvas-empty{min-height:250px;padding:20px 12px;margin:12px 4px;border-radius:12px}.empty-icon{font-size:40px;margin-bottom:10px}.canvas-empty h3{font-size:16px}.canvas-empty p{font-size:12px}}.skeleton-loader{background:linear-gradient(90deg,var(--color-gray-200) 0%,var(--color-gray-100) 50%,var(--color-gray-200) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;display:inline-block}.skeleton-text{height:1em;border-radius:var(--radius-sm)}.skeleton-rectangular{border-radius:var(--radius-md)}.skeleton-circular{border-radius:50%}.skeleton-group{display:flex;flex-direction:column;gap:var(--space-2)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.palette-item-skeleton{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);min-height:64px;width:100%}.palette-item-skeleton-icon{width:36px;height:36px;border-radius:var(--radius-md);flex-shrink:0}.palette-item-skeleton-content{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.palette-item-skeleton-title{height:16px;width:60%;border-radius:var(--radius-sm)}.palette-item-skeleton-desc{height:12px;width:80%;border-radius:var(--radius-sm)}.component-palette{width:280px;min-width:280px;background:var(--bg-primary);border-right:1px solid var(--border-light);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.component-palette::-webkit-scrollbar{width:8px}.component-palette::-webkit-scrollbar-track{background:transparent}.component-palette::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-base)}.component-palette::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@media (max-width: 768px){.component-palette.mobile-palette{width:100%;min-width:100%;position:fixed;top:56px;left:0;right:0;bottom:0;z-index:var(--z-sticky);background:var(--bg-primary);transform:translate(-100%);transition:transform var(--transition-slow);box-shadow:var(--shadow-xl);border-right:none;display:flex;flex-direction:column;overflow:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;height:calc(100dvh - 56px);max-height:calc(100dvh - 56px)}.component-palette.mobile-palette:not(.closed){transform:translate(0)}.component-palette.mobile-palette.closed{transform:translate(-100%)}.component-palette.mobile-palette:not(.closed):before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:-1;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.component-palette.mobile-palette .palette-header{padding:16px;padding-top:max(16px,env(safe-area-inset-top));background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0000000d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-shrink:0}.component-palette.mobile-palette .palette-header h2{font-size:16px;font-weight:700;margin:0 0 12px;color:#111827}.palette-close-btn{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .2s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.palette-close-btn:active{background:#f3f4f6;transform:scale(.95)}.palette-toggle-btn{min-height:36px;padding:8px 14px!important;font-size:13px!important;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.palette-toggle-btn:active{transform:scale(.95)}.palette-header-mobile-toggle{width:100%}.palette-toggle-btn-mobile{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);min-height:48px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-xs)}.palette-toggle-btn-mobile:hover{background:var(--bg-hover);border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.palette-toggle-btn-mobile.active{background:var(--gradient-primary);color:var(--text-inverse);border-color:var(--color-primary-600);box-shadow:var(--shadow-primary)}.palette-toggle-btn-mobile:active{transform:scale(.98)}.palette-toggle-btn-mobile svg{flex-shrink:0}.palette-toggle-btn-mobile span{flex:1;text-align:center}.component-palette.mobile-palette .palette-search{padding:14px 16px;font-size:16px;min-height:48px;border-radius:12px;border:2px solid #e5e7eb;margin-bottom:12px;touch-action:manipulation;-webkit-appearance:none;-moz-appearance:none;appearance:none}.component-palette.mobile-palette .palette-search:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;transform:none}.component-palette.mobile-palette .palette-categories{gap:6px;margin-bottom:4px}.component-palette.mobile-palette .palette-categories button{padding:10px 14px;font-size:12px;min-height:40px;border-radius:10px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;flex:1;min-width:0;white-space:nowrap;overflow:visible;text-overflow:clip}.component-palette.mobile-palette .palette-categories button:active{transform:scale(.96);background:#f3f4f6}.component-palette.mobile-palette .palette-categories button.active:active{transform:scale(.96)}.component-palette.mobile-palette .palette-items{flex:1 1 auto;overflow-y:scroll!important;overflow-x:hidden!important;padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior:contain;min-height:0;max-height:none;height:100%;width:100%;display:flex!important;flex-direction:column!important;position:relative;z-index:1;touch-action:pan-y;will-change:scroll-position}.component-palette.mobile-palette .palette-item{min-width:100%;width:100%;flex-direction:row;text-align:left;padding:14px 16px;min-height:64px;margin-bottom:8px;border-radius:12px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 3px #00000014;display:flex!important;visibility:visible!important;opacity:1!important;flex-shrink:0}.component-palette.mobile-palette .palette-item:active{transform:scale(.98);background:#f3f4f6;box-shadow:0 2px 6px #0000001f}.component-palette.mobile-palette .palette-item-icon{width:44px;height:44px;margin:0 12px 0 0;flex-shrink:0}.component-palette.mobile-palette .palette-item-info{flex:1;min-width:0}.component-palette.mobile-palette .palette-item-label{font-size:15px;font-weight:600;margin-bottom:4px;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;overflow:visible;line-height:1.4}.component-palette.mobile-palette .palette-item-desc{font-size:13px;color:#6b7280;white-space:normal;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:4.5em}.component-palette.mobile-palette .palette-template-item{padding:16px!important;margin-bottom:12px!important;border-radius:14px!important;min-height:80px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.component-palette.mobile-palette .palette-template-item:active{transform:scale(.98)!important;background:#f9fafb!important;box-shadow:0 2px 8px #0000001a!important}.component-palette.mobile-palette .palette-template-name{font-size:15px!important;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.4}.component-palette.mobile-palette .palette-template-desc{font-size:13px!important;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.component-palette.mobile-palette .palette-item:hover,.component-palette.mobile-palette .palette-item:hover .palette-item-icon{transform:none}}.palette-header{padding:var(--space-4);background:var(--bg-primary);border-bottom:1px solid var(--border-light);flex-shrink:0;box-shadow:var(--shadow-xs)}.palette-header h2{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0;text-transform:uppercase;letter-spacing:.5px;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;overflow:visible}.palette-subtitle{display:none}.palette-search{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-family:var(--font-family);margin-bottom:var(--space-3);outline:none;transition:all var(--transition-base);background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-xs)}.palette-search:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.palette-search:focus{border-color:var(--color-primary-500);background:var(--bg-primary);box-shadow:0 0 0 3px #3b82f61a,var(--shadow-sm);transform:translateY(-1px)}.palette-search::placeholder{color:var(--text-disabled)}.palette-categories{display:flex;gap:var(--space-1);flex-wrap:wrap}.palette-categories button{padding:var(--space-2) var(--space-3);border:1px solid var(--border-light);background:var(--bg-primary);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;box-shadow:var(--shadow-xs);white-space:nowrap;overflow:visible;word-wrap:normal;text-overflow:clip;position:relative}.palette-categories button:hover{background:var(--bg-tertiary);border-color:var(--border-medium);color:var(--text-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.palette-categories button.active{background:var(--gradient-primary);border-color:var(--color-primary-600);color:var(--text-inverse);box-shadow:var(--shadow-primary);transform:translateY(-1px)}.palette-categories button.active:hover{background:var(--gradient-primary-hover);box-shadow:var(--shadow-primary-hover)}.palette-empty{padding:var(--space-12) var(--space-6);text-align:center;color:var(--text-disabled);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);font-family:var(--font-family);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.palette-empty:before{content:"🔍";font-size:48px;opacity:.5;margin-bottom:8px}.palette-template-item{word-wrap:break-word;overflow-wrap:break-word;display:block!important;visibility:visible!important;opacity:1!important;width:100%;position:relative;z-index:1;padding:var(--space-4);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--space-3);box-shadow:var(--shadow-xs)}.palette-template-item:hover{background:var(--bg-tertiary);border-color:var(--color-primary-500);box-shadow:0 4px 12px #667eea26,var(--shadow-sm);transform:translateY(-2px)}.palette-template-item:active{transform:scale(.98);background:var(--bg-hover);box-shadow:var(--shadow-xs)}.palette-template-header{display:flex;align-items:center;gap:var(--space-3)}.palette-template-icon-wrapper{width:44px;height:44px;border-radius:var(--radius-md);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:var(--text-inverse);flex-shrink:0;box-shadow:var(--shadow-sm)}.palette-template-content{flex:1;min-width:0;overflow:hidden}.palette-template-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-primary);margin-bottom:var(--space-1);word-wrap:break-word;overflow-wrap:break-word;white-space:normal;overflow:visible;line-height:1.4}.palette-template-desc{font-size:var(--font-size-xs);font-family:var(--font-family);color:var(--text-tertiary);word-wrap:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:3em}.palette-template-badge{display:flex;align-items:center;color:var(--color-primary-600);flex-shrink:0}.palette-items{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;width:100%;position:relative;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.palette-items::-webkit-scrollbar{width:8px}.palette-items::-webkit-scrollbar-track{background:transparent}.palette-items::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-base)}.palette-items::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.palette-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:grab;transition:all var(--transition-base);min-width:0;min-height:72px;width:100%;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-sm);position:relative;z-index:1;flex-shrink:0}.palette-item:hover{background:var(--bg-tertiary);border-color:var(--color-primary-500);box-shadow:0 4px 12px #667eea26,var(--shadow-sm);transform:translateY(-2px)}.palette-item:active{cursor:grabbing;transform:scale(.98);background:var(--bg-hover);box-shadow:var(--shadow-xs)}.palette-item.dragging{opacity:.5;transform:scale(.95) rotate(2deg);box-shadow:var(--shadow-2xl);z-index:var(--z-tooltip)}.drag-preview{position:fixed;top:-1000px;left:-1000px;pointer-events:none;opacity:0}@media (hover: none) and (pointer: coarse){.palette-item{min-height:64px;padding:14px}.palette-item:hover{transform:none}.palette-item:active{transform:scale(.95);background:#f3f4f6;opacity:.8}.palette-item:active .palette-item-icon{transform:scale(.9)}}.palette-item-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-primary-100) 100%);border-radius:var(--radius-md);color:var(--color-primary-600);flex-shrink:0;box-shadow:var(--shadow-sm);transition:all var(--transition-base);border:1px solid var(--color-primary-200)}.palette-item:hover .palette-item-icon{background:var(--gradient-primary);color:var(--text-inverse);transform:scale(1.05);box-shadow:var(--shadow-primary);border-color:var(--color-primary-600)}.palette-item-info{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;gap:2px}.palette-item-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-primary);margin-bottom:var(--space-1);line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;white-space:normal;overflow:visible}.palette-item-desc{font-size:11px;color:#6b7280;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:2.8em}@media (max-width: 1024px){.component-palette{width:240px;min-width:240px}.palette-header{padding:16px}.palette-items,.palette-item{padding:10px}}@media (max-width: 768px){.component-palette:not(.mobile-palette){width:100%;min-width:100%;max-height:40vh;border-right:none;border-bottom:1px solid #e5e7eb;-webkit-overflow-scrolling:touch;position:relative;background:#fff;box-shadow:0 2px 8px #0000000d}}@media (max-width: 480px){.component-palette.mobile-palette .palette-header{padding:14px;padding-top:max(14px,env(safe-area-inset-top))}.component-palette.mobile-palette .palette-header h2{font-size:15px}.component-palette.mobile-palette .palette-search{padding:12px 14px;font-size:16px;min-height:44px}.component-palette.mobile-palette .palette-categories{gap:4px}.component-palette.mobile-palette .palette-categories button{padding:8px 12px;font-size:11px;min-height:36px}.component-palette.mobile-palette .palette-items{padding:12px;padding-bottom:max(12px,env(safe-area-inset-bottom));overflow-y:scroll!important;-webkit-overflow-scrolling:touch;max-height:none;height:100%;flex:1 1 auto}.component-palette.mobile-palette .palette-item{padding:12px 14px;min-height:60px}.component-palette.mobile-palette .palette-item-icon{width:40px;height:40px}.component-palette.mobile-palette .palette-item-label{font-size:14px;word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.component-palette.mobile-palette .palette-item-desc{font-size:12px;word-wrap:break-word;overflow-wrap:break-word;-webkit-line-clamp:3;max-height:4.2em}.component-palette.mobile-palette .palette-template-item{padding:14px!important;min-height:72px}.component-palette.mobile-palette .palette-template-name{font-size:14px!important}.component-palette.mobile-palette .palette-template-desc{font-size:12px!important;-webkit-line-clamp:2;max-height:3em}}.property-panel{width:300px;min-width:300px;max-width:300px;background:linear-gradient(to bottom,#fff,#fafbfc);border-left:1px solid var(--border-light);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;box-shadow:-4px 0 24px #0000000a,-1px 0 4px #00000005;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent;position:relative}.property-panel::-webkit-scrollbar{width:8px}.property-panel::-webkit-scrollbar-track{background:transparent}.property-panel::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-base)}.property-panel::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.property-panel-collapsed{width:40px;min-width:40px;max-width:40px;padding:16px 0 0;border-left:1px solid #e5e7eb;display:flex;align-items:flex-start;justify-content:center}.panel-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000a}.panel-toggle-btn:hover{background:var(--bg-hover);color:var(--color-primary-600);border-color:var(--color-primary-300);box-shadow:0 2px 8px #667eea26;transform:translate(-2px)}.panel-close-btn{display:none;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-base)}.panel-close-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.mobile-only{display:none}.desktop-only{display:flex}.property-panel-backdrop{display:none}.panel-header{padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#fff,#f8fafc);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:var(--space-2);box-shadow:0 2px 8px #00000005;position:sticky;top:0;z-index:10;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.panel-header-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.panel-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.refine-button{display:flex;align-items:center;gap:var(--space-2);padding:10px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:var(--text-inverse);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-shadow:0 4px 12px #667eea4d,0 2px 4px #667eea33;position:relative;overflow:hidden}.refine-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.refine-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66,0 4px 8px #667eea4d;background:linear-gradient(135deg,#764ba2,#667eea)}.refine-button:hover:before{left:100%}.refine-button:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.refine-button svg{flex-shrink:0}.panel-header h2{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0;text-transform:none;letter-spacing:-.2px;white-space:nowrap;font-family:var(--font-family);background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.component-type-badge{padding:4px 10px;background:linear-gradient(135deg,#667eea,#764ba2);color:var(--text-inverse);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);font-family:var(--font-family);white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #667eea40,0 1px 3px #667eea26;border:1px solid rgba(255,255,255,.2)}.panel-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;min-height:400px;position:relative}.panel-empty-icon-wrapper{position:relative;margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:center}.panel-empty-icon{color:var(--color-primary-400);opacity:.8;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(102,126,234,.2));z-index:1;position:relative}.panel-empty-icon-glow{position:absolute;width:80px;height:80px;background:linear-gradient(135deg,#667eea26,#764ba226);border-radius:50%;animation:pulse 2s ease-in-out infinite;z-index:0}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-12px) scale(1.05)}}@keyframes pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:.3}}.panel-empty-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);font-family:var(--font-family);color:var(--text-primary);margin:0 0 var(--space-2) 0;letter-spacing:-.3px;background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.panel-empty-description{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);font-family:var(--font-family);color:var(--text-secondary);margin:0 0 var(--space-5) 0;line-height:1.6;max-width:280px;opacity:.8}.panel-empty-hint{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,#667eea14,#764ba214);border-radius:var(--radius-lg);border:1px solid rgba(102,126,234,.15);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary-600);margin-top:var(--space-2)}.panel-empty-hint svg{flex-shrink:0;opacity:.7}.panel-empty-text{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-tertiary);letter-spacing:-.2px}.panel-content{flex:1;padding:var(--space-4) var(--space-5);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent;background:transparent}.panel-content::-webkit-scrollbar{width:8px}.panel-content::-webkit-scrollbar-track{background:transparent}.panel-content::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-base)}.panel-content::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.property-section{margin-bottom:var(--space-5);background:#fff;border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--border-light);box-shadow:0 1px 3px #0000000a,0 1px 2px #00000005;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.property-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .2s ease}.property-section:hover{border-color:var(--border-medium);box-shadow:0 4px 12px #0000000f,0 2px 4px #0000000a;transform:translateY(-1px)}.property-section:hover:before{opacity:1}.property-section:last-child{margin-bottom:0}.property-section h3,.property-section-header{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-4) 0;padding-bottom:var(--space-2);border-bottom:2px solid var(--border-light);text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-family);display:flex;align-items:center;gap:var(--space-2)}.property-section h3 svg,.property-section-header svg{color:var(--color-primary-500);flex-shrink:0;opacity:.9}.property-group{margin-bottom:var(--space-4);position:relative}.property-group:last-child{margin-bottom:0}.property-group label{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-primary);margin-bottom:var(--space-2);letter-spacing:-.1px;text-transform:none}.property-group input,.property-group select,.property-group textarea{width:100%;min-height:80px;padding:10px 14px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--text-primary);background:#fff;transition:all .2s cubic-bezier(.4,0,.2,1);box-sizing:border-box;touch-action:manipulation;-webkit-appearance:none;box-shadow:0 1px 2px #0000000a;position:relative;resize:vertical;line-height:1.5}.property-group input:hover,.property-group select:hover,.property-group textarea:hover{border-color:var(--color-primary-300);box-shadow:0 2px 4px #667eea14;background:#fafbfc}.property-group input:focus,.property-group select:focus,.property-group textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 4px #667eea1f,0 2px 8px #667eea26;transform:translateY(-1px);background:#fff}.property-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;padding-right:36px;cursor:pointer}@media (hover: none) and (pointer: coarse){.property-group input,.property-group select,.property-group textarea{font-size:16px;min-height:48px;padding:12px 16px}.property-group label{font-size:14px;margin-bottom:8px;font-weight:600}.control-btn,.panel-toggle-btn,.panel-close-btn{min-width:48px;min-height:48px}}@media screen and (max-width: 768px){.property-group input,.property-group select,.property-group textarea{font-size:16px}}.property-group input[type=color]{height:48px;padding:4px;cursor:pointer;border-radius:var(--radius-md);border:2px solid var(--border-light);transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.property-group input[type=color]:hover{border-color:var(--color-primary-300);box-shadow:0 2px 8px #667eea33;transform:scale(1.02)}.property-group input[type=color]:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 4px #667eea1f,0 4px 12px #667eea40}.property-group input[type=checkbox]{width:20px;height:20px;min-height:20px;margin:0;cursor:pointer;accent-color:var(--color-primary-600);border-radius:4px;border:2px solid var(--border-medium);transition:all .2s ease}.property-group input[type=checkbox]:checked{background:linear-gradient(135deg,#667eea,#764ba2);border-color:var(--color-primary-600)}.property-group input[type=checkbox]:hover{border-color:var(--color-primary-400);transform:scale(1.1)}@media (max-width: 1024px){.property-panel{width:280px;min-width:280px;max-width:280px}}@media (max-width: 768px){.mobile-only{display:flex}.desktop-only{display:none}.property-panel{width:90%;max-width:420px;min-width:0;position:fixed;top:0;right:0;bottom:0;z-index:301;box-shadow:-8px 0 32px #0003,-2px 0 8px #0000001a;border-left:1px solid #e5e7eb;border-radius:0;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s cubic-bezier(.4,0,.2,1),visibility .35s cubic-bezier(.4,0,.2,1);will-change:transform,opacity,visibility;pointer-events:none;visibility:hidden;opacity:0;background:#fff;display:flex;flex-direction:column;overflow:hidden}.property-panel.mobile-open{transform:translate(0)!important;pointer-events:all!important;visibility:visible!important;opacity:1!important;display:flex!important;z-index:301!important;position:fixed!important}.property-panel:not(.mobile-open){pointer-events:none!important;visibility:hidden!important;opacity:0!important;transform:translate(100%)!important}.property-panel-backdrop{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:300;opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.4,0,.2,1);will-change:opacity;touch-action:none;visibility:hidden}.property-panel-backdrop.active{opacity:1;pointer-events:all;visibility:visible;z-index:300}.panel-header{padding:14px 16px;position:sticky;top:0;background:#fff;z-index:10;border-bottom:1px solid #e5e7eb;flex-shrink:0;box-shadow:0 2px 4px #0000000d}.panel-close-btn.mobile-only{display:flex!important;min-width:44px;min-height:44px;width:44px;height:44px;align-items:center;justify-content:center;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:10px;color:#6b7280;transition:all .2s cubic-bezier(.4,0,.2,1);touch-action:manipulation;-webkit-tap-highlight-color:transparent;flex-shrink:0;cursor:pointer}.panel-close-btn.mobile-only:hover{background:#e5e7eb;border-color:#d1d5db;color:#374151}.panel-close-btn.mobile-only:active{background:#d1d5db;transform:scale(.95)}.panel-content{padding:16px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;flex:1;min-height:0;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#d1d5db transparent;background:#fff}.panel-content::-webkit-scrollbar{width:6px}.panel-content::-webkit-scrollbar-track{background:transparent}.panel-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.panel-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.property-panel.mobile-open .panel-content{display:block!important;visibility:visible!important;opacity:1!important}.property-section{margin-bottom:12px}.property-group input,.property-group select,.property-group textarea{min-height:48px;padding:12px 14px;font-size:16px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:10px;transition:all .2s ease}.property-group input:focus,.property-group select:focus,.property-group textarea:focus{transform:none;box-shadow:0 0 0 3px #667eea1a}.property-group input:active,.property-group select:active{transform:scale(.98)}}@media (max-width: 480px){.property-panel{width:100%;max-width:100%}.panel-header{padding:10px 12px}.panel-header h2{font-size:12px}.panel-content{padding:10px}.property-section,.property-group{margin-bottom:10px}.property-group label{font-size:11px;margin-bottom:6px}.property-group input,.property-group select,.property-group textarea{min-height:48px;padding:14px 16px;font-size:16px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.refine-button{padding:8px 12px;font-size:12px}.refine-button span.desktop-only{display:none}.panel-header h2{font-size:14px}.panel-content{padding:10px 12px}.property-group{margin-bottom:12px}.property-group input,.property-group select,.property-group textarea{padding:6px 10px;font-size:13px}}.language-selector{position:relative;display:inline-block;z-index:10001;overflow:visible;isolation:isolate}.language-selector-button{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151;font-weight:500;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;position:relative;z-index:10002;pointer-events:auto}.language-selector-button:hover{background:#e5e7eb;border-color:#d1d5db}.language-flag{font-size:18px;line-height:1}.language-native{font-weight:500;color:#333}.language-dropdown{position:fixed;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 20px #00000026;min-width:200px;z-index:99999!important;overflow:hidden;animation:slideDown .2s ease;pointer-events:auto!important;isolation:isolate;visibility:visible!important;opacity:1!important;display:block!important;cursor:pointer}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-option{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:transparent;border:none;cursor:pointer;transition:background .15s;text-align:left;touch-action:manipulation;-webkit-tap-highlight-color:transparent;user-select:none;pointer-events:auto!important;position:relative;z-index:1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.language-option:hover{background:#f9fafb}.language-option.active{background:#f0f4ff}.language-option .language-flag{font-size:20px;line-height:1}.language-option .language-native{font-size:14px;font-weight:500;color:#111827;flex:1}.language-option.active .language-native{color:#667eea}.check-icon{color:#667eea;flex-shrink:0;margin-left:12px}@media (max-width: 768px){.language-selector{z-index:10010;position:relative;display:inline-block;overflow:visible}.language-selector-button{padding:8px 12px;font-size:13px;min-height:44px;min-width:44px;z-index:10011;pointer-events:auto!important;-webkit-tap-highlight-color:rgba(0,0,0,.1);position:relative}.language-flag{font-size:16px}.language-native{font-size:13px}.language-dropdown{min-width:180px;max-width:calc(100vw - 32px);z-index:99999!important;position:fixed!important;transform:none!important;box-shadow:0 8px 32px #0003!important;animation:slideDown .2s ease!important;pointer-events:auto!important}.language-option{padding:14px 16px;min-height:48px;pointer-events:auto!important;-webkit-tap-highlight-color:rgba(0,0,0,.1)}}@media (max-width: 480px){.language-selector-button{padding:6px 10px;font-size:12px}.language-dropdown{min-width:160px;max-width:calc(100vw - 24px)}.language-option{padding:12px 14px;min-height:44px}.language-option .language-native{font-size:13px}}.toolbar{display:flex;justify-content:space-between;align-items:center;padding:0 var(--space-5);height:56px;background:var(--bg-primary);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);z-index:var(--z-sticky);gap:var(--space-4);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:relative;overflow:visible}.toolbar-left{display:flex;align-items:center;flex:1;min-width:0;gap:var(--space-3)}.toolbar-logo{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-base)}.toolbar-logo:hover{background:var(--bg-hover)}.logo-icon{font-size:24px;line-height:1;filter:drop-shadow(0 2px 4px rgba(102,126,234,.3))}.toolbar-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0;letter-spacing:-.5px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.toolbar-divider{width:1px;height:24px;background:var(--border-light);flex-shrink:0;opacity:.6}.toolbar-actions-primary,.toolbar-actions-secondary,.toolbar-actions-preview,.toolbar-actions-edit{display:flex;align-items:center;gap:4px}.toolbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0;position:relative;z-index:1;overflow:visible}.toolbar-btn-icon{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;width:44px;height:44px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-base);flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative}.toolbar-btn-icon:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:10px;background:transparent;transition:all .2s ease;z-index:-1}.toolbar-btn-icon:hover:not(.disabled){background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px)}.toolbar-btn-icon.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.toolbar-btn-icon:hover:before{background:#00000005}.toolbar-btn-icon:active{transform:scale(.95) translateY(0);background:var(--bg-active)}.toolbar-btn-icon.active{background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-primary-100) 100%);color:var(--color-primary-600);box-shadow:var(--shadow-sm);border:1px solid var(--color-primary-200)}.toolbar-btn-icon.active:hover{background:linear-gradient(135deg,#dbeafe,#c7d2fe);box-shadow:0 4px 12px #667eea4d}.toolbar-btn-icon.active:active{background:linear-gradient(135deg,#bfdbfe,#a5b4fc);box-shadow:0 1px 4px #667eea33}.toolbar-btn-icon.saving{color:var(--color-primary-600);cursor:wait}.toolbar-btn-icon.saving .spinning{animation:spin 1s linear infinite}.toolbar-btn-icon.saved{color:#10b981;animation:savedPulse .3s ease-out}@keyframes savedPulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.toolbar-btn-icon.error{color:#ef4444}.toolbar-btn-icon.error:hover{background:#ef44441a}.toolbar-btn-primary{background:var(--gradient-primary);color:var(--text-inverse);box-shadow:var(--shadow-primary)}.toolbar-btn-primary:hover{background:var(--gradient-primary-hover);color:var(--text-inverse);transform:translateY(-2px);box-shadow:var(--shadow-primary-hover)}.toolbar-btn-primary:active{transform:translateY(0) scale(.95);box-shadow:0 2px 8px #667eea4d,0 1px 2px #667eea33}.toolbar-btn-ai{background:linear-gradient(135deg,var(--color-success) 0%,#059669 100%);color:var(--text-inverse);box-shadow:var(--shadow-success)}.toolbar-btn-ai:hover{background:linear-gradient(135deg,#059669,#047857);color:var(--text-inverse);transform:translateY(-2px);box-shadow:var(--shadow-success-hover)}.toolbar-btn-ai:active{transform:translateY(0) scale(.95);box-shadow:0 2px 8px #10b9814d,0 1px 2px #10b98133}.user-info-compact{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);flex-shrink:0;transition:all var(--transition-base)}.user-info-compact:hover{background:var(--bg-hover);border-color:var(--border-medium)}.tier-badge-compact{display:flex;align-items:center;flex-shrink:0}.user-email-compact{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--text-secondary);white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}@media (hover: none) and (pointer: coarse){.toolbar-btn-icon{min-width:48px;min-height:48px;width:48px;height:48px}.toolbar-btn-icon:active{transform:scale(.9)}}@media (max-width: 1024px){.toolbar{padding:0 16px;height:56px}.toolbar-title{font-size:16px}.toolbar-divider,.toolbar-actions-secondary,.user-email-compact{display:none}}@media (max-width: 768px){.toolbar{padding:0 12px;height:56px;gap:8px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.toolbar::-webkit-scrollbar{display:none}.toolbar-left{gap:8px;min-width:max-content}.toolbar-title{font-size:15px}.logo-icon{font-size:20px}.toolbar-btn-icon{min-width:44px;min-height:44px;width:44px;height:44px;flex-shrink:0}.toolbar-btn-icon svg{width:20px;height:20px}.toolbar-actions-edit{gap:2px}.toolbar-right{gap:4px;flex-shrink:0;overflow:visible;position:relative;z-index:1}.user-info-compact{padding:6px 10px;display:none}.toolbar-divider{display:none}}@media (max-width: 480px){.toolbar{padding:0 8px;height:56px;gap:4px;overflow-x:auto;overflow-y:hidden}.toolbar-title,.toolbar-actions-preview{display:none}.toolbar-actions-primary{gap:2px}.toolbar-actions-secondary{display:none}.toolbar-actions-edit{gap:2px}.toolbar-btn-icon{min-width:44px;min-height:44px;width:44px;height:44px;flex-shrink:0}.toolbar-btn-icon svg{width:18px;height:18px}.user-info-compact{display:none}.tier-badge-compact svg{width:14px;height:14px}.toolbar-right .toolbar-btn-icon:not(:last-child){display:none}}.toolbar-project-name{display:flex;align-items:center;margin:0 8px}.project-name-display{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:var(--text-primary);max-width:200px}.project-name-display:hover{background:var(--bg-hover);border-color:var(--border-light)}.project-name-display:hover .project-name-edit-icon{opacity:1}.project-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}.project-name-edit-icon{opacity:0;transition:opacity .2s;color:var(--text-secondary);flex-shrink:0}.project-name-editor{display:flex;align-items:center;gap:4px;background:var(--bg-primary);border:2px solid var(--color-primary-500);border-radius:8px;padding:4px 8px;min-width:150px;max-width:250px}.project-name-input{flex:1;border:none;background:transparent;font-size:14px;font-weight:500;color:var(--text-primary);outline:none;padding:2px 4px;min-width:0}.project-name-input::placeholder{color:var(--text-tertiary)}.project-name-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;background:transparent;border-radius:4px;cursor:pointer;transition:all .2s;flex-shrink:0}.project-name-btn:hover{background:var(--bg-hover)}.project-name-save{color:var(--color-success-600)}.project-name-save:hover{background:var(--color-success-50);color:var(--color-success-700)}.project-name-cancel{color:var(--text-secondary)}.project-name-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width: 768px){.toolbar-project-name{margin:0 4px}.project-name-display{padding:4px 8px;font-size:13px;max-width:120px}.project-name-text{max-width:80px}.project-name-editor{min-width:120px;max-width:180px}.project-name-input{font-size:13px}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;width:100%;box-sizing:border-box}.auth-card{background:#fff;border-radius:20px;padding:48px 40px;width:100%;max-width:450px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d;box-sizing:border-box}.auth-logo{display:flex;justify-content:center;margin-bottom:32px}.logo-placeholder{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:18px;box-shadow:0 8px 24px #667eea59,0 0 0 1px #667eea1a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.logo-placeholder:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);opacity:0;transition:opacity .3s}.logo-placeholder:hover{transform:scale(1.08) rotate(5deg);box-shadow:0 12px 32px #667eea73,0 0 0 1px #667eea26}.logo-placeholder:hover:before{opacity:1}.logo-placeholder svg{position:relative;z-index:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}@media (max-width: 768px){.auth-container{padding:40px 16px 16px;align-items:flex-start}.auth-card{padding:32px 24px;max-width:100%}.auth-header h1{font-size:24px}.auth-header p{font-size:13px}.welcome-image{max-width:250px;height:160px;margin-bottom:20px}}@media (max-width: 480px){.auth-container{padding:20px 12px 12px}.auth-card{padding:24px 20px;border-radius:8px}.auth-header h1{font-size:22px}.welcome-image{max-width:200px;height:140px;margin-bottom:16px;border-radius:12px}}.form-group{margin-bottom:16px}.form-group input{padding:10px;font-size:16px}.auth-button{padding:12px;font-size:15px}.social-button{padding:10px;font-size:13px}} .auth-header{text-align:center;margin-bottom:32px}.welcome-image{width:100%;max-width:400px;height:200px;margin:0 auto 24px;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px #667eea33;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.welcome-image img{width:100%;height:100%;object-fit:cover;display:block}.auth-header h1{margin:0 0 8px;color:#111827;font-size:32px;font-weight:800;letter-spacing:-.5px;line-height:1.2}.auth-header p{margin:0;color:#6b7280;font-size:15px;font-weight:400;line-height:1.5}.form-group{margin-bottom:24px}.form-group label{display:flex;align-items:center;gap:8px;margin-bottom:10px;color:#374151;font-weight:600;font-size:14px;letter-spacing:.2px}.form-group label svg{color:#667eea}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .2s cubic-bezier(.4,0,.2,1);box-sizing:border-box;background:#fff;color:#111827}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;transform:translateY(-1px)}.form-group input:hover:not(:focus){border-color:#d1d5db}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{padding-right:52px;width:100%;flex:1}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#667eea1a;border:none;color:#667eea;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:8px;width:40px;height:40px;min-width:40px;min-height:40px;margin:0;flex-shrink:0}.password-toggle:hover:not(:disabled){background:#667eea33;transform:translateY(-50%) scale(1.05)}.password-toggle:active:not(:disabled){transform:translateY(-50%) scale(.95)}.password-toggle:disabled{opacity:.5;cursor:not-allowed}.password-toggle svg{width:20px;height:20px;stroke-width:2;flex-shrink:0}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.password-match{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:12px;font-weight:500}.password-match.match{color:#10b981}.password-match.no-match{color:#ef4444}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-size:14px}.checkbox-label{display:flex;align-items:flex-start;gap:8px;cursor:pointer;font-size:14px;color:#666;line-height:1.5}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer;flex-shrink:0}.checkbox-label a{color:#667eea;text-decoration:none}.checkbox-label a:hover{text-decoration:underline}.forgot-password-link{color:#667eea;text-decoration:none;font-weight:500;font-size:14px}.forgot-password-link:hover{text-decoration:underline}.auth-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 14px #667eea66;position:relative;overflow:hidden}.auth-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.auth-button:hover:not(:disabled):before{width:300px;height:300px}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.auth-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #667eea66}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.error-message{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;border:1px solid #fcc;font-size:14px}.error-message strong{display:block;margin-bottom:4px}.auth-divider{display:flex;align-items:center;margin:24px 0;text-align:center}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #e0e0e0}.auth-divider span{padding:0 16px;color:#999;font-size:14px}.social-auth{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.social-button{width:100%;padding:14px 16px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:12px;color:#374151;box-shadow:0 1px 3px #0000000d}.social-button:hover:not(:disabled){border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.social-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #0000000d}.social-button svg{flex-shrink:0}.social-button:disabled{opacity:.5;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;color:#666;font-size:14px}.auth-footer a{color:#667eea;text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.password-strength{margin-top:8px}.strength-bar-container{width:100%;height:4px;background:#e0e0e0;border-radius:2px;overflow:hidden;margin-bottom:8px}.strength-bar{height:100%;transition:width .3s,background-color .3s;border-radius:2px}.strength-label{font-size:12px;color:#666;margin-bottom:8px}.strength-label strong{font-weight:600}.password-requirements{display:flex;flex-direction:column;gap:6px;font-size:12px}.requirement{display:flex;align-items:center;gap:6px;color:#999;transition:color .3s}.requirement.met{color:#10b981}.requirement svg{flex-shrink:0}@media (max-width: 480px){.password-requirements{gap:4px}.requirement,.strength-label{font-size:11px}}.auth-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:16px}.loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.auth-loading p{color:#666;font-size:16px}@media (max-width: 480px){.auth-loading{padding:20px}.loading-spinner{width:40px;height:40px}.auth-loading p{font-size:14px}}.account-settings-wrapper{min-height:100vh;background:#f8f9ff}.settings-navbar{position:sticky;top:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e0e0e0;z-index:1000;padding:16px 0;box-shadow:0 2px 10px #0000000d}.settings-nav-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.settings-nav-logo{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:700;color:#1a1a1a;text-decoration:none;transition:opacity .3s}.settings-nav-logo:hover{opacity:.8}.settings-nav-links{display:flex;align-items:center;gap:24px}.settings-nav-language{display:flex;align-items:center}.settings-nav-links a{color:#666;text-decoration:none;font-weight:500;font-size:15px;transition:color .3s}.settings-nav-links a:hover{color:#667eea}.settings-nav-btn-primary,.settings-nav-btn-secondary{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;border:none;font-size:14px;text-decoration:none;display:inline-block}.settings-nav-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important}.settings-nav-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.settings-nav-btn-secondary{background:transparent;color:#667eea;border:2px solid #667eea}.settings-nav-btn-secondary:hover{background:#f8f9ff}.settings-mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;color:#1a1a1a}.account-settings{min-height:calc(100vh - 80px);background:#f8f9ff;padding:40px 20px;width:100%;box-sizing:border-box}.settings-container{max-width:800px;margin:0 auto;width:100%}@media (max-width: 1024px){.settings-nav-links{gap:16px}.settings-nav-links a{font-size:14px}}@media (max-width: 768px){.settings-nav-links{position:fixed;top:73px;left:0;right:0;background:#fff;flex-direction:column;padding:24px 20px;gap:16px;box-shadow:0 4px 20px #0000001a;transform:translate(-100%);transition:transform .3s ease;z-index:999;max-height:calc(100vh - 73px);overflow-y:auto}.settings-nav-links.open{transform:translate(0)}.settings-nav-links a{width:100%;padding:12px 0;border-bottom:1px solid #f0f0f0}.settings-nav-links a:last-child{border-bottom:none}.settings-nav-btn-primary,.settings-nav-btn-secondary{width:100%;text-align:center}.settings-mobile-menu-btn{display:block}.settings-nav-language{width:100%;padding:12px 0;border-bottom:1px solid #f0f0f0}.account-settings{padding:24px 16px}.settings-header{margin-bottom:32px}.settings-header h1{font-size:28px}.settings-header p{font-size:15px}.settings-section{padding:24px 20px}.section-header{margin-bottom:20px;padding-bottom:12px}.section-header h2{font-size:18px}.form-group{margin-bottom:18px}.form-group input{padding:12px 14px;font-size:16px}.danger-actions{flex-direction:column;align-items:flex-start;gap:16px}.danger-actions button{width:100%}.subscription-info{gap:12px}}@media (max-width: 480px){.account-settings{padding:20px 12px}.settings-header{margin-bottom:24px}.settings-header h1{font-size:24px}.settings-header p,.back-button{font-size:14px}.settings-section{padding:20px 16px;border-radius:16px}.section-header{padding-bottom:12px;margin-bottom:20px;gap:8px}.section-header h2{font-size:16px}.section-header svg{width:18px;height:18px}.form-group{margin-bottom:16px}.form-group label{font-size:13px;margin-bottom:6px}.form-group input{font-size:16px;padding:12px 14px}.password-input-wrapper input{padding-right:40px}.password-toggle{right:10px;padding:2px}.btn-primary,.btn-secondary,.btn-danger{width:100%;justify-content:center;padding:14px 24px;font-size:15px}.subscription-badge{font-size:13px;padding:6px 14px}.alert{padding:12px 16px;font-size:13px}}.settings-header{margin-bottom:40px;display:flex;flex-direction:column;gap:20px}.back-button{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:#667eea;font-size:15px;font-weight:500;cursor:pointer;padding:8px 0;width:fit-content;transition:all .2s}.back-button:hover{color:#764ba2;transform:translate(-4px)}.settings-header-content{text-align:center}.settings-header h1{font-size:36px;font-weight:800;color:#111827;margin:0 0 12px;letter-spacing:-.8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.settings-header p{color:#6b7280;margin:0;font-size:16px;font-weight:400}.alert{padding:16px;border-radius:8px;margin-bottom:24px;font-size:14px}.alert-error{background:#fee;color:#c33;border:1px solid #fcc}.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.settings-section{background:#fff;border-radius:18px;padding:32px 28px;margin-bottom:24px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d,0 0 0 1px #00000008;border:1px solid rgba(0,0,0,.06);transition:all .3s cubic-bezier(.4,0,.2,1)}.settings-section:hover{box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,0 0 0 1px #0000000a}@media (max-width: 768px){.settings-section:hover{box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d,0 0 0 1px #00000008}}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.section-header h2{font-size:20px;font-weight:700;color:#1a1a1a;margin:0}.section-header svg{color:#667eea}.form-group{margin-bottom:20px}.form-group label{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .25s cubic-bezier(.4,0,.2,1);box-sizing:border-box;background-color:#fff;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1f,0 2px 8px #667eea26;transform:translateY(-1px)}.form-group input:hover:not(:disabled):not(:focus){border-color:#d1d5db}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.input-wrapper{position:relative;width:100%}.field-hint{margin-top:8px;font-size:13px;color:#6b7280;margin-bottom:0;line-height:1.5}.field-error{margin-top:8px;font-size:13px;color:#ef4444;margin-bottom:0;line-height:1.5;font-weight:500}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:45px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#666;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:#667eea}.btn-primary,.btn-secondary,.btn-danger{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;border:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:14px 32px;min-height:52px;border-radius:14px;font-weight:600;font-size:16px;box-shadow:0 4px 16px #667eea59,0 2px 6px #667eea33;transition:all .25s cubic-bezier(.4,0,.2,1)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea73,0 4px 8px #667eea40;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #667eea59,0 1px 3px #667eea33}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:0 2px 4px #0000001a!important}.subscription-info{display:flex;flex-direction:column;gap:16px}.subscription-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#f8f9ff;border-radius:20px;font-weight:600;font-size:14px;width:fit-content}.danger-zone{border:2px solid #fee}.danger-actions{display:flex;justify-content:space-between;align-items:center}.danger-actions h3{font-size:16px;font-weight:700;color:#1a1a1a;margin:0 0 4px}.danger-actions p{font-size:14px;color:#666;margin:0}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.pricing-page-wrapper{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.pricing-navbar{position:sticky;top:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);z-index:1000;padding:16px 0;box-shadow:0 2px 10px #0000001a}.pricing-nav-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.pricing-nav-logo{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:700;color:#1a1a1a;text-decoration:none;transition:opacity .3s}.pricing-nav-logo:hover{opacity:.8}.pricing-nav-links{display:flex;align-items:center;gap:24px}.pricing-nav-language{display:flex;align-items:center}.pricing-nav-links a{color:#666;text-decoration:none;font-weight:500;font-size:15px;transition:color .3s}.pricing-nav-links a:hover{color:#667eea}.pricing-nav-btn-primary,.pricing-nav-btn-secondary{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;border:none;font-size:14px;text-decoration:none;display:inline-block}.pricing-nav-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;box-shadow:0 4px 12px #667eea4d}.pricing-nav-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;background:#bed2fc!important}.pricing-nav-btn-secondary{background:transparent;color:#667eea;border:2px solid #667eea}.pricing-nav-btn-secondary:hover{background:#f8f9ff}.pricing-mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;color:#1a1a1a}.pricing-container{min-height:calc(100vh - 80px);padding:80px 20px;position:relative;overflow:visible}.pricing-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.pricing-header{text-align:center;color:#fff;margin-bottom:80px;position:relative;z-index:1}.header-content{max-width:700px;margin:0 auto}.pricing-header h1{font-size:56px;font-weight:800;margin:0 0 16px;letter-spacing:-.02em;background:linear-gradient(180deg,#fff,#ffffffe6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{font-size:22px;opacity:.95;margin:0 0 24px;font-weight:400;line-height:1.6}.header-note{color:#ffffffe6;font-size:15px;margin-top:16px;font-weight:400}.current-plan-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 24px;border-radius:12px;margin-top:24px;border:1px solid rgba(255,255,255,.2);font-size:15px;font-weight:500}.current-plan-badge svg{flex-shrink:0}.current-plan-badge strong{font-weight:700}.pricing-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px;max-width:1200px;margin:0 auto;position:relative;z-index:1;padding-top:20px}.pricing-card{overflow:visible;background:#fff;border-radius:20px;padding:64px 32px 32px;box-shadow:0 20px 60px #00000026;transition:all .4s cubic-bezier(.4,0,.2,1);border:2px solid transparent;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.pricing-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .3s}.pricing-card:hover:before{opacity:1}.pricing-card:hover{transform:translateY(-8px);box-shadow:0 30px 80px #0003;border-color:#667eea33}.pricing-card.popular{border:2px solid #667eea;transform:scale(1.05);box-shadow:0 25px 70px #667eea4d;overflow:visible!important;z-index:10;position:relative}.pricing-card.popular:before{opacity:1}.pricing-card.current-plan{border-color:#10b981;background:linear-gradient(135deg,#fff,#f0fdf4)}.pricing-card.current-plan:before{background:linear-gradient(90deg,#10b981,#059669);opacity:1}.popular-badge{position:absolute;top:-8px!important;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:10px 28px;border-radius:30px;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;display:flex;align-items:center;gap:6px;box-shadow:0 8px 25px #667eea80;white-space:nowrap;z-index:20;border:4px solid white;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.popular-badge svg{animation:sparkle 2s ease-in-out infinite}.current-plan-indicator{position:absolute;top:20px;right:20px;background:#10b981;color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #10b9814d}.current-plan-indicator svg{flex-shrink:0}.plan-icon-wrapper{display:flex;justify-content:center;align-items:center;width:100%;margin-bottom:24px;position:relative}.plan-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 20px #667eea4d;flex-shrink:0;position:relative;margin:0}.pricing-card.current-plan .plan-icon{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 20px #10b9814d}.pricing-card.popular .plan-icon{animation:pulse 2s ease-in-out infinite;bottom:-50%;left:10%}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.pricing-card h2{margin:0 0 8px;font-size:32px;font-weight:800;color:#1a1a1a;text-align:center;letter-spacing:-.02em;width:100%}.plan-description{text-align:center;color:#6b7280;font-size:15px;margin:0 0 32px;font-weight:400;width:100%}.price{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:40px;padding-bottom:32px;border-bottom:2px solid #f3f4f6;width:100%}.currency{font-size:28px;font-weight:700;color:#667eea;line-height:1}.amount{font-size:64px;font-weight:800;color:#1a1a1a;line-height:1;letter-spacing:-.03em}.period{font-size:18px;color:#6b7280;font-weight:500;margin-left:4px}.features-list{list-style:none;padding:0;margin:0 0 40px;flex:1}.features-list li{display:flex;align-items:flex-start;gap:12px;padding:14px 0;color:#374151;font-size:15px;line-height:1.6;border-bottom:1px solid #f3f4f6}.check-icon{color:#10b981;flex-shrink:0;margin-top:2px;stroke-width:3}.features-list li span{flex:1}.subscribe-button{width:100%;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px #667eea4d;position:relative;overflow:hidden}.subscribe-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.subscribe-button:hover:before{left:100%}.subscribe-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.subscribe-button:active{transform:translateY(0)}.subscribe-button.upgrade{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.subscribe-button.upgrade:hover{box-shadow:0 8px 24px #10b98166}.subscribe-button.current{background:linear-gradient(135deg,#10b981,#059669);cursor:default;box-shadow:0 4px 12px #10b98133}.subscribe-button.current:hover{transform:none;box-shadow:0 4px 12px #10b98133}.subscribe-button.current:before{display:none}.subscribe-button.disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed;box-shadow:none}.subscribe-button.disabled:hover{transform:none;box-shadow:none}.subscribe-button.disabled:before{display:none}.subscribe-button svg{flex-shrink:0;transition:transform .3s}.subscribe-button:hover:not(.disabled):not(.current) svg{transform:translate(4px)}@media (max-width: 1024px){.pricing-plans{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.pricing-card.popular{transform:scale(1.02)}.pricing-nav-links{gap:16px}.pricing-nav-links a{font-size:14px}}@media (max-width: 768px){.pricing-nav-links{position:fixed;top:73px;left:0;right:0;background:#fff;flex-direction:column;padding:24px 20px;gap:16px;box-shadow:0 4px 20px #0000001a;transform:translate(-100%);transition:transform .3s ease;z-index:999;max-height:calc(100vh - 73px);overflow-y:auto}.pricing-nav-links.open{transform:translate(0)}.pricing-nav-links a{width:100%;padding:12px 0;border-bottom:1px solid #f0f0f0}.pricing-nav-links a:last-child{border-bottom:none}.pricing-nav-btn-primary,.pricing-nav-btn-secondary{width:100%;text-align:center}.pricing-mobile-menu-btn{display:block}.pricing-nav-language{width:100%;padding:12px 0;border-bottom:1px solid #f0f0f0}}@media (max-width: 768px){.pricing-container{padding:60px 16px}.pricing-header{margin-bottom:60px}.pricing-header h1{font-size:42px}.header-subtitle{font-size:18px}.pricing-plans{grid-template-columns:1fr;gap:32px;max-width:500px}.pricing-card{padding:56px 28px 28px}.pricing-card.popular{transform:none}.popular-badge{top:-16px!important;padding:10px 24px;font-size:12px}.pricing-card h2{font-size:28px}.amount{font-size:56px}.plan-icon-wrapper{margin-bottom:20px}.plan-icon{width:56px;height:56px}}@media (max-width: 480px){.pricing-container{padding:40px 12px}.pricing-header h1{font-size:36px}.header-subtitle{font-size:16px}.pricing-card{padding:32px 24px}.pricing-card h2{font-size:24px}.amount{font-size:48px}.currency{font-size:24px}.features-list li{padding:12px 0;font-size:14px}.subscribe-button{padding:14px 20px;font-size:15px}.plan-icon-wrapper{margin-bottom:16px}.plan-icon{width:48px;height:48px}}.pricing-container .pricing-header p{opacity:.8}.subscription-success-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.subscription-success-card{background:#fff;border-radius:16px;padding:60px 40px;max-width:600px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.success-icon-wrapper{position:relative;display:inline-block;margin-bottom:30px}.success-icon{color:#10b981;animation:scaleIn .5s ease}.sparkle-icon{position:absolute;top:-10px;right:-10px;color:#fbbf24;animation:sparkle 2s ease infinite}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:1}50%{transform:scale(1.2) rotate(180deg);opacity:.8}}.cancel-icon{color:#ef4444;margin-bottom:30px}.subscription-success-card h1{font-size:36px;margin:0 0 15px;color:#111827}.success-message{font-size:18px;color:#6b7280;margin-bottom:40px}.success-message strong{color:#667eea;font-weight:600}.premium-features-preview{background:#f9fafb;border-radius:12px;padding:30px;margin:30px 0;text-align:left}.premium-features-preview h2{font-size:20px;margin:0 0 20px;color:#111827;text-align:center}.premium-features-preview .features-list{margin:0}.premium-features-preview .features-list li{padding:10px 0;color:#374151;font-size:16px}.success-actions{display:flex;gap:15px;justify-content:center;margin:40px 0 20px;flex-wrap:wrap}.action-button{display:flex;align-items:center;gap:8px;padding:14px 28px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;min-width:180px;justify-content:center}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.action-button.secondary:hover{background:#f9fafb;transform:translateY(-2px)}.help-text{font-size:14px;color:#9ca3af;margin-top:20px}.loading-spinner{border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 20px}@media (max-width: 768px){.subscription-success-card{padding:40px 24px}.subscription-success-card h1{font-size:28px}.success-message{font-size:16px}.premium-features-preview{padding:20px}.success-actions{flex-direction:column}.action-button{width:100%}}.landing-page{min-height:100vh;background:#fff;overflow-x:hidden;position:relative;width:100%;overflow-y:auto}body:has(.landing-page){overflow:auto!important;position:static!important;height:auto!important;width:100%!important}@supports not selector(:has(*)){body{overflow:auto;position:static;height:auto;width:100%}}.navbar{position:sticky;top:0;background:#fffffffa;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(226,232,240,.8);z-index:1000;padding:18px 0;box-shadow:0 1px 3px #0000000a;transition:all .3s ease}.nav-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1000}@media (max-width: 768px){.navbar{padding:12px 0}.nav-container{padding:0 16px}}.nav-logo{display:flex;align-items:center;gap:10px;font-size:26px;font-weight:800;color:#0f172a;letter-spacing:-.02em;transition:transform .2s ease}.nav-logo:hover{transform:scale(1.05)}.nav-logo svg{color:#667eea;filter:drop-shadow(0 2px 4px rgba(102,126,234,.2))}.nav-links{display:flex;align-items:center;gap:24px}.nav-language{display:flex;align-items:center}.nav-links a{color:#475569;text-decoration:none;font-weight:500;font-size:15px;transition:all .2s ease;position:relative;padding:6px 0}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.nav-links a:hover{color:#667eea}.nav-links a:hover:after{width:100%}.nav-btn-primary,.nav-btn-secondary{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;border:none;font-size:14px;min-height:44px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.nav-btn-primary,.nav-btn-secondary{padding:10px 16px;font-size:13px;min-height:40px}}.nav-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea40;position:relative;overflow:hidden}.nav-btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.nav-btn-primary:hover:before{left:100%}.nav-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.nav-btn-secondary{background:transparent;color:#667eea;border:2px solid #667eea;transition:all .2s ease}.nav-btn-secondary:hover{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-color:#5a67d8;transform:translateY(-1px);box-shadow:0 2px 8px #667eea26}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;color:#1a1a1a;z-index:1001;position:relative;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.hero{max-width:1400px;margin:0 auto;padding:140px 20px 120px;display:grid;grid-template-columns:1.1fr .9fr;gap:100px;align-items:center;position:relative;overflow:hidden;background:linear-gradient(180deg,#fff,#fafbfc)}.hero:before{content:"";position:absolute;top:-50%;right:-20%;width:800px;height:800px;background:radial-gradient(circle,rgba(102,126,234,.15) 0%,transparent 70%);border-radius:50%;z-index:0;animation:pulse-glow 4s ease-in-out infinite}.hero:after{content:"";position:absolute;bottom:-30%;left:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(118,75,162,.1) 0%,transparent 70%);border-radius:50%;z-index:0;animation:pulse-glow 5s ease-in-out infinite reverse}@keyframes pulse-glow{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.8}}@media (max-width: 768px){.hero{grid-template-columns:1fr;padding:40px 16px 32px;gap:32px;text-align:center}.hero-title{font-size:36px!important;line-height:1.2;margin-bottom:16px}.hero-description{font-size:16px!important;line-height:1.6;margin-bottom:24px}.hero-actions{flex-direction:column;width:100%;gap:12px;margin-top:0}.hero-actions .btn-primary,.hero-actions .btn-secondary{width:100%;justify-content:center;min-height:48px;padding:14px 24px}.hero-visual{order:-1;margin-bottom:8px}.hero-stats{flex-wrap:wrap;gap:20px;justify-content:center;padding-top:24px;margin-top:24px}.stat-item{min-width:100px;flex:0 1 auto}}.hero-content{display:flex;flex-direction:column;gap:28px;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:24px;font-size:14px;font-weight:600;width:fit-content;animation:fadeInUp .6s ease-out;box-shadow:0 4px 20px #667eea66;position:relative;overflow:hidden}.hero-badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 3s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.hero-title{font-size:76px;font-weight:900;line-height:1.05;color:#0f172a;margin:0 0 8px;animation:fadeInUp .8s ease-out .1s both;letter-spacing:-.05em;text-shadow:0 2px 20px rgba(15,23,42,.05)}.gradient-text{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:23px;color:#64748b;line-height:1.75;margin:0;animation:fadeInUp .8s ease-out .2s both;font-weight:400;max-width:600px;letter-spacing:-.01em}.hero-actions{display:flex;gap:16px;margin-top:8px;animation:fadeInUp .6s ease-out .3s both}.btn-primary,.btn-secondary{display:flex;align-items:center;gap:8px;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;border:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:relative;overflow:hidden;box-shadow:0 4px 20px #667eea59}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-primary:hover:before{left:100%}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 30px #667eea80;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.hero-stats{display:flex;gap:48px;margin-top:24px;padding-top:32px;border-top:1px solid rgba(226,232,240,.8);animation:fadeInUp .6s ease-out .4s both}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-number{font-size:28px;font-weight:900;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.stat-label{font-size:14px;color:#64748b;font-weight:500;margin-top:4px}.hero-visual{display:flex;justify-content:center;align-items:center;animation:fadeInRight 1s ease-out .3s both;position:relative;z-index:1}.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(102,126,234,.2) 0%,transparent 70%);border-radius:50%;filter:blur(60px);z-index:0;animation:pulse-glow 3s ease-in-out infinite;pointer-events:none}.hero-card{background:#fff;border-radius:20px;box-shadow:0 25px 80px #0000001f,0 10px 30px #667eea26;overflow:hidden;width:100%;max-width:480px;transition:all .4s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.8);position:relative}.hero-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:20px;padding:2px;background:linear-gradient(135deg,#667eea4d,#764ba24d);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s}.hero-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 35px 100px #00000026,0 15px 40px #667eea33}.hero-card:hover:before{opacity:1}.card-header{background:#f5f5f5;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.card-dots{display:flex;gap:6px}.card-dots span{width:12px;height:12px;border-radius:50%;background:#ddd}.card-dots span:nth-child(1){background:#ff5f57}.card-dots span:nth-child(2){background:#ffbd2e}.card-dots span:nth-child(3){background:#28ca42}.card-title-bar{font-size:13px;color:#475569;font-weight:600;display:flex;align-items:center;gap:6px}.card-title-bar svg{color:#667eea}.card-content{padding:32px;display:flex;flex-direction:column;gap:20px;background:linear-gradient(180deg,#fff,#fafbfc)}.mock-component{padding:12px;border-radius:6px;font-size:14px}.mock-component.button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px #667eea4d;transition:all .3s}.mock-component.button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.mock-component.button.secondary{background:#fff;color:#667eea;border:2px solid #667eea;display:flex;align-items:center;justify-content:center;gap:8px}.mock-component.button.secondary:hover{background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.mock-component.input{border:2px solid #e2e8f0;background:#fff;color:#94a3b8;transition:all .3s}.mock-component.input:hover{border-color:#cbd5e1;box-shadow:0 0 0 3px #667eea1a}.mock-component.card{background:linear-gradient(135deg,#f8f9ff,#fff);border:2px solid rgba(102,126,234,.15);border-radius:12px;padding:20px;position:relative;overflow:hidden}.mock-component.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2)}.card-icon-wrapper{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:12px;box-shadow:0 4px 12px #667eea4d}.card-title{font-weight:700;margin-bottom:8px;color:#0f172a;font-size:18px;letter-spacing:-.01em}.card-text{font-size:14px;color:#64748b;line-height:1.6}.stats-section{background:linear-gradient(135deg,#667eea,#764ba2);padding:80px 20px;position:relative;overflow:hidden}.stats-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.stats-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px}@media (max-width: 768px){.stats-section{padding:40px 16px}.stats-container{grid-template-columns:repeat(2,1fr);gap:24px}.stat-card{padding:8px}.stat-card-number{font-size:36px;margin-bottom:4px}.stat-card-label{font-size:14px}}@media (max-width: 480px){.stats-section{padding:32px 12px}.stats-container{gap:16px}.stat-card-number{font-size:28px}.stat-card-label{font-size:12px}}.stat-card{text-align:center;color:#fff;position:relative;z-index:1;transition:transform .3s}.stat-card:hover{transform:translateY(-4px)}.stat-card-number{font-size:56px;font-weight:900;margin-bottom:12px;background:linear-gradient(180deg,#fff,#ffffffe6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 20px rgba(255,255,255,.3);letter-spacing:-.02em}.stat-card-label{font-size:17px;opacity:.95;font-weight:500;letter-spacing:.01em}.features{max-width:1400px;margin:0 auto;padding:100px 20px;background:linear-gradient(180deg,#fff,#f8f9ff,#fff);position:relative}@media (max-width: 768px){.features{padding:60px 16px}}@media (max-width: 480px){.features{padding:40px 12px}}.section-header{text-align:center;margin-bottom:80px;position:relative}.section-header h2{font-size:56px;font-weight:900;color:#0f172a;margin:0 0 20px;letter-spacing:-.03em;background:linear-gradient(135deg,#0f172a,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-header p{font-size:22px;color:#64748b;font-weight:400;max-width:700px;margin:0 auto;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.feature-card{background:#fff;padding:40px;border-radius:16px;box-shadow:0 4px 20px #0000000f,0 2px 8px #0000000a;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;border:1px solid rgba(102,126,234,.08);overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform .4s}.feature-card:hover:before{transform:scaleX(1)}@media (max-width: 768px){.features-grid{grid-template-columns:1fr;gap:20px}.feature-card{padding:24px 20px}}@media (max-width: 480px){.features-grid{gap:16px}.feature-card{padding:20px 16px}.feature-icon{width:56px;height:56px}.feature-card h3{font-size:20px;margin-bottom:8px}.feature-card p{font-size:14px}}.feature-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px #0000001f,0 4px 16px #667eea26;border-color:#667eea33}.feature-icon{width:72px;height:72px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:#fff;box-shadow:0 8px 24px #00000026;transition:all .4s}.feature-card:hover .feature-icon{transform:scale(1.1) rotate(5deg);box-shadow:0 12px 32px #0003}.feature-icon.badge-free{background:linear-gradient(135deg,#667eea,#764ba2)}.feature-icon.badge-pro{background:linear-gradient(135deg,#f59e0b,#ef4444)}.feature-icon.badge-enterprise{background:linear-gradient(135deg,#10b981,#059669)}.feature-badge{position:absolute;top:16px;right:16px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.feature-badge.badge-free{background:#e8f0ff;color:#667eea}.feature-badge.badge-pro{background:#fef3c7;color:#f59e0b}.feature-badge.badge-enterprise{background:#d1fae5;color:#10b981}.feature-card h3{font-size:24px;font-weight:700;color:#0f172a;margin:0 0 12px;letter-spacing:-.01em}.feature-card p{font-size:16px;color:#64748b;line-height:1.7;margin:0}.how-it-works{max-width:1400px;margin:0 auto;padding:100px 20px;background:linear-gradient(180deg,#fff,#f8f9ff);position:relative}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:32px}.step-card{text-align:center;padding:40px 32px;border-radius:20px;background:#fff;border:1px solid rgba(226,232,240,.8);box-shadow:0 4px 20px #0000000f,0 2px 8px #0000000a;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.step-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform .4s}.step-card:hover:before{transform:scaleX(1)}@media (max-width: 768px){.how-it-works{padding:60px 16px}.steps-grid{grid-template-columns:1fr;gap:20px}.step-card{padding:24px 20px}}@media (max-width: 480px){.how-it-works{padding:40px 12px}.steps-grid{gap:16px}.step-card{padding:20px 16px}.step-number{width:40px;height:40px;font-size:20px;margin-bottom:12px}.step-card h3{font-size:18px;margin-bottom:8px}.step-card p{font-size:14px}}.step-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px #0000001f,0 4px 16px #667eea26;border-color:#667eea33}.step-number{display:inline-flex;width:56px;height:56px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;align-items:center;justify-content:center;font-size:26px;font-weight:900;margin-bottom:20px;box-shadow:0 8px 24px #667eea4d;transition:all .4s ease}.step-card:hover .step-number{transform:scale(1.1) rotate(5deg);box-shadow:0 12px 32px #667eea66}.step-icon{color:#667eea;margin-bottom:20px;display:flex;justify-content:center;transition:all .4s ease}.step-card:hover .step-icon{transform:scale(1.1);color:#5a67d8}.step-card h3{font-size:22px;font-weight:700;color:#0f172a;margin:0 0 12px;letter-spacing:-.01em}.step-card p{font-size:16px;color:#64748b;line-height:1.7;margin:0}.testimonials{max-width:1400px;margin:0 auto;padding:100px 20px;background:linear-gradient(180deg,#fff,#f8f9ff,#fff);position:relative}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.testimonial-card{background:#fff;padding:36px;border-radius:20px;box-shadow:0 4px 20px #0000000f,0 2px 8px #0000000a;border:1px solid rgba(226,232,240,.8);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.testimonial-card: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 .4s}.testimonial-card:hover:before{transform:scaleX(1)}.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000001f,0 4px 16px #667eea26;border-color:#667eea33}@media (max-width: 768px){.testimonials{padding:60px 16px}.testimonials-grid{grid-template-columns:1fr;gap:20px}.testimonial-card{padding:24px 20px}}@media (max-width: 480px){.testimonials{padding:40px 12px}.testimonials-grid{gap:16px}.testimonial-card{padding:20px 16px}.testimonial-avatar{width:48px;height:48px;font-size:20px}.testimonial-text{font-size:14px}}.testimonial-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.testimonial-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#f8f9ff,#e8f0ff);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 12px #667eea1a;border:2px solid rgba(102,126,234,.1);transition:all .3s ease}.testimonial-card:hover .testimonial-avatar{transform:scale(1.05);box-shadow:0 6px 20px #667eea33}.testimonial-name{font-weight:700;color:#0f172a;margin-bottom:4px;font-size:17px;letter-spacing:-.01em}.testimonial-role{font-size:14px;color:#64748b;font-weight:500}.testimonial-rating{display:flex;gap:4px;margin-bottom:16px}.testimonial-text{font-size:16px;color:#475569;line-height:1.75;margin:0;font-style:italic;font-weight:400}.pricing{max-width:1400px;margin:0 auto;padding:100px 20px;background:linear-gradient(180deg,#fff,#fafbfc);position:relative}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2px;margin-top:60px}.pricing-card{background:#fff;border:2px solid rgba(226,232,240,.8);border-radius:24px;padding:48px 40px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #0000000f,0 2px 8px #0000000a;overflow:hidden}.pricing-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform .4s}.pricing-card:hover:before{transform:scaleX(1)}@media (max-width: 768px){.pricing{padding:60px 16px}.pricing-grid{grid-template-columns:1fr;gap:24px;margin-top:40px}.pricing-card{padding:32px 24px}.pricing-card.popular{transform:none}}@media (max-width: 480px){.pricing{padding:40px 12px}.pricing-grid{gap:20px;margin-top:32px}.pricing-card{padding:24px 20px}.pricing-card h3{font-size:24px;margin-bottom:16px}.price{font-size:36px;margin-bottom:24px}.features-list li{padding:10px 0;font-size:14px}.pricing-button{min-height:48px;font-size:15px}}.pricing-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px #0000001f,0 8px 24px #667eea26;border-color:#667eea4d}.pricing-card.popular{border-color:#667eea;border-width:3px;transform:scale(1.03);box-shadow:0 20px 50px #667eea33,0 8px 24px #667eea26;background:linear-gradient(180deg,#fff,#fafbfc)}.pricing-card.popular:before{transform:scaleX(1);height:5px;background:linear-gradient(90deg,#667eea,#764ba2)}.popular-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);z-index:10;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 24px;border-radius:24px;font-size:13px;font-weight:700;box-shadow:0 4px 20px #667eea66;letter-spacing:.5px;text-transform:uppercase}.pricing-card h3{font-size:32px;font-weight:800;color:#0f172a;margin:0 0 24px;letter-spacing:-.02em}.price{font-size:56px;font-weight:900;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:32px;letter-spacing:-.03em;line-height:1}.price span{font-size:20px;color:#64748b;font-weight:500;margin-left:4px}.features-list{list-style:none;padding:0;margin:0 0 30px}.features-list li{display:flex;align-items:center;gap:14px;padding:14px 0;color:#475569;border-bottom:1px solid rgba(241,245,249,.8);font-size:15px;transition:all .2s ease}.features-list li:hover{color:#0f172a;padding-left:4px}.features-list li:last-child{border-bottom:none}.features-list li svg{color:#667eea;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(102,126,234,.2));transition:transform .2s ease}.features-list li:hover svg{transform:scale(1.1)}.pricing-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea59;position:relative;overflow:hidden}.pricing-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.pricing-button:hover:before{left:100%}.pricing-button:hover{transform:translateY(-2px);box-shadow:0 8px 30px #667eea80;background:linear-gradient(135deg,#5a67d8,#6b46c1)}.faq{max-width:900px;margin:0 auto;padding:100px 20px;background:linear-gradient(180deg,#fff,#f8f9ff);position:relative}.faq-list{display:flex;flex-direction:column;gap:16px}@media (max-width: 768px){.faq{padding:60px 16px}.faq-list{gap:12px}.faq-question{padding:20px;font-size:16px;min-height:56px;display:flex;align-items:center}.faq-answer{padding:0 20px}.faq-item.open .faq-answer{padding:0 20px 20px}.faq-answer p{font-size:14px}}@media (max-width: 480px){.faq{padding:40px 12px}.faq-list{gap:10px}.faq-question{padding:16px;font-size:15px}.faq-answer{padding:0 16px}.faq-item.open .faq-answer{padding:0 16px 16px}}.faq-item{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000000f,0 2px 8px #0000000a;border:1px solid rgba(226,232,240,.8);transition:all .3s ease}.faq-item:hover{box-shadow:0 8px 30px #0000001a,0 4px 16px #667eea1a;border-color:#667eea33}.faq-question{width:100%;padding:28px;display:flex;justify-content:space-between;align-items:center;background:#fff;border:none;cursor:pointer;font-size:18px;font-weight:600;color:#0f172a;text-align:left;transition:all .3s ease;letter-spacing:-.01em}.faq-question:hover{background:linear-gradient(180deg,#fafbfc,#f8f9ff);color:#667eea}.faq-question svg{color:#667eea;transition:transform .3s ease}.faq-item.open .faq-question svg{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease-out,padding .3s ease-out;padding:0 24px}.faq-item.open .faq-answer{max-height:500px;padding:0 24px 24px}.faq-answer p{color:#475569;line-height:1.75;margin:0;font-size:15px}.cta{background:linear-gradient(135deg,#667eea,#764ba2);padding:100px 20px;text-align:center;position:relative;overflow:hidden}.cta:before{content:"";position:absolute;top:-50%;left:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;animation:float-cta 6s ease-in-out infinite}.cta:after{content:"";position:absolute;bottom:-30%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;animation:float-cta 8s ease-in-out infinite reverse}@keyframes float-cta{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}.cta-content{max-width:900px;margin:0 auto;position:relative;z-index:1}.cta-content h2{font-size:56px;font-weight:900;color:#fff;margin:0 0 20px;letter-spacing:-.03em;text-shadow:0 2px 20px rgba(0,0,0,.2)}.cta-content p{font-size:22px;color:#fffffff2;margin:0 0 40px;font-weight:400;line-height:1.6}.cta-actions{display:flex;justify-content:center;gap:16px}@media (max-width: 768px){.cta{padding:60px 16px}.cta-content h2{font-size:32px;margin-bottom:12px}.cta-content p{font-size:16px;margin-bottom:24px}.cta-actions{flex-direction:column;gap:12px}.cta-actions .btn-primary,.cta-actions .btn-secondary{width:100%;min-height:48px}}@media (max-width: 480px){.cta{padding:40px 12px}.cta-content h2{font-size:28px}.cta-content p{font-size:14px;margin-bottom:20px}}.cta-actions .btn-primary{background:#fff;color:#667eea;box-shadow:0 8px 30px #0003}.cta-actions .btn-primary:hover{background:#f8f9ff;transform:translateY(-3px);box-shadow:0 12px 40px #00000040}.cta-actions .btn-secondary{background:transparent;color:#fff;border-color:#fff}.cta-actions .btn-secondary:hover{background:#ffffff1a}.footer{background:#1a1a1a;color:#fff;padding:60px 20px 20px}.footer-container{max-width:1200px;margin:0 auto 40px;display:grid;grid-template-columns:2fr 3fr;gap:60px}@media (max-width: 768px){.footer{padding:40px 16px 16px}.footer-container{grid-template-columns:1fr;gap:32px;margin-bottom:32px}.footer-links{grid-template-columns:repeat(2,1fr);gap:24px}.footer-bottom{flex-direction:column;gap:16px;text-align:center;padding-top:24px}}@media (max-width: 480px){.footer{padding:32px 12px 12px}.footer-container{gap:24px;margin-bottom:24px}.footer-links{grid-template-columns:1fr;gap:20px}.footer-column h4{font-size:14px;margin-bottom:12px}.footer-column a{font-size:13px;margin-bottom:10px}}.footer-brand{display:flex;flex-direction:column;gap:16px}.footer-logo{display:flex;align-items:center;gap:10px;font-size:26px;font-weight:800;margin-bottom:12px;letter-spacing:-.02em}.footer-logo svg{color:#667eea;filter:drop-shadow(0 2px 4px rgba(102,126,234,.3))}.footer-brand p{color:#94a3b8;line-height:1.7;margin:0;font-size:15px;max-width:400px}.footer-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:32px}.footer-column h4{font-size:16px;font-weight:700;margin:0 0 20px;color:#fff;letter-spacing:.01em}.footer-column a,.footer-column a:visited{display:block;color:#94a3b8;text-decoration:none;margin-bottom:14px;transition:all .2s ease;font-size:15px}.footer-column a:hover{color:#fff;transform:translate(4px)}.footer-bottom{max-width:1400px;margin:0 auto;padding-top:48px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;color:#94a3b8;font-size:14px}.footer-language{display:flex;align-items:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (max-width: 1200px){.hero{gap:40px}.features-grid,.pricing-grid,.testimonials-grid,.steps-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width: 1024px){.nav-container{padding:0 16px}.hero{padding:80px 16px 60px;gap:40px}.features,.how-it-works,.testimonials,.pricing,.faq{padding:60px 16px}.stats-section{padding:40px 16px}}@media (max-width: 768px){.nav-links{position:fixed;top:73px;left:0;right:0;background:#fff;flex-direction:column;padding:20px 16px;gap:12px;border-bottom:1px solid #e0e0e0;transform:translateY(-100%);opacity:0;transition:all .3s;box-shadow:0 4px 12px #0000001a;max-height:calc(100vh - 73px);overflow-y:auto;z-index:999;pointer-events:none}.nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}.nav-links a{padding:12px 0;min-height:44px;display:flex;align-items:center}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:8px;z-index:1001;position:relative;background:transparent;border:none;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.mobile-menu-btn:active{opacity:.7}.mobile-menu-btn svg{pointer-events:none}.section-header{margin-bottom:40px}.section-header h2{font-size:32px;line-height:1.2}.section-header p{font-size:16px;line-height:1.5}}@media (max-width: 480px){.navbar{padding:12px 0}.nav-container{padding:0 12px}.nav-logo{font-size:20px}.hero{padding:32px 12px 24px}.hero-title{font-size:28px;line-height:1.2;margin-bottom:12px}.hero-description{font-size:15px;line-height:1.5;margin-bottom:20px}.hero-badge{font-size:12px;padding:6px 12px;margin-bottom:16px}.hero-stats{gap:16px;padding-top:20px;margin-top:20px}.stat-number{font-size:20px}.stat-label{font-size:12px}.section-header{margin-bottom:32px}.section-header h2{font-size:28px;line-height:1.2;margin-bottom:12px}.section-header p{font-size:14px;line-height:1.5}}.legal-page{min-height:100vh;background:#f8f9fa;padding:40px 20px}.legal-container{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.legal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px 40px;display:flex;justify-content:space-between;align-items:center}.back-link{display:flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-size:14px;transition:opacity .3s}.back-link:hover{opacity:.8}.legal-logo{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:700}.legal-content{padding:40px;line-height:1.8;color:#333}.legal-content h1{font-size:36px;font-weight:700;margin:0 0 10px;color:#1a1a1a}.last-updated{color:#666;font-size:14px;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.legal-content section{margin-bottom:40px}.legal-content h2{font-size:24px;font-weight:600;margin:0 0 16px;color:#1a1a1a}.legal-content h3{font-size:18px;font-weight:600;margin:24px 0 12px;color:#333}.legal-content p{margin:0 0 16px;color:#555}.legal-content ul{margin:16px 0;padding-left:24px}.legal-content li{margin:8px 0;color:#555}.legal-footer{padding:30px 40px;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;justify-content:center;align-items:center;gap:16px}.legal-link{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s}.legal-link:hover{color:#764ba2}.separator{color:#ccc}@media (max-width: 768px){.legal-page{padding:20px 16px}.legal-header{padding:20px;flex-direction:column;gap:16px;align-items:flex-start}.legal-content{padding:24px 20px}.legal-content h1{font-size:28px}.legal-content h2{font-size:20px}.legal-footer{padding:20px;flex-direction:column;gap:12px}.separator{display:none}}.template-gallery-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px;overflow-y:auto}.template-gallery{background:#fff;border-radius:12px;width:100%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.template-gallery-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.gallery-header-left{display:flex;align-items:center;gap:16px}.gallery-header-left svg{color:#667eea}.gallery-header-left h2{font-size:24px;font-weight:700;color:#1a1a1a;margin:0 0 4px}.gallery-header-left p{font-size:14px;color:#666;margin:0}.close-button{background:none;border:none;color:#666;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#f5f5f5;color:#333}.template-gallery-filters{display:flex;gap:16px;padding:20px 32px;border-bottom:1px solid #e0e0e0;flex-shrink:0;flex-wrap:wrap}.search-box{flex:1;min-width:200px;display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9ff;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .3s}.search-box:focus-within{border-color:#667eea}.search-box svg{color:#999;flex-shrink:0}.search-box input{flex:1;border:none;background:none;outline:none;font-size:14px;color:#333}.search-box input::placeholder{color:#999}.filter-group{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8f9ff;border:2px solid #e0e0e0;border-radius:8px}.filter-group svg{color:#999;flex-shrink:0}.filter-group select{border:none;background:none;outline:none;font-size:14px;color:#333;cursor:pointer}.template-gallery-content{flex:1;overflow-y:auto;padding:32px}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.template-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;position:relative}.template-card:hover:not(.locked){border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 24px #667eea33}.template-card.locked{cursor:not-allowed;opacity:.7}.template-lock-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffff2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:10;border-radius:12px}.template-lock-overlay svg{color:#667eea}.template-lock-overlay p{font-weight:600;color:#667eea;margin:0}.template-thumbnail{width:100%;height:180px;background:linear-gradient(135deg,#f8f9ff,#e8ebff);display:flex;align-items:center;justify-content:center;border-bottom:1px solid #e0e0e0}.thumbnail-emoji{font-size:64px}.template-info{padding:20px}.template-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.template-header h3{font-size:18px;font-weight:600;color:#1a1a1a;margin:0;flex:1}.tier-badge{font-size:11px;font-weight:600;text-transform:uppercase;padding:4px 8px;border-radius:4px;background:#f8f9ff;white-space:nowrap}.template-description{font-size:14px;color:#666;line-height:1.5;margin:0 0 12px}.template-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-size:11px;padding:4px 8px;background:#f5f5f5;color:#666;border-radius:4px}.template-gallery-footer{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;border-top:1px solid #e0e0e0;flex-shrink:0}.btn-secondary{padding:10px 20px;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f8f9ff}.tier-info{display:flex;align-items:center;gap:6px;font-size:13px;color:#666;margin:0}.tier-info svg{color:#667eea}.no-templates{text-align:center;padding:60px 20px;color:#666}.no-templates p{font-size:16px;margin-bottom:12px}.upgrade-hint{display:flex;align-items:center;justify-content:center;gap:6px;color:#667eea;font-weight:500}@media (max-width: 1024px){.templates-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}}@media (max-width: 768px){.template-gallery-overlay{padding:12px}.template-gallery{max-height:95vh}.template-gallery-header{padding:20px 24px}.gallery-header-left h2{font-size:20px}.template-gallery-filters{padding:16px 24px;flex-direction:column}.search-box,.filter-group{width:100%}.template-gallery-content{padding:24px 20px}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.template-gallery-footer{padding:16px 24px;flex-direction:column;gap:12px;align-items:stretch}.btn-secondary{width:100%}}@media (max-width: 480px){.templates-grid{grid-template-columns:1fr}.template-thumbnail{height:150px}.thumbnail-emoji{font-size:48px}}.ai-generator-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px}.ai-generator-modal{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.ai-generator-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.ai-header-left{display:flex;align-items:center;gap:16px;flex:1}.ai-icon{color:#fff;flex-shrink:0}.ai-header-left h2{font-size:24px;font-weight:700;margin:0 0 4px}.ai-header-left p{font-size:14px;opacity:.9;margin:0}.close-button{background:#fff3;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.ai-generator-content{flex:1;overflow-y:auto;padding:32px}.prompt-section{margin-bottom:32px}.prompt-section label{display:block;font-size:16px;font-weight:600;color:#333;margin-bottom:12px}.prompt-input-wrapper{position:relative}.prompt-textarea{width:100%;padding:16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;font-family:inherit;resize:vertical;transition:border-color .3s;box-sizing:border-box;margin-bottom:12px}.prompt-textarea:disabled{background:#f5f5f5;cursor:not-allowed}.generate-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .3s;display:flex;align-items:center;justify-content:center;gap:8px}.generate-button:hover:not(:disabled){opacity:.9}.generate-button:disabled{opacity:.6;cursor:not-allowed}.generate-button .spinner{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{margin-top:12px;padding:12px;background:#fee;color:#c33;border-radius:6px;font-size:14px}.examples-section{margin-bottom:32px}.examples-section h3{font-size:16px;font-weight:600;color:#333;margin-bottom:16px}.examples-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.example-button{padding:12px 16px;background:#f8f9ff;border:2px solid #e0e0e0;border-radius:8px;font-size:13px;color:#666;cursor:pointer;transition:all .2s;text-align:left}.example-button:hover:not(:disabled){border-color:#667eea;background:#f0f2ff;color:#333}.example-button:disabled{opacity:.5;cursor:not-allowed}.ai-tips{background:#f8f9ff;padding:20px;border-radius:8px;border-left:4px solid #667eea}.ai-tips h4{font-size:14px;font-weight:600;color:#333;margin:0 0 12px}.ai-tips ul{margin:0;padding-left:20px;color:#666;font-size:13px;line-height:1.6}.ai-tips li{margin-bottom:6px}@media (max-width: 768px){.ai-generator-overlay{padding:12px}.ai-generator-modal{max-height:95vh}.ai-generator-header{padding:20px 24px}.ai-header-left h2{font-size:20px}.ai-generator-content{padding:24px 20px}.examples-grid{grid-template-columns:1fr}}.ai-chat-button{position:fixed;bottom:24px;left:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;box-shadow:0 4px 12px #667eea66;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;transition:transform .2s,box-shadow .2s}.ai-chat-button:hover{transform:scale(1.1);box-shadow:0 6px 20px #667eea99}.ai-chat-window{position:fixed;bottom:24px;left:24px;width:400px;height:600px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;z-index:1001;overflow:hidden;transition:height .3s}.ai-chat-window.minimized{height:60px}.ai-chat-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:8px;font-weight:600}.chat-header-actions{display:flex;gap:8px}.header-button{background:#fff3;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.header-button:hover{background:#ffffff4d}.ai-chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:#f8f9ff}.message{display:flex;gap:12px;align-items:flex-start}.message.user{flex-direction:row-reverse}.message-avatar{width:32px;height:32px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 4px #0000001a}.message.user .message-avatar{background:#667eea;color:#fff}.message.assistant .message-avatar{background:#f0f0f0;color:#667eea}.message-content{max-width:75%;background:#fff;padding:12px 16px;border-radius:12px;box-shadow:0 2px 4px #0000000d}.message.user .message-content{background:#667eea;color:#fff}.message-content p{margin:0 0 4px;font-size:14px;line-height:1.5}.message-time{font-size:11px;opacity:.6}.typing-indicator{display:flex;gap:4px;padding:8px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#999;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.quick-actions{padding:16px 20px;border-top:1px solid #e0e0e0;background:#fff}.quick-actions p{font-size:12px;color:#666;margin:0 0 12px;font-weight:600}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.quick-action-button{padding:8px 12px;background:#f8f9ff;border:1px solid #e0e0e0;border-radius:6px;font-size:12px;color:#666;cursor:pointer;transition:all .2s;text-align:left}.quick-action-button:hover{border-color:#667eea;background:#f0f2ff;color:#333}.ai-chat-input{display:flex;gap:8px;padding:16px 20px;border-top:1px solid #e0e0e0;background:#fff;flex-shrink:0}.chat-textarea{flex:1;padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:none;max-height:100px;transition:border-color .3s}.chat-textarea:focus{outline:none;border-color:#667eea}.send-button{padding:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .3s;flex-shrink:0}.send-button:hover:not(:disabled){opacity:.9}.send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.ai-chat-button{bottom:16px;left:16px;width:48px;height:48px}.ai-chat-window{bottom:16px;left:16px;right:16px;width:auto;height:calc(100vh - 100px);max-height:600px}.quick-actions-grid{grid-template-columns:1fr}}.ai-refiner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}.ai-refiner-modal{background:#fff;border-radius:20px;width:100%;max-width:700px;max-height:90vh;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ai-refiner-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.ai-header-left{display:flex;align-items:center;gap:16px}.ai-icon{flex-shrink:0}.ai-header-left h2{margin:0;font-size:24px;font-weight:700}.ai-header-left p{margin:4px 0 0;font-size:14px;opacity:.9}.close-button{background:#fff3;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .2s}.close-button:hover{background:#ffffff4d}.ai-refiner-content{padding:28px;overflow-y:auto;flex:1}.component-preview-section{background:#f9fafb;border-radius:12px;padding:20px;margin-bottom:24px;border:1px solid #e5e7eb}.component-preview-section h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#111827}.component-count{font-size:14px;color:#6b7280;margin-bottom:12px}.component-types{display:flex;flex-wrap:wrap;gap:8px}.component-type-badge{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;color:#667eea}.refinement-section{margin-bottom:24px}.refinement-section label{display:block;font-size:14px;font-weight:600;color:#111827;margin-bottom:8px}.prompt-input-wrapper{display:flex;gap:12px;align-items:flex-start}.prompt-textarea{flex:1;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}.prompt-textarea:focus{outline:none;border-color:#667eea}.prompt-textarea:disabled{background:#f3f4f6;cursor:not-allowed}.refine-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:transform .2s,box-shadow .2s;white-space:nowrap}.refine-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.refine-button:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:8px;margin-top:12px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.suggestions-section{margin-bottom:24px}.suggestions-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#6b7280}.suggestions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.suggestion-button{padding:10px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;color:#374151;cursor:pointer;text-align:left;transition:all .2s}.suggestion-button:hover:not(:disabled){border-color:#667eea;background:#f8f9ff;color:#667eea}.suggestion-button:disabled{opacity:.5;cursor:not-allowed}.changes-section{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:20px;margin-bottom:24px}.changes-section h4{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:16px;font-weight:600;color:#059669}.changes-list{margin:0;padding-left:20px;color:#047857;font-size:14px}.changes-list li{margin:6px 0;line-height:1.5}.preview-toggle-section{margin-bottom:24px}.preview-toggle-button{width:100%;padding:12px 20px;background:#f8f9ff;border:2px solid #667eea;border-radius:10px;color:#667eea;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.preview-toggle-button:hover{background:#667eea;color:#fff}.preview-section{display:flex;align-items:flex-start;gap:20px;margin-bottom:24px;padding:20px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.preview-column{flex:1}.preview-column h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#111827}.preview-content{background:#fff;padding:16px;border-radius:8px;border:1px solid #e5e7eb}.component-summary{margin-bottom:12px;font-size:14px;color:#6b7280}.component-summary strong{color:#111827;font-size:18px}.preview-arrow{font-size:24px;color:#667eea;font-weight:700;padding-top:20px}.quality-score-section{background:#f0f9ff;border:1px solid #bae6fd;border-radius:12px;padding:20px;margin-bottom:24px}.quality-score-section h4{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:16px;font-weight:600;color:#0369a1}.quality-strengths,.quality-issues{margin-top:12px}.quality-strengths strong{color:#059669}.quality-issues strong{color:#dc2626}.quality-strengths ul,.quality-issues ul{margin:8px 0 0 20px;padding:0;color:#374151;font-size:14px}.quality-strengths li{color:#059669}.quality-issues li{color:#dc2626}.refiner-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:20px;border-top:1px solid #e5e7eb}.action-button{padding:12px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;border:none}.action-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.action-button.secondary{background:#fff;color:#667eea;border:2px solid #667eea}.action-button.secondary:hover:not(:disabled){background:#f8f9ff}.action-button.cancel{background:#f3f4f6;color:#6b7280}.action-button.cancel:hover:not(:disabled){background:#e5e7eb}.action-button:disabled{opacity:.5;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}@media (max-width: 768px){.ai-refiner-modal{max-width:100%;max-height:100vh;border-radius:0}.ai-refiner-header,.ai-refiner-content{padding:20px}.prompt-input-wrapper{flex-direction:column}.refine-button{width:100%;justify-content:center}.suggestions-grid{grid-template-columns:1fr}.preview-section{flex-direction:column;gap:16px}.preview-arrow{transform:rotate(90deg);padding:0;text-align:center}.quality-score-section{padding:16px}.refiner-actions{flex-direction:column}.action-button{width:100%;justify-content:center}}.questionnaire-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .3s ease}.questionnaire-modal{background:#fff;border-radius:24px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;overflow:hidden}.questionnaire-header{padding:24px 24px 16px;border-bottom:1px solid #e5e7eb;position:relative}.questionnaire-progress{height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin-bottom:16px}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:2px}.questionnaire-steps{display:flex;gap:8px;justify-content:center;margin-bottom:12px}.step-indicator{width:8px;height:8px;border-radius:50%;background:#e5e7eb;transition:all .3s ease}.step-indicator.active{background:#667eea;width:24px;border-radius:4px}.step-indicator.completed{background:#10b981}.questionnaire-skip{position:absolute;top:24px;right:24px;background:transparent;border:none;color:#6b7280;font-size:14px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.questionnaire-skip:hover{background:#f3f4f6;color:#374151}.questionnaire-content{flex:1;padding:32px 24px;overflow-y:auto;-webkit-overflow-scrolling:touch}.questionnaire-title{font-size:28px;font-weight:700;color:#111827;margin:0 0 8px;text-align:center}.questionnaire-subtitle{font-size:16px;color:#6b7280;margin:0 0 32px;text-align:center}.questionnaire-options{display:grid;gap:12px}.questionnaire-option{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;position:relative}.questionnaire-option:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.questionnaire-option.selected{border-color:#667eea;background:linear-gradient(135deg,#f8f9ff,#fff5f5);box-shadow:0 4px 16px #667eea33}.option-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#f3f4f6;border-radius:12px;color:#667eea;flex-shrink:0;transition:all .2s}.questionnaire-option.selected .option-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.option-content{flex:1;min-width:0}.option-label{font-size:16px;font-weight:600;color:#111827;margin-bottom:4px}.option-description{font-size:13px;color:#6b7280;line-height:1.4}.option-check{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#667eea;border-radius:50%;flex-shrink:0}.check-mark{color:#fff;font-size:14px;font-weight:700}.questionnaire-footer{display:flex;align-items:center;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.questionnaire-btn-primary,.questionnaire-btn-secondary{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.questionnaire-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.questionnaire-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.questionnaire-btn-primary:disabled{opacity:.5;cursor:not-allowed}.questionnaire-btn-secondary{background:#fff;color:#374151;border:1px solid #e5e7eb}.questionnaire-btn-secondary:hover{background:#f3f4f6}@media (max-width: 768px){.questionnaire-modal{max-width:100%;max-height:100vh;border-radius:0;height:100vh}.questionnaire-content{padding:24px 16px}.questionnaire-title{font-size:24px}.questionnaire-subtitle{font-size:14px}.questionnaire-option{padding:14px 16px}.option-icon{width:40px;height:40px}.option-label{font-size:15px}.option-description{font-size:12px}}.generation-loader-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .3s ease}.generation-loader-modal{background:#fff;border-radius:24px;width:90%;max-width:500px;padding:40px 32px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.loader-header{text-align:center;margin-bottom:32px}.loader-icon-wrapper{position:relative;display:inline-block;margin-bottom:16px}.loader-main-icon{color:#667eea;animation:float 2s ease-in-out infinite;position:relative;z-index:2}.loader-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;background:#667eea33;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.7}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.3}}.loader-title{font-size:28px;font-weight:700;color:#111827;margin:0 0 8px}.loader-subtitle{font-size:16px;color:#6b7280;margin:0}.loader-progress-section{margin-bottom:32px}.loader-progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:12px}.loader-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.loader-status{text-align:center;font-size:14px;color:#667eea;font-weight:500}.loader-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.loader-step{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border-radius:8px;transition:all .3s ease;opacity:.5}.loader-step.active{background:#f0f4ff;opacity:1;transform:scale(1.02)}.loader-step.completed{background:#f0fdf4;opacity:1}.step-icon-wrapper{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff;border-radius:8px;color:#667eea}.loader-step.completed .step-icon-wrapper{background:#10b981;color:#fff}.loader-step.active .step-icon-wrapper{background:#667eea;color:#fff;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.step-label{font-size:13px;font-weight:500;color:#374151}.loader-tips{text-align:center;padding-top:24px;border-top:1px solid #e5e7eb}.tip-text{font-size:14px;color:#6b7280;margin:0}@media (max-width: 768px){.generation-loader-modal{width:95%;padding:32px 24px}.loader-title{font-size:24px}.loader-subtitle{font-size:14px}.loader-steps{grid-template-columns:1fr;gap:12px}}.keyboard-shortcuts-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-base)}.keyboard-shortcuts-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:90%;max-width:600px;max-height:80vh;box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;animation:slideUp var(--transition-slow);overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-light);flex-shrink:0}.shortcuts-header-left{display:flex;align-items:center;gap:var(--space-3)}.shortcuts-icon{color:var(--color-primary-600)}.shortcuts-header h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);font-family:var(--font-family);color:var(--text-primary);margin:0}.shortcuts-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-base)}.shortcuts-close-btn:hover{background:var(--bg-hover);border-color:var(--border-medium);color:var(--text-primary)}.shortcuts-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-light);background:var(--bg-tertiary)}.shortcuts-search svg{color:var(--text-tertiary);flex-shrink:0}.shortcuts-search-input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);outline:none;transition:all var(--transition-base)}.shortcuts-search-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.shortcuts-content{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-6);scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.shortcuts-content::-webkit-scrollbar{width:8px}.shortcuts-content::-webkit-scrollbar-track{background:transparent}.shortcuts-content::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}.shortcuts-content::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.shortcuts-category{margin-bottom:var(--space-6)}.shortcuts-category:last-child{margin-bottom:0}.shortcuts-category-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-3) 0}.shortcuts-list{display:flex;flex-direction:column;gap:var(--space-2)}.shortcut-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-base)}.shortcut-item:hover{background:var(--bg-hover);border-color:var(--border-medium);box-shadow:var(--shadow-xs)}.shortcut-description{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--text-primary);flex:1}.shortcut-icon{color:var(--color-primary-600);display:flex;align-items:center}.shortcut-keys{display:flex;align-items:center;gap:var(--space-1)}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 var(--space-2);background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-primary);box-shadow:var(--shadow-xs);line-height:1}.shortcut-separator{color:var(--text-tertiary);font-size:var(--font-size-xs);margin:0 var(--space-1)}.shortcuts-empty{text-align:center;padding:var(--space-8);color:var(--text-tertiary);font-size:var(--font-size-sm);font-family:var(--font-family)}.shortcuts-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);text-align:center;flex-shrink:0;background:var(--bg-tertiary)}.shortcuts-footer p{margin:0;font-size:var(--font-size-xs);font-family:var(--font-family);color:var(--text-tertiary)}.shortcuts-footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-2);background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--text-primary);box-shadow:var(--shadow-xs);margin:0 var(--space-1)}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:24px;background:#f9fafb}.error-boundary-content{max-width:500px;text-align:center;background:#fff;border-radius:16px;padding:40px 32px;box-shadow:0 4px 16px #0000001a;border:1px solid rgba(0,0,0,.08)}.error-boundary-icon{color:#ef4444;margin-bottom:20px;display:flex;justify-content:center}.error-boundary-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 12px}.error-boundary-message{font-size:16px;color:#6b7280;line-height:1.6;margin:0 0 24px}.error-boundary-details{margin:24px 0;text-align:left;background:#f9fafb;border-radius:8px;padding:16px;border:1px solid #e5e7eb}.error-boundary-details summary{cursor:pointer;font-weight:600;color:#374151;margin-bottom:12px;-webkit-user-select:none;user-select:none}.error-boundary-details summary:hover{color:#111827}.error-boundary-stack{font-size:12px;color:#6b7280;white-space:pre-wrap;word-break:break-all;font-family:Monaco,Menlo,Ubuntu Mono,monospace;line-height:1.5;margin:0;padding:12px;background:#fff;border-radius:6px;border:1px solid #e5e7eb;max-height:300px;overflow-y:auto}.error-boundary-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.error-boundary-button{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.error-boundary-button-primary{background:#3b82f6;color:#fff}.error-boundary-button-primary:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.error-boundary-button-secondary{background:#f3f4f6;color:#374151}.error-boundary-button-secondary:hover{background:#e5e7eb}@media (max-width: 768px){.error-boundary-content{padding:32px 24px}.error-boundary-actions{flex-direction:column}.error-boundary-button{width:100%;justify-content:center}}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;box-shadow:0 4px 16px #00000026;background:#fff;border:1px solid rgba(0,0,0,.08);pointer-events:auto;animation:toast-enter .3s ease-out;min-width:280px;max-width:400px}.toast-exiting{animation:toast-exit .3s ease-in forwards}@keyframes toast-enter{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-exit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast-message{flex:1;font-size:14px;line-height:1.5;color:#111827;font-weight:500}.toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#6b7280;border-radius:4px;transition:all .2s}.toast-close:hover{background:#0000000d;color:#111827}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{color:#10b981}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{color:#ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{color:#3b82f6}@media (max-width: 768px){.toast-container{top:16px;right:16px;left:16px;max-width:none}.toast{min-width:auto;max-width:none}}.app{display:flex;flex-direction:column;height:100vh;width:100%;max-width:100vw;overflow:hidden;background:#f9fafb}.app-content{display:flex;flex:1;overflow:hidden;position:relative;background:#fafafa;touch-action:pan-y}@media (max-width: 768px){.app{height:100vh;height:100dvh;overflow:hidden;position:fixed;top:0;left:0;right:0;bottom:0}.app-content{flex-direction:column;height:calc(100vh - 56px);height:calc(100dvh - 56px);position:relative;overflow:hidden}.component-palette{position:fixed;top:56px;left:0;right:0;bottom:0;width:100%;max-width:100%;max-height:none;height:calc(100dvh - 56px);z-index:200;background:#fff;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 12px #0000001a;order:0}.component-palette.open{transform:translate(0)}.property-panel{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;max-height:70vh;z-index:201;order:0}.builder-canvas{flex:1;min-height:0;overflow:hidden;order:1;position:relative;width:100%;height:100%;max-width:100%}.app{overflow:hidden;position:fixed;width:100%;height:100%}}@media (max-width: 480px){.app-content{height:calc(100vh - 108px);height:calc(100dvh - 108px)}.component-palette{max-height:35vh}}@media (hover: none) and (pointer: coarse){.app-content,.component-palette,.property-panel,.canvas-content{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior:contain}button,.palette-item,.page-tab,.toolbar-btn-icon{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.component-wrapper,.palette-item,.page-tab{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (max-width: 1024px){.app-content{flex-direction:column}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%;touch-action:manipulation}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;margin:0;padding:0;overflow-x:hidden;overflow-y:auto;width:100%;touch-action:pan-y;position:relative}#root{width:100%;min-height:100vh;overflow-x:hidden}button,a,input,select,textarea{touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1)}button:active,a:active{transform:scale(.98);transition:transform .1s}.no-select{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}@media (max-width: 768px){html{font-size:14px}}@media (max-width: 480px){html{font-size:13px}}@supports (padding: max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}}:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-800: #1e40af;--color-primary-900: #1e3a8a;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-primary-hover: linear-gradient(135deg, #5a67d8 0%, #6b46c1 100%);--gradient-primary-active: linear-gradient(135deg, #4c51bf 0%, #553c9a 100%);--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-success: #10b981;--color-success-light: #d1fae5;--color-error: #ef4444;--color-error-light: #fee2e2;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-info: #3b82f6;--color-info-light: #dbeafe;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f9fafb;--bg-hover: #f3f4f6;--bg-active: #e5e7eb;--text-primary: #111827;--text-secondary: #374151;--text-tertiary: #6b7280;--text-disabled: #9ca3af;--text-inverse: #ffffff;--border-light: #e5e7eb;--border-medium: #d1d5db;--border-dark: #9ca3af;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Inter", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-primary: 0 4px 12px rgba(102, 126, 234, .3), 0 2px 4px rgba(102, 126, 234, .2);--shadow-primary-hover: 0 6px 20px rgba(102, 126, 234, .4), 0 4px 8px rgba(102, 126, 234, .25);--shadow-success: 0 4px 12px rgba(16, 185, 129, .3), 0 2px 4px rgba(16, 185, 129, .2);--shadow-success-hover: 0 6px 20px rgba(16, 185, 129, .4), 0 4px 8px rgba(16, 185, 129, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-slower: .35s cubic-bezier(.4, 0, .2, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700}.btn-base{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:var(--line-height-tight);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.btn-base:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff1a;opacity:0;transition:opacity var(--transition-fast)}.btn-base:hover:before{opacity:1}.btn-base:active{transform:scale(.98)}.input-base{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-sm);line-height:var(--line-height-normal);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-base)}.input-base:hover{border-color:var(--border-medium)}.input-base:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.card-base{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card-base:hover{box-shadow:var(--shadow-md);border-color:var(--border-medium)}.smooth-scroll{scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.smooth-scroll::-webkit-scrollbar{width:8px;height:8px}.smooth-scroll::-webkit-scrollbar-track{background:transparent}.smooth-scroll::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full);transition:background var(--transition-base)}.smooth-scroll::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}*:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}::selection{background:var(--color-primary-100);color:var(--color-primary-900)}
