*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #FAFAFA;--color-surface: #FFFFFF;--color-border: #E8E8EC;--color-border-hover: #D0D0D6;--color-text: #1A1A2E;--color-text-secondary: #6B7280;--color-text-tertiary: #9CA3AF;--color-primary: #6366F1;--color-primary-hover: #5558E6;--color-primary-light: #EEF2FF;--color-danger: #EF4444;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 4px 16px rgba(0,0,0,.08);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}#root{height:100vh;width:100vw}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 20px;border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.app-header__left{display:flex;align-items:center;gap:8px}.screenwrap-logo{flex-shrink:0}.app-header__title{font-size:16px;font-weight:650;letter-spacing:-.02em}.app-header__badge{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);background:var(--color-primary-light);padding:2px 6px;border-radius:4px}.app-header__right{display:flex;align-items:center;gap:8px}.app-main--workspace{display:flex;flex-direction:column;height:calc(100vh - 52px)}.landing{flex:1;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;min-height:100vh}.landing__bg{position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 80%,rgba(139,92,246,.35) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 20%,rgba(56,189,248,.3) 0%,transparent 55%),radial-gradient(ellipse 90% 80% at 50% 50%,rgba(37,99,235,.15) 0%,transparent 70%),linear-gradient(160deg,#0a1628,#0f2450,#162d6b,#1a3a7a,#1e4488);z-index:0}.landing__bg:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.5;pointer-events:none}.landing__deco{position:absolute;pointer-events:none}.landing__deco--browser{top:10%;left:6%;width:140px;height:95px;border:1.5px solid rgba(255,255,255,.08);border-radius:8px;background:#ffffff08;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transform:rotate(-8deg);animation:float-slow 20s ease-in-out infinite}.landing__deco-dots{display:flex;gap:4px;padding:8px 10px}.landing__deco-dots span{width:6px;height:6px;border-radius:50%;background:#ffffff26}.landing__deco-lines{padding:6px 10px;display:flex;flex-direction:column;gap:5px}.landing__deco-lines span{height:3px;border-radius:2px;background:#ffffff0f}.landing__deco-lines span:nth-child(1){width:70%}.landing__deco-lines span:nth-child(2){width:90%}.landing__deco-lines span:nth-child(3){width:50%}.landing__deco--device{bottom:14%;right:7%;display:flex;flex-direction:column;align-items:center;transform:rotate(6deg);animation:float-slow 22s ease-in-out infinite reverse}.landing__deco-screen{width:110px;height:72px;border:1.5px solid rgba(255,255,255,.08);border-radius:6px;background:#ffffff08;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.landing__deco-stand{width:30px;height:14px;border-left:1.5px solid rgba(255,255,255,.06);border-right:1.5px solid rgba(255,255,255,.06);border-bottom:1.5px solid rgba(255,255,255,.06);border-radius:0 0 4px 4px;margin-top:-1px}.landing__deco--text{top:18%;right:10%;width:60px;height:60px;border:1.5px solid rgba(255,255,255,.07);border-radius:12px;background:#ffffff05;display:flex;align-items:center;justify-content:center;transform:rotate(12deg);animation:float-slow 18s ease-in-out infinite}.landing__deco--text span{font-size:22px;font-weight:700;color:#ffffff1a;font-family:Georgia,serif}.landing__deco--grid{bottom:16%;left:8%;display:grid;grid-template-columns:repeat(4,18px);grid-template-rows:repeat(3,18px);gap:3px;transform:rotate(-5deg);animation:float-slow 24s ease-in-out infinite reverse}.landing__deco--grid span{border:1px solid rgba(255,255,255,.06);border-radius:2px;background:#ffffff04}.landing__deco--gradient-card{top:38%;right:4%;width:80px;height:55px;border-radius:8px;background:linear-gradient(135deg,#38bdf81f,#8b5cf61f);border:1px solid rgba(255,255,255,.06);transform:rotate(-10deg) perspective(300px) rotateY(15deg);animation:float-slow 16s ease-in-out infinite}.landing__deco--orb{border-radius:50%;filter:blur(60px)}.landing__deco--orb-1{top:-5%;right:15%;width:300px;height:300px;background:#38bdf814;animation:pulse-orb 12s ease-in-out infinite}.landing__deco--orb-2{bottom:-10%;left:10%;width:350px;height:350px;background:#8b5cf614;animation:pulse-orb 15s ease-in-out infinite reverse}@keyframes float-slow{0%,to{transform:translateY(0) rotate(var(--r, -8deg))}50%{transform:translateY(-12px) rotate(var(--r, -8deg))}}.landing__deco--browser{--r: -8deg}.landing__deco--device{--r: 6deg}.landing__deco--text{--r: 12deg}.landing__deco--grid{--r: -5deg}.landing__deco--gradient-card{--r: -10deg}@keyframes pulse-orb{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.landing__logo{display:flex;align-items:center;gap:12px;color:#fff;font-size:26px;font-weight:700;letter-spacing:-.02em;margin-bottom:32px}.landing__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:40px;width:100%;max-width:720px}.landing__title{font-size:48px;font-weight:800;color:#fff;text-align:center;line-height:1.15;letter-spacing:-.03em;margin-bottom:16px}.landing__subtitle{font-size:17px;color:#ffffffa6;text-align:center;font-weight:400;margin-bottom:40px}.landing__mockup{width:100%;max-width:580px;border-radius:12px;overflow:hidden;box-shadow:0 30px 80px #0006,0 10px 24px #00000040,0 0 0 1px #ffffff0f}.landing__mockup-header{background:#e8e8e8;padding:14px 18px;display:flex;align-items:center;gap:8px}.landing__dot{width:13px;height:13px;border-radius:50%}.landing__dot--red{background:#ff5f57}.landing__dot--yellow{background:#ffbd2e}.landing__dot--green{background:#28c840}.landing__mockup-body{background:#fff;padding:0}.landing__privacy{display:flex;align-items:center;gap:6px;margin-top:24px;font-size:13px;color:#ffffff73}.drop-zone{width:100%;padding:60px 40px;border:none;border-radius:0;background:#fff;cursor:pointer;transition:all .2s ease;outline:none}.drop-zone:hover,.drop-zone:focus-visible{background:#f8f9ff}.drop-zone--active{background:#f0f4ff}.drop-zone__content{display:flex;flex-direction:column;align-items:center;gap:20px}.drop-zone__text{font-size:16px;color:#888;font-weight:400}.drop-zone__browse{padding:12px 28px;background:#2563eb;color:#fff;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background .15s}.drop-zone__browse:hover{background:#1d4ed8}.drop-zone-compact{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:var(--font-sans);min-height:52px}.drop-zone-compact:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.image-strip{border-bottom:1px solid var(--color-border);background:var(--color-surface);padding:10px 16px;flex-shrink:0}.image-strip__list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.image-strip__list::-webkit-scrollbar{height:4px}.image-strip__list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.image-strip__item{position:relative;flex-shrink:0;width:72px;height:52px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:all .15s}.image-strip__item:hover{border-color:var(--color-border-hover)}.image-strip__item--selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.image-strip__thumb{width:100%;height:100%;object-fit:cover}.image-strip__remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:10px;padding:0;line-height:1}.image-strip__item:hover .image-strip__remove{display:flex}.image-strip__count{font-size:11px;color:var(--color-text-tertiary);margin-top:6px}.workspace{display:flex;flex:1;overflow:hidden}.workspace__preview{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:var(--color-bg);position:relative}.workspace__controls{width:340px;flex-shrink:0;border-left:1px solid var(--color-border);background:var(--color-surface);overflow-y:auto;scrollbar-width:thin}.workspace__controls::-webkit-scrollbar{width:4px}.workspace__controls::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.preview{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;position:relative}.preview--empty{color:var(--color-text-tertiary);font-size:14px}.preview__canvas-wrapper{position:relative;max-width:100%;max-height:calc(100% - 40px);display:inline-flex;align-items:center;justify-content:center}.preview__canvas{max-width:100%;max-height:calc(100% - 40px);display:flex;align-items:center;justify-content:center;overflow:auto}.preview__canvas canvas{border-radius:var(--radius-sm)}.preview__zoom-controls{position:absolute;bottom:16px;display:flex;align-items:center;gap:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:4px;box-shadow:var(--shadow-md)}.preview__zoom-btn{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:11px;font-family:var(--font-sans);transition:all .15s}.preview__zoom-btn:hover{background:var(--color-bg);color:var(--color-text)}.preview__zoom-label{font-size:11px;color:var(--color-text-tertiary);min-width:28px;text-align:center;font-family:var(--font-mono)}.control-panel{padding:0}.control-panel__header{display:flex;align-items:center;gap:10px;padding:16px 20px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.control-section{padding:16px 20px;border-bottom:1px solid var(--color-border)}.control-section__title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:12px}.frame-picker-v2__tabs{display:flex;gap:2px;background:var(--color-bg);border-radius:var(--radius-sm);padding:3px;margin-bottom:12px}.frame-picker-v2__tab{flex:1;padding:7px 6px;border:none;border-radius:4px;background:transparent;font-size:12px;font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.frame-picker-v2__tab--active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.frame-picker-v2__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.frame-thumb{display:flex;flex-direction:column;align-items:center;gap:5px;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;transition:all .15s;font-family:var(--font-sans)}.frame-thumb:hover{border-color:var(--color-border-hover);background:var(--color-bg)}.frame-thumb--active{border-color:var(--color-primary);background:var(--color-primary-light)}.frame-thumb__preview{width:100%;height:44px;border-radius:3px;overflow:hidden;background:var(--color-bg)}.frame-thumb__label{font-size:10px;color:var(--color-text-secondary);text-align:center;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.frame-thumb--active .frame-thumb__label{color:var(--color-primary)}.slider-control{display:flex;align-items:center;gap:10px}.slider-control__label{font-size:13px;color:var(--color-text-secondary);white-space:nowrap}.slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--color-border);outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #00000026}.slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #00000026}.slider-control__value{font-size:12px;font-family:var(--font-mono);color:var(--color-text-tertiary);min-width:36px;text-align:right}.toggle-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.toggle-row__label{font-size:14px;color:var(--color-text-secondary)}.toggle{position:relative;width:40px;height:22px;display:inline-block}.toggle input{opacity:0;width:0;height:0}.toggle__slider{position:absolute;inset:0;background:var(--color-border);border-radius:10px;cursor:pointer;transition:.2s}.toggle__slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 2px #0000001a}.toggle input:checked+.toggle__slider{background:var(--color-primary)}.toggle input:checked+.toggle__slider:before{transform:translate(18px)}.color-input-row{display:flex;align-items:center;gap:10px}.color-input{width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px;cursor:pointer;background:transparent}.color-input--full{width:100%;height:32px;margin-top:8px}.color-reset-btn{font-size:13px;color:var(--color-text-tertiary);background:none;border:none;cursor:pointer;font-family:var(--font-sans);text-decoration:underline}.color-reset-btn:hover{color:var(--color-text-secondary)}.bg-type-tabs{display:flex;gap:4px;margin-bottom:10px;background:var(--color-bg);border-radius:var(--radius-sm);padding:3px}.bg-type-tab{flex:1;padding:7px 10px;border:none;border-radius:4px;background:transparent;font-size:13px;font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.bg-type-tab--active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.bg-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.bg-swatch{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:all .15s}.bg-swatch:hover{transform:scale(1.1)}.bg-swatch--active{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.bg-image-upload__btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:20px;border:1.5px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-size:13px;font-family:var(--font-sans);cursor:pointer;transition:all .15s}.bg-image-upload__btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.bg-image-preview{position:relative;border-radius:var(--radius-md);overflow:hidden}.bg-image-preview__thumb{width:100%;height:80px;object-fit:cover;display:block;border-radius:var(--radius-md)}.bg-image-preview__change{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;color:#fff;font-size:13px;font-weight:500;font-family:var(--font-sans);border:none;cursor:pointer;opacity:0;transition:opacity .15s}.bg-image-preview:hover .bg-image-preview__change{opacity:1}.canvas-presets{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px}.canvas-preset-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;font-family:var(--font-sans);transition:all .15s}.canvas-preset-btn:hover{border-color:var(--color-border-hover)}.canvas-preset-btn--active{border-color:var(--color-primary);background:var(--color-primary-light)}.canvas-preset-btn__label{font-size:12px;font-weight:500;color:var(--color-text)}.canvas-preset-btn__sub{font-size:10px;color:var(--color-text-tertiary)}.canvas-preset-btn--active .canvas-preset-btn__label{color:var(--color-primary)}.canvas-preset-btn--active .canvas-preset-btn__sub{color:var(--color-primary);opacity:.7}.canvas-custom{margin-top:8px}.canvas-input-row{display:flex;align-items:center;gap:6px}.canvas-input-label{font-size:13px;color:var(--color-text-tertiary);font-weight:500}.canvas-input{width:80px;padding:7px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-mono);color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s}.canvas-input:focus{border-color:var(--color-primary)}.canvas-input-x{font-size:13px;color:var(--color-text-tertiary)}.aspect-picker{display:flex;flex-wrap:wrap;gap:4px}.aspect-btn{padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:11px;font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.aspect-btn:hover{border-color:var(--color-border-hover)}.aspect-btn--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.position-layout{display:flex;gap:16px}.position-layout__group{flex:1;display:flex;flex-direction:column;gap:8px}.position-layout__label{font-size:11px;font-weight:500;color:var(--color-text-tertiary)}.position-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;background:var(--color-bg);border-radius:var(--radius-sm);padding:4px}.position-grid__cell{aspect-ratio:1;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}.position-grid__cell:hover{border-color:var(--color-border-hover);background:var(--color-bg)}.position-grid__cell--active{border-color:var(--color-primary);background:var(--color-primary-light)}.position-grid__dot{width:6px;height:6px;border-radius:50%;background:var(--color-text-tertiary);transition:background .15s}.position-grid__cell--active .position-grid__dot{background:var(--color-primary)}.padding-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;background:var(--color-bg);border-radius:var(--radius-sm);padding:4px}.padding-grid__corner{aspect-ratio:1}.padding-grid__preview{aspect-ratio:1;border:1.5px dashed var(--color-border);border-radius:4px;background:var(--color-surface)}.padding-grid__input{aspect-ratio:1;width:100%;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);color:var(--color-text);font-size:11px;font-family:var(--font-mono);text-align:center;padding:0;-moz-appearance:textfield}.padding-grid__input::-webkit-inner-spin-button,.padding-grid__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.padding-grid__input:focus{outline:none;border-color:var(--color-primary)}.text-overlay{position:absolute;pointer-events:none;z-index:10;overflow:hidden}.text-overlay__item{position:absolute;pointer-events:auto;cursor:grab;-webkit-user-select:none;user-select:none;padding:4px 8px;border:2px solid transparent;border-radius:4px;transition:border-color .15s;outline:none;min-width:20px}.text-overlay__item:hover{border-color:#6366f166}.text-overlay__item--selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-light)}.text-overlay__item:active{cursor:grabbing}.text-overlay__item[contenteditable=true]{cursor:text;border-color:var(--color-primary);background:#00000026}.text-overlay__resize-handle{position:absolute;top:0;bottom:0;width:8px;cursor:ew-resize;pointer-events:auto}.text-overlay__resize-handle--left{left:-4px}.text-overlay__resize-handle--right{right:-4px}.text-overlay__resize-handle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:3px;height:20px;border-radius:2px;background:var(--color-primary);opacity:.7;transition:opacity .15s}.text-overlay__resize-handle:hover:after{opacity:1}.text-controls__add{width:100%;justify-content:center;margin-bottom:8px}.text-layers-list{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}.text-layer-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;font-size:12px;color:var(--color-text-secondary);transition:all .15s;font-family:var(--font-sans)}.text-layer-item:hover{border-color:var(--color-border-hover)}.text-layer-item--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.text-layer-item__label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-layer-item__delete{flex-shrink:0;width:20px;height:20px;border:none;background:transparent;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);padding:0;transition:all .15s}.text-layer-item__delete:hover{background:#ef44441a;color:#ef4444}.text-format{display:flex;flex-direction:column;gap:8px}.text-format__input{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:13px;font-family:var(--font-sans);resize:vertical;min-height:36px}.text-format__input:focus{outline:none;border-color:var(--color-primary)}.text-format__row{display:flex;align-items:center;gap:8px}.text-format__font-select{width:100%;padding:7px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:13px;font-family:var(--font-sans);cursor:pointer}.text-format__font-select:focus{outline:none;border-color:var(--color-primary)}.text-format__style-btns,.text-format__align-btns{display:flex;gap:2px}.text-format__style-btn{width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);padding:0;transition:all .15s}.text-format__style-btn:hover{border-color:var(--color-border-hover)}.text-format__style-btn--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.export-scale{display:flex;gap:6px;margin-bottom:12px}.export-scale__btn{flex:1;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:13px;font-family:var(--font-mono);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.export-scale__btn--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.export-actions{display:flex;flex-direction:column;gap:8px}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-border)}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn--sm{padding:7px 12px;font-size:13px}.crop-controls{display:flex;flex-direction:column;gap:8px}.crop-controls__info{font-size:13px;color:var(--color-text-secondary);font-family:var(--font-mono)}.crop-controls__btns{display:flex;gap:6px}.crop-controls__btns .btn{flex:1}.crop-overlay{position:absolute;inset:0;background:#111;z-index:20;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none}.crop-overlay__image{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none}.crop-overlay__selection{position:absolute;border:2px solid rgba(255,255,255,.85);box-shadow:0 0 0 9999px #0000008c;cursor:move;z-index:1}.crop-grid{position:absolute;inset:0;pointer-events:none}.crop-grid__line{position:absolute;background:#fff3}.crop-grid__line--h{left:0;right:0;height:1px}.crop-grid__line--v{top:0;bottom:0;width:1px}.crop-handle{position:absolute;width:14px;height:14px;background:#fff;border:1.5px solid rgba(0,0,0,.2);border-radius:2px;z-index:2}.crop-handle--nw{top:-7px;left:-7px;cursor:nw-resize}.crop-handle--ne{top:-7px;right:-7px;cursor:ne-resize}.crop-handle--sw{bottom:-7px;left:-7px;cursor:sw-resize}.crop-handle--se{bottom:-7px;right:-7px;cursor:se-resize}.crop-handle--edge{border-radius:3px}.crop-handle--edge.crop-handle--n{top:-5px;left:50%;transform:translate(-50%);width:32px;height:8px;cursor:n-resize}.crop-handle--edge.crop-handle--s{bottom:-5px;left:50%;transform:translate(-50%);width:32px;height:8px;cursor:s-resize}.crop-handle--edge.crop-handle--e{right:-5px;top:50%;transform:translateY(-50%);width:8px;height:32px;cursor:e-resize}.crop-handle--edge.crop-handle--w{left:-5px;top:50%;transform:translateY(-50%);width:8px;height:32px;cursor:w-resize}.crop-overlay__dims{position:absolute;transform:translate(-50%);background:#000000bf;color:#fff;padding:3px 10px;border-radius:4px;font-size:12px;font-family:var(--font-mono);white-space:nowrap;pointer-events:none;z-index:3}.crop-overlay__actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:8px;justify-content:center;padding:12px;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5}.crop-overlay__actions .btn--ghost{color:#ffffffd9;border-color:#fff3}.crop-overlay__actions .btn--ghost:hover{background:#ffffff1a;border-color:#ffffff4d}.export-overlay{position:fixed;inset:0;background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.export-overlay__modal{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 48px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.export-overlay__modal p{font-size:14px;color:var(--color-text-secondary)}.export-overlay__spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.workspace{flex-direction:column}.workspace__controls{width:100%;border-left:none;border-top:1px solid var(--color-border);max-height:300px}.workspace__preview{min-height:300px}}
