:root{--app-header-base-height:64px;--app-footer-base-height:56px;--app-header-height:var(--app-header-base-height);--app-footer-height:var(--app-footer-base-height);--app-content-gap:clamp(12px, 2.4vmin, 24px);--app-content-gap-mobile:clamp(8px, 1.8vmin, 16px);--app-shell-inline-gap:clamp(12px, 2vw, 24px);--theme-primary:#9f8c7b;--theme-primary-rgb:159 140 123;color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fb;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:#f5f7fb;margin:0;overflow:hidden}#root{height:100vh;overflow:hidden}.app-root{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{z-index:100;background:#fff;border-bottom:1px solid #e5e7eb;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 20px #0f172a0f}.app-shell{width:min(1520px, calc(100% - (var(--app-shell-inline-gap) * 2)));margin:0 auto}.app-header-inner{min-height:var(--app-header-base-height);padding:0 var(--app-shell-inline-gap);justify-content:space-between;align-items:center;gap:16px;min-width:0;display:flex}.app-title{flex:none;margin:0}.app-header-main{flex:auto;align-items:center;gap:24px;min-width:0;display:flex}.app-header-nav{border-bottom:none;flex:auto;min-width:0}.app-header-nav.ant-menu{min-width:0}.app-header-nav.ant-menu-horizontal{min-width:0;line-height:calc(var(--app-header-base-height) - 1px)}.app-header-settings-trigger{justify-content:center;align-items:center;display:inline-flex}.app-header-settings-menu .ant-dropdown-menu{border-radius:12px;min-width:180px;box-shadow:0 12px 32px #0f172a1f}.app-header-settings-theme-grid{grid-template-columns:repeat(5,20px);gap:8px;padding:2px 0;display:grid}.app-header-settings-theme-swatch{cursor:pointer;border:1px solid #0f172a1a;border-radius:999px;width:20px;height:20px;transition:transform .18s,box-shadow .18s,border-color .18s}.app-header-settings-theme-swatch:hover{transform:scale(1.08)}.app-header-settings-theme-swatch.is-active{border-color:var(--theme-primary);box-shadow:0 0 0 2px rgb(var(--theme-primary-rgb) / 18%)}.app-content{height:100vh;padding:calc(var(--app-header-height) + var(--app-content-gap)) var(--app-content-gap) calc(var(--app-footer-height) + var(--app-content-gap));flex:1;min-height:0;display:flex;overflow:hidden}.app-content-inner{flex:1;height:100%;min-height:0;display:flex}.app-footer{z-index:100;text-align:center;padding:0 var(--app-shell-inline-gap);background:#fff;border-top:1px solid #e5e7eb;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0f172a0f}.app-footer-inner{min-height:var(--app-footer-base-height);justify-content:center;align-items:center;display:flex}.page{max-width:1200px;margin:0 auto}.page-home{flex:1;align-items:flex-start;width:100%;max-width:1520px;height:100%;min-height:0;margin:0 auto;display:flex;overflow:auto}.page-grid{grid-template-columns:1fr 2fr 1fr;gap:16px;display:grid}.page-home .page-grid{grid-template-columns:minmax(0,1fr) minmax(380px,500px);align-items:start;width:100%;height:100%;min-height:100%;overflow:visible}.panel{min-height:320px}.canvas-panel{min-height:520px}.image-card .ant-card-body{padding:10px}.image-thumb{object-fit:contain;background:#f3f4f6;border-radius:8px;width:100%;height:96px}.image-card{-webkit-user-select:none;user-select:none}.bbox-page{max-width:1440px}.bbox-preview-card .ant-card-body{height:100%}.bbox-legend{flex-wrap:wrap;gap:12px;display:flex}.bbox-legend-item{color:#4b5563;align-items:center;gap:8px;display:inline-flex}.bbox-legend-swatch{border:2px solid #0000;border-radius:4px;width:14px;height:14px}.bbox-legend-swatch--group{background:#f59e0b29;border-color:#f59e0b}.bbox-legend-swatch--padded{background:#ef444429;border-color:#ef4444}.bbox-legend-swatch--tight{background:#22c55e29;border-color:#22c55e}.bbox-image-stage{background-color:#eef2f7;background-image:linear-gradient(45deg,#f8fafc 25%,#0000 25%),linear-gradient(-45deg,#f8fafc 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#f8fafc 75%),linear-gradient(-45deg,#0000 75%,#f8fafc 75%);background-position:0 0,0 12px,12px -12px,-12px 0;background-repeat:repeat,repeat,repeat,repeat;background-size:24px 24px;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:360px;display:flex;position:relative;overflow:hidden}.bbox-image{object-fit:contain;max-width:100%;max-height:70vh;display:block}.bbox-box{pointer-events:none;border:2px solid #0000;position:absolute;box-shadow:inset 0 0 0 1px #ffffff8c}.bbox-box--active{z-index:2}.bbox-box--group{background:#f59e0b1a;border-color:#f59e0b}.bbox-box--padded{background:#ef44441a;border-color:#ef4444}.bbox-box--tight{background:#22c55e1a;border-color:#22c55e}.bbox-result-image{object-fit:contain;background:#f8fafc;border-radius:12px;width:100%;max-height:360px;display:block}.bbox-json-block{color:#e2e8f0;background:#0f172a;border-radius:8px;max-height:320px;margin:0;padding:12px;font-size:12px;line-height:1.6;overflow:auto}.bbox-table-row-active>td{background:#eff6ff!important}@media (width<=1280px){.app-shell{width:min(1360px,100%)}}@media (width<=720px){.page-home .page-grid{grid-template-columns:1fr}.home-library-panel,.home-canvas-panel{height:auto;min-height:480px}.home-canvas-panel{position:static}}@media (width<=1024px){.app-content{padding:calc(var(--app-header-height) + var(--app-content-gap-mobile)) var(--app-content-gap-mobile) calc(var(--app-footer-height) + var(--app-content-gap-mobile))}.page-grid{grid-template-columns:1fr}.page-home .page-grid{grid-template-columns:minmax(0,1fr) minmax(260px,38vw)}.home-canvas-scroll-area{overflow-y:auto}.canvas-pages-stack>*,.canvas-wysiwyg-shell{min-height:0}.canvas-wysiwyg-toolbar{border-radius:20px;align-self:stretch}.canvas-wysiwyg-toolbar__divider{display:none}.bbox-image-stage{min-height:240px}}.masonry-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));align-items:start;gap:8px;display:grid}.library-gallery__items{min-width:0}.library-gallery__items--uniform{grid-template-columns:repeat(auto-fill,148px);justify-content:start;align-items:stretch;gap:10px;display:grid}.masonry-item{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.masonry-item:hover{border-color:var(--theme-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.masonry-item img{object-fit:cover;background:#fff;width:100%;height:auto;display:block}.library-gallery__items--uniform .masonry-item{aspect-ratio:1;justify-content:center;align-items:center;width:148px;min-height:148px;padding:8px;display:flex}.library-gallery__items--uniform .masonry-item img{object-fit:contain;width:auto;max-width:100%;max-height:132px}.masonry-item.has-actions{cursor:default}.masonry-item__actions{z-index:2;position:absolute;top:8px;right:8px}.masonry-item__delete-button{color:#fff;cursor:pointer;background:#0f172ab8;border:none;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:inline-flex}.masonry-item__delete-button:disabled{cursor:not-allowed;opacity:.55}.masonry-item__delete-button:hover{background:#dc2626e6}.masonry-item--editing{cursor:grab}.masonry-item--editing.is-dragging{opacity:.58;transform:scale(.98)}.masonry-item--editing.is-drag-over{box-shadow:0 0 0 2px rgb(var(--theme-primary-rgb) / 24%);border-color:var(--theme-primary)}.masonry-item__size-badge{color:#fff;text-align:center;opacity:0;pointer-events:none;background:#0f172ac2;border-radius:8px;padding:6px 8px;font-size:11px;line-height:1.35;transition:opacity .2s,transform .2s;position:absolute;bottom:8px;left:8px;right:8px;transform:translateY(4px)}.library-gallery__items--uniform .masonry-item:hover .masonry-item__size-badge{opacity:1;transform:translateY(0)}.library-context-menu{z-index:1200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;border:1px solid #dbeafe;border-radius:12px;width:176px;padding:8px;position:fixed;box-shadow:0 18px 48px #0f172a29}.library-context-menu__item{color:#1f2937;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;width:100%;margin-top:4px;padding:7px 9px;transition:background-color .2s,color .2s}.library-context-menu__item:hover{color:var(--theme-primary);background:#eff6ff}.official-gallery-container{width:100%}.official-gallery-container::-webkit-scrollbar{display:none}.official-gallery-scroll-area{flex-direction:column;flex:auto;gap:24px;min-width:0;padding-bottom:8px;display:flex}.library-gallery{width:100%}.library-gallery--indexed{align-items:flex-start;gap:16px;display:flex}.library-gallery__index{flex-direction:column;flex:0 0 76px;gap:6px;display:flex;position:sticky;top:0}.library-gallery__index-button{width:100%;color:rgb(var(--theme-primary-rgb) / 56%);text-align:left;cursor:pointer;transform-origin:0;opacity:.72;background:0 0;border:none;border-radius:0;padding:4px 0;font-size:11px;font-weight:600;transition:transform .18s,color .18s,opacity .18s}.library-gallery__index-button:hover{color:var(--theme-primary);opacity:1;transform:scale(1.08)}.official-gallery-section{scroll-snap-align:start;scroll-margin-top:0}.library-gallery__section-header{background:0 0;border:none;border-bottom:1px solid #e5e7eb;border-radius:0;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:4px 0 10px;display:flex}.library-gallery__section-main{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;display:flex}.library-gallery__section-name{color:#0f172a;font-size:18px;font-weight:700;line-height:1.3}.library-gallery__section-count{color:#64748b;background:#f1f5f9;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600}.library-gallery__section-actions{align-items:center;gap:4px;display:flex}.home-library-panel,.home-canvas-panel{height:calc(100dvh - var(--app-header-height) - var(--app-footer-height) - (var(--app-content-gap) * 2));flex-direction:column;min-height:0;display:flex;overflow:hidden}.home-canvas-panel{position:sticky;top:0}.home-library-panel .ant-card-body,.home-canvas-panel .ant-card-body{flex-direction:column;flex:auto;min-height:0;display:flex}.home-canvas-panel .ant-card-body{overflow-y:auto}.home-library-tabs,.home-library-tabs .ant-tabs-content-holder,.home-library-tabs .ant-tabs-content,.home-library-tabs .ant-tabs-tabpane{height:100%;min-height:0}.home-library-tabs{flex-direction:column;min-height:0;display:flex}.home-library-tabs .ant-tabs-nav{margin-bottom:12px}.home-library-tabs .ant-tabs-nav-wrap,.home-library-tabs .ant-tabs-extra-content{align-items:center;display:flex}.home-library-tabs .ant-tabs-content-holder{scroll-snap-type:y mandatory;scroll-behavior:smooth;scrollbar-width:thin;overflow:hidden auto}.home-library-pane,.home-library-tabs .ant-tabs-tabpane>.ant-space,.home-canvas-content{flex:1;min-height:0}.home-library-pane{flex-direction:column;gap:12px;display:flex}.home-library-page-action{align-items:center;display:flex}.library-import-modal__section{flex-direction:column;gap:12px;display:flex}.library-import-modal__layout{align-items:flex-start;gap:20px;display:flex}.library-import-modal__section--generated{flex:0 0 40%;min-width:0}.library-import-modal__section--cut{flex:60%;min-width:0}.library-import-modal__section--generated-only{flex:100%}.library-import-modal__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.library-import-modal__toolbar-group{flex-wrap:wrap;gap:8px;display:flex}.library-import-modal__generated-item{position:relative}.library-import-modal__generated-delete{z-index:2;color:#fff;cursor:pointer;background:#0f172ab8;border:none;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex;position:absolute;top:8px;right:8px}.library-import-modal__generated-delete:hover{background:#dc2626e6}.library-import-modal__loading{background:#0f172a3d;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.home-canvas-content{flex-direction:column;gap:12px;display:flex;overflow:hidden auto}.home-canvas-meta{background:#f8fafce0;border:1px solid #e2e8f0;border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:10px 14px;display:flex}.home-canvas-meta__current{color:#334155;font-size:14px}.home-canvas-meta__summary{text-align:right;margin-inline-start:auto;font-size:13px}.home-canvas-panel-header{justify-content:space-between;align-items:flex-start;gap:16px;width:100%;display:flex}.home-canvas-panel-header__title{color:#101828;white-space:nowrap;font-size:16px;font-weight:600;line-height:32px}.home-canvas-panel-header__actions{flex:1;justify-content:flex-end;align-items:center;gap:12px;min-width:0;display:flex}.home-canvas-panel-header__restore{flex:320px;min-width:220px;max-width:480px}.home-canvas-panel-header__restore .ant-input-search{width:100%}.home-canvas-panel-header__primary{flex-wrap:wrap;flex:none;justify-content:flex-end;align-items:center;gap:8px;display:flex}.home-canvas-note{display:block}.home-canvas-scroll-area{scroll-snap-type:x mandatory;scroll-behavior:smooth;flex-direction:row;flex:1;align-items:stretch;height:auto;min-height:0;display:flex;overflow:auto hidden}.canvas-pages-stack{flex-direction:row;gap:20px;min-width:100%;height:100%;min-height:100%;display:flex}.canvas-pages-stack>*{scroll-snap-align:center;flex:0 0 100%;width:100%;max-width:100%;min-height:0;display:flex}.home-canvas-page{background:0 0;border:1px solid #0000;border-radius:18px;min-height:0;padding:clamp(4px,.8vmin,8px) clamp(4px,.8vmin,8px) clamp(8px,1.2vmin,12px);transition:color .24s,opacity .24s;position:relative}.home-canvas-page.is-active-page{box-shadow:none;background:0 0;border-color:#0000;transform:none}.canvas-wysiwyg-shell{flex-direction:column;flex:1;gap:clamp(8px,1.4vmin,14px);width:100%;min-height:0;display:flex}.canvas-wysiwyg-wrapper{box-sizing:border-box;background-color:#f8fafc;background-image:linear-gradient(45deg,#eef2f7 25%,#0000 25%),linear-gradient(-45deg,#eef2f7 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#eef2f7 75%),linear-gradient(-45deg,#0000 75%,#eef2f7 75%);background-position:0 0,0 14px,14px -14px,-14px 0;background-repeat:repeat,repeat,repeat,repeat;background-size:28px 28px;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;border:1px solid #0000;border-radius:clamp(10px,1.5vmin,12px);flex:1;justify-content:center;align-items:center;width:100%;min-height:0;padding:clamp(10px,1.8vmin,16px);transition:border-color .24s,box-shadow .24s,background-color .24s;display:flex;position:relative;overflow:hidden}.home-canvas-page.is-active-page .canvas-wysiwyg-wrapper{box-shadow:none;background-color:#f8fafc;border-color:#0000}.canvas-wysiwyg-toolbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);opacity:.72;background:#ffffffad;border:1px solid #94a3b83d;border-radius:999px;flex-wrap:wrap;justify-content:center;align-self:center;align-items:center;gap:clamp(4px,1vmin,8px);max-width:100%;padding:clamp(6px,1vmin,8px);transition:opacity .2s,background-color .2s,box-shadow .2s,transform .2s;display:inline-flex;box-shadow:0 10px 28px #0f172a1a}.canvas-wysiwyg-toolbar:hover,.canvas-wysiwyg-toolbar:focus-within{opacity:1;background:#ffffffeb;transform:translateY(-1px);box-shadow:0 14px 32px #0f172a24}.canvas-wysiwyg-toolbar__group{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;display:inline-flex}.canvas-wysiwyg-toolbar__button{border-radius:999px}.canvas-wysiwyg-toolbar__divider{background:#94a3b857;flex:none;width:1px;height:22px}.canvas-wysiwyg-board{background:#fff;border-radius:14px;position:relative;overflow:hidden;box-shadow:0 12px 28px #0f172a24}.canvas-wysiwyg-safe-area{border:1px solid #dbeafe;position:absolute;inset:0}.canvas-wysiwyg-placement{background:#f8fafceb;border:1px dashed #cbd5e1;border-radius:10px;justify-content:center;align-items:center;display:flex;position:absolute;overflow:hidden}.canvas-wysiwyg-placement--manual{cursor:grab}.canvas-wysiwyg-placement--manual.is-dragging{cursor:grabbing;z-index:2;box-shadow:0 8px 24px #3b82f640}.canvas-wysiwyg-placement img{object-fit:contain;pointer-events:none;width:100%;height:100%}.canvas-wysiwyg-cell-remove{cursor:pointer;color:#ff4d4f;opacity:0;background:#fffc;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:opacity .2s;display:flex;position:absolute;top:6px;right:6px}.canvas-wysiwyg-placement:hover .canvas-wysiwyg-cell-remove{opacity:1}.canvas-wysiwyg-cell-remove:hover{color:#fff;background:#ff4d4f}.home-canvas-pagination-slot{justify-content:center;align-items:center;min-height:26px;display:flex}.home-canvas-pagination{justify-content:center;gap:10px;padding:8px 0;display:flex}.home-canvas-pagination__dot{cursor:pointer;background:#d0d5dd;border:none;border-radius:999px;width:10px;height:10px;padding:0;transition:transform .24s,background-color .24s,box-shadow .24s}.home-canvas-pagination__dot.is-active-page{background:#1677ff;transform:scale(1.25);box-shadow:0 0 0 4px #1677ff24}@media (width<=1200px){.home-canvas-meta{align-items:flex-start}.home-canvas-meta__summary{text-align:left;margin-inline-start:0}.home-canvas-panel-header{flex-direction:column;align-items:stretch}.home-canvas-panel-header__actions,.home-canvas-panel-header__primary{justify-content:flex-start;align-items:flex-start}.home-canvas-panel-header__restore{max-width:none}}
