body{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;height:100vh;height:100dvh;overflow:hidden;padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}.editor-layout{display:flex;flex-direction:column;height:100%;min-height:100vh;min-height:100dvh;overflow:hidden;background:var(--bg)}.editor-topbar{display:flex;align-items:center;height:48px;padding:0 var(--space-md);border-bottom:1px solid var(--border);background:var(--bg-elevated);gap:var(--space-md);flex-shrink:0;z-index:10;box-shadow:var(--shadow-xs)}.editor-logo{text-decoration:none;flex-shrink:0;display:flex;align-items:center}.editor-logo-img{display:block;height:22px;width:auto}.editor-topbar-template{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--text-muted);margin-right:auto;min-width:0;overflow:hidden}.editor-topbar-label{flex-shrink:0}.editor-topbar-sep{color:var(--text-subtle);font-size:var(--text-xs)}.editor-topbar-name{font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-mobile-tabs-wrapper{display:none}.mobile-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.mobile-tab{flex:1;padding:var(--space-md) var(--space-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color var(--transition),border-color var(--transition);min-height:48px;-webkit-tap-highlight-color:transparent}.mobile-tab.active{color:var(--text);border-bottom-color:var(--accent-primary)}.editor-panels{display:flex;flex:1;overflow:hidden}.editor-left{width:280px;border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;background:var(--bg-surface)}.editor-center{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:var(--space-lg);gap:var(--space-lg)}.editor-right{width:320px;border-left:1px solid var(--border);overflow-y:auto;flex-shrink:0}.template-panel{display:flex;flex-direction:column;height:100%}.template-panel-header{padding:var(--space-md);border-bottom:1px solid var(--border)}.template-search{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.template-search:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-subtle)}.template-categories{display:flex;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);overflow-x:auto;border-bottom:1px solid var(--border);scrollbar-width:none;flex-shrink:0}.template-categories::-webkit-scrollbar{display:none}.template-cat-pill{flex-shrink:0;padding:4px 10px;font-size:11px;font-weight:500;background:transparent;border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all var(--transition)}.template-cat-pill:hover{border-color:var(--border-strong);color:var(--text)}.template-cat-pill.active{background:var(--text);color:var(--bg);border-color:var(--text)}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:min-content;align-content:start;gap:var(--space-sm);padding:var(--space-md);overflow-y:auto;flex:1}.template-thumb{position:relative;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all var(--transition);text-align:left;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.template-thumb:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow-md)}.template-thumb.active{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-subtle),var(--shadow-glow)}.template-thumb-preview{width:100%;aspect-ratio:1200 / 630;overflow:hidden;background:var(--bg-subtle);background-image:linear-gradient(135deg,var(--bg-subtle) 0%,var(--bg-surface) 100%)}.template-thumb-preview img{display:block;width:100%;height:100%;object-fit:cover}.template-thumb-name{display:block;padding:6px 8px;font-size:11px;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-thumb-check{position:absolute;top:6px;right:6px;width:20px;height:20px;background:var(--accent-primary);border-radius:50%}.template-thumb-check:after{content:"";position:absolute;top:5px;left:7px;width:5px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.template-empty{grid-column:1 / -1;padding:var(--space-2xl);text-align:center;color:var(--text-subtle);font-size:var(--text-sm)}.canvas-wrapper{display:flex;align-items:center;justify-content:center;flex:1;min-height:300px;position:relative;background-image:radial-gradient(circle,var(--border-muted) 1px,transparent 1px);background-size:20px 20px;border-radius:var(--radius-lg)}.canvas-frame{width:100%;max-width:800px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl)}.canvas-image{width:100%;height:auto;display:block}.canvas-loading,.canvas-error,.canvas-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);color:var(--text-muted);font-size:var(--text-sm)}.canvas-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .6s linear infinite}.canvas-shimmer{width:100%;max-width:800px;aspect-ratio:1200 / 630;background:linear-gradient(90deg,var(--bg-surface) 0%,var(--bg-elevated) 50%,var(--bg-surface) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg)}.customize-panel{display:flex;flex-direction:column;height:100%}.customize-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);flex-shrink:0}.customize-title{font-size:var(--text-sm);font-weight:600;color:var(--text);letter-spacing:0}.customize-reset{font-size:var(--text-xs);color:var(--text-subtle);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);padding:var(--space-sm) var(--space-md);min-height:36px;-webkit-tap-highlight-color:transparent}.customize-reset:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--accent-primary-subtle)}.customize-reset:active{transform:scale(.97)}.customize-fields{flex:1;overflow-y:auto;padding:var(--space-md) var(--space-lg)}.customize-group{margin-bottom:var(--space-lg)}.customize-group:last-child{margin-bottom:0}.customize-group-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:1px solid var(--border-muted)}.editor-field{margin-bottom:var(--space-md)}.editor-field-label{display:block;font-size:var(--text-xs);font-weight:500;color:var(--text-muted);margin-bottom:4px}.editor-field-required{color:var(--accent-primary);margin-left:2px}.editor-field-input{width:100%;padding:8px 12px;font-size:var(--text-sm);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.editor-field-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-subtle)}.editor-field-textarea{resize:vertical;min-height:60px;font-family:var(--font-sans)}.editor-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;min-height:40px;cursor:pointer}.editor-color-row{display:flex;gap:var(--space-sm);align-items:center}.editor-color-swatch{width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:2px;flex-shrink:0;-webkit-tap-highlight-color:transparent}.editor-color-text{flex:1;font-family:var(--font-mono);font-size:var(--text-xs)}.editor-toggle-row{display:flex;align-items:center;justify-content:space-between;min-height:44px}.editor-toggle{width:44px;height:26px;background:var(--border-strong);border:none;border-radius:13px;cursor:pointer;position:relative;transition:background var(--transition);flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.editor-toggle.active{background:var(--accent-primary)}.editor-toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:var(--shadow-xs)}.editor-toggle.active .editor-toggle-thumb{transform:translate(18px)}.editor-field-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.editor-field-value{font-size:var(--text-xs);color:var(--text-subtle);font-family:var(--font-mono)}.editor-slider{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:var(--border);border-radius:3px;outline:none;touch-action:manipulation}.editor-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--accent-primary);border-radius:50%;cursor:pointer;box-shadow:var(--shadow-sm)}.editor-upload-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;font-size:var(--text-xs);font-weight:500;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;margin-top:6px;transition:all var(--transition);-webkit-tap-highlight-color:transparent;min-height:40px}.editor-upload-btn:hover{border-color:var(--border-strong);color:var(--text)}.editor-upload-btn:active{transform:scale(.97)}.export-bar{display:flex;align-items:center}.export-buttons{display:flex;align-items:center;gap:var(--space-sm)}.export-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.export-btn:active{transform:scale(.97)}.export-btn-primary{background:var(--gradient-coral);color:#fff;border-color:var(--accent-primary);box-shadow:var(--shadow-xs)}.export-btn-primary:hover{box-shadow:var(--shadow-md),var(--shadow-glow)}.export-btn-primary:active{box-shadow:var(--shadow-xs)}.export-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.export-btn-ghost{background:var(--bg-elevated);color:var(--text-muted);border-color:var(--border)}.export-btn-ghost:hover{background:var(--bg-surface);color:var(--text);border-color:var(--border-strong)}.export-btn-ghost:active{background:var(--bg-surface)}.platform-strip{flex-shrink:0}.platform-strip-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.platform-strip-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-primary)}.platform-strip-scroll{display:flex;gap:var(--space-md);overflow-x:auto;padding-bottom:var(--space-sm);scrollbar-width:none;-webkit-overflow-scrolling:touch}.platform-strip-scroll::-webkit-scrollbar{display:none}.platform-mini{flex-shrink:0;cursor:pointer;border-radius:var(--radius);transition:transform var(--transition),box-shadow var(--transition);min-width:120px;-webkit-tap-highlight-color:transparent}.platform-mini:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-md)}.platform-mini:active{transform:scale(.98)}.platform-mini-header{margin-bottom:4px}.platform-mini-name{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);text-align:center}.viewport-switcher{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg-surface)}.viewport-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:var(--text-xs);font-weight:500;color:var(--text-muted);background:transparent;border:none;border-right:1px solid var(--border);cursor:pointer;transition:background var(--transition),color var(--transition);white-space:nowrap}.viewport-btn:last-child{border-right:none}.viewport-btn:hover{background:var(--bg-elevated);color:var(--text)}.viewport-btn-active{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-xs)}.viewport-btn-icon{font-size:14px;line-height:1}.viewport-btn-size{font-size:10px;color:var(--text-subtle);font-family:var(--font-mono)}.viewport-btn-active .viewport-btn-size{color:var(--accent-primary)}.viewport-switcher-compact .viewport-btn{padding:4px 8px}.platform-expanded-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-md);animation:fadeIn .15s ease-out;-webkit-tap-highlight-color:transparent}.platform-expanded-card{background:var(--bg-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;overflow:hidden;transition:max-width var(--transition)}.platform-expanded-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border)}.platform-expanded-name{font-size:var(--text-sm);font-weight:600;color:var(--text)}.platform-expanded-actions{display:flex;align-items:center;gap:var(--space-sm)}.platform-expanded-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-muted);font-size:20px;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}.platform-expanded-close:hover{background:var(--bg-surface);color:var(--text)}.platform-expanded-body{padding:var(--space-lg);overflow-x:auto;-webkit-overflow-scrolling:touch}.platform-expanded-close{min-width:44px;min-height:44px}.editor-export-mobile{padding:var(--space-lg) var(--space-md);padding-bottom:max(var(--space-xl),env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:var(--space-lg);width:100%}.editor-export-preview{display:none}.editor-export-mobile .export-bar{flex-direction:column}.editor-export-mobile .export-buttons{flex-direction:column;width:100%;gap:var(--space-sm)}.editor-export-mobile .export-btn{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--text-sm);min-height:52px;justify-content:center;border-radius:var(--radius-lg)}.editor-export-mobile .export-btn-primary{font-size:var(--text-base);font-weight:600;gap:var(--space-sm);min-height:56px}.editor-export-mobile .export-btn-primary svg{width:18px;height:18px}.editor-export-mobile .export-btn-ghost{background:var(--bg-surface);border-color:var(--border)}.editor-export-mobile .platform-strip{margin-top:var(--space-sm);border-top:1px solid var(--border-muted);padding-top:var(--space-lg)}@media(max-width:1024px){.editor-left{width:240px}.editor-right{width:280px}}@media(max-width:768px){.editor-topbar .export-bar{display:none}.editor-mobile-tabs-wrapper{display:block}.editor-topbar{gap:var(--space-sm)}.editor-topbar-label{display:none}.editor-logo-img{height:20px}.editor-panels{flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.editor-left{width:100%;border-left:none;border-right:none;flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.editor-center{width:100%;height:auto;min-height:auto;flex:none;padding:var(--space-md);overflow:visible;position:sticky;top:0;z-index:5;background:var(--bg);border-bottom:1px solid var(--border-muted)}.editor-right{width:100%;min-height:0;border-left:none;border-right:none;flex:1 1 auto;flex-direction:column;overflow:visible}.editor-center .canvas-wrapper{min-height:200px;max-height:35vh;flex-shrink:0;border-radius:var(--radius)}.editor-center .platform-strip{display:none}.editor-right .customize-panel{height:auto;width:100%;padding-bottom:max(var(--space-lg),env(safe-area-inset-bottom))}.editor-right .customize-header{position:sticky;top:0;z-index:2;background:var(--bg-elevated);padding:var(--space-sm) var(--space-md);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px)}.editor-right .customize-fields{padding:var(--space-md);overflow:visible}.editor-right .customize-group-title{position:sticky;top:0;background:var(--bg);padding-top:var(--space-sm);z-index:1}.editor-export-preview{display:block;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.editor-export-preview .canvas-wrapper{min-height:120px;max-height:28vh;border-radius:var(--radius-lg)}.editor-field-textarea{min-height:80px}.editor-select{font-size:16px;min-height:44px}.editor-upload-btn{width:100%;min-height:44px;justify-content:center}.editor-toggle{width:48px;height:28px;border-radius:14px}.editor-toggle-thumb{width:22px;height:22px}.editor-toggle.active .editor-toggle-thumb{transform:translate(20px)}.mobile-hide{display:none!important}.mobile-show{display:flex!important}.template-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-sm);padding:var(--space-sm);flex:1;align-content:start}.template-thumb{min-height:0;border-radius:var(--radius-sm)}.template-thumb:active{transform:scale(.97);box-shadow:none}.template-thumb-preview{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.platform-strip-header{flex-wrap:wrap;gap:var(--space-sm)}.platform-strip-scroll{margin-left:calc(-1 * var(--space-md));margin-right:calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md);gap:var(--space-sm)}.platform-expanded-overlay{padding:var(--space-sm);align-items:flex-end}.platform-expanded-card{max-height:85vh;max-height:85dvh;overflow-y:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.platform-expanded-header{padding:var(--space-md);position:sticky;top:0;background:var(--bg-elevated);z-index:1}.platform-expanded-body{padding:var(--space-md)}.viewport-switcher-compact .viewport-btn{padding:6px 10px;min-height:36px}.template-panel-header{padding:var(--space-sm) var(--space-md)}.template-search{font-size:16px;min-height:44px;padding:var(--space-sm) var(--space-md)}.template-categories{padding:var(--space-xs) var(--space-md)}.editor-color-swatch{width:44px;height:44px}.editor-slider::-webkit-slider-thumb{width:24px;height:24px}}@media(max-width:480px){.editor-topbar{padding:0 var(--space-sm);min-height:44px;height:44px;gap:var(--space-xs)}.editor-topbar-name{font-size:var(--text-xs)}.editor-logo-img{height:18px}.mobile-tab{font-size:var(--text-xs);min-height:44px;padding:var(--space-sm) var(--space-xs)}.editor-center{padding:var(--space-sm)}.editor-center .canvas-wrapper{min-height:180px;max-height:36vh}.customize-fields{padding:var(--space-sm) var(--space-md)}.editor-field{margin-bottom:var(--space-lg)}.editor-field-label{font-size:var(--text-sm);margin-bottom:6px}.editor-field-input{font-size:16px;min-height:48px;padding:12px 14px;border-radius:var(--radius)}.editor-field-textarea{min-height:90px}.editor-color-swatch{width:48px;height:48px;border-radius:var(--radius)}.editor-color-text{font-size:var(--text-sm);min-height:48px}.editor-slider{height:8px;border-radius:4px}.editor-slider::-webkit-slider-thumb{width:28px;height:28px}.editor-select{min-height:48px;border-radius:var(--radius)}.editor-upload-btn{min-height:48px;font-size:var(--text-sm);border-radius:var(--radius)}.editor-export-mobile{padding:var(--space-md)}.editor-export-mobile .export-btn{min-height:52px;border-radius:var(--radius)}.editor-export-mobile .export-btn-primary{min-height:56px}.editor-export-preview .canvas-wrapper{min-height:100px;max-height:25vh}.template-cat-pill{min-height:40px;padding:8px 14px;font-size:10px}.template-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm);padding:var(--space-sm)}.template-thumb-name{font-size:10px;padding:5px 6px}}@media(max-width:380px){.template-grid{grid-template-columns:1fr}.customize-group-title{font-size:10px}.editor-export-mobile .export-btn-primary{font-size:var(--text-sm);min-height:52px}.platform-mini{min-width:100px}}
