@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";.layout-item--danger[data-v-e75e1098]{border-color:#ff50508c}.layout-item--danger[data-v-e75e1098]:hover{border-color:#ff5050f2}.fonts-panel[data-v-9cabff20]{display:grid;grid-template-columns:1fr;gap:12px;padding:12px;height:100%;overflow-y:auto;overflow-x:hidden;align-content:start;box-sizing:border-box;scrollbar-gutter:stable}.fonts-search[data-v-9cabff20]{width:100%;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:#0000002e;color:#fff;outline:none}.fonts-list[data-v-9cabff20]{display:grid;grid-template-columns:1fr;gap:12px;padding:0}.font-item[data-v-9cabff20]{text-align:left;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;border-radius:10px;padding:10px 12px;cursor:grab;-webkit-user-select:none;user-select:none;color:#a9a9a9}.font-item[data-v-9cabff20]:active{cursor:grabbing}.font-item.active[data-v-9cabff20]{border-color:#0066ffe6}.font-title[data-v-9cabff20]{font-size:16px;line-height:1.2}.font-preview[data-v-9cabff20]{margin-top:6px;font-size:14px;line-height:1.2;opacity:.9}.fonts-hint[data-v-9cabff20]{font-size:12px;opacity:.75}.fonts-retry[data-v-9cabff20]{margin-left:8px;padding:4px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#fff;cursor:pointer}.fonts-retry[data-v-9cabff20]:hover{background:#ffffff1f}.editor{display:flex;flex-direction:column;width:100vw;height:100vh;background:#3a3a3a;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.header-card-id-input{width:160px;height:32px;padding:0 12px;background:#1a1a1a;border:1px solid #555;border-radius:6px;color:#fff;font-size:13px;outline:none}.header-card-id-input:focus{border-color:#00d6d6}.header-url-input{width:320px;height:32px;padding:0 12px;background:#1a1a1a;border:1px solid #555;border-radius:6px;color:#fff;font-size:13px;outline:none}.header-url-input:focus{border-color:#00d6d6}.header-url-input:disabled,.header-url-input.input-locked{background:#2a2a2a;border-color:#444;color:#888;cursor:not-allowed}.header-url-add-btn{width:32px;height:32px;background:#00d6d6;border:none;border-radius:6px;color:#1a1a1a;cursor:pointer;font-size:18px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.header-url-add-btn:hover:not(:disabled){background:#0ee;transform:scale(1.05)}.header-url-add-btn:active:not(:disabled){transform:scale(.95)}.header-url-add-btn:disabled{opacity:.5;cursor:not-allowed;background:#555;transform:none}.header-url-add-btn.loading{background:#00b8b8;cursor:wait}.header-url-add-btn .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.save-btn,.download-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#4a4a4a;border:none;border-radius:6px;color:#fff;cursor:pointer}.save-btn:hover,.download-btn:hover{background:#00d6d6;color:#1a1a1a}.download-btn:disabled{opacity:.5;cursor:not-allowed}.loading-notification{position:fixed;top:80px;left:50%;transform:translate(-50%);padding:12px 24px;background:#00d6d6f2;color:#1a1a1a;border-radius:8px;z-index:10001}.pagination{display:flex;flex-direction:column;gap:8px;align-items:center}.pagination--canvas{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:6;max-width:min(70%,720px)}.pagination-scroll{display:flex;gap:4px;max-width:100%;overflow-x:auto;overflow-y:hidden;padding:4px 0}.pagination-info{font-size:12px;color:#999}.page-btn{min-width:36px;height:32px;padding:0 12px;border:none;border-radius:4px;background:#3a3a3a;color:#888;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.page-btn:hover{background:#4a4a4a;color:#fff}.page-btn.active{background:#fff;color:#1a1a1a;font-weight:600}.editor-content{display:flex;flex:1;min-height:0}.editor-main{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0}.photos-strip-wrapper{position:relative;border-top:1px solid #444;background:#2b2b2b;overflow:visible}.photos-strip-wrapper.collapsed{height:20px}.photos-panel-edge{position:absolute;top:0;left:0;right:0;height:10px;background:transparent;border-bottom:2px solid transparent;cursor:ns-resize;transition:background .2s ease,border-color .2s ease;z-index:5}.photos-panel-edge:hover{background:#00d6d614;border-bottom-color:#00d6d64d}.photos-strip-wrapper.collapsed .photos-panel-edge{background:#00d6d62e;border-bottom-color:#00d6d673}.sidebar{display:flex;flex-direction:column;align-items:center;padding:20px 12px;background:#2d2d2d;z-index:10}.sidebar--left{width:56px;justify-content:flex-start;gap:16px;padding-top:40px}.sidebar--right{width:56px;align-items:center;padding-top:16px}.zoom-controls{display:flex;flex-direction:column;align-items:center;gap:8px}.zoom-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#4a4a4a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease}.zoom-btn:hover:not(:disabled){background:#5a5a5a}.zoom-btn:disabled{opacity:.4;cursor:not-allowed}.delete-btn{background:#d32f2f;margin-top:8px}.delete-btn:hover:not(:disabled){background:#f44336}.delete-btn:disabled{opacity:.3;background:#6a6a6a}.zoom-slider-container{position:relative;height:180px;width:36px;display:flex;align-items:center;justify-content:center}.zoom-slider{position:absolute;width:180px;height:6px;transform:rotate(-90deg);transform-origin:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;z-index:2}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#1a1a1a;border:3px solid #fff;cursor:pointer;box-shadow:0 2px 8px #0006}.zoom-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#1a1a1a;border:3px solid #fff;cursor:pointer}.zoom-track{position:absolute;width:6px;height:180px;background:linear-gradient(to top,#666,#888);border-radius:3px;overflow:hidden}.zoom-track-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(to top,#ff1493,#fff);border-radius:3px;transition:height .1s ease}.zoom-value{text-align:center;font-size:12px;color:#aaa;margin-top:8px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.zoom-value:hover{background:#4a4a4a;color:#fff}.reset-btn,.rotate-btn{margin-top:8px}.format-selector-wrapper{position:relative;margin-bottom:20px}.format-btn{position:relative}.format-dropdown{position:absolute;top:0;left:60px;background:#2d2d2d;border:1px solid #444;border-radius:8px;padding:8px;min-width:140px;box-shadow:0 4px 16px #0006;z-index:100}.format-option{width:100%;padding:10px 14px;background:transparent;border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:background .2s ease}.format-option:hover{background:#3a3a3a}.format-option.active{background:#00d6d6;color:#1a1a1a}.canvas-container{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:background .2s ease;min-height:0}.canvas-container.drag-over{background:#00d6d60d}.canvas-danger-btn{position:absolute;right:16px;bottom:16px;width:40px;height:40px;border-radius:10px;border:none;background:#ef444433;color:#fecaca;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:70}.canvas-danger-btn:hover:not(:disabled){background:#ef444466;color:#fff;transform:translateY(-1px)}.canvas-danger-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.stage-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:16px;-webkit-user-select:none;user-select:none}.text-editor-overlay{position:absolute;z-index:50;padding:0;margin:0;background:#fff0;border:1px solid rgba(0,102,255,.85);outline:none;resize:none;overflow:visible;line-height:1.2;white-space:pre-wrap}.text-editor-toolbar{position:absolute;z-index:60;display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:6px 10px;border-radius:10px;background:#1a1a1aeb;border:1px solid rgba(255,255,255,.14);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);-webkit-user-select:none;user-select:none;width:max-content;max-width:calc(100% - 16px)}.text-toolbar-group{display:inline-flex;align-items:center;gap:6px}.text-toolbar-sep{width:1px;height:18px;background:#ffffff24}.text-toolbar-btn{width:30px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.text-toolbar-btn:hover{background:#ffffff1a}.text-toolbar-btn.active{border-color:#0066ffd9;background:#0066ff2e}.text-toolbar-color{position:relative;width:30px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.text-toolbar-color:hover{background:#ffffff1a}.text-toolbar-color-swatch{width:14px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.25)}.text-toolbar-color-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.text-toolbar-size{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 8px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f}.text-toolbar-size-input{width:54px;height:22px;border:none;outline:none;background:transparent;color:#fff;font-size:12px}.text-toolbar-size-suffix{font-size:12px;opacity:.75}.logo-editor-toolbar{position:absolute;z-index:60;height:36px;display:inline-flex;align-items:center;gap:10px;padding:0 10px;border-radius:10px;background:#1a1a1aeb;border:1px solid rgba(255,255,255,.14);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);-webkit-user-select:none;user-select:none;width:max-content;max-width:calc(100% - 16px)}.logo-toolbar-color{position:relative;width:30px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.logo-toolbar-color:hover{background:#ffffff1a}.logo-toolbar-color-swatch{width:14px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.25)}.logo-toolbar-color-input{position:absolute;left:0;top:-300px;width:30px;height:28px;opacity:0;cursor:pointer}.logo-toolbar-opacity{display:inline-flex;align-items:center;gap:8px;height:28px;padding:0 10px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;color:#fff}.logo-toolbar-opacity-range{width:120px}.logo-toolbar-opacity-label{font-size:12px;opacity:.8;min-width:36px;text-align:right}.nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#4a4a4a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease;z-index:5;box-shadow:0 4px 16px #0000004d}.nav-btn:hover:not(:disabled){background:#5a5a5a;transform:translateY(-50%) scale(1.05)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.nav-btn--left{left:24px}.nav-btn--right{right:24px}.navigation{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.navigation>*{pointer-events:auto}.add-spread-btn{position:absolute;top:16px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#4a4a4a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease;z-index:5;box-shadow:0 4px 12px #0000004d}.add-spread-btn:hover:not(:disabled){background:#5a5a5a;transform:scale(1.1)}.add-spread-btn:disabled{opacity:.3;cursor:not-allowed}.add-spread-btn--left{left:16px}.add-spread-btn--right{right:16px}.action-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#4a4a4a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#5a5a5a}.spread-label-container{position:absolute;left:50%;bottom:16px;transform:translate(-50%);display:flex;align-items:center;justify-content:center;gap:12px;z-index:6}.spread-label{background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:8px 24px;font-size:13px;font-weight:500;color:#fff;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #0000004d}.spread-label--page-number{text-transform:none;min-width:40px;text-align:center;cursor:pointer;transition:all .2s ease}.spread-label--page-number:hover{background:#2a2a2a;border-color:#555}.spread-label--page-number.spread-label--active{background:#2563eb;border-color:#3b82f6;box-shadow:0 4px 12px #2563eb66}.spread-label--page-number.spread-label--active:hover{background:#3b82f6;border-color:#60a5fa}.right-panel{width:300px;background:#2a2a2a;border-left:1px solid #444;flex-shrink:0;display:flex;flex-direction:column;position:relative;transition:all .3s ease;min-height:0}.right-panel.collapsed{width:20px}.panel-edge{position:absolute;left:0;top:0;bottom:0;width:12px;background:transparent;cursor:ew-resize;z-index:100;transition:background .2s ease;border-right:2px solid transparent}.panel-edge:hover{background:#00d6d61a;border-right-color:#00d6d64d}.right-panel.collapsed .panel-edge{width:100%;cursor:ew-resize;background:#00d6d626}.right-panel.collapsed .panel-edge:hover{background:#00d6d64d}.panel-tabs{display:flex;gap:0;background:#1a1a1a;border-bottom:1px solid #444;padding:0 10px;flex-shrink:0}.panel-actions{display:flex;gap:8px;padding:10px;border-bottom:1px solid #3a3a3a;background:#1f1f1f;justify-content:flex-start}.panel-tab{padding:8px 14px;background:transparent;border:none;border-bottom:2px solid transparent;color:#aaa;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;white-space:nowrap}.panel-tab:hover{color:#fff;background:#2a2a2a}.panel-tab.active{color:#00d6d6;border-bottom-color:#00d6d6;background:#2a2a2a}.panel-tab.panel-tab-icon{padding:8px 10px;display:inline-flex;align-items:center;justify-content:center}.panel-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.tab-content{height:100%;overflow:hidden;display:flex;flex-direction:column;min-height:0}.settings-panel{display:grid;gap:12px;padding:14px;height:100%;overflow-y:auto;overflow-x:hidden;align-content:start;box-sizing:border-box;scrollbar-gutter:stable}.settings-field{display:grid;gap:6px}.settings-label{font-size:12px;color:#e2e8f0cc}.settings-input{width:100%;box-sizing:border-box}.settings-url-row{display:flex;align-items:center;gap:8px}.settings-folder-name{padding:8px 10px;border-radius:8px;background:#22d3ee1f;color:#67e8f9;font-size:12px;font-weight:600}.settings-select{width:100%;height:36px;padding:0 10px;border-radius:8px;border:1px solid #374151;background:#111827;color:#e5e7eb;font-size:13px;outline:none}.settings-select:focus{border-color:#22d3ee}.settings-modal-card{width:min(560px,92vw);max-height:min(80vh,720px)}.settings-modal-card .tab-content{height:auto;overflow:visible}.settings-modal-card .settings-panel{padding:0;height:auto;max-height:60vh}.layouts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:12px;height:100%;overflow-x:hidden;overflow-y:auto;align-content:start;box-sizing:border-box;scrollbar-gutter:stable}.layout-item{width:100%;cursor:pointer;transition:transform .2s ease}.layout-item:hover{transform:translateY(-2px)}.layout-preview{width:100%;aspect-ratio:1;background:#fff;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:border-color .2s ease,box-shadow .2s ease;position:relative}.layout-item:hover .layout-preview{border-color:#007bff;box-shadow:0 4px 12px #007bff33}.layout-svg{width:100%;height:100%;display:block}.layout-svg--transform{transition:transform .2s ease}.layout-index{position:absolute;top:6px;left:6px;z-index:2;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#000000b3;color:#fff;font-size:11px;font-weight:600;line-height:22px;text-align:center;pointer-events:none}.layout-name{margin-top:6px;text-align:center;font-size:11px;font-weight:500;color:#333}.layout-actions{position:absolute;bottom:0;left:0;right:0;z-index:3;display:flex;gap:4px;padding:6px;background:linear-gradient(transparent,#000000b3);opacity:0;transition:opacity .2s ease}.layout-item:hover .layout-actions{opacity:1}.layout-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#00000059;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:background .2s ease}.layout-action-btn:hover{background:#0000008c}.layout-action-btn--active{background:#007bffb3}.tab-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-size:14px}.photos-strip{display:flex;flex-direction:column;gap:10px;padding:10px 12px 12px;height:100%;box-sizing:border-box}.photos-strip-top{display:flex;align-items:center;gap:12px;min-width:0}.photos-strip-header{display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:nowrap}.auto-fill-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:auto;padding:10px 14px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d;box-sizing:border-box;white-space:nowrap}.auto-fill-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea80}.auto-fill-btn:active{transform:translateY(0);box-shadow:0 2px 6px #667eea4d}.auto-fill-btn svg{flex-shrink:0}.photos-count{width:auto;padding:6px 10px;border-radius:8px;background:#ffffff14;color:#e5e7eb;font-size:12px;display:flex;align-items:center;justify-content:space-between;gap:8px;letter-spacing:.2px;box-sizing:border-box}.photos-refresh-btn{width:26px;height:26px;border-radius:6px;border:none;background:#ffffff1f;color:#e5e7eb;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,color .2s ease}.photos-refresh-btn:hover{background:#ffffff38;color:#fff}.photos-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.hidden-input{display:none}.photo-folder-tabs{display:flex;align-items:center;gap:8px;overflow-x:auto;overflow-y:hidden;scrollbar-gutter:stable;flex:1;min-width:0;height:100%}.photo-folder-tab{display:inline-flex;align-items:center;height:100%;gap:6px;padding:2px 4px;border-radius:5px;border:1px solid transparent;background:#ffffff14;color:#e5e7eb;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s ease,border-color .2s ease,color .2s ease}.photo-folder-tab:hover{background:#ffffff24}.photo-folder-tab.active{background:#00d6d62e;border-color:#00d6d699;color:#e6fcff}.photo-folder-tab-icon{display:inline-flex;color:#fbbf24;flex-shrink:0}.photo-folder-tab-label{max-width:160px;overflow:hidden;text-overflow:ellipsis}.photo-folder-tab-count{color:#e2e8f0b3;font-weight:500}.photos-strip-list{flex:1;overflow-x:auto;overflow-y:hidden;scrollbar-gutter:stable both-edges;min-height:0}.photos-strip-track{display:flex;align-items:stretch;gap:10px;padding:4px 2px 12px;min-height:100%;height:100%;box-sizing:border-box}.layouts-grid::-webkit-scrollbar,.settings-panel::-webkit-scrollbar,.fonts-panel::-webkit-scrollbar{width:8px}.layouts-grid::-webkit-scrollbar-track,.settings-panel::-webkit-scrollbar-track,.fonts-panel::-webkit-scrollbar-track{background:#0f172a59;border-radius:999px}.layouts-grid::-webkit-scrollbar-thumb,.settings-panel::-webkit-scrollbar-thumb,.fonts-panel::-webkit-scrollbar-thumb{background:#94a3b899;border-radius:999px;border:2px solid rgba(15,23,42,.35)}.layouts-grid::-webkit-scrollbar-thumb:hover,.settings-panel::-webkit-scrollbar-thumb:hover,.fonts-panel::-webkit-scrollbar-thumb:hover{background:#e2e8f0b3}.layouts-grid,.settings-panel,.fonts-panel{scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.6) rgba(15,23,42,.35)}.photo-folder-tabs::-webkit-scrollbar,.photos-strip-list::-webkit-scrollbar{height:8px}.photo-folder-tabs::-webkit-scrollbar-track,.photos-strip-list::-webkit-scrollbar-track{background:#0f172a59;border-radius:999px}.photo-folder-tabs::-webkit-scrollbar-thumb,.photos-strip-list::-webkit-scrollbar-thumb{background:#94a3b899;border-radius:999px;border:2px solid rgba(15,23,42,.35)}.photo-folder-tabs::-webkit-scrollbar-thumb:hover,.photos-strip-list::-webkit-scrollbar-thumb:hover{background:#e2e8f0b3}.photo-folder-tabs,.photos-strip-list{scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.6) rgba(15,23,42,.35)}.photo-item{position:relative;flex:0 0 auto;height:100%;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000004d;cursor:move;-webkit-user-select:none;user-select:none;box-sizing:border-box;display:flex;align-items:center;justify-content:center}.photo-item:active{cursor:grabbing}.photo-thumb{height:100%;width:auto;max-width:none;max-height:100%;object-fit:contain;display:block}.photo-index{position:absolute;top:6px;left:6px;z-index:2;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#000000b3;color:#fff;font-size:11px;font-weight:600;line-height:22px;text-align:center;pointer-events:none}.photo-used{position:absolute;top:6px;right:6px;z-index:2;width:22px;height:22px;border-radius:50%;background:#22c55ee6;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000004d;pointer-events:none}.photo-name{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:18px 8px 6px;background:linear-gradient(transparent,#000000bf);color:#fff;font-size:11px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.photo-actions{position:absolute;bottom:0;left:0;right:0;z-index:3;display:flex;gap:4px;padding:6px;background:linear-gradient(transparent,#000c);opacity:0;transition:opacity .2s ease}.photo-item:hover .photo-actions{opacity:1}.photo-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:background .2s ease}.photo-action-btn:hover{background:#ffffff4d}.photo-action-btn--delete:hover{background:#e53935}.preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preview-content{position:relative;max-width:92vw;max-height:90vh;display:grid;grid-template-columns:minmax(0,1fr) 260px;align-items:start;gap:18px}.preview-image{max-width:100%;max-height:calc(90vh - 60px);object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #00000080;display:block}.preview-visual{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:100%}.preview-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059;color:#fff;font-size:12px;border-radius:8px}.preview-close{position:absolute;top:-40px;right:-40px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .2s ease}.preview-close:hover{background:#fff3}.preview-info{margin-top:16px;padding:8px 16px;background:#ffffff1a;border-radius:6px;color:#fff;font-size:13px}.preview-editor{background:#1f2937f2;border-radius:12px;padding:16px;width:260px;color:#e5e7eb;display:flex;flex-direction:column;gap:12px;box-shadow:0 16px 40px #0006}.preview-editor-title{font-size:14px;font-weight:600;color:#f8fafc}.preview-editor-controls{display:grid;gap:12px}.preview-slider{display:grid;grid-template-columns:1fr;gap:6px;font-size:12px;color:#e2e8f0e6}.preview-slider input[type=range]{width:100%}.preview-slider-value{font-size:11px;color:#94a3b8e6;justify-self:end}.preview-editor-actions{display:flex;justify-content:space-between;gap:10px}.preview-btn-ghost,.preview-btn-primary{padding:8px 12px;border-radius:8px;border:none;font-size:12px;cursor:pointer}.preview-btn-ghost{background:#94a3b826;color:#e5e7eb}.preview-btn-primary{background:#22d3ee;color:#0f172a;font-weight:600}@media (max-width: 760px){.preview-content{grid-template-columns:1fr;max-height:92vh}.preview-editor{width:100%}}.auto-fill-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#050a14b3;display:flex;align-items:center;justify-content:center;z-index:9998;animation:fadeIn .2s ease}.auto-fill-card{width:min(420px,90vw);background:#1f2937;border-radius:14px;padding:20px;color:#e5e7eb;box-shadow:0 20px 60px #0006;display:grid;gap:14px}.auto-fill-title{font-size:16px;font-weight:600;color:#f8fafc}.auto-fill-description{font-size:12px;color:#e2e8f0cc;line-height:1.4}.auto-fill-options{display:grid;gap:10px}.auto-fill-option{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:#94a3b81f;cursor:pointer;font-size:13px;color:#e2e8f0}.auto-fill-option input{accent-color:#22d3ee}.download-option{width:100%;border:none;justify-content:flex-start;text-align:left}.download-option:disabled{opacity:.5;cursor:not-allowed}.auto-fill-warning{font-size:12px;color:#fca5a5}.auto-fill-actions{display:flex;justify-content:flex-end;gap:10px}.recent-projects-list{display:flex;flex-direction:column;gap:10px;margin-top:12px;max-height:320px;overflow-y:auto;padding-right:4px}.recent-project-row{border:1px solid rgba(148,163,184,.2);border-radius:10px;background:#94a3b814;padding:10px 12px;text-align:left;color:#e2e8f0;cursor:pointer}.recent-project-row:hover{background:#22d3ee26;border-color:#22d3ee80}.recent-project-main{display:flex;flex-direction:column;gap:4px}.recent-project-name{font-size:13px;font-weight:600;color:#f8fafc}.recent-project-meta{font-size:12px;color:#94a3b8;word-break:break-all}.recent-projects-empty{margin:14px 0 6px;font-size:12px;color:#94a3b8}.auto-fill-btn-ghost,.auto-fill-btn-primary{padding:8px 14px;border-radius:8px;border:none;font-size:12px;cursor:pointer}.auto-fill-btn-ghost{background:#94a3b826;color:#e5e7eb}.auto-fill-btn-primary{background:#22d3ee;color:#0f172a;font-weight:600}.auto-fill-btn-primary:disabled{opacity:.5;cursor:not-allowed}.export-progress-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000}.global-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05090fdb;display:flex;align-items:center;justify-content:center;z-index:11000}.global-loading-card{background:#0f172ae6;border:1px solid rgba(148,163,184,.3);border-radius:16px;padding:28px 32px;display:flex;flex-direction:column;align-items:center;gap:16px;color:#e2e8f0;box-shadow:0 24px 60px #00000059}.global-loading-text{font-size:13px;font-weight:600;color:#e2e8f0;letter-spacing:.02em}.export-progress-modal{background:#2d2d2d;border-radius:12px;padding:32px}.export-progress-content{display:flex;flex-direction:column;align-items:center;gap:16px}.export-spinner{width:60px;height:60px;animation:rotate 2s linear infinite}.export-spinner .path{stroke:#00d6d6;stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.export-progress-text{font-size:18px;font-weight:600;color:#fff}.export-progress-bar{width:300px;height:8px;background:#1a1a1a;border-radius:4px;overflow:hidden}.export-progress-fill{height:100%;background:linear-gradient(90deg,#00d6d6,#00a8a8);border-radius:4px;transition:width .3s ease}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}
